/* ============================================================
   PRIYANSH.AI — CASE FILE THEME
   Shared Spider-Verse design system for /projects pages.
   Tokens & components mirror the homepage (index.html).
============================================================ */
:root{
  --bg:#0B0B14;
  --bg-2:#14142A;
  --ink:#F4F2FF;
  --ink-soft:#A39FC4;
  --red:#FF2E63;
  --red-deep:#B81443;
  --purple:#B537F2;
  --purple-deep:#7A1FB8;
  --cyan:#00E5FF;
  --cyan-deep:#0093A6;
  --yellow:#FFE600;
  --line:rgba(244,242,255,.16);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{background:var(--bg);color:var(--ink);overflow-x:hidden}
body{font-family:'Archivo',sans-serif;line-height:1.6;cursor:none}
::selection{background:var(--yellow);color:var(--bg)}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none}
ul{list-style:none}

/* ---------- spider-verse halftone print ---------- */
.halftone{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.35;
  background-image:radial-gradient(rgba(244,242,255,.07) 1px,transparent 1.4px);
  background-size:14px 14px}
.halftone-pink{position:fixed;top:-20vh;right:-15vw;width:55vw;height:55vw;z-index:1;pointer-events:none;opacity:.16;border-radius:50%;
  background-image:radial-gradient(var(--red) 1.4px,transparent 2px);background-size:11px 11px;
  -webkit-mask-image:radial-gradient(circle,black 0%,transparent 68%);mask-image:radial-gradient(circle,black 0%,transparent 68%);
  animation:dotDrift 14s ease-in-out infinite alternate}
.halftone-cyan{position:fixed;bottom:-25vh;left:-18vw;width:60vw;height:60vw;z-index:1;pointer-events:none;opacity:.12;border-radius:50%;
  background-image:radial-gradient(var(--cyan) 1.4px,transparent 2px);background-size:13px 13px;
  -webkit-mask-image:radial-gradient(circle,black 0%,transparent 68%);mask-image:radial-gradient(circle,black 0%,transparent 68%);
  animation:dotDrift 18s ease-in-out infinite alternate-reverse}
@keyframes dotDrift{from{transform:translate(0,0) rotate(0)}to{transform:translate(4vw,-3vh) rotate(8deg)}}
.glow{position:fixed;z-index:0;pointer-events:none;border-radius:50%;filter:blur(90px);opacity:.22}
.glow-1{top:-10vh;left:55vw;width:46vw;height:46vw;background:var(--purple)}
.glow-2{bottom:-18vh;left:-10vw;width:42vw;height:42vw;background:var(--red)}

/* ---------- cursor ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;transform:translate(-50%,-50%)}
.cursor-dot{width:10px;height:10px;background:var(--red);border:2px solid var(--ink);box-shadow:0 0 12px rgba(255,46,99,.8)}
.cursor-ring{width:44px;height:44px;border:2px solid rgba(244,242,255,.7);transition:width .25s,height .25s,border-color .25s,background .25s}
.cursor-ring.hovering{width:86px;height:86px;border-color:var(--cyan);background:rgba(0,229,255,.07)}
.cursor-label{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;font-family:'Bangers',cursive;font-size:15px;letter-spacing:.1em;color:var(--yellow);transform:translate(16px,20px) rotate(-4deg);opacity:0;transition:opacity .3s;text-shadow:2px 2px 0 var(--bg),3.5px 3.5px 0 var(--red)}
#webTrail{position:fixed;inset:0;z-index:9998;pointer-events:none}
@media (hover:none){.cursor-dot,.cursor-ring,.cursor-label,#webTrail{display:none}body{cursor:auto}}

/* ---------- HUD + progress ---------- */
.hud{position:fixed;z-index:7000;pointer-events:none;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.22em;color:var(--ink-soft);text-transform:uppercase}
.hud b{color:var(--red);font-weight:500}
.hud-tl{top:84px;left:22px}.hud-br{bottom:18px;right:22px;text-align:right}
.hud::before{content:"";position:absolute;width:18px;height:18px;border:2px solid var(--cyan)}
.hud-tl::before{top:-12px;left:-8px;border-right:none;border-bottom:none}
.hud-br::before{bottom:-6px;right:-8px;border-left:none;border-top:none}
@media(max-width:860px){.hud{display:none}}
.progress{position:fixed;top:0;left:0;height:5px;width:100%;z-index:8000}
.progress i{display:block;height:100%;width:0;background:repeating-linear-gradient(90deg,var(--red) 0 30px,var(--cyan) 30px 60px);border-bottom:2px solid var(--bg)}

