/* ============================================================
   PANGEA — Option 1 · "Nocturne"
   Cinematic editorial dark-luxe. Fraunces + Inter.
   ============================================================ */

:root{
  --ink:        #0B0E11;   /* near-black base */
  --ink-2:      #0E1318;
  --teal:       #0C1A1E;   /* progressive warm/teal shift */
  --charcoal:   #15120E;   /* warm charcoal */
  --paper:      #F4F1EA;   /* soft off-white text */
  --paper-dim:  #C9C6BD;
  --paper-mute: #8A887F;
  --brass:      #C9A86A;   /* champagne accent */
  --brass-soft: #E0C690;
  --navy:       #16202C;
  --hair:       rgba(244,241,234,.14);
  --hair-brass: rgba(201,168,106,.34);

  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
  --gut: clamp(20px, 5vw, 96px);
  --maxw: 1320px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--ink);
  color:var(--paper);
  font-family:var(--sans);
  font-weight:300;
  font-size:clamp(15px,1.05vw,17px);
  line-height:1.7;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
ul,ol{ margin:0; padding:0; list-style:none; }
h1,h2,h3{ margin:0; font-weight:400; }
::selection{ background:var(--brass); color:var(--ink); }

/* progressive background shift — sections carry their own tone */
.experience,.specs,.why{ background:var(--ink); }
.filmstrip{ background:linear-gradient(180deg,var(--ink),var(--teal)); }
.deckmap{ background:var(--teal); }
.toys{ background:linear-gradient(180deg,var(--teal),#0d1714); }
.interior{ background:linear-gradient(180deg,#0d1714,var(--charcoal)); }
.itin{ background:var(--charcoal); }
.pricing{ background:linear-gradient(180deg,var(--charcoal),#100d09); }
.crew{ background:#100d09; }
.gallery{ background:linear-gradient(180deg,#100d09,var(--ink)); }
.enquire{ background:var(--ink); }

/* ---------- shared type ---------- */
.sectionno{
  font-family:var(--sans);
  font-size:.72rem; font-weight:500;
  letter-spacing:.32em; text-transform:uppercase;
  color:var(--brass);
  margin:0 0 1.4rem;
  display:flex; align-items:center; gap:.85rem;
}
.sectionno::before{ content:""; width:34px; height:1px; background:var(--brass); opacity:.7; }
.sectionno--center{ justify-content:center; }

.kicker{
  font-size:.72rem; letter-spacing:.32em; text-transform:uppercase;
  color:var(--brass); font-weight:500;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:48px; padding:0 1.7rem;
  font-family:var(--sans); font-size:.82rem; font-weight:500;
  letter-spacing:.14em; text-transform:uppercase;
  border-radius:2px; cursor:pointer; border:1px solid transparent;
  transition:background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease), transform .25s var(--ease);
  will-change:transform;
}
.btn--brass{ background:var(--brass); color:var(--ink); }
.btn--brass:hover{ background:var(--brass-soft); }
.btn--ghost{ color:var(--paper); border-color:var(--hair); }
.btn--ghost:hover{ border-color:var(--brass); color:var(--brass-soft); }

/* ============================================================
   LOADER
   ============================================================ */
.loader{
  position:fixed; inset:0; z-index:1000;
  background:var(--ink);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:1.1rem;
}
.loader__inner{ text-align:center; }
.loader__word{
  font-family:var(--serif); font-weight:300;
  font-size:clamp(3rem,11vw,7rem); letter-spacing:.12em;
  color:var(--paper); display:flex; gap:.04em; line-height:1;
}
.loader__char{
  display:inline-block;
  clip-path:inset(0 0 100% 0);
  transform:translateY(.25em);
  opacity:0;
}
.loader__rule{
  height:1px; width:0; margin:1.5rem auto .4rem;
  background:var(--brass);
}
.loader__sub{
  font-size:.7rem; letter-spacing:.34em; text-transform:uppercase;
  color:var(--brass); opacity:0; transition:opacity .5s ease .2s;
}
.loader__skip{
  position:absolute; bottom:2rem; right:2rem;
  background:none; border:none; cursor:pointer;
  color:var(--paper-mute); font-family:var(--sans);
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
  padding:.6rem 1rem;
}
.loader__skip:hover{ color:var(--brass); }
.loader--done{ opacity:0; transform:translateY(-2%); pointer-events:none;
  transition:opacity .8s var(--ease), transform .9s var(--ease); }

/* no-js: never show the loader */
.no-js .loader{ display:none; }

/* ============================================================
   GRAIN + global texture
   ============================================================ */
.grain{
  position:fixed; inset:-50%; z-index:900; pointer-events:none;
  opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 7s steps(6) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0)} 20%{transform:translate(-4%,2%)}
  40%{transform:translate(3%,-3%)} 60%{transform:translate(-2%,4%)}
  80%{transform:translate(4%,-2%)}
}
@media (prefers-reduced-motion: reduce){ .grain{ display:none; } }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:800;
  display:flex; align-items:center; justify-content:space-between;
  gap:1.5rem; padding:1.1rem var(--gut);
  transition:background .5s var(--ease), padding .5s var(--ease), border-color .5s var(--ease);
  border-bottom:1px solid transparent;
}
.nav--scrolled{
  background:rgba(11,14,17,.78);
  -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border-bottom-color:var(--hair);
  padding-top:.85rem; padding-bottom:.85rem;
}
.nav__brand{ display:flex; flex-direction:column; line-height:1.05; }
.nav__mark{ font-family:var(--serif); font-size:1.25rem; letter-spacing:.22em; }
.nav__model{ font-size:.6rem; letter-spacing:.26em; text-transform:uppercase; color:var(--paper-mute); }
.nav__links{ display:flex; gap:2rem; margin-left:auto; margin-right:2rem; }
.nav__links a{
  font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--paper-dim); position:relative; padding:.4rem 0;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--brass); transition:width .4s var(--ease);
}
.nav__links a:hover{ color:var(--paper); }
.nav__links a:hover::after{ width:100%; }

.pill{
  display:inline-flex; align-items:center; gap:.6rem;
  min-height:46px; padding:0 1.3rem;
  border:1px solid var(--brass); border-radius:100px;
  color:var(--brass-soft); background:rgba(201,168,106,.06);
  transition:background .4s var(--ease), color .4s var(--ease), transform .25s var(--ease);
  will-change:transform;
}
.pill:hover{ background:var(--brass); color:var(--ink); }
.pill__dot{ width:7px; height:7px; border-radius:50%; background:var(--brass); }
.pill:hover .pill__dot{ background:var(--ink); }
.pill__label{ font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; font-weight:500; }
.pill__sub{ font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; opacity:.7; }

/* nav entrance — one-time */
.js .nav{ transform:translateY(-110%); }
.nav--in{ transform:translateY(0)!important; transition:transform .8s var(--ease); }
.no-js .nav{ transform:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; height:100svh; min-height:600px;
  display:flex; align-items:flex-end;
  overflow:hidden;
}
.hero__media{ position:absolute; inset:-8% 0; will-change:transform; }
.hero__img{ width:100%; height:100%; object-fit:cover; }
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(11,14,17,.55) 0%, rgba(11,14,17,0) 28%, rgba(11,14,17,.1) 55%, rgba(11,14,17,.92) 100%),
    linear-gradient(90deg, rgba(11,14,17,.6), rgba(11,14,17,0) 60%);
}
.hero__vignette{
  position:absolute; inset:0; pointer-events:none;
  box-shadow:inset 0 0 240px 60px rgba(0,0,0,.6);
}
.hero__content{
  position:relative; z-index:2;
  padding:0 var(--gut) clamp(3rem,8vh,6rem);
  max-width:920px;
}
.hero__kicker{ margin:0 0 1.3rem; }
.hero__title{
  font-family:var(--serif); font-weight:300;
  font-size:clamp(4.5rem,17vw,13rem); line-height:.86;
  letter-spacing:.01em; margin:0 0 1.5rem;
  text-shadow:0 6px 50px rgba(0,0,0,.5);
}
.hero__sub{
  font-size:clamp(1.05rem,1.7vw,1.35rem); line-height:1.55;
  color:var(--paper-dim); max-width:34ch; margin:0 0 2.2rem;
}
.hero__actions{ display:flex; flex-wrap:wrap; gap:1rem; }
.hero__cue{
  position:absolute; bottom:1.8rem; left:50%; transform:translateX(-50%);
  z-index:2; display:flex; flex-direction:column; align-items:center; gap:.7rem;
}
.hero__cue-line{ width:1px; height:46px; background:linear-gradient(var(--brass),transparent); }
.hero__cue-text{ font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; color:var(--paper-mute); }
@media (prefers-reduced-motion: no-preference){
  .hero__cue-line{ animation:cueDrop 2.2s var(--ease) infinite; transform-origin:top; }
}
@keyframes cueDrop{ 0%,100%{transform:scaleY(.4);opacity:.4} 50%{transform:scaleY(1);opacity:1} }

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
section{ position:relative; }
.experience,.specs,.why,.deckmap,.itin,.pricing,.crew,.gallery,.enquire{
  padding:clamp(5rem,12vh,9rem) var(--gut);
}

/* hairline divider helper */
.hair{ height:1px; background:var(--hair-brass); border:0; margin:0; }

/* ---------- 02 EXPERIENCE ---------- */
.experience{ max-width:var(--maxw); margin:0 auto; }
.experience__title{
  font-family:var(--serif); font-weight:300;
  font-size:clamp(2.6rem,6.5vw,5.2rem); line-height:1.02;
  margin:0 0 2rem; letter-spacing:-.01em;
}
.experience__body{
  font-size:clamp(1.15rem,1.9vw,1.5rem); line-height:1.6;
  color:var(--paper-dim); max-width:62ch; font-weight:300;
}

/* ---------- 03 SPECS ---------- */
.specs{ border-top:1px solid var(--hair); }
.specs__grid{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:repeat(6,1fr);
  gap:1px; background:var(--hair);
  border:1px solid var(--hair);
}
.spec{
  background:var(--ink);
  padding:clamp(1.8rem,4vw,3rem) 1.2rem;
  display:flex; flex-direction:column; align-items:center; gap:.4rem; text-align:center;
}
.spec__value{ font-family:var(--serif); font-size:clamp(2.2rem,4vw,3.4rem); line-height:1; color:var(--paper); }
.spec__unit{ font-family:var(--serif); font-size:1rem; color:var(--brass); margin-top:-.3rem; }
.spec__label{ font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--paper-mute); margin-top:.4rem; }

