/* Mind Over Image — Portfolio Homepage
   System: black canvas, bone foreground, neon accents pulled from the loop.
   Type pair: Anton (display) + Archivo Black (chunky) + JetBrains Mono (tech).
*/

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Archivo+Black&family=JetBrains+Mono:wght@400;500;700&family=Permanent+Marker&display=swap');

:root{
  --bg:#000;
  --ink:#f6f5f0;
  --ink-2:rgba(246,245,240,.62);
  --ink-3:rgba(246,245,240,.32);
  --hair:rgba(246,245,240,.14);
  --hair-2:rgba(246,245,240,.06);
  --accent:#ff2e88;        /* hot pink — overridden by tweak */
  --accent-2:#ffe600;      /* acid yellow */
  --chrome-pad:14px;
  --rail:38px;
  --header-h:54px;
  --footer-h:38px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:#000;color:var(--ink);
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:12px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
html{height:100%;scroll-behavior:smooth;}
body{min-height:100%;cursor:none;overflow-x:hidden;
  scroll-snap-type:y mandatory;
  overscroll-behavior:none;
}
/* Sticky stack mode: drop snap and let sections pin instead */
body:has(.page[data-fx="stack"]){
  scroll-snap-type:none;
}
.page[data-fx="stack"] .section{
  position:sticky;
  top:0;
  height:100vh;
  scroll-snap-align:none;
  /* later sections naturally paint on top → covering effect */
}
/* Cancel any one-shot entrance animation in stack mode */
.page[data-fx="stack"] .section.entering{animation:none;}
img,svg,video{display:block;max-width:100%}

/* ─── Section transition animations (Tweak: scrollFx) ────────────── */
/* Triggered by an .entering class added once when a section snaps in. */

.page[data-fx="peel"], .page[data-fx="warp"]{ perspective:1400px; }
.section{ will-change:transform, opacity, filter, clip-path; }

/* Zoom pop — section pops in from 80% scale with brief blur */
.page[data-fx="zoom"] .section.entering{
  animation:fxZoom 900ms cubic-bezier(.22,1,.36,1) both;
}
@keyframes fxZoom{
  0%   {opacity:0; transform:scale(.78); filter:blur(14px)}
  60%  {opacity:1}
  100% {opacity:1; transform:scale(1); filter:blur(0)}
}

/* 3D Peel — section folds in like a page */
.page[data-fx="peel"] .section.entering{
  animation:fxPeel 1100ms cubic-bezier(.22,1,.36,1) both;
  transform-style:preserve-3d;
}
@keyframes fxPeel{
  0%   {opacity:0; transform-origin:top center;
        transform:perspective(1400px) rotateX(32deg) translateY(140px) translateZ(-260px)}
  60%  {opacity:1}
  100% {opacity:1; transform:perspective(1400px) rotateX(0) translateY(0) translateZ(0)}
}

/* Blur slide — slides up + sharpens */
.page[data-fx="blur"] .section.entering{
  animation:fxBlur 900ms cubic-bezier(.22,1,.36,1) both;
}
@keyframes fxBlur{
  0%   {opacity:0; transform:translateY(120px); filter:blur(22px) saturate(3)}
  100% {opacity:1; transform:translateY(0);     filter:blur(0)   saturate(1)}
}

/* Glitch cut — clip-path slices + chromatic hue thrash */
.page[data-fx="glitch"] .section.entering{
  animation:fxGlitch 750ms steps(12, end) both;
}
@keyframes fxGlitch{
  0%   {opacity:0; clip-path:inset(0 0 100% 0); filter:hue-rotate(120deg) saturate(3) contrast(1.4); transform:translateX(20px)}
  20%  {opacity:1; clip-path:inset(0 30% 0 0);  filter:hue-rotate(60deg) saturate(2);  transform:translateX(-12px)}
  40%  {opacity:1; clip-path:inset(0 0 0 25%);  filter:hue-rotate(-40deg) saturate(2.4); transform:translateX(8px)}
  60%  {opacity:1; clip-path:inset(20% 0 0 0);  filter:hue-rotate(90deg) contrast(1.2);  transform:translateX(-4px)}
  80%  {opacity:1; clip-path:inset(0 10% 0 0);  filter:none;  transform:translateX(0)}
  100% {opacity:1; clip-path:inset(0);          filter:none;  transform:translateX(0)}
}

/* Cinema fade — letterbox bars open to reveal */
.page[data-fx="cinema"] .section.entering{
  animation:fxCinema 1100ms cubic-bezier(.22,1,.36,1) both;
}
@keyframes fxCinema{
  0%   {opacity:0; clip-path:inset(50% 0); filter:contrast(1.6) brightness(.5)}
  40%  {opacity:1}
  100% {opacity:1; clip-path:inset(0);     filter:none}
}

/* Hyperspace warp — flies in from the depth */
.page[data-fx="warp"] .section.entering{
  animation:fxWarp 1100ms cubic-bezier(.22,1,.36,1) both;
}
@keyframes fxWarp{
  0%   {opacity:0; transform:perspective(900px) translateZ(-900px) rotateZ(8deg); filter:blur(28px) hue-rotate(180deg) saturate(2.5)}
  60%  {opacity:1}
  100% {opacity:1; transform:perspective(900px) translateZ(0)     rotateZ(0);    filter:none}
}

@media (prefers-reduced-motion: reduce){
  .page[data-fx] .section.entering{animation:none !important;}
}

/* ─── Page sections ─────────────────────────────────────────────────── */
.page{position:relative;}
.section{position:relative;height:100vh;overflow:hidden;scroll-snap-align:start;
  background:var(--bg);}

/* Fixed chrome overlay shared site-wide */
.chrome-fixed{position:fixed;inset:0;pointer-events:none;display:grid;
  grid-template-rows:var(--header-h) minmax(0,1fr) var(--footer-h);
  grid-template-columns:var(--rail) minmax(0,1fr) var(--rail);
  z-index:50;
}
.chrome-fixed > *{pointer-events:auto}

/* ─── Stage (hero section) ──────────────────────────────────────────── */
.stage{position:relative;width:100%;height:100%;background:var(--bg);overflow:hidden;}

/* Video layer — fills viewport behind chrome */
.loop{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  background:#000;will-change:transform;}

/* Centered-frame mode wraps the video in a maxed-out 16:9 box w/ margin. */
.stage[data-layout="centered"] .loop-wrap{
  position:absolute;inset:0;display:grid;place-items:center;padding:90px 60px 130px;
}
.stage[data-layout="centered"] .loop{position:relative;width:min(100%,calc((100vh - 220px) * 16/9));aspect-ratio:16/9;height:auto;inset:auto;
  border:1px solid var(--hair);box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.04);}

.stage[data-layout="split"] .loop-wrap{
  position:absolute;left:50%;right:0;top:64px;bottom:108px;display:grid;place-items:center;padding:0 24px 0 0;
}
.stage[data-layout="split"] .loop{position:relative;width:100%;height:100%;inset:auto;object-fit:cover;border:1px solid var(--hair);}

.stage[data-layout="mini"] .loop-wrap{
  position:absolute;right:24px;bottom:120px;width:min(38vw,520px);aspect-ratio:16/9;
  border:1px solid var(--hair);box-shadow:0 30px 80px rgba(0,0,0,.6);
  outline:3px solid var(--accent);outline-offset:-3px;
}
.stage[data-layout="mini"] .loop{position:relative;width:100%;height:100%;inset:auto;}

/* Vignette + grain to keep overlay text legible */
.vignette{position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% 50%,transparent 55%,rgba(0,0,0,.55) 100%),
    linear-gradient(180deg,rgba(0,0,0,.55) 0,transparent 14%,transparent 76%,rgba(0,0,0,.7) 100%);
  mix-blend-mode:multiply;
}
.grain{position:absolute;inset:0;pointer-events:none;opacity:.22;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size:160px 160px;
  animation:grain 1.2s steps(6) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)} 20%{transform:translate(-3%,2%)}
  40%{transform:translate(2%,-1%)} 60%{transform:translate(-1%,3%)}
  80%{transform:translate(3%,-2%)} 100%{transform:translate(0,0)}
}

