/* ==========================================================================
   COMPONENTS — section/widget styles from the approved mockups (design/*.html).
   Grows as each homepage/tour/destination section is ported. Prefix: aaa-
   ========================================================================== */

/* ── Section heading ── */
.aaa-sec-head .aaa-eyebrow{margin-bottom:12px}
.aaa-sec-head h2{font-size:clamp(2.3rem,4.2vw,3.5rem);margin-top:6px}
.aaa-sec-head h2 em{font-style:italic;color:var(--aaa-blue)}
.aaa-sec-head p{margin-top:14px;color:var(--aaa-ink-soft)}
.aaa-sec-head .aaa-lead{font-size:1.22rem;max-width:660px}
/* Split variant — heading on the left, "view all" link on the right */
.aaa-sec-head--split{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;max-width:none;margin:0 auto 54px}
.aaa-sec-head--split>div{max-width:680px}
@media(max-width:768px){.aaa-sec-head--split{flex-direction:column;align-items:flex-start;gap:18px}}

/* ── HERO ── */
.aaa-hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;color:#fff}
.aaa-hero__bg{position:absolute;inset:0;z-index:0}
.aaa-hero__bg img{width:100%;height:100%;object-fit:cover}
.aaa-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(7,18,38,.86),rgba(7,18,38,.5) 45%,rgba(7,18,38,.12));z-index:1}
/* Top scrim so a transparent header (white text) stays readable over light sky */
.aaa-hero::before{content:"";position:absolute;top:0;left:0;right:0;height:210px;background:linear-gradient(180deg,rgba(7,18,38,.6),transparent);z-index:1;pointer-events:none}
.aaa-hero .aaa-container{position:relative;z-index:2}
.aaa-hero h1{font-size:clamp(3rem,6.4vw,5.6rem);color:#fff;max-width:15ch;text-shadow:0 2px 36px rgba(0,0,0,.35)}
.aaa-hero h1 em{font-style:italic;color:var(--aaa-gold)}
.aaa-hero .aaa-eyebrow{color:#fff;display:inline-flex;align-items:center;gap:12px}
.aaa-hero .aaa-eyebrow::before{content:"";width:42px;height:2px;background:var(--aaa-gold)}
.aaa-hero__sub{font-size:1.4rem;max-width:48ch;margin:22px 0 32px;color:#eaf2ff}
.aaa-hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.aaa-hero__stats{display:flex;gap:34px;align-items:center;margin-top:42px;flex-wrap:wrap;color:#fff}
.aaa-hero__stat b{font-family:var(--aaa-serif);font-size:1.8rem;display:block;line-height:1}
.aaa-hero__stat span{font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;opacity:.85}
.aaa-hero__div{width:1px;height:42px;background:rgba(255,255,255,.25)}

/* ── TRUST STRIP ── */
.aaa-trust{background:var(--aaa-mist)}
.aaa-trust__row{display:flex;justify-content:space-between;align-items:center;gap:26px;flex-wrap:wrap;padding:30px 0}
.aaa-trust__item{display:flex;align-items:center;gap:14px}
.aaa-trust__item .ic{width:50px;height:50px;border-radius:50%;background:#fff;box-shadow:var(--aaa-shadow-sm);display:grid;place-items:center;font-size:1.4rem}
.aaa-trust__item b{font-family:var(--aaa-serif);font-size:1.1rem;display:block;line-height:1.1}
.aaa-trust__item .big{font-size:2.1rem;color:var(--aaa-blue)}
.aaa-trust__item span{font-size:.86rem;color:var(--aaa-ink-soft)}

/* ── FEATURE LIST (Why) ── */
.aaa-feature{display:flex;gap:16px;margin-bottom:22px}
.aaa-feature .ic{flex-shrink:0;width:52px;height:52px;border-radius:14px;background:var(--aaa-sky);display:grid;place-items:center;font-size:1.4rem;color:var(--aaa-blue)}
.aaa-feature b{font-family:var(--aaa-serif);font-size:1.25rem;display:block}
.aaa-feature p{font-size:1rem;color:var(--aaa-ink-soft);margin:4px 0 0}

/* ── HOW IT WORKS ── */
.aaa-how{background:var(--aaa-navy);color:#fff}
.aaa-how .aaa-eyebrow{color:var(--aaa-gold)}
.aaa-how h2{color:#fff}
.aaa-step{text-align:center}
.aaa-step .num{width:84px;height:84px;border-radius:50%;border:2px solid var(--aaa-gold);color:var(--aaa-gold);display:grid;place-items:center;font-family:var(--aaa-serif);font-size:2rem;font-weight:700;margin:0 auto 22px}
.aaa-step h3{color:#fff;font-size:1.5rem;margin-bottom:10px}
.aaa-step p{opacity:.82;max-width:30ch;margin:0 auto}

/* ── TOUR / DESTINATION CARDS ── */
.aaa-grid{display:grid;gap:28px}
.aaa-grid--2{grid-template-columns:repeat(2,1fr)}
.aaa-grid--3{grid-template-columns:repeat(3,1fr)}
.aaa-grid--4{grid-template-columns:repeat(4,1fr)}
.aaa-tour-card{background:var(--aaa-paper);border:1px solid var(--aaa-line);border-radius:var(--aaa-radius);overflow:hidden;display:flex;flex-direction:column;transition:.3s}
.aaa-tour-card:hover{transform:translateY(-8px);box-shadow:var(--aaa-shadow)}
.aaa-tour-card .ph{aspect-ratio:3/2;overflow:hidden;position:relative}
.aaa-tour-card .ph img{width:100%;height:100%;object-fit:cover;transition:.6s}
.aaa-tour-card:hover .ph img{transform:scale(1.09)}
.aaa-tour-card .tag{position:absolute;top:16px;left:16px;background:var(--aaa-blue);color:#fff;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;padding:6px 13px;border-radius:50px;font-weight:700}
.aaa-tour-card .fav{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;font-size:1.05rem;color:var(--aaa-blue)}
.aaa-tour-card .b{padding:22px 24px;display:flex;flex-direction:column;flex:1}
.aaa-tour-card .loc{font-size:.8rem;color:var(--aaa-blue);font-weight:700;text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:6px}
.aaa-tour-card h3{font-size:1.45rem;margin:9px 0 13px;line-height:1.2}
.aaa-tour-card .meta{display:flex;gap:16px;font-size:.88rem;color:var(--aaa-ink-soft);border-top:1px solid var(--aaa-line);padding-top:14px;margin-top:auto;flex-wrap:wrap}
.aaa-tour-card .meta span{display:flex;align-items:center;gap:6px;font-weight:500}
.aaa-tour-card .foot{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-top:1px solid var(--aaa-line);background:var(--aaa-mist)}
.aaa-tour-card .price small{display:block;font-size:.76rem;color:var(--aaa-ink-soft);font-weight:500;line-height:1.3}
.aaa-tour-card .price b{font-family:var(--aaa-serif);font-size:1.55rem;color:var(--aaa-ink);line-height:1}
.aaa-tour-card .rate{font-size:.84rem;color:var(--aaa-ink-soft);text-align:right;font-weight:500;line-height:1.4}
.aaa-tour-card .rate .star{color:var(--aaa-gold);font-size:.98rem}
.aaa-dest{position:relative;border-radius:var(--aaa-radius);overflow:hidden;aspect-ratio:3/4;display:flex;align-items:flex-end;color:#fff}
.aaa-dest img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.6s}
.aaa-dest:hover img{transform:scale(1.08)}
.aaa-dest .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,18,38,.92),rgba(7,18,38,.05) 65%)}
.aaa-dest .c{position:relative;padding:26px;width:100%}
.aaa-dest h3{color:#fff;font-size:1.85rem}
.aaa-dest__meta{display:flex;justify-content:space-between;align-items:center;margin-top:10px;gap:12px}
.aaa-dest__meta span{font-size:.9rem;opacity:.9}
.aaa-dest__go{width:42px;height:42px;border-radius:50%;border:2px solid rgba(255,255,255,.6);display:grid;place-items:center;transition:.25s;flex-shrink:0;font-size:1.1rem}
.aaa-dest:hover .aaa-dest__go{background:var(--aaa-gold);border-color:var(--aaa-gold);color:var(--aaa-navy)}

/* ── CTA ── */
.aaa-cta{position:relative;color:#fff;overflow:hidden;text-align:center}
.aaa-cta__bg{position:absolute;inset:0}.aaa-cta__bg img{width:100%;height:100%;object-fit:cover}
.aaa-cta::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(7,18,38,.94),rgba(11,91,211,.8))}
.aaa-cta .aaa-container{position:relative;z-index:2}
.aaa-cta h2{color:#fff}
.aaa-cta h2 em{color:var(--aaa-gold)}

/* ── WHY (image + feature list) ── */
.aaa-why{display:grid;grid-template-columns:1.05fr 1fr;gap:70px;align-items:center}
.aaa-why__imgs{position:relative}
.aaa-why__main{border-radius:var(--aaa-radius);overflow:hidden;box-shadow:var(--aaa-shadow);aspect-ratio:4/5}
.aaa-why__main img{width:100%;height:100%;object-fit:cover}
.aaa-why__badge{position:absolute;right:-24px;bottom:38px;background:var(--aaa-blue);color:#fff;border-radius:16px;padding:22px 26px;box-shadow:var(--aaa-shadow);max-width:215px}
.aaa-why__badge b{font-family:var(--aaa-serif);font-size:2.8rem;color:#fff;display:block;line-height:1}
.aaa-why__badge span{font-size:.9rem;opacity:.92}
.aaa-why h2{font-size:clamp(2.3rem,3.9vw,3.4rem);margin:14px 0 18px}
.aaa-why h2 em{font-style:italic;color:var(--aaa-blue)}
.aaa-why__features{display:grid;gap:22px;margin-top:30px}

/* ── REVIEWS (navy split) ── */
.aaa-reviews{background:var(--aaa-navy);color:#e8f0fb}
.aaa-reviews .aaa-eyebrow{color:var(--aaa-gold)}
.aaa-reviews h2{color:#fff;font-size:clamp(2.2rem,4vw,3.3rem);margin:14px 0 30px}
.aaa-reviews h2 em{font-style:italic;color:var(--aaa-gold)}
.aaa-rev-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:center}
.aaa-rev__stats{display:grid;gap:22px}
.aaa-rev__stat{border:1px solid rgba(255,255,255,.16);border-radius:16px;padding:24px 26px;display:flex;align-items:center;gap:20px;background:rgba(255,255,255,.04)}
.aaa-rev__stat b{font-family:var(--aaa-serif);font-size:2.8rem;color:var(--aaa-gold);line-height:1}
.aaa-rev__stat .star{color:var(--aaa-gold);letter-spacing:2px;font-size:1.05rem;display:block}
.aaa-rev__stat small{display:block;opacity:.78;font-size:.92rem;margin-top:4px}
.aaa-rev__cards{display:grid;gap:22px}
.aaa-rev__card{background:var(--aaa-paper);color:var(--aaa-ink);border-radius:18px;padding:34px 36px;box-shadow:var(--aaa-shadow)}
.aaa-rev__card .star{color:var(--aaa-gold);letter-spacing:2px;font-size:1.2rem}
.aaa-rev__quote{font-family:var(--aaa-serif);font-size:1.4rem;line-height:1.5;margin:16px 0 22px;font-style:italic;font-weight:500}
.aaa-rev__who{display:flex;align-items:center;gap:16px}
.aaa-rev__av{width:54px;height:54px;border-radius:50%;background:var(--aaa-sky);display:grid;place-items:center;font-family:var(--aaa-serif);color:var(--aaa-blue);font-weight:700;font-size:1.3rem;flex-shrink:0}
.aaa-rev__who b{display:block;font-size:1.02rem}
.aaa-rev__who small{color:var(--aaa-ink-soft);font-size:.9rem}

/* ── JOURNAL / BLOG cards ── */
.aaa-post{border-radius:var(--aaa-radius);overflow:hidden;border:1px solid var(--aaa-line);background:var(--aaa-paper);transition:.3s;display:flex;flex-direction:column}
.aaa-post:hover{transform:translateY(-6px);box-shadow:var(--aaa-shadow)}
.aaa-post .ph{aspect-ratio:16/10;overflow:hidden}
.aaa-post .ph img{width:100%;height:100%;object-fit:cover;transition:.6s}
.aaa-post:hover .ph img{transform:scale(1.08)}
.aaa-post .b{padding:26px}
.aaa-post .cat{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--aaa-blue);font-weight:700}
.aaa-post h3{font-size:1.35rem;margin:10px 0 12px;line-height:1.25}
.aaa-post p{font-size:.96rem;color:var(--aaa-ink-soft)}
.aaa-post .more{margin-top:16px;font-size:.9rem;font-weight:700;color:var(--aaa-blue);display:inline-flex;gap:6px}

/* ── CTA extra (points row) ── */
.aaa-cta .aaa-eyebrow{color:var(--aaa-gold)}
.aaa-cta p{margin:18px auto 26px;opacity:.94;font-size:1.18rem;max-width:52ch}
.aaa-cta__points{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;margin-bottom:30px}
.aaa-cta__points span{display:flex;align-items:center;gap:9px;font-size:.98rem;opacity:.95;font-weight:500}

/* ── PLANNER BAR (search) ── */
.aaa-planner{position:relative;z-index:6;margin:-52px auto 0}
.aaa-planner--flush{margin-top:0}
.aaa-planner__card{background:var(--aaa-paper);border-radius:18px;box-shadow:var(--aaa-shadow);padding:16px;display:grid;grid-template-columns:1.4fr 1fr 1fr auto;gap:10px;align-items:stretch}
.aaa-planner__field{padding:12px 18px;border-right:1px solid var(--aaa-line);display:flex;flex-direction:column;gap:4px}
.aaa-planner__field:last-of-type{border-right:none}
.aaa-planner__field label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--aaa-blue);font-weight:700}
.aaa-planner__field select,.aaa-planner__field input{border:none;background:none;font-family:var(--aaa-sans);font-size:1.05rem;color:var(--aaa-ink);outline:none;font-weight:600;width:100%}
.aaa-planner__card .aaa-btn{justify-content:center}

/* ── AWARDS MARQUEE ── */
.aaa-marquee{background:var(--aaa-navy);color:#fff;padding:22px 0;overflow:hidden;white-space:nowrap}
.aaa-marquee__track{display:inline-flex;gap:60px;align-items:center;animation:aaa-scrollx 26s linear infinite}
.aaa-marquee__track span{font-family:var(--aaa-serif);font-size:1.12rem;font-weight:600;opacity:.85;display:inline-flex;align-items:center}
.aaa-marquee__track span::after{content:"★";color:var(--aaa-gold);margin-left:46px}
@keyframes aaa-scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── BEST TIME / SEASON ── */
.aaa-season{background:var(--aaa-sand)}
.aaa-season-card{background:var(--aaa-paper);border-radius:var(--aaa-radius);padding:30px 26px;box-shadow:var(--aaa-shadow-sm);border-top:4px solid var(--aaa-blue);height:100%}
.aaa-season-card:nth-child(2){border-color:var(--aaa-gold)}
.aaa-season-card:nth-child(3){border-color:#3f9e6a}
.aaa-season-card:nth-child(4){border-color:#9c4a2c}
.aaa-season-card .mo{font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--aaa-blue)}
.aaa-season-card h3{font-size:1.4rem;margin:8px 0 10px}
.aaa-season-card p{font-size:.98rem;color:var(--aaa-ink-soft)}
.aaa-season-card .pk{display:inline-block;margin-top:14px;font-size:.78rem;font-weight:700;background:var(--aaa-sky);color:var(--aaa-blue-ink);padding:5px 12px;border-radius:50px}

/* ── SAFARI TYPES ── */
.aaa-types{background:var(--aaa-mist)}
.aaa-type{background:var(--aaa-paper);border:1px solid var(--aaa-line);border-radius:var(--aaa-radius);padding:34px 30px;transition:.3s;display:flex;gap:20px;align-items:flex-start;height:100%}
.aaa-type:hover{transform:translateY(-6px);box-shadow:var(--aaa-shadow);border-color:transparent}
.aaa-type .ic{flex-shrink:0;width:62px;height:62px;border-radius:16px;background:linear-gradient(135deg,var(--aaa-sky),#d4e7fe);display:grid;place-items:center;font-size:1.8rem}
.aaa-type h3{font-size:1.35rem;margin-bottom:8px}
.aaa-type p{font-size:.98rem;color:var(--aaa-ink-soft)}
.aaa-type .lnk{font-size:.9rem;color:var(--aaa-blue);font-weight:700;margin-top:12px;display:inline-block}

/* ── EDITORIAL GALLERY ── */
.aaa-gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:215px;gap:16px}
.aaa-gallery a{position:relative;border-radius:14px;overflow:hidden}
.aaa-gallery a img{width:100%;height:100%;object-fit:cover;transition:.6s}
.aaa-gallery a:hover img{transform:scale(1.08)}
.aaa-gallery .tall{grid-row:span 2}
.aaa-gallery .wide{grid-column:span 2}
.aaa-gallery .cap{position:absolute;left:0;bottom:0;right:0;padding:16px;background:linear-gradient(to top,rgba(7,18,38,.75),transparent);color:#fff;font-size:.9rem;font-weight:600;opacity:0;transition:.3s}
.aaa-gallery a:hover .cap{opacity:1}

/* ── EXPERTS / ABOUT ── */
.aaa-experts{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.aaa-experts__ph{border-radius:var(--aaa-radius);overflow:hidden;box-shadow:var(--aaa-shadow);aspect-ratio:5/4}
.aaa-experts__ph img{width:100%;height:100%;object-fit:cover}
.aaa-experts h2{font-size:clamp(2.3rem,3.9vw,3.4rem)}
.aaa-experts h2 em{font-style:italic;color:var(--aaa-blue)}
.aaa-experts__list{list-style:none;margin:26px 0;padding:0;display:grid;gap:14px}
.aaa-experts__list li{display:flex;gap:13px;align-items:flex-start;font-size:1.06rem}
.aaa-experts__list li::before{content:"✓";color:#fff;background:var(--aaa-blue);width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:.8rem;font-weight:700;flex-shrink:0;margin-top:3px}
.aaa-experts__sign{font-family:var(--aaa-serif);font-style:italic;font-size:1.5rem;color:var(--aaa-blue);margin:18px 0}

/* ── FAQ ── */
.aaa-faq-grid{max-width:860px;margin:0 auto;display:grid;gap:16px}
.aaa-faq{background:var(--aaa-paper);border:1px solid var(--aaa-line);border-radius:14px;padding:4px 26px;transition:.25s}
.aaa-faq[open]{box-shadow:var(--aaa-shadow-sm);border-color:transparent}
.aaa-faq summary{list-style:none;cursor:pointer;font-family:var(--aaa-serif);font-size:1.2rem;font-weight:600;padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:20px}
.aaa-faq summary::-webkit-details-marker{display:none}
.aaa-faq summary::after{content:"+";font-family:var(--aaa-sans);font-size:1.8rem;color:var(--aaa-blue);font-weight:400;transition:.25s;flex-shrink:0}
.aaa-faq[open] summary::after{transform:rotate(45deg)}
.aaa-faq p{padding:0 0 24px;color:var(--aaa-ink-soft);font-size:1.04rem;max-width:64ch}

/* ── NEWSLETTER ── */
.aaa-news{background:linear-gradient(120deg,var(--aaa-blue),var(--aaa-blue-deep));color:#fff;border-radius:24px;padding:60px;display:grid;grid-template-columns:1.2fr 1fr;gap:50px;align-items:center;box-shadow:var(--aaa-shadow)}
.aaa-news .aaa-eyebrow{color:var(--aaa-gold)}
.aaa-news h2{color:#fff;font-size:clamp(2rem,3.4vw,2.9rem);margin-top:10px}
.aaa-news p{opacity:.92;font-size:1.08rem;margin-top:12px;max-width:42ch}
.aaa-news__form{display:flex;gap:12px;background:#fff;padding:10px;border-radius:50px}
.aaa-news__form input{flex:1;border:none;outline:none;padding:0 20px;font-family:var(--aaa-sans);font-size:1.02rem;color:var(--aaa-ink);min-width:0}
.aaa-news__fine{opacity:.85;font-size:.86rem;margin-top:14px}

/* ── INSTAGRAM ── */
.aaa-insta{text-align:center}
.aaa-insta__handle{font-family:var(--aaa-serif);font-size:1.6rem;font-weight:600;color:var(--aaa-blue);margin-top:6px}
.aaa-insta__row{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-top:30px}
.aaa-insta__row a{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;display:block}
.aaa-insta__row img{width:100%;height:100%;object-fit:cover;transition:.5s}
.aaa-insta__row a::after{content:"⊕";position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-size:1.5rem;background:rgba(23,129,254,.55);opacity:0;transition:.3s}
.aaa-insta__row a:hover::after{opacity:1}
.aaa-insta__row a:hover img{transform:scale(1.1)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .aaa-grid--3,.aaa-grid--4{grid-template-columns:1fr 1fr}
  .aaa-why,.aaa-rev-grid,.aaa-experts,.aaa-news{grid-template-columns:1fr;gap:44px}
  .aaa-why__badge{right:14px}
  .aaa-planner__card{grid-template-columns:1fr 1fr}
  .aaa-gallery{grid-template-columns:1fr 1fr;grid-auto-rows:170px}
  .aaa-insta__row{grid-template-columns:repeat(3,1fr)}
  .aaa-news{padding:44px}
}
@media(max-width:768px){
  .aaa-hero{min-height:auto;padding:120px 0 60px}
  .aaa-grid--2,.aaa-grid--3,.aaa-grid--4{grid-template-columns:1fr}
  .aaa-trust__row{justify-content:flex-start}
  .aaa-rev__quote{font-size:1.2rem}
  .aaa-planner__card,.aaa-gallery{grid-template-columns:1fr}
  .aaa-planner{margin-top:0}
  .aaa-insta__row{grid-template-columns:repeat(2,1fr)}
  .aaa-news{padding:32px}
}