/* ---------- 04 WHY ---------- */
.why{ max-width:var(--maxw); margin:0 auto; }
.why__head{ margin-bottom:3.5rem; max-width:40ch; }
.why__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.2rem,5vw,4rem); line-height:1.05; }
.why__list{ display:grid; gap:0; }
.why__item{
  display:grid; grid-template-columns:auto 1fr; gap:clamp(1.5rem,4vw,4rem);
  align-items:start; padding:2.2rem 0; border-top:1px solid var(--hair);
}
.why__item:last-child{ border-bottom:1px solid var(--hair); }
.why__num{ font-family:var(--serif); font-size:clamp(1.6rem,3vw,2.4rem); color:var(--brass); opacity:.55; line-height:1; }
.why__item h3{ font-family:var(--serif); font-size:clamp(1.5rem,2.6vw,2.1rem); font-weight:400; margin-bottom:.5rem; }
.why__item p{ color:var(--paper-dim); max-width:46ch; }
.why__item:hover .why__num{ opacity:1; transition:opacity .4s var(--ease); }

/* ---------- FILMSTRIP ---------- */
.filmstrip{ padding:clamp(5rem,12vh,9rem) 0; overflow:hidden; }
.filmstrip__head{ padding:0 var(--gut); max-width:var(--maxw); margin:0 auto 3rem; }
.filmstrip__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.2rem,5vw,4rem); }
.filmstrip__track-wrap{ position:relative; }
.filmstrip__edge{ position:absolute; top:0; bottom:0; width:11%; z-index:3; pointer-events:none; }
.filmstrip__edge--l{ left:0; background:linear-gradient(90deg, rgba(11,14,17,.95), transparent); }
.filmstrip__edge--r{ right:0; background:linear-gradient(270deg, rgba(11,14,17,.0), transparent); }
.filmstrip__track{
  display:flex; gap:clamp(1.2rem,2.4vw,2.4rem);
  padding:0 var(--gut); will-change:transform;
}
.frame{ flex:0 0 auto; width:min(46vw,640px); margin:0; }
.frame img{
  width:100%; aspect-ratio:3/2; object-fit:cover; border-radius:2px;
  filter:brightness(.92) saturate(1.02);
  transition:filter .5s var(--ease), transform .6s var(--ease);
}
.frame:hover img{ filter:brightness(1.04) saturate(1.06); transform:translateY(-6px); }
.frame figcaption{ margin-top:1.1rem; display:flex; flex-direction:column; gap:.25rem; }
.frame__cap{
  font-family:var(--serif); font-size:1.4rem; position:relative; width:max-content;
  padding-bottom:.3rem;
}
.frame__cap::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--brass); transition:width .5s var(--ease); }
.frame:hover .frame__cap::after{ width:100%; }
.frame__sub{ font-size:.92rem; color:var(--paper-mute); max-width:40ch; }
/* mobile: no horizontal-scroll pin, just native scroll-snap */
.filmstrip--native .filmstrip__track{ overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; padding-bottom:1rem; }
.filmstrip--native .frame{ scroll-snap-align:center; width:82vw; }

