/* =========================================================
   PANGEA · HORIZON
   Stealth-wealth horological / hypercar-terminal aesthetic
   Syne (display) + JetBrains Mono (data) · obsidian + cyan
   ========================================================= */

/* ---- Lenis scroll-correctness (mandatory) ---- */
html:not(.lenis){ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html:not(.lenis){ scroll-behavior:auto; } }
html.lenis{ scroll-behavior:auto !important; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-stopped{ overflow:hidden; }

/* ---- tokens ---- */
:root{
  --obsidian:#0B0C10;
  --obsidian-2:#0e1016;
  --gunmetal:#1F2833;
  --gunmetal-2:#171d25;
  --silver:#C5C6C7;
  --silver-dim:#8a8f93;
  --cyan:#66FCF1;
  --teal:#45A29E;
  --line:rgba(197,198,199,.12);
  --line-2:rgba(197,198,199,.20);
  --glass:rgba(31,40,51,.42);
  --shadow:0 24px 60px -28px rgba(0,0,0,.85);

  --pad:clamp(16px,4vw,40px);
  --gap:clamp(10px,1.4vw,18px);
  --radius:14px;
  --maxw:1360px;

  --ff-display:"Syne",-apple-system,system-ui,sans-serif;
  --ff-mono:"JetBrains Mono",ui-monospace,"SFMono-Regular",monospace;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ background:var(--obsidian); -webkit-text-size-adjust:100%; }
body{
  font-family:var(--ff-display);
  color:var(--silver);
  background:
    radial-gradient(120% 80% at 80% -10%, rgba(69,162,158,.10), transparent 55%),
    radial-gradient(90% 70% at 0% 10%, rgba(102,252,241,.05), transparent 50%),
    var(--obsidian);
  background-attachment:fixed;
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; }
button{ font:inherit; color:inherit; cursor:pointer; }

[data-mono]{ font-family:var(--ff-mono); }

.visually-hidden{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; }

.skip-link{
  position:fixed; left:12px; top:-60px; z-index:200;
  background:var(--cyan); color:#04201f; padding:10px 16px; border-radius:8px;
  font-family:var(--ff-mono); font-size:13px; text-decoration:none;
  transition:top .2s;
}
.skip-link:focus{ top:12px; }

:focus-visible{ outline:2px solid var(--cyan); outline-offset:3px; border-radius:4px; }

/* ============ LOADER ============ */
.loader{
  position:fixed; inset:0; z-index:300;
  background:var(--obsidian);
  display:grid; place-items:center;
  transition:opacity .6s ease, visibility .6s;
}
.loader.is-done{ opacity:0; visibility:hidden; pointer-events:none; }
.loader__inner{ display:grid; justify-items:center; gap:14px; }
.loader__mark{
  font-family:var(--ff-display); font-weight:800;
  font-size:clamp(34px,8vw,72px); letter-spacing:.14em;
  color:var(--silver);
}
.loader__sub{ font-size:11px; letter-spacing:.34em; color:var(--teal); }
.loader__bar{ width:min(260px,60vw); height:1px; background:var(--line-2); overflow:hidden; }
.loader__bar i{ display:block; height:100%; width:0; background:var(--cyan);
  box-shadow:0 0 12px var(--cyan); animation:load 1s ease forwards; }
@keyframes load{ to{ width:100%; } }

/* ============ TOPBAR ============ */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:120;
  display:flex; align-items:center; gap:16px;
  padding:14px var(--pad);
  background:linear-gradient(to bottom, rgba(11,12,16,.82), rgba(11,12,16,0));
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  transition:background .35s, border-color .35s;
  border-bottom:1px solid transparent;
}
.topbar.is-stuck{
  background:rgba(11,12,16,.78);
  border-bottom:1px solid var(--line);
}
.topbar__brand{ display:flex; flex-direction:column; line-height:1; text-decoration:none; margin-right:auto; }
.topbar__mark{ font-family:var(--ff-display); font-weight:800; letter-spacing:.2em; font-size:18px; color:var(--silver); }
.topbar__model{ font-size:9px; letter-spacing:.32em; color:var(--teal); margin-top:4px; }
.topbar__nav{ display:flex; gap:22px; }
.topbar__nav a{
  font-family:var(--ff-mono); font-size:11px; letter-spacing:.08em;
  color:var(--silver-dim); text-decoration:none; position:relative; padding:4px 0;
  transition:color .2s;
}
.topbar__nav a::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--cyan); transition:width .25s; }
.topbar__nav a:hover{ color:var(--silver); }
.topbar__nav a:hover::after{ width:100%; }
.topbar__cta{
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 16px; border:1px solid var(--line-2); border-radius:999px;
  text-decoration:none; color:var(--silver); font-size:12px;
  transition:border-color .25s, color .25s, box-shadow .25s, background .25s;
}
.topbar__cta:hover{ border-color:var(--cyan); color:var(--cyan); box-shadow:0 0 0 1px rgba(102,252,241,.25), 0 0 22px -6px rgba(102,252,241,.5); }
.topbar__cta svg{ transition:transform .25s; }
.topbar__cta:hover svg{ transform:translate(2px,-2px); }

