/* Sections B — scoped */

/* === fmt === */
.s-fmt ::selection{ background: var(--ochre); color: var(--white-bright); }
.s-fmt .wrap{
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 0 var(--gutter);
  }
.s-fmt .fmt{
    position: relative;
    color: var(--on-dark);
    padding: clamp(96px, 11vw, 168px) 0 clamp(96px, 11vw, 168px);
    overflow: hidden;
    isolation: isolate;
    background: var(--ink-deep);
  }
.s-fmt .fmt::before{
    content: "";
    position: absolute;
    inset: 0;
    z-index: -2;
    background:
      linear-gradient(180deg, rgba(16,14,12,0.92) 0%, rgba(16,14,12,0.86) 40%, rgba(16,14,12,0.94) 100%),
      url("media/formats-bg.jpg") center / cover no-repeat;
    filter: saturate(0.55);
  }
.s-fmt .fmt::after{
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
      repeating-linear-gradient(
        0deg,
        transparent 0,
        transparent 47px,
        rgba(241, 236, 227, 0.025) 47px,
        rgba(241, 236, 227, 0.025) 48px
      ),
      radial-gradient(120% 80% at 50% 0%, rgba(16,14,12,0) 0%, rgba(16,14,12,0.55) 70%);
  }
.s-fmt .fmt-id{
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 24px;
    flex-wrap: wrap;
    padding-bottom: clamp(40px, 5vw, 64px);
    border-bottom: 1px solid var(--on-dark-rule);
    margin-bottom: clamp(48px, 6vw, 80px);
  }
.s-fmt .eyebrow{
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--on-dark-soft);
    display: inline-flex;
    align-items: center;
    gap: 14px;
  }
.s-fmt .eyebrow::before{
    content: "";
    width: 36px; height: 1px;
    background: var(--ochre);
    display: inline-block;
  }
.s-fmt .fmt-id .meta{
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.14em;
    color: var(--on-dark-mute);
    text-transform: uppercase;
  }
.s-fmt .fmt-id .meta b{ color: var(--on-dark); font-weight: 500; }
.s-fmt .fmt-head{
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(24px, 4vw, 64px);
    align-items: end;
    margin-bottom: clamp(64px, 8vw, 112px);
  }
@media (min-width: 900px) {.s-fmt .fmt-head{ grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr); }
}
.s-fmt .fmt-headline{
    font-family: var(--font-display);
    font-weight: 300;
    font-size: clamp(48px, 7vw, 120px);
    line-height: 0.96;
    letter-spacing: -0.015em;
    text-transform: none;
    margin: 0;
    color: var(--on-dark);
    text-wrap: balance;
    max-width: 12ch;
  }
.s-fmt .fmt-headline em{
    font-style: normal;
    color: var(--ochre);
    font-weight: 400;
  }
.s-fmt .fmt-intro{
    font-family: var(--font-body);
    font-size: 14px;
    line-height: 1.65;
    color: var(--on-dark-soft);
    max-width: 38ch;
    border-left: 1px solid var(--on-dark-rule-strong);
    padding-left: 24px;
  }
.s-fmt .fmt-intro b{
    color: var(--on-dark);
    font-weight: 500;
    display: block;
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    margin-bottom: 10px;
  }
.s-fmt .fmt-grid{
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(24px, 2.6vw, 36px);
    align-items: stretch;
  }
@media (min-width: 880px) {.s-fmt .fmt-grid{
      grid-template-columns: repeat(3, 1fr);
      gap: clamp(20px, 2vw, 32px);
      padding: 28px 0; 
    }
}
.s-fmt .card{
    position: relative;
    background: rgba(241, 236, 227, 0.025);
    border: 1px solid rgba(241, 236, 227, 0.13);
    padding: clamp(32px, 2.6vw, 44px) clamp(28px, 2.2vw, 38px) clamp(32px, 2.6vw, 44px);
    display: flex;
    flex-direction: column;
    gap: clamp(20px, 1.6vw, 26px);
    transition: background 280ms ease, border-color 280ms ease, transform 280ms ease;
  }
@media (hover: hover) {.s-fmt .card:hover{
      background: rgba(241, 236, 227, 0.045);
      border-color: rgba(241, 236, 227, 0.22);
    }
}
.s-fmt .card.is-rec{
    background: rgba(241, 236, 227, 0.05);
    border-color: rgba(241, 236, 227, 0.22);
  }
