/* =====================================================================
   AFRICAN SAFARI TRIPS — Design System
   Cinematic · editorial · luxury · motion-rich
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  --ink:#11100E;        /* near-black charcoal */
  --ink-2:#1B1916;      /* slightly lifted ink */
  --bone:#F4EFE7;       /* warm ivory */
  --bone-2:#EAE2D4;     /* deeper ivory */
  --gold:#cf9a00;       /* savanna amber */
  --gold-soft:#E6B73A;
  --clay:#B5683E;       /* terracotta */
  --forest:#2E3D2F;     /* deep green */
  --stone:#8A8175;      /* muted caption/border */
  --stone-2:#6E665B;

  --maxw:1280px;
  --gutter:clamp(1.25rem,5vw,4rem);
  --radius:22px;
  --radius-lg:30px;
  --radius-sm:14px;

  --shadow-soft:0 18px 50px -20px rgba(17,16,14,.35);
  --shadow-card:0 30px 70px -28px rgba(17,16,14,.55);
  --shadow-float:0 14px 40px -12px rgba(17,16,14,.45);

  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);
  --dur:.7s;
  --header-h:84px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:auto}
body{
  font-family:var(--sans);
  background:var(--bone);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video{display:block;max-width:100%}
svg{display:inline-block;width:1.15em;height:1.15em;flex-shrink:0;vertical-align:-.15em}
.ico svg{width:24px;height:24px}
.footer-socials a svg{width:18px;height:18px}
.carousel-nav button svg{width:20px;height:20px}
.fab svg{width:26px;height:26px}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
ul{list-style:none;padding:0}
input,textarea,select{font:inherit;color:inherit}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:430;line-height:1.04;letter-spacing:-.01em}
.display{
  font-family:var(--serif);
  font-weight:430;
  font-size:clamp(2.9rem,7vw,7rem);
  line-height:.98;
  letter-spacing:-.02em;
}
.display em,.title em,h1 em,h2 em{font-style:italic;font-weight:430;color:var(--gold)}
.title{font-size:clamp(2rem,4.4vw,3.6rem);line-height:1.02;letter-spacing:-.015em}
.subtitle{font-size:clamp(1.5rem,2.6vw,2.2rem);line-height:1.1}
.lede{font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--stone-2);max-width:60ch}
.eyebrow{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--sans);font-weight:600;
  font-size:.72rem;text-transform:uppercase;letter-spacing:.24em;
  color:var(--gold);
}
.eyebrow.on-dark{color:var(--gold-soft)}
.muted{color:var(--stone-2)}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(4.5rem,9vw,8.5rem)}
.section-tight{padding-block:clamp(3rem,6vw,5rem)}
.dark{background:var(--ink);color:var(--bone)}
.dark .lede,.dark .muted{color:rgba(244,239,231,.66)}
.forest{background:var(--forest);color:var(--bone)}
.bone-2{background:var(--bone-2)}
.center{text-align:center}
.section-head{max-width:62ch}
.section-head.center{margin-inline:auto}
.section-head .title{margin-top:.7rem}
.section-head .lede{margin-top:1.1rem}
.grid{display:grid;gap:clamp(1rem,2vw,1.6rem)}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--gold);--fg:var(--ink);--bd:transparent;
  position:relative;display:inline-flex;align-items:center;gap:.6em;
  padding:.95em 1.7em;border-radius:999px;
  background:var(--bg);color:var(--fg);border:1px solid var(--bd);
  font-weight:600;font-size:.92rem;letter-spacing:.01em;
  transition:transform .35s var(--ease),background .35s var(--ease),color .35s var(--ease),box-shadow .35s var(--ease);
  will-change:transform;
}
.btn svg{width:1.05em;height:1.05em}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-float)}
.btn-gold{--bg:var(--gold);--fg:#1a160c}
.btn-gold:hover{--bg:var(--gold-soft)}
.btn-ink{--bg:var(--ink);--fg:var(--bone)}
.btn-ghost{--bg:transparent;--fg:currentColor;--bd:currentColor}
.btn-ghost{border-color:rgba(244,239,231,.5)}
.btn-ghost:hover{background:rgba(244,239,231,.1)}
.btn-ghost.on-light{border-color:rgba(17,16,14,.28)}
.btn-ghost.on-light:hover{background:rgba(17,16,14,.05)}
.btn-lg{padding:1.1em 2em;font-size:1rem}
.btn-row{display:flex;flex-wrap:wrap;gap:.9rem}
.link-arrow{display:inline-flex;align-items:center;gap:.5em;font-weight:600;color:var(--clay)}
.dark .link-arrow{color:var(--gold-soft)}
.link-arrow svg{transition:transform .3s var(--ease)}
.link-arrow:hover svg{transform:translateX(5px)}

/* ---------- Reveal animation hooks ---------- */
[data-reveal]{opacity:0;transform:translateY(34px)}
.reveal-ready [data-reveal]{will-change:transform,opacity}
.no-motion [data-reveal]{opacity:1!important;transform:none!important}

/* ---------- Film grain + vignette (dark cinematic sections) ---------- */
.grain::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
  opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.vignette::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(120% 80% at 50% 45%,transparent 55%,rgba(0,0,0,.45) 100%);
}

/* =====================================================================
   CINEMATIC HERO (full-bleed single image, depth, one-line title)
   ===================================================================== */
.cinema-hero{position:relative;height:100svh;min-height:620px;width:100%;overflow:hidden;background:var(--ink);display:flex;align-items:flex-end}
.cinema-hero .ch-bg{position:absolute;inset:-14% 0;z-index:0;will-change:transform}
.cinema-hero .ch-bg img,.cinema-hero .ch-bg video{width:100%;height:100%;object-fit:cover}
.cinema-hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(8,7,6,.82) 0%,rgba(8,7,6,.15) 45%,rgba(8,7,6,.45) 100%)}
.cinema-hero .container{position:relative;z-index:3;width:100%;padding-bottom:clamp(3.5rem,8vh,7rem);padding-top:var(--header-h)}
.cinema-hero .eyebrow{margin-bottom:1.1rem}
.cinema-hero h1{font-family:var(--serif);font-weight:430;color:var(--bone);font-size:clamp(2.8rem,8.2vw,8.5rem);line-height:.95;letter-spacing:-.02em;max-width:16ch}
.cinema-hero h1 em{font-style:italic;color:var(--gold)}
.cinema-hero .sub{margin-top:1.5rem;max-width:46ch;color:rgba(244,239,231,.85);font-size:clamp(1.05rem,1.5vw,1.3rem)}
.cinema-hero .btn-row{margin-top:2.2rem}
.cinema-hero .ch-meta{position:absolute;right:var(--gutter);bottom:clamp(3.5rem,8vh,7rem);z-index:3;text-align:right;color:rgba(244,239,231,.7)}
.cinema-hero .ch-meta .where{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--gold-soft)}
.cinema-hero .ch-meta .what{font-size:.72rem;text-transform:uppercase;letter-spacing:.22em;margin-top:.2rem}

/* =====================================================================
   ANCHORED IMAGE BANDS (fixed background, text scrolls over)
   ===================================================================== */
.anchored{position:relative;overflow:hidden;background:var(--ink);color:var(--bone)}
.anchored .anchored-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;background-attachment:fixed}
.anchored::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(8,7,6,.5),rgba(8,7,6,.66))}
.anchored>.container{position:relative;z-index:2}
.anchored.tall{min-height:78vh;display:flex;align-items:center}
.anchored .quote-lead{font-family:var(--serif);font-size:clamp(1.8rem,4vw,3.4rem);line-height:1.18;letter-spacing:-.01em;max-width:20ch;color:var(--bone)}
.anchored .quote-lead em{font-style:italic;color:var(--gold)}
.anchored .lede{color:rgba(244,239,231,.8)}
.anchored .eyebrow{color:var(--gold-soft)}
@media (hover:none),(max-width:760px){
  .anchored .anchored-bg{background-attachment:scroll}
}

