/* =============================================================
   WILDTRAX 4×4 — Landing page styles
   Theme: rugged outdoor / campfire. Mobile-first, responsive.
   ============================================================= */

:root{
  --bg:        #0e1311;
  --bg-2:      #131a16;
  --surface:   #182019;
  --surface-2: #1f2a22;
  --line:      rgba(255,255,255,.10);
  --text:      #f3f1ea;
  --muted:     #a9b3a8;
  --muted-2:   #7f8a80;
  --fire:      #ee7b30;   /* primary CTA — campfire orange */
  --fire-2:    #f59b4e;
  --moss:      #8ba36b;   /* secondary — moss/olive */
  --sky:       #6fb0c9;
  --easy:      #6fae6a;
  --mod:       #e0a64e;
  --hard:      #df6a4a;
  --radius:    16px;
  --radius-sm: 10px;
  --maxw:      1180px;
  --shadow:    0 18px 40px -18px rgba(0,0,0,.65);
  --ff-head:   "Oswald", "Arial Narrow", system-ui, sans-serif;
  --ff-body:   "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; scroll-padding-top:78px; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--ff-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:0; background:none; color:inherit; }
ul{ list-style:none; }
h1,h2,h3,h4{ font-family:var(--ff-head); font-weight:600; line-height:1.05; letter-spacing:.5px; }
:focus-visible{ outline:2px solid var(--fire-2); outline-offset:3px; border-radius:4px; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:22px; }
.container--narrow{ max-width:820px; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--ff-head); font-weight:600; letter-spacing:.6px;
  text-transform:uppercase; font-size:.92rem;
  padding:.85em 1.5em; border-radius:999px;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  white-space:nowrap;
}
.btn--sm{ padding:.6em 1.1em; font-size:.78rem; }
.btn--lg{ padding:1em 1.9em; font-size:1.02rem; }
.btn--block{ width:100%; }
.btn--primary{ background:linear-gradient(135deg,var(--fire),var(--fire-2)); color:#1a0f05; box-shadow:0 10px 24px -10px rgba(238,123,48,.8); }
.btn--primary:hover{ transform:translateY(-2px); box-shadow:0 16px 30px -10px rgba(238,123,48,.9); }
.btn--ghost{ background:rgba(255,255,255,.06); color:var(--text); border:1.5px solid rgba(255,255,255,.35); backdrop-filter:blur(4px); }
.btn--ghost:hover{ background:rgba(255,255,255,.14); transform:translateY(-2px); }

/* ---------- nav ---------- */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:60;
  transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
  padding:6px 0;
}
.nav.is-scrolled{ background:rgba(12,16,14,.88); backdrop-filter:blur(12px); box-shadow:0 1px 0 var(--line); }
.nav__inner{ display:flex; align-items:center; justify-content:space-between; gap:18px; min-height:64px; }
.brand{ display:flex; align-items:baseline; gap:8px; font-family:var(--ff-head); }
.brand__mark{ color:var(--fire); font-size:1.1rem; transform:translateY(-1px); }
.brand__name{ font-size:1.4rem; font-weight:600; letter-spacing:2px; }
.brand__name strong{ color:var(--fire); font-weight:700; }
.brand__sub{ font-size:.7rem; color:var(--muted); letter-spacing:2px; text-transform:uppercase; }