/* ---------- 05 DECK MAP ---------- */
.deckmap{ }
.deckmap__head{ max-width:var(--maxw); margin:0 auto 3rem; text-align:center; }
.deckmap__head .sectionno{ justify-content:center; }
.deckmap__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.2rem,5vw,4rem); }
.deckmap__hint{ color:var(--paper-mute); font-size:.92rem; margin-top:.6rem; }
.deckmap__stage{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:1.55fr 1fr; gap:clamp(1.5rem,3vw,3rem);
  align-items:center;
}
.deckmap__figure{ position:relative; border:1px solid var(--hair); border-radius:3px; overflow:hidden; }
.deckmap__img{ width:100%; filter:brightness(.85) contrast(1.02); }
.hotspot{
  position:absolute; transform:translate(-50%,-50%);
  width:44px; height:44px; border:0; background:none; cursor:pointer; padding:0;
  display:grid; place-items:center;
}
.hotspot__pin{ width:11px; height:11px; border-radius:50%; background:var(--brass); box-shadow:0 0 0 4px rgba(11,14,17,.55); z-index:2; transition:transform .3s var(--ease); }
.hotspot__ring{
  position:absolute; width:22px; height:22px; border-radius:50%;
  border:1px solid var(--brass); opacity:.8;
}
@media (prefers-reduced-motion: no-preference){
  .hotspot__ring{ animation:ring 2.4s var(--ease) infinite; }
}
@keyframes ring{ 0%{transform:scale(.6);opacity:.9} 100%{transform:scale(2.1);opacity:0} }
.hotspot:hover .hotspot__pin,
.hotspot[aria-expanded="true"] .hotspot__pin{ transform:scale(1.5); }
.hotspot:focus-visible{ outline:none; }
.hotspot:focus-visible .hotspot__pin{ box-shadow:0 0 0 4px rgba(11,14,17,.55), 0 0 0 7px var(--brass); }
.hotspot.is-active .hotspot__pin{ background:var(--brass-soft); transform:scale(1.5); }