/* =====================================================================
   HEADER + MEGA-DROPDOWN
   ===================================================================== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:90;
  transition:background .5s var(--ease),box-shadow .5s var(--ease),backdrop-filter .5s,padding .5s var(--ease);
  padding-block:18px;
}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.brand{display:flex;align-items:center;gap:.7rem;z-index:2}
.brand .logo{height:52px;width:auto;transition:height .45s var(--ease)}
.brand .logo-on-light{display:none}
.site-header.scrolled .brand .logo-on-dark{display:none}
.site-header.scrolled .brand .logo-on-light{display:inline-block}
.brand .brand-word{display:none}
.site-header.scrolled{
  background:rgba(244,239,231,.86);
  backdrop-filter:saturate(1.2) blur(14px);
  -webkit-backdrop-filter:saturate(1.2) blur(14px);
  box-shadow:0 1px 0 rgba(17,16,14,.07),0 16px 40px -30px rgba(17,16,14,.4);
  padding-block:10px;
}
.site-header.scrolled .brand .logo{height:40px}

/* nav */
.nav{display:flex;align-items:center;gap:.35rem}
.nav-item{position:relative}
.nav-link{
  display:inline-flex;align-items:center;gap:.4em;
  padding:.6em .9em;border-radius:999px;
  font-weight:550;font-size:.92rem;color:var(--bone);
  transition:color .3s,background .3s;
}
.nav-link .chev{width:.7em;height:.7em;transition:transform .35s var(--ease)}
.nav-item:hover .nav-link .chev,.nav-item.open .nav-link .chev{transform:rotate(180deg)}
.site-header.scrolled .nav-link{color:var(--ink)}
.nav-link:hover{color:var(--gold)}
.site-header.scrolled .nav-link:hover{background:rgba(17,16,14,.05);color:var(--clay)}

.header-actions{display:flex;align-items:center;gap:.7rem;z-index:2}
.lang{
  display:inline-flex;align-items:center;gap:.35em;
  font-size:.82rem;font-weight:600;letter-spacing:.04em;
  color:var(--bone);padding:.5em .7em;border-radius:999px;
  border:1px solid rgba(244,239,231,.32);
}
.site-header.scrolled .lang{color:var(--ink);border-color:rgba(17,16,14,.18)}
.header-cta{padding:.7em 1.25em;font-size:.85rem}

/* mega dropdown — viewport-anchored so it never clips */
.mega{
  position:fixed;top:90px;left:50%;transform:translateX(-50%) translateY(-10px);
  width:min(1180px,94vw);
  background:rgba(244,239,231,.98);
  backdrop-filter:blur(20px);
  border:1px solid rgba(17,16,14,.07);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  padding:1.5rem;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .4s var(--ease),transform .45s var(--ease),visibility .4s;
  z-index:80;
}
.site-header.scrolled .mega{top:74px}
.nav-item.open .mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.mega-rail-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.1rem}
.mega-rail-row .rail-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;color:var(--stone);font-weight:700;white-space:nowrap}
.rail-pills{display:flex;gap:.5rem;flex-wrap:wrap}
.rail-pill{
  display:inline-flex;align-items:center;gap:.55em;
  padding:.55em .95em;border-radius:999px;
  border:1px solid rgba(17,16,14,.14);
  font-weight:550;font-size:.88rem;
  transition:border-color .3s,background .3s,color .3s,transform .3s var(--ease);
}
.rail-pill .dot{width:.55em;height:.55em;border-radius:50%;background:var(--gold)}
.rail-pill:hover{border-color:var(--gold);background:#fff;color:var(--clay);transform:translateY(-2px)}
.mega-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:.8rem}
.mega-card{
  position:relative;border-radius:var(--radius-sm);overflow:hidden;
  aspect-ratio:3/4;box-shadow:var(--shadow-soft);
}
.mega-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.mega-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(17,16,14,.82),transparent 60%)}
.mega-card .mc-cap{position:absolute;left:.85rem;right:.7rem;bottom:.8rem;z-index:2;transition:transform .5s var(--ease)}
.mega-card .mc-label{display:block;color:var(--bone);font-family:var(--serif);font-size:1.15rem;line-height:1.05}
.mega-card .mc-feature{display:block;margin-top:.25rem;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft);line-height:1.3}
.mega-card:hover img{transform:scale(1.08)}
.mega-card:hover .mc-cap{transform:translateY(-4px)}
.mega-band{
  position:relative;margin-top:1.2rem;border-radius:var(--radius-sm);overflow:hidden;
  min-height:128px;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.4rem 1.6rem;
}
.mega-band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.mega-band::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(17,16,14,.8),rgba(17,16,14,.25))}
.mega-band .band-copy{position:relative;z-index:2;color:var(--bone)}
.mega-band .band-copy .scriptline{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--gold-soft)}
.mega-band .band-copy p{font-size:.9rem;color:rgba(244,239,231,.8);max-width:46ch;margin-top:.2rem}
.mega-band .btn{position:relative;z-index:2;flex-shrink:0}

/* ---------- Mobile drawer ---------- */
.hamburger{display:none;flex-direction:column;gap:5px;width:40px;height:40px;align-items:center;justify-content:center;z-index:120}
.hamburger span{width:24px;height:2px;background:var(--bone);border-radius:2px;transition:transform .4s var(--ease),opacity .3s}
.site-header.scrolled .hamburger span{background:var(--ink)}
.drawer-open .hamburger span{background:var(--bone)}
.drawer-open .hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.drawer-open .hamburger span:nth-child(2){opacity:0}
.drawer-open .hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.drawer{
  position:fixed;inset:0;z-index:100;background:var(--ink);color:var(--bone);
  transform:translateX(100%);transition:transform .55s var(--ease);
  display:flex;flex-direction:column;padding:6rem var(--gutter) 2rem;overflow-y:auto;
}
.drawer-open .drawer{transform:translateX(0)}
.drawer a{font-family:var(--serif);font-size:1.8rem;padding:.5rem 0;border-bottom:1px solid rgba(244,239,231,.12)}
.drawer details summary{font-family:var(--serif);font-size:1.8rem;padding:.5rem 0;border-bottom:1px solid rgba(244,239,231,.12);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.drawer details summary::-webkit-details-marker{display:none}
.drawer details[open] summary{color:var(--gold)}
.drawer details .sub{padding:.4rem 0 .8rem 1rem;display:flex;flex-direction:column;gap:.2rem}
.drawer details .sub a{font-size:1.1rem;font-family:var(--sans);color:rgba(244,239,231,.75);border:none;padding:.3rem 0}
.drawer .btn{margin-top:1.5rem;justify-content:center}

/* =====================================================================
   HOMEPAGE HERO
   ===================================================================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;background:var(--ink)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg video,.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,9,8,.86) 0%,rgba(10,9,8,.5) 45%,rgba(10,9,8,.25) 100%),linear-gradient(to top,rgba(10,9,8,.7),transparent 50%)}
.hero .container{position:relative;z-index:3;width:100%;padding-top:var(--header-h)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.hero-copy{color:var(--bone);max-width:40ch}
.hero-copy .display{margin-top:1.2rem;color:var(--bone)}
.hero-copy .lede{margin-top:1.4rem;color:rgba(244,239,231,.8)}
.ticks{display:flex;flex-direction:column;gap:.55rem;margin-top:1.6rem}
.tick{display:flex;align-items:center;gap:.7em;font-size:.96rem;color:rgba(244,239,231,.9)}
.tick svg{width:1.15em;height:1.15em;color:var(--gold);flex-shrink:0}
.hero-copy .btn-row{margin-top:2rem}
.stats{display:flex;gap:clamp(1.2rem,3vw,2.6rem);margin-top:2.4rem;padding-top:1.6rem;border-top:1px solid rgba(244,239,231,.16)}
.stat .num{font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);color:var(--gold)}
.stat .lbl{font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:rgba(244,239,231,.65);margin-top:.2rem}

/* Now showing card */
.now-showing{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);aspect-ratio:3/3.7}
.now-showing video,.now-showing img{width:100%;height:100%;object-fit:cover}
.now-showing::before{content:"";position:absolute;inset:0;z-index:1;box-shadow:inset 0 0 0 1px rgba(244,239,231,.18);border-radius:var(--radius);pointer-events:none}
.now-showing::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(17,16,14,.7),transparent 55%)}
.ns-top{position:absolute;top:1rem;left:1rem;z-index:3;display:flex;align-items:center;gap:.5em}
.ns-dot{width:.6em;height:.6em;border-radius:50%;background:#ff4d4d;box-shadow:0 0 0 0 rgba(255,77,77,.6);animation:pulse 2s infinite}
.no-motion .ns-dot{animation:none}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,77,77,.55)}70%{box-shadow:0 0 0 9px rgba(255,77,77,0)}100%{box-shadow:0 0 0 0 rgba(255,77,77,0)}}
.ns-top span{font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;color:var(--bone);font-weight:600}
.ns-chips{position:absolute;left:1rem;bottom:1rem;z-index:3;display:flex;gap:.5rem;flex-wrap:wrap}
.chip{
  display:inline-flex;align-items:center;gap:.45em;
  padding:.45em .85em;border-radius:999px;
  background:rgba(17,16,14,.42);backdrop-filter:blur(8px);
  border:1px solid rgba(244,239,231,.22);
  color:var(--bone);font-size:.74rem;font-weight:500;letter-spacing:.02em;
}
.chip.solid{background:var(--gold);color:#1a160c;border-color:transparent;font-weight:600}

/* scroll cue */
.scroll-cue{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);z-index:4;color:rgba(244,239,231,.8);text-align:center}
.scroll-cue .lbl{font-size:.66rem;text-transform:uppercase;letter-spacing:.3em;margin-bottom:.5rem}
.scroll-cue .line{width:1px;height:38px;margin:0 auto;background:linear-gradient(var(--gold),transparent)}

