/* ============================================================
   Generative Solutions — Cinematic Studio (sandbox)
   Dark luminous · kinetic Clash Display · self-hosted · vanilla motion
   ============================================================ */

/* ---- Fonts (self-hosted woff2) ----------------------------- */
@font-face{font-family:"Clash Display";src:url("/static/sandbox/fonts/ClashDisplay-400.woff2") format("woff2");font-weight:400;font-display:swap;font-style:normal}
@font-face{font-family:"Clash Display";src:url("/static/sandbox/fonts/ClashDisplay-500.woff2") format("woff2");font-weight:500;font-display:swap;font-style:normal}
@font-face{font-family:"Clash Display";src:url("/static/sandbox/fonts/ClashDisplay-600.woff2") format("woff2");font-weight:600;font-display:swap;font-style:normal}
@font-face{font-family:"Clash Display";src:url("/static/sandbox/fonts/ClashDisplay-700.woff2") format("woff2");font-weight:700;font-display:swap;font-style:normal}
@font-face{font-family:"Satoshi";src:url("/static/sandbox/fonts/Satoshi-400.woff2") format("woff2");font-weight:400;font-display:swap;font-style:normal}
@font-face{font-family:"Satoshi";src:url("/static/sandbox/fonts/Satoshi-500.woff2") format("woff2");font-weight:500;font-display:swap;font-style:normal}
@font-face{font-family:"Satoshi";src:url("/static/sandbox/fonts/Satoshi-700.woff2") format("woff2");font-weight:700;font-display:swap;font-style:normal}
@font-face{font-family:"JetBrains Mono";src:url("/static/sandbox/fonts/JetBrainsMono-400.woff2") format("woff2");font-weight:400;font-display:swap;font-style:normal}

/* ---- Tokens ------------------------------------------------ */
:root{
  /* Palette eyedropped from the Generative Solutions logo */
  --ink:#0A0720; --panel:#140E30; --panel-2:#1C1545; --paper:#F5F4F0;
  --fg:#EFECFA; --fg-dim:#A9A4C8; --fg-faint:#6F6A92;
  --line:rgba(255,255,255,.10); --line-2:rgba(255,255,255,.05);
  --blue:#6C90FC; --violet:#9B6CFF; --magenta:#D860D8; --pink:#FC6CA8; --coral:#FF9E6B;
  --cyan:#B9A8FF; --ember:#FF9E6B;
  /* single workhorse accent — used for nearly all emphasis so the full
     rainbow stays a rare, deliberate brand moment (logo / hero / CTA). */
  --accent:#A98BFF; --accent-soft:rgba(169,139,255,.14);
  --grad:linear-gradient(100deg,var(--blue) 0%,var(--violet) 26%,var(--magenta) 54%,var(--pink) 78%,var(--coral) 100%);
  --grad-warm:linear-gradient(100deg,var(--magenta) 0%,var(--pink) 50%,var(--coral) 100%);
  --f-display:"Clash Display",system-ui,sans-serif;
  --f-text:"Satoshi",system-ui,sans-serif;
  --f-mono:"JetBrains Mono",ui-monospace,monospace;
  --maxw:1280px; --pad:clamp(1.25rem,5vw,4rem);
  --ease:cubic-bezier(.16,1,.3,1);
  --r:18px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html.menu-open,body.menu-open{overflow:hidden}
body.sb-body{
  background:var(--ink);color:var(--fg);
  font-family:var(--f-text);font-weight:400;line-height:1.6;
  font-synthesis:none;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--violet);color:#fff}

/* grain + ambient glow overlays */
body.sb-body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.34;
  background:
    radial-gradient(60vw 60vw at 78% -8%,rgba(155,108,255,.14),transparent 62%),
    radial-gradient(50vw 50vw at -10% 18%,rgba(155,108,255,.07),transparent 58%);
}
body.sb-body::after{
  content:"";position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:.035;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);position:relative;z-index:1}
.sb-main{position:relative;z-index:1}

/* ---- Type primitives --------------------------------------- */
.eyebrow{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--fg-faint);display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:1.6em;height:1px;background:var(--grad)}
h1,h2,h3,h4{font-family:var(--f-display);font-weight:600;line-height:1.02;letter-spacing:-.02em;word-spacing:.06em;text-wrap:balance}
/* Clash Display has a narrow space; at smaller heading sizes the tight tracking
   closes word gaps. Relax tracking + widen spaces on h3/h4 so they read clearly. */
h3,h4{letter-spacing:0;word-spacing:.12em;line-height:1.15}
p{text-wrap:pretty}
.display{font-size:clamp(2.7rem,8vw,7rem);font-weight:600;line-height:.98;letter-spacing:-.03em}
.h2{font-size:clamp(2rem,4.5vw,3.6rem)}
.lede{font-size:clamp(1.05rem,1.6vw,1.35rem);color:var(--fg-dim);max-width:54ch;line-height:1.55}
/* Inline emphasis: ONE confident accent, not the whole rainbow. The
   five-stop gradient is the brand mark — kept for the logo, the hero word
   rotator (.brand-grad) and the primary button only. */
.grad-text{color:var(--accent)}
.brand-grad{background:var(--grad);background-size:220% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 7s linear infinite}
@keyframes shimmer{to{background-position:220% 0}}
.serif-i{font-style:italic;font-weight:500}