.deckmap__panel{
  border:1px solid var(--hair); border-radius:3px; overflow:hidden;
  background:var(--ink-2);
}
.deckmap__panel-media{ overflow:hidden; }
.deckmap__panel-media img{ width:100%; aspect-ratio:3/2; object-fit:cover; transition:opacity .4s var(--ease), transform .8s var(--ease); }
.deckmap__panel-body{ padding:1.6rem 1.7rem 1.9rem; position:relative; }
.deckmap__panel-no{ position:absolute; top:-2.2rem; right:1.4rem; font-family:var(--serif); font-size:3rem; color:var(--brass); opacity:.25; }
.deckmap__panel-body h3{ font-family:var(--serif); font-size:1.6rem; margin-bottom:.5rem; }
.deckmap__panel-body p{ color:var(--paper-dim); font-size:.98rem; }
.is-swapping .deckmap__panel-media img{ opacity:.2; }

.deckmap__list{
  display:none; max-width:var(--maxw); margin:2.5rem auto 0;
  gap:1px; background:var(--hair); border:1px solid var(--hair);
}
.deckmap__list li{ background:var(--ink-2); padding:1.2rem 1.4rem; color:var(--paper-dim); }
.deckmap__list strong{ color:var(--paper); font-weight:500; }

/* ---------- 06 TOYS ---------- */
.toys{ display:grid; grid-template-columns:1fr 1fr; gap:0; padding:0; align-items:stretch; }
.toys__media{ overflow:hidden; }
.toys__media img{ width:100%; height:100%; min-height:60vh; object-fit:cover; }
.toys__body{ padding:clamp(4rem,10vh,8rem) var(--gut); display:flex; flex-direction:column; justify-content:center; }
.toys__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.2rem,5vw,4rem); margin-bottom:2rem; line-height:1.04; }
.toys__list{ columns:2; column-gap:2.5rem; }
.toys__list li{
  padding:.85rem 0; border-bottom:1px solid var(--hair);
  font-size:1.02rem; color:var(--paper-dim); break-inside:avoid;
  position:relative; padding-left:1.4rem;
}
.toys__list li::before{ content:""; position:absolute; left:0; top:1.35rem; width:7px; height:7px; background:var(--brass); border-radius:50%; }

