/* ===========================================================
   Emmet Africa — Exclusive Safaris
   Brand system: ivory paper, warm tan, deep brown.
   Playfair Display (display) + Montserrat (text).
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Montserrat:wght@300;400;500;600&display=swap');

:root{
  --paper:#f3ede1;
  --paper-2:#ece3d2;
  --card:#efe7d7;
  --tan:#c9bb96;
  --tan-deep:#b1a075;
  --brown:#5a3719;
  --brown-2:#704a2b;
  --ink:#463524;
  --muted:#8b7a62;
  --gold:#a37d3d;
  --green:#394231;
  --green-deep:#2b322a;
  --line:#d9ceb8;
  --white:#fffdf8;
  --shadow:0 18px 50px -22px rgba(74,52,29,.45);
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Montserrat',system-ui,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.85;
  font-weight:400;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:500;color:var(--brown);line-height:1.18}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.eyebrow{
  font-family:'Montserrat',sans-serif;
  text-transform:uppercase;
  letter-spacing:.42em;
  font-size:11.5px;
  font-weight:600;
  color:var(--gold);
  margin-bottom:22px;
}
.subhead{font-family:'Playfair Display',serif;font-style:italic;color:var(--brown-2);font-size:1.25rem}
.lead{font-size:1.08rem;color:var(--ink)}
.muted{color:var(--muted)}
.center{text-align:center}

/* ---- Buttons ---- */
.btn{
  display:inline-block;
  font-family:'Montserrat',sans-serif;
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:11.5px;
  font-weight:600;
  padding:16px 34px;
  border:1px solid var(--brown);
  color:var(--brown);
  background:transparent;
  cursor:pointer;
  transition:.35s ease;
}
.btn:hover{background:var(--brown);color:var(--paper)}
.btn--light{border-color:var(--white);color:var(--white)}
.btn--light:hover{background:var(--white);color:var(--brown)}
.btn--solid{background:var(--brown);color:var(--paper)}
.btn--solid:hover{background:var(--brown-2)}

/* =========================================================
   NAVIGATION
   ========================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 40px;
  transition:background .4s ease, padding .4s ease, box-shadow .4s;
}
.nav__logo{display:flex;align-items:center}
.nav__logo img{height:54px;width:auto;display:block}
.nav__logo .logo-dark{display:none}
.nav__links{display:flex;gap:34px;align-items:center}
.nav__links a{
  color:var(--white);
  text-transform:lowercase;
  letter-spacing:.16em;
  font-size:13px;
  font-weight:500;
  position:relative;
  padding:4px 0;
  transition:color .3s;
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:currentColor;transition:width .3s}
.nav__links a:hover::after,.nav__links a.active::after{width:100%}
/* .uc kept as a no-op so the Resources link matches the other nav items */

/* scrolled / solid nav */
.nav.solid{background:var(--paper);box-shadow:0 1px 0 var(--line);padding:12px 40px}
.nav.solid .nav__logo .logo-light{display:none}
.nav.solid .nav__logo .logo-dark{display:block}
.nav.solid .nav__links a{color:var(--ink)}
.nav.solid .nav__links a.active{color:var(--brown)}

/* inner pages: nav solid from start */
body.inner{padding-top:0}
body.inner .nav{background:var(--paper);box-shadow:0 1px 0 var(--line)}
body.inner .nav__logo .logo-light{display:none}
body.inner .nav__logo .logo-dark{display:block}
body.inner .nav__links a{color:var(--ink)}