/* =====================================================================
   SEARCH BAR
   ===================================================================== */
.searchbar-wrap{position:relative;z-index:20;margin-top:-2.6rem}
.searchbar{
  background:var(--bone);border-radius:var(--radius);
  box-shadow:var(--shadow-card);
  display:grid;grid-template-columns:repeat(3,1fr) auto;gap:.4rem;
  padding:.7rem;align-items:stretch;
}
.search-field{display:flex;flex-direction:column;gap:.15rem;padding:.7rem 1rem;border-radius:var(--radius-sm);transition:background .3s}
.search-field:hover{background:var(--bone-2)}
.search-field label{font-size:.68rem;text-transform:uppercase;letter-spacing:.16em;color:var(--stone);font-weight:700}
.search-field select{border:none;background:transparent;font-weight:600;font-size:1rem;cursor:pointer;padding:.1rem 0;color:var(--ink)}
.search-go{align-self:center}
.searchbar .btn{height:100%;border-radius:var(--radius-sm)}

/* =====================================================================
   CARDS / GRIDS
   ===================================================================== */
/* destination cards */
.dest-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,1.8vw,1.5rem)}
.dest-card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  min-height:clamp(320px,42vw,500px);display:flex;align-items:flex-end;
  box-shadow:var(--shadow-card);color:var(--bone);
}
.dest-card .media{position:absolute;inset:0;z-index:0}
.dest-card .media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.dest-card::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(10,9,8,.88),rgba(10,9,8,.1) 60%,rgba(10,9,8,.25))}
.dest-card:hover .media img{transform:scale(1.06)}
.dest-card .body{position:relative;z-index:2;padding:clamp(1.4rem,2.5vw,2.2rem);width:100%}
.dest-card .kicker{font-size:.7rem;text-transform:uppercase;letter-spacing:.22em;color:var(--gold-soft);font-weight:600}
.dest-card h3{font-size:clamp(1.8rem,3vw,2.6rem);margin-top:.3rem}
.dest-card p{color:rgba(244,239,231,.8);margin-top:.5rem;max-width:42ch;font-size:.95rem}
.dest-card .meta{display:flex;gap:1.2rem;margin-top:1rem;flex-wrap:wrap}
.dest-card .meta span{font-size:.8rem;color:rgba(244,239,231,.85);display:flex;align-items:center;gap:.4em}
.dest-card .go{margin-top:1.1rem;display:inline-flex;align-items:center;gap:.5em;font-weight:600;color:var(--gold-soft)}
.dest-card .go svg{transition:transform .35s var(--ease)}
.dest-card:hover .go svg{transform:translateX(6px)}
.dest-card.tall{grid-row:span 1}

/* feature cards (why choose etc.) */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.8rem)}
.feature{padding:1.8rem;border-radius:var(--radius);background:var(--bone);border:1px solid rgba(17,16,14,.07);box-shadow:var(--shadow-soft);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.dark .feature{background:var(--ink-2);border-color:rgba(244,239,231,.08)}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow-card)}
.feature .ico{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;background:rgba(207,154,0,.16);color:var(--gold);margin-bottom:1.1rem}
.feature .ico svg{width:24px;height:24px}
.feature h3{font-size:1.4rem}
.feature p{margin-top:.55rem;color:var(--stone-2);font-size:.95rem}
.dark .feature p{color:rgba(244,239,231,.66)}

/* generic image+text editorial split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,4rem);align-items:center}
.split.rev .split-media{order:2}
.split-media{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);aspect-ratio:4/3.4}
.split-media img{width:100%;height:100%;object-fit:cover}
.split-media .inset{position:absolute;right:-8%;bottom:-10%;width:42%;border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-card);border:5px solid var(--bone);aspect-ratio:3/4}
.dark .split-media .inset{border-color:var(--ink)}
.split-media .inset img{width:100%;height:100%;object-fit:cover}

/* =====================================================================
   CAROUSEL (packages / lodges)
   ===================================================================== */
.carousel{position:relative}
.carousel-track{
  display:flex;gap:clamp(1rem,1.8vw,1.5rem);overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:1rem;scrollbar-width:none;-ms-overflow-style:none;
}
.carousel-track::-webkit-scrollbar{display:none}
.pkg-card{
  flex:0 0 clamp(280px,80vw,360px);scroll-snap-align:start;
  background:var(--bone);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-soft);transition:transform .5s var(--ease),box-shadow .5s var(--ease);
  display:flex;flex-direction:column;
}
.dark .pkg-card{background:var(--ink-2)}
.pkg-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card)}
.pkg-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.pkg-media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.pkg-card:hover .pkg-media img{transform:scale(1.07)}
.pkg-badge{position:absolute;top:.8rem;left:.8rem;z-index:2}
.pkg-fav{position:absolute;top:.8rem;right:.8rem;z-index:2;width:34px;height:34px;border-radius:50%;background:rgba(17,16,14,.4);backdrop-filter:blur(6px);display:grid;place-items:center;color:var(--bone)}
.pkg-body{padding:1.3rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.pkg-body .loc{font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:var(--clay);font-weight:600}
.dark .pkg-body .loc{color:var(--gold-soft)}
.pkg-body h3{font-size:1.35rem;line-height:1.1}
.pkg-body .desc{font-size:.9rem;color:var(--stone-2);flex:1}
.dark .pkg-body .desc{color:rgba(244,239,231,.6)}
.pkg-foot{display:flex;align-items:center;justify-content:space-between;margin-top:.6rem;padding-top:.9rem;border-top:1px solid rgba(17,16,14,.08)}
.dark .pkg-foot{border-color:rgba(244,239,231,.1)}
.pkg-price{font-size:.85rem;color:var(--stone-2)}
.pkg-price b{font-family:var(--serif);font-size:1.3rem;color:var(--ink);display:block}
.dark .pkg-price b{color:var(--bone)}
.pkg-rate{display:flex;align-items:center;gap:.3em;font-size:.85rem;font-weight:600}
.pkg-rate svg{width:1em;height:1em;color:var(--gold)}
.carousel-nav{display:flex;gap:.6rem;margin-top:1.3rem;justify-content:flex-end}
.carousel-nav button{width:46px;height:46px;border-radius:50%;border:1px solid rgba(17,16,14,.18);display:grid;place-items:center;transition:background .3s,color .3s,border-color .3s,transform .3s var(--ease)}
.dark .carousel-nav button{border-color:rgba(244,239,231,.22)}
.carousel-nav button:hover{background:var(--gold);border-color:transparent;color:#1a160c}
.carousel-nav button:disabled{opacity:.3;cursor:default}
.carousel-nav button:disabled:hover{background:none;color:inherit;transform:none}

/* lodges grid */
.lodge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,1.8vw,1.5rem)}
.lodge{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;display:flex;align-items:flex-end;box-shadow:var(--shadow-soft)}
.lodge img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform 1s var(--ease)}
.lodge::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(10,9,8,.86),transparent 60%)}
.lodge:hover img{transform:scale(1.07)}
.lodge .body{position:relative;z-index:2;padding:1.4rem;color:var(--bone)}
.lodge .body .loc{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:var(--gold-soft);font-weight:600}
.lodge .body h3{font-size:1.5rem;margin-top:.2rem}
.lodge .body p{font-size:.85rem;color:rgba(244,239,231,.78);margin-top:.35rem}