.s-fmt .card.is-rec::before{
    content: "";
    position: absolute;
    top: -1px; left: -1px; right: -1px;
    height: 3px;
    background: var(--ochre);
  }
@media (min-width: 880px) {.s-fmt .card.is-rec{ transform: scale(1.05); z-index: 2; }
@media (hover: hover) {.s-fmt .card.is-rec:hover{ transform: scale(1.05) translateY(-2px); }
.s-fmt .card:not(.is-rec):hover{ transform: translateY(-3px); }
}
}
.s-fmt .rec-tag{
    position: absolute;
    top: clamp(20px, 1.6vw, 26px);
    right: clamp(28px, 2.2vw, 38px);
    font-family: var(--font-mono);
    font-weight: 500;
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ochre);
  }
.s-fmt .card-top{
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: clamp(8px, 1vw, 14px);
  }
.s-fmt .card-icon{
    width: clamp(48px, 4vw, 64px);
    height: clamp(48px, 4vw, 64px);
    color: var(--on-dark);
    stroke: currentColor;
    fill: none;
    stroke-width: 1.1;
    stroke-linecap: round;
    stroke-linejoin: round;
    display: block;
  }
.s-fmt .card.is-rec .card-icon{ color: var(--ochre); }
.s-fmt .card-idx{
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--on-dark-mute);
  }
.s-fmt .card-idx b{ color: var(--on-dark); font-weight: 500; }
.s-fmt .card-title{
    font-family: var(--font-display);
    font-weight: 400;
    font-size: clamp(28px, 2.4vw, 38px);
    line-height: 1.02;
    letter-spacing: 0.005em;
    text-transform: none;
    color: var(--on-dark);
    margin: 0;
    text-wrap: balance;
  }
.s-fmt .card-dur{
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--on-dark-soft);
    margin: 0;
  }
.s-fmt .card-dur::before{
    content: "";
    display: inline-block;
    width: 18px; height: 1px;
    background: var(--on-dark-rule-strong);
    vertical-align: middle;
    margin-right: 12px;
    transform: translateY(-2px);
  }
.s-fmt .card.is-rec .card-dur::before{ background: var(--ochre); }
.s-fmt .card-body{
    font-family: var(--font-body);
    font-weight: 400;
    font-size: 14.5px;
    line-height: 1.65;
    color: var(--on-dark-soft);
    margin: 0;
    text-wrap: pretty;
    flex: 1;
  }
.s-fmt .card-body b{ color: var(--on-dark); font-weight: 500; }
.s-fmt .card-price{
    margin-top: clamp(8px, 1.4vw, 18px);
    padding-top: clamp(20px, 1.8vw, 28px);
    border-top: 1px solid var(--on-dark-rule);
    display: flex;
    flex-direction: column;
    gap: 4px;
  }
.s-fmt .card-price .label{
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--on-dark-mute);
  }
.s-fmt .card-price .value{
    font-family: var(--font-display);
    font-weight: 400;
    font-size: clamp(22px, 1.8vw, 28px);
    letter-spacing: 0.005em;
    color: var(--on-dark);
  }
.s-fmt .card.is-rec .card-price .value{ color: var(--ochre); }
.s-fmt .card-cta{
    display: inline-flex;
    align-items: center;
    gap: 14px;
    margin-top: clamp(20px, 1.8vw, 28px);
    font-family: var(--font-body);
    font-weight: 500;
    font-size: 13px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--on-dark);
    text-decoration: none;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--on-dark-rule-strong);
    align-self: flex-start;
    transition: color 200ms ease, border-color 200ms ease;
  }
.s-fmt .card-cta svg{
    width: 22px; height: 10px;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.4;
    transition: transform 220ms ease;
  }
.s-fmt .card-cta:hover{
    color: var(--ochre);
    border-bottom-color: var(--ochre);
  }
.s-fmt .card-cta:hover svg{ transform: translateX(4px); }
.s-fmt .card.is-rec .card-cta{
    color: var(--ochre);
    border-bottom-color: var(--ochre);
  }
