/* ============================================================
   ENAIDURRA AFRICA — MAIN STYLESHEET v3
   Palette: Olive #8C9765 | Rust #7A2E00 | Cream #F5F0E8
   Aesthetic: Organic paper-cut, artisanal, editorial
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400;1,600&family=Jost:wght@300;400;500;600&display=swap');

:root {
  --olive:#8C9765;--olive-dark:#6b7549;--olive-light:#a8b07e;--olive-pale:#d6ddc2;
  --rust:#7A2E00;--rust-mid:#9e3d00;--rust-pale:#c4602a;
  --cream:#f5f0e8;--cream-dark:#ede5d4;--sand:#d4c9a8;--sand-light:#e8e0cc;
  --charcoal:#2c2a27;--charcoal-2:#3d3a34;--warm-white:#faf8f3;
  --text-main:#2c2a27;--text-muted:#7a7568;
  --shadow:rgba(44,42,39,0.14);--shadow-deep:rgba(44,42,39,0.28);
  --font-serif:'Cormorant Garamond',Georgia,serif;
  --font-sans:'Jost',system-ui,sans-serif;
  --nav-h:70px;--mob-nav-h:62px;
  --ease:cubic-bezier(0.25,0.46,0.45,0.94);--t:0.35s;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--font-sans);background:var(--warm-white);color:var(--text-main);overflow-x:hidden}
@media(max-width:768px){body{padding-bottom:var(--mob-nav-h)}}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--font-serif);font-weight:400;line-height:1.12;letter-spacing:-0.01em}
h1{font-size:clamp(2.4rem,6vw,5.2rem)}
h2{font-size:clamp(1.9rem,4vw,3rem)}
h3{font-size:clamp(1.3rem,2.5vw,1.9rem)}
p{line-height:1.78;color:var(--text-muted);font-weight:300}

/* BRAND SCRIPT */
.brand-script{font-family:var(--font-serif);font-style:italic;font-weight:300;letter-spacing:0.02em}
.catchphrase{font-family:var(--font-serif);font-style:italic;font-weight:300;letter-spacing:0.06em;text-transform:uppercase}

/* PAPER CUT torn bottom edge */
.torn-b{position:relative}
.torn-b::after{content:'';position:absolute;bottom:-18px;left:0;right:0;height:36px;background:var(--warm-white);clip-path:polygon(0% 40%,2% 20%,4% 50%,6% 15%,8% 45%,10% 25%,12% 55%,14% 10%,16% 40%,18% 20%,20% 50%,22% 5%,24% 35%,26% 55%,28% 20%,30% 45%,32% 15%,34% 50%,36% 25%,38% 55%,40% 10%,42% 40%,44% 20%,46% 50%,48% 30%,50% 60%,52% 20%,54% 45%,56% 10%,58% 40%,60% 25%,62% 50%,64% 15%,66% 45%,68% 5%,70% 35%,72% 55%,74% 20%,76% 45%,78% 15%,80% 50%,82% 25%,84% 55%,86% 10%,88% 40%,90% 20%,92% 50%,94% 30%,96% 45%,98% 15%,100% 40%,100% 100%,0% 100%);z-index:2;pointer-events:none}
.torn-b-cream::after{background:var(--cream-dark)}
.torn-b-dark::after{background:var(--charcoal)}
.torn-b-rust::after{background:var(--rust)}
.torn-b-white::after{background:#fff}

/* ══════════════════════════════════════
   NAV
══════════════════════════════════════ */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:900;height:var(--nav-h);transition:background var(--t),box-shadow var(--t),backdrop-filter var(--t)}
.nav-inner{max-width:1380px;margin:0 auto;height:100%;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}

/* Scrolled state — cream background */
.site-nav.scrolled{background:rgba(245,240,232,0.96);box-shadow:0 2px 28px var(--shadow);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}

/* Not scrolled — dark gradient so links are ALWAYS readable over any hero */
.site-nav:not(.scrolled){
  background:linear-gradient(to bottom,rgba(20,14,6,0.62) 0%,rgba(20,14,6,0) 100%);
  box-shadow:none;
}

/* ── Logo ── */
.nav-logo{display:flex;align-items:center;flex-shrink:0}
.logo-script{font-family:var(--font-serif);font-style:italic;font-size:1.7rem;font-weight:300;letter-spacing:0.01em;white-space:nowrap}

.site-nav:not(.scrolled) .logo-script{
  color:#83ea49;
  text-shadow:0 1px 12px rgba(0,0,0,0.65),0 0 28px rgba(0,0,0,0.4);
}
.site-nav.scrolled .logo-script{color:var(--rust);text-shadow:none}

/* ── Nav links ── */
.nav-links{display:flex;list-style:none;align-items:center}
.nav-link{font-size:0.73rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;padding:0.45rem 0.8rem;position:relative;transition:color var(--t)}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:0.8rem;right:0.8rem;height:1.5px;transform:scaleX(0);transform-origin:left;transition:transform var(--t) var(--ease)}

.site-nav:not(.scrolled) .nav-link {
  color: rgba(245,240,232,0.92) !important;
  text-shadow: none;
}
.site-nav:not(.scrolled) .nav-link:hover,
.site-nav:not(.scrolled) .nav-link.active{color:var(--olive-light) !important;text-shadow:none}
.site-nav:not(.scrolled) .nav-link::after{background:var(--olive-light)}