/* Scanlines option */
.stage[data-grain="off"] .grain{display:none}

/* ─── Chrome: header ───────────────────────────────────────────────── */
.chrome{position:absolute;inset:0;pointer-events:none;display:grid;
  grid-template-rows:var(--header-h) minmax(0,1fr) var(--footer-h);
  grid-template-columns:var(--rail) minmax(0,1fr) var(--rail);
  display:none;
}
.chrome > *{pointer-events:auto}

.hd{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;
  padding:0 18px;border-bottom:1px solid var(--hair-2);
  background:linear-gradient(180deg,rgba(0,0,0,.55),transparent);
  backdrop-filter:blur(2px);}
.hd .left,.hd .right,.hd .center{display:flex;align-items:center;gap:14px}
.hd .center{position:absolute;left:50%;top:0;height:var(--header-h);transform:translateX(-50%);
  display:flex;align-items:center;}

.brand{font-family:'Archivo Black',sans-serif;font-size:14px;letter-spacing:.04em;color:var(--ink);
  display:flex;align-items:center;gap:9px;}
.brand .blob{width:11px;height:11px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 16px var(--accent);}
.brand .blob-blue{background:#1f7aff;box-shadow:0 0 16px #1f7aff;}
.brand sup{font-family:'JetBrains Mono',monospace;font-size:8px;color:var(--ink-3);
  font-weight:400;letter-spacing:.05em;margin-left:-3px;align-self:flex-start;margin-top:4px;}

.onair{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:.18em;color:var(--ink-2);text-transform:uppercase;
  padding:6px 10px;border:1px solid var(--hair);border-radius:999px;}
.onair .dot{width:7px;height:7px;border-radius:50%;background:#ff3a3a;box-shadow:0 0 10px #ff3a3a;
  animation:blink 1.4s infinite;}
@keyframes blink{0%,60%{opacity:1}65%,100%{opacity:.2}}

.nav{display:flex;gap:2px}
.nav a{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-2);text-decoration:none;padding:7px 11px;
  border-radius:6px;position:relative;}
