/* ============================================================================
   HOLIDAYS HUNT — Bold Brutalist-Editorial
   Paper + ink + ONE shout (deep purple #812B8D, the real wordmark).
   Bricolage Grotesque (display) · Hanken Grotesk (text) · IBM Plex Mono (meta).
   Hard 90° edges, visible grid rules, stamped mono metadata. No radius, no blur.
   ========================================================================== */

/* ── fonts (self-hosted, vendor/) ──────────────────────────────────────── */
@font-face{
  font-family:"Bricolage Grotesque";
  src:url("vendor/fonts/bricolage-var.woff2") format("woff2");
  font-weight:400 800; font-style:normal; font-display:swap;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Bricolage Grotesque";
  src:url("vendor/fonts/bricolage-var-ext.woff2") format("woff2");
  font-weight:400 800; font-style:normal; font-display:swap;
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+2020,U+20A0-20AB,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Hanken Grotesk";
  src:url("vendor/fonts/hanken-latin.woff2") format("woff2");
  font-weight:400 700; font-style:normal; font-display:swap;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Hanken Grotesk";
  src:url("vendor/fonts/hanken-latinext.woff2") format("woff2");
  font-weight:400 700; font-style:normal; font-display:swap;
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"IBM Plex Mono";
  src:url("vendor/fonts/plexmono-400.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"IBM Plex Mono";
  src:url("vendor/fonts/plexmono-500.woff2") format("woff2");
  font-weight:500; font-style:normal; font-display:swap;
}

/* ── tokens ────────────────────────────────────────────────────────────── */
:root{
  /* paper + ink — warm achromatic, never pure #fff/#000 */
  --paper:      oklch(98.4% 0.004 320);   /* warm paper            */
  --paper-2:    oklch(95.6% 0.006 320);   /* inset panels / alt rows */
  --paper-3:    oklch(93.2% 0.008 320);   /* deeper inset          */
  --ink:        oklch(17% 0.014 320);     /* near-black, warm      */
  --ink-2:      oklch(40% 0.012 320);     /* secondary / meta      */
  --rule:       oklch(17% 0.014 320);     /* borders = ink         */
  --rule-faint: oklch(17% 0.014 320 / .12); /* grid column rules   */

  /* THE shout — derived from the #812B8D wordmark, pushed to a signal colour */
  --accent:      oklch(50% 0.205 322);    /* deep purple, vivid    */
  --accent-press:oklch(40% 0.18 322);     /* hover-fill / active   */
  --on-accent:   oklch(98.4% 0.004 320);  /* text on accent = paper */

  --hair:1px; --bar:2px; --slab:4px;
  --maxw:1320px;
  --gutter:clamp(1.1rem,4vw,3rem);
  --gap-section:clamp(4.5rem,9vw,9rem);

  /* type scale — brutal jumps */
  --display:"Bricolage Grotesque",system-ui,sans-serif;
  --text:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;

  --h0: clamp(2.5rem,12.5vw,11rem);   /* masthead          */
  --h1: clamp(2.05rem,8.4vw,7rem);    /* hero headline     */
  --h2: clamp(1.55rem,5.4vw,4.4rem);  /* section heads     */
  --h3: clamp(1.35rem,2.4vw,1.9rem);
  --body: clamp(1rem,1.05vw,1.135rem);
  --meta: .76rem;
}

/* ── reset ─────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{ -webkit-text-size-adjust:100%; }
/* NOTE: no `scroll-behavior:smooth` — Lenis owns scrolling (SHARED §5) */
body{
  font-family:var(--text);
  font-size:var(--body);
  line-height:1.5;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--accent);color:var(--on-accent)}
:focus-visible{outline:var(--bar) solid var(--accent);outline-offset:3px}

/* display headings never clip — long words break before overflowing the edge.
   (brutalist still: words break hard, no soft hyphenation glyphs) */
.hero h1,.sect-h,.pull,.row .r-title,.pkg-title,.dcard-meta .dn,.jtable .j-title,
.why-cell h3,.rev-big blockquote,.cta-band h2,.foot .mast,.index-row .nm,.rev-rate .rn,.marquee-track{
  overflow-wrap:break-word;
  word-break:normal;
}