.site-nav.scrolled .nav-link{color:var(--charcoal) !important;text-shadow:none}
.site-nav.scrolled .nav-link:hover,
.site-nav.scrolled .nav-link.active{color:var(--rust) !important}
.site-nav.scrolled .nav-link::after{background:var(--rust)}

.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1)}

/* ── Nav right area ── */
.nav-right{display:flex;align-items:center;gap:0.65rem;flex-shrink:0}

/* ── Language dropdown ── */
.lang-dropdown{position:relative}
.lang-current{display:flex;align-items:center;gap:0.4rem;padding:0.38rem 0.65rem;border-radius:3px;cursor:pointer;font-size:0.7rem;font-weight:500;letter-spacing:0.08em;transition:all var(--t);user-select:none}
.lang-current .flag{font-size:1rem;line-height:1}
.lang-current .arr{font-size:0.52rem;transition:transform var(--t);opacity:0.7}
.lang-dropdown.open .lang-current .arr{transform:rotate(180deg)}

.site-nav:not(.scrolled) .lang-current{color:#8ec93e;border:1px solid rgba(255,255,255,0.5);background:rgba(0,0,0,0.28)}
.site-nav.scrolled .lang-current{color:var(--charcoal);border:1px solid var(--sand);background:rgba(44,42,39,0.06)}

.lang-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--cream);border:1px solid var(--sand);border-radius:4px;min-width:150px;box-shadow:0 8px 32px var(--shadow-deep);display:none;z-index:999;overflow:hidden}
.lang-dropdown.open .lang-menu{display:block}
.lang-opt{display:flex;align-items:center;gap:0.6rem;padding:0.7rem 1rem;font-size:0.8rem;cursor:pointer;transition:background var(--t);color:var(--charcoal)}
.lang-opt:hover{background:var(--cream-dark)}
.lang-opt.active{color:var(--rust);font-weight:500}
.lang-opt .flag{font-size:1.1rem}

