:root{
  --bone:#F0EEE6;
  --ink:#070707;
  --ink-2:#0c0c0d;
  --red:#E0102E;
  --red-dim:#7a0a1a;
  --gold:#C8A04B;
  --cyan:#7FE8E0;
  --dim:#6f6c66;
  --line:rgba(240,238,230,.10);
  --mono:'JetBrains Mono', ui-monospace, monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto}
html,body{height:auto}
body{
  background:var(--ink);
  color:var(--bone);
  font-family:var(--mono);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--red);color:var(--bone)}
a{color:inherit;text-decoration:none}
canvas{display:block}
.kicker{font-size:11px;letter-spacing:4px;color:var(--red);text-transform:uppercase;font-weight:700}

/* hide native cursor on devices that support the custom one */
@media (hover:hover) and (pointer:fine){ body{cursor:none} a,[data-mag]{cursor:none} }

/* ---------- CRT flavor ---------- */
.crt-scan,.crt-vignette,.crt-flicker{position:fixed;inset:0;pointer-events:none;z-index:90}
.crt-scan{
  background:repeating-linear-gradient(0deg,rgba(0,0,0,0) 0,rgba(0,0,0,0) 2px,rgba(0,0,0,.16) 3px,rgba(0,0,0,0) 4px);
  mix-blend-mode:multiply;opacity:.45;
}
.crt-vignette{background:radial-gradient(125% 125% at 50% 45%,transparent 58%,rgba(0,0,0,.62) 100%)}
.crt-flicker{background:var(--bone);opacity:0;animation:flick 8s infinite steps(1)}
@keyframes flick{0%,97%,100%{opacity:0}97.5%{opacity:.012}98.6%{opacity:.03}99%{opacity:.008}}

/* ---------- magnetic cursor ---------- */
.cursor{position:fixed;top:0;left:0;z-index:100;pointer-events:none;mix-blend-mode:difference;
  transform:translate(-50%,-50%);will-change:transform}
.cursor__ring{position:absolute;top:50%;left:50%;width:34px;height:34px;border:1px solid var(--bone);
  border-radius:50%;transform:translate(-50%,-50%);transition:width .25s,height .25s,opacity .25s;opacity:.7}
.cursor__dot{position:absolute;top:50%;left:50%;width:5px;height:5px;background:var(--bone);border-radius:50%;
  transform:translate(-50%,-50%)}
.cursor.hot .cursor__ring{width:52px;height:52px;opacity:1;border-color:var(--red)}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

/* ---------- loader ---------- */
.loader{position:fixed;inset:0;z-index:120;background:var(--ink);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:26px;transition:opacity .6s ease}
.loader.done{opacity:0;pointer-events:none}
.loader__art{color:var(--red);font-weight:800;line-height:1;font-size:clamp(5px,1.25vw,13px);
  letter-spacing:1px;white-space:pre;text-shadow:0 0 22px rgba(224,16,46,.5)}
.loader__bar{width:min(360px,72vw);height:2px;background:rgba(240,238,230,.12);overflow:hidden}
.loader__bar i{display:block;height:100%;width:0;background:var(--red);box-shadow:0 0 12px var(--red)}
.loader__pct{font-size:11px;letter-spacing:3px;color:var(--dim)}
.loader__pct span{color:var(--bone)}

/* ---------- fixed chrome ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;display:flex;align-items:center;justify-content:space-between;
  padding:18px 26px;mix-blend-mode:difference}
.nav__logo{font-weight:800;font-size:17px;letter-spacing:-.5px;color:var(--bone)}
.nav__logo span{color:var(--red)}
.nav__meta{display:flex;gap:10px;font-size:11px;letter-spacing:1.5px;color:var(--bone);text-transform:uppercase}
.nav__sep{opacity:.4}
.scrollbar{position:fixed;top:0;left:0;right:0;height:2px;z-index:81;background:transparent}
.scrollbar i{display:block;height:100%;width:0;background:var(--red);box-shadow:0 0 10px var(--red)}

/* ---------- HERO ---------- */
.hero{position:relative;height:100svh;min-height:600px;overflow:hidden;display:flex;align-items:center}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;opacity:.42;
  filter:saturate(1.1) contrast(1.05);transform:scale(1.06)}