@media (max-width:860px){ .topbar__nav{ display:none; } }

/* ============ DECK / LAYOUT ============ */
.deck{
  max-width:var(--maxw);
  margin:0 auto;
  padding:clamp(56px,8vh,120px) var(--pad);
  position:relative;
}
.deck__rail{
  display:flex; align-items:center; gap:14px;
  font-size:10px; letter-spacing:.3em; color:var(--silver-dim);
  margin-bottom:clamp(18px,3vw,34px); text-transform:uppercase;
}
.deck__rail span:first-child{ color:var(--cyan); }
.deck__rail::before{ content:""; width:30px; height:1px; background:var(--cyan); box-shadow:0 0 8px var(--cyan); }
.deck__rail::after{ content:""; flex:1; height:1px; background:var(--line); }

.kicker{
  display:inline-block; font-family:var(--ff-mono);
  font-size:11px; letter-spacing:.26em; text-transform:uppercase;
  color:var(--teal); margin-bottom:14px;
}
.cell__title{
  font-family:var(--ff-display); font-weight:800;
  font-size:clamp(26px,3.6vw,46px); line-height:1.04;
  letter-spacing:-.01em; margin:0 0 14px; color:var(--silver);
}
.cell__title--sm{ font-size:clamp(22px,2.4vw,30px); }
.cell__body{ font-size:clamp(15px,1.1vw,17px); color:var(--silver); opacity:.9; max-width:54ch; }

/* ============ BENTO BASE ============ */
.bento{ display:grid; gap:var(--gap); }
.cell{
  position:relative; border-radius:var(--radius);
  border:1px solid var(--line);
  background:var(--gunmetal-2);
  overflow:hidden;
  transition:border-color .35s, transform .45s cubic-bezier(.22,1,.36,1), box-shadow .45s, filter .35s;
}
.glass{
  background:var(--glass);
  backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
  border:1px solid var(--line-2);
}
.cell--accent{ border-color:rgba(102,252,241,.35); box-shadow:inset 0 0 0 1px rgba(102,252,241,.06); }

/* metallic edge highlight */
.cell::before{
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:linear-gradient(135deg, rgba(255,255,255,.07), transparent 30%, transparent 70%, rgba(255,255,255,.03));
  opacity:.7;
}

/* media cells */
.cell--photo, .cell--space, .cell--crewp, .cell--herofig{ padding:0; }
.cell__media{ width:100%; height:100%; object-fit:cover; }
.cell--photo .cell__media, .cell--space .cell__media{ aspect-ratio:4/3; }
.cell--tall .cell__media{ aspect-ratio:3/4; }

.photo__tag{
  position:absolute; left:12px; bottom:12px; z-index:2;
  font-family:var(--ff-mono); font-size:10px; letter-spacing:.14em;
  padding:5px 10px; border-radius:999px;
  background:rgba(11,12,16,.6); backdrop-filter:blur(6px);
  border:1px solid var(--line-2); color:var(--silver);
}

.space__copy{
  position:absolute; inset:auto 0 0 0; z-index:2; padding:18px 16px 16px;
  background:linear-gradient(to top, rgba(11,12,16,.92), rgba(11,12,16,.55) 60%, transparent);
}
.space__lbl{ display:block; font-size:11px; letter-spacing:.2em; color:var(--cyan); margin-bottom:6px; text-transform:uppercase; }
.space__copy p{ margin:0; font-size:14px; color:var(--silver); max-width:42ch; }

