/* =============================================================================
   BEAST OF AFRICA — ALL PAGES CSS
   File: assets/css/pages.css
   Covers every class from every page template
   Design system: Cormorant Garamond + Jost · Gold #c8a46e · Ink #080806
   ============================================================================= */

/* ─── Shared page tokens (supplement style.css) ─── */
:root {
  --p-serif: 'Cormorant Garamond', Georgia, serif;
  --p-sans:  'Jost', 'Helvetica Neue', sans-serif;
  --p-gold:  #c8a46e;
  --p-gold2: #d4b483;
  --p-ivory: #f0ead8;
  --p-muted: rgba(240,234,216,.62);
  --p-faint: rgba(240,234,216,.35);
  --p-bg:    #080806;
  --p-alt:   #0e0d0a;
  --p-glass: rgba(8,8,6,.78);
  --p-bord:  rgba(200,164,110,.14);
  --p-bord2: rgba(200,164,110,.26);
  --p-ease:  cubic-bezier(.16,1,.3,1);
}

/* ─── Reveal animation (shared, used on all pages) ─── */
.animate { opacity:0; transform:translateY(22px); transition: opacity .8s var(--p-ease), transform .8s var(--p-ease); }
.animate.visible, .animate.is-visible { opacity:1; transform:none; }

/* ─── Shared glass card ─── */
.p-glass {
  background: var(--p-glass);
  backdrop-filter: blur(22px) saturate(1.5);
  -webkit-backdrop-filter: blur(22px) saturate(1.5);
  border: 1px solid var(--p-bord);
  border-radius: 16px;
}


/* ═══════════════════════════════════════════════════════════════
   PAGE SHELL & BASIC PAGES (about, contacts, single-itinerary)
   ═══════════════════════════════════════════════════════════════ */

.page-shell {
  max-width: 1000px;
  margin: 0 auto;
  padding: clamp(3rem,6vw,5rem) clamp(1.25rem,4%,3rem);
}

.page-card {
  background: var(--p-glass);
  backdrop-filter: blur(24px) saturate(1.5);
  -webkit-backdrop-filter: blur(24px) saturate(1.5);
  border: 1px solid var(--p-bord);
  border-radius: 20px;
  padding: clamp(2rem,5vw,3.5rem);
}

.page-title {
  font-family: var(--p-serif);
  font-size: clamp(2.2rem,5vw,3.8rem);
  font-weight: 300;
  color: var(--p-ivory);
  line-height: 1.05;
  margin-bottom: 1rem;
  letter-spacing: -.02em;
}

.lead {
  font-size: 1.1rem;
  color: var(--p-muted);
  line-height: 1.85;
  margin-bottom: 2rem;
}

.kicker {
  display: inline-block;
  font-family: var(--p-sans);
  font-size: .62rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--p-gold);
  margin-bottom: 1rem;
}

/* two-col layout */
.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  margin-top: 2.5rem;
}

.two-col h3 {
  font-family: var(--p-serif);
  font-size: 1.4rem;
  color: var(--p-ivory);
  font-weight: 300;
  margin-bottom: .75rem;
}

.two-col p { font-size: .92rem; color: var(--p-muted); line-height: 1.8; margin-bottom: .75rem; }

/* bullets */
.bullets { list-style: none; padding: 0; display: flex; flex-direction: column; gap: .5rem; margin-top: .75rem; }
.bullets li {
  font-size: .88rem; color: var(--p-muted); display: flex; align-items: flex-start; gap: .65rem;
}
.bullets li::before { content: '✦'; color: var(--p-gold); font-size: .65rem; flex-shrink: 0; margin-top: .2rem; }

/* pullquote */
.quote {
  font-family: var(--p-serif);
  font-size: clamp(1.1rem,2.2vw,1.5rem);
  font-style: italic;
  color: var(--p-gold);
  border-left: 2px solid var(--p-gold);
  padding-left: 1.5rem;
  margin: 2.5rem 0;
  line-height: 1.55;
}

.cta-row {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 2rem;
}

/* map embed */
.map-embed iframe {
  width: 100%;
  height: 280px;
  border: 1px solid var(--p-bord);
  border-radius: 14px;
  margin-top: 1.25rem;
  filter: brightness(.85) saturate(.7);
}

/* contact form on contacts page */
.enquiry-form { display: flex; flex-direction: column; gap: 1rem; margin-top: 1rem; }
.enquiry-form input,
.enquiry-form textarea,
.enquiry-form select {
  width: 100%;
  padding: .8rem 1rem;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--p-bord);
  border-radius: 9px;
  color: var(--p-ivory);
  font-family: var(--p-sans);
  font-size: .9rem;
  transition: border-color .3s, box-shadow .3s;
}
.enquiry-form input:focus,
.enquiry-form textarea:focus {
  outline: none;
  border-color: rgba(200,164,110,.5);
  box-shadow: 0 0 0 3px rgba(200,164,110,.07);
}
.enquiry-form input::placeholder,
.enquiry-form textarea::placeholder { color: rgba(240,234,216,.35); }
.enquiry-form textarea { resize: none; min-height: 120px; }


/* ═══════════════════════════════════════════════════════════════
   PAGE HERO (used on about, contacts, lodges)
   ═══════════════════════════════════════════════════════════════ */

.page-hero {
  position: relative;
  height: clamp(380px,55vh,680px);
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  background: var(--p-bg);
}

.page-hero video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(.5) saturate(1.05);
}

.page-hero::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(8,8,6,.85) 100%);
  pointer-events: none;
}

.page-hero--enquire { height: clamp(480px,70vh,780px); align-items: center; }


/* ═══════════════════════════════════════════════════════════════
   TANZANIA & KENYA PAGES  (tz-* / ke-*)
   ═══════════════════════════════════════════════════════════════ */

/* ── Hero ── */
.tz-hero {
  position: relative;
  height: 100vh; min-height: 640px;
  overflow: hidden;
  display: flex; align-items: center;
}

.tz-hero__media { position: absolute; inset: 0; }
.tz-hero__video {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(.6) saturate(1.1);
  transform: scale(1.04);
}
.tz-hero__overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(8,8,6,.88) 0%, rgba(8,8,6,.5) 55%, rgba(8,8,6,.12) 100%),
    linear-gradient(180deg, rgba(8,8,6,.25) 0%, transparent 40%, rgba(8,8,6,.7) 100%);
}

.tz-hero__content {
  position: relative; z-index: 3;
  padding: 0 clamp(1.5rem,8vw,6rem);
  max-width: 800px;
  animation: tzFadeUp 1s var(--p-ease) both;
}
@keyframes tzFadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:none} }

.tz-kicker {
  display: inline-flex; align-items: center; gap: .6rem;
  padding: .48rem 1rem;
  background: rgba(200,164,110,.1); border: 1px solid rgba(200,164,110,.22);
  border-radius: 999px; font-size: .64rem; letter-spacing: .2em;
  text-transform: uppercase; color: var(--p-gold); margin-bottom: 1.5rem;
}
.tz-kicker--light { background: transparent; border-color: transparent; padding-left: 0; }

.tz-hero__title {
  font-family: var(--p-serif);
  font-size: clamp(3.5rem,10vw,7rem);
  font-weight: 300; color: var(--p-ivory);
  line-height: .92; letter-spacing: -.03em; margin-bottom: 1.25rem;
  background: linear-gradient(180deg,#fff 0%,var(--p-ivory) 55%,var(--p-gold) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

.tz-hero__sub {
  font-size: clamp(.9rem,1.8vw,1.1rem); color: rgba(240,234,216,.72);
  line-height: 1.75; margin-bottom: 2.25rem; font-weight: 300;
}

.tz-hero__actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 2.5rem; }
.tz-hero__trust {
  display: flex; align-items: center; gap: .9rem; flex-wrap: wrap;
  font-size: .74rem; color: var(--p-faint);
}
.tz-divider { width: 1px; height: 14px; background: rgba(200,164,110,.3); }

/* ── Buttons (tz-specific) ── */
.tz-btn {
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .85rem 1.85rem; border-radius: 9px;
  font-family: var(--p-sans); font-size: .82rem; font-weight: 600;
  letter-spacing: .09em; text-transform: uppercase; text-decoration: none;
  transition: all .35s var(--p-ease); cursor: pointer; border: none;
}
.tz-btn--gold { background: var(--p-gold); color: var(--p-bg); }
.tz-btn--gold:hover { background: var(--p-gold2); transform: translateY(-3px); box-shadow: 0 12px 34px rgba(200,164,110,.3); }
.tz-btn--ghost { border: 1px solid rgba(200,164,110,.4); color: var(--p-gold); background: transparent; }
.tz-btn--ghost:hover { background: rgba(200,164,110,.09); border-color: var(--p-gold); }
.tz-btn--lg { padding: 1rem 2.5rem; font-size: .88rem; }

/* ── Shared label ── */
.tz-label {
  display: inline-block; font-size: .6rem; letter-spacing: .28em;
  text-transform: uppercase; color: var(--p-gold); margin-bottom: .75rem;
}

/* ── Intro section ── */
.tz-intro { padding: clamp(4rem,8vw,7rem) clamp(1.5rem,5vw,4rem); background: rgba(8,8,6,.88); }
.tz-intro__inner { max-width: 900px; margin: 0 auto; text-align: center; }
.tz-intro__heading {
  font-family: var(--p-serif); font-size: clamp(2rem,4.5vw,3.5rem);
  font-weight: 300; color: var(--p-ivory); line-height: 1.1; margin-bottom: 1.25rem;
}
.tz-intro__heading em { font-style: italic; color: var(--p-gold); }
.tz-intro__body { font-size: .97rem; color: var(--p-muted); line-height: 1.9; max-width: 760px; margin: 0 auto 2.5rem; }

/* stats row */
.tz-stats { display: flex; justify-content: center; gap: 3rem; flex-wrap: wrap; }
.tz-stat { text-align: center; }
.tz-stat strong { display: block; font-family: var(--p-serif); font-size: 2.2rem; color: var(--p-gold); font-weight: 300; line-height: 1; }
.tz-stat span { font-size: .72rem; color: var(--p-faint); text-transform: uppercase; letter-spacing: .1em; display: block; margin-top: .35rem; }

/* ── Season cards ── */
.tz-seasons { padding: clamp(4rem,8vw,7rem) clamp(1.5rem,5vw,4rem); background: rgba(6,6,5,.92); border-top: 1px solid var(--p-bord); }
.tz-seasons__inner { max-width: 1320px; margin: 0 auto; }
.tz-seasons__heading {
  font-family: var(--p-serif); font-size: clamp(1.8rem,3.5vw,2.8rem);
  font-weight: 300; color: var(--p-ivory); margin-bottom: 2.5rem; text-align: center;
}
.tz-seasons__grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(260px,1fr)); gap: 1.5rem; }

