/* ============================================================
   MAZE — Cinematic Showcase
   Design system + layout + graceful asset fallbacks
   ============================================================ */

/* ---------- Tokens ---------- */
:root {
  --ink:        #0A0A0B;
  --ink-2:      #101012;
  --ink-3:      #15151a;
  --paper:      #F4F1EA;
  --paper-dim:  rgba(244, 241, 234, 0.64);
  --paper-faint:rgba(244, 241, 234, 0.34);
  --gold:       #C8A96A;
  --gold-bright:#E4CE9C;
  --gold-deep:  #8a7038;
  --line:       rgba(244, 241, 234, 0.14);
  --line-soft:  rgba(244, 241, 234, 0.08);

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

  --ease:      cubic-bezier(.16, 1, .3, 1);   /* signature expo-out */
  --ease-soft: cubic-bezier(.33, 1, .68, 1);

  --margin: clamp(1.5rem, 6vw, 9rem);
  --maxw: 1680px;

  --grain: 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='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-text);
  font-weight: 400;
  line-height: 1.6;
  font-size: clamp(1rem, 0.92rem + 0.35vw, 1.18rem);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
body.is-locked { overflow: hidden; height: 100vh; }
img, video, canvas { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
::selection { background: var(--gold); color: var(--ink); }

/* hide native cursor only when custom cursor active (desktop) */
body.cursor-on, body.cursor-on a, body.cursor-on button { cursor: none; }

/* ---------- Shared type ---------- */
.display { font-family: var(--font-display); font-weight: 380; line-height: 0.98; letter-spacing: -0.01em; }
.eyebrow {
  font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.26em;
  color: var(--gold); font-weight: 500;
}
.shell { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--margin); }

.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* cursor comet-trail (canvas overlay, glows via canvas 'lighter' compositing) */
.trail { position: fixed; inset: 0; z-index: 880; pointer-events: none; }

/* focus + skip link (a11y) */
:focus-visible { outline: 2px solid var(--gold); outline-offset: 4px; border-radius: 2px; }
.skip-link {
  position: fixed; top: 0; left: 50%; transform: translate(-50%, -120%);
  background: var(--gold); color: var(--ink); padding: 0.6rem 1.2rem; z-index: 1000;
  font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase; transition: transform .3s var(--ease);
}
.skip-link:focus { transform: translate(-50%, 0.6rem); }

/* film grain over everything */
body::after {
  content: ""; position: fixed; inset: 0; z-index: 900; pointer-events: none;
  background-image: var(--grain); background-size: 160px 160px;
  opacity: 0.05; mix-blend-mode: overlay;
}

/* ============================================================
   MEDIA + FALLBACK SYSTEM
   .media holds an animated CSS-gradient fallback by default;
   JS injects <video>/<img> and adds .is-loaded once it decodes.
   ============================================================ */
.media { position: relative; overflow: hidden; background: var(--ink-2); isolation: isolate; }
.media > video, .media > img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; opacity: 1; z-index: 2;  /* visible at rest — sits on top of the fallback */
}
/* the cosmetic fade is the fallback dissolving UNDER the (always-opaque) media,
   so if a transition is ever paused the image is still fully visible */
