/* ============================================================================
   ISEEMONSTERZ — fan portal v2. dirtier, off-grid, hard to navigate.
   text is scrambled by default and resolves only under the cursor.
   ========================================================================== */
@import url('colors_and_type.css');

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0;background:#050409}
body{
  font-family:var(--font-body);
  color:var(--fg);
  overflow-x:hidden;
  cursor:none;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--chroma-red);color:#050409}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
/* let touch scroll through filled image slots on mobile (img has touch-action:none inside) */
image-slot::part(image),image-slot::part(frame){touch-action:pan-y}

/* ---------------------------------------------------------------------------
   GLOBAL GRIME LAYERS (fixed, above content, below cursor)
--------------------------------------------------------------------------- */
.crt-overlay{position:fixed;inset:0;pointer-events:none;z-index:9000}
.crt-overlay::before{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(to bottom,
    rgba(0,0,0,0) 0px,rgba(0,0,0,0) 1px,rgba(0,0,0,.42) 2px,rgba(0,0,0,.42) 3px);
  mix-blend-mode:multiply}
.crt-overlay::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 120% at 50% 48%, transparent 50%, rgba(5,4,9,.82) 100%)}

/* boiling film grain via fractal noise */
.grain{position:fixed;inset:-120%;z-index:8990;pointer-events:none;opacity:.10;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}
@media (prefers-reduced-motion:no-preference){.grain{animation:boil .5s steps(4) infinite}}
@keyframes boil{0%{transform:translate(0,0)}25%{transform:translate(-6%,3%)}50%{transform:translate(4%,-5%)}75%{transform:translate(-3%,6%)}100%{transform:translate(5%,2%)}}

/* horizontal VHS tracking bands that drift down the screen */
.tracking{position:fixed;left:0;right:0;height:90px;z-index:8995;pointer-events:none;top:-120px;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.05) 30%,rgba(40,212,255,.08) 50%,rgba(255,255,255,.05) 70%,transparent);
  mix-blend-mode:screen;filter:blur(.5px)}
@media (prefers-reduced-motion:no-preference){
  .tracking.t1{animation:track 11s linear infinite}
  .tracking.t2{height:48px;animation:track 19s linear infinite;animation-delay:-7s;background:linear-gradient(180deg,transparent,rgba(255,42,58,.06) 50%,transparent)}
}
@keyframes track{0%{top:-120px}100%{top:110%}}