.tz-season-card {
  background: var(--p-glass); border: 1px solid var(--p-bord);
  border-radius: 16px; padding: 2rem 1.75rem;
  backdrop-filter: blur(18px);
  transition: all .4s var(--p-ease);
}
.tz-season-card:hover { transform: translateY(-6px); border-color: var(--p-bord2); box-shadow: 0 20px 56px rgba(0,0,0,.4); }
.tz-season-card--peak { border-color: rgba(200,164,110,.28); }
.tz-season-card__month {
  font-family: var(--p-serif); font-size: 1.3rem; color: var(--p-gold);
  font-weight: 300; display: block; margin-bottom: .35rem;
}
.tz-season-card__name {
  font-size: .72rem; text-transform: uppercase; letter-spacing: .14em;
  color: var(--p-faint); display: block; margin-bottom: 1rem;
}
.tz-season-card p { font-size: .88rem; color: var(--p-muted); line-height: 1.75; margin-bottom: 1rem; }
.tz-season-card ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: .4rem; }
.tz-season-card ul li { font-size: .82rem; color: var(--p-muted); display: flex; gap: .5rem; }
.tz-season-card ul li::before { content: '—'; color: var(--p-gold); opacity: .55; flex-shrink: 0; }

/* ── Migration / editorial strip ── */
.tz-migration {
  display: grid; grid-template-columns: 1fr 1fr;
  min-height: 520px;
  border-top: 1px solid var(--p-bord);
}
.tz-migration__img { background-size: cover; background-position: center; min-height: 380px; }
.tz-migration__content {
  background: rgba(6,6,5,.95);
  display: flex; flex-direction: column; justify-content: center; gap: 1.25rem;
  padding: clamp(3rem,6vw,5rem) clamp(2rem,5vw,4rem);
}
.tz-migration__content h2 {
  font-family: var(--p-serif); font-size: clamp(1.8rem,3.5vw,2.8rem);
  font-weight: 300; color: var(--p-ivory); line-height: 1.1;
}
.tz-migration__content p { font-size: .92rem; color: var(--p-muted); line-height: 1.85; }
.tz-migration__timeline { display: flex; flex-direction: column; gap: .65rem; border-left: 2px solid rgba(200,164,110,.2); padding-left: 1.25rem; }
.tz-mt { font-size: .84rem; color: var(--p-muted); line-height: 1.6; }
.tz-mt strong { color: var(--p-gold); font-weight: 500; }

/* ── Experiences grid ── */
.tz-experiences { padding: clamp(4rem,8vw,7rem) clamp(1.5rem,5vw,4rem); background: rgba(8,8,6,.9); border-top: 1px solid var(--p-bord); }
.tz-experiences__inner { max-width: 1320px; margin: 0 auto; }
.tz-experiences__heading {
  font-family: var(--p-serif); font-size: clamp(1.8rem,3.5vw,2.8rem);
  font-weight: 300; color: var(--p-ivory); margin-bottom: 2.5rem; text-align: center;
}

.tz-exp-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(300px,1fr)); gap: 1.5rem; }
.tz-exp-card {
  background: var(--p-glass); border: 1px solid var(--p-bord);
  border-radius: 16px; overflow: hidden;
  backdrop-filter: blur(18px);
  transition: all .45s var(--p-ease);
}
.tz-exp-card:hover { transform: translateY(-8px); border-color: var(--p-bord2); box-shadow: 0 22px 60px rgba(0,0,0,.45); }
.tz-exp-card__img { height: 220px; background-size: cover; background-position: center; transition: transform .7s var(--p-ease); }
.tz-exp-card:hover .tz-exp-card__img { transform: scale(1.05); }
.tz-exp-card__body { padding: 1.5rem; }
.tz-exp-card__body h3 { font-family: var(--p-serif); font-size: 1.2rem; color: var(--p-ivory); margin-bottom: .6rem; font-weight: 400; }
.tz-exp-card__body p { font-size: .85rem; color: var(--p-muted); line-height: 1.75; }

/* ── Routes ── */
.tz-routes { padding: clamp(4rem,8vw,7rem) clamp(1.5rem,5vw,4rem); background: rgba(5,5,4,.93); border-top: 1px solid var(--p-bord); }
.tz-routes__inner { max-width: 1320px; margin: 0 auto; }
.tz-routes__inner h2 { font-family: var(--p-serif); font-size: clamp(1.8rem,3.5vw,2.8rem); font-weight: 300; color: var(--p-ivory); margin-bottom: 2.5rem; text-align: center; }
.tz-routes__grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(300px,1fr)); gap: 1.5rem; }

.tz-route {
  background: var(--p-glass); border: 1px solid var(--p-bord);
  border-radius: 16px; padding: 2rem; backdrop-filter: blur(18px);
  transition: all .4s var(--p-ease);
}
.tz-route:hover { border-color: var(--p-bord2); transform: translateY(-5px); }
.tz-route--featured { border-color: rgba(200,164,110,.32); background: rgba(200,164,110,.05); }
.tz-route__days {
  font-family: var(--p-serif); font-size: 2.8rem; color: var(--p-gold);
  font-weight: 300; line-height: 1; margin-bottom: .5rem;
}
.tz-route h3 { font-family: var(--p-serif); font-size: 1.3rem; color: var(--p-ivory); font-weight: 400; margin-bottom: .75rem; }
.tz-route p { font-size: .88rem; color: var(--p-muted); line-height: 1.75; margin-bottom: 1.25rem; }
.tz-route__stops { display: flex; flex-wrap: wrap; gap: .45rem; margin-bottom: 1.25rem; }
.tz-route__stops span {
  padding: .32rem .75rem; background: rgba(200,164,110,.08);
  border: 1px solid rgba(200,164,110,.18); border-radius: 20px;
  font-size: .7rem; color: var(--p-gold);
}
.tz-route__link {
  font-size: .78rem; color: var(--p-gold); text-decoration: none;
  letter-spacing: .05em; border-bottom: 1px solid rgba(200,164,110,.3);
  padding-bottom: 2px; transition: all .3s;
}
.tz-route__link:hover { border-bottom-color: var(--p-gold); }

/* ── Destinations section (filter + cards) ── */
.tz-destinations {
  padding: clamp(4rem,8vw,7rem) clamp(1.5rem,5vw,4rem);
  background: rgba(8,8,6,.88); border-top: 1px solid var(--p-bord); position: relative;
}

.tz-dest__header { max-width: 1320px; margin: 0 auto 2rem; text-align: center; }
.tz-dest__header h2 { font-family: var(--p-serif); font-size: clamp(1.8rem,3.5vw,2.8rem); font-weight: 300; color: var(--p-ivory); margin-bottom: .6rem; }
.tz-dest__sub { font-size: .9rem; color: var(--p-muted); }

/* page background texture (behind cards) */
.tanzania-page-bg {
  position: absolute; inset: 0; background-size: cover; background-position: center;
  opacity: .04; pointer-events: none;
}

/* filter bar */
.tz-filters { display: flex; gap: .6rem; flex-wrap: wrap; max-width: 1320px; margin: 0 auto 2.5rem; }
.tz-filters button,
.filters button {
  padding: .5rem 1.2rem; border: 1px solid var(--p-bord); border-radius: 24px;
  background: transparent; color: var(--p-muted); font-family: var(--p-sans);
  font-size: .78rem; font-weight: 500; cursor: pointer; transition: all .3s;
}
.tz-filters button:hover, .filters button:hover { border-color: var(--p-bord2); color: var(--p-ivory); }
.tz-filters button.is-active, .tz-filters button.active,
.filters button.is-active, .filters button.active {
  background: rgba(200,164,110,.1); border-color: var(--p-gold); color: var(--p-gold);
}

/* Tanzania cards wrapper */
.tanzania-wrapper.tz-cards-wrapper { max-width: 1320px; margin: 0 auto; display: flex; flex-direction: column; gap: 2.5rem; }

/* Place card (Tanzania full-detail) */
.place-card.tz-place-card {
  display: grid; grid-template-columns: 1.1fr 1.6fr;
  background: var(--p-glass); border: 1px solid var(--p-bord);
  border-radius: 20px; overflow: hidden; backdrop-filter: blur(20px);
  transition: all .5s var(--p-ease);
}
.place-card.tz-place-card:hover { border-color: var(--p-bord2); box-shadow: 0 24px 70px rgba(0,0,0,.5); }

/* photo gallery (3 stacked) */
.place-gallery { display: grid; grid-template-rows: 2fr 1fr 1fr; }
.img-slot { background-size: cover; background-position: center; transition: transform .7s var(--p-ease); }
.place-card.tz-place-card:hover .img-slot { transform: scale(1.04); }