/* ── WhatsApp nav btn ── */
.wa-nav-btn{display:flex;align-items:center;gap:0.35rem;background:#25D366;color:#fff;padding:0.4rem 0.85rem;border-radius:3px;font-size:0.68rem;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;transition:background var(--t),transform var(--t);white-space:nowrap}
.wa-nav-btn:hover{background:#1ebe5d;transform:translateY(-1px)}
.wa-icon{font-size:0.9rem}

/* ── Book Now btn — always rust ── */
.btn-book-nav{background:var(--rust) !important;color:var(--cream) !important;padding:0.48rem 1.15rem;font-size:0.7rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;border-radius:2px;transition:background var(--t),transform var(--t);white-space:nowrap}
.btn-book-nav:hover{background:var(--rust-mid) !important;transform:translateY(-1px)}

/* ── Mobile nav overrides ── */
@media(max-width:768px){
  .mobile-nav{display:flex !important;}
  .nav-links,.btn-book-nav{display:none}
  .wa-nav-btn .wa-txt{display:none}
  .wa-nav-btn{padding:0.4rem 0.6rem}
  .nav-right{gap:0.45rem}
  .nav-inner{padding:0 0.9rem}
  .logo-script{font-size:1.3rem}
  /* Stronger gradient + shadow on mobile */
  .site-nav:not(.scrolled){
    background:linear-gradient(to bottom,rgba(20,14,6,0.68) 0%,rgba(20,14,6,0) 100%);
  }
  .site-nav:not(.scrolled) .logo-script {
  color: #aef153;
  text-shadow: 0 1px 12px rgba(0,0,0,0.65), 0 0 28px rgba(0,0,0,0.4);
}
}

/* ══════════════════════════════════════
   MOBILE BOTTOM NAV
══════════════════════════════════════ */
.mobile-nav{display: none;position:fixed;bottom:0;left:0;right:0;z-index:950;height:var(--mob-nav-h);background:var(--cream);border-top:1px solid var(--sand);flex-direction:row;align-items:stretch;box-shadow:0 -4px 24px rgba(44,42,39,0.15)}
.mob-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:0.58rem;font-weight:500;letter-spacing:0.04em;text-transform:uppercase;color:var(--text-muted);transition:color var(--t);padding:0.4rem 0.2rem;position:relative;background:none;border:none;font-family:var(--font-sans);cursor:pointer;text-decoration:none}
.mob-nav-item.active{color:var(--rust)}
.mob-nav-item.active::before{content:'';position:absolute;top:0;left:20%;right:20%;height:2px;background:var(--rust);border-radius:0 0 2px 2px}
.mob-icon{font-size:1.2rem;line-height:1}
.mob-book-btn{flex:1.1;background:var(--rust);color:var(--cream)!important;border-radius:12px 12px 0 0;margin:0 0.4rem;padding-top:0.9rem;position:relative;top:-7px;box-shadow:0 -6px 18px rgba(122,46,0,0.3)}
.mob-more-menu{position:fixed;bottom:calc(var(--mob-nav-h) + 8px);right:0.75rem;background:var(--cream);border:1px solid var(--sand);border-radius:8px;min-width:165px;box-shadow:0 -8px 32px var(--shadow-deep);z-index:10000;overflow:hidden;display:none}
.mob-more-menu.open{display:block}
.mob-more-item{display:flex;align-items:center;gap:0.7rem;padding:0.85rem 1.2rem;font-size:0.82rem;color:var(--charcoal);border-bottom:1px solid rgba(212,201,168,0.4);transition:background var(--t)}
.mob-more-item:last-child{border-bottom:none}
.mob-more-item:hover{background:var(--cream-dark)}
.mob-more-icon{font-size:1rem;color:var(--rust);width:18px;text-align:center}

/* ══════════════════════════════════════
   FLASH MESSAGES
══════════════════════════════════════ */
.flash-messages{position:fixed;top:calc(var(--nav-h)+0.75rem);right:1rem;z-index:1000;display:flex;flex-direction:column;gap:0.5rem}
.flash{padding:0.82rem 1.2rem;background:var(--charcoal);color:var(--cream);font-size:0.8rem;border-left:3px solid var(--rust);transition:opacity 0.4s;max-width:330px;border-radius:0 2px 2px 0}
.flash.success{border-color:var(--olive)}.flash.error{border-color:#c0392b}

/* ══════════════════════════════════════
   REVIEW POPUP
══════════════════════════════════════ */
.review-popup-overlay{position:fixed;inset:0;background:rgba(44,42,39,0.62);z-index:2000;display:flex;align-items:center;justify-content:center;padding:1.5rem;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;animation:popFadeIn 0.5s ease 2s forwards}
@keyframes popFadeIn{to{opacity:1}}
.review-popup-overlay.hidden{display:none!important}
.review-popup{background:var(--cream);max-width:460px;width:100%;border-radius:4px;padding:2.25rem;position:relative;box-shadow:0 24px 64px rgba(44,42,39,0.35);border-top:3px solid var(--rust);transform:translateY(28px);animation:popSlideUp 0.5s var(--ease) 2s both}
@keyframes popSlideUp{from{transform:translateY(28px)}to{transform:translateY(0)}}
.review-popup-close{position:absolute;top:0.8rem;right:0.8rem;background:none;border:none;font-size:1.3rem;color:var(--text-muted);cursor:pointer;line-height:1;transition:color var(--t);padding:0.2rem}
.review-popup-close:hover{color:var(--rust)}
.review-popup h3{font-family:var(--font-serif);font-size:1.55rem;color:var(--charcoal);margin-bottom:0.3rem}
.review-popup>p{font-size:0.8rem;margin-bottom:1.4rem}
.star-select{display:flex;gap:0.3rem;margin-bottom:1.2rem}
.star-btn{font-size:1.5rem;color:var(--sand);background:none;border:none;cursor:pointer;transition:color 0.15s,transform 0.15s;line-height:1}
.star-btn.lit,.star-btn:hover{color:var(--rust-pale);transform:scale(1.12)}

/* ══════════════════════════════════════
   BUTTONS
══════════════════════════════════════ */
.btn-primary{display:inline-block;background:var(--rust);color:var(--cream);padding:0.82rem 1.9rem;font-size:0.74rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;border-radius:2px;transition:all var(--t);border:2px solid var(--rust)}
.btn-primary:hover{background:transparent;color:var(--rust)}
.btn-outline{display:inline-block;background:transparent;color:var(--cream);padding:0.82rem 1.9rem;font-size:0.74rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;border-radius:2px;border:1px solid rgba(245,240,232,0.4);transition:all var(--t)}
.btn-outline:hover{border-color:var(--cream);background:rgba(245,240,232,0.1)}
.btn-submit{width:100%;background:var(--rust);color:var(--cream);padding:0.95rem;font-family:var(--font-sans);font-size:0.76rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;border:none;cursor:pointer;border-radius:2px;transition:background var(--t)}
.btn-submit:hover{background:var(--rust-mid)}
.btn-white{display:inline-block;background:#fff;color:var(--rust);padding:0.82rem 1.9rem;font-size:0.74rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;border-radius:2px;border:2px solid #fff;transition:all var(--t)}
.btn-white:hover{background:transparent;color:#fff}
.btn-outline-white{display:inline-block;background:transparent;color:#fff;padding:0.82rem 1.9rem;font-size:0.74rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;border-radius:2px;border:1px solid rgba(255,255,255,0.4);transition:all var(--t)}
.btn-outline-white:hover{border-color:#fff;background:rgba(255,255,255,0.1)}

/* ══════════════════════════════════════
   FORMS
══════════════════════════════════════ */
.form-group{display:flex;flex-direction:column;gap:0.36rem}
.form-group label{font-size:0.63rem;font-weight:500;letter-spacing:0.13em;text-transform:uppercase;color:var(--rust)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:0.7rem 0.88rem;border:1px solid var(--sand);background:var(--warm-white);font-family:var(--font-sans);font-size:0.87rem;color:var(--charcoal);border-radius:2px;transition:border-color var(--t);outline:none;-webkit-appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--rust)}
.form-group textarea{resize:vertical;min-height:100px}

/* ══════════════════════════════════════
   SECTIONS
══════════════════════════════════════ */
.section{padding:5.5rem 2rem}
.section-inner{max-width:1280px;margin:0 auto}
.section-header{text-align:center;margin-bottom:3.5rem}
.eyebrow{display:inline-block;font-size:0.63rem;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--rust);margin-bottom:0.6rem}
.divider{width:48px;height:1.5px;background:var(--rust);margin:1.2rem auto}
.divider-left{width:48px;height:1.5px;background:var(--rust);margin:1.2rem 0}

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.at-hero{position:relative;height:100vh;min-height:580px;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;background:#1a1208}
.at-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-color:#2a1f10;opacity:0.52;animation:heroZoom 22s ease-in-out infinite alternate;will-change:transform}
.at-hero-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@keyframes heroZoom{from{transform:scale(1)}to{transform:scale(1.07)}}
.at-hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(20,14,6,0.28) 0%,rgba(20,14,6,0.08) 30%,rgba(20,14,6,0.45) 72%,rgba(20,14,6,0.92) 100%)}
.at-hero-center{position:relative;z-index:2;text-align:center;padding:0 1.5rem;max-width:820px;width:100%;margin-top:-90px}
.at-hero-eyebrow{display:inline-block;font-size:0.6rem;font-weight:500;letter-spacing:0.28em;text-transform:uppercase;color:var(--olive-light);margin-bottom:1.1rem;opacity:0;animation:fadeUp 0.8s ease 0.3s forwards}
.at-hero-title{font-family:var(--font-serif);font-size:clamp(2.8rem,7.5vw,6rem);font-weight:300;color:#fff;line-height:1.06;margin-bottom:0.9rem;opacity:0;animation:fadeUp 0.8s ease 0.5s forwards}
.at-hero-title em{font-style:italic;color:var(--olive-light)}
.at-hero-catch{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:clamp(0.95rem,2vw,1.3rem);letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.8);margin-bottom:2.1rem;opacity:0;animation:fadeUp 0.8s ease 0.7s forwards;line-height:1.6}
.at-hero-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp 0.8s ease 0.9s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* Hero layering */
.at-hero-center{z-index:2}
.at-search-bar-wrap{z-index:3}
.at-hero .at-hero-bg{z-index:0}

/* ══════════════════════════════════════
   TRIPADVISOR STRIP
══════════════════════════════════════ */
.ta-strip{background:var(--charcoal);padding:0.9rem 2rem;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:1.25rem}
.ta-logo{display:flex;align-items:center;gap:0.5rem;color:#34e0a1;font-size:0.78rem;font-weight:500;letter-spacing:0.06em}
.ta-owl{width:30px;height:30px;background:#34e0a1;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.ta-stars{color:#34e0a1;font-size:0.85rem;letter-spacing:0.05em}
.ta-text{font-size:0.72rem;color:rgba(255,255,255,0.48)}
.ta-link{font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:#34e0a1;border-bottom:1px solid #34e0a1;padding-bottom:1px;transition:opacity var(--t)}
.ta-link:hover{opacity:0.7}

/* ══════════════════════════════════════
   SEARCH BAR
══════════════════════════════════════ */
.at-search-bar-wrap{position:absolute;bottom:0;left:0;right:0;z-index:3;padding:0 2rem 2.5rem;opacity:0;animation:fadeUp 0.9s ease 1.1s forwards}
.at-search-bar{max-width:980px;margin:0 auto;background:rgba(245,240,232,0.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:4px;display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto;box-shadow:0 20px 60px rgba(0,0,0,0.38);overflow:hidden}
.at-sf{padding:1.1rem 1.15rem;border-right:1px solid rgba(212,201,168,0.65);display:flex;flex-direction:column;gap:0.15rem}
.at-sf-label{font-size:0.57rem;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;color:var(--rust)}
.at-sf select,.at-sf input{background:none;border:none;outline:none;font-family:var(--font-sans);font-size:0.85rem;color:var(--charcoal);width:100%;padding:0;cursor:pointer;-webkit-appearance:none}
.at-search-btn{background:var(--rust);color:#fff;border:none;padding:0 1.75rem;font-family:var(--font-sans);font-size:0.7rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;cursor:pointer;transition:background var(--t);white-space:nowrap;min-width:96px}
.at-search-btn:hover{background:var(--rust-mid)}
@media(max-width:800px){.at-search-bar{grid-template-columns:1fr 1fr; height: 300px;}.at-sf{border-bottom:1px solid rgba(212,201,168,0.5);border-right:none}.at-sf:nth-child(odd){border-right:1px solid rgba(212,201,168,0.5)}.at-search-btn{grid-column:1/-1;padding:1rem}.at-search-bar-wrap{padding:0 1rem 1rem}.at-hero-center{margin-top:-70px}}

/* ══════════════════════════════════════
   STATS
══════════════════════════════════════ */
.at-stats{background:var(--charcoal);padding:2.75rem 2rem}
.at-stats-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);text-align:center}
.at-stat{padding:0.5rem 1rem;position:relative}
.at-stat+.at-stat::before{content:'';position:absolute;left:0;top:15%;bottom:15%;width:1px;background:rgba(255,255,255,0.08)}
.at-stat-num{font-family:var(--font-serif);font-size:clamp(2.2rem,4vw,3.2rem);color:var(--olive-light);line-height:1;margin-bottom:0.35rem;font-weight:300}
.at-stat-label{font-size:0.63rem;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.35)}
@media(max-width:600px){.at-stats-inner{grid-template-columns:1fr 1fr;gap:2rem}.at-stat+.at-stat::before{display:none}}

/* ══════════════════════════════════════
   TOUR CARDS SCROLL
══════════════════════════════════════ */
.at-tours-section{padding:5.5rem 0 5.5rem 2rem;overflow:hidden}
.at-tours-header{max-width:1280px;margin:0 auto 2.25rem;padding-right:2rem;display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}
.at-tours-header h2{color:var(--charcoal);margin:0}
.at-view-all{font-size:0.7rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--rust);border-bottom:1px solid var(--rust);padding-bottom:2px;white-space:nowrap;transition:opacity var(--t)}
.at-view-all:hover{opacity:0.65}
.at-scroll-track{display:flex;gap:1.25rem;overflow-x:auto;padding-right:2rem;padding-bottom:0.5rem;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;cursor:grab}
.at-scroll-track::-webkit-scrollbar{display:none}
.at-scroll-track.grabbing{cursor:grabbing;user-select:none}
.at-tour-card{flex:0 0 278px;scroll-snap-align:start;background:var(--cream);clip-path:polygon(0% 0%,100% 0%,100% 92%,97% 96%,94% 100%,91% 97%,88% 100%,85% 96%,82% 100%,79% 98%,76% 100%,73% 96%,70% 100%,0% 100%);transition:transform 0.35s var(--ease),box-shadow 0.35s var(--ease)}
.at-tour-card:hover{transform:translateY(-8px);box-shadow:0 24px 52px rgba(44,42,39,0.18)}
.at-tour-img{width:100%;height:188px;background:linear-gradient(135deg,var(--olive-dark),var(--rust));position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:3.5rem;color:rgba(255,255,255,0.15)}
.at-tour-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.at-tour-badge{position:absolute;top:0.8rem;left:0.8rem;background:var(--rust);color:#fff;font-size:0.57rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;padding:0.24rem 0.58rem;border-radius:2px}
.at-tour-body{padding:1.1rem 1.15rem 1.7rem}
.at-tour-cat{font-size:0.58rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--rust);margin-bottom:0.3rem;font-weight:500}
.at-tour-name{font-family:var(--font-serif);font-size:1.12rem;color:var(--charcoal);line-height:1.27;margin-bottom:0.5rem}
.at-tour-desc{font-size:0.79rem;line-height:1.62;color:var(--text-muted);margin-bottom:0.8rem}
.at-tour-price{font-size:0.75rem;color:var(--text-muted)}
.at-tour-price strong{font-family:var(--font-serif);font-size:1.08rem;color:var(--rust);font-weight:400}

/* ══════════════════════════════════════
   DESTINATIONS GRID
══════════════════════════════════════ */
.at-dest-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;grid-template-rows:262px 262px;gap:0.65rem}
.at-dest-item:first-child{grid-row:1/3}
.at-dest-item{position:relative;overflow:hidden;background:var(--charcoal);cursor:pointer}
.at-dest-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.75s ease}
.at-dest-item:hover img{transform:scale(1.07)}
.at-dest-bg{width:100%;height:100%;background:linear-gradient(135deg,var(--olive-dark),var(--rust))}
.at-dest-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,14,6,0.8) 0%,transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.35rem;transition:background 0.4s}
.at-dest-item:hover .at-dest-overlay{background:linear-gradient(to top,rgba(20,14,6,0.88) 0%,rgba(20,14,6,0.12) 55%)}
.at-dest-name{font-family:var(--font-serif);font-size:1.35rem;color:#fff;font-weight:300;line-height:1.2}
.at-dest-item:first-child .at-dest-name{font-size:1.95rem}
.at-dest-country{font-size:0.63rem;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.52);margin-top:0.25rem}
@media(max-width:768px){.at-dest-grid{grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,175px)}.at-dest-item:first-child{grid-row:auto}}