/* shared helpers */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.mono{font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em;font-size:var(--meta);color:var(--ink-2)}
.mono--ink{color:var(--ink)}
.accentword{color:var(--accent)}

/* ── DEMO BANNER (invariant) ───────────────────────────────────────────── */
.demo-banner{
  background:var(--ink);
  color:var(--paper);
  font-family:var(--mono);
  text-transform:uppercase;
  letter-spacing:.1em;
  font-size:.66rem;
  line-height:1.4;
  text-align:center;
  padding:.55rem var(--gutter);
  border-bottom:var(--bar) solid var(--ink);
}
.demo-banner b{color:var(--paper);font-weight:500}
.demo-banner a{
  color:var(--paper);
  text-decoration:underline;
  text-underline-offset:2px;
  text-decoration-color:var(--accent);
  text-decoration-thickness:2px;
}
.demo-banner a:hover{background:var(--accent);color:var(--on-accent);text-decoration:none;padding:0 .25em}

/* ── NAV ───────────────────────────────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:60;
  background:var(--paper);
  border-bottom:var(--bar) solid var(--ink);
}
.nav-inner{
  max-width:var(--maxw);margin-inline:auto;
  padding:.7rem var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.brand{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.brand img{height:26px;width:auto}
.brand .b-tag{
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.13em;
  font-size:.6rem;color:var(--ink-2);
  border-left:var(--hair) solid var(--ink);padding-left:.6rem;
  display:none;
}
@media(min-width:680px){ .brand .b-tag{display:block} }

.nav-links{display:none}
@media(min-width:920px){
  .nav-links{display:flex;gap:0;align-items:stretch}
  .nav-links li{display:flex}
  .nav-links a{
    font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;
    font-size:.68rem;color:var(--ink);
    padding:.5rem .85rem;display:flex;align-items:center;
    border-left:var(--hair) solid var(--ink);
    transition:background .1s linear,color .1s linear;
  }
  .nav-links li:last-child a{border-right:var(--hair) solid var(--ink)}
  .nav-links a:hover{background:var(--ink);color:var(--paper)}
}
.nav-cta{display:flex;align-items:center;gap:.5rem}
.nav-burger{
  display:flex;flex-direction:column;justify-content:center;gap:4px;
  width:44px;height:44px;border:var(--bar) solid var(--ink);
}
.nav-burger span{display:block;height:2px;background:var(--ink);transition:transform .15s,opacity .15s}
@media(min-width:920px){ .nav-burger{display:none} }
.nav.open .nav-burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav.open .nav-burger span:nth-child(2){opacity:0}
.nav.open .nav-burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* mobile drawer */
.nav-drawer{
  display:none;
  border-top:var(--bar) solid var(--ink);
  background:var(--paper);
}
.nav.open .nav-drawer{display:block}
@media(min-width:920px){ .nav.open .nav-drawer{display:none} }
.nav-drawer a{
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;
  padding:1rem var(--gutter);min-height:44px;
  border-bottom:var(--hair) solid var(--ink);
}
.nav-drawer a:hover,.nav-drawer a:active{background:var(--accent);color:var(--on-accent)}
.nav-drawer a .ix{color:var(--accent);font-size:.62rem}
.nav-drawer a:hover .ix{color:var(--on-accent)}