/* =====================================================================
   TESTIMONIALS
   ===================================================================== */
.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.6rem)}
.quote{padding:2rem;border-radius:var(--radius);background:var(--ink-2);border:1px solid rgba(244,239,231,.08)}
.quote .stars{display:flex;gap:.2em;color:var(--gold);margin-bottom:1rem}
.quote .stars svg{width:1.1em;height:1.1em}
.quote blockquote{font-family:var(--serif);font-size:1.2rem;line-height:1.45;color:var(--bone)}
.quote .who{display:flex;align-items:center;gap:.8rem;margin-top:1.4rem}
.quote .who .av{width:42px;height:42px;border-radius:50%;background:var(--gold);color:#1a160c;display:grid;place-items:center;font-weight:700;font-family:var(--serif)}
.quote .who .nm{font-weight:600;color:var(--bone);font-size:.95rem}
.quote .who .mt{font-size:.8rem;color:rgba(244,239,231,.55)}

/* logos / trust strip */
.trust{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(1.5rem,5vw,3.5rem);opacity:.7}
.trust span{font-family:var(--serif);font-size:1.1rem;letter-spacing:.02em;color:var(--stone-2)}

/* =====================================================================
   STATS / CONSERVATION BAND
   ===================================================================== */
.bigstats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.bigstat .num{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.6rem);color:var(--gold);line-height:1}
.bigstat .lbl{margin-top:.5rem;font-size:.85rem;color:rgba(244,239,231,.7);text-transform:uppercase;letter-spacing:.12em}

/* =====================================================================
   CTA PREFOOTER (global)
   ===================================================================== */
.cta-band{position:relative;overflow:hidden;background:var(--ink);color:var(--bone);text-align:center}
.cta-band .cta-bg{position:absolute;inset:0;z-index:0}
.cta-band .cta-bg video,.cta-band .cta-bg img{width:100%;height:100%;object-fit:cover}
.cta-band .cta-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(10,9,8,.74),rgba(10,9,8,.82))}
.cta-band .container{position:relative;z-index:2}
.cta-band .display{color:var(--bone)}
.cta-band .lede{margin:1.2rem auto 0;color:rgba(244,239,231,.8)}
.cta-band .btn-row{margin-top:2rem;justify-content:center}

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer{background:#0C0B0A;color:rgba(244,239,231,.7);padding-block:clamp(3.5rem,6vw,5.5rem) 2rem}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:2.5rem}
.footer-brand img{height:64px;margin-bottom:1.2rem}
.footer-brand p{font-size:.92rem;max-width:34ch}
.footer-socials{display:flex;gap:.7rem;margin-top:1.4rem}
.footer-socials a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(244,239,231,.18);display:grid;place-items:center;color:var(--bone);transition:background .3s,border-color .3s,transform .3s var(--ease)}
.footer-socials a:hover{background:var(--gold);border-color:transparent;color:#1a160c;transform:translateY(-3px)}
.footer-col h4{font-family:var(--sans);font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:var(--gold-soft);font-weight:700;margin-bottom:1.1rem}
.footer-col a{display:block;padding:.32rem 0;font-size:.93rem;transition:color .3s,transform .3s var(--ease)}
.footer-col a:hover{color:var(--bone);transform:translateX(4px)}
.newsletter p{font-size:.92rem;margin-bottom:1rem}
.newsletter form{display:flex;gap:.5rem;background:rgba(244,239,231,.06);border:1px solid rgba(244,239,231,.16);border-radius:999px;padding:.35rem .35rem .35rem 1.1rem}
.newsletter input{flex:1;background:none;border:none;color:var(--bone);font-size:.9rem}
.newsletter input::placeholder{color:rgba(244,239,231,.45)}
.newsletter button{flex-shrink:0}
.footer-note{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;margin-top:3rem;padding-top:1.6rem;border-top:1px solid rgba(244,239,231,.12);font-size:.82rem}
.footer-note .legal{display:flex;gap:1.4rem;flex-wrap:wrap}
.footer-note a:hover{color:var(--bone)}

/* =====================================================================
   FLOATING BUTTONS + COOKIE
   ===================================================================== */
.floats{position:fixed;right:clamp(1rem,2.5vw,1.6rem);bottom:clamp(1rem,2.5vw,1.6rem);z-index:70;display:flex;flex-direction:column;gap:.8rem}
.fab{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow-float);transition:transform .35s var(--ease)}
.fab svg{width:26px;height:26px}
.fab.wa{background:#25D366;color:#fff}
.fab.inq{background:var(--gold);color:#1a160c}
.fab:hover{transform:translateY(-4px) scale(1.05)}
.cookie{
  position:fixed;left:clamp(1rem,2.5vw,1.6rem);bottom:clamp(1rem,2.5vw,1.6rem);z-index:80;
  max-width:380px;background:var(--ink);color:var(--bone);border-radius:var(--radius);
  padding:1.3rem 1.4rem;box-shadow:var(--shadow-card);border:1px solid rgba(244,239,231,.1);
  transform:translateY(140%);transition:transform .6s var(--ease);
}
.cookie.show{transform:translateY(0)}
.cookie p{font-size:.86rem;color:rgba(244,239,231,.78)}
.cookie .row{display:flex;gap:.6rem;margin-top:1rem}
.cookie .btn{padding:.6em 1.1em;font-size:.82rem}

/* custom cursor — themed safari emblem (varies per page) */
.cursor-dot{position:fixed;top:0;left:0;z-index:201;pointer-events:none;width:6px;height:6px;border-radius:50%;background:var(--gold);transform:translate(-50%,-50%);box-shadow:0 0 0 1px rgba(0,0,0,.25)}
.cursor-emblem{position:fixed;top:0;left:0;z-index:200;pointer-events:none;width:40px;height:40px;transform:translate(-50%,-50%) rotate(0deg);color:var(--gold);opacity:.82;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5));transition:width .35s var(--ease),height .35s var(--ease),opacity .3s}
.cursor-emblem svg{width:100%;height:100%;display:block}
.cursor-emblem.hover{width:62px;height:62px;opacity:1}
@media (hover:none){.cursor-dot,.cursor-emblem{display:none}}
/* hide the native pointer (incl. the finger over links) wherever the emblem is active */
html.has-cursor, html.has-cursor a, html.has-cursor button, html.has-cursor [role="button"], html.has-cursor .btn, html.has-cursor label, html.has-cursor summary, html.has-cursor .map-pin, html.has-cursor .iconic-tab, html.has-cursor .filter-btn{cursor:none!important}
html.has-cursor input, html.has-cursor textarea, html.has-cursor select{cursor:auto}

/* global enquiry band + footer credit */
.enquiry-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.enquiry-copy .ticks .tick{color:var(--stone-2)}
.enquiry-copy .ticks .tick svg{color:var(--gold-deep)}
@media (max-width:860px){.enquiry-grid{grid-template-columns:1fr}}
.footer-built{margin-top:1.4rem;padding-top:1.2rem;border-top:1px solid rgba(244,239,231,.08);text-align:center;font-size:.82rem;color:rgba(244,239,231,.55)}
.footer-built a{color:var(--gold-soft);font-weight:600}
.footer-built a:hover{color:var(--gold)}

/* =====================================================================
   PAGE HERO (secondary pages + destination intro)
   ===================================================================== */