.nav__links{ display:flex; align-items:center; gap:26px; }
.nav__links > a{ font-weight:500; font-size:.95rem; color:var(--text); opacity:.9; transition:opacity .2s, color .2s; }
.nav__links > a:hover{ opacity:1; color:var(--fire-2); }
.nav__cta{ color:#1a0f05 !important; }

.nav__right{ display:flex; align-items:center; gap:14px; }
.lang{ display:flex; align-items:center; gap:6px; font-family:var(--ff-head); font-size:.9rem; }
.lang__btn{ color:var(--muted); letter-spacing:1px; padding:2px 2px; transition:color .2s; }
.lang__btn.is-active{ color:var(--fire); font-weight:700; }
.lang__sep{ color:var(--muted-2); }

.nav__toggle{ display:none; flex-direction:column; gap:5px; width:30px; padding:6px 2px; }
.nav__toggle span{ height:2px; background:var(--text); border-radius:2px; transition:transform .25s, opacity .25s; }
.nav.is-open .nav__toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav.is-open .nav__toggle span:nth-child(2){ opacity:0; }
.nav.is-open .nav__toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- hero ---------- */
/* hero height leaves room for the orange marquee bar to peek into the first screen */
.hero{ position:relative; min-height:calc(100svh - 46px); display:flex; align-items:center; overflow:hidden; }
.hero__video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.hero__overlay{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(10,13,11,.62) 0%, rgba(10,13,11,.42) 42%, rgba(10,13,11,.82) 100%),
    radial-gradient(120% 90% at 20% 90%, rgba(238,123,48,.16), transparent 60%);
}
.hero__content{ position:relative; z-index:2; padding-top:96px; padding-bottom:90px; max-width:880px; }
.hero__eyebrow{ text-transform:uppercase; letter-spacing:3px; font-size:.82rem; color:var(--fire-2); font-weight:600; margin-bottom:14px; }
.hero__title{ font-size:clamp(2.7rem,7.5vw,5.6rem); text-transform:uppercase; letter-spacing:1px; text-shadow:0 4px 30px rgba(0,0,0,.5); }
.hero__title span{ color:var(--fire); display:block; }
.hero__lead{ font-size:clamp(1.05rem,2.2vw,1.32rem); color:#e9e6dd; max-width:640px; margin:20px 0 30px; text-shadow:0 2px 16px rgba(0,0,0,.6); }
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; }
.hero__trust{ display:flex; flex-wrap:wrap; gap:14px 26px; margin-top:38px; }
.hero__trust li{ display:flex; align-items:center; gap:9px; font-size:.92rem; color:#e4e1d8; }
.hero__trust li span:first-child{ font-size:1.15rem; }
.hero__scroll{ position:absolute; left:50%; bottom:22px; transform:translateX(-50%); z-index:2; width:26px; height:42px; border:2px solid rgba(255,255,255,.5); border-radius:14px; }
.hero__scroll span{ position:absolute; left:50%; top:8px; width:4px; height:8px; background:#fff; border-radius:2px; transform:translateX(-50%); animation:scrolldot 1.6s infinite; }
@keyframes scrolldot{ 0%{opacity:0;transform:translate(-50%,0)} 40%{opacity:1} 80%{opacity:0;transform:translate(-50%,14px)} 100%{opacity:0} }

/* ---------- marquee ---------- */
.marquee{ background:var(--fire); color:#1a0f05; overflow:hidden; padding:11px 0; }
.marquee__track{ display:inline-flex; align-items:center; gap:26px; white-space:nowrap; font-family:var(--ff-head); font-weight:600; letter-spacing:2px; text-transform:uppercase; font-size:.9rem; animation:marquee 30s linear infinite; }
.marquee__track i{ font-style:normal; opacity:.6; }
@keyframes marquee{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ---------- sections ---------- */
.section{ padding:84px 0; position:relative; }
.section--dark{ background:linear-gradient(180deg,var(--bg-2),var(--bg)); }
.section--flush{ padding-bottom:0; }
.section__head{ max-width:720px; margin:0 auto 48px; text-align:center; }
.section__eyebrow{ text-transform:uppercase; letter-spacing:3px; font-size:.8rem; color:var(--fire); font-weight:600; margin-bottom:12px; }
.section__title{ font-size:clamp(2rem,4.5vw,3.1rem); text-transform:uppercase; }
.section__intro{ color:var(--muted); margin-top:16px; font-size:1.06rem; }
.section__note{ text-align:center; color:var(--muted); margin-top:38px; font-size:.98rem; }

/* ---------- adventure cards ---------- */
.cards{ display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:26px; }
.card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; box-shadow:var(--shadow); transition:transform .25s ease, border-color .25s ease; }
.card:hover{ transform:translateY(-6px); border-color:rgba(238,123,48,.5); }
.card--feature{ grid-column:span 1; outline:1.5px solid rgba(238,123,48,.35); }
.card__media{ position:relative; aspect-ratio:16/10; overflow:hidden; }
.card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.card:hover .card__media img{ transform:scale(1.07); }
.card__ribbon{ position:absolute; top:12px; left:12px; background:var(--sky); color:#08222b; font-family:var(--ff-head); font-size:.72rem; letter-spacing:1px; text-transform:uppercase; padding:5px 10px; border-radius:6px; font-weight:600; }
.card__body{ padding:20px 20px 22px; display:flex; flex-direction:column; flex:1; }
.card__tags{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:12px; }
.tag{ font-family:var(--ff-head); font-size:.72rem; letter-spacing:.8px; text-transform:uppercase; padding:4px 10px; border-radius:999px; background:var(--surface-2); color:var(--muted); font-weight:600; }
.tag--time{ color:#e7e3d9; }
.tag--easy{ background:rgba(111,174,106,.16); color:var(--easy); }
.tag--mod{ background:rgba(224,166,78,.16); color:var(--mod); }
.tag--hard{ background:rgba(223,106,74,.18); color:var(--hard); }
.tag--star{ background:var(--fire); color:#1a0f05; }
.card__title{ font-size:1.42rem; text-transform:uppercase; margin-bottom:10px; }
.card__text{ color:var(--muted); font-size:.96rem; margin-bottom:14px; }
.card__incl{ display:flex; flex-direction:column; gap:7px; margin-bottom:18px; }
.card__incl li{ position:relative; padding-left:24px; font-size:.9rem; color:#d7d3c8; }
.card__incl li::before{ content:"✓"; position:absolute; left:0; top:0; color:var(--moss); font-weight:700; }
.card__foot{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:10px; padding-top:14px; border-top:1px solid var(--line); }
.price{ font-family:var(--ff-head); font-size:1.3rem; line-height:1.1; color:var(--text); }
.price small{ display:block; font-size:.62rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted-2); }
.price em{ display:block; font-style:normal; font-size:.7rem; color:var(--muted); letter-spacing:.5px; }

/* ---------- off-grid experiences ---------- */
.exp-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:24px; }
.exp{ text-align:center; }
.exp__img{ aspect-ratio:1/1; border-radius:var(--radius); overflow:hidden; margin-bottom:16px; box-shadow:var(--shadow); position:relative; }
.exp__img::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(8,11,9,.55)); }
.exp__img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s; }
.exp:hover .exp__img img{ transform:scale(1.08); }
.exp h3{ font-size:1.2rem; text-transform:uppercase; margin-bottom:8px; }
.exp p{ color:var(--muted); font-size:.94rem; }

/* ---------- how it works ---------- */
.steps{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:26px; counter-reset:s; }
.step{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:26px 22px; }
.step__num{ display:inline-flex; align-items:center; justify-content:center; width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--fire),var(--fire-2)); color:#1a0f05; font-family:var(--ff-head); font-size:1.3rem; font-weight:700; margin-bottom:14px; }
.step h3{ font-size:1.18rem; text-transform:uppercase; margin-bottom:8px; }
.step p{ color:var(--muted); font-size:.93rem; }
.why{ display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:18px; margin-top:34px; }
.why__item{ background:var(--surface-2); border-radius:var(--radius-sm); padding:18px 20px; }
.why__item strong{ display:block; font-family:var(--ff-head); letter-spacing:.5px; font-size:1.05rem; margin-bottom:4px; }
.why__item span{ color:var(--muted); font-size:.92rem; }

/* ---------- gallery ---------- */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:4px; margin-top:30px; }
.gallery figure{ overflow:hidden; aspect-ratio:1/1; }
.gallery img{ width:100%; height:100%; object-fit:cover; transition:transform .6s, filter .4s; filter:saturate(.92); }
.gallery figure:hover img{ transform:scale(1.1); filter:saturate(1.1); }