/* ══════════════════════════════════════
   SPLIT SECTION
══════════════════════════════════════ */
.at-split{display:grid;grid-template-columns:1fr 1fr;min-height:520px}
.at-split-visual{position:relative;overflow:hidden;min-height:380px}
.at-split-visual-bg{position:absolute;inset:0;background:linear-gradient(155deg,#4a5830 0%,var(--rust) 100%)}
.at-split-visual-inner{position:relative;z-index:1;padding:4rem;height:100%;display:flex;flex-direction:column;justify-content:flex-end}
.at-split-text{background:var(--cream-dark);padding:4rem;display:flex;flex-direction:column;justify-content:center}
.feature-list{margin-top:1.75rem;display:flex;flex-direction:column;gap:1.35rem}
.feature-item{display:flex;gap:1rem;align-items:flex-start}
.feature-icon{width:36px;height:36px;flex-shrink:0;background:var(--rust);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.88rem;margin-top:2px}
.feature-item h4{font-size:0.87rem;font-weight:500;color:var(--charcoal);margin-bottom:0.17rem;font-family:var(--font-sans)}
.feature-item p{font-size:0.79rem;line-height:1.62}
@media(max-width:860px){.at-split{grid-template-columns:1fr}.at-split-visual{min-height:260px}.at-split-visual-inner,.at-split-text{padding:2.5rem 1.5rem}}

/* ══════════════════════════════════════
   AWARDS
══════════════════════════════════════ */
.at-awards{background:#fff;padding:1.9rem 2rem;border-top:1px solid var(--sand);border-bottom:1px solid var(--sand)}
.at-awards-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-around;flex-wrap:wrap;gap:1.25rem}
.at-award{text-align:center;min-width:100px}
.at-award-icon{font-size:1.7rem;color:var(--rust);display:block;margin-bottom:0.28rem;opacity:0.8}
.at-award-name{font-size:0.63rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--charcoal)}
.at-award-sub{font-size:0.6rem;color:var(--text-muted);margin-top:0.08rem}

/* ══════════════════════════════════════
   PARTNERS
══════════════════════════════════════ */
.partners-section{background:var(--cream-dark);padding:3.5rem 2rem}
.partners-grid{display:flex;flex-wrap:wrap;gap:1.25rem;justify-content:center;align-items:center;margin-top:2rem}
.partner-item{background:var(--warm-white);border:1px solid var(--sand);border-radius:3px;padding:1rem 1.6rem;display:flex;align-items:center;justify-content:center;min-width:130px;min-height:68px;transition:transform var(--t),box-shadow var(--t)}
.partner-item:hover{transform:translateY(-3px);box-shadow:0 8px 24px var(--shadow)}
.partner-item img{max-height:38px;max-width:115px;object-fit:contain;filter:grayscale(15%)}
.partner-placeholder{font-size:0.72rem;color:var(--text-muted);text-align:center;font-weight:500}

/* ══════════════════════════════════════
   TESTIMONIALS
══════════════════════════════════════ */
.at-testimonials{background:var(--charcoal);padding:6rem 2rem;overflow:hidden;position:relative}
.at-testimonials::before{content:'\201C';position:absolute;top:-3rem;left:-0.5rem;font-family:var(--font-serif);font-size:28vw;color:rgba(255,255,255,0.022);line-height:1;pointer-events:none}
.at-tcard{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.07);padding:1.8rem;clip-path:polygon(0% 0%,100% 0%,100% 95%,98% 100%,95% 96%,92% 100%,89% 97%,86% 100%,83% 96%,80% 100%,77% 97%,0% 97%);transition:background 0.3s,border-color 0.3s}
.at-tcard:hover{background:rgba(255,255,255,0.08);border-color:rgba(140,151,101,0.28)}
.at-tcard-stars{color:var(--rust-pale);margin-bottom:0.88rem;font-size:0.8rem;letter-spacing:0.07em}
.at-tcard-text{font-family:var(--font-serif);font-style:italic;font-size:1rem;color:rgba(255,255,255,0.82);line-height:1.74;margin-bottom:1.35rem}
.at-tcard-author{display:flex;align-items:center;gap:0.68rem}
.at-tcard-avatar{width:38px;height:38px;border-radius:50%;background:var(--olive);object-fit:cover;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1rem;color:rgba(255,255,255,0.4)}
.at-tcard-name{font-size:0.83rem;font-weight:500;color:var(--cream)}
.at-tcard-country{font-size:0.67rem;color:rgba(255,255,255,0.35)}