.page-hero{position:relative;min-height:64vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--ink);color:var(--bone)}
.page-hero .media{position:absolute;inset:0;z-index:0}
.page-hero .media img,.page-hero .media video{width:100%;height:100%;object-fit:cover}
.page-hero .media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,9,8,.9),rgba(10,9,8,.25) 60%,rgba(10,9,8,.45))}
.page-hero .container{position:relative;z-index:2;padding-block:clamp(3rem,7vw,6rem) clamp(3rem,6vw,5rem);padding-top:calc(var(--header-h) + 2rem)}
.page-hero .display{color:var(--bone);max-width:18ch}
.page-hero .lede{color:rgba(244,239,231,.82);margin-top:1.2rem}
.breadcrumb{display:flex;gap:.5em;font-size:.8rem;color:rgba(244,239,231,.6);margin-bottom:1.2rem;letter-spacing:.02em}
.breadcrumb a:hover{color:var(--gold-soft)}

/* =====================================================================
   DESTINATION SCRUB JOURNEY
   ===================================================================== */
.dest-hero{position:relative;height:100svh;width:100%;overflow:hidden;background:var(--ink)}
.dest-hero video,.dest-hero img.hero-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.dest-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,9,8,.7),transparent 40%,rgba(10,9,8,.5))}
.dest-hero .hero-inner{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--bone);padding:0 var(--gutter)}
.dest-hero .display{color:var(--bone);margin-top:1rem}
.dest-hero .promise{margin-top:1.2rem;max-width:46ch;color:rgba(244,239,231,.85);font-size:clamp(1.05rem,1.6vw,1.3rem)}

.journey{position:relative;background:var(--ink)}
.chapter{position:relative;height:100svh;width:100%;overflow:hidden;background:var(--ink)}
.chapter video,.chapter .ch-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.chapter .grad{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(10,9,8,.78),rgba(10,9,8,.08) 45%,rgba(10,9,8,.42))}
.chapter .seam{position:absolute;inset:0;z-index:2;background:#000;opacity:1}
.chapter .panel-wrap{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;justify-content:center;padding:0 var(--gutter)}
.chapter .panel-wrap.left{align-items:flex-start;text-align:left}
.chapter .panel-wrap.right{align-items:flex-end;text-align:right}
.ch-panel{max-width:34rem;visibility:hidden}
.ch-panel .eyebrow{margin-bottom:.9rem}
.ch-panel h2{font-size:clamp(2.2rem,5.5vw,4.2rem);color:var(--bone);line-height:1.02}
.ch-panel .copy{margin-top:1.1rem;color:rgba(244,239,231,.85);font-size:clamp(1rem,1.5vw,1.2rem);max-width:30rem}
.panel-wrap.right .ch-panel .copy{margin-left:auto}
.ch-panel .chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.panel-wrap.right .ch-panel .chips{justify-content:flex-end}
.ch-progress{position:fixed;top:0;left:0;height:3px;background:var(--gold);width:0;z-index:85;transition:opacity .3s}
.journey-counter{position:absolute;bottom:1.6rem;right:var(--gutter);z-index:4;color:rgba(244,239,231,.7);font-family:var(--serif);font-size:1rem}
.journey-counter b{color:var(--gold);font-size:1.4rem}

/* reduced motion / fallback carousel chapters */
.chapter-static{position:relative;min-height:78vh;display:flex;align-items:flex-end;overflow:hidden}
.chapter-static img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.chapter-static::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(10,9,8,.88),transparent 55%)}
.chapter-static .panel-wrap{position:relative;z-index:2;padding:2.5rem var(--gutter)}

/* best time timeline */
.season-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:.35rem;margin-top:2rem}
.season-col{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.season-col .m{font-size:.72rem;color:var(--stone);font-weight:600}
.season-bar{width:100%;height:60px;border-radius:8px;background:var(--bone-2);position:relative;overflow:hidden}
.dark .season-bar{background:var(--ink-2)}
.season-bar .fill{position:absolute;bottom:0;left:0;right:0;border-radius:8px}
.season-bar .fill.peak{background:var(--gold);height:100%}
.season-bar .fill.good{background:var(--clay);opacity:.8;height:66%}
.season-bar .fill.low{background:var(--stone);opacity:.5;height:32%}
.season-legend{display:flex;gap:1.4rem;margin-top:1.4rem;flex-wrap:wrap;font-size:.82rem}
.season-legend span{display:flex;align-items:center;gap:.5em}
.season-legend i{width:14px;height:14px;border-radius:4px;display:inline-block}

/* FAQ */
.faq{max-width:780px;margin-inline:auto}
.faq details{border-bottom:1px solid rgba(17,16,14,.12);padding:1.2rem 0}
.dark .faq details{border-color:rgba(244,239,231,.12)}
.faq summary{display:flex;justify-content:space-between;align-items:center;gap:1rem;cursor:pointer;list-style:none;font-family:var(--serif);font-size:1.25rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:1px solid currentColor;display:grid;place-items:center;transition:transform .4s var(--ease);opacity:.6}
.faq details[open] summary .pm{transform:rotate(45deg);color:var(--gold);opacity:1}
.faq details p{margin-top:.9rem;color:var(--stone-2);max-width:64ch}
.dark .faq details p{color:rgba(244,239,231,.66)}

/* itinerary cards */
.itin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.6rem)}
.itin{border-radius:var(--radius);overflow:hidden;background:var(--bone);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.dark .itin{background:var(--ink-2)}
.itin:hover{transform:translateY(-6px);box-shadow:var(--shadow-card)}
.itin .im{aspect-ratio:16/10;overflow:hidden}
.itin .im img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.itin:hover .im img{transform:scale(1.06)}
.itin .bd{padding:1.4rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.itin .days{font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:var(--clay);font-weight:700}
.dark .itin .days{color:var(--gold-soft)}
.itin h3{font-size:1.3rem}
.itin ul.route{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.3rem}
.itin ul.route li{font-size:.78rem;color:var(--stone-2);display:flex;align-items:center;gap:.4em}
.itin ul.route li:not(:last-child)::after{content:"›";margin-left:.4em;color:var(--gold)}
.itin .foot{margin-top:auto;padding-top:1rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(17,16,14,.08)}
.dark .itin .foot{border-color:rgba(244,239,231,.1)}

/* =====================================================================
   FORMS
   ===================================================================== */
.form-card{background:var(--bone);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:clamp(1.6rem,3vw,2.6rem)}
.dark .form-card{background:var(--ink-2)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field.full{grid-column:1/-1}
.field label{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--stone-2)}
.field input,.field select,.field textarea{
  padding:.85rem 1rem;border-radius:var(--radius-sm);
  border:1px solid rgba(17,16,14,.16);background:#fff;
  transition:border-color .3s,box-shadow .3s;
}
.dark .field input,.dark .field select,.dark .field textarea{background:rgba(244,239,231,.04);border-color:rgba(244,239,231,.16);color:var(--bone)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(207,154,0,.18)}
.field textarea{resize:vertical;min-height:130px}
.form-card .btn{margin-top:1.4rem}

/* contact info list */
.contact-list{display:flex;flex-direction:column;gap:1.4rem}
.contact-item{display:flex;gap:1rem;align-items:flex-start}
.contact-item .ico{width:46px;height:46px;border-radius:14px;flex-shrink:0;display:grid;place-items:center;background:rgba(207,154,0,.16);color:var(--gold)}
.contact-item h4{font-family:var(--sans);font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--stone)}
.contact-item p{font-size:1.05rem;margin-top:.2rem}

/* team grid */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2vw,1.6rem)}
.member{text-align:center}
.member .ph{aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);margin-bottom:1rem}
.member .ph img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.member:hover .ph img{transform:scale(1.05)}
.member h3{font-size:1.3rem}
.member .role{color:var(--clay);font-size:.85rem;font-weight:600;margin-top:.2rem}
.dark .member .role{color:var(--gold-soft)}
.member p{font-size:.88rem;color:var(--stone-2);margin-top:.6rem}

/* steps / process */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2vw,1.8rem);counter-reset:step}
.step{position:relative;padding-top:2.5rem}
.step::before{counter-increment:step;content:"0" counter(step);position:absolute;top:0;left:0;font-family:var(--serif);font-size:2.4rem;color:var(--gold);opacity:.5}
.step h3{font-size:1.25rem}
.step p{margin-top:.5rem;color:var(--stone-2);font-size:.92rem}
.dark .step p{color:rgba(244,239,231,.66)}