.s-fmt .fmt-foot{
    margin-top: clamp(64px, 7vw, 104px);
    padding-top: 22px;
    border-top: 1px solid var(--on-dark-rule);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--on-dark-mute);
    display: flex;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
  }
.s-fmt .fmt-foot b{ color: var(--on-dark); font-weight: 500; }
.s-fmt .fmt-foot .dot{
    width: 5px; height: 5px;
    background: var(--ochre);
    border-radius: 50%;
    display: inline-block;
    vertical-align: middle;
    margin-right: 10px;
  }
@media (max-width: 879px) {.s-fmt .card.is-rec{ order: -1; }
}

/* === dst === */
.s-dst ::selection{ background: var(--ochre); color: var(--white-bright); }
.s-dst .wrap{
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 0 var(--gutter);
  }
.s-dst .destinations{
    padding: clamp(96px, 11vw, 168px) 0 clamp(96px, 11vw, 168px);
    position: relative;
  }
.s-dst .dst-id{
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 24px;
    flex-wrap: wrap;
    padding-bottom: 28px;
    margin-bottom: clamp(48px, 6vw, 96px);
    border-bottom: 1px solid var(--stone-light);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--stone);
  }
.s-dst .dst-id .id-left{
    display: inline-flex;
    align-items: center;
    gap: 14px;
    color: var(--stone);
  }
.s-dst .dst-id .id-left::before{
    content: "";
    width: 32px; height: 1px;
    background: var(--ochre);
    display: inline-block;
  }
.s-dst .dst-id .id-right{ display: flex; gap: 28px; }
.s-dst .dst-id .id-right b{ color: var(--ink); font-weight: 500; }
.s-dst .dst-head{
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(28px, 4vw, 56px);
    margin-bottom: clamp(56px, 7vw, 96px);
  }
@media (min-width: 920px) {.s-dst .dst-head{
      grid-template-columns: 1.45fr 1fr;
      align-items: end;
      gap: 72px;
    }
}
.s-dst .dst-headline{
    font-family: var(--font-display);
    font-weight: 300;
    text-transform: uppercase;
    font-size: clamp(44px, 6.8vw, 104px);
    line-height: 0.93;
    letter-spacing: -0.012em;
    margin: 0;
    color: var(--ink);
    text-wrap: balance;
  }
.s-dst .dst-headline em{
    font-style: normal;
    color: var(--ochre);
    font-weight: 300;
  }
.s-dst .dst-sub{
    font-size: 16px;
    line-height: 1.6;
    color: var(--ink-soft);
    margin: 0;
    max-width: 44ch;
  }
.s-dst .map-frame{
    position: relative;
    padding: clamp(24px, 4vw, 56px) 0;
    margin-bottom: clamp(64px, 8vw, 112px);
  }
.s-dst .map-frame::before, .s-dst .map-frame::after{
    content: "";
    position: absolute;
    left: 0; right: 0;
    height: 1px;
    background: var(--stone-light);
  }
.s-dst .map-frame::before{ top: 0; }
.s-dst .map-frame::after{ bottom: 0; }
.s-dst .map-corners{
    position: absolute;
    top: 12px;
    left: 0; right: 0;
    display: flex;
    justify-content: space-between;
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--stone);
    pointer-events: none;
  }
.s-dst .map-corners .right{ color: var(--ink); }
.s-dst .map-svg{
    display: block;
    width: 100%;
    height: auto;
    margin-top: 22px;
    overflow: visible;
  }
.s-dst .country-outline{
    fill: none;
    stroke: var(--ink);
    stroke-width: 1.4;
    stroke-linejoin: round;
    stroke-linecap: round;
    vector-effect: non-scaling-stroke;
  }
.s-dst .country-fill{
    fill: var(--paper-soft);
    opacity: 0.55;
  }
.s-dst .graticule{
    stroke: var(--stone-light);
    stroke-width: 0.5;
    opacity: 0.55;
    stroke-dasharray: 2 4;
    vector-effect: non-scaling-stroke;
  }
.s-dst .city{ fill: var(--stone); }
.s-dst .city-label{
    font-family: var(--font-mono);
    font-size: 9px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    fill: var(--stone);
  }
.s-dst .region{
    cursor: pointer;
    transition: opacity 220ms ease;
  }