/* photo hover */
.cell--photo .cell__media, .cell--space .cell__media, .cell--crewp .cell__media{ transition:transform .8s cubic-bezier(.22,1,.36,1), filter .5s; }
@media (hover:hover){
  .cell--photo:hover .cell__media, .cell--space:hover .cell__media, .cell--crewp:hover .cell__media{ transform:scale(1.045); }
}

/* ============ HERO ============ */
.deck--hero{ max-width:var(--maxw); padding-top:clamp(96px,16vh,180px); min-height:100vh; display:flex; flex-direction:column; justify-content:center; }
.bento--hero{
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto;
}
.cell--herofig{ grid-column:1 / 4; min-height:min(70vh,640px); display:flex; }
.cell--herofig .cell__media{ position:absolute; inset:0; }
.herofig__grain{ position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(to top, rgba(11,12,16,.9), rgba(11,12,16,.25) 45%, rgba(11,12,16,.55) 100%),
    radial-gradient(140% 100% at 20% 100%, rgba(11,12,16,.7), transparent 60%);
}
.herofig__copy{ position:relative; z-index:2; margin-top:auto; padding:clamp(22px,4vw,48px); max-width:760px; }
.hero__title{
  font-family:var(--ff-display); font-weight:800;
  font-size:clamp(64px,15vw,180px); line-height:.86; margin:.06em 0 .18em;
  letter-spacing:-.03em; color:#fff;
  text-shadow:0 2px 40px rgba(0,0,0,.5);
}
.hero__sub{ font-size:clamp(16px,1.5vw,20px); max-width:46ch; color:var(--silver); opacity:.92; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:12px; margin-top:26px; }
.herofig__coords{
  position:absolute; top:clamp(16px,3vw,28px); right:clamp(16px,3vw,28px); z-index:2;
  display:flex; gap:14px; font-size:11px; letter-spacing:.14em; color:var(--cyan);
  background:rgba(11,12,16,.45); padding:7px 12px; border-radius:999px; border:1px solid var(--line-2);
}

.cell--metric{
  display:flex; flex-direction:column; justify-content:space-between; gap:10px;
  padding:clamp(16px,2vw,24px); min-height:140px;
}
.metric__k{ font-size:10px; letter-spacing:.3em; color:var(--silver-dim); }
.metric__v{ display:flex; align-items:baseline; gap:6px; }
.metric__v b{ font-family:var(--ff-mono); font-weight:700; font-size:clamp(30px,4vw,52px); color:var(--silver); font-variant-numeric:tabular-nums; letter-spacing:-.02em; }
.cell--accent .metric__v b{ color:var(--cyan); text-shadow:0 0 24px rgba(102,252,241,.4); }
.metric__v i{ font-style:normal; font-size:13px; color:var(--silver-dim); }
.metric__l{ font-size:10px; letter-spacing:.16em; color:var(--silver-dim); text-transform:uppercase; }

.scrollcue{ display:flex; align-items:center; gap:10px; margin-top:26px; font-size:10px; letter-spacing:.3em; color:var(--silver-dim); }
.scrollcue i{ width:1px; height:28px; background:linear-gradient(var(--cyan),transparent); animation:cue 1.8s ease-in-out infinite; }
@keyframes cue{ 0%,100%{ opacity:.3; transform:scaleY(.6); } 50%{ opacity:1; transform:scaleY(1); } }

/* ============ EXPERIENCE ============ */
.bento--exp{ grid-template-columns:repeat(12,1fr); grid-auto-rows:minmax(80px,auto); }
.cell--exp{ grid-column:span 7; padding:clamp(22px,3vw,40px); display:flex; flex-direction:column; }
.cell--exp .cell__body{ margin-top:auto; }
.cell--exp .cell__expand, .cell--photo .cell__expand{ display:none; }
.cell--specs{ grid-column:span 5; padding:clamp(20px,2.4vw,32px); }
.bento--exp .cell--photo:nth-of-type(2){ grid-column:span 5; }
.bento--exp .cell--wide{ grid-column:span 7; }