/* info panel */
.place-info { padding: 2.25rem; display: flex; flex-direction: column; gap: 1rem; overflow-y: auto; max-height: 680px; }

/* card meta */
.tz-card__meta { display: flex; justify-content: space-between; align-items: center; }
.tz-card__cat { font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; color: var(--p-gold); }
.tz-card__stay { font-size: .72rem; color: var(--p-faint); }

.tz-card__title { font-family: var(--p-serif); font-size: clamp(1.4rem,2.5vw,2rem); font-weight: 300; color: var(--p-ivory); line-height: 1.1; }
.tz-card__desc { font-size: .9rem; color: var(--p-muted); line-height: 1.8; }

/* facts */
.tz-facts { display: flex; flex-direction: column; gap: 1rem; padding-top: 1rem; border-top: 1px solid var(--p-bord); }
.tz-fact-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.tz-fact { display: flex; flex-direction: column; gap: .25rem; }
.tz-fact__label { font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: var(--p-gold); }
.tz-fact__val { font-size: .84rem; color: var(--p-muted); }

/* highlights list */
.tz-highlights { display: flex; flex-direction: column; gap: .35rem; }
.tz-highlights ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: .35rem; }
.tz-highlights ul li { font-size: .83rem; color: var(--p-muted); display: flex; gap: .5rem; }
.tz-highlights ul li::before { content: '–'; color: var(--p-gold); flex-shrink: 0; }

/* tip block */
.tz-tip {
  display: flex; gap: .75rem; align-items: flex-start;
  padding: 1rem 1.1rem; background: rgba(200,164,110,.06);
  border: 1px solid rgba(200,164,110,.15); border-radius: 12px;
  font-size: .82rem; color: var(--p-muted); line-height: 1.65;
}
.tz-tip__icon { color: var(--p-gold); flex-shrink: 0; font-size: .9rem; margin-top: .15rem; }

/* enquire button on card */
.tz-enquire-btn {
  display: inline-flex; align-items: center; gap: .55rem;
  color: var(--p-gold); font-size: .8rem; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase; text-decoration: none;
  border: 1px solid rgba(200,164,110,.3); border-radius: 8px;
  padding: .7rem 1.25rem; transition: all .3s; margin-top: .5rem;
}
.tz-enquire-btn:hover { background: rgba(200,164,110,.09); border-color: var(--p-gold); }
.tz-enquire-btn svg { transition: transform .3s; }
.tz-enquire-btn:hover svg { transform: translateX(4px); }

/* ── CTA section ── */
.tz-cta {
  padding: clamp(5rem,10vw,8rem) clamp(1.5rem,5vw,4rem);
  text-align: center;
  background: rgba(6,6,5,.95);
  border-top: 1px solid var(--p-bord);
}
.tz-cta__inner { max-width: 700px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: 1.25rem; }
.tz-cta__inner h2 { font-family: var(--p-serif); font-size: clamp(2rem,5vw,3.8rem); font-weight: 300; color: var(--p-ivory); line-height: 1.05; }
.tz-cta__inner p { font-size: .95rem; color: var(--p-muted); line-height: 1.85; }


/* ── KENYA-SPECIFIC ── */
.ke-bigcats { /* same as tz-migration */ }
.ke-conservancy-intro { background: rgba(8,8,6,.88); }

/* Kenya place cards */
.places-grid.ke-places-grid { max-width: 1320px; margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fill,minmax(320px,1fr)); gap: 1.5rem; }

.ke-place-card {
  background: var(--p-glass); border: 1px solid var(--p-bord);
  border-radius: 16px; overflow: hidden; backdrop-filter: blur(18px);
  transition: all .45s var(--p-ease); display: flex; flex-direction: column;
}
.ke-place-card:hover { transform: translateY(-8px); border-color: var(--p-bord2); box-shadow: 0 22px 60px rgba(0,0,0,.45); }

.ke-card__img {
  height: 240px; background-size: cover; background-position: center;
  position: relative; flex-shrink: 0; transition: transform .7s var(--p-ease);
}
.ke-place-card:hover .ke-card__img { transform: scale(1.04); }
.ke-card__cat-badge {
  position: absolute; top: 1rem; left: 1rem;
  background: rgba(200,164,110,.88); color: var(--p-bg);
  padding: .3rem .75rem; border-radius: 6px;
  font-size: .62rem; font-weight: 700; letter-spacing: .08em;
}

.ke-card__body { padding: 1.5rem; display: flex; flex-direction: column; flex-grow: 1; }
.ke-card__meta-row { display: flex; justify-content: space-between; font-size: .72rem; color: var(--p-faint); margin-bottom: .65rem; }
.ke-card__body h3 { font-family: var(--p-serif); font-size: 1.25rem; font-weight: 400; color: var(--p-ivory); margin-bottom: .6rem; }
.ke-card__body p { font-size: .86rem; color: var(--p-muted); line-height: 1.75; flex-grow: 1; margin-bottom: 1rem; }

.ke-card__highlights { list-style: none; padding: 0; display: flex; flex-direction: column; gap: .35rem; margin-bottom: 1.1rem; }
.ke-card__highlights li { font-size: .8rem; color: var(--p-muted); display: flex; gap: .5rem; }
.ke-card__highlights li::before { content: '–'; color: var(--p-gold); flex-shrink: 0; }

.ke-card__footer { display: flex; gap: .75rem; flex-wrap: wrap; margin-top: auto; }
.ke-btn-explore {
  display: inline-flex; align-items: center;
  font-size: .78rem; color: var(--p-gold); font-weight: 600;
  letter-spacing: .07em; text-decoration: none; transition: letter-spacing .3s;
}
.ke-btn-explore:hover { letter-spacing: .14em; }
.ke-btn-enquire {
  display: inline-flex; align-items: center;
  padding: .42rem .95rem; border: 1px solid rgba(200,164,110,.3); border-radius: 20px;
  font-size: .75rem; color: var(--p-gold); text-decoration: none; transition: all .3s;
}
.ke-btn-enquire:hover { background: rgba(200,164,110,.09); border-color: var(--p-gold); }


/* ═══════════════════════════════════════════════════════════════
   ARUSHA PAGE  (pa-*)
   ═══════════════════════════════════════════════════════════════ */

.page-arusha { background: var(--p-bg); }

/* hero */
.pa-hero {
  position: relative; height: 100vh; min-height: 600px;
  display: flex; align-items: flex-end; overflow: hidden;
}
.pa-hero__bg { position: absolute; inset: 0; }
.pa-hero__img { width: 100%; height: 100%; object-fit: cover; filter: brightness(.55) saturate(1.1); }
.pa-hero__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(8,8,6,.82) 0%, rgba(8,8,6,.35) 60%, transparent 100%),
              linear-gradient(180deg, transparent 50%, rgba(8,8,6,.88) 100%);
}
.pa-hero__content {
  position: relative; z-index: 2;
  padding: 0 clamp(1.5rem,7vw,5rem) clamp(4rem,8vw,6rem);
  max-width: 780px;
}
.pa-hero__eyebrow {
  display: inline-flex; align-items: center; gap: .6rem;
  padding: .46rem 1rem; background: rgba(200,164,110,.1);
  border: 1px solid rgba(200,164,110,.22); border-radius: 999px;
  font-size: .62rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--p-gold); margin-bottom: 1.5rem;
}
.pa-hero__title {
  font-family: var(--p-serif); font-size: clamp(3rem,9vw,6.5rem);
  font-weight: 300; color: var(--p-ivory); line-height: .95;
  letter-spacing: -.03em; margin-bottom: 1.1rem;
  background: linear-gradient(180deg,#fff 0%,var(--p-ivory) 55%,var(--p-gold) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.pa-hero__title em { display: block; font-style: italic; }
.pa-hero__subtitle { font-size: 1rem; color: rgba(240,234,216,.65); font-weight: 300; margin-bottom: 2rem; }
.pa-hero__scroll-hint {
  position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: .4rem;
}
.pa-hero__scroll-hint span {
  width: 1px; height: 50px;
  background: linear-gradient(180deg,var(--p-gold) 0%,transparent 100%);
  animation: paScroll 1.8s ease-in-out infinite;
}
@keyframes paScroll { 0%,100%{opacity:.3;transform:scaleY(1)} 50%{opacity:1;transform:scaleY(1.15)} }

/* container */
.pa-container { max-width: 1320px; margin: 0 auto; padding: 0 clamp(1.25rem,4%,3rem); }

/* intro */
.pa-intro { padding: clamp(4rem,7vw,6rem) 0; background: rgba(8,8,6,.88); border-bottom: 1px solid var(--p-bord); }
.pa-intro__inner { display: grid; grid-template-columns: 1fr auto; gap: 4rem; align-items: center; }
.pa-intro__text h2 { font-family: var(--p-serif); font-size: clamp(1.8rem,3.5vw,2.8rem); font-weight: 300; color: var(--p-ivory); margin-bottom: 1rem; }
.pa-intro__text p { font-size: .95rem; color: var(--p-muted); line-height: 1.85; }
.pa-intro__stats { display: flex; flex-direction: column; gap: 1.5rem; }
.pa-stat { text-align: center; }
.pa-stat__number { display: block; font-family: var(--p-serif); font-size: 2.4rem; color: var(--p-gold); font-weight: 300; }
.pa-stat__label { display: block; font-size: .68rem; color: var(--p-faint); text-transform: uppercase; letter-spacing: .12em; margin-top: .2rem; }

/* attractions */
.pa-attractions { padding: clamp(4rem,7vw,6rem) 0; background: rgba(6,6,5,.9); }

.pa-region { margin-bottom: 4.5rem; }
.pa-region--alt .pa-region__header { background: rgba(200,164,110,.04); border: 1px solid var(--p-bord); border-radius: 16px; padding: 2.5rem; margin-bottom: 2.5rem; }
.pa-region__header { margin-bottom: 2.5rem; }
.pa-region__label { font-size: .62rem; letter-spacing: .22em; text-transform: uppercase; color: var(--p-gold); display: block; margin-bottom: .65rem; }
.pa-region__title { font-family: var(--p-serif); font-size: clamp(1.8rem,3.5vw,2.8rem); font-weight: 300; color: var(--p-ivory); margin-bottom: .75rem; }
.pa-region__desc { font-size: .92rem; color: var(--p-muted); line-height: 1.8; max-width: 620px; }

/* pa cards */
.pa-cards { display: grid; grid-template-columns: repeat(auto-fill,minmax(280px,1fr)); gap: 1.5rem; }
.pa-card {
  background: var(--p-glass); border: 1px solid var(--p-bord);
  border-radius: 16px; overflow: hidden; backdrop-filter: blur(18px);
  transition: all .45s var(--p-ease); display: flex; flex-direction: column;
}
.pa-card:hover { transform: translateY(-7px); border-color: var(--p-bord2); box-shadow: 0 20px 55px rgba(0,0,0,.45); }
.pa-card__img-wrap { overflow: hidden; height: 200px; flex-shrink: 0; }
.pa-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--p-ease); }
.pa-card:hover .pa-card__img { transform: scale(1.06); }
.pa-card__body { padding: 1.5rem; display: flex; flex-direction: column; flex-grow: 1; gap: .6rem; }
.pa-card__name { font-family: var(--p-serif); font-size: 1.15rem; font-weight: 400; color: var(--p-ivory); }
.pa-card__desc { font-size: .85rem; color: var(--p-muted); line-height: 1.72; flex-grow: 1; }