.s-dst .region .pin-ring{
    fill: none;
    stroke: var(--ochre);
    stroke-width: 1.2;
    vector-effect: non-scaling-stroke;
    transform-origin: center;
    transform-box: fill-box;
    opacity: 0.45;
    transition: r 260ms ease, opacity 260ms ease, stroke-width 260ms ease;
  }
.s-dst .region .pin-dot{
    fill: var(--ochre);
    transition: r 220ms ease;
  }
.s-dst .region .pin-cross{
    stroke: var(--ochre);
    stroke-width: 1.2;
    vector-effect: non-scaling-stroke;
    opacity: 0.65;
  }
.s-dst .region .pin-label{
    font-family: var(--font-display);
    font-weight: 500;
    text-transform: uppercase;
    font-size: 22px;
    letter-spacing: 0.02em;
    fill: var(--ink);
    transition: fill 220ms ease;
  }
.s-dst .region .pin-meta{
    font-family: var(--font-mono);
    font-size: 9.5px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    fill: var(--stone);
  }
.s-dst .region .pin-leader{
    stroke: var(--stone);
    stroke-width: 0.6;
    vector-effect: non-scaling-stroke;
    opacity: 0.55;
  }
.s-dst .region.is-active .pin-dot{ r: 6; }
.s-dst .region.is-active .pin-ring{ opacity: 1; stroke-width: 1.6; }
.s-dst .region.is-active .pin-label{ fill: var(--ochre-deep); }
.s-dst .map-stage.has-active .region:not(.is-active){ opacity: 0.32; }
.s-dst .compass-group{ color: var(--stone); }
.s-dst .compass-group text{
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.14em;
    fill: var(--ink);
  }
.s-dst .cards{
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    background: var(--stone-light);
    border-top: 1px solid var(--stone-light);
    border-bottom: 1px solid var(--stone-light);
  }
@media (min-width: 820px) {.s-dst .cards{
      grid-template-columns: repeat(3, 1fr);
      border-left: 1px solid var(--stone-light);
      border-right: 1px solid var(--stone-light);
    }
}
.s-dst .rcard{
    background: var(--paper);
    padding: 32px 28px 36px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    position: relative;
    cursor: pointer;
    transition: background 280ms ease;
  }
.s-dst .rcard:hover, .s-dst .rcard.is-active{
    background: var(--white-bright);
  }
.s-dst .rcard-head{
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--stone);
  }
.s-dst .rcard-head .idx::before{
    content: "";
    display: inline-block;
    width: 24px;
    height: 1px;
    background: var(--ochre);
    vertical-align: middle;
    margin-right: 10px;
    transition: width 260ms ease, background 260ms ease;
  }
.s-dst .rcard.is-active .rcard-head .idx::before, .s-dst .rcard:hover .rcard-head .idx::before{ width: 56px; background: var(--ochre-deep); }
.s-dst .rcard-img{
    aspect-ratio: 5 / 3;
    background:
      repeating-linear-gradient(
        45deg,
        #D8CFBE 0 2px,
        transparent 2px 14px
      ),
      linear-gradient(135deg, #C9BFAD 0%, #A9A091 100%);
    position: relative;
    display: flex;
    align-items: flex-end;
    padding: 14px;
    margin: 4px 0 2px;
  }
.s-dst .rcard-img.has-photo{
    background: var(--paper-soft);
  }
.s-dst .rcard-img.has-photo img{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
.s-dst .rcard-img .ph-tag{
    font-family: var(--font-mono);
    font-size: 9.5px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--white-bright);
    background: rgba(24,21,18,0.55);
    padding: 4px 7px;
    backdrop-filter: blur(4px);
    position: relative;
    z-index: 2;
  }
.s-dst .rcard-img .ph-coord{
    position: absolute;
    top: 12px; right: 12px;
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.06em;
    color: var(--white-bright);
    text-shadow: 0 1px 2px rgba(0,0,0,0.4);
    z-index: 2;
  }
.s-dst .rcard-title{
    font-family: var(--font-display);
    font-weight: 400;
    text-transform: uppercase;
    font-size: clamp(40px, 4.4vw, 60px);
    line-height: 0.95;
    letter-spacing: -0.005em;
    margin: 6px 0 0;
    color: var(--ink);
  }
.s-dst .rcard-desc{
    font-size: 14.5px;
    line-height: 1.6;
    color: var(--ink-soft);
    margin: 0;
    max-width: 38ch;
  }
.s-dst .rcard-foot{
    margin-top: auto;
    padding-top: 22px;
    border-top: 1px solid var(--stone-light);
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--stone);
  }