/* ── buttons / stamps ──────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;
  font-size:.74rem;font-weight:500;
  padding:.85rem 1.25rem;min-height:44px;
  border:var(--bar) solid var(--ink);
  border-radius:0;
  background:var(--paper);color:var(--ink);
  transition:background .1s linear,color .1s linear,border-color .1s linear;
}
.btn svg{width:17px;height:17px;flex-shrink:0}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn--wa{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.btn--wa:hover{background:var(--accent-press);border-color:var(--accent-press);color:var(--on-accent)}
.btn--ink{background:var(--ink);color:var(--paper)}
.btn--ink:hover{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}
.btn--sm{padding:.55rem .9rem;font-size:.66rem;min-height:44px}
.btn--lg{padding:1.05rem 1.6rem;font-size:.84rem}
.btn--block{width:100%}

/* ── section scaffolding — every section fenced top+bottom ─────────────── */
.sect{
  position:relative;
  border-top:var(--bar) solid var(--ink);
  padding-block:var(--gap-section);
}
.sect:last-of-type{border-bottom:var(--bar) solid var(--ink)}
/* mono section index pinned in the gutter line */
.sect-head{
  display:flex;flex-wrap:wrap;align-items:baseline;gap:.75rem 1.4rem;
  margin-bottom:clamp(2rem,5vw,3.6rem);
}
.sect-ix{
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;
  font-size:.72rem;color:var(--accent);
  border:var(--hair) solid var(--ink);padding:.3rem .55rem;
  white-space:nowrap;
}
.sect-h{
  font-family:var(--display);font-weight:800;
  font-size:var(--h2);line-height:.9;letter-spacing:-.02em;
  text-transform:uppercase;text-wrap:balance;
  flex:1 1 16ch;
}
.sect-note{
  font-family:var(--text);text-transform:none;letter-spacing:0;
  color:var(--ink-2);font-size:var(--body);max-width:46ch;
  flex:1 1 22ch;
}

/* ── 12-col rule field (behind hero + destinations) ────────────────────── */
.gridlines{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.gridlines .col{
  position:absolute;top:0;bottom:0;width:var(--hair);
  background:var(--rule-faint);
}

/* ============================================================================
   HERO — split: type left (7) / framed photo right (5)
   ========================================================================== */
.hero{position:relative;border-bottom:var(--bar) solid var(--ink);overflow:hidden}
.hero .gridlines .col{background:var(--rule-faint)}
.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr;
  gap:0;
}
@media(min-width:980px){
  .hero-grid{grid-template-columns:7fr 5fr}
}
.hero-left{
  padding:clamp(2.4rem,5vw,4.2rem) var(--gutter) clamp(2.4rem,5vw,3.4rem);
  display:flex;flex-direction:column;
  border-bottom:var(--bar) solid var(--ink);
}
@media(min-width:980px){
  .hero-left{border-bottom:none;border-right:var(--bar) solid var(--ink);padding-left:var(--gutter)}
  /* keep left content aligned with .wrap left edge */
  .hero-grid{max-width:var(--maxw);margin-inline:auto}
}
.hero-kicker{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:clamp(1.4rem,3vw,2.2rem)}
.hero-kicker .tick{width:10px;height:10px;background:var(--accent)}
.hero h1{
  font-family:var(--display);font-weight:800;
  font-size:var(--h1);line-height:.88;letter-spacing:-.025em;
  text-transform:uppercase;text-wrap:balance;
  margin-bottom:clamp(1.3rem,3vw,2rem);
}
.hero h1 .lead{display:block;color:var(--ink)}
.hero h1 .accent{display:block;color:var(--accent)}
.hero-sub{
  font-size:clamp(1rem,1.3vw,1.18rem);color:var(--ink-2);
  max-width:54ch;margin-bottom:auto;padding-bottom:clamp(1.6rem,3vw,2.2rem);
}
.hero-actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:clamp(1.4rem,3vw,2rem)}
@media(max-width:560px){ .hero-actions .btn{width:100%} }

/* hero stat strip — hairline mini table */
.hero-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:var(--bar) solid var(--ink);margin-top:clamp(1.6rem,3vw,2.4rem);
}
.hero-stats .st{padding:.95rem .4rem .2rem;border-left:var(--hair) solid var(--ink)}
.hero-stats .st:first-child{border-left:none}
.hero-stats .st b{
  display:block;font-family:var(--display);font-weight:700;
  font-size:clamp(1.5rem,3vw,2.1rem);line-height:1;letter-spacing:-.02em;
}
.hero-stats .st span{font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:.6rem;color:var(--ink-2)}