/* tags */
.pa-tags { display: flex; flex-wrap: wrap; gap: .4rem; }
.pa-tag {
  padding: .28rem .72rem; background: rgba(200,164,110,.07);
  border: 1px solid rgba(200,164,110,.15); border-radius: 20px;
  font-size: .68rem; color: var(--p-gold);
}

/* buttons */
.pa-btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .6rem 1.35rem; border-radius: 8px;
  font-family: var(--p-sans); font-size: .78rem; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase; text-decoration: none;
  transition: all .35s var(--p-ease); margin-top: auto;
}
.pa-btn.pa-btn--gold, .pa-btn:not(.pa-btn--ghost):not(.pa-btn--sm) { background: var(--p-gold); color: var(--p-bg); }
.pa-btn.pa-btn--ghost { border: 1px solid rgba(200,164,110,.4); color: var(--p-gold); }
.pa-btn.pa-btn--sm {
  background: transparent; border: 1px solid rgba(200,164,110,.28);
  color: var(--p-gold); padding: .45rem 1rem; font-size: .72rem;
}
.pa-btn.pa-btn--sm:hover { background: rgba(200,164,110,.08); border-color: var(--p-gold); }
.pa-btn.pa-btn--gold:hover { background: var(--p-gold2); transform: translateY(-2px); }

/* itinerary section */
.pa-itinerary { padding: clamp(4rem,7vw,6rem) 0; background: rgba(8,8,6,.9); border-top: 1px solid var(--p-bord); }
.pa-section-head { text-align: center; margin-bottom: 3rem; }
.pa-section-head__label { font-size: .62rem; letter-spacing: .22em; text-transform: uppercase; color: var(--p-gold); display: block; margin-bottom: .7rem; }
.pa-section-head h2 { font-family: var(--p-serif); font-size: clamp(1.8rem,3.5vw,2.8rem); font-weight: 300; color: var(--p-ivory); }
.pa-section-head p { font-size: .9rem; color: var(--p-muted); margin-top: .6rem; }

.pa-itinerary__grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(280px,1fr)); gap: 1.5rem; }
.pa-itin-card {
  background: var(--p-glass); border: 1px solid var(--p-bord);
  border-radius: 16px; padding: 2rem; backdrop-filter: blur(18px);
  transition: all .4s var(--p-ease); position: relative;
}
.pa-itin-card:hover { transform: translateY(-6px); border-color: var(--p-bord2); }
.pa-itin-card--featured { border-color: rgba(200,164,110,.28); }
.pa-itin-card__badge {
  display: inline-block; background: var(--p-gold); color: var(--p-bg);
  padding: .3rem .75rem; border-radius: 6px; font-size: .62rem;
  font-weight: 700; letter-spacing: .08em; margin-bottom: 1rem;
}
.pa-itin-card h3 { font-family: var(--p-serif); font-size: 1.2rem; color: var(--p-ivory); font-weight: 400; margin-bottom: 1rem; }
.pa-itin-card__list { padding-left: 1.25rem; display: flex; flex-direction: column; gap: .65rem; }
.pa-itin-card__list li { font-size: .85rem; color: var(--p-muted); line-height: 1.65; }
.pa-itin-card__list strong { color: var(--p-ivory); font-weight: 500; }

/* pa CTA */
.pa-cta { padding: clamp(4rem,7vw,6rem) 0; background: rgba(5,5,4,.95); border-top: 1px solid var(--p-bord); }
.pa-cta__inner { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 1.25rem; }
.pa-cta__inner h2 { font-family: var(--p-serif); font-size: clamp(2rem,5vw,3.8rem); font-weight: 300; color: var(--p-ivory); }
.pa-cta__inner p { font-size: .95rem; color: var(--p-muted); }


/* ═══════════════════════════════════════════════════════════════
   SOUVENIRS PAGE  (ps-*)
   ═══════════════════════════════════════════════════════════════ */

.page-souvenirs { background: var(--p-bg); }

/* hero */
.ps-hero {
  position: relative; height: clamp(480px,65vh,720px);
  display: flex; align-items: flex-end; overflow: hidden;
}
.ps-hero__bg { position: absolute; inset: 0; }
.ps-hero__img { width: 100%; height: 100%; object-fit: cover; filter: brightness(.5) saturate(1.1); }
.ps-hero__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg,rgba(8,8,6,.3) 0%,rgba(8,8,6,.88) 100%);
}
.ps-hero__content {
  position: relative; z-index: 2;
  padding: 0 clamp(1.5rem,7vw,5rem) clamp(3rem,6vw,5rem);
}
.ps-hero__eyebrow { font-size: .62rem; letter-spacing: .22em; text-transform: uppercase; color: var(--p-gold); display: block; margin-bottom: 1rem; }
.ps-hero__title {
  font-family: var(--p-serif); font-size: clamp(3rem,8vw,5.5rem);
  font-weight: 300; color: var(--p-ivory); line-height: .95;
  background: linear-gradient(180deg,#fff 0%,var(--p-ivory) 55%,var(--p-gold) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.ps-hero__title em { display: block; font-style: italic; }
.ps-hero__subtitle { font-size: 1rem; color: rgba(240,234,216,.62); font-weight: 300; margin-top: .75rem; }

/* ps container */
.ps-container { max-width: 1320px; margin: 0 auto; padding: 0 clamp(1.25rem,4%,3rem); }

/* filter bar */
.ps-filter-bar { padding: 2rem 0; background: rgba(8,8,6,.92); border-bottom: 1px solid var(--p-bord); }
.ps-filters { display: flex; gap: .55rem; flex-wrap: wrap; }
.ps-filter {
  padding: .48rem 1.15rem; border: 1px solid var(--p-bord); border-radius: 24px;
  background: transparent; color: var(--p-muted); font-family: var(--p-sans);
  font-size: .78rem; font-weight: 500; cursor: pointer; transition: all .3s;
}
.ps-filter:hover { border-color: var(--p-bord2); color: var(--p-ivory); }
.ps-filter.ps-filter--active { background: rgba(200,164,110,.1); border-color: var(--p-gold); color: var(--p-gold); }

/* shop grid */
.ps-shop { padding: clamp(3rem,6vw,5rem) 0; background: rgba(8,8,6,.88); }
.ps-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(280px,1fr)); gap: 1.5rem; }

/* product card */
.ps-card {
  background: var(--p-glass); border: 1px solid var(--p-bord);
  border-radius: 16px; overflow: hidden; backdrop-filter: blur(18px);
  transition: all .45s var(--p-ease); display: flex; flex-direction: column;
}
.ps-card:hover { transform: translateY(-8px); border-color: var(--p-bord2); box-shadow: 0 22px 60px rgba(0,0,0,.45); }

.ps-card__img-wrap { position: relative; overflow: hidden; height: 220px; flex-shrink: 0; }
.ps-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--p-ease); }
.ps-card:hover .ps-card__img { transform: scale(1.06); }
.ps-card__category {
  position: absolute; top: 1rem; left: 1rem;
  background: rgba(200,164,110,.88); color: var(--p-bg);
  padding: .3rem .75rem; border-radius: 6px;
  font-size: .62rem; font-weight: 700; letter-spacing: .07em;
}

.ps-card__body { padding: 1.5rem; display: flex; flex-direction: column; flex-grow: 1; gap: .65rem; }
.ps-card__name { font-family: var(--p-serif); font-size: 1.1rem; font-weight: 400; color: var(--p-ivory); }
.ps-card__desc { font-size: .84rem; color: var(--p-muted); line-height: 1.72; flex-grow: 1; }
.ps-card__price { display: flex; flex-direction: column; gap: .15rem; }
.ps-price { font-family: var(--p-serif); font-size: 1.1rem; color: var(--p-gold); font-weight: 300; }
.ps-price-tzs { font-size: .72rem; color: var(--p-faint); }