/* ---------- booking / lead form ---------- */
.section--book{ position:relative; padding:90px 0; overflow:hidden; }
.book__bg{ position:absolute; inset:0; background:url("../img/friends-camp-stars.jpg") center/cover; z-index:0; }
.book__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(105deg, rgba(10,13,11,.95) 0%, rgba(10,13,11,.86) 45%, rgba(10,13,11,.6) 100%); }
.book__inner{ position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; }
.book__copy .section__title{ text-align:left; }
.book__copy .section__eyebrow{ text-align:left; }
.book__copy .section__intro{ margin-left:0; }
.book__perks{ display:flex; flex-direction:column; gap:10px; margin:22px 0; }
.book__perks li{ font-size:1rem; color:#e7e3d9; }
.book__trust{ color:var(--muted); font-size:.9rem; }

.book__formwrap{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:30px 28px; box-shadow:var(--shadow); }
.form__title{ font-size:1.4rem; text-transform:uppercase; margin-bottom:20px; }
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.field > span{ font-size:.82rem; font-weight:600; letter-spacing:.4px; color:var(--muted); }
.field input,.field select,.field textarea{
  background:var(--bg); border:1.5px solid var(--line); border-radius:var(--radius-sm);
  color:var(--text); padding:.72em .85em; font:inherit; font-size:.95rem; transition:border-color .2s, box-shadow .2s; width:100%;
}
.field input::placeholder,.field textarea::placeholder{ color:var(--muted-2); }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--fire); box-shadow:0 0 0 3px rgba(238,123,48,.18); }
.field textarea{ resize:vertical; min-height:54px; }
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23a9b3a8' d='M6 8 0 0h12z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:34px; }
.check{ display:flex; gap:10px; align-items:flex-start; margin:4px 0 18px; font-size:.86rem; color:var(--muted); }
.check input{ margin-top:3px; width:17px; height:17px; accent-color:var(--fire); flex:none; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }
.form__fine{ text-align:center; color:var(--muted-2); font-size:.8rem; margin-top:12px; }
.form__status{ margin-top:14px; font-size:.95rem; text-align:center; border-radius:var(--radius-sm); }
.form__status.is-ok{ padding:14px; background:rgba(111,174,106,.14); color:#bfe0ba; border:1px solid rgba(111,174,106,.4); }
.form__status.is-err{ padding:14px; background:rgba(223,106,74,.14); color:#f0b6a6; border:1px solid rgba(223,106,74,.4); }
.form.is-success > *:not(.form__status):not(.form__title){ display:none; }

/* ---------- faq ---------- */
.faq{ display:flex; flex-direction:column; gap:12px; }
.faq__item{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm); padding:4px 20px; }
.faq__item summary{ list-style:none; cursor:pointer; padding:16px 0; font-family:var(--ff-head); font-size:1.08rem; letter-spacing:.3px; display:flex; justify-content:space-between; align-items:center; gap:14px; }
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{ content:"+"; color:var(--fire); font-size:1.5rem; line-height:1; transition:transform .25s; }
.faq__item[open] summary::after{ transform:rotate(45deg); }
.faq__item p{ color:var(--muted); padding:0 0 18px; font-size:.96rem; }

/* ---------- footer ---------- */
.footer{ background:#0a0d0b; border-top:1px solid var(--line); padding:56px 0 0; }
.footer__inner{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:34px; padding-bottom:40px; }
.footer__brand p{ color:var(--muted); margin-top:12px; font-size:.92rem; max-width:280px; }
.footer__col h4{ font-size:.85rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--fire); margin-bottom:14px; }
.footer__col a,.footer__col span{ display:block; color:var(--muted); font-size:.92rem; margin-bottom:9px; transition:color .2s; }
.footer__col a:hover{ color:var(--fire-2); }
.social{ display:flex; flex-direction:row; flex-wrap:wrap; gap:10px; margin-top:2px; }
.footer__col .social__link{ display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto; width:42px; height:42px; margin:0; padding:0; border:1px solid var(--line); border-radius:50%; color:var(--muted); transition:color .2s, border-color .2s, background .2s, transform .15s; }
.footer__col .social__link:hover{ color:#1a0f05; border-color:var(--fire); background:linear-gradient(135deg,var(--fire),var(--fire-2)); transform:translateY(-2px); }
.footer__col .social__link .ic{ width:20px; height:20px; }
.footer__bar{ border-top:1px solid var(--line); padding:18px 22px; display:flex; flex-wrap:wrap; justify-content:space-between; gap:8px; max-width:var(--maxw); margin-inline:auto; }
.footer__bar p{ color:var(--muted-2); font-size:.8rem; }

/* ---------- floating CTA ---------- */
.fab{ position:fixed; right:16px; bottom:16px; z-index:55; background:linear-gradient(135deg,var(--fire),var(--fire-2)); color:#1a0f05; font-family:var(--ff-head); font-weight:600; letter-spacing:.6px; text-transform:uppercase; padding:.85em 1.3em; border-radius:999px; box-shadow:0 12px 26px -10px rgba(238,123,48,.9); display:none; transition:transform .15s; }
.fab:hover{ transform:translateY(-2px); }

/* ---------- reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .6s ease, transform .6s ease; }
.reveal.is-in{ opacity:1; transform:none; }

/* ---------- responsive ---------- */
@media (max-width:900px){
  .nav__links{
    position:fixed; inset:0 0 0 auto; width:min(80vw,320px);
    background:rgba(12,16,14,.97); backdrop-filter:blur(12px);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:22px;
    padding:40px; transform:translateX(110%); transition:transform .3s ease; box-shadow:var(--shadow);
  }
  .nav.is-open .nav__links{ transform:translateX(0); }
  .nav__links > a{ font-size:1.2rem; }
  .nav__toggle{ display:flex; }
  .book__inner{ grid-template-columns:1fr; gap:32px; }
  .gallery{ grid-template-columns:repeat(2,1fr); }
  .fab{ display:inline-flex; }
}
@media (max-width:560px){
  .section{ padding:60px 0; }
  .form__row{ grid-template-columns:1fr; gap:0; }
  .hero__trust{ gap:10px 18px; }
  .footer__inner{ grid-template-columns:1fr 1fr; }
  .card__foot{ flex-direction:column; align-items:flex-start; }
  .card__foot .btn{ width:100%; }
  /* tidy the cramped mobile nav: drop the redundant sub-label, tighten brand */
  .nav__inner{ gap:12px; min-height:58px; }
  .brand__sub{ display:none; }
  .brand{ gap:6px; }
  .brand__name{ font-size:1.2rem; letter-spacing:1.5px; }
  .nav__right{ gap:12px; }
}

/* ============================================================
   v2 — GLAMPING REBUILD COMPONENTS
   ============================================================ */
/* rotating image hero — cross-fading slides with slow ken-burns */
.hero__bg{ position:absolute; inset:0; z-index:0; overflow:hidden; background:#0b0f0c; }
.hero__slide{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transform:scale(1.06); transition:opacity 1.6s ease-in-out, transform 7s ease-out; will-change:opacity,transform; }
.hero__slide.is-active{ opacity:1; z-index:1; transform:scale(1.14); }

/* story / problem→solution band */
.section--story{ text-align:center; padding:74px 0; background:linear-gradient(180deg,var(--bg),var(--bg-2)); }
.section--story .section__eyebrow,.section--story .section__title{ text-align:center; }
.story__lead{ font-size:clamp(1.08rem,2.3vw,1.42rem); color:#e4e1d8; margin-top:18px; line-height:1.6; }

/* done-for-you pillars */
.pillars{ display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:22px; }
.pillar{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:26px 24px; transition:transform .25s, border-color .25s; }
.pillar:hover{ transform:translateY(-5px); border-color:rgba(238,123,48,.45); }
.pillar__ic{ font-size:2.1rem; display:block; margin-bottom:12px; }
.pillar h3{ font-size:1.18rem; text-transform:uppercase; margin-bottom:8px; }
.pillar p{ color:var(--muted); font-size:.95rem; }

/* two big offer cards */
.offers{ display:grid; grid-template-columns:repeat(auto-fit,minmax(330px,1fr)); gap:28px; }
.offer{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; box-shadow:var(--shadow); transition:transform .25s, border-color .25s; }
.offer:hover{ transform:translateY(-6px); border-color:rgba(238,123,48,.5); }
.offer--feature{ outline:2px solid rgba(238,123,48,.5); }
.offer__media{ position:relative; aspect-ratio:16/10; overflow:hidden; }
.offer__media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s; }
.offer:hover .offer__media img{ transform:scale(1.06); }
.offer__badge{ position:absolute; top:14px; left:14px; background:var(--fire); color:#1a0f05; font-family:var(--ff-head); font-size:.74rem; letter-spacing:1px; text-transform:uppercase; padding:5px 12px; border-radius:6px; font-weight:700; }
.offer__body{ padding:24px; display:flex; flex-direction:column; flex:1; }
.offer__body .tag{ align-self:flex-start; margin-bottom:12px; }
.offer__title{ font-size:1.65rem; text-transform:uppercase; margin-bottom:10px; }
.offer__text{ color:var(--muted); margin-bottom:16px; }
.offer__foot{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:14px; padding-top:16px; border-top:1px solid var(--line); flex-wrap:wrap; }

/* routes with sketch maps */
.routes{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:24px; }
.route{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); transition:transform .25s, border-color .25s; }
.route:hover{ transform:translateY(-5px); border-color:rgba(238,123,48,.4); }
.route__map{ background:#f4ecdd; padding:10px; }
.route__map img{ width:100%; height:auto; display:block; border-radius:8px; }
.route__body{ padding:18px 20px 22px; }
.route__head{ display:flex; align-items:baseline; justify-content:space-between; gap:10px; margin-bottom:8px; flex-wrap:wrap; }
.route__head h3{ font-size:1.22rem; text-transform:uppercase; }
.route__tag{ font-family:var(--ff-head); font-size:.72rem; letter-spacing:.6px; text-transform:uppercase; color:var(--fire); background:rgba(238,123,48,.12); padding:3px 9px; border-radius:999px; white-space:nowrap; }
.route__body p{ color:var(--muted); font-size:.94rem; }
.route__cta{ display:inline-flex; align-items:center; margin-top:14px; font-family:var(--ff-head); font-size:.78rem; letter-spacing:1.2px; text-transform:uppercase; color:var(--fire); font-weight:600; }
.route__cta::after{ content:"→"; margin-left:7px; transition:transform .2s; }
.route:hover .route__cta::after{ transform:translateX(4px); }

/* merged section: single-product wide feature banner + route sub-head */
.offer--wide{ display:grid; grid-template-columns:1.05fr 1fr; align-items:stretch; max-width:980px; margin:0 auto; }
.offer--wide .offer__media{ aspect-ratio:auto; height:100%; min-height:380px; }
.offer--wide .offer__media img{ object-position:center 75%; }
.offer--wide .offer__body{ padding:30px 32px; }
.section__head--sub{ margin-top:64px; }
.anchor{ display:block; height:0; overflow:hidden; }
@media (max-width:760px){
  .offer--wide{ grid-template-columns:1fr; }
  .offer--wide .offer__media{ aspect-ratio:16/11; min-height:0; }
}

/* for whom */
.forwhom{ display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:20px; }
.who{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:24px 22px; text-align:center; transition:transform .25s, border-color .25s; }
.who:hover{ transform:translateY(-4px); border-color:rgba(238,123,48,.4); }
.who span{ font-size:2rem; display:block; margin-bottom:10px; }
.who h3{ font-size:1.1rem; text-transform:uppercase; margin-bottom:6px; }
.who p{ color:var(--muted); font-size:.92rem; }

/* ---------- inline icon system (Material Symbols, SVG sprite) ---------- */
.svg-sprite{ position:absolute; width:0; height:0; overflow:hidden; }
.ic{ width:1em; height:1em; fill:currentColor; flex:none; }
.hero__trust li .ic{ width:20px; height:20px; color:var(--fire); }
.pillar__ic{ color:var(--fire); }
.who__ic{ width:2rem; height:2rem; color:var(--fire); display:block; margin:0 auto 12px; }
.tag--time{ display:inline-flex; align-items:center; gap:5px; }
.tag--time .ic{ width:.95rem; height:.95rem; }
.book__perks li{ display:flex; align-items:center; gap:10px; }
.book__ic{ width:1.2rem; height:1.2rem; color:var(--fire); }
.fab{ align-items:center; gap:.5em; }
.fab .ic{ width:1.15em; height:1.15em; }

/* ---------- accessibility: reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
  .hero__slide{ animation:none !important; transform:none !important; }
}