/* ---- Buttons ----------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--f-text);font-weight:600;
  font-size:1rem;padding:.95em 1.6em;border-radius:100px;border:1px solid transparent;cursor:pointer;
  transition:transform .5s var(--ease),background .3s,border-color .3s,color .3s,box-shadow .3s;will-change:transform}
.btn--primary{background:var(--grad);color:#0A0A12;position:relative;box-shadow:0 6px 24px -12px rgba(155,108,255,.45)}
.btn--primary:hover{box-shadow:0 10px 32px -12px rgba(155,108,255,.55)}
.btn--ghost{border-color:var(--line);color:var(--fg);background:rgba(255,255,255,.02)}
.btn--ghost:hover{border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.06)}
.btn .arr{transition:transform .4s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn--lg{font-size:1.05rem;padding:1.1em 1.9em}

/* ---- Preloader --------------------------------------------- */
.preload{position:fixed;inset:0;z-index:10000;background:var(--ink);display:grid;place-items:center;
  transition:opacity .6s ease,visibility .6s}
.preload.done{opacity:0;visibility:hidden;pointer-events:none}
.preload__mark{display:flex;flex-direction:column;align-items:center;gap:1.2rem}
.preload__logo{font-family:var(--f-display);font-weight:600;font-size:clamp(2.4rem,7vw,4rem);letter-spacing:-.03em;display:flex;align-items:center;gap:.5rem}
.preload__logo .dot{width:14px;height:14px;border-radius:50%;background:var(--grad);box-shadow:0 0 20px rgba(155,108,255,.9)}
.preload__bar{width:min(60vw,260px);height:2px;background:var(--line);overflow:hidden;border-radius:2px}
.preload__bar i{display:block;height:100%;width:0;background:var(--grad);animation:load 1.1s var(--ease) forwards}
@keyframes load{to{width:100%}}

/* ---- Sandbox banner + header ------------------------------- */
.sandbox-banner{position:relative;z-index:60;background:linear-gradient(90deg,rgba(155,108,255,.18),rgba(155,108,255,.1));
  border-bottom:1px solid var(--line);font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--fg-dim);text-align:center;padding:.5rem 1rem;display:flex;justify-content:center;gap:.6rem;align-items:center}
.sandbox-banner a{color:var(--cyan)}
.sb-banner-dot{width:7px;height:7px;border-radius:50%;background:var(--ember);box-shadow:0 0 10px var(--ember);animation:pulse 2s infinite}
@keyframes pulse{50%{opacity:.4}}

.sb-header{position:sticky;top:0;z-index:50;transition:background .4s,backdrop-filter .4s,border-color .4s;
  border-bottom:1px solid transparent}
.sb-header.is-stuck{background:rgba(7,7,11,.72);backdrop-filter:blur(16px) saturate(1.4);border-bottom-color:var(--line)}
.sb-header__bar{max-width:var(--maxw);margin:0 auto;padding:1rem var(--pad);display:flex;align-items:center;justify-content:space-between;gap:1rem}
.sb-logo{display:inline-flex;align-items:center;gap:.65rem;font-family:var(--f-display);font-weight:600;font-size:1.2rem;letter-spacing:-.02em}
.sb-logo__mark{height:38px;width:auto;display:block;transition:transform .5s var(--ease)}
.sb-logo:hover .sb-logo__mark{transform:rotate(-4deg) scale(1.05)}
.sb-logo__full{height:34px;width:auto;display:block;transition:transform .5s var(--ease)}
.sb-logo:hover .sb-logo__full{transform:scale(1.04)}
.sb-logo__dot{width:11px;height:11px;border-radius:50%;background:var(--grad);box-shadow:0 0 16px rgba(155,108,255,.8);flex:none}
.sb-nav{display:flex;align-items:center;gap:2rem}
.sb-nav__links{display:flex;gap:1.7rem;align-items:center}
.sb-nav__links a{font-size:.95rem;color:var(--fg-dim);font-weight:500;position:relative;padding:.2rem 0;transition:color .3s}
.sb-nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--grad);transition:width .4s var(--ease)}
.sb-nav__links a:hover{color:var(--fg)}
.sb-nav__links a:hover::after,.sb-nav__links a.is-current::after{width:100%}
.sb-nav__num{font-family:var(--f-mono);font-size:.62rem;color:var(--fg-faint);margin-right:.35em;vertical-align:super}

.sb-burger{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:50%;background:rgba(255,255,255,.03);
  position:relative;cursor:pointer;flex:none}
.sb-burger span{position:absolute;left:50%;top:50%;width:18px;height:1.5px;background:var(--fg);transform:translate(-50%,-50%);transition:.35s var(--ease)}
.sb-burger span:nth-child(1){transform:translate(-50%,-5px)}
.sb-burger span:nth-child(2){transform:translate(-50%,5px)}
.menu-open .sb-burger span:nth-child(1){transform:translate(-50%,-50%) rotate(45deg)}
.menu-open .sb-burger span:nth-child(2){transform:translate(-50%,-50%) rotate(-45deg)}

/* mobile slide menu */
.sb-mobile{position:fixed;inset:0;z-index:55;background:rgba(7,7,11,.97);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;justify-content:center;gap:.2rem;padding:var(--pad);
  transform:translateY(-100%);transition:transform .55s var(--ease);visibility:hidden}
.menu-open .sb-mobile{transform:translateY(0);visibility:visible}
.sb-mobile a:not(.btn){font-family:var(--f-display);font-size:clamp(1.8rem,9vw,2.4rem);font-weight:500;padding:.4rem 0;border-bottom:1px solid var(--line-2);display:flex;align-items:baseline;gap:.7rem}
.sb-mobile a .n{font-family:var(--f-mono);font-size:.8rem;color:var(--fg-faint)}
.sb-mobile .btn{margin-top:1.6rem;justify-content:center;width:100%}