/* ---------- 07 INTERIOR ---------- */
.interior{ }
.interior__head{ max-width:var(--maxw); margin:0 auto 3.5rem; }
.interior__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.2rem,5vw,4rem); margin:0 0 1.3rem; }
.interior__body{ color:var(--paper-dim); max-width:58ch; font-size:1.12rem; }
.interior__grid{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:repeat(2,1fr);
  grid-auto-rows:minmax(0,auto); gap:clamp(1.2rem,2.5vw,2.5rem);
}
.room--tall{ grid-row:span 2; }
.room__media{ overflow:hidden; border-radius:2px; }
.room__media img{ width:100%; aspect-ratio:3/2; object-fit:cover; filter:brightness(.92); transition:transform .8s var(--ease), filter .5s var(--ease); }
.room--tall .room__media img{ aspect-ratio:3/4; }
.room:hover .room__media img{ transform:scale(1.04); filter:brightness(1.02); }
.room__cap{ padding:1.2rem .2rem 0; }
.room__cap h3{ font-family:var(--serif); font-size:1.5rem; margin-bottom:.4rem; }
.room__cap p{ color:var(--paper-mute); font-size:.96rem; max-width:42ch; }

/* ---------- 08 ITINERARY ---------- */
.itin{ }
.itin__head{ max-width:var(--maxw); margin:0 auto 3.5rem; }
.itin__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.4rem,6vw,4.6rem); line-height:1.02; margin:0 0 1rem; }
.itin__sub{ color:var(--paper-mute); font-size:1.05rem; }
.itin__days{ max-width:920px; margin:0 auto; }
.day{
  display:grid; grid-template-columns:auto 1fr; gap:clamp(1.4rem,4vw,3.5rem);
  padding:1.9rem 0; border-top:1px solid var(--hair);
  position:relative;
}
.day:last-child{ border-bottom:1px solid var(--hair); }
.day__no{ font-family:var(--serif); font-size:clamp(1.6rem,3vw,2.6rem); color:var(--brass); opacity:.6; line-height:1; }
.day__main h3{ font-family:var(--serif); font-size:clamp(1.4rem,2.6vw,2rem); font-weight:400; margin-bottom:.4rem; }
.day__main h3 em{ font-style:normal; color:var(--brass); font-size:.7em; letter-spacing:.04em; }
.day__main p{ color:var(--paper-dim); max-width:54ch; }

/* ---------- INTERSTITIAL ---------- */
.interstitial{ position:relative; height:80vh; min-height:480px; overflow:hidden; display:grid; place-items:center; }
.interstitial__media{ position:absolute; inset:-8% 0; will-change:transform; }
.interstitial__media img{ width:100%; height:100%; object-fit:cover; }
.interstitial__scrim{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(11,14,17,.5),rgba(11,14,17,.15) 40%,rgba(11,14,17,.7)); }
.interstitial__quote{ position:relative; z-index:2; margin:0; padding:0 var(--gut); max-width:24ch; text-align:center; }
.interstitial__quote p{
  font-family:var(--serif); font-weight:300; font-style:italic;
  font-size:clamp(1.8rem,4.5vw,3.4rem); line-height:1.2;
  text-shadow:0 4px 30px rgba(0,0,0,.5);
}