.s-dst .rcard-foot b{ color: var(--ink); font-weight: 500; }
.s-dst .dst-foot{
    margin-top: clamp(48px, 6vw, 80px);
    padding-top: 22px;
    border-top: 1px solid var(--stone-light);
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 18px;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--stone);
  }
.s-dst .dst-foot b{ color: var(--ink); font-weight: 500; }
@media (max-width: 720px) {.s-dst .map-corners{ font-size: 9.5px; }
.s-dst .region .pin-label{ font-size: 18px; }
}

/* === already === */
.s-already ::selection{ background: var(--ochre); color: var(--white-bright); }
.s-already .wrap{
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 0 var(--gutter);
  }
.s-already .already{
    padding: clamp(96px, 11vw, 168px) 0 clamp(96px, 11vw, 168px);
    position: relative;
  }
.s-already .id-strip{
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 24px;
    flex-wrap: wrap;
    padding-bottom: 28px;
    margin-bottom: clamp(56px, 7vw, 104px);
    border-bottom: 1px solid var(--stone-light);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--stone);
  }
.s-already .id-strip .id-left{
    display: inline-flex;
    align-items: center;
    gap: 14px;
    color: var(--stone);
  }
.s-already .id-strip .id-left::before{
    content: "";
    width: 32px; height: 1px;
    background: var(--ochre);
    display: inline-block;
  }
.s-already .id-strip .id-right{ display: flex; gap: 28px; flex-wrap: wrap; }
.s-already .id-strip .id-right b{ color: var(--ink); font-weight: 500; }
.s-already .hero{
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(48px, 6vw, 88px);
    align-items: start;
  }
@media (min-width: 920px) {.s-already .hero{ grid-template-columns: 1.05fr 1fr; gap: clamp(56px, 6vw, 96px); }
}
.s-already .col-left{ display: flex; flex-direction: column; gap: clamp(36px, 4vw, 56px); }
.s-already .lede h2{
    font-family: var(--font-display);
    font-weight: 300;
    text-transform: uppercase;
    font-size: clamp(40px, 5.6vw, 88px);
    line-height: 0.94;
    letter-spacing: -0.012em;
    margin: 0;
    color: var(--ink);
    text-wrap: balance;
  }
.s-already .lede h2 em{
    font-style: normal;
    color: var(--ochre);
    font-weight: 300;
  }
.s-already .lede p.subhead{
    font-size: 16px;
    line-height: 1.65;
    color: var(--ink-soft);
    margin: 28px 0 0;
    max-width: 46ch;
  }
.s-already .pull{
    border-top: 1px solid var(--ink);
    padding-top: clamp(32px, 3.5vw, 48px);
    position: relative;
  }
.s-already .pull blockquote{
    margin: 0;
    font-family: var(--font-display);
    font-weight: 300;
    font-style: italic;
    font-size: clamp(22px, 2.6vw, 34px);
    line-height: 1.22;
    letter-spacing: -0.005em;
    color: var(--ink);
    text-wrap: balance;
  }
.s-already .pull blockquote .em-word{
    color: var(--ochre-deep);
    font-style: italic;
  }
.s-already .pull cite{
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 14px;
    margin-top: clamp(22px, 2.4vw, 32px);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--stone);
    font-style: normal;
  }
.s-already .pull cite b{
    color: var(--ink);
    font-weight: 500;
  }
.s-already .pull cite::before{
    content: "";
    display: inline-block;
    width: 36px;
    height: 1px;
    background: var(--ink);
  }
.s-already .carousel-wrap{
    position: relative;
  }
.s-already .car-meta{
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 14px;
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--stone);
  }
.s-already .car-meta b{ color: var(--ink); font-weight: 500; }
.s-already .carousel{
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    background: var(--paper-deeper);
    border: 1px solid var(--stone-light);
  }
