/* ============================================================
   CONNECTING SAFARIS — shared site styles · v3
   "Field Editorial" — ivory paper, deep forest, burnt clay.
   Fraunces display · Manrope text · Space Mono labels
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400;1,9..144,500;1,9..144,600&family=Manrope:wght@400;500;600;700;800&family=Space+Mono:ital,wght@0,400;0,700;1,400&display=swap');

:root{
  --paper:#f2ecdf;
  --paper-2:#f9f5ea;
  --paper-3:#e9e1cd;
  --ink:#1d1a13;
  --ink-soft:#4d463a;
  --ink-faint:#82775f;
  --line:#ddd2ba;
  --line-strong:#c2b394;
  --forest:#1b2a20;
  --forest-deep:#121f16;
  --forest-mid:#27392c;
  --clay:#a8512a;
  --clay-deep:#8c3f1d;
  --clay-soft:#eeddc8;
  --gold:#c29a4d;
  --gold-soft:#d8b86e;
  --wa:#17a34a;
  --card:#fbf8f0;
  --night:#14110b;
  --shadow-sm:0 1px 2px rgba(29,26,19,.05), 0 8px 20px -14px rgba(29,26,19,.25);
  --shadow:0 2px 4px rgba(29,26,19,.05), 0 22px 48px -24px rgba(29,26,19,.38);
  --shadow-lg:0 34px 80px -32px rgba(29,26,19,.5);
  --maxw:1280px;
  --r:6px;
  --serif:"Fraunces",Georgia,serif;
  --sans:"Manrope",system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

h1,h2,h3{font-family:var(--serif);font-weight:400;letter-spacing:-.01em;line-height:1.02;margin:0;}
h1 em,h2 em,h3 em{font-style:italic;color:var(--clay);}
.dark h1 em,.dark h2 em{color:var(--gold-soft);}
p{margin:0 0 1em;text-wrap:pretty;}
.mono{font-family:var(--mono);}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--mono);font-weight:500;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;
  padding:15px 26px;border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s;line-height:1;white-space:nowrap;}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--clay);color:#fff7ec;box-shadow:0 10px 26px -12px rgba(168,81,42,.85);}
.btn-primary:hover{background:var(--clay-deep);}
.btn-dark{background:var(--ink);color:var(--paper);}
.btn-dark:hover{background:#000;}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong);}
.btn-ghost:hover{border-color:var(--ink);background:rgba(255,255,255,.45);}
.btn-light{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.4);backdrop-filter:blur(4px);}
.btn-light:hover{background:rgba(255,255,255,.2);}
.btn-wa{background:var(--wa);color:#fff;box-shadow:0 10px 26px -12px rgba(23,163,74,.85);}
.btn-wa:hover{background:#12873d;}
.btn-lg{font-size:13.5px;padding:18px 32px;}
.btn svg{width:17px;height:17px;flex:none;}

/* ---------- eyebrow / headings ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);
  font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--clay);font-weight:500;margin-bottom:18px;}
.eyebrow::before{content:"✦";font-size:10px;color:var(--gold);}
.eyebrow.center{justify-content:center;}
.section-h{font-size:clamp(34px,4.6vw,56px);}
.lead{font-size:clamp(18px,2vw,21px);color:var(--ink-soft);max-width:60ch;line-height:1.55;}

section{position:relative;}
.pad{padding:clamp(70px,9vw,124px) 0;}
.pad-sm{padding:clamp(52px,6vw,84px) 0;}
.center{text-align:center;}
.mx-auto{margin-left:auto;margin-right:auto;}

/* ---------- top announcement bar ---------- */
.topbar{background:var(--forest-deep);color:#cfc6ad;font-size:12.5px;text-align:center;padding:9px 16px;
  font-family:var(--mono);letter-spacing:.04em;}
.topbar a{color:var(--gold-soft);font-weight:500;border-bottom:1px solid rgba(216,184,110,.4);}
.topbar a:hover{color:#fff;}
.topbar strong{color:#fff;font-weight:500;}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:100;transition:background .3s ease, box-shadow .3s ease, border-color .3s;
  border-bottom:1px solid transparent;}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:76px;gap:20px;}