/* ---------- 09 PRICING ---------- */
.pricing{ }
.pricing__head{ max-width:var(--maxw); margin:0 auto 3rem; }
.pricing__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.2rem,5vw,4rem); }
.pricing__grid{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:1fr 1.25fr; gap:clamp(1.5rem,4vw,4rem);
  align-items:start;
}
.pricing__rate{ border:1px solid var(--hair-brass); border-radius:3px; padding:clamp(1.8rem,3vw,2.6rem); background:linear-gradient(180deg,rgba(201,168,106,.05),transparent); }
.pricing__from{ font-size:.72rem; letter-spacing:.26em; text-transform:uppercase; color:var(--brass); }
.pricing__price{ display:block; font-family:var(--serif); font-size:clamp(2.6rem,5vw,3.8rem); line-height:1; margin:.4rem 0 .2rem; }
.pricing__price span{ font-size:1rem; color:var(--paper-mute); letter-spacing:.04em; }
.pricing__note{ color:var(--paper-mute); font-size:.86rem; margin:0 0 1.6rem; }
.pricing__extra{ font-size:.92rem; color:var(--paper-dim); padding-top:1rem; margin:0; border-top:1px solid var(--hair); }
.pricing__extra span{ display:inline-block; font-weight:500; color:var(--brass); letter-spacing:.1em; font-size:.72rem; text-transform:uppercase; margin-right:.6rem; }
.pricing__cta{ margin-top:1.8rem; width:100%; }
.pricing__cols{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,3vw,3rem); }
.pricing__col h3{ font-family:var(--serif); font-size:1.4rem; margin-bottom:1.1rem; padding-bottom:.7rem; border-bottom:1px solid var(--hair-brass); }
.ticks li{ padding:.6rem 0 .6rem 1.8rem; position:relative; color:var(--paper-dim); font-size:.96rem; border-bottom:1px solid var(--hair); }
.ticks--in li::before{ content:"✓"; position:absolute; left:0; top:.55rem; color:var(--brass); font-size:.9rem; }
.ticks--out li::before{ content:"—"; position:absolute; left:0; top:.55rem; color:var(--paper-mute); }
.pricing__season{ max-width:var(--maxw); margin:3rem auto 0; color:var(--paper-dim); font-size:1rem; max-width:70ch; }
.pricing__season strong{ color:var(--paper); font-weight:500; }

/* ---------- 10 CREW ---------- */
.crew__head{ max-width:var(--maxw); margin:0 auto 3.5rem; }
.crew__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.2rem,5vw,4rem); }
.crew__members{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,4vw,4rem); }
.member{ display:grid; grid-template-columns:auto 1fr; gap:1.6rem; align-items:start; }
.member__media{ width:clamp(120px,16vw,200px); border-radius:2px; overflow:hidden; }
.member__media img{ width:100%; aspect-ratio:4/5; object-fit:cover; filter:grayscale(.15) brightness(.95); transition:filter .5s var(--ease); }
.member:hover .member__media img{ filter:grayscale(0) brightness(1.02); }
.member__role{ font-size:.68rem; letter-spacing:.26em; text-transform:uppercase; color:var(--brass); }
.member__body h3{ font-family:var(--serif); font-size:1.7rem; margin:.3rem 0 .7rem; }
.member__body p{ color:var(--paper-dim); font-size:.98rem; }
.member__creds{ color:var(--paper-mute)!important; font-size:.82rem!important; margin-top:.8rem; }

.culinary{ max-width:var(--maxw); margin:clamp(4rem,9vh,7rem) auto 0; display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,4vw,4rem); align-items:center; }
.culinary__media{ overflow:hidden; border-radius:2px; }
.culinary__media img{ width:100%; aspect-ratio:4/3; object-fit:cover; }
.culinary__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2rem,4vw,3.2rem); margin-bottom:1.3rem; }
.culinary__body p{ color:var(--paper-dim); font-size:1.08rem; max-width:46ch; }

.quotes{ max-width:var(--maxw); margin:clamp(4rem,9vh,7rem) auto 0; }
.quotes__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.5rem,3vw,3rem); margin-top:2.5rem; }
.quote{ margin:0; padding:2rem 0 0; border-top:1px solid var(--hair-brass); position:relative; }
.quote::before{ content:"“"; font-family:var(--serif); font-size:4rem; line-height:0; position:absolute; top:1.9rem; left:0; color:var(--brass); opacity:.4; }
.quote blockquote{ margin:1.2rem 0 1.2rem; font-family:var(--serif); font-size:1.3rem; font-style:italic; font-weight:300; line-height:1.4; color:var(--paper); }
.quote figcaption{ font-size:.82rem; letter-spacing:.06em; color:var(--paper-mute); text-transform:uppercase; }
.quote figcaption span{ color:var(--brass); }