.media__fallback {
  position: absolute; inset: 0; z-index: 1; opacity: 1;
  transition: opacity 1s var(--ease);
  background:
    radial-gradient(120% 120% at 70% 18%, rgba(200,169,106,.22), transparent 55%),
    radial-gradient(90% 90% at 18% 88%, rgba(200,169,106,.10), transparent 60%),
    linear-gradient(135deg, #0d0d10 0%, #08080a 60%, #050506 100%);
}
.media.is-loaded .media__fallback { opacity: 0; }
/* slow drift + grain on every fallback */
.media__fallback::before {
  content: ""; position: absolute; inset: -25%;
  background:
    radial-gradient(40% 55% at 30% 40%, rgba(228,206,156,.16), transparent 70%),
    radial-gradient(35% 45% at 75% 65%, rgba(138,112,56,.18), transparent 70%);
  filter: blur(8px);
  animation: drift 26s var(--ease-soft) infinite alternate;
}
.media__fallback::after {
  content: ""; position: absolute; inset: 0;
  background-image: var(--grain); background-size: 150px 150px;
  opacity: 0.06; mix-blend-mode: overlay;
}
@keyframes drift {
  0%   { transform: translate3d(-4%, -2%, 0) scale(1.05) rotate(0deg); }
  100% { transform: translate3d(5%, 4%, 0) scale(1.18) rotate(6deg); }
}

/* themed fallbacks — keep the gallery cohesive but distinct */
.media[data-theme="hero"]    .media__fallback { background:
  radial-gradient(130% 120% at 62% 12%, rgba(228,206,156,.30), transparent 52%),
  radial-gradient(80% 90% at 12% 95%, rgba(138,112,56,.20), transparent 60%),
  linear-gradient(160deg, #14110c 0%, #0a0a0c 55%, #060607 100%); }
.media[data-theme="watch"]   .media__fallback { background:
  radial-gradient(120% 120% at 70% 30%, rgba(186,196,210,.18), transparent 55%),
  linear-gradient(150deg, #0e1014 0%, #08090b 70%); }
.media[data-theme="hotel"]   .media__fallback { background:
  radial-gradient(120% 120% at 60% 25%, rgba(206,156,92,.28), transparent 55%),
  linear-gradient(150deg, #14100a 0%, #0a0807 70%); }
.media[data-theme="couture"] .media__fallback { background:
  radial-gradient(120% 120% at 65% 20%, rgba(228,206,156,.32), transparent 50%),
  linear-gradient(150deg, #120f0c 0%, #080708 70%); }
.media[data-theme="winery"]  .media__fallback { background:
  radial-gradient(120% 120% at 60% 30%, rgba(150,42,52,.30), transparent 55%),
  linear-gradient(150deg, #160b0d 0%, #0a0708 70%); }
.media[data-theme="ev"]      .media__fallback { background:
  radial-gradient(120% 120% at 70% 25%, rgba(120,140,168,.20), transparent 55%),
  linear-gradient(150deg, #0c0e12 0%, #070809 70%); }
.media[data-theme="perfume"] .media__fallback { background:
  radial-gradient(120% 120% at 62% 28%, rgba(212,170,104,.30), transparent 55%),
  linear-gradient(150deg, #131009 0%, #090807 70%); }
.media[data-theme="avatar"]  .media__fallback { background:
  radial-gradient(90% 90% at 50% 32%, rgba(228,206,156,.26), transparent 60%),
  linear-gradient(180deg, #14110c 0%, #08080a 75%); }
.media[data-theme="engine"]  .media__fallback { background:
  radial-gradient(120% 120% at 55% 30%, rgba(200,169,106,.22), transparent 55%),
  linear-gradient(150deg, #0f0d0a 0%, #070708 70%); }

/* ============================================================
   LOADER
   ============================================================ */
.loader { position: fixed; inset: 0; z-index: 950; display: grid; place-items: center; background: var(--ink); }
.loader__inner { text-align: center; }
.loader__word {
  display: block; font-family: var(--font-display); font-weight: 360;
  font-size: clamp(3rem, 12vw, 9rem); letter-spacing: 0.02em; line-height: 1;
  background: linear-gradient(100deg, var(--paper) 30%, var(--gold-bright) 50%, var(--paper) 70%);
  background-size: 220% 100%; -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: sheen 2s var(--ease) infinite;
}
.loader__sub {
  display: block; margin-top: 1rem; font-size: 0.7rem; letter-spacing: 0.32em;
  text-transform: uppercase; color: var(--paper-faint);
}
@keyframes sheen { 0% { background-position: 130% 0; } 100% { background-position: -30% 0; } }
.loader__curtain { position: absolute; inset: 0; background: var(--ink); transform-origin: top; }
.loader.is-done { pointer-events: none; }

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor {
  position: fixed; top: 0; left: 0; z-index: 940; pointer-events: none;
  transform: translate(-50%, -50%); display: none;
  width: 8px; height: 8px; align-items: center; justify-content: center;
  will-change: transform;
}
body.cursor-on .cursor { display: flex; }
.cursor__dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--gold);
  flex: 0 0 auto; border: 1.5px solid transparent; box-sizing: border-box;
  box-shadow: 0 0 0 1px rgba(10,10,11,.22), 0 0 10px rgba(200,169,106,.45);
  transition: width .32s var(--ease), height .32s var(--ease),
              background .32s var(--ease), border-color .32s var(--ease), box-shadow .32s var(--ease);
}
.cursor.is-hover .cursor__dot {
  width: 42px; height: 42px; background: transparent;
  border-color: var(--gold); box-shadow: 0 0 18px rgba(200,169,106,.3);
}
.cursor__label {
  position: absolute; font-family: var(--font-text); font-size: 0.58rem; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); white-space: nowrap;
  opacity: 0; transform: scale(.6); transition: opacity .25s var(--ease), transform .25s var(--ease);
}
.cursor.is-hover .cursor__label { opacity: 1; transform: scale(1); }

/* ============================================================
   HUD — scroll progress + live section label
   ============================================================ */
.hud {
  position: fixed; left: var(--margin); bottom: clamp(1.2rem, 3vh, 2.4rem); z-index: 800;
  display: flex; align-items: center; gap: 0.8rem; font-size: 0.66rem;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--paper-dim);
  mix-blend-mode: difference; opacity: 0; transition: opacity .8s var(--ease);
}
.hud.is-visible { opacity: 1; }
.hud__index { color: var(--gold); font-weight: 600; }
.hud__bar { width: clamp(60px, 12vw, 140px); height: 1px; background: var(--line); position: relative; }
.hud__bar-fill { position: absolute; inset: 0; transform-origin: left; transform: scaleX(0); background: var(--gold); }

/* ============================================================
   ACCENT SWITCHER — recolour the whole site live
   ============================================================ */
.accent-switch {
  position: fixed; right: var(--margin); bottom: clamp(1.2rem, 3vh, 2.4rem); z-index: 806;
  display: flex; align-items: center; gap: 0.65rem;
  opacity: 0; transform: translateY(8px); pointer-events: none;
  transition: opacity .8s var(--ease), transform .8s var(--ease);
}
.accent-switch.is-visible { opacity: 1; transform: none; pointer-events: auto; }
.accent-switch__label { font-size: 0.6rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--paper-faint); }
.accent-dot {
  width: 16px; height: 16px; border-radius: 50%; border: 1px solid var(--line); background: var(--d);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}
.accent-dot:hover { transform: scale(1.25); }
.accent-dot.is-active { box-shadow: 0 0 0 2px var(--ink), 0 0 0 3px var(--paper); }
@media (max-width: 680px) { .accent-switch__label { display: none; } }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 820;
  display: flex; align-items: center; justify-content: space-between;
  padding: clamp(1rem, 2.4vw, 1.8rem) var(--margin);
  transition: transform .5s var(--ease), background .5s var(--ease), padding .5s var(--ease);
  mix-blend-mode: difference;
}
.nav.is-hidden { transform: translateY(-110%); }
.nav__logo { font-family: var(--font-display); font-size: 1.4rem; font-weight: 420; letter-spacing: 0.02em; display: inline-flex; align-items: center; gap: 0.5rem; }
.nav__logo-mark { color: var(--gold); font-size: 0.7em; }
.nav__links { display: flex; align-items: center; gap: clamp(1rem, 2.4vw, 2.6rem); }
.nav__links a { font-size: 0.82rem; letter-spacing: 0.04em; color: var(--paper); position: relative; }
.nav__links > a:not(.btn)::after {
  content: ""; position: absolute; left: 0; bottom: -4px; width: 100%; height: 1px;
  background: currentColor; transform: scaleX(0); transform-origin: right; transition: transform .5s var(--ease);
}
.nav__links > a:not(.btn):hover::after { transform: scaleX(1); transform-origin: left; }

/* ---------- Buttons ---------- */
.btn { display: inline-flex; align-items: center; justify-content: center; letter-spacing: 0.06em; }
.btn--ghost {
  border: 1px solid var(--line); padding: 0.6rem 1.2rem; border-radius: 100px; font-size: 0.78rem;
  transition: border-color .4s var(--ease), color .4s var(--ease);
}
.btn--ghost:hover { border-color: var(--gold); color: var(--gold); }
.btn--line { border-bottom: 1px solid var(--line); padding-bottom: 0.4rem; font-size: 0.86rem; letter-spacing: 0.1em; text-transform: uppercase; transition: border-color .4s var(--ease), color .4s var(--ease); }
.btn--line:hover { border-color: var(--gold); color: var(--gold); }
.btn--solid {
  background: var(--gold); color: var(--ink); padding: 0.8rem 1.6rem; border-radius: 100px;
  font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600;
  transition: background .4s var(--ease), transform .4s var(--ease);
}
.btn--solid:hover { background: var(--gold-bright); }

/* ============================================================
   1 · HERO
   ============================================================ */
.hero { position: relative; height: 100svh; min-height: 600px; overflow: hidden; }
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(to top, rgba(10,10,11,.95) 2%, rgba(10,10,11,.30) 36%, rgba(10,10,11,.12) 60%, rgba(10,10,11,.55) 100%),
    radial-gradient(120% 80% at 50% 120%, rgba(10,10,11,.8), transparent 60%);
}
.hero__content {
  position: absolute; left: 0; right: 0; bottom: clamp(5rem, 14vh, 9rem); z-index: 3;
}
.hero__title {
  font-size: clamp(3rem, 11vw, 12rem); line-height: 0.92; letter-spacing: -0.02em;
  max-width: 16ch; margin: 1.2rem 0 1.6rem; font-weight: 360;
}
.hero__sub { max-width: 40ch; color: var(--paper-dim); font-size: clamp(1rem, 1.2vw, 1.25rem); }
.hero__cue {
  position: absolute; right: var(--margin); bottom: clamp(2rem, 6vh, 3.5rem); z-index: 3;
  display: inline-flex; flex-direction: column; align-items: center; gap: 0.8rem;
  font-size: 0.64rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--paper-dim);
}
.hero__cue-line { width: 1px; height: 56px; background: linear-gradient(var(--gold), transparent); position: relative; overflow: hidden; }
.hero__cue-line::after { content: ""; position: absolute; top: -50%; left: 0; width: 100%; height: 50%; background: var(--gold-bright); animation: cue 2.2s var(--ease) infinite; }
@keyframes cue { 0% { transform: translateY(-100%); } 60%,100% { transform: translateY(300%); } }

/* SplitText line masks */
.split-line-mask { display: block; overflow: hidden; }
.split-line { display: block; }

/* ============================================================
   2 · MANIFESTO  (+ WebGL backdrop)
   ============================================================ */
.manifesto { position: relative; padding: clamp(8rem, 20vh, 16rem) 0; overflow: hidden; background: var(--ink); }
.manifesto .webgl { position: absolute; inset: 0; z-index: 0; width: 100%; height: 100%; opacity: 0; transition: opacity 1.2s var(--ease); }
.manifesto.webgl-on .webgl { opacity: 1; }
.manifesto__fallback {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(60% 80% at 30% 20%, rgba(200,169,106,.10), transparent 60%),
    radial-gradient(50% 70% at 80% 90%, rgba(138,112,56,.10), transparent 60%);
  animation: drift 32s var(--ease-soft) infinite alternate;
}
.manifesto.webgl-on .manifesto__fallback { opacity: 0.4; }
.manifesto .shell { position: relative; z-index: 2; }
.manifesto__statement {
  font-size: clamp(1.9rem, 6.4vw, 6rem); line-height: 1.04; max-width: 20ch; font-weight: 340;
}
.manifesto__statement .word { display: inline-block; opacity: 0.14; transition: opacity .35s var(--ease); }
.manifesto__statement .word.is-lit { opacity: 1; }

/* ============================================================
   ✦ · THE MEDIUM — interactive liquid-gold WebGL
   ============================================================ */
.medium { position: relative; height: 100svh; min-height: 560px; overflow: hidden; background: var(--ink); }
.medium__gl { position: absolute; inset: 0; width: 100%; height: 100%; display: block; z-index: 1; }
.medium__fallback {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(60% 70% at 50% 45%, rgba(200,169,106,.22), transparent 60%),
    radial-gradient(40% 50% at 75% 80%, rgba(138,112,56,.20), transparent 60%),
    linear-gradient(160deg, #14110c 0%, #08080a 70%);
  animation: drift 30s var(--ease-soft) infinite alternate;
}
.medium__content {
  position: absolute; inset: 0; z-index: 2; display: flex; flex-direction: column;
  justify-content: space-between; align-items: center; text-align: center;
  padding: clamp(5rem, 13vh, 9rem) var(--margin) clamp(3rem, 8vh, 5rem);
  pointer-events: none;
}
.medium__foot { display: flex; flex-direction: column; gap: 1rem; align-items: center; }
.medium__tag { max-width: 32ch; color: var(--paper); font-size: clamp(1rem, 1.8vw, 1.35rem); text-shadow: 0 2px 24px rgba(0,0,0,.65); }
.medium__hint {
  font-size: 0.66rem; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--paper-faint); transition: opacity .6s var(--ease);
}
.medium.is-touched .medium__hint { opacity: 0; }

/* ============================================================
   3 · CAPABILITIES / THE ENGINE
   ============================================================ */
.engine { padding: clamp(6rem, 14vh, 11rem) 0; border-top: 1px solid var(--line-soft); }
.engine__head { margin-bottom: clamp(3rem, 7vh, 6rem); }
.engine__title { font-size: clamp(1.8rem, 4.4vw, 3.6rem); max-width: 18ch; margin-top: 1.2rem; }
.engine__grid { display: grid; grid-template-columns: 1.3fr 0.7fr; gap: clamp(2rem, 5vw, 5rem); align-items: start; }
.engine__list { border-top: 1px solid var(--line); }
.engine__row {
  display: grid; grid-template-columns: auto 1fr; column-gap: 1.4rem; align-items: baseline;
  padding: clamp(1.2rem, 2.6vh, 2rem) 0; border-bottom: 1px solid var(--line);
  position: relative; transition: padding-left .5s var(--ease), color .5s var(--ease);
}
.engine__row::before {
  content: ""; position: absolute; left: -1.4rem; top: 50%; width: 6px; height: 6px; border-radius: 50%;
  background: var(--gold); transform: translateY(-50%) scale(0); transition: transform .5s var(--ease);
}
.engine__num { font-size: 0.7rem; letter-spacing: 0.2em; color: var(--paper-dim); grid-row: 1; }
.engine__name { font-size: clamp(1.6rem, 3.4vw, 3rem); grid-column: 2; transition: color .5s var(--ease); }
.engine__desc { grid-column: 2; color: var(--paper-dim); max-width: 46ch; font-size: 0.92rem; margin-top: 0.5rem; transition: color .5s var(--ease); max-height: 0; overflow: hidden; opacity: 0; transition: max-height .6s var(--ease), opacity .5s var(--ease), color .5s var(--ease); }
.engine__row.is-active { padding-left: 1.4rem; }
.engine__row.is-active::before { transform: translateY(-50%) scale(1); }
.engine__row.is-active .engine__name { color: var(--gold); }
.engine__row.is-active .engine__desc { max-height: 8rem; opacity: 1; }
@media (hover:none) { .engine__desc { max-height: 8rem; opacity: 1; } }

.engine__preview { position: sticky; top: 18vh; }
.engine__preview-media { aspect-ratio: 4 / 5; border: 1px solid var(--line-soft); background-size: cover; background-position: center; transition: background-image .4s var(--ease); }
.engine__preview-cap { display: block; margin-top: 1rem; font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--paper-faint); }

/* ============================================================
   4 · SELECTED WORK — pinned horizontal
   ============================================================ */
.work { background: var(--ink); position: relative; }
.work__intro { padding-top: clamp(5rem, 12vh, 9rem); padding-bottom: clamp(2rem, 5vh, 4rem); }
.work__heading { font-size: clamp(2rem, 6vw, 5rem); margin-top: 1rem; }
.work__viewport { position: relative; height: 100svh; overflow: hidden; display: flex; align-items: center; }
.work__track { display: flex; gap: clamp(1.5rem, 3vw, 3rem); padding: 0 var(--margin); width: max-content; will-change: transform; perspective: 1400px; }
.work__panel { width: clamp(280px, 42vw, 540px); flex: 0 0 auto; transform-style: preserve-3d; transition: transform .5s var(--ease); }
.work__media { aspect-ratio: 4 / 5; border: 1px solid var(--line-soft); margin-bottom: 1.4rem; }
/* cursor-following gold sheen on hover */
.work__media::after {
  content: ""; position: absolute; inset: 0; z-index: 5; pointer-events: none; opacity: 0;
  background: radial-gradient(240px circle at var(--mx, 50%) var(--my, 50%), rgba(228,206,156,.30), transparent 62%);
  transition: opacity .4s var(--ease);
}
.work__panel.is-tilt .work__media::after { opacity: 1; }
.work__client { font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); }
.work__name { font-size: clamp(1.6rem, 3vw, 2.6rem); margin: 0.6rem 0 0.5rem; }
.work__result { color: var(--paper-dim); max-width: 32ch; }
.work__metric { display: inline-block; margin-top: 1rem; font-size: 0.84rem; letter-spacing: 0.06em; color: var(--paper-dim); }
.work__metric b { font-family: var(--font-display); font-size: 1.5em; color: var(--paper); margin-right: 0.3em; font-weight: 420; }

/* fallback when horizontal pin is off (reduced motion / small screens) */
.work.is-static .work__viewport { height: auto; display: block; overflow: visible; padding-block: clamp(2rem, 5vh, 4rem); }
.work.is-static .work__track { flex-wrap: wrap; width: 100%; transform: none !important; gap: clamp(2rem, 5vw, 4rem); }
.work.is-static .work__panel { width: min(100%, 540px); }
/* mobile: everything stacks vertically — full-width panels, one under the other */
@media (max-width: 1024px) {
  .work.is-static .work__track { flex-direction: column; align-items: stretch; }
  .work.is-static .work__panel { width: 100%; }
}

/* ============================================================
   ✦ · THE PALETTE — live colour configurator
   ============================================================ */
/* Registered so var(--pick) resolves + transitions correctly when JS swaps it
   (an unregistered custom property + transition freezes at the old value in Chromium). */
@property --pick {
  syntax: "<color>";
  inherits: true;
  initial-value: #C8A96A;
}
.palette { padding: clamp(6rem, 14vh, 11rem) 0; border-top: 1px solid var(--line-soft); --pick: #C8A96A; }
.palette__head { margin-bottom: clamp(3rem, 7vh, 5rem); }
.palette__title { font-size: clamp(2rem, 5vw, 4rem); margin-top: 1rem; }
.palette__sub { color: var(--paper-dim); max-width: 46ch; margin-top: 1.2rem; }
.palette__grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: clamp(2rem, 5vw, 5rem); align-items: start; }

/* --- the 360° recolouring hoodie turntable --- */
.hoodie-stage {
  position: relative; aspect-ratio: 1 / 1; display: grid; place-items: center;
  perspective: 1300px; border: 1px solid var(--line-soft); border-radius: 18px; overflow: hidden;
  background:
    radial-gradient(80% 70% at 50% 28%, color-mix(in srgb, var(--pick) 16%, transparent), transparent 60%),
    radial-gradient(120% 120% at 50% 125%, rgba(0,0,0,.65), transparent 60%),
    linear-gradient(180deg, #101013 0%, #08080a 82%);
  box-shadow: inset 0 0 120px rgba(0,0,0,.6);
}
.hoodie {
  position: relative; width: 62%; aspect-ratio: 240 / 286; z-index: 2;
  transform-style: preserve-3d; animation: spin360 9s linear infinite; will-change: transform;
}
.hoodie__face { position: absolute; inset: 0; backface-visibility: hidden; }
.hoodie__face svg { width: 100%; height: 100%; overflow: visible; filter: drop-shadow(0 26px 36px rgba(0,0,0,.55)); }
.hoodie__face--back { transform: rotateY(180deg); }
@keyframes spin360 { from { transform: rotateY(0deg); } to { transform: rotateY(360deg); } }
.hoodie__shadow {
  position: absolute; bottom: 11%; left: 50%; transform: translateX(-50%);
  width: 46%; height: 22px; border-radius: 50%; z-index: 1;
  background: radial-gradient(ellipse at center, rgba(0,0,0,.6), transparent 70%);
  filter: blur(7px); animation: shadowPulse 9s ease-in-out infinite;
}
@keyframes shadowPulse { 0%, 100% { width: 46%; opacity: .9; } 50% { width: 30%; opacity: .5; } }

/* every hoodie part derives from --pick → recolours live */
.h-body   { fill: var(--pick); }
.h-arm    { fill: color-mix(in srgb, var(--pick) 82%, #000); }
.h-hood   { fill: color-mix(in srgb, var(--pick) 90%, #000); }
.h-open   { fill: color-mix(in srgb, var(--pick) 40%, #000); }
.h-pocket { fill: color-mix(in srgb, var(--pick) 78%, #000); }
.h-rib    { fill: color-mix(in srgb, var(--pick) 66%, #000); }
.h-string { stroke: color-mix(in srgb, var(--pick) 55%, #fff); stroke-width: 4; stroke-linecap: round; }
.h-seam   { stroke: color-mix(in srgb, var(--pick) 44%, #000); stroke-width: 2; fill: none; }

/* real Kling 3.0 turntable — shown once hoodie-360.mp4 is present */
.hoodie__video { position: absolute; inset: 0; z-index: 3; opacity: 0; pointer-events: none; border: 0; }
.hoodie__video.is-loaded { opacity: 1; }
.hoodie__video .media__fallback { display: none; }
.hoodie__video > video { object-fit: contain; }

/* live --pick tint over the photoreal spin: multiply recolours the cream hoodie
   while keeping the black studio black — so the Kling spin still changes colour */
.hoodie__tint { position: absolute; inset: 0; z-index: 4; pointer-events: none; background: var(--pick); mix-blend-mode: multiply; opacity: 0; }
.hoodie-stage.has-video .hoodie__tint { opacity: 0.82; }
.hoodie-stage.has-video .hoodie,
.hoodie-stage.has-video .hoodie__shadow { display: none; }  /* video takes over from the SVG */

.hoodie__cap { margin-top: 1rem; font-size: 0.72rem; color: var(--paper-faint); letter-spacing: 0.02em; }
.hoodie__cap code { color: var(--paper-dim); font-family: ui-monospace, Menlo, monospace; font-size: 0.92em; }

/* --- controls --- */
.palette__controls { display: flex; flex-direction: column; gap: clamp(1.6rem, 3vh, 2.4rem); }
.palette__macro {
  position: relative; height: clamp(7rem, 12vh, 9rem); border-radius: 14px; overflow: hidden;
  border: 1px solid var(--line-soft); background: var(--pick); will-change: opacity;
}
.palette__macro::after {
  content: ""; position: absolute; inset: 0; background-image: var(--grain);
  background-size: 150px 150px; opacity: 0.12; mix-blend-mode: overlay;
}
.palette__macro-name {
  position: absolute; bottom: 0.9rem; left: 1.1rem; font-size: 0.7rem; letter-spacing: 0.22em;
  text-transform: uppercase; font-weight: 600; text-shadow: 0 1px 4px rgba(0,0,0,.35);
}
.palette__rail-label { color: var(--paper-dim); display: block; margin-bottom: 1rem; }
.palette__rail-label span { color: var(--paper-dim); opacity: 0.85; }
.palette__swatches { display: grid; grid-template-columns: repeat(auto-fit, minmax(34px, 1fr)); gap: 0.6rem; max-width: 440px; }
.swatch {
  aspect-ratio: 1; border-radius: 8px; border: 1px solid var(--line);
  transition: transform .35s var(--ease), box-shadow .35s var(--ease);
  position: relative;
}
.swatch--auto {
  background: conic-gradient(from 0deg, #C8A96A, #7E2E2E, #2E6B58, #3B57A0, #C9CDD2, #A9712F, #6C4A73, #7FA9BC, #C8A96A);
  display: grid; place-items: center; color: #fff; font-size: 0.95rem; line-height: 1;
  text-shadow: 0 1px 3px rgba(0,0,0,.7);
}
.swatch:hover { transform: translateY(-3px) scale(1.06); }
.swatch.is-active { box-shadow: 0 0 0 2px var(--ink), 0 0 0 3px var(--paper); }
.palette__spec { border-top: 1px solid var(--line); padding-top: clamp(1.4rem, 3vh, 2rem); }
.palette__spec .eyebrow { color: var(--paper-dim); }
.palette__dl { margin: 1.2rem 0 1.8rem; display: flex; flex-direction: column; gap: 0.8rem; }
.palette__dl > div { display: flex; justify-content: space-between; gap: 1.5rem; border-bottom: 1px solid var(--line-soft); padding-bottom: 0.8rem; }
.palette__dl dt { color: var(--paper-dim); font-size: 0.84rem; letter-spacing: 0.04em; }
.palette__dl dd { color: var(--paper); font-size: 0.92rem; }
.palette__spec .btn--solid { background: var(--pick); transition: transform .4s var(--ease); }
.palette__spec .btn--solid:hover { filter: brightness(1.1); }

@media (max-width: 1024px) {
  .palette__grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .palette__stage { max-width: 460px; }
}
@media (max-width: 680px) {
  .palette__swatches { max-width: 300px; }
}

/* ============================================================
   6 · PROOF / NUMBERS + marquee
   ============================================================ */
.proof { padding: clamp(6rem, 14vh, 11rem) 0 0; border-top: 1px solid var(--line-soft); }
.proof__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.5rem, 4vw, 4rem); padding-bottom: clamp(5rem, 12vh, 9rem); }
.proof__num { display: block; font-size: clamp(3rem, 9vw, 8rem); line-height: 1; font-weight: 340; }
.proof__cap { display: block; margin-top: 0.8rem; font-size: 0.74rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--paper-faint); }

.marquee { overflow: hidden; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: clamp(1.4rem, 3vh, 2.4rem) 0; }
.marquee__track { display: flex; align-items: center; gap: 2.5rem; width: max-content; white-space: nowrap; will-change: transform; }
.marquee__track span { font-family: var(--font-display); font-size: clamp(1.6rem, 4vw, 3.4rem); color: var(--paper-dim); font-weight: 360; }
.marquee__dot { color: var(--gold) !important; font-size: 1rem !important; }

/* ============================================================
   ✦ · BEYOND THE BUILD — the automation engine
   ============================================================ */
.beyond { position: relative; padding: clamp(6rem, 14vh, 11rem) 0; border-top: 1px solid var(--line-soft); background: var(--ink); }
.beyond__head { max-width: 72ch; }
.beyond__title { font-size: clamp(2rem, 5.5vw, 4.6rem); margin: 1.2rem 0 1.6rem; }
.beyond__lead { color: var(--paper-dim); max-width: 58ch; font-size: clamp(1rem, .6vw + .9rem, 1.25rem); }
.beyond__grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: clamp(2.5rem, 7vw, 7rem); margin-top: clamp(3rem, 7vh, 5rem); align-items: start; }
.beyond__caps { display: flex; flex-direction: column; gap: 1.4rem; }
.beyond__caps li { display: grid; grid-template-columns: auto 1fr; gap: 1rem; align-items: baseline; padding-bottom: 1.4rem; border-bottom: 1px solid var(--line-soft); color: var(--paper-dim); line-height: 1.5; }
.beyond__caps b { color: var(--paper); font-weight: 460; font-family: var(--font-display); font-size: 1.12em; }
.beyond__mk { color: var(--gold); font-size: .8rem; line-height: 1.7; }
.beyond__stats { display: grid; grid-template-columns: 1fr; gap: 2rem; }
.beyond__stat { border-left: 1px solid var(--line); padding-left: 1.4rem; }
.beyond__num { display: block; font-size: clamp(2.6rem, 6vw, 4.4rem); line-height: 1; font-weight: 340; color: var(--paper); }
.beyond__cap { display: block; margin-top: .5rem; font-size: .74rem; letter-spacing: .2em; text-transform: uppercase; color: var(--paper-faint); }
.beyond__cta { margin-top: clamp(3rem, 7vh, 5rem); }
.beyond__link { display: inline-flex; align-items: center; gap: .8rem; font-family: var(--font-display); font-size: clamp(1.2rem, 2vw, 1.7rem); color: var(--paper); border-bottom: 1px solid var(--line); padding-bottom: .4rem; transition: color .4s var(--ease), border-color .4s var(--ease), gap .4s var(--ease); }
.beyond__link:hover { color: var(--gold); border-color: var(--gold); gap: 1.3rem; }
.beyond__arrow { transition: transform .4s var(--ease); }
.beyond__link:hover .beyond__arrow { transform: translateX(4px); }
@media (max-width: 860px) {
  .beyond__grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .beyond__stats { grid-template-columns: repeat(3, 1fr); gap: 1rem; }
  .beyond__stat { border-left: none; border-top: 1px solid var(--line); padding-left: 0; padding-top: 1rem; }
}
@media (max-width: 560px) {
  .beyond__stats { grid-template-columns: 1fr; }
  .beyond__stat { border-top: none; border-left: 1px solid var(--line); padding-left: 1.2rem; }
}

/* ============================================================
   7 · TESTIMONIAL
   ============================================================ */
.voice { padding: clamp(6rem, 16vh, 12rem) 0; }
.voice__grid { display: grid; grid-template-columns: 0.6fr 1fr; gap: clamp(2rem, 6vw, 6rem); align-items: center; }
.voice__media { aspect-ratio: 4 / 5; border: 1px solid var(--line-soft); max-width: 420px; }
.voice__quote blockquote { font-size: clamp(1.6rem, 4.2vw, 3.4rem); line-height: 1.16; font-weight: 340; letter-spacing: -0.01em; }
.voice__quote figcaption { margin-top: 2rem; display: flex; flex-direction: column; gap: 0.2rem; }
.voice__name { color: var(--gold); letter-spacing: 0.04em; }
.voice__role { font-size: 0.82rem; color: var(--paper-faint); letter-spacing: 0.08em; text-transform: uppercase; }

/* ============================================================
   ✦ · THE LOUPE — x-ray magnifier (craft beneath the polish)
   ============================================================ */
.loupe { padding: clamp(6rem, 14vh, 11rem) 0; border-top: 1px solid var(--line-soft); }
.loupe__head { text-align: center; margin-bottom: clamp(2.5rem, 6vh, 4rem); }
.loupe__title { font-size: clamp(2rem, 5vw, 4rem); margin-top: 1rem; }
.loupe__sub { color: var(--paper-dim); max-width: 50ch; margin: 1.2rem auto 0; }
.loupe__stage {
  position: relative; width: min(90vw, 560px); aspect-ratio: 4 / 5; margin-inline: auto;
  border: 1px solid var(--line); border-radius: 14px; overflow: hidden;
  background: linear-gradient(150deg, #14110c, #08080a);
  box-shadow: 0 50px 90px -50px rgba(0,0,0,.85);
  --lx: 50%; --ly: 50%; --lr: 0px;   /* radius 0 = lens hidden until cursor is over the stage */
}
.loupe__stage.is-active { --lr: 96px; }
.loupe__base, .loupe__mag { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.loupe__lens {
  position: absolute; inset: 0; opacity: 1;   /* visible at rest; the CLIP RADIUS controls reveal (no transition to stall) */
  -webkit-clip-path: circle(var(--lr) at var(--lx) var(--ly));
  clip-path: circle(var(--lr) at var(--lx) var(--ly));
}
.loupe__lens-inner { position: absolute; inset: 0; transform-origin: var(--lx) var(--ly); transform: scale(1.18); }
.loupe__tint { position: absolute; inset: 0; background: radial-gradient(circle at var(--lx) var(--ly), rgba(8,8,10,.30), rgba(8,8,10,.72)); }
.loupe__blueprint { position: absolute; inset: 0; width: 100%; height: 100%; }
.loupe__blueprint line, .loupe__blueprint rect, .loupe__blueprint circle, .loupe__blueprint path {
  stroke: var(--gold-bright); fill: none; stroke-width: 1.1; vector-effect: non-scaling-stroke;
}
.loupe__blueprint .bp-dot { fill: var(--gold-bright); stroke: none; }
.loupe__blueprint .bp-label { fill: var(--gold-bright); stroke: none; font-family: ui-monospace, Menlo, monospace; font-size: 15px; letter-spacing: 0.1em; }
.loupe__ring {
  position: absolute; left: var(--lx); top: var(--ly); width: calc(var(--lr) * 2); height: calc(var(--lr) * 2);
  transform: translate(-50%, -50%); border-radius: 50%; pointer-events: none;
  border: 1px solid rgba(228,206,156,.6);
  box-shadow: 0 0 0 1px rgba(0,0,0,.45), 0 24px 50px -12px rgba(0,0,0,.7), inset 0 0 34px rgba(228,206,156,.16);
  opacity: 0;
}
.loupe__stage.is-active .loupe__ring { opacity: 1; }
.loupe__hint {
  position: absolute; left: 50%; bottom: 1rem; transform: translateX(-50%);
  font-size: 0.62rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--paper-faint);
  pointer-events: none; transition: opacity .4s var(--ease);
}
.loupe__stage.is-active .loupe__hint { opacity: 0; }
/* touch fallback — reveal the blueprint statically, dimmed */
.loupe__stage.is-touch .loupe__lens { opacity: 0.5; clip-path: none; -webkit-clip-path: none; }
.loupe__stage.is-touch .loupe__lens-inner { transform: none; }
.loupe__stage.is-touch .loupe__tint { background: rgba(8,8,10,.45); }
.loupe__stage.is-touch .loupe__ring, .loupe__stage.is-touch .loupe__hint { display: none; }

/* ============================================================
   ✦ · THE LABYRINTH — playable maze mini-game
   ============================================================ */
.laby { padding: clamp(6rem, 14vh, 11rem) 0; border-top: 1px solid var(--line-soft); }
.laby__head { text-align: center; margin-bottom: clamp(2.5rem, 6vh, 4rem); }
.laby__title { font-size: clamp(2rem, 5vw, 4rem); margin-top: 1rem; }
.laby__sub { color: var(--paper-dim); max-width: 46ch; margin: 1.2rem auto 0; }
.laby__stage { display: flex; flex-direction: column; align-items: center; gap: 1.4rem; }
.laby__board { position: relative; width: min(92vw, 540px); aspect-ratio: 1 / 1; }
.laby__canvas {
  width: 100%; height: 100%; display: block; border-radius: 14px;
  border: 1px solid var(--line); background: #08080a; outline: none;
  box-shadow: 0 50px 90px -50px rgba(0,0,0,.85);
}
.laby__canvas:focus-visible { border-color: var(--gold); }
.laby__overlay, .laby__win {
  position: absolute; inset: 0; z-index: 2; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 1.1rem; text-align: center;
  background: radial-gradient(closest-side, rgba(8,8,10,.86), rgba(8,8,10,.6));
  border-radius: 14px; padding: 2rem;
}
.laby__win[hidden] { display: none; }
.laby__win-eyebrow { font-size: 0.7rem; letter-spacing: 0.26em; text-transform: uppercase; color: var(--gold); }
.laby__win-text { font-size: clamp(1.6rem, 4vw, 2.8rem); }
.laby__again {
  font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--paper-faint);
  border-bottom: 1px solid var(--line); padding-bottom: 0.3rem; transition: color .4s var(--ease), border-color .4s var(--ease);
}
.laby__again:hover { color: var(--gold); border-color: var(--gold); }
.laby__meta { display: flex; align-items: center; gap: clamp(1.5rem, 4vw, 3rem); font-size: 0.84rem; color: var(--paper-dim); letter-spacing: 0.04em; }
.laby__stat b { font-family: var(--font-display); font-size: 1.5em; color: var(--paper); font-weight: 420; margin-right: 0.3em; }
.laby__new {
  font-size: 0.66rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--paper-dim);
  border: 1px solid var(--line); border-radius: 100px; padding: 0.5rem 1.1rem;
  transition: border-color .4s var(--ease), color .4s var(--ease);
}
.laby__new:hover { border-color: var(--gold); color: var(--gold); }

/* ============================================================
   8 · PACKAGES
   ============================================================ */
.packages { padding: clamp(5rem, 12vh, 9rem) 0; border-top: 1px solid var(--line-soft); }
.packages__head { margin-bottom: clamp(3rem, 7vh, 5rem); }
.packages__title { font-size: clamp(2rem, 5vw, 4rem); margin-top: 1rem; }
.packages__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.2rem, 2vw, 1.8rem); }
.pkg {
  border: 1px solid var(--line); border-radius: 6px; padding: clamp(1.6rem, 2.6vw, 2.6rem);
  display: flex; flex-direction: column; gap: 1.4rem; background: linear-gradient(180deg, rgba(244,241,234,.015), transparent);
  transition: border-color .5s var(--ease), transform .5s var(--ease), background .5s var(--ease);
  position: relative;
}
.pkg:hover { border-color: var(--line); transform: translateY(-4px); }
.pkg--feature { border-color: rgba(200,169,106,.45); background: linear-gradient(180deg, rgba(200,169,106,.06), transparent); }
.pkg__tag { position: absolute; top: -0.7rem; left: clamp(1.6rem, 2.6vw, 2.6rem); background: var(--gold); color: var(--ink); font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase; padding: 0.25rem 0.7rem; border-radius: 100px; font-weight: 600; }
.pkg__name { font-size: clamp(1.4rem, 2.4vw, 2rem); }
.pkg__for { color: var(--paper-faint); font-size: 0.92rem; margin-top: 0.4rem; }
.pkg__price { font-size: 1.1rem; color: var(--paper-dim); border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); padding: 1rem 0; }
.pkg__price b { font-family: var(--font-display); font-size: 1.6em; color: var(--paper); font-weight: 420; }
.pkg__list { display: flex; flex-direction: column; gap: 0.7rem; flex: 1; }
.pkg__list li { color: var(--paper-dim); font-size: 0.92rem; padding-left: 1.2rem; position: relative; }
.pkg__list li::before { content: "—"; position: absolute; left: 0; color: var(--gold); }
.pkg .btn { align-self: flex-start; margin-top: 0.6rem; }

/* ============================================================
   9 · FOOTER CTA
   ============================================================ */
.footer { padding: clamp(6rem, 16vh, 13rem) 0 clamp(2rem, 5vh, 4rem); background: linear-gradient(180deg, var(--ink) 0%, #060607 100%); border-top: 1px solid var(--line-soft); }
.footer__cta { font-size: clamp(2.4rem, 9vw, 9rem); line-height: 0.96; margin: 1.4rem 0 clamp(2.5rem, 6vh, 4rem); font-weight: 340; }
.footer__btn {
  display: inline-flex; align-items: center; gap: 1.2rem; border: 1px solid var(--gold);
  color: var(--gold); border-radius: 100px; padding: 1.1rem 2.2rem; font-size: clamp(1rem, 1.6vw, 1.3rem);
  letter-spacing: 0.04em; transition: background .5s var(--ease), color .5s var(--ease); will-change: transform;
}
.footer__btn:hover { background: var(--gold); color: var(--ink); }
.footer__btn-arrow { transition: transform .5s var(--ease); }
.footer__btn:hover .footer__btn-arrow { transform: translateX(6px); }
.footer__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; margin-top: clamp(4rem, 10vh, 7rem); padding-top: 2.5rem; border-top: 1px solid var(--line); }
.footer__col { display: flex; flex-direction: column; gap: 0.6rem; }
.footer__h { font-size: 0.68rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--paper-faint); margin-bottom: 0.4rem; }
.footer__col a { color: var(--paper-dim); transition: color .4s var(--ease); width: fit-content; }
.footer__col a:hover { color: var(--gold); }
.footer__soon { color: var(--paper-faint); cursor: default; font-size: 0.95em; }
.footer__base { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; margin-top: clamp(3rem, 8vh, 5rem); font-size: 0.74rem; color: var(--paper-faint); letter-spacing: 0.04em; }

/* ============================================================
   REVEALS (JS sets these; CSS is the at-rest state)
   ============================================================ */
[data-reveal] { opacity: 0; transform: translateY(28px); will-change: transform, opacity; }
[data-reveal].is-in { opacity: 1; transform: none; transition: opacity 1s var(--ease), transform 1s var(--ease); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .engine__grid { grid-template-columns: 1fr; }
  .engine__preview { display: none; }
  .engine__desc { max-height: 8rem; opacity: 1; }
  .voice__grid { grid-template-columns: 1fr; }
  .voice__media { max-width: 320px; }
  .packages__grid { grid-template-columns: 1fr; max-width: 520px; }
  .proof__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 680px) {
  .nav__links a:not(.btn) { display: none; }
  .nav { mix-blend-mode: normal; }
  .hero__cue { display: none; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   REDUCED MOTION — calm path
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; }
  .media__fallback::before, .manifesto__fallback { animation: none; }
  [data-reveal] { opacity: 1 !important; transform: none !important; }
  .manifesto__statement .word > span { opacity: 1 !important; }
  .hero__cue-line::after { display: none; }
  html { scroll-behavior: auto; }
}

.engine__more { display: flex; gap: 2.2rem; flex-wrap: wrap; margin-top: clamp(1.6rem, 4vh, 2.8rem); }
.engine__more a {
  color: var(--gold); font-size: 0.95rem; letter-spacing: 0.04em;
  border-bottom: 1px solid var(--gold-deep); padding-bottom: 0.2rem;
  transition: color .3s var(--ease), border-color .3s var(--ease);
}
.engine__more a:hover { color: var(--gold-bright); border-color: var(--gold-bright); }

/* ============================================================
   MOBILE RENDER BUDGET — offscreen sections are UNLOADED
   (browser skips layout/paint/compositing entirely until the
   section approaches the viewport, then it mounts and its
   entrance animations re-fire). Hero + manifesto excluded:
   hero is first paint, manifesto is scroll-scrubbed.
   ============================================================ */
@media (max-width: 1024px) {
  .medium, .engine, .work, .loupe, .drop, .proof, .beyond, .voice, .laby, .packages {
    content-visibility: auto;
    contain-intrinsic-size: auto 90vh;
  }
}