/* hero figure (right) */
.hero-fig{position:relative;min-height:340px;overflow:hidden;background:var(--paper-2)}
.hero-fig .hero-media{
  position:absolute;inset:-6% 0 -6% 0;width:100%;height:112%;
  object-fit:cover;
  filter:contrast(1.08) saturate(.94);
  will-change:transform;
}
/* the single duotone — accent multiply, so one photo carries the shout */
.hero-fig::after{
  content:"";position:absolute;inset:0;
  background:var(--accent);
  mix-blend-mode:multiply;opacity:.16;pointer-events:none;
}
.hero-cap{
  position:absolute;left:0;bottom:0;z-index:3;
  display:flex;gap:0;align-items:stretch;
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.13em;font-size:.62rem;
}
.hero-cap .lab{background:var(--ink);color:var(--paper);padding:.45rem .7rem}
.hero-cap .loc{background:var(--accent);color:var(--on-accent);padding:.45rem .7rem}
/* rotated stamp — one deliberate grid break */
.hero-stamp{
  position:absolute;right:clamp(.8rem,2vw,1.4rem);top:clamp(.8rem,2vw,1.4rem);z-index:3;
  background:var(--paper);border:var(--bar) solid var(--ink);
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;font-size:.6rem;
  padding:.4rem .6rem;transform:rotate(-5deg);
  box-shadow:none;
}
.hero-stamp b{color:var(--accent);font-weight:500}