.nav a:hover{color:var(--ink);background:rgba(255,255,255,.05)}
.nav a .idx{color:var(--ink-3);margin-right:6px;font-size:9px}
.nav a .arr{display:inline-block;margin-left:6px;opacity:0;transform:translateX(-3px);transition:.2s}
.nav a:hover .arr{opacity:1;transform:translateX(0)}

/* ─── Side rails ───────────────────────────────────────────────────── */
.rail{display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  padding:18px 0;color:var(--ink-3);}
.rail .v{writing-mode:vertical-rl;transform:rotate(180deg);font-size:9.5px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--ink-2);}
.rail.left .v{color:var(--ink)}
.rail .ticks{display:flex;flex-direction:column;gap:6px;align-items:center;padding:14px 0;}
.rail .ticks span{width:6px;height:1px;background:var(--ink-3);}
.rail .ticks span:nth-child(5n){width:14px;background:var(--ink);}

/* Side rails are decorative now — pass clicks through to the content below */
.chrome-fixed .rail{pointer-events:none}

/* ─── Main center stage area — slogan tags ─────────────────────────── */
.stagebody{position:relative;min-height:0;min-width:0;overflow:hidden;padding:18px 24px 8px;}

.corner-tags{position:absolute;left:24px;top:14px;display:flex;flex-direction:column;gap:6px;}
.corner-tags-r{position:absolute;right:24px;top:14px;display:flex;flex-direction:column;gap:6px;align-items:flex-end;}

.tag{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--ink-2);
  letter-spacing:.12em;text-transform:uppercase;
  background:rgba(0,0,0,.45);border:1px solid var(--hair);
  padding:5px 9px;border-radius:4px;backdrop-filter:blur(6px);display:inline-flex;gap:8px;align-items:center;}
.tag .k{color:var(--ink-3)}
.tag .v{color:var(--ink)}
.tag.acc{border-color:var(--accent);color:var(--accent);}
.tag.acc .v{color:var(--accent)}

/* Drift slogan in stage center — pinned to corners so video centerpiece stays visible */
.bigword{font-family:'Anton',sans-serif;font-size:clamp(40px,7.4vw,120px);line-height:.85;
  text-transform:uppercase;letter-spacing:-.01em;color:var(--ink);
  text-shadow:0 4px 24px rgba(0,0,0,.6);
  pointer-events:none;
}
.bigword .stroke{-webkit-text-stroke:1.5px var(--ink);color:transparent;}
.bigword .acc{color:var(--accent);}

.stage-slogan{position:absolute;left:24px;bottom:18px;max-width:46%;}
.stage-slogan .kicker{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-3);margin-bottom:8px;display:flex;gap:8px;align-items:center;}
.stage-slogan .kicker::before{content:"";width:24px;height:1px;background:var(--accent);}