/* ---- Hero -------------------------------------------------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding-block:6rem 5rem;overflow:hidden}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:1}
.hero__veil{position:absolute;inset:0;z-index:1;background:
  radial-gradient(125% 85% at 72% 14%,transparent 38%,rgba(10,7,32,.55) 70%,var(--ink) 92%),
  linear-gradient(180deg,transparent 60%,var(--ink) 100%)}
.hero .wrap{z-index:2}
.hero__eyebrow{margin-bottom:1.8rem}
.hero__title{font-family:var(--f-display);font-weight:600;font-size:clamp(2.5rem,6.4vw,5.6rem);line-height:.98;letter-spacing:-.035em;max-width:15ch}
.hero__title .ln{display:block;overflow:hidden}
.hero__title .ln > span{display:block;transform:translateY(110%);transition:transform .9s var(--ease)}
.is-loaded .hero__title .ln > span{transform:translateY(0)}
.hero__title .ln:nth-child(2) > span{transition-delay:.08s}
.hero__title .ln:nth-child(3) > span{transition-delay:.16s}
.hero__lede{margin-top:2rem;opacity:0;transform:translateY(20px);transition:.9s var(--ease) .5s}
.is-loaded .hero__lede{opacity:1;transform:none}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2.6rem;opacity:0;transform:translateY(20px);transition:.9s var(--ease) .62s}
.is-loaded .hero__actions{opacity:1;transform:none}
.hero__trust{display:flex;gap:1.6rem;flex-wrap:wrap;margin-top:3.4rem;font-family:var(--f-mono);font-size:.74rem;
  letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint);opacity:0;transition:opacity .9s ease .85s}
.is-loaded .hero__trust{opacity:1}
.hero__trust span{display:inline-flex;align-items:center;gap:.5em}
.hero__trust span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--cyan)}
.hero__cue{position:absolute;left:50%;bottom:1.8rem;transform:translateX(-50%);z-index:2;font-family:var(--f-mono);
  font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-faint);display:flex;flex-direction:column;align-items:center;gap:.5rem}
.hero__cue i{width:1px;height:36px;background:linear-gradient(var(--fg-faint),transparent);animation:cue 2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---- Hero word rotator ------------------------------------- */
.rotator{position:relative;display:inline-grid;vertical-align:top}
/* Beat `.hero__title .ln > span{display:block}` (0,2,1) so the rotator words
   stack in one grid cell instead of flowing inline (caused word overlap). */
.hero__title .ln > span.rotator{display:inline-grid}
.rotator__w{grid-area:1/1;opacity:0;transform:translateY(45%);transition:opacity .5s var(--ease),transform .6s var(--ease);white-space:nowrap}
.rotator__w.is-active{opacity:1;transform:none}

/* ---- Approach (them-vs-us comparison — turns the value prop into a
   designed differentiation moment instead of one floating sentence) */
.approach{position:relative;z-index:2;padding-block:clamp(2.4rem,4.5vw,4rem);
  border-block:1px solid var(--line-2);background:linear-gradient(180deg,var(--panel),var(--ink))}
.approach__inner{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(2.5rem,6vw,5rem);align-items:center}
.approach__head .eyebrow{margin-bottom:1.4rem}
.approach__lead{font-family:var(--f-display);font-weight:600;font-size:clamp(1.8rem,3.4vw,2.7rem);
  line-height:1.1;letter-spacing:-.022em;text-wrap:pretty}
.approach__sub{margin-top:1.5rem;color:var(--fg-dim);font-size:1.04rem;line-height:1.6;max-width:46ch}

/* animated project flow (auto-advancing vertical stepper) */
.flow{position:relative}
.flow__list{list-style:none;display:flex;flex-direction:column}
.flow__step{position:relative;display:grid;grid-template-columns:38px 1fr;gap:1.1rem;padding-bottom:1.9rem;transition:opacity .45s var(--ease)}
.flow__step:last-child{padding-bottom:0}
.flow__step:not(:last-child)::before{content:"";position:absolute;left:18px;top:40px;bottom:6px;width:2px;
  background:var(--line);transition:background .5s var(--ease)}
.flow__step.is-done:not(:last-child)::before{background:var(--accent)}
.flow__dot{width:38px;height:38px;border-radius:50%;border:2px solid var(--line);background:var(--ink);
  display:grid;place-items:center;position:relative;z-index:1;transition:.45s var(--ease)}