.specs{ margin:6px 0 14px; display:grid; gap:0; }
.spec{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; padding:11px 0; border-bottom:1px solid var(--line); }
.spec:last-child{ border-bottom:0; }
.spec dt{ font-size:11px; letter-spacing:.14em; color:var(--silver-dim); text-transform:uppercase; }
.spec dd{ margin:0; display:flex; align-items:baseline; gap:5px; }
.spec dd b{ font-family:var(--ff-mono); font-weight:700; font-size:clamp(20px,2.4vw,30px); color:var(--silver); font-variant-numeric:tabular-nums; }
.spec dd i{ font-style:normal; font-size:12px; color:var(--silver-dim); }
.spec--hi dd b{ color:var(--cyan); text-shadow:0 0 20px rgba(102,252,241,.35); }
.specs__line{ display:block; font-size:11px; letter-spacing:.1em; color:var(--silver-dim); padding-top:6px; border-top:1px solid var(--line); }

/* ============ WHY ============ */
.bento--why{ grid-template-columns:repeat(6,1fr); }
.cell--whyhead{ grid-column:span 6; padding:clamp(22px,3vw,40px); }
.cell--why{ grid-column:span 2; padding:clamp(18px,2vw,26px); display:flex; flex-direction:column; gap:8px; min-height:200px; }
.why__n{ font-size:12px; color:var(--cyan); letter-spacing:.2em; }
.why__t{ font-family:var(--ff-display); font-weight:700; font-size:clamp(18px,1.5vw,22px); margin:6px 0 0; color:var(--silver); }
.why__b{ margin:0; font-size:14px; color:var(--silver); opacity:.82; }
.cell--why::after{
  content:attr(data-spec); position:absolute; left:0; right:0; bottom:0;
  font-family:var(--ff-mono); font-size:10px; letter-spacing:.14em; color:var(--cyan);
  background:linear-gradient(to top, rgba(11,12,16,.9), transparent);
  padding:14px 18px 10px; transform:translateY(110%); transition:transform .35s ease; pointer-events:none;
}
@media (hover:hover){
  .bento--why:hover .cell--why{ filter:saturate(.7) brightness(.78); }
  .bento--why .cell--why:hover{ filter:none; transform:translateY(-4px); border-color:var(--cyan); box-shadow:0 0 0 1px rgba(102,252,241,.2),var(--shadow); }
  .bento--why .cell--why:hover::after{ transform:translateY(0); }
}
@media (max-width:560px){ .cell--why::after{ display:none; } }

/* ============ ON DECK + DECK MAP ============ */
.bento--deck{ grid-template-columns:repeat(4,1fr); }
.cell--deckmap{ grid-column:span 4; padding:clamp(20px,2.6vw,34px); }
.deckmap__head{ margin-bottom:18px; }
.deckmap__hint{ display:block; font-size:11px; letter-spacing:.18em; color:var(--silver-dim); }
.deckmap{ display:grid; grid-template-columns:1.6fr 1fr; gap:var(--gap); align-items:start; }
.deckmap__stage{ position:relative; border-radius:10px; overflow:hidden; border:1px solid var(--line); background:#000; }
.deckmap__img{ width:100%; aspect-ratio:3/2; object-fit:cover; opacity:.92; }
.hot{
  position:absolute; transform:translate(-50%,-50%);
  background:none; border:0; padding:0; display:flex; align-items:center; gap:8px;
}
.hot__dot{
  width:16px; height:16px; border-radius:50%;
  background:rgba(102,252,241,.18); border:1.5px solid var(--cyan);
  position:relative; flex:none;
}
.hot__dot::after{ content:""; position:absolute; inset:0; border-radius:50%; box-shadow:0 0 0 0 rgba(102,252,241,.5); animation:pulse 2.4s ease-out infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(102,252,241,.5);} 70%{ box-shadow:0 0 0 12px rgba(102,252,241,0);} 100%{ box-shadow:0 0 0 0 rgba(102,252,241,0);} }
.hot__lbl{
  font-family:var(--ff-mono); font-size:10px; letter-spacing:.08em; white-space:nowrap;
  padding:4px 8px; border-radius:6px; background:rgba(11,12,16,.78); border:1px solid var(--line-2); color:var(--silver);
  opacity:0; transform:translateX(-4px); transition:opacity .2s, transform .2s; pointer-events:none;
}
.hot:hover .hot__lbl, .hot:focus-visible .hot__lbl, .hot.is-active .hot__lbl{ opacity:1; transform:translateX(0); }
.hot.is-active .hot__dot{ background:var(--cyan); box-shadow:0 0 18px var(--cyan); }
.deckmap__panel{ border:1px solid var(--line); border-radius:10px; overflow:hidden; background:var(--gunmetal-2); }
.deckmap__photo{ width:100%; aspect-ratio:4/3; object-fit:cover; }
.deckmap__pcopy{ padding:14px 16px; }
.deckmap__plbl{ display:block; font-size:11px; letter-spacing:.18em; color:var(--cyan); text-transform:uppercase; margin-bottom:6px; }
.deckmap__pdesc{ margin:0; font-size:14px; color:var(--silver); opacity:.88; }
.deckmap__list{ display:none; list-style:none; margin:16px 0 0; padding:0; }
.deckmap__list li{ font-size:12px; padding:10px 0; border-bottom:1px solid var(--line); color:var(--silver); }
.deckmap__list b{ color:var(--cyan); font-weight:500; }