/* ---------- 11 GALLERY ---------- */
.gallery__head{ max-width:var(--maxw); margin:0 auto 3rem; }
.gallery__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.2rem,5vw,4rem); }
.gallery__grid{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:repeat(4,1fr);
  grid-auto-rows:1fr; gap:clamp(.6rem,1.2vw,1rem);
}
.gtile{ position:relative; padding:0; border:0; cursor:pointer; overflow:hidden; border-radius:2px; background:var(--ink-2); aspect-ratio:1/1; }
.gtile--wide{ grid-column:span 2; aspect-ratio:2/1; }
.gtile img{ width:100%; height:100%; object-fit:cover; filter:brightness(.86); transition:transform .7s var(--ease), filter .5s var(--ease); }
.gtile::after{ content:""; position:absolute; inset:0; border:1px solid transparent; transition:border-color .4s var(--ease); }
.gtile:hover img{ transform:scale(1.06); filter:brightness(1.02); }
.gtile:hover::after,.gtile:focus-visible::after{ border-color:var(--brass); }
.gtile:focus-visible{ outline:none; }

/* ---------- 12 ENQUIRE ---------- */
.enquire__inner{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:start; }
.enquire__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.4rem,5.5vw,4.6rem); line-height:1.02; margin:0 0 1.6rem; }
.enquire__lead{ font-size:1.15rem; color:var(--paper-dim); max-width:40ch; margin:0 0 1.4rem; }
.enquire__reassure{ font-size:.95rem; color:var(--paper-mute); max-width:42ch; }
.enquire__response{ display:flex; align-items:center; gap:.7rem; font-size:.85rem; letter-spacing:.06em; text-transform:uppercase; color:var(--brass); margin-top:1.6rem; }
.dotpulse{ width:8px; height:8px; border-radius:50%; background:var(--brass); }
@media (prefers-reduced-motion: no-preference){ .dotpulse{ animation:pulse 2s ease-in-out infinite; } }
@keyframes pulse{ 0%,100%{box-shadow:0 0 0 0 rgba(201,168,106,.5)} 50%{box-shadow:0 0 0 7px rgba(201,168,106,0)} }