/* Testimonials horizontal scroll track */
.at-testimonials-track{display:flex;gap:1.5rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:1rem;margin-top:2.75rem;cursor:grab}
.at-testimonials-track::-webkit-scrollbar{display:none}
.at-testimonials-track.grabbing{cursor:grabbing;user-select:none}
.at-testimonials-track .at-tcard{flex:0 0 clamp(280px,80vw,340px);scroll-snap-align:start}

/* Testimonial arrow buttons */
.at-t-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);color:#fff;width:42px;height:42px;border-radius:50%;cursor:pointer;font-size:1.1rem;transition:background 0.2s;z-index:5;display:flex;align-items:center;justify-content:center}
.at-t-arrow:hover{background:rgba(255,255,255,0.25)}
.at-t-arrow-left{left:-1.2rem}
.at-t-arrow-right{right:-1.2rem}
@media(max-width:768px){.at-t-arrow{display:none}}

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
.site-footer{background:var(--charcoal);color:rgba(245,240,232,0.62);padding:5rem 2rem 2rem}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:4rem;padding-bottom:4rem;border-bottom:1px solid rgba(255,255,255,0.07)}
.footer-logo{font-family:var(--font-serif);font-style:italic;font-size:1.85rem;color:var(--olive-light);display:block;margin-bottom:0.85rem}
.footer-tagline{font-style:italic;font-family:var(--font-serif);color:rgba(245,240,232,0.38);margin-bottom:1.35rem;font-size:0.87rem}
.footer-socials{display:flex;gap:0.85rem;flex-wrap:wrap}
.social-link{font-size:0.7rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--olive-light);border-bottom:1px solid transparent;transition:border-color var(--t)}
.social-link:hover{border-bottom-color:var(--olive-light)}
.footer-heading{font-family:var(--font-sans);font-size:0.63rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--olive-light);margin-bottom:1.35rem;font-weight:500}
.footer-nav ul{list-style:none}
.footer-nav li{margin-bottom:0.62rem}
.footer-nav a{font-size:0.86rem;color:rgba(245,240,232,0.52);transition:color var(--t)}
.footer-nav a:hover{color:var(--cream)}
.footer-contact p,.footer-contact a{font-size:0.86rem;margin-bottom:0.52rem;color:rgba(245,240,232,0.52)}
.footer-contact a:hover{color:var(--cream)}
.footer-bottom{max-width:1280px;margin:1.75rem auto 0;font-size:0.72rem;color:rgba(245,240,232,0.25);text-align:center}
@media(max-width:768px){.footer-inner{grid-template-columns:1fr;gap:2.5rem}}