/* ps buy button */
.ps-btn {
  display: inline-flex; align-items: center; gap: .55rem;
  background: #25d366; color: #fff; padding: .7rem 1.25rem;
  border-radius: 9px; font-family: var(--p-sans); font-size: .78rem;
  font-weight: 600; letter-spacing: .06em; text-decoration: none;
  text-transform: uppercase; transition: all .35s var(--p-ease); margin-top: auto;
}
.ps-btn:hover { background: #20ba57; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(37,211,102,.28); }
.ps-btn.ps-btn--large { padding: 1rem 2.25rem; font-size: .86rem; }

/* trust strip */
.ps-trust { padding: 3rem 0; background: rgba(6,6,5,.92); border-top: 1px solid var(--p-bord); }
.ps-trust__inner { display: grid; grid-template-columns: repeat(auto-fit,minmax(180px,1fr)); gap: 2rem; text-align: center; }
.ps-trust__item { display: flex; flex-direction: column; align-items: center; gap: .6rem; }
.ps-trust__item svg { color: var(--p-gold); }
.ps-trust__item span { font-size: .82rem; color: var(--p-muted); }

/* ps CTA */
.ps-cta { padding: clamp(4rem,7vw,6rem) 0; background: rgba(8,8,6,.9); border-top: 1px solid var(--p-bord); }
.ps-cta__inner { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 1.25rem; }
.ps-cta__inner h2 { font-family: var(--p-serif); font-size: clamp(2rem,4vw,3rem); font-weight: 300; color: var(--p-ivory); }
.ps-cta__inner p { font-size: .92rem; color: var(--p-muted); max-width: 520px; }


/* ═══════════════════════════════════════════════════════════════
   LODGES PAGE  (tz-lodge-*)
   ═══════════════════════════════════════════════════════════════ */

.lodges-collection.page-shell { max-width: 1320px; }
.lodges-collection .page-card { background: rgba(8,8,6,.82); }
.lodges-filters { justify-content: flex-start; }

.tz-lodges-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(340px,1fr)); gap: 2rem; margin-top: 2rem; }

.tz-lodge-card {
  background: var(--p-glass); border: 1px solid var(--p-bord);
  border-radius: 18px; overflow: hidden; backdrop-filter: blur(18px);
  transition: all .45s var(--p-ease); display: flex; flex-direction: column;
}
.tz-lodge-card:hover { transform: translateY(-8px); border-color: var(--p-bord2); box-shadow: 0 24px 65px rgba(0,0,0,.48); }

.tz-lodge-img {
  height: 240px; background-size: cover; background-position: center;
  position: relative; flex-shrink: 0; transition: transform .7s var(--p-ease);
}
.tz-lodge-card:hover .tz-lodge-img { transform: scale(1.04); }
.tz-lodge-region {
  position: absolute; top: 1rem; left: 1rem;
  background: rgba(8,8,6,.82); backdrop-filter: blur(8px);
  border: 1px solid var(--p-bord); border-radius: 6px;
  padding: .32rem .75rem; font-size: .68rem; color: var(--p-gold); letter-spacing: .1em;
}
.tz-lodge-style {
  position: absolute; top: 1rem; right: 1rem;
  background: rgba(200,164,110,.88); color: var(--p-bg);
  padding: .3rem .75rem; border-radius: 6px;
  font-size: .62rem; font-weight: 700; letter-spacing: .07em;
}

.tz-lodge-body { padding: 1.75rem; display: flex; flex-direction: column; flex-grow: 1; gap: .75rem; }
.tz-lodge-meta { font-size: .62rem; color: var(--p-gold); letter-spacing: .16em; text-transform: uppercase; }
.tz-lodge-title { font-family: var(--p-serif); font-size: 1.3rem; font-weight: 400; color: var(--p-ivory); line-height: 1.15; }
.tz-lodge-copy { font-size: .88rem; color: var(--p-muted); line-height: 1.75; flex-grow: 1; }

.tz-lodge-features { list-style: none; padding: 0; display: flex; flex-direction: column; gap: .38rem; }
.tz-lodge-features li { font-size: .8rem; color: var(--p-muted); display: flex; gap: .5rem; }
.tz-lodge-features li::before { content: '–'; color: var(--p-gold); flex-shrink: 0; }

.tz-lodge-footer { border-top: 1px solid var(--p-bord); padding-top: 1rem; margin-top: auto; }
.tz-lodge-enquire {
  display: inline-flex; align-items: center; gap: .55rem;
  color: var(--p-gold); font-size: .78rem; font-weight: 600;
  letter-spacing: .07em; text-decoration: none;
  border-bottom: 1px solid rgba(200,164,110,.3); padding-bottom: 2px;
  transition: all .3s;
}
.tz-lodge-enquire:hover { border-bottom-color: var(--p-gold); }
.tz-lodge-enquire svg { transition: transform .3s; }
.tz-lodge-enquire:hover svg { transform: translateX(4px); }

/* lodges advisory (strip) */
.lodges-advisory .tz-migration__content { border-left: 1px solid var(--p-bord); }


/* ═══════════════════════════════════════════════════════════════
   ENQUIRE PAGE  (wizard-specific)
   ═══════════════════════════════════════════════════════════════ */

.enquiry-wizard { background: var(--p-bg); padding: clamp(3rem,6vw,5rem) clamp(1.25rem,4%,3rem); position: relative; }
.enquiry-wizard--page { min-height: 60vh; }

/* ambient orbs */
.wizard-ambient { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 0; }
.ambient-orb {
  position: absolute; border-radius: 50%;
  filter: blur(80px); opacity: .12;
}
.ambient-orb--1 { width: 600px; height: 600px; background: var(--p-gold); top: -200px; left: -100px; }
.ambient-orb--2 { width: 500px; height: 500px; background: rgba(60,100,50,.5); bottom: -150px; right: -100px; }

/* trip banner */
.wizard-trip-banner {
  max-width: 760px; margin: 0 auto 2rem; position: relative; z-index: 2;
}
.wizard-trip-banner__inner {
  display: flex; align-items: center; gap: 1rem;
  padding: 1rem 1.5rem; background: rgba(200,164,110,.08);
  border: 1px solid rgba(200,164,110,.22); border-radius: 14px;
  backdrop-filter: blur(12px);
}
.trip-banner__icon { color: var(--p-gold); flex-shrink: 0; width: 22px; height: 22px; }
.trip-banner__label { display: block; font-size: .64rem; color: var(--p-faint); letter-spacing: .14em; text-transform: uppercase; margin-bottom: .2rem; }
.trip-banner__name { font-family: var(--p-serif); font-size: 1.1rem; color: var(--p-ivory); font-weight: 400; }

/* wizard container */
.wizard#enquireWizard {
  max-width: 760px; margin: 0 auto;
  background: var(--p-glass); border: 1px solid var(--p-bord);
  border-radius: 22px; padding: clamp(2rem,5vw,3.5rem);
  backdrop-filter: blur(26px); position: relative; z-index: 2;
}

/* progress architecture */
.progress-architecture { margin-bottom: 3rem; }
.progress-wrap { height: 3px; background: rgba(255,255,255,.07); border-radius: 2px; margin-bottom: 1rem; }
.progress-bar { height: 100%; background: linear-gradient(90deg,var(--p-gold),var(--p-gold2)); border-radius: 2px; width: 0%; transition: width .65s var(--p-ease); }
.progress-steps { display: flex; justify-content: space-between; margin-bottom: .6rem; }
.progress-step { display: flex; flex-direction: column; align-items: center; gap: .3rem; }
.progress-step__dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: rgba(255,255,255,.1); border: 1.5px solid rgba(255,255,255,.15);
  transition: all .4s;
}
.progress-step.active .progress-step__dot { background: var(--p-gold); border-color: var(--p-gold); box-shadow: 0 0 12px rgba(200,164,110,.4); }
.progress-step.done .progress-step__dot { background: rgba(200,164,110,.4); border-color: rgba(200,164,110,.5); }
.progress-step__num { font-size: .6rem; color: var(--p-faint); }
.progress-meta { display: flex; justify-content: space-between; font-size: .76rem; color: var(--p-muted); }
.progress-current strong { color: var(--p-gold); }

/* step */
.step { display: none; }
.step.active { display: block; }

/* step header */
.step-header { margin-bottom: 2rem; }
.step-eyebrow { font-size: .62rem; letter-spacing: .22em; text-transform: uppercase; color: var(--p-gold); display: block; margin-bottom: .65rem; }
.step-headline {
  font-family: var(--p-serif); font-size: clamp(1.6rem,3.5vw,2.5rem);
  font-weight: 300; color: var(--p-ivory); line-height: 1.1; margin-bottom: .5rem;
}
.step-hint { font-size: .86rem; color: var(--p-muted); line-height: 1.7; }

/* option cards (destination, budget, theme, duration, travel) */
.options { display: flex; flex-direction: column; gap: .75rem; margin-bottom: 2rem; }
.options--destination { display: grid; grid-template-columns: 1fr 1fr; }
.options--theme { display: grid; grid-template-columns: 1fr 1fr; }
.options--duration { display: grid; grid-template-columns: 1fr 1fr; }
.options--travel-mode { display: grid; grid-template-columns: repeat(3,1fr); }

.option-card {
  display: flex; align-items: center; gap: 1rem;
  padding: 1.15rem 1.25rem; background: rgba(255,255,255,.03);
  border: 1.5px solid var(--p-bord); border-radius: 14px;
  cursor: pointer; text-align: left; transition: all .35s var(--p-ease);
  font-family: var(--p-sans);
}
.option-card:hover { border-color: rgba(200,164,110,.3); background: rgba(200,164,110,.04); }
.option-card.is-active, .option-card.selected {
  border-color: var(--p-gold); background: rgba(200,164,110,.09);
  box-shadow: 0 0 0 1px rgba(200,164,110,.2);
}