@media (min-width: 920px) {.s-already .carousel{ aspect-ratio: 4 / 5; }
}
.s-already .slides{
    position: absolute;
    inset: 0;
    display: flex;
    transition: transform 700ms cubic-bezier(0.65, 0.05, 0.35, 1);
    will-change: transform;
  }
.s-already .slide{
    flex: 0 0 100%;
    position: relative;
  }
.s-already .slide img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
.s-already .slide .caption{
    position: absolute;
    left: 18px;
    bottom: 18px;
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--white-bright);
    background: rgba(24,21,18,0.55);
    padding: 5px 9px;
    backdrop-filter: blur(4px);
  }
.s-already .slide .coord{
    position: absolute;
    top: 18px;
    right: 18px;
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.06em;
    color: var(--white-bright);
    text-shadow: 0 1px 2px rgba(0,0,0,0.5);
  }
.s-already .slide .frame-num{
    position: absolute;
    top: 18px;
    left: 18px;
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--white-bright);
    text-shadow: 0 1px 2px rgba(0,0,0,0.45);
  }
.s-already .car-nav{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border: 0;
    background: rgba(251,248,242,0.82);
    color: var(--ink);
    cursor: pointer;
    display: grid;
    place-items: center;
    transition: background 200ms ease;
    backdrop-filter: blur(6px);
  }
.s-already .car-nav:hover{ background: var(--white-bright); }
.s-already .car-nav.prev{ left: 14px; }
.s-already .car-nav.next{ right: 14px; }
.s-already .car-nav svg{ width: 18px; height: 12px; display: block; }
.s-already .dots{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 12px;
    margin-top: 22px;
  }
.s-already .dot{
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: 1px solid var(--stone);
    background: transparent;
    padding: 0;
    cursor: pointer;
    transition: background 200ms ease, border-color 200ms ease, transform 200ms ease;
  }
.s-already .dot.is-active{
    background: var(--ink);
    border-color: var(--ink);
    transform: scale(1.15);
  }
.s-already .dot:hover{ border-color: var(--ink); }
.s-already .stats{
    margin-top: clamp(88px, 10vw, 144px);
    border-top: 1px solid var(--ink);
    border-bottom: 1px solid var(--ink);
    display: grid;
    grid-template-columns: 1fr;
  }
@media (min-width: 720px) {.s-already .stats{ grid-template-columns: repeat(4, 1fr); }
}
.s-already .stat{
    padding: clamp(32px, 4vw, 56px) clamp(20px, 2.4vw, 36px);
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: relative;
  }
@media (min-width: 720px) {.s-already .stat + .stat::before{
      content: "";
      position: absolute;
      left: 0;
      top: 18%;
      bottom: 18%;
      width: 1px;
      background: var(--stone-light);
    }
}
@media (max-width: 719px) {.s-already .stat + .stat{
      border-top: 1px solid var(--stone-light);
    }
}
.s-already .stat .stat-idx{
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--stone);
  }
.s-already .stat .stat-num{
    font-family: var(--font-display);
    font-weight: 300;
    font-size: clamp(56px, 8vw, 120px);
    line-height: 0.9;
    letter-spacing: -0.025em;
    color: var(--ink);
    font-feature-settings: "tnum" 1, "lnum" 1;
    display: flex;
    align-items: baseline;
    gap: 6px;
    flex-wrap: wrap;
  }
.s-already .stat .stat-num .unit{
    font-family: var(--font-display);
    font-weight: 400;
    font-size: clamp(20px, 2.4vw, 32px);
    letter-spacing: 0;
    color: var(--ink-soft);
    text-transform: lowercase;
    margin-left: -2px;
  }
.s-already .stat .stat-num .plus{
    color: var(--ochre);
    font-weight: 300;
    margin-left: -4px;
  }
.s-already .stat .stat-label{
    font-family: var(--font-body);
    font-size: 13.5px;
    line-height: 1.45;
    color: var(--ink-soft);
    max-width: 22ch;
    margin: 0;
    padding-top: 8px;
    border-top: 1px solid var(--stone-light);
  }
.s-already .foot{
    margin-top: clamp(40px, 5vw, 64px);
    padding-top: 22px;
    border-top: 1px solid var(--stone-light);
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 18px;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--stone);
  }
.s-already .foot b{ color: var(--ink); font-weight: 500; }