.bento--deck .cell--space{ grid-column:span 1; }
@media (max-width:900px){ .bento--deck .cell--space{ grid-column:span 2; } }

/* ============ TOYS ============ */
.bento--toys{ grid-template-columns:repeat(6,1fr); }
.cell--toyshead{ grid-column:span 6; padding:clamp(22px,3vw,40px); }
.toys__list{ list-style:none; margin:18px 0 0; padding:0; display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:0 24px; }
.toys__list li{ display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid var(--line); font-size:15px; color:var(--silver); }
.toys__list li span{ color:var(--teal); font-size:11px; letter-spacing:.1em; }
.bento--toys .cell--photo{ grid-column:span 3; }
.bento--toys .cell--wide{ grid-column:span 6; }
@media (max-width:900px){ .bento--toys .cell--photo, .bento--toys .cell--wide{ grid-column:span 6; } }

/* ============ INTERIOR ============ */
.bento--interior{ grid-template-columns:repeat(6,1fr); }
.cell--inthead{ grid-column:span 6; padding:clamp(22px,3vw,40px); }
.bento--interior .cell--tall{ grid-column:span 2; grid-row:span 2; }
.bento--interior .cell--wide{ grid-column:span 4; }
.bento--interior .cell--photo:not(.cell--wide){ grid-column:span 2; }
@media (max-width:900px){ .bento--interior .cell--tall, .bento--interior .cell--wide, .bento--interior .cell--photo:not(.cell--wide){ grid-column:span 3; grid-row:auto; } }

/* ============ PRICING ============ */
.bento--price{ grid-template-columns:repeat(4,1fr); align-items:start; }
.cell--rate{ grid-column:span 2; grid-row:span 2; padding:clamp(24px,3vw,42px); display:flex; flex-direction:column; gap:14px; }
.rate__from{ font-family:var(--ff-display); font-weight:700; font-size:clamp(22px,2.4vw,30px); margin:6px 0 0; color:var(--silver); }
.rate__from b{ color:var(--cyan); font-size:1.15em; text-shadow:0 0 28px rgba(102,252,241,.35); }
.rate__from span{ font-size:13px; color:var(--silver-dim); margin-left:6px; }
.rate__note{ font-size:11px; color:var(--silver-dim); margin:0; }
.rate__line{ margin:0; font-size:13.5px; color:var(--silver); opacity:.88; padding-left:16px; border-left:2px solid var(--teal); }
.rate__line b{ display:inline-block; color:var(--cyan); margin-right:6px; letter-spacing:.06em; }
.rate__season{ margin-top:6px; padding-top:18px; border-top:1px solid var(--line); }
.rate__season p{ margin:6px 0 0; font-size:13.5px; color:var(--silver); opacity:.88; }
.cell--rate .btn{ margin-top:auto; align-self:flex-start; }
.cell--incl{ grid-column:span 2; padding:clamp(20px,2.4vw,30px); }
.incl__h{ display:block; font-size:11px; letter-spacing:.2em; color:var(--silver-dim); text-transform:uppercase; margin-bottom:12px; }
.incl{ list-style:none; margin:0; padding:0; }
.incl li{ position:relative; padding:9px 0 9px 26px; font-size:14px; border-bottom:1px solid var(--line); color:var(--silver); }
.incl li:last-child{ border-bottom:0; }
.incl li::before{ position:absolute; left:0; top:9px; font-family:var(--ff-mono); font-size:13px; }
.incl--yes li::before{ content:"+"; color:var(--cyan); }
.incl--no li::before{ content:"−"; color:var(--silver-dim); }
@media (max-width:900px){ .cell--rate{ grid-column:span 4; grid-row:auto; } .cell--incl{ grid-column:span 4; } }