/* prose */
.prose p{margin-bottom:1.1rem;color:var(--stone-2)}
.dark .prose p{color:rgba(244,239,231,.72)}
.prose p:first-child{font-size:1.2rem;color:var(--ink)}
.dark .prose p:first-child{color:var(--bone)}

/* utility */
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}
.maxw-md{max-width:680px}
.hide-mobile{display:initial}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .now-showing{max-width:440px;aspect-ratio:16/11}
  .feature-grid,.quote-grid,.lodge-grid,.itin-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
  .mega{display:none}
}
@media (max-width:900px){
  .nav,.lang,.header-cta{display:none}
  .hamburger{display:flex}
  .bigstats{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  :root{--header-h:70px}
  .brand .logo{height:40px}
  .cinema-hero{min-height:560px}
  .cinema-hero .ch-meta{display:none}
  .cinema-hero h1{font-size:clamp(2.6rem,11vw,3.6rem)}
  .cinema-hero .container{padding-bottom:clamp(4.5rem,12vh,7rem)}
  .now-showing{aspect-ratio:4/3}
  .dest-grid,.split{grid-template-columns:1fr}
  .split.rev .split-media{order:0}
  .split-media .inset{display:none}
  .searchbar{grid-template-columns:1fr}
  .searchbar-wrap{margin-top:-1.5rem}
  .feature-grid,.quote-grid,.lodge-grid,.itin-grid,.form-grid,.team-grid,.steps{grid-template-columns:1fr}
  .stats{flex-wrap:wrap;gap:1.2rem}
  .season-grid{grid-template-columns:repeat(6,1fr);gap:.5rem 1rem}
  .footer-top{grid-template-columns:1fr}
  .chapter .panel-wrap.right{align-items:flex-start;text-align:left}
  .panel-wrap.right .ch-panel .copy,.panel-wrap.right .ch-panel .chips{margin-left:0;justify-content:flex-start}
  .floats .fab{width:50px;height:50px}
  .cookie{max-width:none;left:1rem;right:1rem}
}

/* =====================================================================
   REDUCED MOTION
   ===================================================================== */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1!important;transform:none!important}
  .cursor-dot,.cursor-ring{display:none}
}

/* =====================================================================
   SPLIT "DMC" HERO  (About page — theluxuryafrica concept)
   ===================================================================== */
.split-hero{position:relative;background:var(--ink);color:var(--bone);min-height:100svh;display:flex;align-items:center;overflow:hidden;padding-block:calc(var(--header-h) + 2.5rem) 3rem}
.split-hero .container{width:100%}
.split-hero .hero-copy{max-width:48ch}
.split-hero .display{color:var(--bone);margin-top:.6rem}
.ns-wrap{display:flex;flex-direction:column}
.dmc-band{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:.7rem;padding:.95rem 1.3rem;border:1px solid rgba(244,239,231,.14);border-radius:var(--radius);background:rgba(17,16,14,.55);font-size:.84rem;color:rgba(244,239,231,.72)}
.dmc-band b{color:var(--bone)}
.dmc-band .dmc-tag{color:var(--gold-soft);font-weight:600;letter-spacing:.04em;white-space:nowrap}

/* =====================================================================
   CONTRAST HARDENING — stronger media scrims + subtle text halo
   (best practice: darken the overlay AND give text a soft edge)
   ===================================================================== */
.cinema-hero::after{background:linear-gradient(to top,rgba(6,5,4,.9) 0%,rgba(6,5,4,.32) 46%,rgba(6,5,4,.6) 100%),linear-gradient(90deg,rgba(6,5,4,.62),rgba(6,5,4,.04) 62%)}
.dest-hero::after{background:linear-gradient(to top,rgba(6,5,4,.82),rgba(6,5,4,.22) 45%,rgba(6,5,4,.62))}
.page-hero .media::after{background:linear-gradient(to top,rgba(6,5,4,.92),rgba(6,5,4,.42) 60%,rgba(6,5,4,.62))}
.anchored::after{background:linear-gradient(to bottom,rgba(6,5,4,.62),rgba(6,5,4,.78))}
.chapter .grad{background:linear-gradient(to top,rgba(6,5,4,.82),rgba(6,5,4,.12) 45%,rgba(6,5,4,.52))}
.dest-card::after{background:linear-gradient(to top,rgba(6,5,4,.92),rgba(6,5,4,.1) 62%,rgba(6,5,4,.32))}
.lodge::after{background:linear-gradient(to top,rgba(6,5,4,.9),transparent 58%)}
.now-showing::after{background:linear-gradient(to top,rgba(6,5,4,.78),transparent 52%)}

.cinema-hero h1,.cinema-hero .sub,.cinema-hero .eyebrow,.cinema-hero .ch-meta .where,.cinema-hero .ch-meta .what,
.dest-hero .display,.dest-hero .promise,.dest-hero .eyebrow,.dest-hero .scroll-cue,
.page-hero .display,.page-hero .lede,.page-hero .breadcrumb,.page-hero .eyebrow,
.split-hero .display,.split-hero .lede,.split-hero .eyebrow,
.ch-panel h2,.ch-panel .copy,.ch-panel .eyebrow,
.anchored .quote-lead,.anchored .lede,.anchored .eyebrow,
.dest-card h3,.dest-card p,.dest-card .kicker,.dest-card .go,
.lodge .body h3,.lodge .body p,.lodge .body .loc{
  text-shadow:0 2px 16px rgba(0,0,0,.45),0 1px 4px rgba(0,0,0,.32);
}

/* =====================================================================
   DYNAMIC SAFARI / ACTIVITY PAGES (CMS-driven)
   ===================================================================== */