.stage-slogan-r{position:absolute;right:24px;bottom:18px;max-width:38%;text-align:right;font-family:'JetBrains Mono',monospace;
  font-size:11px;line-height:1.55;color:var(--ink-2);}
.stage-slogan-r b{color:var(--ink);font-weight:500;letter-spacing:.04em;text-transform:uppercase;font-size:9.5px;display:block;margin-bottom:4px;color:var(--accent);}

/* ─── Footer: marquee + transport ──────────────────────────────────── */
.ft{grid-column:1 / -1;display:grid;grid-template-rows:auto auto;border-top:1px solid var(--hair-2);
  background:linear-gradient(0deg,rgba(0,0,0,.65),transparent);backdrop-filter:blur(2px);}

.marq{height:38px;overflow:hidden;position:relative;
  display:flex;align-items:center;}
.marq-track{display:flex;align-items:center;gap:36px;white-space:nowrap;
  animation:scroll 38s linear infinite;will-change:transform;}
.marq-track.rev{animation-direction:reverse}
.marq:hover .marq-track{animation-play-state:paused}
.marq span{font-family:'Anton',sans-serif;font-size:20px;letter-spacing:.02em;
  text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:36px}
.marq span::after{content:"✦";color:var(--accent);font-family:serif;font-size:14px;}
.marq span.acc{color:var(--accent);}
.marq span.outline{-webkit-text-stroke:1px var(--ink);color:transparent;}
@keyframes scroll{from{transform:translateX(0)} to{transform:translateX(-50%)}}

.transport{display:grid;grid-template-columns:auto 1fr auto auto auto;gap:18px;align-items:center;
  padding:0 18px;height:58px;}

.now{display:flex;align-items:center;gap:12px;}
.now .badge{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.16em;
  text-transform:uppercase;color:#000;background:var(--accent);padding:3px 6px;border-radius:3px;font-weight:700;}
.now .label{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--ink-2);
  letter-spacing:.06em;text-transform:uppercase;}
.now .label b{color:var(--ink);font-weight:500;}

.scrub{display:flex;align-items:center;gap:10px;color:var(--ink-3);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.06em;}
.scrub .bar{flex:1;height:2px;background:var(--hair);position:relative;border-radius:1px;cursor:pointer;}
.scrub .fill{position:absolute;left:0;top:0;height:100%;background:var(--ink);}
.scrub .head{position:absolute;top:50%;width:8px;height:8px;background:var(--accent);transform:translate(-50%,-50%);border-radius:50%;box-shadow:0 0 10px var(--accent);}

.tbtn{appearance:none;background:transparent;border:1px solid var(--hair);color:var(--ink);
  padding:6px 10px;border-radius:6px;font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;cursor:none;display:inline-flex;gap:7px;align-items:center;}
.tbtn:hover{border-color:var(--ink);background:rgba(255,255,255,.06)}
.tbtn.on{color:var(--accent);border-color:var(--accent);}
.tbtn .ico{width:10px;height:10px;display:inline-block;}

/* ─── Custom cursor (splash trail) ─────────────────────────────────── */
/* A full-viewport canvas paints blue paint splashes that trail the
   pointer; a tight inverted-difference dot tracks the true position. */
.cursor-canvas{
  position:fixed;inset:0;
  pointer-events:none;
  z-index:2147483638;
  mix-blend-mode:screen;
  transition:opacity .25s ease;
  will-change:opacity;
}
.cursor-dot{
  position:fixed;left:0;top:0;
  width:10px;height:10px;border-radius:50%;
  background:#fff;
  mix-blend-mode:difference;
  pointer-events:none;
  z-index:2147483640;
  will-change:transform;
  transition:width .2s cubic-bezier(.22,1,.36,1),
             height .2s cubic-bezier(.22,1,.36,1),
             background .2s ease,
             opacity .2s ease;
}
.cursor-dot.hot{
  width:42px;height:42px;
  background:rgba(255,255,255,0);
  border:1.5px solid #fff;
  mix-blend-mode:difference;
}