/* ══════════════════════════════════════
   CTA BANNER
══════════════════════════════════════ */
.at-cta{position:relative;padding:6.5rem 2rem;background:var(--rust);text-align:center;overflow:hidden}
.at-cta::before{content:'AFRICA';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-serif);font-size:22vw;color:rgba(255,255,255,0.04);white-space:nowrap;pointer-events:none;line-height:1}
.at-cta>*{position:relative}
.at-cta h2{color:#fff;font-weight:300;font-size:clamp(2rem,4vw,3rem);margin-bottom:0.72rem}
.at-cta p{color:rgba(255,255,255,0.65);max-width:520px;margin:0 auto 2.2rem}
.at-cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ══════════════════════════════════════
   ABOUT
══════════════════════════════════════ */
.about-hero{min-height:52vh;background:linear-gradient(135deg,var(--charcoal) 0%,var(--rust) 100%);display:flex;align-items:flex-end;padding:calc(var(--nav-h) + 4rem) 2rem 4rem;position:relative;overflow:hidden}
.about-hero::before{content:'AFRICA';position:absolute;right:-2rem;bottom:-1rem;font-family:var(--font-serif);font-size:18vw;color:rgba(255,255,255,0.03);line-height:1;pointer-events:none}
.about-story{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:1.35rem;margin-top:2rem}
.value-card{padding:1.35rem;background:var(--warm-white);border-top:2px solid var(--olive);border-radius:2px}
.value-card h4{font-size:0.88rem;color:var(--charcoal);margin-bottom:0.42rem;font-weight:500;font-family:var(--font-sans)}
.value-card p{font-size:0.8rem}
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(195px,1fr));gap:2rem}
.team-card{text-align:center}
.team-photo{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:2px;margin-bottom:1.1rem;background:var(--cream-dark);filter:grayscale(12%);transition:filter var(--t)}
.team-card:hover .team-photo{filter:grayscale(0%)}
.team-placeholder{width:100%;aspect-ratio:3/4;background:linear-gradient(160deg,var(--olive) 0%,var(--rust) 100%);border-radius:2px;margin-bottom:1.1rem;display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:3rem;color:rgba(255,255,255,0.4)}
.team-card h3{font-size:1.02rem;color:var(--charcoal)}
.team-card .role{font-size:0.66rem;color:var(--rust);letter-spacing:0.1em;text-transform:uppercase;margin:0.2rem 0 0.58rem}
@media(max-width:768px){.about-story{grid-template-columns:1fr}.about-values{grid-template-columns:1fr}}