.form{ display:grid; gap:1.3rem; }
.field{ display:grid; gap:.5rem; }
.field--row{ grid-template-columns:1fr 1fr; gap:1.3rem; }
.field--row > div{ display:grid; gap:.5rem; }
.field label{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--paper-dim); }
.field label span{ color:var(--brass); }
.field .opt{ color:var(--paper-mute); letter-spacing:.06em; text-transform:none; }
.field input,.field select,.field textarea{
  width:100%; background:var(--ink-2); border:1px solid var(--hair);
  color:var(--paper); font-family:var(--sans); font-size:1rem; font-weight:300;
  padding:.95rem 1rem; border-radius:2px; min-height:48px;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.field textarea{ resize:vertical; min-height:120px; }
.field select{ appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C9A86A' stroke-width='1.4'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 1rem center; padding-right:2.4rem; cursor:pointer; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--brass); background:#0c1115; }
.field input:user-invalid,.field input.invalid{ border-color:#c46a5a; }
.form__submit{ margin-top:.5rem; justify-self:start; min-width:200px; }
.form__status{ font-size:.92rem; min-height:1.2em; margin:0; }
.form__status.is-ok{ color:var(--brass-soft); }
.form__status.is-err{ color:#e0917f; }
.form.is-sent .field,.form.is-sent .form__submit{ display:none; }
.form.is-sent .form__status{ font-family:var(--serif); font-size:1.4rem; line-height:1.4; }

/* ---------- FOOTER ---------- */
.footer{ background:var(--ink); border-top:1px solid var(--hair); padding:clamp(3rem,7vh,5rem) var(--gut) 2.5rem; }
.footer__top{ max-width:var(--maxw); margin:0 auto; display:flex; flex-wrap:wrap; justify-content:space-between; gap:2rem; padding-bottom:2.5rem; border-bottom:1px solid var(--hair); }
.footer__mark{ font-family:var(--serif); font-size:2rem; letter-spacing:.2em; display:block; }
.footer__tag{ font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; color:var(--paper-mute); }
.footer__meta{ text-align:right; }
.footer__meta p{ margin:.2rem 0; color:var(--paper-dim); font-size:.92rem; }
.footer__meta a{ color:var(--brass-soft); }
.footer__bottom{ max-width:var(--maxw); margin:2rem auto 0; display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; font-size:.78rem; color:var(--paper-mute); letter-spacing:.04em; }
.footer__bottom a{ color:var(--paper-dim); }
.footer__bottom a:hover{ color:var(--brass); }

/* ---------- LIGHTBOX ---------- */
.lightbox{ position:fixed; inset:0; z-index:1100; background:rgba(7,9,11,.96); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:opacity .4s var(--ease), visibility .4s; }
.lightbox.is-open{ opacity:1; visibility:visible; }
.lightbox__stage{ margin:0; max-width:92vw; max-height:86vh; display:flex; flex-direction:column; align-items:center; gap:1rem; }
.lightbox__stage img{ max-width:92vw; max-height:80vh; object-fit:contain; border-radius:2px; box-shadow:0 30px 80px rgba(0,0,0,.6); }
.lightbox__count{ font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--paper-mute); }
.lightbox__close{ position:absolute; top:1.4rem; right:1.6rem; width:48px; height:48px; border:1px solid var(--hair); background:rgba(11,14,17,.5); color:var(--paper); border-radius:50%; cursor:pointer; font-size:1rem; transition:border-color .3s, background .3s; }
.lightbox__nav{ position:absolute; top:50%; transform:translateY(-50%); width:56px; height:56px; border:1px solid var(--hair); background:rgba(11,14,17,.5); color:var(--paper); border-radius:50%; cursor:pointer; font-size:1.8rem; line-height:0; transition:border-color .3s, background .3s; }
.lightbox__nav:hover,.lightbox__close:hover{ border-color:var(--brass); background:rgba(201,168,106,.12); }
.lightbox__nav--prev{ left:clamp(.8rem,3vw,2.5rem); }
.lightbox__nav--next{ right:clamp(.8rem,3vw,2.5rem); }

/* ============================================================
   SCROLL REVEAL (JS-gated start states)
   ============================================================ */
.js .reveal{ opacity:0; transform:translateY(34px); }
.js .reveal.is-in{ opacity:1; transform:none; transition:opacity .9s var(--ease), transform .9s var(--ease); }
.no-js .reveal{ opacity:1; transform:none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px){
  .nav__links{ display:none; }
  .deckmap__stage{ grid-template-columns:1fr; }
  .quotes__grid{ grid-template-columns:1fr; }
  .quote{ border-top:1px solid var(--hair-brass); }
}
@media (max-width:900px){
  .specs__grid{ grid-template-columns:repeat(3,1fr); }
  .toys{ grid-template-columns:1fr; }
  .toys__media img{ min-height:48vh; }
  .interior__grid{ grid-template-columns:1fr; }
  .room--tall{ grid-row:auto; }
  .room--tall .room__media img{ aspect-ratio:3/2; }
  .pricing__grid{ grid-template-columns:1fr; }
  .crew__members{ grid-template-columns:1fr; }
  .culinary{ grid-template-columns:1fr; }
  .enquire__inner{ grid-template-columns:1fr; }
  .gallery__grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px){
  .specs__grid{ grid-template-columns:repeat(2,1fr); }
  .toys__list{ columns:1; }
  .pricing__cols{ grid-template-columns:1fr; }
  .field--row{ grid-template-columns:1fr; }
  .member{ grid-template-columns:1fr; }
  .member__media{ width:140px; }
  .footer__meta{ text-align:left; }
  .gtile--wide{ grid-column:span 2; }
  .hero__title{ font-size:clamp(4rem,22vw,7rem); }
}

/* ============================================================
   REDUCED MOTION — kill the heavy stuff
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  .js .reveal{ opacity:1!important; transform:none!important; }
  .hero__media,.interstitial__media,.toys__media,.culinary__media{ position:absolute; inset:0; transform:none!important; }
  .interstitial__media,.hero__media{ inset:0; }
  *{ animation-duration:.001ms!important; animation-iteration-count:1!important; }
  .loader{ display:none!important; }
  .filmstrip__track{ transform:none!important; }
}