.hero__grad{position:absolute;inset:0;z-index:1;
  background:radial-gradient(70% 90% at 28% 50%,transparent,rgba(7,7,7,.72) 75%),
             linear-gradient(180deg,rgba(7,7,7,.35),transparent 30%,rgba(7,7,7,.55))}
.hero__inner{position:relative;z-index:2;padding:0 clamp(22px,6vw,90px);max-width:1100px}
.hero__kicker{display:flex;align-items:center;gap:10px;font-size:12px;letter-spacing:3px;color:var(--dim);
  text-transform:uppercase;margin-bottom:26px}
.dotpulse{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan);
  animation:dp 1.2s infinite}
@keyframes dp{50%{opacity:.3}}
.hero__title{font-weight:800;line-height:.92;letter-spacing:-.03em;
  font-size:clamp(52px,11.5vw,176px);text-transform:uppercase}
.hero__title .line{display:block;overflow:hidden}
.hero__title .w{display:inline-block;will-change:transform}
.hero__title .accent{color:var(--red);text-shadow:0 0 40px rgba(224,16,46,.4)}
.hero__sub{margin-top:30px;max-width:520px;font-size:clamp(13px,1.5vw,16px);line-height:1.7;color:var(--bone);opacity:.82}
.hero__scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;display:flex;
  flex-direction:column;align-items:center;gap:10px;font-size:10px;letter-spacing:3px;color:var(--dim);text-transform:uppercase}
.hero__scroll i{width:1px;height:46px;background:linear-gradient(var(--red),transparent);
  animation:scl 1.8s infinite}
@keyframes scl{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}
  50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;
  background:var(--ink-2);padding:22px 0;white-space:nowrap}
.marquee__track{display:inline-block;will-change:transform;font-weight:800;font-size:clamp(26px,5vw,64px);
  letter-spacing:-.02em;text-transform:uppercase}
.marquee__track .g{color:transparent;-webkit-text-stroke:1px var(--dim);padding:0 .35em}
.marquee__track .r{color:var(--red);padding:0 .35em}
.marquee__track .b{color:var(--bone);padding:0 .35em}

/* ---------- THE REEL (scrub) ---------- */
.scrub{position:relative;height:520vh}
.scrub__pin{position:sticky;top:0;height:100svh;display:grid;grid-template-columns:1.35fr 1fr;
  align-items:center;gap:clamp(20px,4vw,60px);padding:0 clamp(22px,5vw,80px);overflow:hidden}
.scrub__stage{position:relative;width:100%;aspect-ratio:150/42;max-height:78vh;display:flex;
  align-items:center;justify-content:center;background:
  radial-gradient(80% 80% at 50% 50%,rgba(20,20,22,.5),transparent);border:1px solid var(--line)}
#scrubCanvas{max-width:100%;max-height:100%;image-rendering:pixelated;
  filter:drop-shadow(0 0 1px rgba(127,232,224,.18))}
.scrub__loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:8px}
.scrub__loading.hide{display:none}
.scrub__loading i{width:8px;height:8px;background:var(--red);animation:ld 1s infinite ease-in-out}
.scrub__loading i:nth-child(2){animation-delay:.15s}.scrub__loading i:nth-child(3){animation-delay:.3s}
@keyframes ld{0%,100%{opacity:.2;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1.4)}}
.scrub__copy{max-width:380px}
.scrub__head{font-weight:800;font-size:clamp(30px,4.6vw,62px);line-height:.96;letter-spacing:-.02em;
  text-transform:uppercase;margin:18px 0 22px}
.scrub__txt{font-size:14px;line-height:1.7;color:var(--bone);opacity:.8;margin-bottom:26px}
.scrub__txt #scrubCps{color:var(--cyan)}
.scrub__bar{width:100%;height:2px;background:rgba(240,238,230,.12);overflow:hidden;margin-bottom:12px}
.scrub__bar i{display:block;height:100%;width:0;background:var(--red);box-shadow:0 0 10px var(--red)}
.scrub__meta{font-size:11px;letter-spacing:2px;color:var(--dim)}
.scrub__meta span{color:var(--bone)}

/* ---------- GALLERY SECTIONS ---------- */
.sec{position:relative;padding:clamp(80px,12vh,160px) clamp(22px,5vw,80px)}
.sec__head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;
  margin-bottom:clamp(40px,7vh,90px);border-bottom:1px solid var(--line);padding-bottom:22px}