/* ══════════════════════════════════════
   SERVICES
══════════════════════════════════════ */
.services-hero{min-height:44vh;background:var(--olive-dark);display:flex;align-items:flex-end;padding:calc(var(--nav-h) + 3rem) 2rem 3rem;overflow:hidden;position:relative}
.services-hero h1{color:var(--cream);font-weight:300}
.services-hero p{color:rgba(245,240,232,0.7);max-width:500px;margin-top:0.82rem}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:1.65rem}
.service-card{background:var(--cream);padding:1.8rem;border-left:3px solid transparent;transition:all var(--t);clip-path:polygon(0% 0%,100% 0%,100% 96%,98% 100%,95% 97%,92% 100%,89% 97%,86% 100%,0% 100%)}
.service-card:hover{border-left-color:var(--rust);transform:translateY(-5px);box-shadow:0 18px 44px var(--shadow)}
.service-icon{font-size:1.82rem;color:var(--rust);margin-bottom:1.05rem;display:block}
.service-card h3{font-size:1.15rem;color:var(--charcoal);margin-bottom:0.58rem}
.service-card p{font-size:0.82rem}
.service-price{margin-top:0.85rem;font-size:0.76rem;font-weight:500;color:var(--rust);letter-spacing:0.04em}

/* ══════════════════════════════════════
   CONTACT
══════════════════════════════════════ */
.contact-hero{min-height:40vh;background:var(--charcoal);display:flex;align-items:flex-end;padding:calc(var(--nav-h) + 3.5rem) 2rem 3rem;position:relative;overflow:hidden}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-form-wrap{background:var(--cream);padding:2.2rem;border-radius:3px}
.info-item{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.7rem}
.info-icon{width:38px;height:38px;background:var(--rust);color:var(--cream);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:0.95rem}
.info-text h4{font-size:0.65rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--rust);margin-bottom:0.28rem;font-family:var(--font-sans);font-weight:500}
.info-text p,.info-text a{font-size:0.88rem;color:var(--charcoal)}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════════
   BOOKING
══════════════════════════════════════ */
.booking-hero{min-height:38vh;background:var(--charcoal);display:flex;align-items:flex-end;padding:calc(var(--nav-h) + 3rem) 2rem 3rem;position:relative;overflow:hidden}
.booking-form-wrap{max-width:860px;margin:0 auto;background:var(--cream);border-radius:4px;padding:2.7rem;box-shadow:0 8px 40px var(--shadow)}
.booking-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.35rem}
.booking-full{grid-column:1/-1}
.booking-section-title{grid-column:1/-1;font-family:var(--font-serif);font-size:1.28rem;color:var(--charcoal);padding-bottom:0.62rem;border-bottom:1px solid var(--sand);margin-top:1.2rem}
.booking-section-title:first-child{margin-top:0}
@media(max-width:620px){.booking-grid{grid-template-columns:1fr}.booking-full,.booking-section-title{grid-column:1}}