.crt-flicker{position:fixed;inset:0;pointer-events:none;z-index:9001;background:#0a0813;opacity:0;mix-blend-mode:overlay}
@media (prefers-reduced-motion:no-preference){.crt-flicker{animation:flicker 6s steps(60) infinite}}
@keyframes flicker{0%,96%,100%{opacity:0}96.5%{opacity:.14}97%{opacity:0}98.2%{opacity:.2}98.6%{opacity:0}}

.glitch-flash{position:fixed;inset:0;z-index:9002;pointer-events:none;opacity:0;mix-blend-mode:difference}

/* ---------------------------------------------------------------------------
   (boot intro + broadcast marquee + sound toggle removed)
--------------------------------------------------------------------------- */

/* ---------------------------------------------------------------------------
   CURSOR + WORD GHOSTS
--------------------------------------------------------------------------- */
.cursor{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;width:16px;height:16px;margin:-8px 0 0 -8px;mix-blend-mode:exclusion;transition:transform .12s}
.cursor::before,.cursor::after{content:"";position:absolute;inset:0;border:1.5px solid;border-radius:50%}
.cursor::before{border-color:var(--chroma-red);transform:translate(-2px,0)}
.cursor::after{border-color:var(--chroma-cyan);transform:translate(2px,0)}
.cursor.big{transform:scale(2.6)}
.cursor-dot{position:fixed;top:0;left:0;z-index:9999;width:4px;height:4px;margin:-2px 0 0 -2px;background:var(--chroma-grn);pointer-events:none;box-shadow:0 0 8px var(--chroma-grn)}
.cursor-halo{position:fixed;top:0;left:0;z-index:7500;width:240px;height:240px;margin:-120px 0 0 -120px;pointer-events:none;border-radius:50%;
  background:radial-gradient(circle,rgba(56,240,138,.07),transparent 65%);mix-blend-mode:screen}
@media (pointer:coarse){.cursor,.cursor-dot,.cursor-halo{display:none}body{cursor:auto}}
.ghost{position:fixed;z-index:8000;pointer-events:none;font-family:var(--font-display);font-weight:900;text-transform:uppercase;font-size:13px;letter-spacing:.2em;opacity:0;will-change:transform,opacity}

/* ---------------------------------------------------------------------------
   DECODE TEXT
--------------------------------------------------------------------------- */
.dc{display:inline-block;text-align:center;vertical-align:baseline;transition:color .14s, opacity .14s}
.dc.scram{color:var(--chroma-grn);opacity:.42}
.dc.near{color:#ecebf4;opacity:1}
/* element-level scrambled blocks */
[data-decode]:not([data-decode="char"]){transition:color .15s}
.el-scram{color:var(--chroma-grn);opacity:.5}
.el-clear{color:inherit;opacity:1}

/* MARQUEE removed */

/* ---------------------------------------------------------------------------
   SECTIONS — intentionally off-grid
--------------------------------------------------------------------------- */
section{position:relative;z-index:1}
.band{padding:clamp(90px,18vh,240px) 0;position:relative}
.band.void{background:#050409}
.band.indigo{background:linear-gradient(170deg,#0a0813,#150e36 45%,#08060f)}
.wrap{max-width:1280px;margin:0 auto;padding:0 clamp(20px,6vw,96px);position:relative}

.kicker{font-family:var(--font-mono);font-weight:700;font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--chroma-grn);margin:0 0 22px;display:inline-block}
.kicker.red{color:var(--chroma-red)}.kicker.cyan{color:var(--chroma-cyan)}

/* HERO */
.hero{height:100vh;min-height:620px;overflow:hidden;background:#050409;display:grid;place-items:center}
.hero-media{position:absolute;inset:0;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5;filter:saturate(1.15) contrast(1.05)}
.hero-poster{position:absolute;inset:0;background:url('assets/covers/star-child.jpg') center/cover;opacity:.5;filter:saturate(1.2) contrast(1.08)}
.hero-veil{position:absolute;inset:0;background:radial-gradient(80% 70% at 38% 46%, transparent, rgba(5,4,9,.74) 82%, #050409)}
.hero-inner{position:relative;z-index:3;text-align:left;width:100%;max-width:1280px;margin:0 auto;padding:0 clamp(20px,6vw,96px)}
.eyebrow{font-family:var(--font-mono);font-weight:700;font-size:clamp(10px,1.4vw,13px);letter-spacing:.46em;text-transform:uppercase;color:var(--chroma-grn);margin:0 0 4vh;transform:translateX(4px)}
.monsterz{font-family:var(--font-display);font-weight:900;text-transform:uppercase;line-height:.8;
  font-size:clamp(40px,12.2vw,206px);letter-spacing:-.03em;color:#ecebf4;display:inline-block;max-width:96vw;position:relative;transform:rotate(-2.2deg)}
.tagline{font-family:var(--font-mono);font-size:clamp(11px,1.7vw,16px);letter-spacing:.4em;text-transform:uppercase;color:var(--fg-1);margin-top:5vh;transform:translateX(6px)}
.tagline b{color:var(--chroma-red)}
.scrollcue{position:absolute;bottom:24px;left:6vw;z-index:4;text-align:left}
.scrollcue .w{font-family:var(--font-mono);font-size:10px;letter-spacing:.34em;color:var(--fg-2);text-transform:uppercase;display:block;margin-bottom:8px}
.scrollcue .arr{font-size:18px;color:var(--chroma-cyan);animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0);opacity:.4}50%{transform:translateY(7px);opacity:1}}
@media (prefers-reduced-motion:reduce){.scrollcue .arr{animation:none}}
.eye{position:absolute;z-index:4;top:13%;right:8%;font-family:var(--font-mono);font-size:13px;letter-spacing:.3em;color:var(--chroma-red);opacity:0;text-transform:uppercase}

/* tiny floating hook (legacy, unused) */
.hook{display:none}

/* big pull-quote — off center, tilted */
.pq blockquote{font-family:var(--font-display);font-weight:900;text-transform:uppercase;
  font-size:clamp(34px,7.2vw,112px);line-height:.82;letter-spacing:-.03em;color:#ecebf4;margin:0;
  text-shadow:-2px 0 var(--chroma-red),2px 0 var(--chroma-cyan)}
.pq cite{display:block;margin-top:26px;font-family:var(--font-mono);font-style:normal;font-size:12px;letter-spacing:.3em;color:var(--fg-2);text-transform:uppercase}
.tilt-l{transform:rotate(-3deg)}.tilt-r{transform:rotate(2.4deg)}
.off-l{margin-left:0;text-align:left;max-width:80%}
.off-r{margin-left:auto;text-align:right;max-width:82%}

/* MANIFESTO — overlapping, mismatched */
.mani{position:relative}
.mani-head{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:clamp(8px,3vw,40px);position:relative;z-index:2}
.mani .mh{font-family:var(--font-display);font-weight:900;text-transform:uppercase;line-height:.82;margin:0;
  font-size:clamp(46px,11vw,150px);letter-spacing:-.03em;color:#ecebf4;position:relative;z-index:2}
.mh-l{transform:rotate(-2.5deg);align-self:flex-start}
.mh-r{transform:rotate(2deg);align-self:flex-end;text-align:right;margin-top:clamp(18px,5vw,70px)}
.mani .col{max-width:42ch;position:relative;z-index:3}
.mani p{font-family:var(--font-mono);font-size:clamp(12px,1.02vw,14px);line-height:1.5;letter-spacing:.01em;color:var(--fg-1);margin:0 0 26px}
.mani p .hot{color:#ecebf4;font-weight:700}
/* ragged lines — uneven indents so the blocks don't read as tidy rectangles */
.mani .ln{display:block}
.mani .ln:nth-child(2){margin-left:2.4em}
.mani .ln:nth-child(3){margin-left:.7em}
.mani .ln:nth-child(4){margin-left:3.1em}
.mani .ln:nth-child(5){margin-left:1.3em}
.mani .ln:nth-child(6){margin-left:2em}
.mani .col.b p:nth-child(2) .ln:nth-child(2){margin-left:1.6em}
.mani .col.b p:nth-child(2) .ln:nth-child(4){margin-left:.5em}
.mani .col.b p:nth-child(2) .ln:nth-child(5){margin-left:2.7em}
.mani .col.a{margin-left:auto;transform:rotate(-1.2deg)}
.mani .col.b{margin-top:clamp(-220px,-13vw,-80px);transform:rotate(.8deg);margin-left:8%}

/* scattered facts — NO boxes, wild big/small typographic */
.facts2{position:relative;display:flex;flex-wrap:wrap;align-items:flex-end;gap:clamp(20px,6vw,90px);margin-top:clamp(50px,9vh,120px);padding-bottom:10px}
.ft{display:flex;flex-direction:column;line-height:.82}
.ftn{font-family:var(--font-display);font-weight:900;letter-spacing:-.04em;color:var(--chroma-red);display:block}
.ftl{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.16em;color:var(--fg-2);margin-top:14px}
.ft .c{color:var(--chroma-cyan)}.ft .g{color:var(--chroma-grn)}
.ft-a{transform:rotate(-4deg)}
.ft-a .ftn{font-size:clamp(80px,17vw,260px)}
.ft-a .ftl{font-size:11px}
.ft-b{transform:rotate(3deg);margin-bottom:clamp(30px,8vh,120px)}
.ft-b .ftn{font-size:clamp(44px,8vw,120px)}
.ft-b .ftl{font-size:10px}
.ft-c{transform:rotate(-1.5deg);margin-left:auto}
.ft-c .ftn{font-size:clamp(100px,20vw,320px);line-height:.7}
.ft-c .ftl{font-size:13px;color:var(--chroma-grn)}

/* FULLSCREEN PHOTO SLOT */
.photo{position:relative;height:100vh;min-height:560px;overflow:hidden;background:#050409;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.photo image-slot{position:absolute;inset:0;width:100%;height:100%;filter:saturate(1.12) contrast(1.05) brightness(1.18)}
.photo .crt-local{position:absolute;inset:0;z-index:4;pointer-events:none;
  background:repeating-linear-gradient(to bottom,transparent 0 2px,rgba(0,0,0,.28) 3px 4px);mix-blend-mode:multiply}
.photo .vig{position:absolute;inset:0;z-index:4;pointer-events:none;background:radial-gradient(110% 110% at 50% 50%,transparent 55%,rgba(5,4,9,.55))}
.photo .scrap{position:absolute;z-index:5;font-family:var(--font-mono);font-size:13px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--chroma-grn);text-shadow:0 2px 10px #050409, -1px 0 var(--chroma-red),1px 0 var(--chroma-cyan)}
.photo .scrap.bl{left:5vw;bottom:8vh}.photo .scrap.tr{right:5vw;top:14vh;color:var(--chroma-red);transform:rotate(2deg)}
/* embedded SoundCloud player — top-right of a live photo, with padding */
.live-player{position:absolute;z-index:6;top:clamp(16px,3vw,40px);right:clamp(16px,3vw,40px);
  width:min(680px,calc(100vw - 2*clamp(16px,3vw,40px)));padding:8px;background:#08060f;
  border:1px solid var(--hairline-2);box-shadow:0 18px 50px rgba(5,4,9,.6)}
.live-player iframe{display:block;width:100%;height:300px;border:0;background:#0a0813}
.live-player-cap{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--fg-2);margin-top:7px;padding:0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.live-player-cap a{color:var(--fg-2)}.live-player-cap a:hover{color:var(--chroma-cyan)}

/* DATAMOSH */
.mosh{position:relative;height:clamp(360px,72vh,760px);overflow:hidden;background:#050409;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.mosh-img{position:absolute;inset:0;background:url('assets/covers/erase-me.jpg') center/cover;will-change:transform}
.mosh-cap{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:40px 6vw;background:linear-gradient(transparent,rgba(5,4,9,.86))}
.mosh-cap .big{font-family:var(--font-display);font-weight:900;text-transform:uppercase;font-size:clamp(30px,6.8vw,100px);line-height:.82;letter-spacing:-.03em;color:#ecebf4;display:inline-block;transform:rotate(-1.5deg);transform-origin:left bottom}
.mosh-cap .sub{font-family:var(--font-mono);font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--chroma-grn);margin-top:14px}

/* THE TWO DOORS — cryptic clickable links, no labels/descriptions */
.doors{display:flex;flex-direction:column;gap:clamp(40px,10vh,140px);align-items:stretch;overflow:hidden;position:relative}
/* Marathon-ish halftone dot fade behind the doors */
.doors::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.55;
  background-image:radial-gradient(rgba(255,42,58,.55) 1px, transparent 1.5px);background-size:8px 8px;
  -webkit-mask-image:linear-gradient(115deg,#000,transparent 52%);mask-image:linear-gradient(115deg,#000,transparent 52%)}
.door{position:relative;z-index:1;display:flex;align-items:center;gap:clamp(14px,3vw,42px);text-decoration:none;width:max-content;max-width:100%}
.door .dword{font-family:var(--font-display);font-weight:900;text-transform:uppercase;letter-spacing:-.03em;line-height:.82;color:#ecebf4}
.door .play{font-family:var(--font-mono);line-height:1;flex:none}
/* SoundCloud — the loud one, oversized, tilted, hot, pulsing */
.door.sc{align-self:flex-start;transform:rotate(-2.5deg);margin-left:2vw}
.door.sc .dword{font-size:clamp(56px,15vw,230px);color:#fff}
.door.sc .play{font-size:clamp(30px,7vw,96px);color:var(--chroma-red);text-shadow:0 0 22px var(--chroma-red)}
.door.sc::after{content:"";position:absolute;left:-6%;top:50%;width:46%;height:150%;transform:translateY(-50%);z-index:-1;
  background:radial-gradient(circle,var(--chroma-red),transparent 62%);opacity:.16}
@media (prefers-reduced-motion:no-preference){.door.sc::after{animation:throb 2.6s ease-in-out infinite}}
@keyframes throb{0%,100%{opacity:.1}50%{opacity:.3}}
.door.sc .dword{text-shadow:-2px 0 var(--chroma-red),2px 0 var(--chroma-cyan)}
.door.sc:hover .dword{text-shadow:-4px 0 var(--chroma-red),4px 0 var(--chroma-cyan)}
/* Bandcamp — secondary, smaller, pushed to the right, opposite tilt */
.door.bc{align-self:flex-end;transform:rotate(2deg);margin-right:3vw;opacity:.92}
.door.bc .dword{font-size:clamp(32px,7vw,104px);color:#b8b4cc;text-shadow:-1.5px 0 var(--chroma-red),1.5px 0 var(--chroma-cyan)}
.door.bc .play.sm{font-size:clamp(18px,3vw,40px);color:var(--chroma-cyan)}
.door.bc:hover .dword{color:#ecebf4}
.door:hover .play{animation:blink .5s steps(1) 3}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}

/* THE THREE — each portrait carries its name beneath it */
.three{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,3vw,46px);align-items:start;margin-top:clamp(24px,4vw,52px)}
.mem{margin:0}
.mem:nth-child(1){transform:rotate(-2.5deg);margin-top:clamp(0px,2vw,28px)}
.mem:nth-child(2){transform:rotate(1.5deg)}
.mem:nth-child(3){transform:rotate(-1deg);margin-top:clamp(0px,3vw,40px)}
.mem-cap{display:flex;align-items:baseline;gap:clamp(8px,1vw,14px);margin-top:clamp(12px,1.5vw,22px);padding:0 4px}
.mem-cap .no{font-family:var(--font-mono);font-size:12px;letter-spacing:.3em;color:var(--fg-3);flex:none;transform:translateY(-.3em)}
.mem-cap .nm{font-family:var(--font-display);font-weight:900;text-transform:uppercase;line-height:.84;letter-spacing:-.03em;
  font-size:clamp(24px,3.2vw,46px);color:#ecebf4;text-shadow:-2px 0 var(--chroma-red),2px 0 var(--chroma-cyan)}
.mbr{display:none}

/* loose portrait under the name — frameless, edges feather into the dark, no border */
.mem-photo{position:relative;width:100%;aspect-ratio:3/4}
.mem-photo image-slot{position:absolute;inset:0;width:100%;height:100%;
  -webkit-mask-image:radial-gradient(120% 118% at 50% 42%, #000 58%, transparent 100%);
  mask-image:radial-gradient(120% 118% at 50% 42%, #000 58%, transparent 100%);
  color:var(--chroma-grn);font-family:var(--font-mono);letter-spacing:.22em;text-transform:uppercase}
.mem-photo::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  -webkit-mask-image:radial-gradient(120% 118% at 50% 42%, #000 58%, transparent 100%);
  mask-image:radial-gradient(120% 118% at 50% 42%, #000 58%, transparent 100%);
  background:repeating-linear-gradient(to bottom,transparent 0 2px,rgba(0,0,0,.32) 3px 4px);mix-blend-mode:multiply}

/* photos row — three across, loosely tilted */
.three .mem-photo{width:100%}

/* FOOTER */
/* ============ BOOKING CTA ============ */
.cta{border-top:1px solid var(--hairline)}
.cta-title{font-family:var(--font-display);font-weight:900;text-transform:uppercase;line-height:.84;letter-spacing:-.03em;
  font-size:clamp(40px,9vw,140px);color:#ecebf4;margin:0;transform:rotate(-1.5deg);
  text-shadow:-2px 0 var(--chroma-red),2px 0 var(--chroma-cyan)}
.cta-sub{font-family:var(--font-mono);font-size:clamp(13px,1.6vw,16px);line-height:1.7;letter-spacing:.04em;color:var(--fg-1);
  margin:26px 0 44px;max-width:46ch}

.bk-form{max-width:760px}
.bk-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.bk-field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.bk-field.bk-wide{margin-bottom:14px}
.bk-field>span{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--chroma-grn)}
.bk-field input,.bk-field textarea{background:#0a0813;border:1px solid var(--hairline-2);color:#ecebf4;
  font-family:var(--font-mono);font-size:14px;padding:13px 14px;outline:none;border-radius:0;width:100%;resize:vertical;
  transition:border-color .15s,box-shadow .15s}
.bk-field input:focus,.bk-field textarea:focus{border-color:var(--chroma-cyan);box-shadow:0 0 0 1px var(--chroma-cyan),0 0 18px -6px var(--chroma-cyan)}
.bk-field input::placeholder,.bk-field textarea::placeholder{color:var(--fg-3)}

.bk-consent{display:flex;gap:12px;align-items:flex-start;margin:6px 0 26px;cursor:pointer}
.bk-consent input{appearance:none;-webkit-appearance:none;flex:none;width:20px;height:20px;margin:0;background:#0a0813;
  border:1px solid var(--hairline-2);display:grid;place-content:center;cursor:pointer}
.bk-consent input:checked{border-color:var(--chroma-grn);background:rgba(56,240,138,.12)}
.bk-consent input:checked::after{content:"✓";color:var(--chroma-grn);font-family:var(--font-mono);font-size:13px;line-height:1}
.bk-consent>span{font-family:var(--font-mono);font-size:12px;line-height:1.6;letter-spacing:.02em;color:var(--fg-2)}
.bk-inline{background:none;border:0;padding:0;cursor:pointer;color:var(--chroma-cyan);font:inherit;letter-spacing:inherit;text-decoration:underline;text-underline-offset:2px}
.bk-inline:hover{color:#ecebf4}

.bk-actions{display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.bk-submit{background:var(--chroma-red);color:#050409;border:0;cursor:pointer;
  font-family:var(--font-mono);font-weight:700;font-size:14px;letter-spacing:.18em;text-transform:uppercase;padding:16px 30px;
  text-shadow:none;transition:box-shadow .15s,transform .15s}
.bk-submit:hover{box-shadow:var(--glow-red);transform:translate(-1px,-1px)}
.bk-alt{font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-2);text-decoration:underline;text-underline-offset:3px}
.bk-alt:hover{color:var(--chroma-cyan)}
.bk-note{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);margin:24px 0 0}
.bk-error{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;color:var(--chroma-red);margin:14px 0 0}

.bk-done{max-width:600px;border:1px solid var(--chroma-grn);background:linear-gradient(120deg,#0a1a12,#0a0813 70%);padding:clamp(28px,4vw,48px);position:relative}
.bk-done::after{content:"";position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(to bottom,transparent 0 2px,rgba(0,0,0,.3) 3px 4px);mix-blend-mode:multiply}
.bk-done-glyph{font-family:var(--font-mono);font-size:34px;color:var(--chroma-grn);text-shadow:0 0 16px var(--chroma-grn)}
.bk-done-msg{font-family:var(--font-display);font-weight:900;text-transform:uppercase;font-size:clamp(28px,5vw,52px);color:#ecebf4;margin:10px 0 14px;text-shadow:-2px 0 var(--chroma-red),2px 0 var(--chroma-cyan)}
.bk-done p{font-family:var(--font-mono);font-size:13px;line-height:1.7;color:var(--fg-1);margin:0}
.bk-done a{color:var(--chroma-cyan);text-decoration:underline;text-underline-offset:2px}

/* FOOTER — offset, tilted, not centered */
.foot{padding:clamp(70px,16vh,200px) 6vw clamp(90px,16vh,180px);text-align:left;background:#050409;border-top:1px solid var(--hairline);overflow:hidden}
.foot .wm{font-family:var(--font-display);font-weight:900;text-transform:uppercase;font-size:clamp(34px,12vw,200px);line-height:.8;letter-spacing:-.03em;transform:rotate(-2deg);display:inline-block}
.foot .threat{font-family:var(--font-mono);font-size:clamp(11px,1.5vw,14px);letter-spacing:.3em;text-transform:uppercase;color:var(--chroma-red);margin-top:34px;margin-left:6vw}

/* legal links — quiet, in the footer */
.legal-links{margin-top:56px;display:flex;gap:14px;align-items:center}
.legal-link{background:none;border:0;font-family:var(--font-mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--fg-3);cursor:none;padding:0;transition:color .2s}
.legal-link:hover{color:var(--chroma-grn)}
.legal-sep{color:var(--fg-3);font-family:var(--font-mono)}

/* LEGAL OVERLAY — deliberately calm + fully legible (no scramble, no glitch) */
.legal-modal{position:fixed;inset:0;z-index:9600;display:none;cursor:auto}
.legal-modal.open{display:block}
.legal-backdrop{position:absolute;inset:0;background:rgba(3,2,7,.86);backdrop-filter:blur(2px)}
.legal-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(760px,92vw);max-height:86vh;overflow-y:auto;
  background:#0a0813;border:1px solid var(--hairline-2);box-shadow:0 0 0 1px #050409, 0 30px 80px -20px #000;padding:clamp(26px,5vw,56px);
  background-image:repeating-linear-gradient(to bottom,transparent 0 3px,rgba(0,0,0,.18) 4px 5px)}
.legal-close{position:sticky;top:0;float:right;margin:-8px -8px 0 0;background:#0a0813;border:1px solid var(--hairline-2);
  font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-1);padding:8px 12px;cursor:pointer}
.legal-close:hover{color:var(--chroma-red);border-color:var(--chroma-red)}
.legal-doc{color:var(--fg-1)}
.legal-doc+.legal-doc{margin-top:48px;padding-top:40px;border-top:1px solid var(--hairline)}
.legal-doc h2{font-family:var(--font-display);font-weight:900;text-transform:uppercase;font-size:clamp(26px,4.5vw,40px);
  letter-spacing:-.01em;color:#ecebf4;margin:0 0 18px;text-shadow:-1.5px 0 var(--chroma-red),1.5px 0 var(--chroma-cyan)}
.legal-doc h3{font-family:var(--font-mono);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--chroma-grn);margin:26px 0 8px}
.legal-doc p{font-family:var(--font-body);font-size:14px;line-height:1.7;color:var(--fg-1);margin:0 0 6px}
.legal-doc strong{color:#ecebf4}
.legal-doc .legal-note{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;line-height:1.6;color:var(--fg-2);margin-bottom:16px}

/* fixed chrome */
.clock{position:fixed;right:14px;bottom:12px;z-index:8400;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.18em;color:var(--fg-2);text-align:right;pointer-events:none;mix-blend-mode:difference}
.clock b{color:var(--chroma-grn)}
.sound{display:none}

/* ============ DATES / GIGS ============ */
.gigs-title{font-family:var(--font-display);font-weight:900;text-transform:uppercase;line-height:.82;letter-spacing:-.03em;
  font-size:clamp(40px,8.5vw,128px);color:#ecebf4;margin:0 0 clamp(34px,6vw,70px);transform:rotate(-1.5deg);
  text-shadow:-2px 0 var(--chroma-red),2px 0 var(--chroma-cyan)}
.gig-list{list-style:none;margin:0;padding:0;border-top:1px solid var(--hairline)}
.gig{display:grid;grid-template-columns:minmax(120px,160px) minmax(150px,1fr) minmax(0,1.4fr) minmax(110px,auto);
  align-items:baseline;gap:clamp(14px,3vw,40px);padding:clamp(16px,2.4vw,30px) 4px;border-bottom:1px solid var(--hairline);transition:background .2s}
.gig:hover{background:rgba(40,212,255,.045)}
.g-date{font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;color:var(--fg-1);white-space:nowrap;display:flex;align-items:baseline;gap:8px}
.g-date b{font-family:var(--font-display);font-weight:900;font-size:clamp(28px,3.6vw,48px);color:#ecebf4;letter-spacing:-.02em}
.g-mo{color:var(--chroma-grn)}
.g-yr{color:var(--fg-3)}
.g-city{font-family:var(--font-display);font-weight:900;text-transform:uppercase;font-size:clamp(22px,3vw,42px);line-height:.9;color:#ecebf4;
  text-shadow:-1.5px 0 var(--chroma-red),1.5px 0 var(--chroma-cyan)}
.g-venue{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-2);line-height:1.5}
.g-act{justify-self:end;text-align:right}
.g-tix{font-family:var(--font-mono);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#050409;
  background:var(--chroma-grn);padding:9px 16px;white-space:nowrap;display:inline-block;transition:box-shadow .15s,transform .15s}
.g-tix:hover{box-shadow:var(--glow-grn);transform:translate(-1px,-1px)}
.g-flag{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.g-flag.sold{color:var(--chroma-red)}
.g-flag.tba{color:var(--fg-3)}
.g-flag.past{color:var(--fg-3)}
.gig.past{opacity:.5}
.gig.past .g-city,.gig.past .g-date b{text-decoration:line-through;text-decoration-color:var(--chroma-red);color:var(--fg-2);text-shadow:none}
.gig-archive{margin-top:clamp(40px,7vw,88px)}
.gig-archive .kicker{color:var(--fg-3)}
.gigs-empty{font-family:var(--font-mono);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--chroma-grn);margin:8px 0 0}
.gigs-empty span{color:var(--fg-2)}

/* ============ SOUND TOGGLE ============ */
.sndbtn{position:fixed;left:14px;bottom:12px;z-index:8400;display:flex;align-items:center;gap:10px;
  background:rgba(10,8,19,.62);border:1px solid var(--hairline-2);padding:8px 13px;cursor:pointer;
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-2);
  transition:border-color .2s,color .2s}
.sndbtn:hover{border-color:var(--chroma-cyan);color:#ecebf4}
.sndbtn.on{border-color:var(--chroma-grn);color:var(--chroma-grn)}
.sndwave{display:flex;align-items:flex-end;gap:2px;height:14px}
.sndwave i{width:2px;height:3px;background:currentColor;opacity:.75}
.sndbtn.on .sndwave i{animation:sndbar .9s ease-in-out infinite}
.sndbtn.on .sndwave i:nth-child(2){animation-delay:.15s}
.sndbtn.on .sndwave i:nth-child(3){animation-delay:.3s}
.sndbtn.on .sndwave i:nth-child(4){animation-delay:.45s}
.sndbtn.on .sndwave i:nth-child(5){animation-delay:.6s}
@keyframes sndbar{0%,100%{height:3px}50%{height:14px}}
@media (pointer:coarse){.sndbtn{cursor:auto}}
@media (prefers-reduced-motion:reduce){.sndbtn.on .sndwave i{animation:none;height:8px}}

/* ============ KONAMI SECRET ============ */
.secret{position:fixed;inset:0;z-index:9600;display:none;align-items:center;justify-content:center;padding:6vw}
.secret.open{display:flex}
.secret-backdrop{position:absolute;inset:0;background:rgba(5,4,9,.9);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
.secret-inner{position:relative;max-width:780px;text-align:center}
.secret-q{font-family:var(--font-display);font-weight:900;text-transform:uppercase;line-height:.84;letter-spacing:-.02em;
  font-size:clamp(48px,12vw,150px);color:#ecebf4;margin:14px 0 26px;text-shadow:-3px 0 var(--chroma-red),3px 0 var(--chroma-cyan);
  animation:secretglitch .5s steps(2) 6}
@keyframes secretglitch{0%{transform:translate(0,0)}25%{transform:translate(-3px,1px)}50%{transform:translate(3px,-2px)}75%{transform:translate(-2px,0)}100%{transform:translate(0,0)}}
.secret-sub{font-family:var(--font-mono);font-size:clamp(13px,1.8vw,17px);letter-spacing:.18em;text-transform:uppercase;line-height:1.9;color:var(--fg-1)}
.secret-sub span{color:var(--chroma-red)}
.secret-close{margin-top:34px;background:none;border:1px solid var(--hairline-2);color:var(--fg-2);cursor:pointer;
  font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;padding:11px 22px;transition:border-color .2s,color .2s}
.secret-close:hover{border-color:var(--chroma-red);color:#ecebf4}
@media (pointer:coarse){.secret-close{cursor:auto}}
@media (prefers-reduced-motion:reduce){.secret-q{animation:none}}

/* video placeholder note — plain mono line, no box */
.vidnote{position:absolute;left:6vw;top:12vh;z-index:5;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--chroma-cyan);opacity:.7;text-shadow:0 1px 6px #050409}

.whisper{position:fixed;z-index:7000;pointer-events:none;font-family:var(--font-mono);font-size:12px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--chroma-red);opacity:0;mix-blend-mode:screen}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

@media (max-width:760px){
  .mani .col.a,.mani .col.b{margin-left:0;transform:none;margin-top:0}
  .mani .ln{margin-left:0!important}
  .mani h2{font-size:clamp(40px,16vw,90px)}
  .bk-grid{grid-template-columns:1fr}
  .three{grid-template-columns:1fr;gap:44px;max-width:360px;margin:24px auto 0}
  .mem{transform:none!important;margin-top:0!important}
  .mbr{display:block}
  .mem-cap .nm{font-size:clamp(30px,9vw,46px)}
  .mani-head{flex-direction:column}
  .mh-l,.mh-r{transform:none!important;text-align:left;margin-top:0;align-self:flex-start}
  .mh-l{font-size:clamp(40px,16vw,90px)}
  .mh-r{margin:2px 0 0!important;font-size:clamp(76px,29vw,170px)}
  /* wide full-bleed photos pan horizontally as you scroll, revealing the full image in the narrow column */
  .photo image-slot::part(image){transform:translate(calc(-50% + var(--panx,0px)),-50%)!important}
  .off-l,.off-r{max-width:100%}
  .gigs-title{font-size:clamp(40px,14vw,88px)}
  .gig{grid-template-columns:60px 1fr;column-gap:16px;row-gap:3px;align-items:start;padding:18px 2px}
  .g-date{grid-column:1;grid-row:1/4;flex-direction:column;align-items:flex-start;gap:0;font-size:11px}
  .g-date b{font-size:30px;line-height:1}
  .g-city{grid-column:2;font-size:clamp(24px,8vw,34px)}
  .g-venue{grid-column:2}
  .g-act{grid-column:2;justify-self:start;text-align:left;margin-top:8px}
}