/* ── MARQUEE / TICKER — the accent's big appearance ────────────────────── */
.marquee{
  background:var(--accent);color:var(--on-accent);
  border-bottom:var(--bar) solid var(--ink);
  overflow:hidden;white-space:nowrap;
}
.marquee-track{
  display:inline-flex;align-items:center;
  font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:.01em;
  font-size:clamp(1.1rem,2.4vw,1.8rem);
  padding-block:.5rem;
  will-change:transform;
  animation:marquee 26s linear infinite;
}
.marquee-track span{padding-inline:1.1rem;display:inline-flex;align-items:center;gap:1.1rem}
.marquee-track .x{color:var(--ink);font-family:var(--mono);font-size:.9em}
@keyframes marquee{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── INDEX / CONTENTS (magazine TOC, doubles as in-page nav) ───────────── */
.index{border-top:var(--bar) solid var(--ink)}
.index-grid{
  display:grid;grid-template-columns:1fr;
}
@media(min-width:680px){ .index-grid{grid-template-columns:1fr 1fr} }
@media(min-width:1040px){ .index-grid{grid-template-columns:repeat(3,1fr)} }
.index-row{
  display:flex;align-items:baseline;gap:1rem;
  padding:1.1rem var(--gutter);
  border-bottom:var(--hair) solid var(--ink);
  border-right:var(--hair) solid var(--ink);
  transition:background .1s linear,color .1s linear;
}
.index-row .ix{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;color:var(--accent);flex-shrink:0}
.index-row .nm{
  font-family:var(--display);font-weight:700;text-transform:uppercase;
  letter-spacing:-.01em;font-size:1.15rem;line-height:1;
}
.index-row .ar{margin-left:auto;font-family:var(--mono);font-size:.62rem;color:var(--ink-2);letter-spacing:.1em}
.index-row:hover{background:var(--accent);color:var(--on-accent)}
.index-row:hover .ix,.index-row:hover .ar{color:var(--on-accent)}

/* ── ABOUT + PULL-QUOTE ────────────────────────────────────────────────── */
.about-grid{display:grid;grid-template-columns:1fr;gap:clamp(2rem,5vw,3.5rem)}
@media(min-width:900px){ .about-grid{grid-template-columns:5fr 7fr} }
.about-paras p{max-width:60ch;margin-bottom:1.1rem;color:var(--ink-2)}
.about-paras p:first-child{color:var(--ink)}
.about-side{align-self:start}
.pull{
  font-family:var(--display);font-weight:800;text-transform:uppercase;
  font-size:clamp(1.6rem,3.4vw,2.7rem);line-height:.95;letter-spacing:-.02em;
  text-wrap:balance;
  border-top:var(--slab) solid var(--ink);padding-top:1.2rem;
}
.pull .q{display:block;font-size:2.4em;line-height:.6;color:var(--accent);margin-bottom:.1em}
.about-meta{
  margin-top:1.4rem;display:flex;flex-wrap:wrap;gap:.4rem .9rem;
}
.about-meta .chip{
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:.6rem;
  border:var(--hair) solid var(--ink);padding:.3rem .55rem;
}

/* ── SERVICES — numbered editorial list-rows ───────────────────────────── */
.rows{border-top:var(--bar) solid var(--ink)}
.row{
  display:grid;grid-template-columns:auto 1fr;gap:.9rem 1.2rem;
  align-items:start;
  padding:clamp(1.2rem,2.6vw,1.8rem) 0;
  border-bottom:var(--hair) solid var(--ink);
  transition:background .1s linear,color .1s linear;
}
@media(min-width:760px){
  .row{grid-template-columns:5ch 1fr minmax(28ch,42%);align-items:center}
}
.row .r-ix{font-family:var(--mono);font-size:.8rem;letter-spacing:.05em;color:var(--accent);padding-top:.15rem}
.row .r-title{
  font-family:var(--display);font-weight:700;text-transform:uppercase;
  letter-spacing:-.01em;font-size:clamp(1.3rem,2.4vw,1.85rem);line-height:.98;
}
.row .r-desc{color:var(--ink-2);font-size:.97rem;max-width:46ch}
.row:hover{background:var(--accent);color:var(--on-accent)}
.row:hover .r-ix{color:var(--on-accent)}
.row:hover .r-desc{color:var(--on-accent)}
/* gutter padding for rows lives on the wrap; add inner pad on hover-fill */
.rows .row{padding-inline:clamp(.4rem,1.5vw,1rem)}

/* ── PACKAGES — list-rows w/ photo + price-on-request stamp ─────────────── */
.pkgs{border-top:var(--bar) solid var(--ink)}
.pkg{
  display:grid;grid-template-columns:1fr;gap:0;
  border-bottom:var(--hair) solid var(--ink);
}
@media(min-width:840px){
  .pkg{grid-template-columns:auto 1fr auto;align-items:stretch}
}
.pkg-fig{
  position:relative;overflow:hidden;background:var(--paper-2);
  aspect-ratio:16/10;
  border-bottom:var(--hair) solid var(--ink);
}
@media(min-width:840px){
  .pkg-fig{width:clamp(220px,26vw,320px);aspect-ratio:auto;border-bottom:none;border-right:var(--hair) solid var(--ink)}
}
.pkg-fig img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:contrast(1.07) saturate(.93);transition:transform .35s cubic-bezier(.16,1,.3,1)}
.pkg:hover .pkg-fig img{transform:scale(1.04)}
.pkg-fig .fig-cap{
  position:absolute;left:0;bottom:0;
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;font-size:.56rem;
  background:var(--ink);color:var(--paper);padding:.3rem .5rem;
}
.pkg-body{padding:clamp(1.2rem,2.5vw,1.7rem) clamp(1rem,2.4vw,1.6rem);display:flex;flex-direction:column;gap:.55rem;min-width:0}
.pkg-tag{
  align-self:flex-start;
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;font-size:.58rem;
  background:var(--accent);color:var(--on-accent);padding:.28rem .5rem;
}
.pkg-title{
  font-family:var(--display);font-weight:700;text-transform:uppercase;
  letter-spacing:-.01em;font-size:clamp(1.3rem,2.3vw,1.8rem);line-height:.98;
}
.pkg-meta{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;font-size:.66rem;color:var(--ink-2)}
.pkg-desc{color:var(--ink-2);font-size:.96rem;max-width:60ch}
.pkg-aside{
  display:flex;flex-direction:column;justify-content:space-between;gap:1rem;
  padding:clamp(1.2rem,2.5vw,1.7rem) clamp(1rem,2.4vw,1.6rem);
  border-top:var(--hair) solid var(--ink);
}
@media(min-width:840px){
  .pkg-aside{width:clamp(190px,20vw,240px);border-top:none;border-left:var(--hair) solid var(--ink);align-items:stretch;text-align:left}
}
/* price-on-request stamp — solid accent block, square, paper text */
.price-stamp{
  background:var(--ink);color:var(--paper);
  border:var(--bar) solid var(--ink);
  padding:.7rem .8rem;
}
.price-stamp .pl{font-family:var(--mono);text-transform:uppercase;letter-spacing:.13em;font-size:.54rem;opacity:.75;display:block;margin-bottom:.2rem}
.price-stamp .pv{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:1.05rem;line-height:1;letter-spacing:-.01em}
.price-stamp .pv b{color:var(--accent);font-weight:700}