.option-card__flag { font-size: 1.5rem; flex-shrink: 0; }
.option-card__icon { font-size: 1.3rem; flex-shrink: 0; }
.option-card__days {
  font-family: var(--p-serif); font-size: 1.8rem; color: var(--p-gold);
  font-weight: 300; flex-shrink: 0; line-height: 1; min-width: 54px;
}
.option-card__body { flex: 1; min-width: 0; }
.option-card__title { display: block; font-size: .92rem; font-weight: 500; color: var(--p-ivory); }
.option-card__sub { display: block; font-size: .76rem; color: var(--p-muted); margin-top: .2rem; }

.option-card__badge {
  flex-shrink: 0; font-family: var(--p-serif); font-size: 1.1rem;
  color: var(--p-muted); font-weight: 300;
}
.option-card__badge--gold { color: var(--p-gold); }
.option-card__badge--platinum { color: #e8e8e8; }

.option-card__check {
  flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center;
  transition: all .3s;
}
.option-card.is-active .option-card__check { background: var(--p-gold); border-color: var(--p-gold); color: var(--p-bg); }
.option-card__check svg { width: 14px; height: 14px; opacity: 0; transition: opacity .2s; }
.option-card.is-active .option-card__check svg { opacity: 1; }

/* option-card travel type */
.option-card--travel { flex-direction: column; text-align: center; gap: .5rem; padding: 1.25rem; }
.option-card--travel .option-card__icon { font-size: 1.6rem; }

/* travellers */
.travellers-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-bottom: 2rem; }
.traveller-field { display: flex; flex-direction: column; gap: 1rem; }
.traveller-label { display: flex; align-items: center; gap: .75rem; cursor: pointer; }
.traveller-label__icon svg { width: 24px; height: 24px; color: var(--p-gold); }
.traveller-label__title { display: block; font-size: .9rem; color: var(--p-ivory); font-weight: 500; }
.traveller-label__sub { display: block; font-size: .74rem; color: var(--p-faint); }
.required-mark { color: var(--p-gold); }

.traveller-counter { display: flex; align-items: center; gap: .75rem; }
.counter-btn {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1.5px solid var(--p-bord); background: transparent;
  color: var(--p-gold); font-size: 1.2rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .3s; line-height: 1;
}
.counter-btn:hover { border-color: var(--p-gold); background: rgba(200,164,110,.1); }
.counter-display {
  flex: 1; text-align: center; padding: .65rem; background: rgba(255,255,255,.04);
  border: 1px solid var(--p-bord); border-radius: 9px; color: var(--p-ivory);
  font-family: var(--p-sans); font-size: .92rem;
}

/* date grid */
.date-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.date-field { display: flex; flex-direction: column; gap: .5rem; }
.date-label { display: flex; align-items: center; gap: .6rem; font-size: .72rem; color: var(--p-gold); text-transform: uppercase; letter-spacing: .1em; }
.date-label svg { width: 16px; height: 16px; }
.luxury-date-input {
  width: 100%; padding: .8rem 1rem; background: rgba(255,255,255,.04);
  border: 1px solid var(--p-bord); border-radius: 9px; color: var(--p-ivory);
  font-family: var(--p-sans); font-size: .9rem; transition: border-color .3s;
  color-scheme: dark;
}
.luxury-date-input:focus { outline: none; border-color: rgba(200,164,110,.5); box-shadow: 0 0 0 3px rgba(200,164,110,.07); }

/* text input */
.luxury-input-wrap { position: relative; margin-bottom: 1.25rem; }
.luxury-input-icon {
  position: absolute; left: 1rem; top: 50%; transform: translateY(-50%);
  width: 18px; height: 18px; color: var(--p-gold); pointer-events: none;
}
.luxury-text-input {
  width: 100%; padding: .88rem 1rem .88rem 3rem;
  background: rgba(255,255,255,.04); border: 1px solid var(--p-bord);
  border-radius: 10px; color: var(--p-ivory); font-family: var(--p-sans);
  font-size: .95rem; transition: border-color .3s, box-shadow .3s;
}
.luxury-text-input:focus { outline: none; border-color: rgba(200,164,110,.5); box-shadow: 0 0 0 3px rgba(200,164,110,.07); }
.luxury-text-input::placeholder { color: rgba(240,234,216,.3); }

/* textarea wrap */
.luxury-textarea-wrap { margin-bottom: 1.25rem; }
.textarea-label { display: flex; align-items: center; gap: .55rem; font-size: .72rem; color: var(--p-gold); text-transform: uppercase; letter-spacing: .1em; margin-bottom: .6rem; }
.textarea-icon { width: 16px; height: 16px; }
.luxury-textarea {
  width: 100%; min-height: 120px; padding: 1rem; resize: none;
  background: rgba(255,255,255,.04); border: 1px solid var(--p-bord);
  border-radius: 10px; color: var(--p-ivory); font-family: var(--p-sans);
  font-size: .9rem; line-height: 1.7; transition: border-color .3s;
}
.luxury-textarea:focus { outline: none; border-color: rgba(200,164,110,.5); }
.luxury-textarea::placeholder { color: rgba(240,234,216,.3); }

/* contact fields in wizard */
.contact-fields { display: flex; flex-direction: column; gap: 0; margin-bottom: 1.5rem; }

/* months (rendered dynamically) */
.months { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1rem; }
.months button {
  padding: .48rem 1.1rem; border: 1px solid var(--p-bord); border-radius: 20px;
  background: transparent; color: var(--p-muted); font-family: var(--p-sans);
  font-size: .8rem; cursor: pointer; transition: all .3s;
}
.months button:hover { border-color: var(--p-bord2); color: var(--p-ivory); }
.months button.active { border-color: var(--p-gold); color: var(--p-gold); background: rgba(200,164,110,.09); }
.months.hidden { display: none; }
.calendar.hidden { display: none; }

/* submit trust */
.submit-trust { display: flex; gap: 2rem; flex-wrap: wrap; margin-bottom: 1.5rem; padding: 1.25rem; background: rgba(200,164,110,.05); border: 1px solid rgba(200,164,110,.12); border-radius: 12px; }
.submit-trust__item { display: flex; align-items: center; gap: .6rem; font-size: .8rem; color: var(--p-muted); }
.submit-trust__item svg { width: 18px; height: 18px; color: var(--p-gold); flex-shrink: 0; }

/* wizard actions */
.wizard-actions { display: flex; justify-content: space-between; align-items: center; padding-top: 1.75rem; border-top: 1px solid var(--p-bord); margin-top: 1.5rem; gap: 1rem; }

/* btn styles inside wizard */
.btn--primary, .btn.btn--primary {
  display: inline-flex; align-items: center; gap: .6rem;
  background: var(--p-gold); color: var(--p-bg);
  padding: .82rem 2rem; border-radius: 9px;
  font-family: var(--p-sans); font-size: .84rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  border: none; cursor: pointer; transition: all .35s var(--p-ease);
  text-decoration: none;
}
.btn--primary:hover, .btn.btn--primary:hover { background: var(--p-gold2); transform: translateY(-2px); box-shadow: 0 10px 30px rgba(200,164,110,.28); }
.btn--primary[disabled], .btn--primary.next[disabled] { opacity: .38; cursor: not-allowed; transform: none; box-shadow: none; }
.btn--primary svg { width: 16px; height: 16px; }

.btn--ghost, .btn.btn--ghost {
  display: inline-flex; align-items: center; gap: .5rem;
  border: 1px solid var(--p-bord); color: var(--p-muted);
  padding: .78rem 1.5rem; border-radius: 9px;
  font-family: var(--p-sans); font-size: .82rem; font-weight: 500;
  background: transparent; cursor: pointer; transition: all .3s;
  text-decoration: none;
}
.btn--ghost:hover, .btn.btn--ghost:hover { border-color: var(--p-gold); color: var(--p-gold); }
.btn--ghost svg { width: 14px; height: 14px; }

.btn--submit {
  display: inline-flex; align-items: center; gap: .6rem;
  background: linear-gradient(135deg,var(--p-gold) 0%,var(--p-gold2) 100%);
  color: var(--p-bg); padding: .9rem 2.25rem; border-radius: 9px;
  font-family: var(--p-sans); font-size: .88rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; border: none; cursor: pointer;
  transition: all .35s var(--p-ease);
}
.btn--submit:hover { transform: translateY(-3px); box-shadow: 0 14px 40px rgba(200,164,110,.35); }
.btn--submit svg { width: 16px; height: 16px; }

/* success state */
.wizard-success {
  text-align: center; padding: 3rem 2rem;
}
.wizard-success__icon {
  width: 64px; height: 64px; margin: 0 auto 1.75rem; color: var(--p-gold);
  animation: wsCheck .6s var(--p-ease) both;
}
@keyframes wsCheck { from{transform:scale(.5);opacity:0} to{transform:scale(1);opacity:1} }
.wizard-success__title { font-family: var(--p-serif); font-size: 2rem; font-weight: 300; color: var(--p-ivory); margin-bottom: 1rem; }
.wizard-success__body { font-size: .9rem; color: var(--p-muted); line-height: 1.8; max-width: 500px; margin: 0 auto 2rem; }

/* scroll cue on enquire hero */
.hero-scroll-cue {
  position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: .5rem; z-index: 4;
}
.scroll-cue__label { font-size: .6rem; color: var(--p-faint); letter-spacing: .18em; text-transform: uppercase; }
.scroll-cue__track { width: 1px; height: 50px; background: rgba(200,164,110,.2); position: relative; overflow: hidden; }
.scroll-cue__dot {
  position: absolute; top: -8px; left: -2px; width: 5px; height: 5px;
  border-radius: 50%; background: var(--p-gold);
  animation: scDot 1.6s ease-in-out infinite;
}
@keyframes scDot { 0%{top:-8px;opacity:1} 100%{top:52px;opacity:0} }

