/* ==========================================================================
   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 em{font-style:italic;color:var(--aaa-blue)}
.aaa-sec-head p{margin-top:14px;color:var(--aaa-ink-soft)}

/* ── 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}
.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--3{grid-template-columns:repeat(3,1fr)}
.aaa-grid--4{grid-template-columns:repeat(4,1fr)}
.aaa-tour-card{display:flex;flex-direction:column}
.aaa-tour-card .ph{aspect-ratio:3/2;overflow:hidden;position:relative}
.aaa-tour-card .ph img{width:100%;height:100%;object-fit:cover}
.aaa-tour-card .b{padding:22px;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}
.aaa-tour-card h3{font-size:1.4rem;margin:8px 0 12px}
.aaa-tour-card .foot{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:14px;border-top:1px solid var(--aaa-line)}
.aaa-tour-card .foot b{font-family:var(--aaa-serif);font-size:1.3rem}
.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,.9),transparent 62%)}
.aaa-dest .c{position:relative;padding:24px;width:100%}
.aaa-dest h3{color:#fff;font-size:1.6rem}
.aaa-dest span{font-size:.88rem;opacity:.9}

/* ── 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)}

@media(max-width:1024px){.aaa-grid--3,.aaa-grid--4{grid-template-columns:1fr 1fr}}
@media(max-width:768px){.aaa-hero{min-height:auto;padding:120px 0 60px}.aaa-grid--3,.aaa-grid--4{grid-template-columns:1fr}.aaa-trust__row{justify-content:flex-start}}