/* ============ CREW ============ */
.bento--crew{ grid-template-columns:repeat(4,1fr); }
.cell--crewhead{ grid-column:span 4; padding:clamp(22px,3vw,40px); }
.cell--crewp{ grid-column:span 1; }
.cell--crewp .cell__media{ aspect-ratio:3/4; }
.crewp__copy{ position:absolute; inset:auto 0 0 0; padding:18px 16px 16px; background:linear-gradient(to top, rgba(11,12,16,.95), rgba(11,12,16,.4) 70%, transparent); }
.crewp__role{ font-size:10px; letter-spacing:.22em; color:var(--cyan); text-transform:uppercase; }
.crewp__name{ font-family:var(--ff-display); font-weight:800; font-size:24px; margin:4px 0 8px; color:#fff; }
.crewp__bio{ margin:0 0 8px; font-size:13px; color:var(--silver); opacity:.9; }
.crewp__creds{ font-size:10px; letter-spacing:.06em; color:var(--silver-dim); line-height:1.6; }
.cell--culinary{ grid-column:span 2; padding:clamp(22px,2.6vw,34px); }
.cell--testi{ grid-column:span 4; padding:clamp(22px,2.6vw,34px); display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,34px); }
.testi{ margin:0; }
.testi p{ font-family:var(--ff-display); font-weight:600; font-size:clamp(15px,1.3vw,18px); line-height:1.4; color:var(--silver); margin:0 0 12px; }
.testi cite{ font-style:normal; font-size:10px; letter-spacing:.12em; color:var(--teal); }
@media (max-width:900px){
  .cell--crewp{ grid-column:span 2; }
  .cell--culinary{ grid-column:span 4; }
  .cell--testi{ grid-template-columns:1fr; gap:22px; }
}

/* ============ GALLERY ============ */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--gap); grid-auto-rows:1fr; }
.gallery__item{ position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); background:var(--gunmetal-2); padding:0; aspect-ratio:1; }
.gallery__item.is-wide{ grid-column:span 2; aspect-ratio:2/1; }
.gallery__item img{ width:100%; height:100%; object-fit:cover; transition:transform .7s cubic-bezier(.22,1,.36,1), filter .4s; filter:saturate(.9); }
.gallery__item::after{ content:"⤢"; position:absolute; right:10px; bottom:10px; font-family:var(--ff-mono); font-size:14px; color:var(--cyan); opacity:0; transition:opacity .25s; }
@media (hover:hover){
  .gallery__item:hover img{ transform:scale(1.06); filter:saturate(1.05); }
  .gallery__item:hover::after{ opacity:1; }
}
@media (max-width:900px){ .gallery{ grid-template-columns:repeat(2,1fr); } .gallery__item.is-wide{ grid-column:span 2; } }