/* ── DESTINATIONS — uniform figure grid (assigned gridType) ────────────── */
.dest{position:relative;border-top:var(--bar) solid var(--ink)}
.dest-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr;gap:0;
  border:var(--hair) solid var(--ink);
}
@media(min-width:560px){ .dest-grid{grid-template-columns:1fr 1fr} }
@media(min-width:1040px){ .dest-grid{grid-template-columns:repeat(4,1fr)} }
.dcard{
  position:relative;display:block;
  border-right:var(--hair) solid var(--ink);
  border-bottom:var(--hair) solid var(--ink);
  overflow:hidden;background:var(--paper-2);
}
.dcard-fig{position:relative;aspect-ratio:3/4;overflow:hidden}
.dcard-fig img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:contrast(1.08) saturate(.92);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.dcard:hover .dcard-fig img{transform:scale(1.05)}
.dcard-fig::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(20,12,22,.5) 100%)}
.dcard-meta{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:.85rem .9rem;color:var(--paper);
  display:flex;align-items:flex-end;justify-content:space-between;gap:.5rem;
}
.dcard-meta .dn{font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:-.01em;font-size:1.4rem;line-height:.92}
.dcard-meta .ds{font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:.56rem;opacity:.9}
.dcard .dnum{
  position:absolute;top:0;left:0;z-index:2;
  font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;
  background:var(--paper);color:var(--ink);padding:.3rem .5rem;
  border-right:var(--hair) solid var(--ink);border-bottom:var(--hair) solid var(--ink);
}
.dcard:hover .dnum{background:var(--accent);color:var(--on-accent)}

/* ── JOURNEY — hairline data table ─────────────────────────────────────── */
.journey-wrap{border-top:var(--bar) solid var(--ink)}
.jtable{width:100%;border-collapse:collapse}
.jtable tr{border-bottom:var(--hair) solid var(--ink);transition:background .1s linear,color .1s linear}
.jtable tr:hover{background:var(--paper-2)}
.jtable td{padding:clamp(1rem,2.2vw,1.5rem) .6rem;vertical-align:top}
.jtable .j-day{
  width:6.5rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;
  font-size:.72rem;color:var(--accent);white-space:nowrap;
  border-right:var(--hair) solid var(--ink);
}
.jtable .j-title{
  font-family:var(--display);font-weight:700;text-transform:uppercase;
  letter-spacing:-.01em;font-size:clamp(1.15rem,2vw,1.5rem);line-height:1;
  width:34%;
}
.jtable .j-desc{color:var(--ink-2);font-size:.95rem}
@media(max-width:640px){
  .jtable,.jtable tbody,.jtable tr,.jtable td{display:block;width:auto}
  .jtable tr{padding:1rem .2rem}
  .jtable td{padding:.15rem .2rem;border:none}
  .jtable .j-day{border:none;padding-bottom:.3rem}
  .jtable .j-title{padding-bottom:.3rem}
}

/* ── WHY — 4-up panels ─────────────────────────────────────────────────── */
.why-grid{
  display:grid;grid-template-columns:1fr;gap:0;
  border:var(--hair) solid var(--ink);
}
@media(min-width:600px){ .why-grid{grid-template-columns:1fr 1fr} }
@media(min-width:1000px){ .why-grid{grid-template-columns:repeat(4,1fr)} }
.why-cell{
  padding:clamp(1.3rem,2.6vw,1.9rem);
  border-right:var(--hair) solid var(--ink);
  border-bottom:var(--hair) solid var(--ink);
  display:flex;flex-direction:column;gap:.6rem;min-height:200px;
}
.why-cell .wn{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;color:var(--accent)}
.why-icon{width:30px;height:30px;color:var(--ink);margin-bottom:.2rem}
.why-icon svg{width:100%;height:100%}
.why-cell h3{font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:-.01em;font-size:1.2rem;line-height:1;margin-top:auto}
.why-cell p{color:var(--ink-2);font-size:.92rem}