.flow__dot::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--fg-faint);transition:.45s var(--ease)}
.flow__step.is-done .flow__dot{border-color:var(--accent);background:rgba(169,139,255,.16)}
.flow__step.is-done .flow__dot::after{background:var(--accent)}
.flow__step.is-active .flow__dot{border-color:transparent;background:var(--grad);box-shadow:0 0 0 6px var(--accent-soft);transform:scale(1.12)}
.flow__step.is-active .flow__dot::after{background:#0A0712;width:9px;height:9px}
.flow__body h4{font-family:var(--f-display);font-size:1.18rem;font-weight:600;line-height:1.2;transition:color .4s}
.flow__body p{color:var(--fg-dim);font-size:.94rem;line-height:1.5;margin-top:.35rem;transition:color .4s}
.flow__step:not(.is-active){opacity:.5}
.flow__step.is-done{opacity:.82}
.flow__step.is-active{opacity:1}
@media(max-width:860px){.approach__inner{grid-template-columns:1fr;gap:2.6rem;align-items:start}}

/* ---- Marquee (pure CSS, always animates) ------------------- */
.marquee{border-block:1px solid var(--line);padding:1.4rem 0;overflow:hidden;white-space:nowrap;
  -webkit-user-select:none;user-select:none;pointer-events:none;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:inline-flex;gap:3rem;will-change:transform;animation:marq 38s linear infinite}
.marquee__item{font-family:var(--f-display);font-weight:500;font-size:clamp(1.1rem,2vw,1.6rem);color:var(--fg-dim);display:inline-flex;align-items:center;gap:1rem}
.marquee__item::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--grad)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---- Section scaffold -------------------------------------- */
.section{padding-block:clamp(2.1rem,4vw,3.6rem)}
.section--band{background:linear-gradient(var(--panel),var(--ink));border-top:1px solid var(--line-2)}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:2.6rem;flex-wrap:wrap}
.sec-head h2{margin-top:1rem}
.sec-head p{color:var(--fg-dim);max-width:38ch}

/* ---- Capabilities (feature cards) -------------------------- */
.caps{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.cap{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r);
  background:rgba(255,255,255,.02);padding:clamp(1.8rem,3vw,2.6rem);position:relative;overflow:hidden;
  transition:transform .5s var(--ease),border-color .4s,background .4s}