/* ─── About section ─────────────────────────────────────────────────── */
.about{position:relative;}
.about .about-frame{position:absolute;
  top:calc(var(--header-h) + 16px);
  right:32px;
  bottom:calc(var(--footer-h) + 16px);
  left:32px;
}
.about video{width:100%;height:100%;object-fit:contain;background:#000;display:block;}
.about .grain{position:absolute;inset:0;pointer-events:none;}
.about .vignette{position:absolute;inset:0;
  background:radial-gradient(120% 90% at 50% 50%,transparent 60%,rgba(0,0,0,.5) 100%);
  pointer-events:none;mix-blend-mode:multiply;}

/* ─── Work section ─────────────────────────────────────────────────── */
.work{position:relative;}
.work .work-frame{position:absolute;inset:0;container-type:size;overflow:hidden;background:#000;}
.work .work-inner{position:absolute;inset:0;overflow:hidden;}
.work .work-frame .video-mask{position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:max(100cqw, calc(100cqh * 16 / 9));
  aspect-ratio:16/9;
}
.work .video-mask video{position:absolute;inset:0;width:100%;height:100%;display:block;object-fit:fill;}

/* 3×2 grid of small 16:9 tiles, centered in the available black area
   under the painted "MY WORK" title. Positions are % of the 16:9 mask. */
.work .work-grid{position:absolute;
  left:16%;
  top:30%;
  width:68%;
  height:58%;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  grid-template-rows:repeat(2, 1fr);
  gap:1.8cqh 1.8cqw;
}
.work .work-tile{
  position:relative;
  aspect-ratio:16/9;
  align-self:center;
  background:#000;
  border:1px solid rgba(255,255,255,.16);
  border-radius:3px;
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;color:var(--ink-2);
  box-shadow:0 8px 28px rgba(0,0,0,.55);
  cursor:none;
  transition:transform .22s ease, border-color .22s ease, box-shadow .22s ease, background .22s ease;
  overflow:hidden;
}
.work .work-tile::before{
  /* subtle scanline-ish texture so the tile reads as a video placeholder */
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(180deg,
    rgba(255,255,255,.025) 0 1px, transparent 1px 3px);
  pointer-events:none;
}
.work .work-tile .num{
  font-family:'Anton',sans-serif;
  font-size:clamp(20px, 4cqh, 56px);
  letter-spacing:.02em;
  color:rgba(246,245,240,.32);
  transition:color .22s ease;
  position:relative;z-index:2;
}
.work .work-tile .tile-thumb{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;display:block;
  opacity:.85;
  transition:opacity .25s ease, transform .35s ease;
  z-index:1;
}
.work .work-tile:hover .tile-thumb{
  opacity:1;
  transform:scale(1.04);
}
/* Subtle dark veil over the thumbnail so the play arrow reads on hover */
.work .work-tile::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.0) 30%,rgba(0,0,0,.55) 100%);
  opacity:0;transition:opacity .25s ease;
  z-index:2;pointer-events:none;
}
.work .work-tile:hover::after{opacity:1;}
.work .work-tile .play{
  position:absolute;
  font-size:clamp(14px, 3.6cqh, 44px);
  color:rgba(246,245,240,.0);
  transform:translateY(2px);
  transition:color .22s ease, transform .22s ease, text-shadow .22s ease;
  pointer-events:none;
  z-index:3;
}
.work .work-tile:hover{
  transform:scale(1.04);
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent), 0 14px 38px rgba(0,0,0,.7), 0 0 36px rgba(255,46,136,.35);
  background:#0a0a0a;
}
.work .work-tile:hover .num{
  color:rgba(246,245,240,.0);
}
.work .work-tile:hover .play{
  color:#fff;
  transform:scale(1.25);
  text-shadow:0 0 14px rgba(255,255,255,.6), 0 0 36px var(--accent);
}