/* ── GALLERY — uniform band ────────────────────────────────────────────── */
.gal-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border:var(--hair) solid var(--ink);
}
@media(min-width:760px){ .gal-grid{grid-template-columns:repeat(4,1fr)} }
.gal-fig{position:relative;aspect-ratio:1/1;overflow:hidden;border-right:var(--hair) solid var(--ink);border-bottom:var(--hair) solid var(--ink);background:var(--paper-2)}
.gal-fig img{width:100%;height:100%;object-fit:cover;filter:contrast(1.07) saturate(.92);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.gal-fig:hover img{transform:scale(1.06)}
.gal-fig .gc{position:absolute;left:0;bottom:0;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:.54rem;background:var(--ink);color:var(--paper);padding:.25rem .45rem}

/* ── REVIEWS — oversized pull-quote + supporting rows ──────────────────── */
.rev-lead{
  display:grid;grid-template-columns:1fr;gap:clamp(1.4rem,3vw,2.4rem);
  align-items:start;margin-bottom:clamp(2rem,4vw,3rem);
}
@media(min-width:900px){ .rev-lead{grid-template-columns:auto 1fr} }
.rev-big{
  position:relative;
}
.rev-big .rq{
  font-family:var(--mono);font-size:clamp(4rem,9vw,7rem);line-height:.6;color:var(--accent);
  display:block;transform:rotate(-4deg);transform-origin:left top;margin-bottom:.1em;
}
.rev-big blockquote{
  font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(1.6rem,3.6vw,3rem);line-height:.98;letter-spacing:-.02em;
  text-wrap:balance;max-width:18ch;
}
.rev-big .rwho{margin-top:1rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;font-size:.64rem;color:var(--ink-2);display:flex;gap:.6rem;align-items:center}
.rev-big .stars{color:var(--accent);letter-spacing:.1em}
.rev-rate{
  align-self:stretch;display:flex;flex-direction:column;justify-content:center;gap:.3rem;
  border:var(--bar) solid var(--ink);padding:1.3rem 1.5rem;background:var(--paper-2);
  min-width:min(100%,15rem);
}
.rev-rate .rn{font-family:var(--display);font-weight:800;font-size:clamp(3rem,6vw,4.6rem);line-height:.85;letter-spacing:-.03em}
.rev-rate .rn small{font-size:.4em;color:var(--accent)}
.rev-rate .rl{font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:.62rem;color:var(--ink-2)}
.rev-grid{
  display:grid;grid-template-columns:1fr;gap:0;border-top:var(--hair) solid var(--ink);
}
@media(min-width:720px){ .rev-grid{grid-template-columns:1fr 1fr} }
@media(min-width:1080px){ .rev-grid{grid-template-columns:repeat(3,1fr)} }
.rev-cell{
  padding:clamp(1.2rem,2.5vw,1.7rem);
  border-right:var(--hair) solid var(--ink);
  border-bottom:var(--hair) solid var(--ink);
  display:flex;flex-direction:column;gap:.7rem;
}
.rev-cell .stars{color:var(--accent);font-size:.85rem;letter-spacing:.12em}
.rev-cell p{font-size:.98rem;color:var(--ink)}
.rev-cell .who{margin-top:auto;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:.6rem;color:var(--ink-2)}

/* ── CTA BAND ──────────────────────────────────────────────────────────── */
.cta-band{
  position:relative;background:var(--ink);color:var(--paper);
  border-top:var(--bar) solid var(--ink);overflow:hidden;
}
.cta-band .gridlines .col{background:rgba(255,255,255,.07)}
.cta-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr;gap:clamp(1.6rem,4vw,2.6rem);align-items:end}
@media(min-width:880px){ .cta-inner{grid-template-columns:7fr 5fr} }
.cta-band h2{
  font-family:var(--display);font-weight:800;text-transform:uppercase;
  font-size:clamp(2.2rem,6vw,5rem);line-height:.9;letter-spacing:-.025em;text-wrap:balance;
}
.cta-band h2 .ac{color:var(--accent)}
.cta-band p{color:rgba(255,255,255,.72);max-width:48ch;margin-top:1.1rem}
.cta-actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.6rem}
@media(max-width:560px){ .cta-actions .btn{width:100%} }
.cta-band .btn{border-color:var(--paper)}
.cta-band .btn--ink-on-dark{background:transparent;color:var(--paper);border-color:var(--paper)}
.cta-band .btn--ink-on-dark:hover{background:var(--paper);color:var(--ink)}
.cta-aside{display:flex;flex-direction:column;gap:0;border:var(--hair) solid rgba(255,255,255,.3)}
.cta-aside .car{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.95rem 1.1rem;border-bottom:var(--hair) solid rgba(255,255,255,.3);
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;font-size:.66rem;
}
.cta-aside .car:last-child{border-bottom:none}
.cta-aside .car .k{color:rgba(255,255,255,.55)}
.cta-aside .car a:hover{color:var(--accent)}