/* ══════════════════════════════════════
   FAQ
══════════════════════════════════════ */
.faq-accordion{max-width:755px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--sand)}
.faq-q{padding:1.15rem 0;font-family:var(--font-serif);font-size:1.08rem;color:var(--charcoal);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:color var(--t)}
.faq-q:hover{color:var(--rust)}
.faq-q.open{color:var(--rust)}
.faq-arrow{font-size:0.72rem;transition:transform var(--t);flex-shrink:0}
.faq-q.open .faq-arrow{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.4s var(--ease)}
.faq-a-inner{padding:0 0 1.35rem;font-size:0.88rem;line-height:1.8;color:var(--text-muted)}

/* ══════════════════════════════════════
   BLOG
══════════════════════════════════════ */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(315px,1fr));gap:2rem}
.blog-card{background:var(--cream);border-radius:3px;overflow:hidden;transition:transform var(--t),box-shadow var(--t);clip-path:polygon(0% 0%,100% 0%,100% 95%,97% 100%,94% 96%,91% 100%,88% 97%,85% 100%,82% 96%,79% 100%,0% 100%)}
.blog-card:hover{transform:translateY(-6px);box-shadow:0 18px 44px var(--shadow)}
.blog-cover{width:100%;height:195px;object-fit:cover;background:linear-gradient(135deg,var(--olive-dark),var(--rust))}
.blog-body{padding:1.45rem}
.blog-meta{font-size:0.62rem;color:var(--text-muted);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:0.58rem}
.blog-title{font-family:var(--font-serif);font-size:1.18rem;color:var(--charcoal);margin-bottom:0.58rem;line-height:1.28}
.blog-excerpt{font-size:0.8rem;line-height:1.64}
.blog-author{display:flex;align-items:center;gap:0.58rem;margin-top:1.05rem;font-size:0.76rem;color:var(--text-muted)}

/* ══════════════════════════════════════
   WHATSAPP FLOAT
══════════════════════════════════════ */
.wa-float{position:fixed;bottom:calc(var(--mob-nav-h) + 1rem);right:1.2rem;z-index:9999;display:flex;flex-direction:column;align-items:flex-end;gap:0.5rem;pointer-events:none}
.wa-float>*{pointer-events:auto}
@media(min-width:769px){.wa-float{bottom:1.75rem}}
.wa-float-btn{width:52px;height:52px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;color:#fff;font-size:1.4rem;box-shadow:0 4px 18px rgba(37,211,102,0.45);transition:transform 0.2s,box-shadow 0.2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;cursor:pointer;pointer-events:auto}
.wa-float-btn:hover,.wa-float-btn:active{transform:scale(1.08);box-shadow:0 6px 24px rgba(37,211,102,0.55)}
.wa-float-label{background:var(--charcoal);color:var(--cream);font-size:0.68rem;font-weight:500;letter-spacing:0.06em;padding:0.32rem 0.7rem;border-radius:3px;white-space:nowrap;box-shadow:0 4px 12px var(--shadow-deep);display:none}
@media(min-width:769px){.wa-float-label{display:block;opacity:0;animation:wa-pulse 3s ease-in-out infinite;transition:opacity 0.3s}.wa-float:hover .wa-float-label{opacity:1;animation:none}}
@keyframes wa-pulse{0%,100%{opacity:1}50%{opacity:0.65}}

/* ══════════════════════════════════════
   COOKIE BANNER
══════════════════════════════════════ */
.cookie-banner{position:fixed;bottom:calc(var(--mob-nav-h) + 0.5rem);left:0.75rem;right:0.75rem;z-index:1500;background:var(--charcoal);color:var(--cream);border-radius:4px;padding:1rem 1.35rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;box-shadow:0 8px 32px rgba(0,0,0,0.28);font-size:0.78rem;transform:translateY(20px);opacity:0;transition:all 0.4s var(--ease)}
.cookie-banner.show{transform:translateY(0);opacity:1}
.cookie-banner p{color:rgba(245,240,232,0.72);flex:1;min-width:200px}
.cookie-banner a{color:var(--olive-light);border-bottom:1px solid var(--olive-light)}
.cookie-btns{display:flex;gap:0.55rem;flex-shrink:0}
.cookie-accept,.cookie-decline{padding:0.42rem 0.95rem;font-size:0.7rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;border:none;border-radius:2px;cursor:pointer;transition:all var(--t)}
.cookie-accept{background:var(--olive);color:#fff}
.cookie-accept:hover{background:var(--olive-dark)}
.cookie-decline{background:transparent;color:rgba(245,240,232,0.48);border:1px solid rgba(245,240,232,0.2)}
.cookie-decline:hover{color:var(--cream)}
@media(min-width:769px){.cookie-banner{bottom:1.25rem;left:1.5rem;right:auto;max-width:580px}}

/* ══════════════════════════════════════
   SCROLL REVEAL
══════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.7s var(--ease),transform 0.7s var(--ease)}
.reveal.visible{opacity:1;transform:none}

/* ══════════════════════════════════════
   UTILITY
══════════════════════════════════════ */
.page-main{padding-top:var(--nav-h)}
.bg-cream{background:var(--cream-dark)}
.bg-dark{background:var(--charcoal)}
.text-center{text-align:center}
.mt-2{margin-top:2rem}

/* ══════════════════════════════════════
   HERO SLIDESHOW
══════════════════════════════════════ */
.at-hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;pointer-events:none}
.at-hero-slide.active{opacity:1}
.at-hero-slide .at-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0.52;animation:heroZoom 22s ease-in-out infinite alternate}
.at-hero-slide-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0.52;z-index:0}