/* ============ ENQUIRE ============ */
.deck--enquire{ padding-bottom:clamp(70px,10vh,140px); }
.bento--enquire{ grid-template-columns:repeat(2,1fr); align-items:stretch; }
.cell--enqcopy{ padding:clamp(24px,3vw,44px); display:flex; flex-direction:column; }
.enq__reassure{ font-size:12px; color:var(--silver-dim); border-left:2px solid var(--teal); padding-left:14px; margin:6px 0 0; max-width:44ch; }
.enq__coords{ margin-top:auto; padding-top:24px; display:flex; flex-direction:column; gap:8px; font-size:11px; letter-spacing:.16em; color:var(--cyan); }
.cell--enqform{ padding:clamp(24px,3vw,40px); }
.field{ margin-bottom:16px; }
.field--row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field label{ display:block; font-family:var(--ff-mono); font-size:11px; letter-spacing:.1em; color:var(--silver-dim); margin-bottom:7px; }
.field label i{ color:var(--cyan); font-style:normal; }
.field input, .field select, .field textarea{
  width:100%; padding:12px 14px; font:inherit; font-size:15px;
  background:var(--obsidian-2); color:var(--silver);
  border:1px solid var(--line-2); border-radius:9px; outline:none;
  transition:border-color .25s, box-shadow .25s;
}
.field textarea{ resize:vertical; }
.field select{ font-family:var(--ff-mono); font-size:13px; }
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--cyan); box-shadow:0 0 0 1px rgba(102,252,241,.3); }
.field input:invalid:not(:placeholder-shown){ border-color:#c0564f; }
.field.is-error input{ border-color:#c0564f; box-shadow:0 0 0 1px rgba(192,86,79,.3); }
.enq__err{ color:#e08a84; font-size:13px; margin:0 0 12px; font-family:var(--ff-mono); }
.enq__note{ font-size:11px; color:var(--silver-dim); text-align:center; margin:12px 0 0; }
.enq__success{ margin-top:18px; text-align:center; padding:22px; border:1px solid rgba(102,252,241,.3); border-radius:10px; background:rgba(102,252,241,.05); }
.enq__tick{ display:inline-grid; place-items:center; width:42px; height:42px; border-radius:50%; background:var(--cyan); color:#04201f; font-size:20px; margin-bottom:10px; }
.enq__success p{ margin:0; color:var(--silver); }
@media (max-width:760px){ .bento--enquire{ grid-template-columns:1fr; } }

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex; align-items:center; gap:8px; text-decoration:none;
  padding:13px 24px; border-radius:999px; font-family:var(--ff-mono);
  font-size:13px; letter-spacing:.08em; border:1px solid transparent;
  transition:transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s, background .25s, color .25s, border-color .25s;
}
.btn--primary{ background:var(--cyan); color:#04201f; box-shadow:0 0 30px -8px rgba(102,252,241,.6); }
.btn--primary:hover{ box-shadow:0 0 0 1px rgba(102,252,241,.5),0 0 40px -6px rgba(102,252,241,.85); transform:translateY(-2px); }
.btn--ghost{ border-color:var(--line-2); color:var(--silver); }
.btn--ghost:hover{ border-color:var(--cyan); color:var(--cyan); }
.btn--block{ width:100%; justify-content:center; padding:15px; }

/* ============ FOOTER ============ */
.footer{ border-top:1px solid var(--line); margin-top:40px; padding:clamp(32px,5vw,56px) var(--pad); }
.footer__grid{ max-width:var(--maxw); margin:0 auto; display:flex; flex-wrap:wrap; align-items:center; gap:10px 28px; }
.footer__brand{ font-family:var(--ff-display); font-weight:800; letter-spacing:.22em; font-size:18px; color:var(--silver); margin-right:auto; }
.footer p{ margin:0; font-size:11px; letter-spacing:.06em; color:var(--silver-dim); }
.footer a{ color:var(--teal); text-decoration:none; }
.footer a:hover{ color:var(--cyan); }

/* ============ LIGHTBOX ============ */
.lightbox{ position:fixed; inset:0; z-index:250; display:grid; place-items:center; background:rgba(6,7,10,.94); backdrop-filter:blur(8px); }
.lightbox[hidden]{ display:none; }
.lightbox__fig{ margin:0; max-width:92vw; max-height:84vh; }
.lightbox__fig img{ max-width:92vw; max-height:84vh; object-fit:contain; border:1px solid var(--line-2); border-radius:8px; }
.lightbox__close, .lightbox__nav{ position:absolute; background:rgba(31,40,51,.6); border:1px solid var(--line-2); color:var(--silver); width:48px; height:48px; border-radius:50%; font-size:22px; display:grid; place-items:center; transition:border-color .2s, color .2s; }
.lightbox__close:hover, .lightbox__nav:hover{ border-color:var(--cyan); color:var(--cyan); }
.lightbox__close{ top:18px; right:18px; }
.lightbox__nav--prev{ left:18px; top:50%; transform:translateY(-50%); }
.lightbox__nav--next{ right:18px; top:50%; transform:translateY(-50%); }
.lightbox__count{ position:absolute; bottom:18px; left:50%; transform:translateX(-50%); font-size:11px; letter-spacing:.2em; color:var(--silver-dim); }
@media (max-width:600px){ .lightbox__nav{ width:42px; height:42px; } }

/* ============ FLIP expand ============ */
.cell.is-flipped{
  position:fixed; z-index:240; margin:0;
  box-shadow:0 40px 120px -30px rgba(0,0,0,.9);
  overflow:auto;
}
.cell.is-flipped.cell--photo, .cell.is-flipped.cell--space, .cell.is-flipped.cell--crewp{ overflow:hidden; }
.cell.is-flipped .cell__media{ height:100%; }
.flip-backdrop{ position:fixed; inset:0; z-index:235; background:rgba(6,7,10,.8); backdrop-filter:blur(6px); opacity:0; transition:opacity .35s; }
.flip-backdrop.is-on{ opacity:1; }
.flip-close{ position:fixed; z-index:241; top:20px; right:20px; width:46px; height:46px; border-radius:50%; background:rgba(31,40,51,.7); border:1px solid var(--line-2); color:var(--silver); font-size:20px; display:none; place-items:center; }
.flip-close.is-on{ display:grid; }
.flip-close:hover{ border-color:var(--cyan); color:var(--cyan); }
.cell--exp.is-flipped .cell__expand, .cell--photo.is-flipped .cell__expand{ display:none; }
.cell--exp .cell__expand{
  display:inline-flex; align-items:center; gap:7px; align-self:flex-start; margin-top:18px;
  background:none; border:1px solid var(--line-2); border-radius:999px; padding:8px 14px;
  font-family:var(--ff-mono); font-size:11px; letter-spacing:.12em; color:var(--silver-dim);
  transition:border-color .2s,color .2s;
}
.cell--exp .cell__expand:hover{ border-color:var(--cyan); color:var(--cyan); }

/* ============ REVEAL (JS-gated) ============ */
.js [data-reveal]{ opacity:0; transform:translateY(22px); }
.js [data-reveal].is-in{ opacity:1; transform:none; transition:opacity .7s ease, transform .7s cubic-bezier(.22,1,.36,1); }

/* ============ RESPONSIVE BENTO COLLAPSE ============ */
@media (max-width:900px){
  .bento--hero{ grid-template-columns:1fr 1fr; }
  .cell--herofig{ grid-column:1 / 3; }
  .cell--metric:last-child{ grid-column:1 / 3; }

  .bento--exp{ grid-template-columns:1fr 1fr; }
  .cell--exp, .cell--specs, .bento--exp .cell--photo:nth-of-type(2), .bento--exp .cell--wide{ grid-column:1 / 3; }

  .bento--why{ grid-template-columns:1fr 1fr; }
  .cell--whyhead{ grid-column:1 / 3; }
  .cell--why{ grid-column:span 1; }

  .deckmap{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  :root{ --gap:10px; }
  .bento--hero, .bento--exp, .bento--why{ grid-template-columns:1fr; }
  .cell--herofig, .cell--metric:last-child, .cell--exp, .cell--specs,
  .bento--exp .cell--photo:nth-of-type(2), .bento--exp .cell--wide,
  .cell--whyhead, .cell--why{ grid-column:1 / -1; }
  .gallery{ grid-template-columns:1fr; }
  .gallery__item.is-wide{ grid-column:1 / -1; }
  .field--row{ grid-template-columns:1fr; }
  .toys__list{ grid-template-columns:1fr; }
  /* deck map → list fallback on small screens */
  .deckmap{ display:none; }
  .deckmap__list{ display:block; }
}

/* ============ REDUCED MOTION ============ */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .js [data-reveal]{ opacity:1 !important; transform:none !important; }
  .loader{ display:none !important; }
  .hot__dot::after{ animation:none; }
  .scrollcue i{ animation:none; }
}