.meta-strip{display:flex;flex-wrap:wrap;gap:clamp(1.2rem,3vw,2.4rem);margin-top:1.6rem}
.meta-strip .m{display:flex;flex-direction:column;gap:.2rem}
.meta-strip .m .k{font-size:.68rem;text-transform:uppercase;letter-spacing:.18em;color:var(--gold-soft)}
.meta-strip .m .v{font-size:1.05rem;color:var(--bone);font-weight:600}
.filter-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2.2rem}
.filter-btn{padding:.55em 1.1em;border-radius:999px;border:1px solid rgba(17,16,14,.16);font-weight:600;font-size:.85rem;background:transparent;transition:background .3s var(--ease),color .3s,border-color .3s,transform .3s var(--ease)}
.filter-btn:hover{transform:translateY(-2px)}
.filter-btn.active{background:var(--ink);color:var(--bone);border-color:var(--ink)}
.itin .desc{font-size:.9rem;color:var(--stone-2);margin:.1rem 0 .2rem}
.itin .price-row{display:flex;align-items:baseline;gap:.4em}
.itin .price-row b{font-family:var(--serif);font-size:1.25rem;color:var(--ink)}
.is-hidden{display:none!important}
/* itinerary timeline */
.itinerary{margin-top:2.5rem;border-left:2px solid rgba(17,16,14,.1);padding-left:2.2rem;display:flex;flex-direction:column;gap:1.7rem;max-width:760px}
.dark .itinerary{border-color:rgba(244,239,231,.14)}
.day{position:relative}
.day::before{content:attr(data-day);position:absolute;left:-2.2rem;top:-.1rem;transform:translateX(-52%);width:2.5rem;height:2.5rem;border-radius:50%;background:var(--gold);color:#1a160c;display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:.95rem;box-shadow:0 0 0 5px var(--bone)}
.dark .day::before{box-shadow:0 0 0 5px var(--ink)}
.day h4{font-family:var(--serif);font-size:1.3rem;line-height:1.1}
.day p{margin-top:.4rem;color:var(--stone-2)}
.dark .day p{color:rgba(244,239,231,.7)}
/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem;margin-top:2rem}
.gallery a{display:block;border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-soft)}
.gallery img{width:100%;height:100%;aspect-ratio:1/1;object-fit:cover;transition:transform .8s var(--ease)}
.gallery a:hover img{transform:scale(1.06)}
.gallery a:first-child{grid-column:span 2;grid-row:span 2}
/* inclusions */
.incl-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3rem);margin-top:1.5rem}
.incl h4{display:flex;align-items:center;gap:.5em;font-family:var(--sans);font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--stone-2);margin-bottom:1rem}
.incl ul{display:flex;flex-direction:column;gap:.7rem}
.incl li{display:flex;gap:.6em;align-items:flex-start;color:var(--stone-2);font-size:.96rem}
.incl li svg{width:1.1em;height:1.1em;color:var(--gold);margin-top:.15em;flex-shrink:0}
.incl.exc li svg{color:var(--clay)}
.sidebar-card{position:sticky;top:calc(var(--header-h) + 1.2rem);background:var(--bone);border:1px solid rgba(17,16,14,.08);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:1.6rem}
.sidebar-card .price{font-family:var(--serif);font-size:2rem;color:var(--ink)}
.sidebar-card .price small{font-size:.85rem;color:var(--stone-2);font-family:var(--sans)}
.detail-grid{display:grid;grid-template-columns:1.7fr .9fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
@media (max-width:900px){.detail-grid{grid-template-columns:1fr}.sidebar-card{position:static}}
@media (max-width:760px){.gallery{grid-template-columns:repeat(2,1fr)}.incl-grid{grid-template-columns:1fr}}

/* =====================================================================
   SAFARI ITINERARY (animal-icon day markers + lodge) + ROUTE MAP
   ===================================================================== */
.itin-days{margin-top:1.6rem;display:flex;flex-direction:column;gap:.4rem;position:relative}
.iday{display:grid;grid-template-columns:auto 1fr;gap:1.2rem;position:relative;padding-bottom:1.4rem}
.iday::before{content:"";position:absolute;left:1.55rem;top:3.2rem;bottom:-.4rem;width:2px;background:rgba(17,16,14,.1)}
.dark .iday::before{background:rgba(244,239,231,.12)}
.iday:last-child::before{display:none}
.iday-mark{display:flex;flex-direction:column;align-items:center;gap:.35rem;width:3.1rem}
.iday-ico{width:3.1rem;height:3.1rem;border-radius:50%;background:var(--gold);color:#1a160c;display:grid;place-items:center;box-shadow:0 6px 16px -8px rgba(207,154,0,.7);flex-shrink:0}
.iday-ico svg{width:1.7rem;height:1.7rem}
.iday-num{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--stone)}
.iday-body{padding-top:.15rem}
.iday-body h4{font-family:var(--serif);font-size:1.3rem;line-height:1.1}
.iday-body p{margin-top:.35rem;color:var(--stone-2)}
.dark .iday-body p{color:rgba(244,239,231,.7)}
.iday-lodge{display:inline-flex;align-items:center;gap:.45em;margin-top:.6rem!important;font-size:.84rem;color:var(--clay);font-weight:600}
.dark .iday-lodge{color:var(--gold-soft)}
.iday-lodge svg{width:1.05em;height:1.05em}

/* route map */
.route-wrap{display:grid;grid-template-columns:1.3fr .9fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;margin-top:2.5rem}
.route-map{position:relative;width:100%;max-width:560px;aspect-ratio:1/1;margin-inline:auto}
.route-sil{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;opacity:.92;filter:drop-shadow(0 16px 36px rgba(17,16,14,.22))}
.route-lines{position:absolute;inset:0;width:100%;height:100%;z-index:1;overflow:visible}
.route-lines polyline{fill:none;stroke:var(--gold);stroke-width:.7;stroke-dasharray:2 2;vector-effect:non-scaling-stroke;opacity:.9}
.route-stop{position:absolute;transform:translate(-50%,-50%);z-index:2}
.rs-dot{display:grid;place-items:center;width:1.7rem;height:1.7rem;border-radius:50%;background:var(--ink);color:var(--bone);font-size:.78rem;font-weight:700;box-shadow:0 0 0 3px var(--bone-2)}
.rs-label{position:absolute;left:50%;top:calc(100% + .25rem);transform:translateX(-50%);white-space:nowrap;font-size:.72rem;font-weight:600;color:var(--ink);text-align:center;text-shadow:0 1px 4px var(--bone-2)}
.rs-label i{display:block;font-style:normal;font-weight:400;color:var(--stone-2);font-size:.66rem}
.route-legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.2rem;counter-reset:rt}
.route-legend li{display:flex;align-items:center;gap:.8rem;padding:.7rem .3rem;border-bottom:1px solid rgba(17,16,14,.08)}
.route-legend .rs-num{width:1.7rem;height:1.7rem;border-radius:50%;background:var(--gold);color:#1a160c;display:grid;place-items:center;font-weight:700;font-size:.8rem;flex-shrink:0}
.route-legend .rs-place{display:flex;flex-direction:column}
.route-legend b{font-family:var(--serif);font-size:1.05rem}
@media (max-width:820px){.route-wrap{grid-template-columns:1fr}.route-map{max-width:440px}}

/* =====================================================================
   TASTE REFINEMENTS — typography polish, legible gold, luxe details
   ===================================================================== */
:root{--gold-deep:#9c7400}
html{scroll-behavior:smooth}
body{font-optical-sizing:auto;letter-spacing:.002em;text-rendering:optimizeLegibility}
.display,.title,h1,h2,h3,h4{font-optical-sizing:auto;font-variation-settings:"opsz" 110}
::selection{background:var(--gold);color:#1a160c}
::-moz-selection{background:var(--gold);color:#1a160c}

/* deeper gold for small labels on light bg (readability + class), keep bright gold on dark */
.eyebrow{color:var(--gold-deep)}
.eyebrow.on-dark{color:var(--gold-soft)}
.dark .eyebrow,.anchored .eyebrow,.split-hero .eyebrow,.cinema-hero .eyebrow,.dest-hero .eyebrow,.page-hero .eyebrow,.cta-band .eyebrow{color:var(--gold-soft)}

/* warmer card framing + refined hover */
.feature,.itin,.pkg-card{border:1px solid rgba(17,16,14,.06)}
.dark .feature,.dark .itin,.dark .pkg-card{border-color:rgba(244,239,231,.07)}
.section.bone-2{background:linear-gradient(180deg,var(--bone-2),#e7dece)}
.btn:active{transform:translateY(0) scale(.985)}
.dest-card,.lodge,.itin,.pkg-card,.feature,.member .ph,.split-media,.now-showing{transition:transform .55s var(--ease),box-shadow .55s var(--ease)}

/* refined eyebrow tick — a short gold rule before section labels */
.section-head>.eyebrow::before{content:"";display:inline-block;width:1.6rem;height:1px;background:currentColor;margin-right:.7em;vertical-align:middle;opacity:.6}

/* slim luxury scrollbar (pointer devices) */
@media (hover:hover){
  html{scrollbar-width:thin;scrollbar-color:var(--stone) transparent}
  ::-webkit-scrollbar{width:11px;height:11px}
  ::-webkit-scrollbar-track{background:transparent}
  ::-webkit-scrollbar-thumb{background:var(--stone);border-radius:10px;border:3px solid var(--bone);background-clip:padding-box}
  ::-webkit-scrollbar-thumb:hover{background:var(--gold-deep);background-clip:padding-box}
}

/* nav underline flourish on hover (desktop) */
.nav-link{position:relative}
.nav-link::after{content:"";position:absolute;left:.9em;right:.9em;bottom:.35em;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;opacity:.5;transition:transform .35s var(--ease)}
.nav-item:not([data-mega]) .nav-link:hover::after{transform:scaleX(1)}

/* =====================================================================
   OUR ICONIC DESTINATIONS — homepage tabbed showcase
   ===================================================================== */
.iconic-tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:.25rem;background:rgba(17,16,14,.05);border-radius:999px;padding:.35rem;width:fit-content;max-width:100%;margin:2.6rem auto 0}
.iconic-tab{padding:.6em 1.25em;border-radius:999px;font-weight:600;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--stone-2);transition:background .35s var(--ease),color .35s var(--ease)}
.iconic-tab.active{background:var(--ink);color:var(--bone)}
.iconic-stage{position:relative;display:flex;align-items:center;justify-content:center;gap:clamp(.5rem,2vw,1.6rem);margin-top:2.6rem}
.iconic-ghost{flex:1;text-align:center;font-family:var(--serif);font-size:clamp(1.2rem,3vw,2.6rem);letter-spacing:.12em;color:rgba(17,16,14,.13);text-transform:uppercase;white-space:nowrap;overflow:hidden;cursor:pointer;user-select:none;transition:color .3s}
.iconic-ghost:hover{color:rgba(17,16,14,.3)}
.iconic-feature{position:relative;display:block;width:min(880px,76vw);aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);flex-shrink:0}
.iconic-feature img{width:100%;height:100%;object-fit:cover;transition:opacity .35s var(--ease),transform 1.4s var(--ease)}
.iconic-feature:hover img{transform:scale(1.05)}
.iconic-feature::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(6,5,4,.55),rgba(6,5,4,.1) 45%,rgba(6,5,4,.2))}
.iconic-name{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:430;font-size:clamp(2.2rem,7vw,5.5rem);letter-spacing:.14em;color:var(--bone);text-transform:uppercase;text-shadow:0 4px 30px rgba(0,0,0,.55);text-align:center;pointer-events:none;padding:0 .3em}
.iconic-arrow{width:48px;height:48px;border-radius:50%;border:1px solid rgba(17,16,14,.18);display:grid;place-items:center;flex-shrink:0;transition:background .3s,color .3s,border-color .3s,transform .3s var(--ease)}
.iconic-arrow.prev{transform:scaleX(-1)}
.iconic-arrow:hover{background:var(--gold);border-color:transparent;color:#1a160c}
.iconic-cap{text-align:center;max-width:62ch;margin:2.2rem auto 0;display:flex;flex-direction:column;align-items:center;gap:1.3rem}
@media (max-width:900px){
  .iconic-ghost{display:none}
  .iconic-feature{width:88vw}
}

/* =====================================================================
   SEAMLESS JOURNEY STAGE (crossfading hero + chapters) + FLAG + MAP
   ===================================================================== */
.journey-stage{position:relative;height:100svh;width:100%;overflow:hidden;background:var(--ink)}
.scene{position:absolute;inset:0;will-change:opacity}
.scene .scene-vid,.scene .hero-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.scene .grad{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(6,5,4,.8),rgba(6,5,4,.12) 45%,rgba(6,5,4,.5))}
.scene .panel-wrap{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;justify-content:center;padding:0 var(--gutter)}
.scene .panel-wrap.left{align-items:flex-start;text-align:left}
.scene .panel-wrap.right{align-items:flex-end;text-align:right}
.scene-title{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--bone);padding:0 var(--gutter)}
.scene-title .display{color:var(--bone);margin-top:1rem}
.scene-title .promise{margin-top:1.2rem;max-width:46ch;color:rgba(244,239,231,.88);font-size:clamp(1.05rem,1.6vw,1.3rem);text-shadow:0 2px 16px rgba(0,0,0,.45)}
.scene-title .display,.scene-title .eyebrow,.scene-title .promise{text-shadow:0 2px 18px rgba(0,0,0,.5)}
.dest-flag{display:inline-block;margin-bottom:.4rem}
.dest-flag img{width:56px;height:auto;border-radius:5px;box-shadow:0 3px 14px rgba(0,0,0,.5);display:block}
.dest-hero .hero-inner .dest-flag{margin-bottom:.6rem}