/* ─── Tools section ────────────────────────────────────────────────── */
.tools{position:relative;}
.tools .tools-frame{position:absolute;inset:0;container-type:size;overflow:hidden;background:#000;}
.tools .tools-inner{position:absolute;inset:0;overflow:hidden;}
.tools .tools-mask{position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  /* Source video is 2206×946 ≈ 2.333:1 — keep that exact aspect so layout doesn't squish */
  width:max(100cqw, calc(100cqh * 2206 / 946));
  aspect-ratio:2206 / 946;
}
.tools .tools-mask video{position:absolute;inset:0;width:100%;height:100%;display:block;object-fit:fill;}

/* ─── Pop-out player modal ─────────────────────────────────────────── */
.player-modal{position:fixed;inset:0;
  background:rgba(0,0,0,.92);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  z-index:2147483645;
  display:flex;align-items:center;justify-content:center;
  padding:max(40px, 6vh) max(40px, 6vw);
  cursor:none;
  animation:modalFade .22s ease;
}
@keyframes modalFade{from{opacity:0}to{opacity:1}}
.player-frame{
  position:relative;
  width:100%;height:100%;
  max-width:calc(min(92vh, 900px) * 16/9);
  max-height:calc(min(96vw, 1600px) * 9/16);
  aspect-ratio:16/9;
  background:#000;
  border:1px solid rgba(255,255,255,.12);
  border-radius:6px;
  overflow:hidden;
  box-shadow:0 40px 100px rgba(0,0,0,.85), 0 0 60px rgba(255,46,136,.18);
}
.player-frame iframe{width:100%;height:100%;border:0;display:block;background:#000;}
.player-close{
  position:absolute;top:-46px;right:0;
  width:36px;height:36px;
  background:transparent;
  border:1px solid rgba(255,255,255,.4);
  color:#fff;
  font-family:'JetBrains Mono',monospace;
  font-size:20px;line-height:1;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:none;
  transition:background .15s, border-color .15s, color .15s, transform .15s;
}
.player-close:hover{
  background:var(--accent);
  border-color:var(--accent);
  color:#000;
  transform:scale(1.08);
}
.player-meta{
  position:absolute;top:-38px;left:0;
  display:inline-flex;align-items:center;gap:9px;
  font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(255,255,255,.7);
}
.player-meta .dot{
  width:7px;height:7px;border-radius:50%;
  background:#ff3a3a;box-shadow:0 0 10px #ff3a3a;
  animation:blink 1.4s infinite;
}

/* ─── Contact section ──────────────────────────────────────────────── */
.contact{position:relative;}
.contact .contact-frame{position:absolute;inset:0;
  container-type:size;
  overflow:hidden;
  background:#000;
}
/* video-mask is exactly 16:9 and at least the size of the container in both axes,
   so the video covers the whole section (overflow clipped) and hotspot percentages
   still line up perfectly with the 1920×1080 source. */
.contact .contact-inner{position:absolute;inset:0;overflow:hidden;}
.contact .video-mask{position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:max(100cqw, calc(100cqh * 16 / 9));
  aspect-ratio:16/9;
}
.contact .video-mask video{position:absolute;inset:0;width:100%;height:100%;display:block;object-fit:fill;}
.contact .video-mask .hotspots{position:absolute;inset:0;}

.contact .hotspot{position:absolute;display:flex;
  align-items:center;justify-content:center;
  cursor:none;
  background:transparent;
  text-decoration:none;
  pointer-events:auto;
}
.contact .hotspot .link-label{
  display:inline-block;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-weight:700;letter-spacing:.02em;
  color:transparent;
  white-space:nowrap;
  pointer-events:none;
  transition:color .18s ease, transform .18s ease, text-shadow .18s ease;
  text-shadow:none;
  transform-origin:center;
}
.contact .hotspot.text-style .link-label{
  font-size:clamp(11px, 2cqh, 30px);
}
.contact .hotspot.icon-style .link-label{
  position:absolute;
  bottom:calc(100% + 2px);
  left:50%;
  font-size:clamp(10px, 1.5cqh, 18px);
  transform:translateX(-50%);
}
/* Hover — letters turn yellow + grow, no rectangle */
.contact .hotspot:hover .link-label{
  color:#ffe600;
  text-shadow:0 0 12px rgba(255,230,0,.55), 0 0 28px rgba(255,230,0,.3);
  transform:scale(1.18);
}
.contact .hotspot.icon-style:hover .link-label{
  transform:translateX(-50%) scale(1.22);
}

/* Section label pinned to upper-left of each section */
.section-label{position:absolute;left:calc(var(--rail) + 18px);top:calc(var(--header-h) + 14px);
  z-index:5;pointer-events:none;display:flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-2);}
.section-label::before{content:"";width:24px;height:1px;background:var(--accent);}
.section-label b{color:var(--ink);font-weight:500;letter-spacing:.14em;}

/* Scroll cue at the bottom of the hero */
.scroll-cue{position:absolute;left:50%;bottom:calc(var(--footer-h) + 16px);transform:translateX(-50%);
  z-index:5;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:8px;
  font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--ink-2);
  animation:cueFloat 2.4s ease-in-out infinite;
  transition:opacity .4s;}