.cap::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--grad);opacity:0;transition:opacity .4s}
.cap:hover{transform:translateY(-5px);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.035)}
.cap:hover::before{opacity:1}
.cap h3{font-size:clamp(1.5rem,2.6vw,2.05rem);font-weight:600}
.cap__lead{color:var(--fg-dim);margin:.85rem 0 1.7rem;font-size:1.02rem;line-height:1.55}
.cap__list{list-style:none;display:flex;flex-direction:column;gap:.9rem;margin:0 0 1.9rem}
.cap__list li{position:relative;padding-left:1.8rem;color:var(--fg);font-size:.95rem;line-height:1.5}
.cap__list li::before{content:"";position:absolute;left:0;top:.35em;width:14px;height:14px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.cap__list li::after{content:"";position:absolute;left:4px;top:.62em;width:5px;height:3px;border-left:1.5px solid #0A0712;
  border-bottom:1.5px solid #0A0712;transform:rotate(-45deg)}
.cap__foot{margin-top:auto;border-top:1px solid var(--line-2);padding-top:1.5rem;display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.cap__price{font-family:var(--f-mono);font-size:.74rem;letter-spacing:.04em;color:var(--cyan)}

/* ---- Showreel (horizontal) --------------------------------- */
.reel{padding-block:clamp(2.1rem,4vw,3.6rem) clamp(1.8rem,3.5vw,2.8rem);overflow:hidden}
.reel__head{max-width:var(--maxw);margin:0 auto 2.6rem;padding-inline:var(--pad);display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1.5rem}
/* Auto-scrolling, NON-interactive showreel (house rule: always animates,
   even under reduced-motion; pointer-events:none, no hover-pause). */
.reel__viewport{overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.reel__row{display:flex;gap:1.6rem;width:max-content;padding:0 .8rem 1.5rem;
  pointer-events:none;user-select:none;-webkit-user-select:none;
  will-change:transform;animation:reelscroll 80s linear infinite}
@keyframes reelscroll{to{transform:translateX(-50%)}}
.reel-card{flex:0 0 min(86vw,520px)}
/* Clean, device-less portfolio frame — no fake browser chrome (that mock
   toolbar with three dots is a dead giveaway of a generated template). */
.frame{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--panel-2);
  box-shadow:0 24px 60px -34px rgba(0,0,0,.75);transition:transform .6s var(--ease),border-color .4s}
.reel-card:hover .frame,.work-card:hover .frame{transform:translateY(-6px);border-color:rgba(255,255,255,.22)}
.frame__chrome{display:none}
.frame__url{display:none}
.frame__shot{aspect-ratio:1366/860;background:linear-gradient(135deg,var(--panel-2),var(--panel));position:relative;overflow:hidden}
.frame__shot img{width:100%;height:100%;object-fit:cover;object-position:top}
.frame__shot--empty{display:grid;place-items:center;color:var(--fg-faint);font-family:var(--f-mono);font-size:.8rem}
.reel-card__name{display:block;font-family:var(--f-display);font-size:1.2rem;font-weight:600;margin-bottom:.85rem}
.reel-card__tag{display:block;font-family:var(--f-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:var(--fg-faint);margin-top:.9rem}
.reel-card__meta{display:flex;justify-content:space-between;align-items:baseline;margin-top:1.1rem;gap:1rem}

/* ---- Process ----------------------------------------------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.step{padding:2rem 1.6rem;border:1px solid var(--line);border-radius:var(--r);background:rgba(255,255,255,.015);
  position:relative;overflow:hidden}
.step__n{font-family:var(--f-mono);font-size:.75rem;color:var(--cyan);margin-bottom:1.2rem}
.step h4{font-size:1.3rem;font-weight:600;margin-bottom:.6rem}
.step p{font-size:.95rem;color:var(--fg-dim)}

/* ---- Scroll-pinned process --------------------------------- */
.pinwrap{position:relative;height:380vh}
.pin{position:sticky;top:0;height:100svh;display:flex;align-items:center;overflow:hidden}
.pin__inner{width:100%;display:grid;grid-template-columns:.85fr 1.15fr;gap:3rem;align-items:center}
.pin__head h2{margin-top:1rem}
.pin__bars{display:flex;gap:.5rem;margin-top:2.2rem;max-width:320px}
.pin__bars span{flex:1;height:3px;border-radius:3px;background:var(--line);transition:background .4s}
.pin__bars span.is-on{background:var(--grad)}
.pin__stage{position:relative;min-height:46vh}
.pin__step{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;
  opacity:0;transform:translateY(34px);transition:opacity .55s var(--ease),transform .6s var(--ease)}
.pin__step.is-active{opacity:1;transform:none}
.pin__n{font-family:var(--f-mono);font-weight:400;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);line-height:1;display:flex;align-items:center;gap:.7em;margin-bottom:1.1rem}
.pin__n::before{content:"";width:1.8em;height:1px;background:var(--accent);opacity:.5}
.pin__step h3{font-size:clamp(2rem,5vw,3.6rem);font-weight:600;margin-bottom:1rem}
.pin__step p{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--fg-dim);max-width:46ch}

/* ---- Trusted-by logos — STATIC tasteful wrap (was a 2nd marquee;
   one moving strip on the page, the showreel, is plenty) ------- */
.logos{padding-block:clamp(1.6rem,3vw,2.6rem)}
.logos__list{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem 2.6rem}
.logos__item{font-family:var(--f-display);font-weight:500;font-size:clamp(1.05rem,1.7vw,1.35rem);
  color:var(--fg-faint);white-space:nowrap;word-spacing:.05em;transition:color .3s}
.logos__list:hover .logos__item{color:var(--fg-dim)}
/* Mobile: no scroll-jacking — unpin and stack the steps as a simple list. */
@media(max-width:860px){
  .pinwrap{height:auto}
  .pin{position:static;height:auto;display:block;padding-block:clamp(3rem,9vw,5rem)}
  .pin__inner{display:block}
  .pin__head h2{font-size:clamp(1.8rem,7vw,2.4rem)}
  .pin__bars{display:none}
  .pin__stage{position:static;min-height:0;display:flex;flex-direction:column;gap:2.4rem;margin-top:2.4rem}
  .pin__step{position:static;inset:auto;opacity:1;transform:none;border-top:1px solid var(--line-2);padding-top:2rem}
  .pin__step:first-child{border-top:0;padding-top:0}
  .pin__n{font-size:2.4rem;margin-bottom:.4rem}
  .pin__step h3{font-size:clamp(1.6rem,6vw,2.2rem)}
}

/* ---- Product grid ------------------------------------------ */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.prod{padding:1.7rem;border:1px solid var(--line);border-radius:var(--r);background:rgba(255,255,255,.015);
  transition:transform .5s var(--ease),border-color .4s,background .4s;display:flex;flex-direction:column;gap:.4rem}
.prod:hover{transform:translateY(-4px);border-color:rgba(155,108,255,.4);background:rgba(155,108,255,.04)}
.prod__name{font-family:var(--f-display);font-size:1.2rem;font-weight:500}
.prod__desc{font-size:.92rem;color:var(--fg-dim);flex:1}
.prod__cta{font-family:var(--f-mono);font-size:.72rem;color:var(--cyan);text-transform:uppercase;letter-spacing:.06em;margin-top:.8rem}

/* ---- M8 feature (focused: GlassM8 live + bespoke invite) --- */
.m8-feature{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.m8-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r);
  background:rgba(255,255,255,.02);padding:clamp(1.8rem,3vw,2.6rem);position:relative;overflow:hidden;
  transition:transform .5s var(--ease),border-color .4s,background .4s}
.m8-card:hover{transform:translateY(-5px);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.035)}
.m8-card--bespoke{border-style:dashed;background:transparent}
.m8-card__top{display:flex;align-items:center;gap:1rem;margin-bottom:.4rem}
.m8-card__name{font-family:var(--f-display);font-weight:600;font-size:clamp(1.6rem,3vw,2.1rem);line-height:1}
.m8-card__industry{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-faint);margin-bottom:1.1rem}
.m8-card__desc{color:var(--fg-dim);font-size:1.02rem;line-height:1.6;flex:1}
.m8-card__cta{font-family:var(--f-mono);font-size:.74rem;color:var(--cyan);text-transform:uppercase;letter-spacing:.06em;margin-top:1.6rem}
.badge{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;
  padding:.4em .75em;border-radius:100px;border:1px solid var(--line);white-space:nowrap}
.badge--live{color:#0A0712;background:var(--accent);border-color:transparent}
@media(max-width:760px){.m8-feature{grid-template-columns:1fr}}

/* ---- Stats ------------------------------------------------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding-block:2.1rem}
.stat__num{font-family:var(--f-display);font-size:clamp(2.4rem,5vw,3.6rem);font-weight:600;line-height:1}
.stat__label{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint);margin-top:.6rem}

/* ---- FAQ --------------------------------------------------- */
.faq-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:3rem}
.faq details{border-bottom:1px solid var(--line);padding:1.3rem 0}
.faq summary{font-family:var(--f-display);font-size:1.15rem;font-weight:500;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--f-mono);color:var(--cyan);font-size:1.4rem;transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq__a{color:var(--fg-dim);margin-top:.9rem;max-width:60ch;font-size:.98rem}

/* ---- CTA panel --------------------------------------------- */
.cta{position:relative;border-radius:28px;overflow:hidden;padding:clamp(3rem,7vw,6rem);text-align:center;
  background:radial-gradient(120% 140% at 50% -20%,rgba(155,108,255,.35),transparent 60%),var(--panel-2);
  border:1px solid var(--line)}