/* interactive map */
.map-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.map-stage{position:relative;width:100%;max-width:560px;aspect-ratio:1/1;margin-inline:auto}
.map-silhouette{position:absolute;inset:0;color:#2c2b26;filter:drop-shadow(0 18px 40px rgba(17,16,14,.25))}
.map-silhouette svg{width:100%;height:100%;display:block}
.map-pins{position:absolute;inset:0;z-index:2}
.map-pin{position:absolute;transform:translate(-50%,-50%);width:auto;height:auto;z-index:2}
.pin-dot{display:block;width:14px;height:14px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(207,154,0,.28);transition:transform .3s var(--ease),box-shadow .3s}
.pin-dot::after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 0 rgba(207,154,0,.5);animation:pinpulse 2.4s infinite}
.no-motion .pin-dot::after{animation:none}
@keyframes pinpulse{0%{box-shadow:0 0 0 0 rgba(207,154,0,.45)}70%{box-shadow:0 0 0 14px rgba(207,154,0,0)}100%{box-shadow:0 0 0 0 rgba(207,154,0,0)}}
.map-pin:hover{z-index:5}
.map-pin:hover .pin-dot,.map-pin.active .pin-dot{transform:scale(1.35);box-shadow:0 0 0 7px rgba(207,154,0,.32)}
.pin-card{position:absolute;bottom:150%;left:50%;transform:translateX(-50%) translateY(8px);width:210px;background:var(--bone);border-radius:var(--radius-sm);box-shadow:var(--shadow-card);overflow:hidden;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s var(--ease),transform .3s var(--ease)}
.map-pin:hover .pin-card,.map-pin:focus-visible .pin-card,.map-pin.active .pin-card{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.pin-card img{width:100%;height:118px;object-fit:cover;display:block}
.pin-meta{display:block;padding:.65rem .85rem;text-align:left}
.pin-meta b{font-family:var(--serif);font-size:1.02rem;display:block;line-height:1.1}
.pin-meta i{font-style:normal;font-size:.78rem;color:var(--stone-2);display:block;margin-top:.2rem}
.map-legend{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;margin-top:1.9rem}
.map-legend li{display:flex;align-items:center;gap:.55em;font-size:.92rem;color:var(--stone-2);cursor:pointer;transition:color .3s}
.map-legend li .dot{width:9px;height:9px;border-radius:50%;background:var(--gold);flex-shrink:0}
.map-legend li:hover{color:var(--ink)}
@media (max-width:860px){.map-grid{grid-template-columns:1fr}.map-stage{max-width:420px}}

/* =====================================================================
   HERO -> SECTION SOFT FADE (static pages only; injected by JS)
   A gentle feathered dissolve from the hero photo into the next
   section's colour, with a faint static gold horizon line.
   ===================================================================== */
.hero-blend{position:absolute;left:0;right:0;bottom:-1px;height:30%;z-index:2;pointer-events:none}
.hero-blend .hb-line{position:absolute;top:0;left:0;right:0;height:1px;opacity:.3;background:linear-gradient(90deg,transparent,rgba(207,154,0,.55),transparent)}

/* =====================================================================
   PRE-FOOTER — ONE pinned, scroll-scrubbed section:
   logo fills screen → scroll zooms INTO the logo → words appear → video
   reveals & plays. (Falls back to a clean static stack without motion.)
   ===================================================================== */
.prefooter{position:relative;background:var(--ink);color:var(--bone);overflow:hidden}
.prefooter-stage{position:relative}
.pf-layer{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:clamp(3.5rem,8vw,6rem) var(--gutter)}
.pf-logo{width:min(300px,54vw);height:auto;filter:drop-shadow(0 10px 36px rgba(0,0,0,.55));will-change:transform,opacity}
.pf-words-layer .display{color:var(--bone)}
.pf-words-layer .lede{margin-top:1.2rem;margin-inline:auto;max-width:60ch}
.pf-words-layer .btn-row{margin-top:2rem;justify-content:center}
.pf-video-layer{padding:0;position:relative;height:min(64vh,620px)}
.pf-video-layer video{width:100%;height:100%;object-fit:cover;display:block}
.pf-reel-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,5,4,.55),transparent 42%)}
.pf-reel-cap{position:absolute;left:clamp(1rem,4vw,3rem);bottom:clamp(1rem,4vw,2.5rem);z-index:2;display:flex;gap:.6rem;flex-wrap:wrap}
.prefooter .scroll-cue{z-index:6}
.prefooter:not(.animate) .scroll-cue{display:none}

/* animated (pinned scrub) state — layers stack & are driven by JS */
.prefooter.animate .prefooter-stage{height:100svh;overflow:hidden}
.prefooter.animate .pf-layer{position:absolute;inset:0;height:100svh;padding:0 var(--gutter);will-change:transform,opacity}
.prefooter.animate .pf-logo-layer{z-index:1}
.prefooter.animate .pf-words-layer{z-index:2;opacity:0;visibility:hidden}
.prefooter.animate .pf-video-layer{z-index:3;opacity:0;visibility:hidden;will-change:transform,opacity,clip-path}
@media (max-width:760px){.pf-logo{width:64vw}.pf-video-layer{height:54vh}}