/* ---------- nav ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:7500;display:flex;justify-content:space-between;align-items:center;padding:18px clamp(20px,5vw,64px);background:rgba(11,11,20,.78);backdrop-filter:blur(10px);border-bottom:3px solid var(--red)}
.nav-logo{font-family:'Bangers',cursive;font-size:24px;letter-spacing:.06em;color:var(--ink)}
.nav-logo span{color:var(--red);text-shadow:-2px 0 var(--cyan)}
.nav-links{display:flex;gap:28px;font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:500}
.nav-links a{position:relative;color:var(--ink-soft);transition:color .3s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:3px;background:var(--cyan);transition:width .35s}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}
.nav-links a.here{color:var(--ink)}
.nav-links a.here::after{width:100%;background:var(--red)}
@media(max-width:860px){.nav-links{display:none}}
.nav-cta{font-family:'Bangers',cursive;font-size:16px;letter-spacing:.08em;border:3px solid var(--ink);padding:8px 20px;border-radius:99px;color:var(--bg);background:var(--yellow);box-shadow:3px 3px 0 var(--red);transition:.25s;display:inline-block}
.nav-cta:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--red)}
.nav-right{display:flex;align-items:center;gap:14px}
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;padding:10px;background:var(--bg-2);border:3px solid var(--ink);border-radius:12px;box-shadow:3px 3px 0 var(--red);cursor:pointer;transition:.25s}
.nav-burger span{display:block;height:3px;width:100%;background:var(--ink);border-radius:2px;transition:transform .3s,opacity .3s}
.nav-burger.open{background:var(--red)}
.nav-burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
@media(max-width:860px){.nav-burger{display:flex}}
.mobile-menu{position:fixed;inset:0;z-index:7400;background:var(--bg);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:100px 24px 40px;transform:translateX(100%);transition:transform .45s cubic-bezier(.7,0,.2,1);visibility:hidden}
.mobile-menu::before{content:"";position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(rgba(255,46,99,.14) 1.6px,transparent 2px);background-size:16px 16px}
.mobile-menu.open{transform:translateX(0);visibility:visible}
.mobile-menu a{position:relative;font-family:'Bangers',cursive;font-size:clamp(28px,7.5vw,44px);letter-spacing:.05em;text-transform:uppercase;color:var(--ink);padding:6px 18px;transition:.25s}
.mobile-menu a:nth-child(odd){transform:rotate(-1.5deg)}
.mobile-menu a:nth-child(even){transform:rotate(1.5deg)}
.mobile-menu a .no{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.3em;color:var(--cyan);vertical-align:super;margin-right:10px}
.mobile-menu a:hover,.mobile-menu a:active{color:var(--red);text-shadow:-2px 0 var(--cyan),3px 3px 0 rgba(0,0,0,.7)}
.mobile-menu .menu-cta{margin-top:26px;font-size:22px;background:var(--red);color:#fff;border:3px solid var(--ink);border-radius:14px;padding:12px 30px;box-shadow:5px 5px 0 var(--cyan-deep);transform:rotate(-1deg)}
body.menu-locked{overflow:hidden}

/* ---------- layout ---------- */
main{position:relative;z-index:2}
section{position:relative;padding:clamp(80px,12vh,140px) clamp(20px,6vw,96px)}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:var(--cyan);display:flex;align-items:center;gap:14px;margin-bottom:28px;font-weight:500}
.eyebrow::before{content:"";width:36px;height:3px;background:var(--red)}
.h2{font-family:'Bangers',cursive;font-weight:400;font-size:clamp(38px,6vw,80px);line-height:1;text-transform:uppercase;max-width:960px;letter-spacing:.02em}
.h2 .accent{color:var(--red);text-shadow:-2px 0 var(--cyan),3px 3px 0 #000}
.h2 .accent-b{color:var(--cyan);text-shadow:-2px 0 var(--red),3px 3px 0 #000}

/* reveals (hidden only when JS is on) */
.reveal,.flip3d{transition:opacity .95s cubic-bezier(.25,.7,.3,1),transform .95s cubic-bezier(.25,.7,.3,1)}
.js .reveal{opacity:0;transform:translateY(60px)}
.js .flip3d{opacity:0;transform:perspective(900px) rotateX(-85deg) translateY(40px);transform-origin:top center}
.js .reveal.in,.js .flip3d.in{opacity:1;transform:none}

/* ---------- case hero ---------- */
.case-hero{position:relative;min-height:86svh;display:flex;flex-direction:column;justify-content:center;padding-top:150px}
.hero-emblem{position:absolute;right:clamp(6px,5vw,80px);top:52%;width:clamp(210px,26vw,430px);height:auto;opacity:.55;pointer-events:none;z-index:-1;transform:translateY(-50%)}
.emblem-spin{animation:emblemSpin 38s linear infinite}
@keyframes emblemSpin{from{transform:translateY(-50%) rotate(0)}to{transform:translateY(-50%) rotate(360deg)}}
.emblem-float{animation:emblemFloat 6s ease-in-out infinite}
@keyframes emblemFloat{0%,100%{transform:translateY(-52%) rotate(-3deg)}50%{transform:translateY(-46%) rotate(3deg)}}
@media(max-width:900px){.hero-emblem{opacity:.14;right:-60px}}
.issue-tag{font-family:'JetBrains Mono',monospace;font-size:clamp(11px,1.2vw,13px);letter-spacing:.4em;text-transform:uppercase;color:var(--cyan);margin-bottom:26px;display:flex;align-items:center;gap:14px;font-weight:500}
.issue-tag::before{content:"";width:36px;height:3px;background:var(--red)}
.case-title{font-family:'Bangers',cursive;font-weight:400;font-size:clamp(48px,9.5vw,140px);line-height:.94;letter-spacing:.015em;text-transform:uppercase}
.case-title .row{display:block}
.t3d-red{color:var(--red);text-shadow:1px 1px 0 var(--red-deep),2px 2px 0 var(--red-deep),3px 3px 0 var(--red-deep),4px 4px 0 var(--red-deep),5px 5px 0 var(--red-deep),6px 6px 0 #000,9px 9px 0 rgba(0,229,255,.3)}
.t3d-cyan{color:var(--cyan);text-shadow:1px 1px 0 var(--cyan-deep),2px 2px 0 var(--cyan-deep),3px 3px 0 var(--cyan-deep),4px 4px 0 var(--cyan-deep),5px 5px 0 var(--cyan-deep),6px 6px 0 #000,9px 9px 0 rgba(255,46,99,.3)}
.t3d-ink{color:var(--bg);-webkit-text-stroke:3px var(--ink);text-shadow:5px 5px 0 var(--yellow),8px 8px 0 var(--purple-deep)}
.lede{margin-top:32px;max-width:680px;font-size:clamp(16px,1.7vw,20px);color:var(--ink-soft);font-weight:500}
.lede b{color:var(--ink);font-weight:700}
.case-meta{display:flex;flex-wrap:wrap;gap:14px;margin-top:42px}
.meta-box{border:3px solid var(--ink);border-radius:14px;padding:14px 20px;background:var(--bg-2);box-shadow:4px 4px 0 var(--red);min-width:150px;transition:.25s}
.meta-box:nth-child(odd){transform:rotate(-.8deg)}
.meta-box:nth-child(even){transform:rotate(.8deg);box-shadow:4px 4px 0 var(--cyan-deep)}
.meta-box:hover{transform:translate(-2px,-3px) rotate(0);box-shadow:7px 8px 0 var(--purple-deep)}
.meta-box .k{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
.meta-box .v{font-family:'Bangers',cursive;font-size:19px;letter-spacing:.06em;margin-top:4px;text-transform:uppercase}
.case-actions{display:flex;gap:16px;margin-top:42px;flex-wrap:wrap}

/* ---------- buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:12px;font-family:'Bangers',cursive;font-size:20px;letter-spacing:.08em;padding:14px 32px;border-radius:14px;border:3px solid var(--ink);transition:.25s;will-change:transform;overflow:hidden}
.btn-primary{background:var(--red);color:#fff;box-shadow:5px 5px 0 var(--cyan-deep),0 0 26px rgba(255,46,99,.35)}
.btn-primary:hover{transform:translate(-3px,-3px) rotate(-1deg);box-shadow:9px 9px 0 var(--cyan-deep),0 0 34px rgba(255,46,99,.5)}
.btn-ghost{background:var(--bg-2);color:var(--ink);box-shadow:5px 5px 0 var(--purple-deep)}
.btn-ghost:hover{transform:translate(-3px,-3px) rotate(1deg);box-shadow:9px 9px 0 var(--purple-deep);background:var(--yellow);color:var(--bg)}
.btn .dot{width:9px;height:9px;border-radius:50%;background:#fff;border:2px solid var(--bg);animation:blink 1.2s infinite}
.btn-ghost .dot{background:var(--red)}
@keyframes blink{50%{opacity:.25}}

/* ---------- marquee strip ---------- */
.marquee{position:relative;z-index:2;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);overflow:hidden;padding:16px 0;background:var(--red);transform:rotate(-1.2deg) scale(1.02);margin:10px 0}
.marquee.m2{background:var(--purple);transform:rotate(1deg) scale(1.02)}
.marquee-track{display:flex;width:max-content;font-family:'Bangers',cursive;font-size:clamp(20px,2.6vw,30px);text-transform:uppercase;letter-spacing:.14em;color:var(--bg)}
.marquee.m2 .marquee-track{color:var(--ink)}
.marquee-track span{padding:0 30px;white-space:nowrap}
.marquee-track .hl{color:var(--yellow)}
.m-fwd .marquee-track{animation:marquee 22s linear infinite}
.m-rev .marquee-track{animation:marqueeRev 26s linear infinite}
@keyframes marquee{to{transform:translateX(-50%)}}
@keyframes marqueeRev{from{transform:translateX(-50%)}to{transform:translateX(0)}}

/* ---------- prose + quote + snapshot ---------- */
.mission-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(36px,6vw,80px);margin-top:56px;align-items:start}
@media(max-width:900px){.mission-grid{grid-template-columns:1fr}}
.prose p{font-size:clamp(16px,1.7vw,19px);color:var(--ink-soft);margin-bottom:22px;font-weight:500}
.prose p b{color:var(--ink);font-weight:700}
.quote,.prose .quote{font-family:'Bangers',cursive;font-size:clamp(21px,2.3vw,28px);color:var(--bg);border:3px solid var(--ink);border-radius:18px;padding:22px 26px;background:var(--yellow);box-shadow:6px 6px 0 var(--red);transform:rotate(-1deg);letter-spacing:.04em}
.snapshot{border:3px solid var(--ink);border-radius:18px;background:var(--bg-2);box-shadow:6px 6px 0 var(--cyan-deep);padding:28px 26px;transform:rotate(.8deg);transition:.25s}
.snapshot:hover{transform:translate(-3px,-3px) rotate(0);box-shadow:10px 10px 0 var(--purple-deep);background:#1B1B36}
.snapshot h5{font-family:'Bangers',cursive;font-size:21px;letter-spacing:.06em;text-transform:uppercase;color:var(--yellow);margin-bottom:12px}
.snapshot li{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);padding:10px 0;border-top:2px dashed var(--line);display:flex;gap:10px;align-items:baseline;font-weight:500}
.snapshot li::before{content:"◆";color:var(--red);font-size:10px}
.snapshot li b{color:var(--ink);font-weight:500}

/* ---------- numbered steps ---------- */
.steps{margin-top:56px;display:grid;gap:18px}
.step{display:grid;grid-template-columns:90px 1fr;gap:26px;align-items:start;border:3px solid var(--ink);border-radius:18px;background:var(--bg-2);padding:28px 30px;box-shadow:5px 5px 0 var(--red);transition:.3s}
.step:nth-child(odd){transform:rotate(-.35deg)}
.step:nth-child(even){transform:rotate(.35deg);box-shadow:5px 5px 0 var(--cyan-deep)}
.step:hover{transform:translate(-4px,-4px) rotate(0);box-shadow:10px 10px 0 var(--purple-deep);background:#1B1B36}
@media(max-width:640px){.step{grid-template-columns:1fr;gap:10px}}
.step .no{font-family:'Bangers',cursive;font-size:46px;line-height:1;color:var(--bg);-webkit-text-stroke:2px var(--ink);text-shadow:4px 4px 0 var(--red)}
.step:nth-child(even) .no{text-shadow:4px 4px 0 var(--cyan-deep)}
.step h4{font-family:'Bangers',cursive;font-size:clamp(20px,2vw,26px);text-transform:uppercase;letter-spacing:.05em}
.step p{color:var(--ink-soft);font-size:15px;margin-top:6px;font-weight:500}
.step p b{color:var(--ink)}
.step .chip-row{margin-top:14px}

/* ---------- comic feature panels ---------- */
.panels{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:56px;perspective:1400px}
@media(max-width:900px){.panels{grid-template-columns:1fr}}
.panel{position:relative;border:3px solid var(--ink);border-radius:20px;padding:34px 30px;background:var(--bg-2);box-shadow:7px 7px 0 var(--red);overflow:hidden;transition:box-shadow .3s;will-change:transform}
.panel:nth-child(even){box-shadow:7px 7px 0 var(--cyan-deep)}
.panel::before{content:"";position:absolute;inset:0;background:radial-gradient(460px circle at var(--mx,50%) var(--my,50%),rgba(181,55,242,.28),transparent 45%);opacity:0;transition:opacity .4s;pointer-events:none}
.panel:hover::before{opacity:1}
.panel:hover{box-shadow:12px 12px 0 var(--purple-deep)}
.panel .badge{position:absolute;top:-3px;right:24px;font-family:'Bangers',cursive;font-size:15px;letter-spacing:.08em;background:var(--red);color:#fff;border:3px solid var(--ink);border-top:none;padding:7px 13px;border-radius:0 0 12px 12px}
.panel:nth-child(even) .badge{background:var(--cyan);color:var(--bg)}
.panel .glyph{font-size:34px;display:inline-block;filter:drop-shadow(0 0 10px rgba(255,46,99,.55));animation:floatGlyph 4s ease-in-out infinite}
.panel:nth-child(even) .glyph{animation-delay:-2s}
@keyframes floatGlyph{0%,100%{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-10px) rotate(6deg)}}
.panel h3{font-family:'Bangers',cursive;font-size:clamp(22px,2vw,28px);margin:16px 0 6px;text-transform:uppercase;letter-spacing:.04em}
.panel .sub{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);margin-bottom:12px;font-weight:500}
.panel p{color:var(--ink-soft);font-size:15px;font-weight:500}
.panel p b{color:var(--ink)}
.panel .chip-row{margin-top:20px}
.chip-row{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;border:2px solid var(--line);border-radius:99px;padding:6px 12px;color:var(--ink);background:rgba(244,242,255,.05);font-weight:500}

/* ---------- architecture board ---------- */
.arch{margin-top:56px;border:3px solid var(--ink);border-radius:20px;background:var(--bg-2);padding:clamp(22px,4vw,40px);box-shadow:8px 8px 0 var(--purple-deep);overflow-x:auto}
.arch-stack{display:grid;gap:0;min-width:560px}
.arch-row{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:14px}
.node{border:3px solid var(--ink);border-radius:14px;padding:16px 12px;text-align:center;background:var(--bg);transition:.25s;position:relative}
.node:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--red);background:#1B1B36}
.node h5{font-family:'Bangers',cursive;font-size:17px;letter-spacing:.06em;text-transform:uppercase}
.node p{font-family:'JetBrains Mono',monospace;font-size:9.5px;color:var(--ink-soft);letter-spacing:.08em;margin-top:6px;text-transform:uppercase;font-weight:500}
.node.hot{border-color:var(--red);box-shadow:0 0 22px rgba(255,46,99,.25)}
.node.cold{border-color:var(--cyan)}
.down{text-align:center;font-family:'Bangers',cursive;font-size:24px;color:var(--cyan);padding:8px 0;text-shadow:2px 2px 0 #000;letter-spacing:.3em}
.arch-caption{margin-top:18px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);text-align:center;font-weight:500}

/* ---------- stats + stamps ---------- */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-top:56px}
.stat{position:relative;background:var(--bg-2);border:3px solid var(--ink);border-radius:16px;padding:26px 24px;box-shadow:5px 5px 0 var(--red);transition:.25s;overflow:hidden}
.stat:nth-child(odd){transform:rotate(-1deg)}
.stat:nth-child(even){transform:rotate(1deg);box-shadow:5px 5px 0 var(--cyan-deep)}
.stat:hover{transform:translate(-3px,-3px) rotate(0);box-shadow:9px 9px 0 var(--purple-deep);background:#1B1B36}
.stat .num{font-family:'Bangers',cursive;font-size:clamp(34px,3.8vw,52px);color:var(--red);text-shadow:-2px 0 var(--cyan),2px 2px 0 #000}
.stat .lbl{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-top:6px;font-weight:500}
.stamps{display:flex;flex-wrap:wrap;gap:14px;margin-top:48px}
.stamp{font-family:'Bangers',cursive;font-size:17px;letter-spacing:.07em;border:3px solid var(--ink);border-radius:14px;padding:12px 22px;background:var(--bg-2);box-shadow:4px 4px 0 var(--red);transition:.25s;transform:rotate(-1.2deg)}
.stamp:nth-child(even){transform:rotate(1.2deg);box-shadow:4px 4px 0 var(--cyan-deep)}
.stamp:hover{transform:translate(-2px,-3px) rotate(0);box-shadow:7px 8px 0 var(--purple-deep);background:var(--yellow);color:var(--bg)}
.stamp span{color:var(--red);margin-right:8px}
.stamp:hover span{color:var(--bg)}

/* ---------- prev / next issue ---------- */
.issue-nav{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:8px}
@media(max-width:700px){.issue-nav{grid-template-columns:1fr}.issue-link.next{text-align:left}}
.issue-link{display:block;border:3px solid var(--ink);border-radius:18px;background:var(--bg-2);padding:26px 30px;box-shadow:6px 6px 0 var(--red);transition:.25s;transform:rotate(-.4deg)}
.issue-link.next{text-align:right;box-shadow:6px 6px 0 var(--cyan-deep);transform:rotate(.4deg)}
.issue-link:hover{transform:translate(-3px,-4px) rotate(0);box-shadow:10px 10px 0 var(--purple-deep);background:#1B1B36}
.issue-link .k{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.24em;color:var(--cyan);text-transform:uppercase;font-weight:500}
.issue-link .t{font-family:'Bangers',cursive;font-size:clamp(22px,3vw,34px);letter-spacing:.05em;margin-top:6px;text-transform:uppercase}

/* ---------- hub: file grid ---------- */
.file-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:60px;perspective:1400px}
@media(max-width:900px){.file-grid{grid-template-columns:1fr}}
.file-card{position:relative;display:block;border:3px solid var(--ink);border-radius:20px;padding:38px 32px;background:var(--bg-2);box-shadow:8px 8px 0 var(--red);overflow:hidden;transition:box-shadow .3s;will-change:transform}
.file-card:nth-child(even){box-shadow:8px 8px 0 var(--cyan-deep)}
.file-card::before{content:"";position:absolute;inset:0;background:radial-gradient(500px circle at var(--mx,50%) var(--my,50%),rgba(181,55,242,.3),transparent 45%);opacity:0;transition:opacity .4s;pointer-events:none}
.file-card:hover::before{opacity:1}
.file-card:hover{box-shadow:14px 14px 0 var(--purple-deep)}
.file-no{position:absolute;top:2px;right:18px;font-family:'Bangers',cursive;font-size:96px;line-height:1;color:transparent;-webkit-text-stroke:2px rgba(244,242,255,.13);pointer-events:none}
.file-card .badge{position:absolute;top:-3px;left:26px;font-family:'Bangers',cursive;font-size:15px;letter-spacing:.08em;background:var(--red);color:#fff;border:3px solid var(--ink);border-top:none;padding:7px 13px;border-radius:0 0 12px 12px}
.file-card .glyph{font-size:38px;display:inline-block;margin-top:14px;filter:drop-shadow(0 0 10px rgba(255,46,99,.55));animation:floatGlyph 4s ease-in-out infinite}
.file-card:nth-child(even) .glyph{animation-delay:-1.6s}
.file-card h3{font-family:'Bangers',cursive;font-size:clamp(26px,2.4vw,36px);margin:16px 0 6px;text-transform:uppercase;letter-spacing:.04em}
.file-card .sub{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);margin-bottom:12px;font-weight:500}
.file-card p{color:var(--ink-soft);font-size:15px;font-weight:500}
.file-card p b{color:var(--ink)}
.file-card .chip-row{margin-top:20px}
.file-card .open{display:inline-flex;align-items:center;gap:8px;margin-top:24px;font-family:'Bangers',cursive;font-size:16px;letter-spacing:.08em;color:var(--bg);background:var(--cyan);border:3px solid var(--ink);border-radius:99px;padding:7px 18px;box-shadow:3px 3px 0 var(--red);transition:.25s}
.file-card:hover .open{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--red)}
.file-card.wanted{grid-column:1/-1;border-style:dashed;background:transparent;box-shadow:8px 8px 0 var(--purple-deep);display:flex;flex-direction:column;justify-content:center;align-items:flex-start}
.file-card.wanted h3{color:var(--yellow)}

/* ---------- footer ---------- */
footer{position:relative;z-index:2;border-top:3px solid var(--red);padding:30px clamp(20px,6vw,96px);display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);background:var(--bg-2);font-weight:500}
footer a{color:var(--cyan)}
footer a:hover{color:var(--ink)}

/* ---------- comic click burst ---------- */
.burst{position:fixed;z-index:9500;pointer-events:none;font-family:'Bangers',cursive;display:flex;align-items:center;justify-content:center;
  animation:burstPop .32s cubic-bezier(.3,1.9,.5,1) both,burstFade .3s ease-in .95s forwards}
.burst svg{position:absolute;width:150px;height:150px}
.burst b{position:relative;font-size:30px;letter-spacing:.06em;color:#fff;transform:rotate(-6deg);text-shadow:2px 2px 0 #000}
@keyframes burstPop{0%{transform:translate(-50%,-50%) scale(0) rotate(-20deg)}60%{transform:translate(-50%,-50%) scale(1.1) rotate(7deg)}100%{transform:translate(-50%,-50%) scale(1) rotate(6deg)}}
@keyframes burstFade{to{transform:translate(-50%,-50%) scale(0);opacity:0}}
.websplat{position:fixed;z-index:9400;pointer-events:none;animation:splatIn .3s cubic-bezier(.3,1.6,.5,1) both,splatOut .55s ease .55s forwards}
@keyframes splatIn{from{transform:translate(-50%,-50%) scale(.2)}to{transform:translate(-50%,-50%) scale(1)}}
@keyframes splatOut{to{transform:translate(-50%,-50%) scale(1.15);opacity:0}}

/* ============================================================
   AVENGER SKINS — one hero per case file.
   Every component reads the tokens, so a body class re-themes
   the whole page:  --red = primary accent · --cyan = secondary
   --yellow = highlight (dark text on it) · --purple = tertiary
============================================================ */

/* IRON MAN — CrewSpace · hot-rod red, gold, arc-reactor glow */
body.t-iron{
  --bg-2:#1D1420;
  --red:#E23636; --red-deep:#8E1D1D;
  --cyan:#7FE7FF; --cyan-deep:#1E93B8;
  --yellow:#FFC33D;
  --purple:#D98E1B; --purple-deep:#8C5A0F;
}

/* BLACK PANTHER — OpenClaw · vibranium purple, silver, night */
body.t-panther{
  --bg-2:#171029;
  --red:#9E63FF; --red-deep:#5A2EA6;
  --cyan:#CBD5E1; --cyan-deep:#64748B;
  --yellow:#E9D8FF;
  --purple:#6D28D9; --purple-deep:#3B1580;
}

/* THOR — AutoOps AI · storm indigo, lightning cyan, cape red */
body.t-thor{
  --bg-2:#101A2E;
  --red:#FF4D5E; --red-deep:#A61E2C;
  --cyan:#8FE3FF; --cyan-deep:#1F7FA6;
  --yellow:#FFE066;
  --purple:#5B7CFF; --purple-deep:#2C3F9E;
}

/* BLACK WIDOW — RAG Chatbot · crimson, gunmetal, hourglass */
body.t-widow{
  --bg-2:#1C1016;
  --red:#E8253D; --red-deep:#8F1226;
  --cyan:#C7CEDE; --cyan-deep:#5F6B80;
  --yellow:#FF8FA3;
  --purple:#B0233A; --purple-deep:#5C0F1F;
}

/* CAPTAIN AMERICA — FMGlobal · cap blue, silver-white, shield red */
body.t-cap{
  --bg-2:#0F1B33;
  --red:#4D8DFF; --red-deep:#1D4FA8;
  --cyan:#F0F5FF; --cyan-deep:#8CA3C7;
  --yellow:#F4F7FF;
  --purple:#E23B55; --purple-deep:#8C1D30;
}

/* S.H.I.E.L.D. — command-deck steel & radar blue */
body.t-shield{
  --bg-2:#121826;
  --red:#64A7FF; --red-deep:#2B5AA6;
  --cyan:#D3DCE8; --cyan-deep:#6E7F94;
  --yellow:#B9C7DA;
  --purple:#3E5C8F; --purple-deep:#22375C;
}

/* VISION — Mach2 · vision crimson, synthezoid green, mind-stone gold */
body.t-vision{
  --bg-2:#1E1322;
  --red:#E0565F; --red-deep:#8E2430;
  --cyan:#7CF2C8; --cyan-deep:#1F9E78;
  --yellow:#FFD34D;
  --purple:#9B72F2; --purple-deep:#5636A8;
}

/* ANT-MAN — Mach1 · suit red, Pym-particle blue, silver */
body.t-antman{
  --bg-2:#191125;
  --red:#F04E3E; --red-deep:#9B1F1F;
  --cyan:#6FC3FF; --cyan-deep:#2A6FB8;
  --yellow:#FFCE5C;
  --purple:#7E8BB8; --purple-deep:#3E4A78;
}

/* HULK — BlastR · gamma green, purple pants, radiation lime */
body.t-hulk{
  --bg-2:#0F1F16;
  --red:#54E065; --red-deep:#1F8A3B;
  --cyan:#C77DFF; --cyan-deep:#7A3FB8;
  --yellow:#D9FF7E;
  --purple:#8C52D9; --purple-deep:#4A2A80;
}

/* WANDA — Ornith · scarlet hex, chaos magenta, rose glow */
body.t-wanda{
  --bg-2:#220F1D;
  --red:#F2314F; --red-deep:#96122F;
  --cyan:#FF7EDB; --cyan-deep:#B0349B;
  --yellow:#FFB3C7;
  --purple:#B03A8C; --purple-deep:#5E1D4C;
}

/* ---------- fixed corner navigation (independent pages) ---------- */
.corner-nav{position:fixed;top:86px;z-index:7300;display:inline-flex;align-items:center;gap:8px;
  font-family:'Bangers',cursive;font-size:16px;letter-spacing:.08em;text-transform:uppercase;
  border:3px solid var(--ink);border-radius:99px;padding:9px 20px;background:var(--bg-2);color:var(--ink);
  box-shadow:3px 3px 0 var(--red);transition:.25s}
.corner-nav.left{left:22px;transform:rotate(-1deg)}
.corner-nav.right{right:22px;transform:rotate(1deg);box-shadow:3px 3px 0 var(--cyan-deep)}
.corner-nav:hover{transform:translate(-2px,-2px) rotate(0);box-shadow:6px 6px 0 var(--purple-deep);background:var(--yellow);color:var(--bg)}
@media(max-width:860px){
  .corner-nav{top:80px;font-size:13px;padding:7px 14px}
  .corner-nav.left{left:12px}
  .corner-nav.right{right:12px}
}

/* radar emblem for the S.H.I.E.L.D. hub (pure CSS) */
.radar{position:absolute;right:clamp(6px,5vw,80px);top:52%;transform:translateY(-50%);width:clamp(220px,24vw,400px);aspect-ratio:1;border-radius:50%;z-index:-1;opacity:.5;pointer-events:none;
  border:3px solid var(--line);
  background:repeating-radial-gradient(circle at 50% 50%,transparent 0 18%,var(--line) 18% 18.8%)}
.radar::before,.radar::after{content:"";position:absolute;background:var(--line)}
.radar::before{left:50%;top:4%;bottom:4%;width:2px;transform:translateX(-50%)}
.radar::after{top:50%;left:4%;right:4%;height:2px;transform:translateY(-50%)}
.radar i{position:absolute;inset:0;border-radius:50%;background:conic-gradient(from 0deg,rgba(100,167,255,.55),transparent 28%);animation:radarSweep 4.5s linear infinite}
@keyframes radarSweep{to{transform:rotate(360deg)}}
@media(max-width:900px){.radar{opacity:.14;right:-60px}}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  body{cursor:auto}
  .cursor-dot,.cursor-ring,.cursor-label,#webTrail{display:none}
  .js .reveal,.js .flip3d{opacity:1!important;transform:none!important}
}