/* trust strip in hero */
.hero-trust-strip { display: flex; justify-content: center; flex-wrap: wrap; gap: 1.25rem; margin-top: 1.75rem; }
.trust-item { display: flex; align-items: center; gap: .5rem; font-size: .8rem; color: rgba(240,234,216,.65); }
.trust-icon { width: 17px; height: 17px; color: var(--p-gold); }
.trust-divider { width: 1px; height: 18px; background: rgba(200,164,110,.25); }


/* ═══════════════════════════════════════════════════════════════
   ARCHIVE ITINERARY (expedition cards, worlds nav, intel, CTA)
   ═══════════════════════════════════════════════════════════════ */

/* hero cinematic */
.hero-cinematic {
  position: relative; height: 100vh; min-height: 640px;
  overflow: hidden; display: flex; align-items: center;
}

.hero-panorama-rail { position: absolute; inset: 0; overflow: hidden; }
.hero-panorama-track {
  display: flex; height: 100%;
  animation: panoramaScroll 40s linear infinite;
  will-change: transform;
}
@keyframes panoramaScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.hero-panorama-slide {
  flex: 0 0 34vw; min-width: 520px; height: 100%;
  background-size: cover; background-position: center;
  filter: brightness(.45) saturate(1.1);
}

.hero-vignette-left  { position: absolute; left: 0; inset-block: 0; width: 30%; background: linear-gradient(90deg,rgba(8,8,6,.95) 0%,transparent 100%); z-index: 2; }
.hero-vignette-right { position: absolute; right: 0; inset-block: 0; width: 25%; background: linear-gradient(270deg,rgba(8,8,6,.8) 0%,transparent 100%); z-index: 2; }
.hero-vignette-bottom{ position: absolute; bottom: 0; inset-inline: 0; height: 35%; background: linear-gradient(180deg,transparent 0%,rgba(8,8,6,.88) 100%); z-index: 2; }
.hero-grain-overlay  { position: absolute; inset: 0; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='.03'/%3E%3C/svg%3E"); background-size: 128px; z-index: 2; pointer-events: none; }

/* intel ticker */
.hero-intel-ticker {
  position: absolute; top: 1.25rem; left: 0; right: 0; z-index: 5;
  display: flex; align-items: center; gap: 1rem;
  background: rgba(8,8,6,.75); backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--p-bord); padding: .55rem 2rem; overflow: hidden;
}
.ticker-label { font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; color: var(--p-gold); flex-shrink: 0; }
.ticker-scroll { display: flex; gap: 4rem; animation: tickerMove 40s linear infinite; white-space: nowrap; }
.ticker-scroll span { font-size: .78rem; color: var(--p-muted); }
@keyframes tickerMove { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* hero content */
.hero-content { position: relative; z-index: 4; padding: 6rem clamp(2rem,8vw,6rem); max-width: 900px; }
.hero-region-label { display: flex; align-items: center; gap: .65rem; font-size: .64rem; letter-spacing: .2em; text-transform: uppercase; color: var(--p-gold); margin-bottom: 1.75rem; }
.region-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--p-gold); animation: pulse 1.8s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.35;transform:scale(.6)} }

.hero-headline {
  font-family: var(--p-serif); font-size: clamp(3rem,8vw,6rem);
  line-height: .92; margin-bottom: 1.5rem; letter-spacing: -.03em;
}
.headline-light { display: inline; font-weight: 300; color: rgba(240,234,216,.72); }
.headline-italic { display: inline; font-style: italic; color: var(--p-gold); }
.headline-bold { display: inline; font-weight: 400; color: var(--p-ivory); }

.hero-descriptor { font-size: clamp(.88rem,1.5vw,1.05rem); color: var(--p-muted); line-height: 1.85; margin-bottom: 2.5rem; max-width: 600px; }

.hero-stats-row { display: flex; align-items: center; gap: 2.5rem; margin-bottom: 2.5rem; flex-wrap: wrap; }
.hero-stat { text-align: center; }
.stat-number { display: block; font-family: var(--p-serif); font-size: 2.5rem; color: var(--p-gold); font-weight: 300; line-height: 1; }
.stat-label { display: block; font-size: .65rem; color: var(--p-faint); text-transform: uppercase; letter-spacing: .12em; margin-top: .3rem; }
.hero-stat-divider { width: 1px; height: 40px; background: rgba(200,164,110,.2); }

.hero-cta-row { display: flex; gap: 1rem; flex-wrap: wrap; }
.cta-primary {
  display: inline-flex; align-items: center; gap: .55rem;
  background: var(--p-gold); color: var(--p-bg); padding: .9rem 2rem;
  border-radius: 9px; font-family: var(--p-sans); font-size: .84rem;
  font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  text-decoration: none; transition: all .35s var(--p-ease);
}
.cta-primary:hover { background: var(--p-gold2); transform: translateY(-3px); box-shadow: 0 12px 34px rgba(200,164,110,.3); }
.cta-ghost {
  display: inline-flex; align-items: center; gap: .55rem;
  border: 1px solid rgba(200,164,110,.4); color: var(--p-gold);
  padding: .9rem 2rem; border-radius: 9px;
  font-family: var(--p-sans); font-size: .84rem; font-weight: 500;
  letter-spacing: .09em; text-transform: uppercase; text-decoration: none;
  transition: all .35s;
}
.cta-ghost:hover { background: rgba(200,164,110,.09); border-color: var(--p-gold); }

/* scroll indicator */
.hero-scroll-indicator { position: absolute; bottom: 2.5rem; right: 3rem; z-index: 4; display: flex; flex-direction: column; align-items: center; gap: .5rem; }
.scroll-line { width: 1px; height: 50px; background: linear-gradient(180deg,var(--p-gold) 0%,transparent 100%); }
.hero-scroll-indicator span { font-size: .6rem; color: var(--p-faint); letter-spacing: .15em; text-transform: uppercase; writing-mode: vertical-rl; }

/* ── worlds nav ── */
.worlds-nav { padding: clamp(4rem,8vw,7rem) clamp(1.5rem,5vw,4rem); background: rgba(6,6,5,.92); border-top: 1px solid var(--p-bord); }
.worlds-container { max-width: 1320px; margin: 0 auto; }
.worlds-header { text-align: center; margin-bottom: 3rem; }
.section-eyebrow { font-size: .62rem; letter-spacing: .24em; text-transform: uppercase; color: var(--p-gold); display: block; margin-bottom: .75rem; }
.worlds-title { font-family: var(--p-serif); font-size: clamp(1.8rem,3.5vw,2.8rem); font-weight: 300; color: var(--p-ivory); line-height: 1.1; }

.worlds-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap: 1.25rem; }
.world-card {
  background: var(--p-glass); border: 1.5px solid var(--p-bord);
  border-radius: 16px; padding: 2rem 1.5rem; text-align: center;
  cursor: pointer; transition: all .4s var(--p-ease); backdrop-filter: blur(16px);
}
.world-card:hover { transform: translateY(-7px); border-color: var(--p-bord2); box-shadow: 0 20px 55px rgba(0,0,0,.4); }
.world-card.world-signature { border-color: rgba(200,164,110,.25); }
.world-icon { font-size: 1.5rem; color: var(--p-gold); margin-bottom: .85rem; font-family: var(--p-serif); font-weight: 300; }
.world-card h3 { font-family: var(--p-serif); font-size: 1.1rem; color: var(--p-ivory); font-weight: 400; margin-bottom: .6rem; }
.world-card p { font-size: .82rem; color: var(--p-muted); line-height: 1.65; margin-bottom: 1rem; }
.world-count { font-size: .68rem; color: var(--p-gold); letter-spacing: .1em; text-transform: uppercase; }

/* ── safari intelligence ── */
.safari-intel { padding: clamp(4rem,7vw,6rem) clamp(1.5rem,5vw,4rem); background: rgba(8,8,6,.9); border-top: 1px solid var(--p-bord); }
.intel-container { max-width: 1320px; margin: 0 auto; }
.intel-header { text-align: center; margin-bottom: 3rem; }
.intel-header h2 { font-family: var(--p-serif); font-size: clamp(1.8rem,3.5vw,2.8rem); font-weight: 300; color: var(--p-ivory); }
.intel-header h2 em { font-style: italic; color: var(--p-gold); }
.intel-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(300px,1fr)); gap: 1.5rem; }

.intel-card {
  background: var(--p-glass); border: 1px solid var(--p-bord);
  border-radius: 18px; padding: 2rem; backdrop-filter: blur(18px);
  transition: all .4s var(--p-ease);
}
.intel-card:hover { transform: translateY(-5px); border-color: var(--p-bord2); }
.intel-region-badge {
  display: inline-block; padding: .28rem .75rem; background: rgba(200,164,110,.1);
  border: 1px solid rgba(200,164,110,.2); border-radius: 20px;
  font-size: .62rem; color: var(--p-gold); letter-spacing: .12em; text-transform: uppercase; margin-bottom: 1rem;
}
.intel-card h3 { font-family: var(--p-serif); font-size: 1.2rem; color: var(--p-ivory); font-weight: 400; margin-bottom: 1.25rem; }
.intel-metrics { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 1.25rem; }
.intel-metric {}
.metric-label { display: flex; justify-content: space-between; font-size: .72rem; color: var(--p-muted); margin-bottom: .4rem; }
.metric-value { color: var(--p-ivory); font-weight: 500; }
.metric-bar { height: 4px; background: rgba(255,255,255,.08); border-radius: 2px; overflow: hidden; }
.metric-fill { height: 100%; background: linear-gradient(90deg,var(--p-gold),var(--p-gold2)); border-radius: 2px; transition: width 1.5s var(--p-ease); }
.intel-alert { font-size: .82rem; color: var(--p-muted); padding: .8rem 1rem; background: rgba(200,164,110,.06); border: 1px solid rgba(200,164,110,.12); border-radius: 10px; line-height: 1.6; }