.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav__toggle span{width:26px;height:2px;background:var(--white);transition:.3s}
.nav.solid .nav__toggle span,body.inner .nav__toggle span{background:var(--brown)}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;
  text-align:center;color:var(--white);
  background:linear-gradient(180deg,rgba(40,28,16,.55),rgba(40,28,16,.30) 40%,rgba(40,28,16,.65)),var(--bg) center 58%/cover no-repeat;
}
.hero__inner{max-width:880px;padding:0 26px}
.hero__eyebrow{text-transform:uppercase;letter-spacing:.5em;font-size:12px;font-weight:600;color:#f0e6d3;margin-bottom:28px}
.hero h1{color:var(--white);font-size:clamp(2.8rem,7vw,5.4rem);font-weight:500;letter-spacing:.04em;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero__tagline{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(1.05rem,2.2vw,1.5rem);margin:22px auto 38px;max-width:640px;color:#f4ecdd;text-shadow:0 1px 16px rgba(0,0,0,.45)}
.hero__scroll{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);font-size:10px;letter-spacing:.4em;text-transform:uppercase;opacity:.85}
.hero__scroll::after{content:"";display:block;width:1px;height:46px;background:#fff;margin:14px auto 0;opacity:.6}

/* page banner (inner pages) */
.banner{
  position:relative;min-height:62vh;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--white);
  background:linear-gradient(180deg,rgba(40,28,16,.5),rgba(40,28,16,.6)),var(--bg) center 50%/cover no-repeat;
}
.banner h1{color:var(--white);font-size:clamp(2.2rem,5.5vw,4rem)}
.banner .eyebrow{color:#f0e6d3}
.banner p{max-width:680px;margin:18px auto 0;color:#f4ecdd;font-style:italic;font-family:'Playfair Display',serif;font-size:1.2rem}

/* =========================================================
   SECTIONS
   ========================================================= */
.section{padding:104px 0}
.section--tan{background:var(--paper-2)}
.section--tight{padding:72px 0}
.section__head{max-width:760px;margin:0 auto 60px;text-align:center}
.section__head h2{font-size:clamp(2rem,4.4vw,3rem)}
.section__head p{margin-top:20px;color:var(--ink)}
.rule{width:54px;height:1px;background:var(--tan-deep);margin:22px auto}

/* intro split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split img{box-shadow:var(--shadow)}
.split h2{font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:22px}
.split p+p{margin-top:18px}
.split--rev .split__media{order:2}

/* destination grid (home) */
.destgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.destgrid a{
  background:var(--paper);
  padding:34px 18px;
  text-align:center;
  font-family:'Playfair Display',serif;
  font-size:1.18rem;
  color:var(--brown);
  letter-spacing:.06em;
  transition:.35s;
  position:relative;
}
.destgrid a span{display:block;font-family:'Montserrat',sans-serif;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-top:8px;transition:.35s}
.destgrid a:hover{background:var(--brown);color:var(--paper)}
.destgrid a:hover span{color:var(--tan)}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.pillar{text-align:center}
.pillar .num{font-family:'Playfair Display',serif;font-style:italic;font-size:1.4rem;color:var(--gold);margin-bottom:16px}
.pillar h3{font-size:1.45rem;margin-bottom:14px}
.pillar p{color:var(--ink);font-size:.97rem}
.pillar .divider{width:30px;height:1px;background:var(--tan-deep);margin:18px auto}

/* values / conservation list */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:14px}
.value{background:var(--card);padding:42px 32px;border:1px solid var(--line)}
.value h3{font-size:1.3rem;margin-bottom:12px}
.value p{font-size:.95rem;color:var(--ink)}

/* destination cards (your journey) */
.destinations{display:grid;gap:34px}
.dcard{
  display:grid;grid-template-columns:1.1fr 1fr;background:var(--white);border:1px solid var(--line);overflow:hidden;
}
.dcard:nth-child(even){grid-template-columns:1fr 1.1fr}
.dcard__body{padding:48px 46px;display:flex;flex-direction:column;justify-content:center}
.dcard__body .country{font-family:'Montserrat',sans-serif;text-transform:uppercase;letter-spacing:.34em;font-size:12px;color:var(--gold);font-weight:600;margin-bottom:12px}
.dcard__body h3{font-size:1.9rem;margin-bottom:18px;font-style:italic}
.dcard__body .areas{font-size:.92rem;color:var(--muted);letter-spacing:.02em;border-top:1px solid var(--line);padding-top:18px;margin-top:6px}
.dcard__body .areas b{color:var(--ink);font-weight:600;display:block;text-transform:uppercase;letter-spacing:.2em;font-size:10px;margin-bottom:8px}
.dcard__art{background:var(--tan);min-height:300px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.dcard__art img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.dcard:nth-child(even) .dcard__art{order:-1}
.dcard__art .mapname{font-family:'Playfair Display',serif;font-size:2.6rem;color:rgba(90,55,25,.20);letter-spacing:.08em;text-align:center;padding:20px}
a.dcard{transition:box-shadow .35s ease, transform .35s ease}
a.dcard:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
a.dcard:hover .discover{color:var(--brown)}
.dcard__body .discover{margin-top:22px;font-family:'Montserrat',sans-serif;text-transform:uppercase;letter-spacing:.26em;font-size:11px;font-weight:600;color:var(--gold);transition:color .3s}

/* resources */
.resgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;max-width:820px;margin:0 auto}
.rescard{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  background:var(--white);border:1px solid var(--line);padding:34px 36px;transition:.35s;
}
.rescard:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.rescard h3{font-size:1.3rem}
.rescard .tag{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-top:6px}
.rescard .dl{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);font-weight:600;white-space:nowrap}

/* contact */
.contact{display:grid;grid-template-columns:1.2fr .9fr;gap:64px;align-items:start}
.form label{display:block;text-transform:uppercase;letter-spacing:.22em;font-size:10.5px;font-weight:600;color:var(--brown-2);margin:0 0 8px}
.form .field{margin-bottom:26px}
.form input,.form textarea{
  width:100%;background:var(--white);border:1px solid var(--line);
  padding:14px 16px;font-family:'Montserrat',sans-serif;font-size:15px;color:var(--ink);
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--tan-deep)}
.form textarea{min-height:140px;resize:vertical}
.contact__info h3{font-size:1.5rem;margin-bottom:10px}
.contact__info .row{margin-top:24px}
.contact__info .row span{display:block;text-transform:uppercase;letter-spacing:.24em;font-size:10px;color:var(--gold);font-weight:600;margin-bottom:6px}
.contact__info a{color:var(--brown);border-bottom:1px solid var(--tan-deep)}
.form__success{display:none;background:var(--card);border:1px solid var(--tan-deep);padding:22px;margin-bottom:24px;color:var(--brown);font-style:italic;font-family:'Playfair Display',serif}

/* full-bleed quote/cta band */
.band{
  position:relative;color:var(--white);text-align:center;padding:120px 0;
  background:linear-gradient(rgba(40,28,16,.6),rgba(40,28,16,.6)),var(--bg) center/cover no-repeat;background-attachment:fixed;
}
.band h2{color:var(--white);font-size:clamp(1.9rem,4.4vw,3rem);max-width:760px;margin:0 auto 18px}
.band p{max-width:600px;margin:0 auto 34px;color:#f4ecdd;font-style:italic;font-family:'Playfair Display',serif;font-size:1.2rem}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:#2e2014;color:#e7dcc8;padding:70px 0 36px;text-align:center}
.footer__logo{width:208px;height:auto;margin:0 auto 30px;display:block;opacity:.95}
.footer .ig{font-family:'Playfair Display',serif;font-size:1.7rem;letter-spacing:.1em;color:var(--white)}
.footer .follow{font-style:italic;font-family:'Playfair Display',serif;color:var(--tan);margin-top:6px}
.footer .social{display:flex;gap:26px;justify-content:center;margin:28px 0}
.footer .social a{text-transform:uppercase;letter-spacing:.22em;font-size:11px;color:#e7dcc8;border:1px solid rgba(231,220,200,.3);padding:10px 18px;transition:.3s}
.footer .social a:hover{background:var(--white);color:#2e2014;border-color:var(--white)}
.footer .mail{margin-top:18px;font-size:13px;letter-spacing:.04em}
.footer .mail a{color:var(--tan);border-bottom:1px solid rgba(201,187,150,.5)}
.footer .copy{margin-top:34px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#8d7d66}
.footer .copy a{color:#b6a585;border-bottom:1px solid rgba(182,165,133,.4)}
.footer .copy a:hover{color:var(--white)}

/* favoured lodges */
.lodges{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.lodge{background:var(--white);border:1px solid var(--line);padding:30px 28px;transition:box-shadow .35s ease, transform .35s ease}
.lodge:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.lodge h4{font-size:1.4rem;line-height:1.2;margin-bottom:8px}
.lodge .by{text-transform:uppercase;letter-spacing:.22em;font-size:10px;color:var(--gold);font-weight:600}
.lodge .larea{font-size:.9rem;color:var(--muted);margin-top:6px}
@media(max-width:760px){.lodges{grid-template-columns:1fr}}

/* destinations map */
.mapsection{background:#d8c9a3}
.africamap{display:block;width:100%;height:auto;max-width:1000px;margin:0 auto}
.africamap .land{fill:#ece2c5}
.africamap .ctry{fill:#46291a;stroke:#ece2c5;stroke-width:1.6;transition:fill .35s ease}
.africamap .lead{stroke:#46291a;stroke-width:1.4;fill:none;opacity:.7}
.africamap .ml{font-family:'Playfair Display',serif;font-weight:500;fill:#46291a;font-size:30px;letter-spacing:3px;transition:fill .35s ease}
.africamap a{cursor:pointer}
.africamap a:hover .ctry{fill:var(--green)}
.africamap a:hover .ml{fill:var(--green)}
.africamap a:hover .lead{opacity:1;stroke:var(--green)}
.africamap a:focus-visible{outline:none}
.africamap a:focus-visible .ctry{fill:var(--green)}
.africamap .ant{fill:#6b4a2e;opacity:.8}
@media(max-width:680px){.africamap .ml{font-size:38px;letter-spacing:4px}}

/* legal / terms page */
.legal{max-width:830px;margin:0 auto}
.legal .meta{font-family:'Playfair Display',serif;font-style:italic;color:var(--brown-2);margin-bottom:6px}
.legal .preamble{color:var(--ink);margin-bottom:8px}
.legal h2{font-size:1.5rem;margin:54px 0 18px;padding-top:30px;border-top:1px solid var(--line)}
.legal h2 .s{font-family:'Playfair Display',serif;font-style:italic;color:var(--gold);margin-right:14px}
.legal h3{font-family:'Montserrat',sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:12px;font-weight:600;color:var(--brown-2);margin:24px 0 10px}
.legal .clause{display:flex;gap:16px;margin-bottom:13px}
.legal .clause .n{color:var(--gold);font-weight:600;min-width:38px;font-variant-numeric:tabular-nums}
.legal .clause p{margin:0;color:var(--ink)}
.legal ul.sub{list-style:none;margin:4px 0 16px 54px}
.legal ul.sub li{position:relative;padding-left:30px;margin-bottom:9px;color:var(--ink)}
.legal ul.sub li .l{position:absolute;left:0;top:0;color:var(--gold);font-family:'Playfair Display',serif;font-style:italic}
.legal .ack{margin-top:54px;padding:32px 34px;background:var(--card);border:1px solid var(--line)}
.legal .ack h3{margin-top:0}
@media(max-width:600px){.legal .clause{gap:10px}.legal .clause .n{min-width:32px}.legal ul.sub{margin-left:24px}}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:900px){
  .nav{padding:14px 22px}
  .nav.solid{padding:12px 22px}
  .nav__logo img{height:46px}
  .nav__toggle{display:flex}
  .nav__links{
    position:fixed;top:0;right:0;height:100vh;width:74%;max-width:320px;
    background:var(--paper);flex-direction:column;justify-content:center;align-items:center;gap:30px;
    transform:translateX(100%);transition:transform .4s ease;box-shadow:var(--shadow);
  }
  .nav__links.open{transform:translateX(0)}
  .nav__links a{color:var(--ink)!important;font-size:16px}
  .split,.contact{grid-template-columns:1fr;gap:36px}
  .split--rev .split__media{order:0}
  .pillars,.values,.resgrid{grid-template-columns:1fr;gap:26px}
  .destgrid{grid-template-columns:repeat(2,1fr)}
  .dcard,.dcard:nth-child(even){grid-template-columns:1fr}
  .dcard:nth-child(even) .dcard__art{order:0}
  .dcard__art{min-height:220px}
  .dcard__body{padding:36px 30px}
  .band{background-attachment:scroll}
  .section{padding:72px 0}
}
@media(max-width:520px){
  .destgrid{grid-template-columns:1fr}
}

/* =========================================================
   DESTINATION (COUNTRY) PAGES
   ========================================================= */
/* overview + quick facts */
.overview{display:grid;grid-template-columns:1.6fr 1fr;gap:60px;align-items:start}
.overview h2{font-size:clamp(1.9rem,4vw,2.6rem);margin-bottom:22px}
.overview p+p{margin-top:18px}
.quickfacts{background:var(--card);border:1px solid var(--line);padding:34px 32px}
.quickfacts h4{font-family:'Montserrat',sans-serif;text-transform:uppercase;letter-spacing:.26em;font-size:11px;color:var(--gold);font-weight:600;margin-bottom:18px}
.quickfacts .qf{padding:14px 0;border-top:1px solid var(--line)}
.quickfacts .qf:first-of-type{border-top:none}
.quickfacts .qf span{display:block;text-transform:uppercase;letter-spacing:.18em;font-size:10px;color:var(--muted);margin-bottom:4px}
.quickfacts .qf b{font-weight:500;color:var(--ink);font-size:.95rem;font-family:'Playfair Display',serif}

/* why go */
.whygo{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 40px;margin-top:10px}
.whygo li{list-style:none;padding-left:26px;position:relative;color:var(--ink);font-size:.98rem}
.whygo li::before{content:"";position:absolute;left:0;top:11px;width:8px;height:8px;background:var(--gold);transform:rotate(45deg)}

/* best time to go — month strip */
.months{display:grid;grid-template-columns:repeat(12,1fr);gap:6px;margin-top:10px}
.m{text-align:center}
.m .lab{font-size:11px;letter-spacing:.1em;color:var(--muted);margin-bottom:8px;font-weight:600}
.m .bar{height:46px;border-radius:3px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:6px;font-size:9px;letter-spacing:.06em;color:#fff;text-transform:uppercase}
.m.best .bar{background:#5a3719}
.m.good .bar{background:#b1a075}
.m.green .bar{background:#d9ceb8;color:var(--brown-2)}
.mlegend{display:flex;gap:26px;flex-wrap:wrap;margin-top:22px;font-size:11px;letter-spacing:.04em;color:var(--ink)}
.mlegend span{display:inline-flex;align-items:center;gap:8px}
.mlegend i{width:14px;height:14px;border-radius:3px;display:inline-block}
.mlegend .best{background:#5a3719}.mlegend .good{background:#b1a075}.mlegend .green{background:#d9ceb8}
.season-note{margin-top:26px;max-width:780px;color:var(--ink)}

/* parks & areas */
.areas-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.area{background:var(--white);padding:30px 32px}
.area h4{font-size:1.35rem;margin-bottom:8px}
.area p{font-size:.93rem;color:var(--ink)}

/* highlights */
.highlights{columns:2;column-gap:48px}
.highlights li{list-style:none;break-inside:avoid;padding:14px 0 14px 28px;position:relative;border-bottom:1px solid var(--line);color:var(--ink);font-size:.97rem}
.highlights li::before{content:"\2014";position:absolute;left:0;color:var(--gold)}

/* sample trip shape */
.trip{max-width:820px;margin:0 auto}
.trip .step{display:flex;gap:22px;padding:20px 0;border-bottom:1px solid var(--line);align-items:baseline}
.trip .step .n{font-family:'Playfair Display',serif;font-style:italic;color:var(--gold);font-size:1.2rem;min-width:90px}
.trip .step .d b{font-family:'Playfair Display',serif;font-weight:500;color:var(--brown);font-size:1.15rem;display:block;margin-bottom:3px}
.trip .step .d p{font-size:.93rem;color:var(--ink)}
.trip .note{margin-top:24px;font-style:italic;font-family:'Playfair Display',serif;color:var(--brown-2);text-align:center}

/* prev/next other destinations */
.moredest{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:14px}
.moredest a{border:1px solid var(--line);background:var(--white);padding:11px 20px;font-size:12px;letter-spacing:.08em;color:var(--brown);transition:.3s}
.moredest a:hover{background:var(--brown);color:var(--paper)}

@media(max-width:900px){
  .overview{grid-template-columns:1fr;gap:36px}
  .whygo,.areas-grid{grid-template-columns:1fr}
  .highlights{columns:1}
  .m .bar{height:38px;font-size:0}
  .trip .step{flex-direction:column;gap:4px}
  .trip .step .n{min-width:0}
}

/* =========================================================
   MOTION & EXCITEMENT
   ========================================================= */
@keyframes kenburns{from{transform:scale(1.05)}to{transform:scale(1.18)}}
@keyframes kenburns-slow{from{transform:scale(1.02)}to{transform:scale(1.14)}}

/* --- Hero: rotating, slow-zoom slideshow --- */
.hero{overflow:hidden;background:#2b1d10}
.hero__slides{position:absolute;inset:0;z-index:0}
.hero__slide{position:absolute;inset:0;background-size:cover;background-position:center 56%;opacity:0;transition:opacity 1.8s ease}
.hero__slide.active{opacity:1;animation:kenburns 8s ease-out both}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(40,28,16,.55),rgba(40,28,16,.28) 40%,rgba(40,28,16,.70))}
.hero__inner{position:relative;z-index:2}
.hero__scroll{z-index:2}
.hero__logoWrap{margin:0 0 4px}
.hero__logo{display:block;width:min(470px,84vw);height:auto;margin:0 auto;filter:drop-shadow(0 6px 34px rgba(0,0,0,.45))}

/* --- Page banners: gentle slow zoom --- */
.banner{overflow:hidden;background:#2b1d10}
.banner::before{content:"";position:absolute;inset:0;background-image:var(--bg);background-size:cover;background-position:center 50%;animation:kenburns-slow 24s ease-out alternate infinite;z-index:0}
.banner::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,28,16,.5),rgba(40,28,16,.62));z-index:1}
.banner .wrap{position:relative;z-index:2}

/* --- Scroll reveal (only hides when JS is active, so no-JS always shows content) --- */
.js .reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease, transform .9s cubic-bezier(.2,.75,.25,1)}
.js .reveal.in{opacity:1;transform:none}

/* --- Destination card photo zoom --- */
.dcard__art img{transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
a.dcard:hover .dcard__art img{transform:scale(1.07)}
.split__media{overflow:hidden}
.split__media img{transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.split__media:hover img{transform:scale(1.05)}

/* --- Animated stats strip --- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat .num{font-family:'Playfair Display',serif;font-weight:500;color:var(--brown);font-size:clamp(2.4rem,5vw,3.6rem);line-height:1}
.stat .num .suf{color:var(--gold)}
.stat .lab{margin-top:14px;text-transform:uppercase;letter-spacing:.24em;font-size:11px;color:var(--muted);font-weight:600}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr);gap:40px 20px}}

@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__slide,.banner::before{animation:none}
  .hero__slide.active{animation:none}
}

/* =========================================================
   LUXE — intro, moments gallery, marquee, green accents
   ========================================================= */

/* brand green woven in */
.footer{background:var(--green-deep)}
.dropcap::first-letter{float:left;font-family:'Playfair Display',serif;font-weight:500;font-size:4.4rem;line-height:.72;margin:9px 16px 0 0;color:var(--green)}

/* refined brand intro / preloader (homepage) */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--paper);display:flex;align-items:center;justify-content:center;
  transition:opacity .8s ease, visibility .8s ease; animation:preloaderHide .8s ease 2.6s forwards}
.preloader img{width:124px;height:auto;animation:plRise 1.25s cubic-bezier(.2,.7,.2,1) both}
.preloader.done{opacity:0;visibility:hidden;pointer-events:none}
@keyframes plRise{0%{opacity:0;transform:translateY(16px) scale(.95)}100%{opacity:1;transform:none}}
@keyframes preloaderHide{to{opacity:0;visibility:hidden}}

/* Moments in the Wild — cinematic gallery */
.moments{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:215px;gap:14px}
.moment{position:relative;overflow:hidden;background:var(--tan)}
.moment img{width:100%;height:100%;object-fit:cover;transition:transform 1.3s cubic-bezier(.2,.7,.2,1)}
.moment:hover img{transform:scale(1.07)}
.moment figcaption{position:absolute;left:0;right:0;bottom:0;padding:26px 26px 22px;color:#fff;
  font-family:'Playfair Display',serif;font-style:italic;font-size:1.3rem;
  background:linear-gradient(transparent,rgba(34,24,14,.74));opacity:0;transform:translateY(12px);
  transition:opacity .5s ease, transform .5s ease}
.moment:hover figcaption{opacity:1;transform:none}
.moment::after{content:"";position:absolute;inset:0;border:1px solid rgba(248,242,220,0);transition:border-color .5s;pointer-events:none}
.moment:hover::after{border-color:rgba(248,242,220,.35)}
.m-bigL{grid-column:span 3;grid-row:span 2}
.m-half{grid-column:span 3}
.m-third{grid-column:span 2}
/* clip-path "wipe" reveal for moments */
.js .moment.reveal{opacity:0;clip-path:inset(0 0 100% 0);transform:none;transition:opacity .7s ease, clip-path 1.05s cubic-bezier(.2,.7,.2,1)}
.js .moment.reveal.in{opacity:1;clip-path:inset(0 0 0 0)}

/* drifting destination marquee */
.marquee{overflow:hidden;background:var(--green);color:var(--paper);padding:34px 0}
.marquee__track{display:flex;align-items:center;width:max-content;animation:marquee 40s linear infinite}
.marquee__track span{font-family:'Playfair Display',serif;font-size:clamp(1.5rem,3vw,2.3rem);letter-spacing:.05em;padding:0 34px;display:inline-flex;align-items:center}
.marquee__track span::after{content:"";width:7px;height:7px;background:var(--gold);margin-left:34px;transform:rotate(45deg)}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

@media(max-width:760px){
  .moments{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .m-bigL{grid-column:span 2;grid-row:span 1}
  .m-half{grid-column:span 2}
  .m-third{grid-column:span 1}
  .dropcap::first-letter{font-size:3.4rem}
}
@media(prefers-reduced-motion:reduce){
  .marquee__track{animation:none}
  .js .moment.reveal{opacity:1;clip-path:inset(0 0 0 0)}
}

/* Signature Experiences showcase */
.experiences{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.exp{position:relative;display:block;height:450px;overflow:hidden;color:#fff;background:var(--green-deep)}
.exp img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.5s cubic-bezier(.2,.7,.2,1)}
.exp:hover img{transform:scale(1.09)}
.exp::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 28%,rgba(28,20,10,.86));transition:background .6s ease}
.exp:hover::after{background:linear-gradient(rgba(28,20,10,.25),rgba(28,20,10,.86))}
.exp__body{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:34px 32px}
.exp__body .num{font-family:'Playfair Display',serif;font-style:italic;color:var(--gold);font-size:1.05rem;margin-bottom:10px}
.exp__body h3{color:#fff;font-size:1.75rem;line-height:1.15}
.exp__body p{color:#f1e9da;font-size:.95rem;max-height:0;opacity:0;margin:0;overflow:hidden;
  transition:max-height .55s ease, opacity .55s ease, margin .45s ease}
.exp:hover .exp__body p{max-height:120px;opacity:1;margin-top:14px}
.exp__body .go{display:inline-block;margin-top:18px;text-transform:uppercase;letter-spacing:.26em;font-size:11px;font-weight:600;color:var(--gold);opacity:0;transform:translateY(8px);transition:opacity .5s ease, transform .5s ease}
.exp:hover .exp__body .go{opacity:1;transform:none}
@media(max-width:900px){
  .experiences{grid-template-columns:1fr}
  .exp{height:380px}
  .exp__body p{max-height:120px;opacity:1;margin-top:12px}
  .exp__body .go{opacity:1;transform:none}
}