.sec__h{font-weight:800;font-size:clamp(38px,7vw,108px);line-height:.9;letter-spacing:-.03em;text-transform:uppercase}
.sec__h .w{display:inline-block;will-change:transform}
.sec__blurb{max-width:300px;font-size:13px;line-height:1.65;color:var(--bone);opacity:.7;text-align:right}
.sec__kick{font-size:11px;letter-spacing:3px;color:var(--red);margin-bottom:14px;text-transform:uppercase}

.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(14px,2vw,28px)}
.tile{position:relative;border:1px solid var(--line);background:var(--ink-2);overflow:hidden;
  display:flex;align-items:center;justify-content:center;min-height:0}
.tile canvas{width:100%;height:100%;object-fit:contain;image-rendering:pixelated}
.tile__cap{position:absolute;left:12px;bottom:10px;z-index:3;font-size:11px;letter-spacing:2px;
  text-shadow:0 1px 6px rgba(0,0,0,.9);pointer-events:none}
.tile__cap b{color:var(--bone);font-weight:700}
.tile__cap span{color:var(--red)}
.tile__idx{position:absolute;right:12px;top:8px;z-index:3;font-size:10px;color:var(--dim);letter-spacing:1px}
.tile__load{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;
  font-size:10px;letter-spacing:3px;color:var(--dim)}
.tile__load.hide{display:none}
.tile__badge{position:absolute;left:12px;top:8px;z-index:3;font-size:9px;letter-spacing:1px;color:var(--cyan);
  border:1px solid rgba(127,232,224,.4);padding:1px 5px;border-radius:2px}
.tile::after{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent 60%,rgba(7,7,7,.55))}

/* span helpers */
.s12{grid-column:span 12}.s8{grid-column:span 8}.s6{grid-column:span 6}.s5{grid-column:span 5}
.s4{grid-column:span 4}.s7{grid-column:span 7}
.tile[data-ar]{aspect-ratio:var(--ar)}

/* reveal */
.reveal{opacity:0;transform:translateY(46px)}
.reveal.in{opacity:1;transform:none;transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}

/* ---------- OUTRO ---------- */
.outro{position:relative;padding:clamp(90px,14vh,180px) clamp(22px,5vw,80px) 80px;text-align:center;
  border-top:1px solid var(--line)}
.outro__stats{display:flex;flex-wrap:wrap;gap:clamp(24px,6vw,80px);justify-content:center;margin-bottom:80px}
.stat{display:flex;flex-direction:column;gap:6px}
.stat b{font-size:clamp(34px,5vw,64px);font-weight:800;color:var(--red);line-height:1}
.stat span{font-size:11px;letter-spacing:2px;color:var(--dim);text-transform:uppercase}
.outro__title{font-weight:800;font-size:clamp(46px,11vw,150px);line-height:.9;letter-spacing:-.03em;text-transform:uppercase}
.outro__title .w{display:inline-block}
.outro__title .accent{color:var(--red);text-shadow:0 0 40px rgba(224,16,46,.4)}
.outro__sub{margin:26px auto 0;max-width:440px;font-size:14px;line-height:1.7;color:var(--bone);opacity:.78}
.outro__links{display:flex;gap:30px;justify-content:center;margin:50px 0 60px;font-size:13px;letter-spacing:2px;
  text-transform:uppercase}
.outro__links a{position:relative;padding-bottom:4px;color:var(--bone)}
.outro__links a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--red);
  transition:width .3s}
.outro__links a:hover{color:var(--red)}.outro__links a:hover::after{width:100%}
.outro__sig{font-size:11px;letter-spacing:2px;color:var(--dim)}

.accent{color:var(--red)}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .scrub__pin{grid-template-columns:1fr;grid-template-rows:auto auto;align-content:center;gap:24px;padding-top:90px}
  .scrub{height:420vh}
  .scrub__copy{max-width:none}
  .s8,.s6,.s5,.s4,.s7{grid-column:span 12}
  .s5,.s4{grid-column:span 6}
}
@media (max-width:560px){
  .sec__blurb{text-align:left}
  .s5,.s4{grid-column:span 12}
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none}
  .crt-flicker,.dotpulse,.hero__scroll i,.scrub__loading i{animation:none}
  .hero__bg{transform:none}
}