.nav.solid{background:rgba(242,236,223,.93);backdrop-filter:blur(12px);border-bottom-color:var(--line);box-shadow:0 4px 20px -16px rgba(0,0,0,.4);}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-size:23px;color:var(--ink);letter-spacing:0;}
.brand .dot{width:36px;height:36px;border-radius:50%;flex:none;display:block;
  box-shadow:0 2px 10px -3px rgba(18,31,22,.55);}
.footer .brand .dot{box-shadow:0 0 0 1px rgba(255,255,255,.14);}
.nav.on-hero:not(.solid) .brand{color:#fff;}
.nav.on-hero:not(.solid) .nav-links a{color:rgba(255,255,255,.88);}
.nav.on-hero:not(.solid) .nav-links a:hover{color:#fff;}
.nav.on-hero:not(.solid) .hamb span{background:#fff;}
.nav-links{display:flex;align-items:center;gap:32px;}
.nav-links a{font-family:var(--mono);font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;color:var(--ink-soft);transition:color .15s;position:relative;}
.nav-links a:hover{color:var(--ink);}
.nav-links a.active{color:var(--clay);}
.nav-right{display:flex;align-items:center;gap:14px;}
.hamb{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;}
.hamb span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.2s;}
.mobile-menu{display:none;position:fixed;inset:0;z-index:99;background:var(--paper);padding:96px 28px 40px;flex-direction:column;gap:6px;}
.mobile-menu.open{display:flex;}
.mobile-menu a{font-family:var(--serif);font-size:30px;padding:14px 0;border-bottom:1px solid var(--line);color:var(--ink);}
.mobile-menu .btn{margin-top:22px;justify-content:center;font-family:var(--mono);font-size:13px;}

/* ---------- placeholder / image-slot framing ---------- */
image-slot{--ph-bg:repeating-linear-gradient(135deg,#e7decb 0 16px,#e0d6bf 16px 32px);}
.hero-media,.phero-media{background:linear-gradient(165deg,#33452f 0%,#1b2a20 55%,#14110b 100%);}
.cat,.dest{background:var(--forest-mid);}
.cta-band-media{background:linear-gradient(120deg,#27392c,#14110b);}
.hero-media image-slot::part(empty),
.phero-media image-slot::part(empty),
.cat image-slot::part(empty),
.dest image-slot::part(empty),
.cta-band-media image-slot::part(empty){color:rgba(255,255,255,.6);}
.ph{position:relative;overflow:hidden;
  background:repeating-linear-gradient(135deg,#e7decb 0 16px,#e0d6bf 16px 32px);}
.ph .ph-lbl{position:absolute;left:12px;bottom:12px;font-family:var(--mono);font-size:11px;
  letter-spacing:.04em;color:#8a7d64;background:rgba(249,245,234,.85);padding:4px 9px;border-radius:4px;text-transform:uppercase;}

/* ---------- hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden;margin-top:-76px;padding-top:76px;}
.hero-media{position:absolute;inset:0;z-index:0;}
.hero-media image-slot{width:100%;height:100%;}
.hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(18,17,12,.45) 0%,rgba(18,17,12,.12) 40%,rgba(18,17,12,.82) 100%);}
.hero .wrap{position:relative;z-index:2;padding-bottom:clamp(56px,7vw,84px);padding-top:60px;width:100%;}
.hero .eyebrow{color:var(--gold-soft);}
.hero .eyebrow::before{color:var(--gold-soft);}
.hero h1{font-size:clamp(48px,8.4vw,112px);max-width:13ch;text-shadow:0 2px 40px rgba(0,0,0,.35);}
.hero h1 em{color:var(--gold-soft);}
.hero .sub{font-size:clamp(17px,2.1vw,21px);max-width:52ch;margin:26px 0 34px;color:rgba(255,255,255,.92);}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.hero-trust{margin-top:38px;padding-top:22px;border-top:1px solid rgba(255,255,255,.22);
  display:flex;flex-wrap:wrap;gap:10px 34px;font-size:12px;color:rgba(255,255,255,.85);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;}
.hero-trust span{display:inline-flex;align-items:center;gap:9px;}
.hero-trust span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--gold-soft);}
.hero-coords{position:absolute;right:34px;bottom:34px;z-index:2;font-family:var(--mono);font-size:11px;
  letter-spacing:.18em;color:rgba(255,255,255,.55);text-transform:uppercase;writing-mode:vertical-rl;}

/* page hero (interior, shorter) */
.phero{position:relative;color:#fff;overflow:hidden;margin-top:-76px;padding:152px 0 64px;display:flex;align-items:flex-end;min-height:48vh;}
.phero-media{position:absolute;inset:0;z-index:0;}
.phero-media image-slot{width:100%;height:100%;}
.phero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(18,17,12,.5),rgba(18,17,12,.74));}
.phero .wrap{position:relative;z-index:2;}
.phero h1{font-size:clamp(40px,6vw,76px);max-width:18ch;}
.phero .sub{font-size:clamp(17px,2vw,20px);max-width:56ch;margin-top:18px;color:rgba(255,255,255,.9);}
.crumb{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:16px;}
.crumb a{color:rgba(255,255,255,.65);}

/* ---------- stats strip ---------- */
.stats{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);}
.stat{padding:30px 26px;border-left:1px solid var(--line);}
.stat:first-child{border-left:none;}
.stat .sv{font-family:var(--serif);font-size:clamp(30px,3.4vw,44px);line-height:1;color:var(--ink);}
.stat .sv em{font-style:italic;color:var(--clay);}
.stat .sk{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-top:8px;}

/* legacy trustbar (kept for compatibility) */
.trustbar{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.trustbar .wrap{display:flex;flex-wrap:wrap;gap:18px 40px;justify-content:space-between;align-items:center;padding:20px 28px;}
.trust-item{display:flex;align-items:center;gap:11px;font-size:14px;color:var(--ink-soft);font-weight:500;}
.trust-item .ic{width:30px;height:30px;border-radius:8px;background:var(--clay-soft);color:var(--clay);display:flex;align-items:center;justify-content:center;flex:none;}
.trust-item .ic svg{width:17px;height:17px;}

/* ---------- marquee ribbon ---------- */
.marquee{background:var(--forest-deep);color:#d9d0b8;overflow:hidden;padding:16px 0;border-top:1px solid rgba(216,184,110,.18);border-bottom:1px solid rgba(216,184,110,.18);}
.marquee-track{display:flex;width:max-content;animation:marq 48s linear infinite;}
.marquee span{font-family:var(--mono);font-size:12px;letter-spacing:.3em;text-transform:uppercase;white-space:nowrap;padding:0 26px;display:inline-flex;align-items:center;gap:0;}
.marquee span::after{content:"✦";color:var(--gold);margin-left:52px;font-size:10px;}
@keyframes marq{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media (prefers-reduced-motion: reduce){.marquee-track{animation:none;}}

/* ---------- category cards ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.cat{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);display:block;
  aspect-ratio:4/5;transition:transform .25s ease, box-shadow .25s;}
.cat:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.cat image-slot{position:absolute;inset:0;width:100%;height:100%;}
.cat .veil{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(18,17,12,0) 38%,rgba(18,17,12,.88));pointer-events:none;}
.cat .cat-body{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:24px;color:#fff;}
.cat .cat-count{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);}
.cat h3{font-size:30px;margin:8px 0 5px;color:#fff;}
.cat .cat-from{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:rgba(255,255,255,.8);}
.cat .arrow{position:absolute;top:18px;right:18px;z-index:3;width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.14);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;color:#fff;
  border:1px solid rgba(255,255,255,.32);transition:.2s;}
.cat:hover .arrow{background:var(--clay);border-color:var(--clay);transform:rotate(-45deg);}
.cat .arrow svg{width:17px;height:17px;}

/* ---------- tour cards (grid) ---------- */
.tours-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.tcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;transition:transform .22s ease, box-shadow .22s, border-color .22s;}
.tcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-strong);}
.tcard .tmedia{position:relative;aspect-ratio:3/2;background:var(--forest-mid);}
.tcard .tmedia image-slot{width:100%;height:100%;}
.tcard .tbadge{position:absolute;top:12px;left:12px;z-index:3;background:rgba(18,17,12,.85);color:#f1e9d6;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;padding:6px 11px;border-radius:999px;backdrop-filter:blur(3px);}
.tcard .tbadge.season{background:var(--clay);}
.tcard .tbody{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1;}
.tcard .tcat{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.tcard h3{font-size:26px;margin:9px 0 9px;}
.tcard .tdesc{font-size:14.5px;color:var(--ink-soft);margin:0 0 16px;flex:1;}
.tcard .tmeta{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px;}
.tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--forest-mid);background:#e8ecdd;
  border:1px solid #d2dbc2;border-radius:999px;padding:4px 11px;}
.tag.season{color:var(--clay-deep);background:var(--clay-soft);border-color:#e0c9a8;}
.tcard .tfoot{display:flex;align-items:flex-end;justify-content:space-between;border-top:1px solid var(--line);padding-top:16px;gap:10px;}
.tprice .lbl{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.tprice .amt{font-family:var(--serif);font-size:32px;color:var(--forest);line-height:1;}
.tprice .per{font-family:var(--mono);font-size:11px;color:var(--ink-faint);letter-spacing:0;}
.tprice .cmp{font-family:var(--mono);font-size:11px;color:var(--ink-faint);margin-top:5px;letter-spacing:.02em;}
.tprice .cmp s{color:var(--clay);text-decoration-thickness:1px;}
.tcard .tfoot .open{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;color:var(--clay);cursor:pointer;display:inline-flex;align-items:center;gap:6px;background:none;border:none;padding:0 0 4px;}
.tcard .tfoot .open svg{width:14px;height:14px;transition:.2s;}
.tcard.expanded .tfoot .open svg{transform:rotate(180deg);}

/* expandable day-by-day */
.tdetail{display:none;border-top:1px solid var(--line);padding:20px 24px 24px;background:var(--paper-2);}
.tcard.expanded .tdetail{display:block;}
.daylist{margin:0;padding:0;list-style:none;}
.daylist li{display:grid;grid-template-columns:64px 1fr;gap:14px;padding:10px 0;border-top:1px dashed var(--line);}
.daylist li:first-child{border-top:none;}
.daylist .dlabel{font-family:var(--mono);font-size:10.5px;font-weight:500;color:var(--clay);text-transform:uppercase;letter-spacing:.06em;padding-top:3px;}
.daylist .dtitle{font-weight:600;font-size:14.5px;}
.daylist .ddesc{font-size:13.5px;color:var(--ink-soft);margin:3px 0 0;}
.incl{display:grid;grid-template-columns:1fr 1fr;gap:6px 26px;margin-top:18px;font-size:13px;}
.incl h5{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;margin:0 0 8px;color:var(--ink-faint);font-weight:500;}
.incl ul{margin:0;padding:0;list-style:none;}
.incl li{padding:2px 0 2px 18px;position:relative;color:var(--ink-soft);}
.incl .yes li::before{content:"+";position:absolute;left:0;color:var(--forest-mid);font-weight:700;}
.incl .no li::before{content:"–";position:absolute;left:0;color:var(--ink-faint);}
.tdetail .det-cta{margin-top:18px;display:flex;gap:10px;flex-wrap:wrap;}
.tdetail .det-cta .btn{padding:12px 20px;font-size:11.5px;}

/* ---------- filter tabs ---------- */
.filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:44px;}
.filters button{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;padding:11px 20px;border-radius:999px;
  border:1px solid var(--line-strong);background:transparent;color:var(--ink-soft);cursor:pointer;transition:.18s;}
.filters button:hover{border-color:var(--ink);color:var(--ink);}
.filters button.active{background:var(--forest);color:var(--paper);border-color:var(--forest);}

/* ---------- why / features ---------- */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--card);box-shadow:var(--shadow-sm);}
.why{padding:34px 30px;border-left:1px solid var(--line);border-top:1px solid var(--line);transition:background .2s;}
.why:nth-child(-n+3){border-top:none;}
.why:nth-child(3n+1){border-left:none;}
.why:hover{background:var(--paper-2);}
.why .wnum{font-family:var(--mono);font-size:12px;color:var(--clay);font-weight:500;letter-spacing:.12em;}
.why h3{font-size:24px;margin:16px 0 10px;}
.why p{font-size:14.5px;color:var(--ink-soft);margin:0;}

/* ---------- split (John / feature) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:center;}
.split.reverse{direction:rtl;}
.split.reverse>*{direction:ltr;}
.split-media{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5;}
.split-media image-slot{width:100%;height:100%;}
.signature{font-family:var(--serif);font-style:italic;font-size:27px;color:var(--clay);margin-top:8px;}

/* ---------- dark sections ---------- */
.dark{background:var(--forest);color:#e6ddc8;}
.dark h2,.dark h3{color:#fdf9ee;}
.dark .lead{color:#c4bba4;}
.dark .eyebrow{color:var(--gold-soft);}
.dark .eyebrow::before{color:var(--gold-soft);}
.dark .note{color:#9d957f;}

/* ---------- steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.step{position:relative;padding:32px 28px;border:1px solid rgba(216,184,110,.22);border-radius:var(--r);background:rgba(255,255,255,.025);}
.step .snum{font-family:var(--serif);font-style:italic;font-size:52px;color:var(--gold-soft);line-height:1;}
.step h3{font-size:25px;margin:16px 0 9px;color:#fdf9ee;}
.step p{font-size:14.5px;color:#c4bba4;margin:0;}
.step .connect{position:absolute;top:46px;right:-15px;color:rgba(216,184,110,.35);z-index:2;}

/* ---------- destinations ---------- */
.dest-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.dest{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:1/1;box-shadow:var(--shadow-sm);transition:transform .2s;}
.dest:hover{transform:translateY(-3px);}
.dest image-slot{position:absolute;inset:0;width:100%;height:100%;}
.dest .veil{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(18,17,12,0) 45%,rgba(18,17,12,.84));}
.dest .dname{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:18px;color:#fff;font-family:var(--serif);font-size:24px;}
.dest .dsub{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--gold-soft);text-transform:uppercase;font-weight:500;margin-bottom:4px;}

/* ---------- real moments gallery ---------- */
.moments{display:grid;gap:14px;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:230px;
  grid-template-areas:
    "con air air gir"
    "con ben rch gir";}
.moment{position:relative;margin:0;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);
  background:var(--forest-mid);transition:transform .25s ease, box-shadow .25s;}
.moment:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.moment img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.moment .veil{position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,rgba(18,17,12,0) 42%,rgba(18,17,12,.82));pointer-events:none;}
.moment figcaption{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:16px 18px;color:#fff;}
.moment .mtag{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-soft);margin-bottom:4px;}
.moment .mcap{font-family:var(--serif);font-size:19px;line-height:1.15;text-wrap:pretty;}
.moment.m-con{grid-area:con;}
.moment.m-air{grid-area:air;}
.moment.m-gir{grid-area:gir;}
.moment.m-ben{grid-area:ben;}
.moment.m-rch{grid-area:rch;}
.moment.m-con img{object-position:50% 22%;}
.moment.m-gir img,.moment.m-rch img{object-position:50% 38%;}
.moment.m-ben img{object-position:50% 30%;}
@media (max-width:860px){
  .moments{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px;
    grid-template-areas:
      "con air"
      "con gir"
      "ben gir"
      "rch rch";}
}
@media (max-width:520px){
  .moments{grid-template-columns:1fr;grid-auto-rows:260px;
    grid-template-areas:"con" "air" "ben" "gir" "rch";}
}

/* ---------- reviews ---------- */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.review{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;}
.review .stars{color:var(--clay);font-size:15px;letter-spacing:4px;margin-bottom:14px;}
.review p{font-family:var(--serif);font-size:21px;line-height:1.3;color:var(--ink);flex:1;}
.review .who{display:flex;align-items:center;gap:12px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line);}
.review .who image-slot,.review .who .av{width:42px;height:42px;border-radius:50%;flex:none;background:var(--clay-soft);}
.review .who .nm{font-weight:600;font-size:14px;}
.review .who .loc{font-family:var(--mono);font-size:11px;color:var(--ink-faint);letter-spacing:.02em;}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;color:#fff;}
.cta-band-media{position:absolute;inset:0;z-index:0;}
.cta-band-media image-slot{width:100%;height:100%;}
.cta-band::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(120deg,rgba(27,42,32,.93),rgba(20,17,11,.82));}
.cta-band .wrap{position:relative;z-index:2;text-align:center;}
.cta-band h2{font-size:clamp(36px,5vw,62px);color:#fdf9ee;max-width:22ch;margin:0 auto 20px;}
.cta-band p{font-size:19px;color:rgba(255,255,255,.88);max-width:54ch;margin:0 auto 32px;}
.cta-band .hero-cta{justify-content:center;}

/* ---------- tables ---------- */
.tbl{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;font-size:15px;box-shadow:var(--shadow-sm);}
.tbl th,.tbl td{text-align:left;padding:15px 20px;border-bottom:1px solid var(--line);}
.tbl th{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);background:var(--paper-2);font-weight:500;}
.tbl td.num{font-family:var(--mono);color:var(--forest);font-weight:500;}
.tbl td.was{font-family:var(--mono);color:var(--ink-faint);}
.tbl td.was s{color:var(--clay);text-decoration-thickness:1px;}
.tbl tr:last-child td{border-bottom:none;}
.save-pill{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:#1f5132;background:#dcead9;border:1px solid #bcd4b8;border-radius:999px;padding:3px 11px;}

/* ---------- faq ---------- */
.faq details{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:6px 22px;margin-bottom:12px;box-shadow:var(--shadow-sm);}
.faq summary{font-family:var(--serif);font-size:21px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:14px;padding:14px 0;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";color:var(--clay);font-family:var(--mono);font-size:22px;line-height:1;}
.faq details[open] summary::after{content:"–";}
.faq details p{margin:0 0 16px;font-size:15px;color:var(--ink-soft);}

/* ---------- forms ---------- */
.form{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:32px;box-shadow:var(--shadow);}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:11px;font-weight:500;color:var(--ink-soft);margin-bottom:7px;font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1px solid var(--line-strong);border-radius:8px;
  font-family:inherit;font-size:15px;background:var(--paper-2);color:var(--ink);transition:.15s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--clay);background:#fff;box-shadow:0 0 0 3px rgba(168,81,42,.14);}
.field textarea{resize:vertical;min-height:110px;}

/* ---------- contact cards ---------- */
.contact-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.ccard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--shadow-sm);}
.ccard .clbl{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.ccard .cval{font-size:18px;font-weight:600;margin-top:6px;color:var(--ink);word-break:break-word;}
.ccard .cval.green{color:var(--forest-mid);}
.socials{display:flex;gap:12px;flex-wrap:wrap;}
.soc{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:var(--card);border:1px solid var(--line);color:var(--ink-soft);transition:.18s;box-shadow:var(--shadow-sm);}
.soc:hover{background:var(--ink);color:#fff;transform:translateY(-2px);}
.soc svg{width:20px;height:20px;}

/* ============================================================
   SAFARI BUILDER
   ============================================================ */
.builder-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(28px,4vw,56px);align-items:start;}
.b-block{margin-bottom:34px;}
.b-label{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:14px;display:flex;align-items:baseline;gap:12px;}
.b-label .b-val{color:#fdf9ee;font-size:13px;letter-spacing:.06em;}
.chips{display:flex;flex-wrap:wrap;gap:9px;}
.chip{font-family:var(--mono);font-size:12px;letter-spacing:.06em;padding:10px 18px;border-radius:999px;cursor:pointer;
  border:1px solid rgba(230,221,200,.3);background:transparent;color:#e6ddc8;transition:.15s;}
.chip:hover{border-color:rgba(230,221,200,.7);}
.chip.on{background:var(--gold-soft);border-color:var(--gold-soft);color:var(--forest-deep);font-weight:500;}
.b-slider{width:100%;accent-color:var(--gold-soft);height:30px;cursor:pointer;}
.b-styles{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.b-style{border:1px solid rgba(230,221,200,.3);border-radius:var(--r);padding:16px 16px 14px;cursor:pointer;transition:.15s;background:transparent;text-align:left;color:#e6ddc8;font-family:var(--sans);}
.b-style:hover{border-color:rgba(230,221,200,.7);}
.b-style.on{border-color:var(--gold-soft);background:rgba(216,184,110,.12);}
.b-style .bs-name{font-family:var(--serif);font-size:21px;color:#fdf9ee;}
.b-style .bs-sub{font-size:12.5px;color:#c4bba4;margin-top:4px;line-height:1.4;}
.b-style .bs-rate{font-family:var(--mono);font-size:11px;color:var(--gold-soft);margin-top:10px;letter-spacing:.04em;}
.b-extras{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.b-extra{display:flex;gap:12px;align-items:flex-start;border:1px solid rgba(230,221,200,.3);border-radius:var(--r);padding:13px 15px;cursor:pointer;transition:.15s;}
.b-extra:hover{border-color:rgba(230,221,200,.7);}
.b-extra.on{border-color:var(--gold-soft);background:rgba(216,184,110,.12);}
.b-extra input{margin-top:3px;accent-color:var(--gold-soft);}
.b-extra .bx-name{font-size:14px;font-weight:600;color:#fdf9ee;}
.b-extra .bx-price{font-family:var(--mono);font-size:11px;color:var(--gold-soft);letter-spacing:.04em;}
.b-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.b-select select,.b-select input{width:100%;padding:13px 15px;border-radius:8px;border:1px solid rgba(230,221,200,.35);
  background:rgba(255,255,255,.05);color:#fdf9ee;font-family:var(--sans);font-size:15px;}
.b-select select:focus,.b-select input:focus{outline:none;border-color:var(--gold-soft);}
.b-select select option{color:var(--ink);background:var(--paper);}

/* summary card */
.b-summary{position:sticky;top:96px;background:var(--card);color:var(--ink);border-radius:var(--r);box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--line);}
.b-summary .bsum-head{padding:22px 26px 18px;border-bottom:1px dashed var(--line-strong);}
.b-summary .bsum-kicker{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);}
.b-summary .bsum-route{font-family:var(--serif);font-size:26px;line-height:1.12;margin-top:8px;}
.b-summary .bsum-meta{font-family:var(--mono);font-size:11.5px;color:var(--ink-faint);margin-top:10px;letter-spacing:.04em;line-height:1.8;}
.b-summary .bsum-price{padding:20px 26px;border-bottom:1px dashed var(--line-strong);display:flex;align-items:flex-end;justify-content:space-between;gap:14px;}
.b-summary .bp-est .lbl{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.b-summary .bp-est .amt{font-family:var(--serif);font-size:42px;line-height:1;color:var(--forest);}
.b-summary .bp-est .per{font-family:var(--mono);font-size:11px;color:var(--ink-faint);}
.b-summary .bp-cmp{text-align:right;}
.b-summary .bp-cmp .was{font-family:var(--mono);font-size:12px;color:var(--ink-faint);}
.b-summary .bp-cmp .was s{color:var(--clay);}
.b-summary .bp-cmp .save-pill{margin-top:6px;}
.b-summary .bsum-form{padding:20px 26px 26px;}
.b-summary .field input,.b-summary .field textarea{background:var(--paper-2);}
.b-summary .btn{width:100%;}
.b-summary .bsum-note{font-family:var(--mono);font-size:10.5px;color:var(--ink-faint);text-align:center;margin-top:12px;letter-spacing:.04em;}
.b-error{display:none;font-size:13px;color:var(--clay-deep);background:var(--clay-soft);border:1px solid #e0c9a8;border-radius:8px;padding:9px 13px;margin-bottom:12px;}
.b-error.show{display:block;}

/* ---------- footer ---------- */
.footer{background:var(--night);color:#b3aa97;padding:68px 0 28px;font-size:14.5px;}
.footer a{color:#c8bfa9;transition:.15s;}
.footer a:hover{color:#fff;}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1);}
.footer .brand{color:#fff;font-size:24px;margin-bottom:14px;}
.footer .fcol h4{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:#776e5b;margin:0 0 16px;font-weight:500;}
.footer .fcol a{display:block;padding:5px 0;}
.footer .fblurb{color:#968d7a;max-width:34ch;margin-bottom:18px;}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;padding-top:24px;color:#776e5b;font-size:12px;font-family:var(--mono);letter-spacing:.04em;}
.footer .socials .soc{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);color:#c8bfa9;}
.footer .socials .soc:hover{background:var(--clay);color:#fff;border-color:var(--clay);}

/* ---------- floating whatsapp ---------- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:90;display:flex;align-items:center;gap:0;
  background:var(--wa);color:#fff;border-radius:999px;padding:14px;box-shadow:0 12px 30px -8px rgba(23,163,74,.7);
  transition:gap .25s ease, padding .25s ease;overflow:hidden;white-space:nowrap;font-weight:600;font-size:14px;}
.wa-float svg{width:28px;height:28px;flex:none;}
.wa-float .wa-txt{max-width:0;opacity:0;transition:max-width .25s ease, opacity .2s ease, margin .25s;}
.wa-float:hover{gap:10px;padding:14px 22px 14px 16px;}
.wa-float:hover .wa-txt{max-width:160px;opacity:1;}

/* ---------- misc ---------- */
.note{font-size:13px;color:var(--ink-faint);font-style:italic;}
.divider{height:1px;background:var(--line);margin:0;border:none;}
.pill-row{display:flex;flex-wrap:wrap;gap:8px;}
.kpill{font-family:var(--mono);font-size:12px;border:1px solid var(--line-strong);border-radius:999px;padding:5px 13px;color:var(--ink-soft);background:var(--paper-2);}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .cat-grid,.tours-grid,.steps,.reviews-grid{grid-template-columns:repeat(2,1fr);}
  .why-grid{grid-template-columns:repeat(2,1fr);}
  .why:nth-child(3n+1){border-left:1px solid var(--line);}
  .why:nth-child(2n+1){border-left:none;}
  .why:nth-child(3){border-top:1px solid var(--line);}
  .dest-grid{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;gap:30px;}
  .split{grid-template-columns:1fr;}
  .split-media{aspect-ratio:16/10;max-height:440px;}
  .split.reverse{direction:ltr;}
  .nav-links{display:none;}
  .hamb{display:flex;}
  .step .connect{display:none;}
  .stats .wrap{grid-template-columns:1fr 1fr;}
  .stat:nth-child(3){border-left:none;}
  .stat{border-top:1px solid var(--line);}
  .stat:nth-child(-n+2){border-top:none;}
  .builder-grid{grid-template-columns:1fr;}
  .b-summary{position:static;}
  .hero-coords{display:none;}
}
@media (max-width:620px){
  .wrap{padding:0 20px;}
  .cat-grid,.tours-grid,.steps,.reviews-grid,.contact-cards,.form .row,.incl,.b-styles,.b-extras,.b-row{grid-template-columns:1fr;}
  .why-grid{grid-template-columns:1fr;}
  .why{border-left:none !important;border-top:1px solid var(--line) !important;}
  .why:first-child{border-top:none !important;}
  .hero{min-height:94vh;}
  .footer-top{grid-template-columns:1fr;}
  .stats .wrap{grid-template-columns:1fr 1fr;}
  .filters{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:8px;}
  .btn{padding:14px 20px;}
}