/* ── CONTACT / FOOTER ──────────────────────────────────────────────────── */
.foot{border-top:var(--bar) solid var(--ink);padding-block:clamp(3rem,6vw,5rem) 2rem}
.foot-grid{display:grid;grid-template-columns:1fr;gap:clamp(2rem,4vw,3rem)}
@media(min-width:820px){ .foot-grid{grid-template-columns:1.4fr 1fr 1fr} }
.foot .mast{
  font-family:var(--display);font-weight:800;text-transform:uppercase;
  font-size:clamp(2.4rem,8vw,5.5rem);line-height:.85;letter-spacing:-.03em;
  margin-bottom:.6rem;
}
.foot .mast .ac{color:var(--accent)}
.foot-dateline{font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;color:var(--ink-2);border-top:var(--slab) solid var(--ink);padding-top:.8rem;max-width:40ch}
.foot h4{font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;color:var(--accent);margin-bottom:.9rem}
.foot-list li{margin-bottom:.55rem}
.foot-list a,.foot-list span{font-size:.95rem;color:var(--ink)}
.foot-list a:hover{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:2px}
.foot-list .lbl{font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:.56rem;color:var(--ink-2);display:block;margin-bottom:.1rem}
.foot-social{display:flex;gap:.5rem;margin-top:.4rem}
.foot-social a{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:var(--bar) solid var(--ink);transition:background .1s linear,color .1s linear}
.foot-social a:hover{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.foot-social svg{width:18px;height:18px}
.foot-bottom{
  border-top:var(--hair) solid var(--ink);margin-top:clamp(2.4rem,5vw,3.6rem);padding-top:1.2rem;
  display:flex;flex-wrap:wrap;gap:.6rem 1.2rem;align-items:center;justify-content:space-between;
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:.58rem;color:var(--ink-2);
}
.foot-bottom .disc{max-width:60ch}

/* ── reveal motion (compositor-only) ───────────────────────────────────── */
[data-reveal]{opacity:0;transform:translateY(14px);transition:opacity .35s cubic-bezier(.16,1,.3,1),transform .35s cubic-bezier(.16,1,.3,1)}
[data-reveal].in{opacity:1;transform:none}
[data-hero-el]{opacity:0;transform:translateY(16px);transition:opacity .4s cubic-bezier(.16,1,.3,1),transform .4s cubic-bezier(.16,1,.3,1)}
[data-hero-el].in{opacity:1;transform:none}

/* ── reduced motion: everything visible + static (invariant) ───────────── */
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important}
  .marquee-track{animation:none !important;transform:none !important}
  [data-reveal],[data-hero-el]{opacity:1 !important;transform:none !important;transition:none !important}
  .pkg:hover .pkg-fig img,.dcard:hover .dcard-fig img,.gal-fig:hover img{transform:none !important}
  .hero-fig .hero-media{position:absolute;inset:0;height:100%}
}