.cta h2{margin-bottom:1.2rem}
.cta p{color:var(--fg-dim);max-width:50ch;margin:0 auto 2.2rem}
.cta__row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---- Footer ------------------------------------------------ */
.sb-footer{border-top:1px solid var(--line);padding-block:4rem 2rem;position:relative;z-index:1;background:var(--panel)}
.sb-footer__grid{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.5rem}
.sb-footer__brand{font-family:var(--f-display);font-size:1.4rem;font-weight:600;display:flex;align-items:center;gap:.6rem}
.sb-footer p{color:var(--fg-dim);font-size:.92rem;margin-top:1rem;max-width:30ch}
.sb-footer h5{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-faint);margin-bottom:1rem}
.sb-footer__grid ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.sb-footer__grid a{color:var(--fg-dim);font-size:.92rem;transition:color .3s}
.sb-footer__grid a:hover{color:var(--fg)}
.sb-footer__meta{max-width:var(--maxw);margin:3rem auto 0;padding:1.6rem var(--pad) 0;border-top:1px solid var(--line-2);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-family:var(--f-mono);font-size:.7rem;color:var(--fg-faint);letter-spacing:.06em}

/* ---- Reveal (IntersectionObserver) ------------------------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
[data-stagger] > *{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-stagger].is-in > *{opacity:1;transform:none}
[data-stagger].is-in > *:nth-child(2){transition-delay:.07s}
[data-stagger].is-in > *:nth-child(3){transition-delay:.14s}
[data-stagger].is-in > *:nth-child(4){transition-delay:.21s}
[data-stagger].is-in > *:nth-child(5){transition-delay:.28s}
[data-stagger].is-in > *:nth-child(6){transition-delay:.35s}

/* ---- Custom cursor: removed ------------------------------- */
.cursor{display:none!important}

/* ---- Inner page hero --------------------------------------- */
.page-hero{padding:2.6rem 0 2.6rem;border-bottom:1px solid var(--line-2);position:relative;overflow:hidden}
.page-hero h1{font-size:clamp(2.6rem,7vw,5.5rem);margin-top:1.4rem}
.page-hero .lede{margin-top:1.6rem}

/* ---- Work grid + sector filter ----------------------------- */
.work-filter{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:clamp(1.8rem,3vw,2.6rem)}
.work-filter__btn{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.62em 1.15em;border-radius:100px;border:1px solid var(--line);background:rgba(255,255,255,.02);
  color:var(--fg-dim);cursor:pointer;transition:color .3s,background .3s,border-color .3s}
.work-filter__btn:hover{color:var(--fg);border-color:rgba(255,255,255,.28)}
.work-filter__btn.is-active{background:var(--accent);border-color:transparent;color:#0A0712}

.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.4rem,2.4vw,1.9rem)}
.work-card{display:flex;flex-direction:column}
.work-card .frame{position:relative}
.work-card .frame__shot img{transition:transform .9s var(--ease)}
.work-card:hover .frame__shot img{transform:scale(1.045)}
.work-card .frame::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .45s var(--ease);
  background:linear-gradient(180deg,transparent 45%,rgba(8,6,16,.62))}
.work-card:hover .frame::after{opacity:1}
.work-card__visit{position:absolute;left:50%;bottom:1.1rem;transform:translate(-50%,10px);opacity:0;z-index:2;pointer-events:none;
  display:inline-flex;align-items:center;gap:.5em;font-family:var(--f-text);font-weight:600;font-size:.9rem;
  padding:.6em 1.2em;border-radius:100px;color:var(--fg);
  background:rgba(12,9,22,.66);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.18);
  transition:opacity .45s var(--ease),transform .45s var(--ease)}
.work-card:hover .work-card__visit{opacity:1;transform:translate(-50%,0)}
.work-card__meta{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-top:1.1rem}
.work-card__id{display:flex;flex-direction:column;gap:.28rem;min-width:0}
.work-card__name{font-family:var(--f-display);font-size:1.25rem;font-weight:600;line-height:1.12}
.work-card__cat{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.07em;text-transform:uppercase;color:var(--fg-faint)}
.work-card__url{font-family:var(--f-mono);font-size:.72rem;color:var(--cyan);white-space:nowrap;flex:none;opacity:.85;transition:opacity .3s}
.work-card:hover .work-card__url{opacity:1}
.work-card.is-filtered{display:none}
.work-empty{color:var(--fg-dim);text-align:center;padding:2rem 0;font-size:1rem}
.work-empty a{color:var(--cyan)}
@media(max-width:620px){.work-grid{grid-template-columns:1fr}.work-card__url{display:none}}

/* ---- About ------------------------------------------------- */
.about-lead{font-family:var(--f-display);font-weight:500;font-size:clamp(1.6rem,3.4vw,2.6rem);line-height:1.2;letter-spacing:-.02em;max-width:24ch}
.principles{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:.6rem}
.principle{position:relative;overflow:hidden;padding:2rem;border:1px solid var(--line);border-radius:var(--r);
  background:rgba(255,255,255,.015);transition:transform .5s var(--ease),border-color .4s,background .4s}
.principle::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--grad);
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.principle:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.03)}
.principle:hover::before{transform:scaleX(1)}
.principle__n{display:block;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.12em;color:var(--accent);margin-bottom:1.1rem}
.principle h4{font-size:1.2rem;margin-bottom:.6rem}
.principle p{color:var(--fg-dim);font-size:.95rem;line-height:1.55}
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}