.scroll-cue .arr{width:1px;height:28px;background:linear-gradient(180deg,transparent,var(--ink));
  position:relative;}
.scroll-cue .arr::after{content:"";position:absolute;left:50%;bottom:-2px;width:6px;height:6px;
  border-right:1px solid var(--ink);border-bottom:1px solid var(--ink);
  transform:translateX(-50%) rotate(45deg);}
@keyframes cueFloat{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,4px)}}
.section.in-view .scroll-cue{opacity:1;transition:opacity .4s}
.scroll-cue.hidden{opacity:0}

/* Tweak overrides */

/* Hero-split additions */
.split-info{display:none;position:absolute;left:0;top:64px;bottom:108px;width:50%;
  padding:40px 40px 40px 64px;display:none;flex-direction:column;justify-content:space-between;
  pointer-events:auto;}
.stage[data-layout="split"] .split-info{display:flex}
.stage[data-layout="split"] .stage-slogan,
.stage[data-layout="split"] .stage-slogan-r,
.stage[data-layout="split"] .corner-tags,
.stage[data-layout="split"] .corner-tags-r{display:none}

.split-info .eyebrow{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-3);display:flex;gap:10px;align-items:center;}
.split-info .eyebrow::before{content:"";width:24px;height:1px;background:var(--accent);}
.split-info h1{font-family:'Anton',sans-serif;font-size:clamp(72px,10vw,176px);line-height:.82;
  text-transform:uppercase;letter-spacing:-.015em;margin:18px 0 22px;}
