/* ===================================================================
   PANGEA · Odyssey — immersive scroll-driven journey
   =================================================================== */
:root{
  --ocean:#06243A;        /* deep ocean blue (open) */
  --ocean-2:#0A3050;
  --teak:#A07A4E;         /* warm teak/sand (mid) */
  --sand:#E9DECB;
  --turq:#19C2C2;         /* electric aqua accent + finale */
  --turq-deep:#0E8C8C;
  --ink:#06151F;
  --white:#F7FAFB;
  --paper:#FBFAF6;
  --glass:rgba(255,255,255,.08);
  --glass-strong:rgba(255,255,255,.14);
  --glass-line:rgba(255,255,255,.22);
  --fs-display:"Archivo",system-ui,sans-serif;
  --fs-body:"Spline Sans",system-ui,sans-serif;
  --wrap:1240px;
  --pad:clamp(20px,5vw,72px);
  --nav-h:74px;
  --r:18px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--fs-body);
  color:var(--white);
  background:var(--ocean);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,p{margin:0}
ul,ol{margin:0;padding:0;list-style:none}
button{font-family:inherit}
::selection{background:var(--turq);color:var(--ink)}

/* Lenis */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}

.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad);width:100%}

/* ===== Living gradient backdrop ===== */
.backdrop{position:fixed;inset:0;z-index:-2;background:var(--ocean)}
.backdrop__layer{position:absolute;inset:0;opacity:0;will-change:opacity;transition:opacity .2s linear}
.backdrop__layer--ocean{
  opacity:1;
  background:
    radial-gradient(120% 80% at 80% -10%, #0E4368 0%, transparent 55%),
    radial-gradient(100% 90% at 10% 110%, #041826 0%, transparent 60%),
    linear-gradient(180deg,#06243A 0%, #0A3050 60%, #06243A 100%);
}
.backdrop__layer--teak{
  background:
    radial-gradient(120% 80% at 70% 0%, #C6A06E 0%, transparent 55%),
    linear-gradient(180deg,#8F6E45 0%, #6E5436 100%);
}
.backdrop__layer--turquoise{
  background:
    radial-gradient(120% 90% at 30% 0%, #2FD6D6 0%, transparent 55%),
    radial-gradient(100% 80% at 90% 100%, #0E8C8C 0%, transparent 60%),
    linear-gradient(180deg,#0E8C8C 0%, #0A6E78 100%);
}
.backdrop__grain{
  position:absolute;inset:0;opacity:.05;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ===== Loader ===== */
.loader{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;transition:opacity .6s var(--ease),visibility .6s}
.loader__bg{position:absolute;inset:0;background:linear-gradient(180deg,#041826,#06243A)}
.loader__bg::after{content:"";position:absolute;inset:0;background:url("https://cdn.scheef.tech/pangea/cove-wide-1200.webp") center/cover;opacity:.32;filter:blur(22px) saturate(1.1)}
.loader__inner{position:relative;text-align:center;color:var(--white)}
.loader__ring{transform:rotate(-90deg)}
.loader__track{stroke:rgba(255,255,255,.16)}
.loader__fill{stroke:var(--turq);stroke-dasharray:100;stroke-dashoffset:100;transition:stroke-dashoffset .25s linear}
.loader__brand{font-family:var(--fs-display);font-weight:800;letter-spacing:.28em;font-size:clamp(26px,5vw,40px);margin-top:-78px;padding-left:.28em}
.loader__sub{font-size:13px;letter-spacing:.22em;text-transform:uppercase;opacity:.65;margin-top:8px}
.loader__skip{margin-top:26px;background:none;border:1px solid var(--glass-line);color:#fff;padding:9px 20px;border-radius:99px;font-size:12px;letter-spacing:.1em;cursor:pointer;opacity:.8;transition:opacity .2s,background .2s}
.loader__skip:hover{opacity:1;background:var(--glass)}
.loader.is-done{opacity:0;visibility:hidden;pointer-events:none}

/* ===== Progress bar ===== */
.progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:60;background:rgba(255,255,255,.06)}
.progress__bar{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--turq),#7af0ec);box-shadow:0 0 12px rgba(25,194,194,.6)}

/* ===== Nav ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:55;height:var(--nav-h);
  display:flex;align-items:center;gap:24px;
  padding-inline:var(--pad);
  transition:background .35s var(--ease),backdrop-filter .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{background:rgba(6,21,31,.55);backdrop-filter:blur(16px) saturate(1.2);border-bottom-color:var(--glass-line)}
.nav__brand{display:flex;flex-direction:column;line-height:1;margin-right:auto}
.nav__mark{font-family:var(--fs-display);font-weight:800;letter-spacing:.22em;font-size:20px;padding-left:.22em}
.nav__model{font-size:10px;letter-spacing:.24em;text-transform:uppercase;opacity:.6;margin-top:4px}
.nav__fast{display:flex;gap:26px;align-items:center}
.nav__fast a{font-size:13px;letter-spacing:.06em;opacity:.82;position:relative;padding:6px 0;transition:opacity .2s}
.nav__fast a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--turq);transition:width .25s var(--ease)}
.nav__fast a:hover,.nav__fast a:focus-visible{opacity:1}
.nav__fast a:hover::after,.nav__fast a:focus-visible::after{width:100%}
.nav__menu{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:10px;cursor:pointer}
.nav__menu span{width:24px;height:2px;background:#fff;border-radius:2px;transition:transform .3s,opacity .3s}
.nav.is-open .nav__menu span:first-child{transform:translateY(7px) rotate(45deg)}
.nav.is-open .nav__menu span:last-child{transform:translateY(-7px) rotate(-45deg)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4em;border-radius:99px;font-weight:600;letter-spacing:.02em;cursor:pointer;border:1px solid transparent;transition:transform .25s var(--ease),background .25s,box-shadow .25s,color .25s;text-align:center}
.btn--cta{background:var(--turq);color:var(--ink);padding:11px 22px;font-size:14px;box-shadow:0 6px 24px rgba(25,194,194,.32)}
.btn--cta:hover{background:#2ad8d8;box-shadow:0 10px 34px rgba(25,194,194,.5);transform:translateY(-2px)}
.btn__season{font-weight:500;opacity:.8}
.btn--ghost{background:var(--glass);color:#fff;border-color:var(--glass-line);backdrop-filter:blur(8px);padding:11px 22px;font-size:14px}
.btn--ghost:hover{background:var(--glass-strong);transform:translateY(-2px)}
.btn--lg{padding:15px 30px;font-size:15px}
.btn--full{width:100%}
.nav__cta{flex-shrink:0}

/* mobile sheet */
.sheet{position:fixed;inset:var(--nav-h) 0 0;z-index:54;background:rgba(6,21,31,.96);backdrop-filter:blur(20px);transform:translateY(-12px);opacity:0;visibility:hidden;transition:opacity .3s,transform .3s,visibility .3s;padding:40px var(--pad)}
.sheet.is-open{opacity:1;visibility:visible;transform:none}
.sheet__nav{display:flex;flex-direction:column;gap:6px}
.sheet__nav a{font-family:var(--fs-display);font-weight:700;font-size:clamp(28px,8vw,44px);padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.sheet__cta{color:var(--turq)}

/* ===== Type ===== */
.kicker{font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--turq);font-weight:600;margin-bottom:18px}
.display{font-family:var(--fs-display);font-weight:800;line-height:.98;letter-spacing:-.02em}
.display--xl{font-size:clamp(40px,8.5vw,108px)}
.display--l{font-size:clamp(32px,5.5vw,66px)}
.display--m{font-size:clamp(26px,4vw,42px)}
.lead{font-size:clamp(17px,2vw,21px);font-weight:300;max-width:62ch;color:rgba(255,255,255,.85)}
.section{position:relative;padding-block:clamp(80px,11vw,150px)}

/* Glass */
.glass{background:var(--glass);border:1px solid var(--glass-line);backdrop-filter:blur(14px) saturate(1.25);-webkit-backdrop-filter:blur(14px) saturate(1.25)}

/* Reveal (JS off => fully visible) */
.js [data-rev]{opacity:0;transform:translate3d(0,28px,0)}
[data-rev].is-in{opacity:1;transform:none;transition:opacity .8s var(--ease),transform .8s var(--ease)}

/* ===== Hero ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:-1;will-change:transform}
.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__scrim{position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(4,16,26,.45) 0%,rgba(4,16,26,.05) 35%,rgba(4,16,26,.55) 78%,rgba(4,16,26,.9) 100%)}
.hero__inner{padding:0 var(--pad) clamp(60px,11vh,130px);max-width:980px}
.hero__kicker{font-size:13px;letter-spacing:.26em;text-transform:uppercase;color:var(--turq);font-weight:600;margin-bottom:20px}
.hero__title{font-family:var(--fs-display);font-weight:900;font-size:clamp(64px,17vw,220px);line-height:.86;letter-spacing:-.03em;text-shadow:0 8px 60px rgba(0,0,0,.35)}
.hero__sub{font-size:clamp(17px,2.2vw,23px);font-weight:300;max-width:52ch;margin-top:22px;color:rgba(255,255,255,.92)}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero__scrollcue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;font-size:11px;letter-spacing:.24em;text-transform:uppercase;opacity:.7}
.hero__scrollcue i{width:1px;height:34px;background:linear-gradient(var(--turq),transparent);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(.2);transform-origin:top;opacity:0}40%{opacity:1}100%{transform:scaleY(1);transform-origin:top;opacity:0}}

/* ===== Experience ===== */
.experience .lead{margin-top:26px;font-size:clamp(19px,2.4vw,27px);line-height:1.5;max-width:30ch;font-weight:300}
.experience h2{max-width:14ch}

/* ===== Fast-track ===== */
.fasttrack{padding-block:0 clamp(40px,7vw,80px)}
.fasttrack__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ft-card{border-radius:var(--r);padding:24px 26px;display:flex;flex-direction:column;gap:6px;transition:transform .3s var(--ease),background .3s,box-shadow .3s}
.ft-card:hover{transform:translateY(-4px);background:var(--glass-strong);box-shadow:0 16px 40px rgba(0,0,0,.28)}
.ft-card__no{font-family:var(--fs-display);font-weight:700;color:var(--turq);font-size:14px;letter-spacing:.1em}
.ft-card__title{font-family:var(--fs-display);font-weight:700;font-size:clamp(19px,2.2vw,24px)}
.ft-card__meta{font-size:13px;opacity:.7}

/* ===== Specs ===== */
.specs__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.spec{border-radius:var(--r);padding:30px 22px;text-align:center;display:flex;flex-direction:column;align-items:center}
.spec__value{font-family:var(--fs-display);font-weight:800;font-size:clamp(34px,4vw,52px);line-height:1;font-variant-numeric:tabular-nums}
.spec__unit{font-family:var(--fs-display);font-weight:600;color:var(--turq);font-size:18px;margin-top:4px}
.spec__label{font-size:12px;letter-spacing:.1em;text-transform:uppercase;opacity:.66;margin-top:12px}

/* ===== Why ===== */
.why h2{margin:0 0 38px;max-width:16ch}
.why__chips{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.chip{border-radius:var(--r);padding:30px 28px;transition:transform .3s var(--ease),box-shadow .3s,background .3s}
.chip:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.28);background:var(--glass-strong)}
.chip h3{font-family:var(--fs-display);font-weight:700;font-size:22px;margin-bottom:10px}
.chip p{font-size:15px;opacity:.82;font-weight:300}
.why__chips .chip:nth-child(4),.why__chips .chip:nth-child(5){grid-column:span 1}

/* ===== Deck areas ===== */
.deck h2{margin:0 0 44px;max-width:14ch}
.deck__areas{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.area{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:3/2}
.area img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.area:hover img{transform:scale(1.05)}
.area::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(4,16,26,.85))}
.area__txt{position:absolute;left:0;bottom:0;padding:26px 28px;z-index:1}
.area__txt h3{font-family:var(--fs-display);font-weight:700;font-size:24px;margin-bottom:6px}
.area__txt p{font-size:14px;opacity:.88;max-width:38ch;font-weight:300}

/* ===== Deck map (the single pinned section) ===== */
.deckmap{position:relative;margin-top:clamp(60px,9vw,110px)}
.deckmap__sticky{min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding-block:90px}
.deckmap__head{text-align:center;margin-bottom:34px}
.deckmap__head .kicker{margin-bottom:14px}
.deckmap__hint{font-size:13px;letter-spacing:.06em;opacity:.6;margin-top:14px}
.deckmap__stage{display:grid;grid-template-columns:1.55fr 1fr;gap:26px;align-items:center;max-width:1340px;margin-inline:auto;padding-inline:var(--pad);width:100%}
.deckmap__figure{position:relative;margin:0;border-radius:var(--r);overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.deckmap__figure img{width:100%;display:block}
.hotspot{position:absolute;transform:translate(-50%,-50%);width:44px;height:44px;background:none;border:0;cursor:pointer;display:grid;place-items:center;z-index:2}
.hotspot__dot{position:relative;width:18px;height:18px;border-radius:50%;background:var(--turq);box-shadow:0 0 0 4px rgba(25,194,194,.3);transition:transform .25s var(--ease),box-shadow .25s}
.hotspot__dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1px solid var(--turq);opacity:.7;animation:ping 2.4s var(--ease) infinite}
@keyframes ping{0%{transform:scale(1);opacity:.7}70%,100%{transform:scale(2.2);opacity:0}}
.hotspot:hover .hotspot__dot,.hotspot:focus-visible .hotspot__dot,.hotspot.is-active .hotspot__dot{transform:scale(1.4);box-shadow:0 0 0 6px rgba(25,194,194,.4)}
.hotspot:focus-visible{outline:2px solid #fff;outline-offset:6px;border-radius:50%}
.deckmap__panel{border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column}
.deckmap__panel-media{aspect-ratio:3/2;overflow:hidden}
.deckmap__panel-media img{width:100%;height:100%;object-fit:cover;transition:opacity .35s var(--ease)}
.deckmap__panel.is-swapping .deckmap__panel-media img{opacity:0}
.deckmap__panel-txt{padding:24px 26px}
.deckmap__panel-no{font-family:var(--fs-display);font-weight:700;color:var(--turq);font-size:13px;letter-spacing:.12em}
.deckmap__panel-txt h3{font-family:var(--fs-display);font-weight:700;font-size:24px;margin:8px 0 8px}
.deckmap__panel-txt p{font-size:15px;opacity:.84;font-weight:300}

/* static deck list (fallback) */
.deckmap-list{display:none;grid-template-columns:repeat(2,1fr);gap:16px;padding-top:30px}
.dm-item{border-radius:var(--r);overflow:hidden}
.dm-item img{width:100%;aspect-ratio:3/2;object-fit:cover}
.dm-item h3{font-family:var(--fs-display);font-weight:700;font-size:20px;margin:18px 22px 6px}
.dm-item p{font-size:14px;opacity:.82;margin:0 22px 22px;font-weight:300}

/* ===== Toys ===== */
.toys{min-height:90svh;display:flex;align-items:center;overflow:hidden}
.toys__media{position:absolute;inset:0;z-index:-1}
.toys__media img{width:100%;height:100%;object-fit:cover}
.toys__scrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(4,16,26,.82) 0%,rgba(4,16,26,.35) 60%,transparent 100%)}
.toys__content{position:relative}
.toys h2{margin-bottom:30px;max-width:12ch}
.toys__list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 30px;max-width:640px}
.toys__list li{font-size:clamp(17px,2vw,21px);font-weight:300;padding-left:26px;position:relative}
.toys__list li::before{content:"";position:absolute;left:0;top:.62em;width:10px;height:10px;border-radius:50%;background:var(--turq);box-shadow:0 0 0 4px rgba(25,194,194,.25)}

/* ===== Interior ===== */
.interior .lead{margin:18px 0 44px}
.interior__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.room{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:3/4}
.room--wide{grid-column:span 2;aspect-ratio:16/10}
.room img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.room:hover img{transform:scale(1.05)}
.room::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(4,16,26,.86))}
.room__txt{position:absolute;left:0;bottom:0;padding:24px 26px;z-index:1}
.room__txt h3{font-family:var(--fs-display);font-weight:700;font-size:22px;margin-bottom:6px}
.room__txt p{font-size:14px;opacity:.86;max-width:36ch;font-weight:300}

/* ===== Itinerary / route ===== */
.itinerary h2{max-width:16ch}
.itinerary .lead{margin-top:16px}
.route{margin-top:clamp(36px,5vw,60px)}
.route__map{width:100%;max-width:1100px;margin:0 auto;display:block;height:auto}
.route__line{stroke:var(--turq);stroke-dasharray:1400;stroke-dashoffset:1400;filter:drop-shadow(0 0 6px rgba(25,194,194,.5))}
.route__pin circle{fill:#fff;stroke:var(--turq);stroke-width:3;opacity:0;transform-box:fill-box;transform-origin:center;transform:scale(0)}
.route__pin.is-on circle{opacity:1;transform:scale(1);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.route__pin text{fill:#fff;font-family:var(--fs-display);font-weight:600;font-size:18px;text-anchor:middle;opacity:0;transition:opacity .4s var(--ease) .1s}
.route__pin.is-on text{opacity:.92}
.route__days{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:clamp(30px,4vw,50px)}
.day{padding:22px 22px;border-radius:14px;border-left:2px solid var(--turq);background:var(--glass)}
.day__n{font-family:var(--fs-display);font-weight:700;color:var(--turq);font-size:13px;letter-spacing:.1em}
.day h3{font-family:var(--fs-display);font-weight:700;font-size:19px;margin:8px 0 8px}
.day h3 em{font-style:normal;font-weight:400;opacity:.6;font-size:14px}
.day p{font-size:13.5px;opacity:.8;font-weight:300}

/* ===== Pricing ===== */
.pricing h2{margin-bottom:38px}
.pricing__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:20px}
.pricing__rate{border-radius:var(--r);padding:36px 34px}
.pricing__from{font-family:var(--fs-display);font-weight:800;font-size:clamp(30px,4vw,46px);line-height:1}
.pricing__from span{font-size:.42em;font-weight:500;opacity:.7;letter-spacing:.04em}
.pricing__note{font-size:13px;opacity:.6;margin-top:8px}
.pricing__line{font-size:14.5px;opacity:.82;margin-top:18px;font-weight:300;max-width:46ch}
.pricing__season{margin-top:30px;padding-top:26px;border-top:1px solid var(--glass-line)}
.pricing__season h3{font-family:var(--fs-display);font-weight:700;font-size:19px;margin-bottom:10px}
.pricing__season p{font-size:14.5px;opacity:.82;font-weight:300}
.pricing__lists{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-content:start}
.pricing__col{padding:30px 28px;border-radius:var(--r);background:var(--glass);border:1px solid var(--glass-line)}
.pricing__h{font-family:var(--fs-display);font-weight:700;font-size:18px;margin-bottom:16px;display:flex;align-items:center;gap:9px}
.pricing__h::before{content:"";width:9px;height:9px;border-radius:50%}
.pricing__h--in::before{background:var(--turq);box-shadow:0 0 0 4px rgba(25,194,194,.25)}
.pricing__h--out::before{background:rgba(255,255,255,.4)}
.pricing__ul li{font-size:14.5px;opacity:.86;font-weight:300;padding:8px 0 8px 22px;position:relative;border-top:1px solid rgba(255,255,255,.07)}
.pricing__ul li:first-child{border-top:0}
.pricing__ul li::before{content:"✓";position:absolute;left:0;color:var(--turq);font-size:13px;top:8px}
.pricing__ul--out li::before{content:"–";color:rgba(255,255,255,.5)}

/* ===== Crew ===== */
.crew h2{margin-bottom:42px}
.crew__grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.crew__card{display:grid;grid-template-columns:auto 1fr;gap:0;border-radius:var(--r);overflow:hidden;background:var(--glass);border:1px solid var(--glass-line)}
.crew__media{width:170px}
.crew__media img{width:100%;height:100%;object-fit:cover}
.crew__txt{padding:28px 28px;align-self:center}
.crew__role{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--turq);font-weight:600}
.crew__txt h3{font-family:var(--fs-display);font-weight:700;font-size:24px;margin:8px 0 12px}
.crew__txt p{font-size:14.5px;opacity:.84;font-weight:300}
.crew__creds{font-size:12.5px;opacity:.62;margin-top:14px;letter-spacing:.01em}

.culinary{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin-top:clamp(50px,7vw,90px)}
.culinary__txt .kicker{margin-bottom:14px}
.culinary__txt h3{margin-bottom:18px}
.culinary__media{border-radius:var(--r);overflow:hidden;aspect-ratio:4/3}
.culinary__media img{width:100%;height:100%;object-fit:cover}

.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:clamp(50px,7vw,90px)}
.quote{border-radius:var(--r);padding:30px 28px}
.quote p{font-family:var(--fs-display);font-weight:500;font-size:19px;line-height:1.4}
.quote cite{display:block;margin-top:18px;font-style:normal;font-size:13px;letter-spacing:.06em;opacity:.62}

/* ===== Gallery ===== */
.gallery h2{margin-bottom:40px}
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding-inline:var(--pad);max-width:1500px;margin-inline:auto}
.gallery__item{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;aspect-ratio:1;background:var(--glass)}
.gallery__item:nth-child(8n+1),.gallery__item:nth-child(8n+6){grid-row:span 2;aspect-ratio:1/2}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gallery__item::after{content:"";position:absolute;inset:0;background:rgba(6,21,31,.18);opacity:0;transition:opacity .3s}
.gallery__item:hover img{transform:scale(1.07)}
.gallery__item:hover::after{opacity:1}
.gallery__item:focus-visible{outline:2px solid var(--turq);outline-offset:3px}

/* ===== Enquiry ===== */
.enquire{min-height:100svh;display:flex;align-items:center;overflow:hidden}
.enquire__media{position:absolute;inset:0;z-index:-1}
.enquire__media img{width:100%;height:100%;object-fit:cover}
.enquire__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(4,16,26,.6),rgba(4,16,26,.78))}
.enquire__inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;position:relative}
.enquire__intro h2{margin:16px 0 18px}
.enquire__resp{margin-top:22px;font-size:14px;letter-spacing:.06em;color:var(--turq);font-weight:600}
.form{border-radius:var(--r);padding:clamp(26px,3vw,40px)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.field span{font-size:13px;letter-spacing:.04em;opacity:.85}
.field i{color:var(--turq);font-style:normal}
.field input,.field select,.field textarea{
  background:rgba(255,255,255,.06);border:1px solid var(--glass-line);border-radius:11px;
  padding:13px 15px;color:#fff;font-family:inherit;font-size:15px;width:100%;transition:border-color .2s,background .2s;
}
.field textarea{resize:vertical;min-height:96px}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2319C2C2' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center}
.field option{color:#06151F}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--turq);background:rgba(255,255,255,.1)}
.field input.invalid,.field input:invalid:not(:placeholder-shown){border-color:#ff8a7a}
.form__reassure{font-size:12.5px;opacity:.66;margin-top:16px;text-align:center;font-weight:300}
.form__status{font-size:14px;margin-top:14px;text-align:center;min-height:1.2em}
.form__status.ok{color:var(--turq)}
.form__status.err{color:#ff9a8a}
.form.is-sent .form__row,.form.is-sent .field:not(.form__status),.form.is-sent button,.form.is-sent .form__reassure{display:none}

/* ===== Footer ===== */
.footer{padding-block:60px 50px;border-top:1px solid var(--glass-line);position:relative;background:rgba(4,16,26,.5)}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;align-items:start}
.footer__brand{font-family:var(--fs-display);font-weight:800;letter-spacing:.2em;font-size:24px;padding-left:.2em}
.footer__model{font-size:12px;letter-spacing:.16em;text-transform:uppercase;opacity:.6;margin-top:8px}
.footer__meta p,.footer__credits p{font-size:13.5px;opacity:.74;margin-bottom:8px;font-weight:300}
.footer__meta a:hover,.footer__credits a:hover{color:var(--turq)}

/* ===== Lightbox ===== */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(4,12,20,.95);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__img{max-width:90vw;max-height:86vh;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox__close{position:absolute;top:20px;right:26px;background:none;border:0;color:#fff;font-size:40px;line-height:1;cursor:pointer;opacity:.8;transition:opacity .2s}
.lightbox__close:hover{opacity:1}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);background:var(--glass);border:1px solid var(--glass-line);color:#fff;width:54px;height:54px;border-radius:50%;font-size:30px;cursor:pointer;display:grid;place-items:center;transition:background .2s,transform .2s}
.lightbox__nav:hover{background:var(--glass-strong);transform:translateY(-50%) scale(1.08)}
.lightbox__nav--prev{left:22px}
.lightbox__nav--next{right:22px}
.lightbox__count{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-size:13px;letter-spacing:.1em;opacity:.7}
.lightbox :focus-visible{outline:2px solid var(--turq);outline-offset:3px}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:1080px){
  .specs__grid{grid-template-columns:repeat(3,1fr)}
  .why__chips{grid-template-columns:repeat(2,1fr)}
  .interior__grid{grid-template-columns:repeat(2,1fr)}
  .room--wide{grid-column:span 2}
  .route__days{grid-template-columns:repeat(2,1fr)}
  .testimonials{grid-template-columns:1fr}
  .gallery__grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:900px){
  .nav__fast{display:none}
  .nav__menu{display:flex}
  .nav__cta{display:none}
  .deckmap__stage{grid-template-columns:1fr}
}
@media (max-width:760px){
  :root{--nav-h:64px}
  .fasttrack__grid{grid-template-columns:1fr}
  .why__chips{grid-template-columns:1fr}
  .deck__areas{grid-template-columns:1fr}
  .interior__grid{grid-template-columns:1fr}
  .room--wide{grid-column:span 1;aspect-ratio:3/2}
  .room{aspect-ratio:3/2}
  .route__days{grid-template-columns:1fr}
  .pricing__grid{grid-template-columns:1fr}
  .pricing__lists{grid-template-columns:1fr}
  .crew__grid{grid-template-columns:1fr}
  .culinary{grid-template-columns:1fr;gap:24px}
  .enquire__inner{grid-template-columns:1fr;gap:30px}
  .form__row{grid-template-columns:1fr}
  .gallery__grid{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr;gap:24px}
  .toys__scrim{background:linear-gradient(180deg,rgba(4,16,26,.55),rgba(4,16,26,.85))}
}
@media (max-width:480px){
  .crew__card{grid-template-columns:1fr}
  .crew__media{width:100%;aspect-ratio:4/3}
  .lightbox__nav{width:46px;height:46px}
  .gallery__item:nth-child(8n+1),.gallery__item:nth-child(8n+6){grid-row:auto;aspect-ratio:1}
}

/* ===================================================================
   KILL-SWITCH: reduced motion (mobile kill-switch applied via JS .no-fx)
   =================================================================== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .js [data-rev]{opacity:1!important;transform:none!important}
  .hero__scrollcue,.hotspot__dot::after{display:none}
  .route__line{stroke-dashoffset:0!important}
  .route__pin circle,.route__pin text{opacity:1!important;transform:none!important}
  .route__pin circle{transform:scale(1)!important}
}

/* JS adds .no-fx when mobile/narrow/reduced → static deck list, static route */
.no-fx .deckmap__sticky{display:none}
.no-fx .deckmap-list{display:grid}
.no-fx .deckmap{margin-top:clamp(40px,7vw,70px)}
.no-fx .route__line{stroke-dashoffset:0}
.no-fx .route__pin circle{opacity:1;transform:scale(1)}
.no-fx .route__pin text{opacity:.92}
.no-fx [data-rev]{opacity:1;transform:none}