/* ---- About: the team --------------------------------------- */
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.member{padding:2.2rem 1.6rem;border:1px solid var(--line);border-radius:var(--r);background:rgba(255,255,255,.015);
  text-align:center;transition:transform .5s var(--ease),border-color .4s,background .4s}
.member:hover{transform:translateY(-5px);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.03)}
.member__mono{display:grid;place-items:center;width:64px;height:64px;margin:0 auto 1.2rem;border-radius:50%;
  font-family:var(--f-display);font-weight:600;font-size:1.55rem;color:var(--accent);
  background:var(--accent-soft);border:1px solid rgba(169,139,255,.35);transition:.45s var(--ease)}
.member:hover .member__mono{background:var(--grad);color:#0A0712;border-color:transparent;box-shadow:0 10px 26px -12px rgba(155,108,255,.55)}
.member__name{font-family:var(--f-display);font-size:1.3rem;font-weight:600;line-height:1.1}
.member__role{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint);margin-top:.55rem}
@media(max-width:760px){.team{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.team{grid-template-columns:1fr}}

/* ---- About: manifesto pull-quote --------------------------- */
.manifesto{padding-block:clamp(2.4rem,4.5vw,4rem);text-align:center}
.manifesto__line{font-family:var(--f-display);font-weight:500;font-size:clamp(1.8rem,4.2vw,3.1rem);
  line-height:1.14;letter-spacing:-.02em;max-width:22ch;margin:0 auto;text-wrap:balance}

/* ---- Contact ----------------------------------------------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.field{margin-bottom:1.3rem}
.field label{display:block;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-faint);margin-bottom:.5rem}
.field input,.field textarea{width:100%;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:12px;
  padding:.9rem 1rem;color:var(--fg);font-family:var(--f-text);font-size:1rem;transition:border-color .3s,background .3s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--violet);background:rgba(155,108,255,.06)}
.field textarea{min-height:140px;resize:vertical}
.flash{padding:1rem 1.2rem;border-radius:12px;margin-bottom:1.2rem;font-size:.95rem;border:1px solid var(--line)}
.flash--success{background:rgba(155,108,255,.08);border-color:rgba(155,108,255,.4);color:#d9ccff}
.flash--error{background:rgba(255,122,69,.08);border-color:rgba(255,122,69,.4);color:#ffcdb8}
/* segmented toggle (Website / SaaS) */
.seg{position:relative;display:inline-flex;border:1px solid var(--line);border-radius:100px;padding:4px;gap:4px;background:rgba(255,255,255,.03);flex-wrap:wrap;max-width:100%}
.seg input{position:absolute;opacity:0;width:1px;height:1px;pointer-events:none}
.seg label{font-family:var(--f-text);font-weight:600;font-size:.95rem;padding:.6em 1.3em;border-radius:100px;cursor:pointer;color:var(--fg-dim);transition:background .3s,color .3s;white-space:nowrap}
.seg input:checked + label{background:var(--grad);color:#0A0A12}
.seg input:focus-visible + label{outline:2px solid var(--violet);outline-offset:2px}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}
.field select{width:100%;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:12px;padding:.9rem 1rem;color:var(--fg);font-family:var(--f-text);font-size:1rem;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--fg-dim) 50%),linear-gradient(135deg,var(--fg-dim) 50%,transparent 50%);background-position:calc(100% - 20px) 1.2rem,calc(100% - 14px) 1.2rem;background-size:6px 6px,6px 6px;background-repeat:no-repeat}
.field select:focus{outline:none;border-color:var(--violet);background-color:rgba(124,92,255,.06)}
.field select option{background:var(--panel-2);color:var(--fg)}
.saas-only[hidden]{display:none}
.contact-side{padding:2rem;border:1px solid var(--line);border-radius:var(--r);background:rgba(255,255,255,.015)}
.contact-side a{color:var(--cyan)}
.contact-side h4{margin-bottom:1rem}
.next-steps{list-style:none;counter-reset:ns;display:flex;flex-direction:column;gap:.7rem;margin:0 0 1.6rem}
.next-steps li{counter-increment:ns;position:relative;padding-left:2.1rem;color:var(--fg-dim);font-size:.92rem;line-height:1.5}
.next-steps li::before{content:counter(ns);position:absolute;left:0;top:.05em;width:1.4rem;height:1.4rem;border-radius:50%;
  background:var(--accent-soft);border:1px solid rgba(169,139,255,.4);color:var(--accent);
  font-family:var(--f-mono);font-size:.7rem;display:grid;place-items:center}
.contact-side p{color:var(--fg-dim);margin-bottom:1.2rem}

/* ---- Legal / prose pages ----------------------------------- */
.legal{max-width:820px;margin:0 auto}
.legal h2{font-family:var(--f-display);font-size:clamp(1.35rem,2.3vw,1.85rem);font-weight:600;letter-spacing:-.01em;margin:2.4rem 0 .8rem}
.legal h2:first-child{margin-top:0}
.legal h3{font-family:var(--f-display);font-size:1.12rem;font-weight:600;margin:1.6rem 0 .6rem}
.legal p{color:var(--fg-dim);line-height:1.72;margin-bottom:1rem}
.legal ul{list-style:disc;margin:0 0 1.2rem 1.3rem;color:var(--fg-dim);line-height:1.7;display:flex;flex-direction:column;gap:.45rem}
.legal li{padding-left:.2rem}
.legal a{color:var(--cyan);text-decoration:underline;text-underline-offset:2px}
.legal a:hover{color:var(--fg)}
.legal strong{color:var(--fg);font-weight:600}
.legal table{width:100%;border-collapse:collapse;margin:1.2rem 0;font-size:.93rem}
.legal th{text-align:left;padding:.7rem .65rem;border-bottom:1px solid var(--line);
  font-family:var(--f-mono);font-size:.68rem;letter-spacing:.07em;text-transform:uppercase;color:var(--fg-faint)}