.split-info h1 .acc{color:var(--accent)}
.split-info h1 .stroke{-webkit-text-stroke:1.4px var(--ink);color:transparent}
.split-info .sub{font-family:'JetBrains Mono',monospace;font-size:13px;line-height:1.5;color:var(--ink-2);max-width:46ch;}
.split-info .meta{display:grid;grid-template-columns:1fr 1fr;gap:10px 24px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.split-info .meta b{display:block;color:var(--ink);font-weight:500;margin-top:2px;letter-spacing:.06em;}

/* Shrink display elements on short viewports so chrome doesn't overflow */
@media (max-height:640px){
  .bigword{font-size:clamp(36px,5.8vw,72px)}
  .stage-slogan-r{display:none}
  .corner-tags .tag:nth-child(n+4),
  .corner-tags-r .tag:nth-child(n+3){display:none}
}
@media (max-height:520px){
  :root{--header-h:46px;--footer-h:30px}
  .bigword{font-size:44px}
  .marq{height:30px}
  .marq span{font-size:16px}
}
@media (max-width:1080px){.nav a .idx{display:none}}

/* Small responsive sanity */
@media (max-width:760px){
  :root{--rail:24px;--header-h:46px;--footer-h:34px}
  .nav a{padding:6px 7px;font-size:9.5px}
  .brand{font-size:12px}
  .bigword{font-size:48px}
  .stage[data-layout="centered"] .loop-wrap{padding:80px 16px 110px}
  .stage[data-layout="split"] .loop-wrap{left:0;padding:0 16px}
  .stage[data-layout="split"] .split-info{display:none}
  .stage[data-layout="mini"] .loop-wrap{width:70vw;right:12px;bottom:100px;}
}

/* ─── Phone-specific cleanup (≤ 640px wide) ────────────────────────── */
/* Each section fills the phone viewport so videos read as immersive
   backgrounds. Snap-on so each swipe lands on one section. */
@media (max-width:640px){
  :root{
    --rail:0px;
    --header-h:46px;
    --footer-h:36px;
  }

  body{scroll-snap-type:y mandatory;}
  .page[data-fx="stack"] .section,
  .section{
    position:relative;
    height:100vh;          /* fallback */
    height:100svh;
    min-height:100vh;
    min-height:100svh;
    scroll-snap-align:start;
    overflow:hidden;
  }
  .page{padding-top:0;padding-bottom:0;}

  /* HERO — full viewport, show entire video (no cropping) */
  .hero .stage{position:relative;width:100%;height:100%;aspect-ratio:auto;}
  .hero .loop-wrap,.hero .loop{position:absolute;inset:0;width:100%;height:100%;}
  .hero .loop{object-fit:contain;background:#000;}

  /* ABOUT — full viewport, contain */
  .about .about-frame{
    position:absolute;inset:0;
    width:100%;height:100%;aspect-ratio:auto;
  }
  .about video{object-fit:contain;background:#000;}

  /* WORK — full viewport, central grid still aligns to source video */
  .work .work-frame{
    position:absolute;inset:0;
    width:100%;height:100%;aspect-ratio:auto;
    container-type:size;
  }
  .work .work-inner{position:absolute;inset:0;overflow:hidden;}
  /* Contain-mask: source 16:9 fits viewport, letterboxes vertically.
     This way nothing is cropped — user can pinch-zoom to inspect details. */
  .work .work-frame .video-mask{
    position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%);
    width:min(100cqw, calc(100cqh * 16 / 9));
    height:auto;
    aspect-ratio:16/9;
  }
  /* Tiles still position as % of the source video */
  .work .work-grid{
    left:8%;top:26%;
    width:84%;height:64%;
    grid-template-columns:repeat(2, 1fr);
    grid-template-rows:repeat(3, 1fr);
    gap:1.6cqh 2.4cqw;
  }

  /* CONTACT — full viewport, cover-mask preserves source-pixel hotspots */
  .contact .contact-frame{
    position:absolute;inset:0;
    width:100%;height:100%;
    container-type:size;
  }
  .contact .contact-inner{position:absolute;inset:0;overflow:hidden;}
  .contact .video-mask{
    position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%);
    width:min(100cqw, calc(100cqh * 16 / 9));
    height:auto;
    aspect-ratio:16/9;
  }
  .contact .hotspot.text-style .link-label{
    color:rgba(255,230,0,.55);
    font-size:clamp(8px, 1.5cqh, 13px);
  }
  .contact .hotspot.icon-style .link-label{
    font-size:clamp(7px, 1.3cqh, 11px);
  }
  .contact .hotspot:hover .link-label,
  .contact .hotspot:active .link-label{
    color:#ffe600;text-shadow:0 0 12px rgba(255,230,0,.55);
    transform:scale(1.1);
  }

  /* TOOLS — full viewport, ultrawide mask */
  .tools .tools-frame{
    position:absolute;inset:0;
    width:100%;height:100%;
    container-type:size;
  }
  .tools .tools-inner{position:absolute;inset:0;overflow:hidden;}
  .tools .tools-mask{
    position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%);
    width:min(100cqw, calc(100cqh * 2206 / 946));
    height:auto;
    aspect-ratio:2206 / 946;
  }

  /* Splash cursor off on touch */
  body{cursor:auto;}
  .cursor-canvas,.cursor-dot{display:none;}

  /* Header */
  .hd{padding:0 12px;}
  .brand{font-size:11px;letter-spacing:.02em;gap:6px;}
  .brand .blob{width:8px;height:8px;box-shadow:0 0 8px var(--accent);}

  /* Side rails gone */
  .chrome-fixed .rail{display:none}
  .chrome-fixed{grid-template-columns:1fr;}
  .chrome-fixed .hd{grid-column:1;}
  .chrome-fixed .ft{grid-column:1;}

  /* Section labels */
  .section-label{
    left:10px;top:calc(var(--header-h) + 8px);
    font-size:8px;letter-spacing:.14em;gap:5px;
  }
  .section-label::before{width:10px;}

  /* Marquee shrink */
  .marq{height:30px;}
  .marq span{font-size:13px;gap:20px;}
  .marq span::after{font-size:10px;}
  .marq-track{gap:20px;}

  /* Scroll cue hidden */
  .scroll-cue{display:none;}

  /* Player modal */
  .player-modal{padding:max(56px, 8vh) max(8px, 2vw);}
  .player-close{top:-38px;width:30px;height:30px;font-size:16px;}
  .player-meta{top:-30px;font-size:9px;letter-spacing:.16em;}

  /* Tweaks panel */
  .twk-panel{right:8px !important;bottom:48px !important;width:240px !important;}

  /* Re-enable entrance animation on mobile even in stack mode */
  .page .section.entering{
    animation:fxZoom 800ms cubic-bezier(.22,1,.36,1) both;
  }
}

/* Extra-narrow (≤ 380px) */
@media (max-width:380px){
  .hd .right .brand{font-size:10px;}
  .hd .left .brand{font-size:10px;}
}

/* Touch / coarse pointer */
@media (pointer:coarse){
  body{cursor:auto;}
  .cursor-canvas,.cursor-dot{display:none;}
}