/* ── expedition archive ── */
.expeditions-archive { padding: clamp(4rem,7vw,6rem) clamp(1.5rem,5vw,4rem); background: rgba(5,5,4,.93); border-top: 1px solid var(--p-bord); }
.archive-container { max-width: 1320px; margin: 0 auto; }
.archive-header { text-align: center; margin-bottom: 3rem; }
.archive-title { font-family: var(--p-serif); font-size: clamp(2rem,5vw,3.8rem); font-weight: 300; color: var(--p-ivory); line-height: 1.05; }
.archive-title em { font-style: italic; color: var(--p-gold); }
.archive-subtitle { font-size: .92rem; color: var(--p-muted); max-width: 600px; margin: 1rem auto 0; line-height: 1.8; }

/* filter bar */
.filter-bar { display: flex; gap: .6rem; flex-wrap: wrap; justify-content: center; margin-bottom: 3rem; }
.filter-btn {
  padding: .5rem 1.2rem; border: 1px solid var(--p-bord); border-radius: 24px;
  background: transparent; color: var(--p-muted); font-family: var(--p-sans);
  font-size: .78rem; font-weight: 500; cursor: pointer; transition: all .3s;
}
.filter-btn:hover { border-color: var(--p-bord2); color: var(--p-ivory); }
.filter-btn.active { background: rgba(200,164,110,.1); border-color: var(--p-gold); color: var(--p-gold); }

/* region divider */
.region-divider { display: flex; align-items: center; gap: 1.5rem; margin: 3rem 0 2rem; }
.region-divider::before, .region-divider::after { content: ''; flex: 1; height: 1px; background: var(--p-bord); }
.region-divider-label { font-family: var(--p-serif); font-size: 1.1rem; color: var(--p-gold); font-weight: 300; letter-spacing: .06em; white-space: nowrap; }

/* expedition grid */
.expeditions-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(360px,1fr)); gap: 2rem; margin-bottom: 2rem; }

/* expedition card */
.expedition-card {
  background: var(--p-glass); border: 1px solid var(--p-bord);
  border-radius: 20px; overflow: hidden; backdrop-filter: blur(18px);
  transition: all .5s var(--p-ease); display: flex; flex-direction: column;
  opacity: 0; transform: translateY(20px);
  transition: opacity .4s var(--p-ease), transform .4s var(--p-ease), border-color .4s, box-shadow .4s;
}
.expedition-card.card-visible { opacity: 1; transform: translateY(0); }
.expedition-card:hover { border-color: var(--p-bord2); box-shadow: 0 24px 70px rgba(0,0,0,.52); transform: translateY(-10px); }
.expedition-card.card-featured { border-color: rgba(200,164,110,.32); }
.expedition-card.card-featured:hover { border-color: var(--p-gold); }

.card-image-wrap { position: relative; height: 260px; overflow: hidden; flex-shrink: 0; }
.card-image { height: 100%; background-size: cover; background-position: center; transition: transform .8s var(--p-ease); filter: brightness(.75) saturate(1.05); }
.expedition-card:hover .card-image { transform: scale(1.06); filter: brightness(.85); }
.card-image-overlay { position: absolute; inset: 0; background: linear-gradient(180deg,transparent 40%,rgba(8,8,6,.9) 100%); }
.card-badges { position: absolute; top: 1.1rem; left: 1.1rem; display: flex; gap: .5rem; z-index: 2; }
.badge { padding: .3rem .75rem; border-radius: 6px; font-size: .62rem; font-weight: 700; letter-spacing: .07em; }
.badge-world { background: rgba(8,8,6,.82); backdrop-filter: blur(8px); border: 1px solid var(--p-bord); color: var(--p-muted); }
.badge-region { background: rgba(200,164,110,.88); color: var(--p-bg); }
.badge-signature { background: var(--p-gold); color: var(--p-bg); }
.card-duration { position: absolute; top: 1.1rem; right: 1.1rem; z-index: 2; background: rgba(8,8,6,.82); backdrop-filter: blur(8px); border: 1px solid var(--p-bord); color: var(--p-ivory); padding: .32rem .8rem; border-radius: 6px; font-size: .72rem; font-weight: 600; }

.card-body { padding: 2rem; display: flex; flex-direction: column; flex-grow: 1; }
.card-sequence-label { font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; color: var(--p-gold); opacity: .6; margin-bottom: .65rem; }
.card-title { font-family: var(--p-serif); font-size: 1.35rem; color: var(--p-ivory); font-weight: 400; line-height: 1.15; margin-bottom: .9rem; }
.card-narrative { font-size: .86rem; color: var(--p-muted); line-height: 1.82; margin-bottom: 1.25rem; flex-grow: 1; }

/* story beats */
.card-story-beats { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1.5rem; padding: 1.1rem 1.25rem; background: rgba(200,164,110,.05); border: 1px solid rgba(200,164,110,.1); border-radius: 12px; }
.beat { display: flex; gap: .65rem; align-items: flex-start; font-size: .8rem; color: var(--p-muted); line-height: 1.6; }
.beat-icon { color: var(--p-gold); flex-shrink: 0; font-size: .7rem; margin-top: .2rem; }

/* card footer */
.card-footer { display: flex; align-items: center; justify-content: space-between; padding-top: 1.25rem; border-top: 1px solid var(--p-bord); margin-top: auto; gap: 1rem; }
.card-pricing { display: flex; align-items: baseline; gap: .35rem; }
.price-from { font-size: .68rem; color: var(--p-faint); text-transform: uppercase; letter-spacing: .1em; }
.price-amount { font-family: var(--p-serif); font-size: 1.4rem; color: var(--p-gold); font-weight: 300; }
.price-unit { font-size: .68rem; color: var(--p-faint); }
.card-cta {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .6rem 1.25rem; background: var(--p-gold); color: var(--p-bg);
  border-radius: 8px; font-family: var(--p-sans); font-size: .76rem;
  font-weight: 700; letter-spacing: .09em; text-transform: uppercase;
  text-decoration: none; flex-shrink: 0; transition: all .35s var(--p-ease);
}
.card-cta:hover { background: var(--p-gold2); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(200,164,110,.28); }

/* ── consultation CTA ── */
.consultation-cta { padding: clamp(5rem,10vw,8rem) clamp(1.5rem,5vw,4rem); position: relative; overflow: hidden; background: rgba(5,5,4,.97); border-top: 1px solid var(--p-bord); }
.cta-inner { max-width: 900px; margin: 0 auto; position: relative; z-index: 2; }
.cta-grain { position: absolute; inset: 0; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E"); background-size: 128px; opacity: .015; pointer-events: none; }
.cta-content { text-align: center; }
.cta-content h2 { font-family: var(--p-serif); font-size: clamp(2.2rem,5vw,3.8rem); font-weight: 300; color: var(--p-ivory); line-height: 1.05; margin: .85rem 0 1.25rem; }
.cta-content p { font-size: .95rem; color: var(--p-muted); line-height: 1.85; max-width: 620px; margin: 0 auto 2.5rem; }
.cta-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }


/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 1080px) {
  .place-card.tz-place-card { grid-template-columns: 1fr; }
  .place-gallery { grid-template-rows: 1fr; grid-template-columns: repeat(3,1fr); height: 200px; }
  .tz-migration { grid-template-columns: 1fr; }
  .tz-migration__img { min-height: 300px; }
  .pa-intro__inner { grid-template-columns: 1fr; }
  .pa-intro__stats { flex-direction: row; justify-content: center; flex-wrap: wrap; }
  .expeditions-grid { grid-template-columns: repeat(auto-fill,minmax(300px,1fr)); }
}

@media (max-width: 768px) {
  .two-col { grid-template-columns: 1fr; gap: 2rem; }
  .tz-seasons__grid { grid-template-columns: 1fr 1fr; }
  .tz-exp-grid { grid-template-columns: 1fr 1fr; }
  .tz-routes__grid { grid-template-columns: 1fr; }
  .pa-cards { grid-template-columns: 1fr 1fr; }
  .pa-itinerary__grid { grid-template-columns: 1fr; }
  .ps-grid { grid-template-columns: 1fr 1fr; }
  .options--destination, .options--theme { grid-template-columns: 1fr; }
  .options--duration { grid-template-columns: 1fr 1fr; }
  .options--travel-mode { grid-template-columns: 1fr; }
  .travellers-grid { grid-template-columns: 1fr; }
  .tz-lodges-grid { grid-template-columns: 1fr; }
  .worlds-grid { grid-template-columns: 1fr 1fr; }
  .intel-grid { grid-template-columns: 1fr; }
  .expeditions-grid { grid-template-columns: 1fr; }
  .hero-stats-row { gap: 1.5rem; }
  .submit-trust { flex-direction: column; gap: .9rem; }
  .places-grid.ke-places-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .tz-hero__title { font-size: clamp(3rem,14vw,4.5rem); }
  .tz-seasons__grid { grid-template-columns: 1fr; }
  .tz-exp-grid { grid-template-columns: 1fr; }
  .pa-cards { grid-template-columns: 1fr; }
  .ps-grid { grid-template-columns: 1fr; }
  .worlds-grid { grid-template-columns: 1fr; }
  .tz-filters, .ps-filters, .filter-bar { gap: .4rem; }
  .date-grid { grid-template-columns: 1fr; }
  .options--duration { grid-template-columns: 1fr; }
  .hero-cta-row, .cta-actions { flex-direction: column; align-items: stretch; }
  .card-image-wrap { height: 200px; }
  .ps-trust__inner { grid-template-columns: 1fr 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
}