.legal td{padding:.7rem .65rem;border-bottom:1px solid var(--line-2);color:var(--fg-dim);vertical-align:top}
.legal code{font-family:var(--f-mono);font-size:.85em;background:rgba(255,255,255,.05);padding:.15em .42em;border-radius:5px;color:var(--cyan)}
.legal__updated{font-family:var(--f-mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint);margin-top:1.1rem}

/* ---- Cookie banner ----------------------------------------- */
.cookie{position:fixed;bottom:1rem;left:1rem;right:1rem;z-index:9000;max-width:560px;margin:0 auto;
  background:rgba(14,14,22,.95);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:16px;
  padding:1.2rem 1.4rem;display:flex;gap:1rem;align-items:center;justify-content:space-between;flex-wrap:wrap;
  box-shadow:0 20px 60px -20px rgba(0,0,0,.8)}
.cookie[hidden]{display:none}
.cookie p{font-size:.85rem;color:var(--fg-dim)}
.cookie a{color:var(--cyan)}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:1024px){
  .process,.prod-grid,.stats,.principles{grid-template-columns:repeat(2,1fr)}
  .faq-grid{grid-template-columns:1fr;gap:1.5rem}
  .work-grid{grid-template-columns:1fr}
  .contact-grid,.about-split{grid-template-columns:1fr}
}
@media(max-width:860px){
  .sb-nav__links,.sb-nav > .btn{display:none}
  .sb-burger{display:block}
  .sb-footer__grid{grid-template-columns:1fr 1fr;gap:2rem}
  .caps{grid-template-columns:1fr;gap:1rem}
}
@media(max-width:560px){
  .process,.prod-grid,.stats,.principles{grid-template-columns:1fr}
  .hero__trust{gap:.8rem 1.2rem}
  .reel-card{flex-basis:88vw}
  .stats{gap:2rem 1.4rem}
  /* compact footer: brand on top, link lists in a tight 3-col row */
  .sb-footer{padding-block:2.6rem 1.4rem}
  .sb-footer__grid{grid-template-columns:repeat(3,1fr);gap:1.6rem 1rem}
  .sb-footer__grid > :first-child{grid-column:1 / -1;margin-bottom:.2rem}
  .sb-footer p{max-width:none;margin-top:.6rem;font-size:.88rem}
  .sb-footer h5{margin-bottom:.7rem}
  .sb-footer__grid ul{gap:.5rem}
  .sb-footer__grid a{font-size:.88rem}
  .sb-footer__meta{margin-top:1.8rem;padding-top:1.1rem;font-size:.66rem}
}
@media(max-width:380px){
  .sb-footer__grid{grid-template-columns:repeat(2,1fr)}
}
/* keep header tidy + nothing cut off at the smallest widths */
@media(max-width:360px){
  .sb-header__bar{padding-inline:1rem;gap:.5rem}
  .sb-logo{font-size:1.05rem}
  .sb-logo__full{height:30px}
}

/* ---- Mobile: swipeable showreel + collapsible sections ----- */
.macc-toggle{display:none}
@media(max-width:768px){
  /* showreel becomes a swipe carousel (not the slow auto-marquee) */
  .reel__viewport{overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .reel__viewport::-webkit-scrollbar{display:none}
  .reel__row{animation:none;pointer-events:auto;gap:1rem;width:max-content}
  .reel-card{scroll-snap-align:center;flex-basis:84vw}
  .reel-card[aria-hidden="true"]{display:none}

  /* collapsible (tap-to-expand) sections */
  [data-macc-h]{cursor:pointer;align-items:center}
  [data-macc] .sec-head,[data-macc] .pin__head{display:flex;align-items:center;gap:1rem;margin-bottom:0}
  [data-macc] .sec-head > p{display:none}
  [data-macc] [data-macc-body]{display:none}
  [data-macc].is-open [data-macc-body]{display:block;margin-top:2.4rem}
  .macc-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex:none;
    margin-left:auto;border:1px solid var(--line);border-radius:50%;color:var(--cyan);
    font-family:var(--f-mono);font-size:1.3rem;line-height:1;transition:transform .35s var(--ease)}
  [data-macc].is-open .macc-toggle{transform:rotate(45deg)}
}

/* ---- Reduced motion ---------------------------------------
   This is a SHOWCASE site for a studio whose whole pitch is motion —
   and the owner's own device requests reduced-motion. So, like the
   marquee house rule, the signature motion (canvas, gradient shimmer,
   hero entrance, scroll reveals) intentionally keeps running for
   everyone. We only drop the jumpiest scroll-coupled bits + smooth
   scrolling so it never feels nauseating. */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  [data-parallax]{transform:none!important}
}
.no-js .reveal,.no-js [data-stagger] > *{opacity:1;transform:none}
.no-js .preload{display:none}
.no-js .hero__title .ln > span,.no-js .hero__lede,.no-js .hero__actions,.no-js .hero__trust{transform:none;opacity:1}
