/* ════════════════════════════════════════════════════════════
   curl your endpoints :: LISTENING BOOTH — Y2K terminal-glamour
   ════════════════════════════════════════════════════════════ */

:root{
  --black:#05030a;
  --ink:#0a0612;
  --lime:#39ff14;
  --lime-dim:#1fae0d;
  --cyan:#00f0ff;
  --pink:#ff2fb9;
  --hot:#ff1493;
  --magenta:#ff00e6;
  --yellow:#ffe600;
  --purple:#b026ff;
  --grid:rgba(57,255,20,.10);
  --panel:#0d0820;
  --shadow:0 0 0 2px #000, 6px 6px 0 0 rgba(0,0,0,.55);
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--black);
  color:var(--lime);
  font-family:'VT323',monospace;
  font-size:20px;
  line-height:1.35;
  overflow-x:hidden;
  -webkit-font-smoothing:none;
}
a{color:var(--cyan);}
code{font-family:'VT323',monospace;color:var(--yellow);background:rgba(255,230,0,.08);padding:0 .25em;border-radius:2px;}
b{color:#fff;}
.blink{animation:blink 1s steps(2) infinite;color:var(--hot);}
@keyframes blink{50%{opacity:0}}
.rainbow{background:linear-gradient(90deg,red,orange,yellow,lime,cyan,violet);background-size:200%;
  -webkit-background-clip:text;background-clip:text;color:transparent;animation:glitterShift 4s linear infinite;font-weight:bold;}
.glitter{
  background:linear-gradient(92deg,var(--hot),var(--yellow),var(--cyan),var(--magenta),var(--lime),var(--hot));
  background-size:300% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:glitterShift 6s linear infinite;
  filter:drop-shadow(0 0 8px rgba(255,47,185,.5));
}
@keyframes glitterShift{to{background-position:300% 0}}

/* ════════════════ ACCESS GATE ════════════════ */
.gate{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 40%, rgba(176,38,255,.22), transparent 60%),#03020a;
  text-align:center;overflow:hidden;}
.gate.gone{opacity:0;transform:scale(1.12);pointer-events:none;transition:opacity .5s,transform .5s;}
.gate-stars{position:absolute;inset:0;background-image:
  radial-gradient(1px 1px at 20% 30%, #fff, transparent),
  radial-gradient(1px 1px at 70% 60%, var(--cyan), transparent),
  radial-gradient(2px 2px at 40% 80%, var(--pink), transparent),
  radial-gradient(1px 1px at 85% 25%, #fff, transparent),
  radial-gradient(1px 1px at 15% 70%, var(--yellow), transparent),
  radial-gradient(2px 2px at 60% 15%, var(--magenta), transparent);
  background-size:300px 300px;animation:twinkle 4s steps(8) infinite;opacity:.8;}
@keyframes twinkle{from{transform:translateY(0)}to{transform:translateY(-300px)}}
.gate-inner{position:relative;z-index:2;padding:2rem;max-width:560px;width:100%;}
.gate-ascii{color:var(--lime);font-size:13px;line-height:1.1;text-shadow:0 0 8px var(--lime);margin:0 auto 1rem;
  animation:flickerLite 6s infinite;}
.gate-title{font-family:'Bungee Shade',cursive;font-size:clamp(2rem,7vw,3.4rem);margin:.2em 0;color:var(--pink);line-height:1;}
.gate-sub{font-size:1.25rem;color:var(--cyan);margin:.3rem 0 1.2rem;}
.gate-term{background:#000;border:2px solid var(--lime);border-radius:8px;overflow:hidden;
  box-shadow:0 0 24px rgba(57,255,20,.3),var(--shadow);text-align:left;}
.gate-term-bar{display:flex;align-items:center;gap:.6em;background:#0a160a;padding:.3em .7em;
  border-bottom:1px solid var(--lime-dim);color:var(--lime-dim);font-size:.95rem;}
.term-dots{display:flex;gap:5px;}
.term-dots i{width:11px;height:11px;border-radius:50%;display:block;}
.term-dots i:nth-child(1){background:#ff5f56}.term-dots i:nth-child(2){background:#ffbd2e}.term-dots i:nth-child(3){background:#27c93f}
.gate-form{display:flex;flex-direction:column;gap:.6em;padding:1em 1.2em 1.2em;}
.gate-prompt{color:var(--cyan);}
.cursor-block{display:inline-block;width:9px;height:1em;background:var(--lime);vertical-align:text-bottom;animation:blink 1s steps(2) infinite;}
#gatePass{font-family:'VT323',monospace;font-size:1.3rem;background:#020;color:var(--lime);
  border:1px solid var(--lime-dim);padding:.35em .6em;border-radius:4px;letter-spacing:.2em;}
#gatePass:focus{outline:none;border-color:var(--lime);box-shadow:0 0 12px rgba(57,255,20,.5);}
.gate-btn{cursor:pointer;align-self:flex-start;display:inline-flex;gap:.5em;align-items:center;
  font-family:'VT323',monospace;font-size:1.4rem;letter-spacing:.12em;color:#000;
  background:linear-gradient(180deg,var(--cyan),var(--lime));
  border:3px solid #fff;padding:.3em 1em;border-radius:6px;
  box-shadow:0 0 0 3px var(--pink),0 0 22px var(--cyan),5px 5px 0 #000;transition:transform .08s;}
.gate-btn:hover{transform:translate(-2px,-2px);}
.gate-btn:active{transform:translate(2px,2px);}
.gate-msg{min-height:1.3em;color:var(--hot);font-size:1.1rem;}
.gate-msg.ok{color:var(--lime);}
.gate-foot{margin-top:1.1rem;color:var(--purple);font-size:1.05rem;}
.gate.denied .gate-term{animation:shake .4s;}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-8px)}75%{transform:translateX(8px)}}

/* glitch text */
.glitch{position:relative;}
.glitch::before,.glitch::after{content:attr(data-text);position:absolute;inset:0;}
.glitch::before{color:var(--cyan);transform:translate(-2px,0);clip-path:inset(0 0 55% 0);animation:glitchA 2.4s infinite steps(2);}
.glitch::after{color:var(--hot);transform:translate(2px,0);clip-path:inset(55% 0 0 0);animation:glitchB 3.1s infinite steps(2);}
@keyframes glitchA{0%,90%,100%{transform:translate(-2px,0)}92%{transform:translate(3px,-2px)}96%{transform:translate(-3px,1px)}}
@keyframes glitchB{0%,88%,100%{transform:translate(2px,0)}90%{transform:translate(-3px,2px)}94%{transform:translate(3px,-1px)}}
@keyframes flickerLite{0%,97%,100%{opacity:1}98%{opacity:.6}99%{opacity:.85}}

/* ════════════════ MARQUEE ════════════════ */
.marquee{position:relative;z-index:55;overflow:hidden;white-space:nowrap;
  background:#000;border-top:2px solid var(--pink);border-bottom:2px solid var(--cyan);
  color:var(--yellow);font-size:1.05rem;letter-spacing:.08em;padding:.25em 0;}
.marquee-track{display:inline-block;animation:marq 26s linear infinite;}
.marquee-track span{padding-right:2rem;text-shadow:0 0 6px var(--yellow);}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ════════════════ PAGE / HERO ════════════════ */
.page{position:relative;min-height:100vh;padding-bottom:110px;
  background:
    radial-gradient(ellipse at 20% 0%, rgba(176,38,255,.18), transparent 55%),
    radial-gradient(ellipse at 90% 20%, rgba(255,47,185,.16), transparent 55%),
    radial-gradient(ellipse at 50% 100%, rgba(0,240,255,.12), transparent 60%),
    linear-gradient(var(--grid) 1px, transparent 1px) 0 0/40px 40px,
    linear-gradient(90deg, var(--grid) 1px, transparent 1px) 0 0/40px 40px,
    var(--black);
  animation:gridScroll 18s linear infinite;}
@keyframes gridScroll{from{background-position:0 0,0 0,0 0,0 0,0 0,0 0;}to{background-position:0 0,0 0,0 0,0 40px,40px 0,0 0;}}
.scanlines{position:fixed;inset:0;pointer-events:none;z-index:60;
  background:repeating-linear-gradient(to bottom,rgba(0,0,0,0) 0,rgba(0,0,0,0) 2px,rgba(0,0,0,.25) 3px,rgba(0,0,0,0) 4px);
  mix-blend-mode:multiply;opacity:.5;}
.vignette{position:fixed;inset:0;pointer-events:none;z-index:59;box-shadow:inset 0 0 220px 40px rgba(0,0,0,.85);}

.hero{position:relative;z-index:10;text-align:center;padding:2.6rem 1rem 1.2rem;}
.hero-badge{display:inline-block;color:#000;background:var(--yellow);font-size:1rem;
  padding:.15em .8em;border:2px solid #000;box-shadow:3px 3px 0 var(--pink);letter-spacing:.1em;margin-bottom:1rem;
  transform:rotate(-1.5deg);}
.hero-title{font-family:'VT323',monospace;font-size:clamp(2.4rem,9vw,5.4rem);line-height:.95;margin:.15em 0;
  display:flex;flex-wrap:wrap;gap:.25em .4em;justify-content:center;}
.hero-title .word{display:inline-block;animation:bob 3s ease-in-out infinite;}
.w1{color:var(--cyan)}.w2{color:#fff}
.w2{animation-delay:.2s}.w3{animation-delay:.4s}.w4{animation-delay:.6s}
@keyframes bob{50%{transform:translateY(-8px)}}
.hero-tag{color:var(--cyan);font-size:1.2rem;margin:.3rem 0;}
.hero-status{color:var(--lime);font-size:1.05rem;opacity:.9;}
.hero-status .dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--lime);
  box-shadow:0 0 10px var(--lime);animation:pulse 1.2s ease-in-out infinite;}
@keyframes pulse{50%{opacity:.3;transform:scale(.7)}}

/* ════════════════ STRIP ════════════════ */
.strip{position:relative;z-index:10;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;align-items:center;
  padding:.8rem 1rem;max-width:1180px;margin:0 auto;}
.panel-mini{display:flex;gap:.5em;align-items:center;background:var(--panel);border:2px solid var(--hot);
  padding:.3em .7em;box-shadow:0 0 14px rgba(255,20,147,.35);}
.who label{color:var(--pink);}
.who input{font-family:'VT323',monospace;font-size:1.05rem;background:#000;color:var(--lime);
  border:1px solid var(--hot);padding:.25em .5em;border-radius:4px;width:200px;}
.who input:focus{outline:none;box-shadow:0 0 10px rgba(255,20,147,.6);}
.blinkies{display:flex;flex-wrap:wrap;gap:.4em;justify-content:center;}
.blinky{font-size:.85rem;padding:.15em .5em;border:1px solid #000;animation:blinkyFlash 1.6s steps(2) infinite;}
.b1{background:var(--lime);color:#000}.b2{background:var(--hot);color:#fff;animation-delay:.2s}
.b3{background:#000;color:var(--cyan);border-color:var(--cyan);animation-delay:.4s}
.b4{background:var(--yellow);color:#000;animation-delay:.6s}
@keyframes blinkyFlash{50%{filter:brightness(1.6) saturate(1.5)}}
.catnav{display:flex;gap:.4em;flex-wrap:wrap;justify-content:center;}
.catnav a{font-size:1rem;color:#fff;background:var(--purple);border:1px solid #fff;border-radius:3px;
  padding:.1em .55em;text-decoration:none;}
.catnav a:hover{background:var(--hot);}

/* ════════════════ CATALOG ════════════════ */
.catalog{position:relative;z-index:10;max-width:1180px;margin:.6rem auto;padding:0 1rem;
  display:flex;flex-direction:column;gap:1.4rem;}
.cat-panel{background:var(--panel);border:2px solid #000;box-shadow:var(--shadow);}
.cat-bar{font-size:1.15rem;color:#000;padding:.25em .8em;letter-spacing:.05em;font-weight:bold;
  display:flex;justify-content:space-between;align-items:center;gap:1em;}
.cat-bar .cat-count{font-size:.95rem;}
.cat-Finals      .cat-bar{background:linear-gradient(90deg,var(--hot),var(--magenta));}
.cat-Finals      {border-color:var(--hot);}
.cat-Iterations  .cat-bar{background:linear-gradient(90deg,var(--cyan),#7df9ff);}
.cat-Iterations  {border-color:var(--cyan);}
.cat-Acappellas  .cat-bar{background:linear-gradient(90deg,var(--lime),#aaff66);}
.cat-Acappellas  {border-color:var(--lime);}
.cat-References  .cat-bar{background:linear-gradient(90deg,var(--yellow),#fff37d);}
.cat-References  {border-color:var(--yellow);}
.cat-Samples     .cat-bar{background:linear-gradient(90deg,var(--purple),#d18aff);}
.cat-Samples     {border-color:var(--purple);}
.cat-body{padding:.5em .7em .8em;display:flex;flex-direction:column;gap:.55em;}

/* track row */
.track{background:#0a0618;border:1px solid #221a3a;border-left:3px solid var(--cyan);border-radius:4px;
  padding:.5em .7em;transition:border-color .15s, box-shadow .15s;}
.track.playing{border-left-color:var(--lime);box-shadow:0 0 16px rgba(57,255,20,.25);}
.track-row{display:flex;align-items:center;gap:.7em;flex-wrap:wrap;}
.t-play{cursor:pointer;flex:none;width:38px;height:38px;border-radius:6px;border:2px solid #fff;
  background:var(--pink);color:#000;font-family:'VT323',monospace;font-size:1.2rem;
  box-shadow:0 0 10px var(--pink);transition:transform .08s;}
.t-play:hover{transform:scale(1.1);}
.track.playing .t-play{background:var(--lime);box-shadow:0 0 12px var(--lime);}
.t-meta{flex:1 1 220px;min-width:0;}
.t-title{color:#fff;font-size:1.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.t-sub{color:var(--lime-dim);font-size:.9rem;display:flex;gap:.8em;align-items:center;}
.t-progress{position:relative;height:8px;background:#020;border:1px solid #1a3a1a;border-radius:3px;
  margin-top:.3em;cursor:pointer;overflow:hidden;}
.t-progress-fill{position:absolute;inset:0 auto 0 0;width:0;background:var(--cyan);}
.track.playing .t-progress-fill{background:var(--lime);}
.t-votes{display:flex;gap:.4em;align-items:center;flex:none;}
.v-btn{cursor:pointer;font-family:'VT323',monospace;font-size:1.1rem;border-radius:5px;padding:.15em .6em;
  border:2px solid #fff;transition:transform .08s;display:inline-flex;gap:.35em;align-items:center;}
.v-up{background:#0f3;background:linear-gradient(180deg,var(--lime),#1fae0d);color:#000;box-shadow:0 0 8px rgba(57,255,20,.5);}
.v-down{background:linear-gradient(180deg,var(--hot),#a00060);color:#fff;box-shadow:0 0 8px rgba(255,20,147,.5);}
.v-btn:hover{transform:scale(1.08);}
.v-btn:disabled{opacity:.45;cursor:default;transform:none;filter:saturate(.4);}
.v-tally{color:var(--yellow);font-size:1rem;min-width:1.2em;text-align:center;}
.v-comment-toggle{cursor:pointer;background:#000;color:var(--cyan);border:1px solid var(--cyan);
  border-radius:4px;font-family:inherit;font-size:.95rem;padding:.12em .5em;}
.v-comment-toggle:hover{background:#012;}
.t-voted{color:var(--yellow);font-size:.95rem;}

/* comment area */
.t-comment{display:none;margin-top:.5em;padding-top:.5em;border-top:1px dashed #2a2050;}
.track.open .t-comment{display:block;}
.t-comment form{display:flex;gap:.4em;flex-wrap:wrap;align-items:flex-start;}
.t-comment textarea{flex:1 1 240px;font-family:'VT323',monospace;font-size:1.02rem;background:#000;color:var(--lime);
  border:1px solid var(--hot);padding:.3em .5em;border-radius:4px;resize:vertical;min-height:2.2em;}
.t-comment textarea::placeholder{color:var(--lime-dim);}
.t-note{width:100%;color:var(--cyan);font-size:.9rem;min-height:1.1em;}
.t-comments{margin-top:.45em;display:flex;flex-direction:column;gap:.35em;}
.c-entry{background:#100a22;border-left:3px solid var(--cyan);padding:.3em .55em;font-size:.98rem;animation:slideIn .35s ease;}
.c-entry.down{border-left-color:var(--hot);}
@keyframes slideIn{from{opacity:0;transform:translateX(14px)}to{opacity:1;transform:translateX(0)}}
.c-h{color:var(--yellow);}
.c-v{float:right;font-size:.9rem;}
.c-m{color:#e6ffe0;display:block;clear:both;}

/* ════════════════ MINI PLAYER ════════════════ */
.player{position:fixed;left:50%;bottom:14px;transform:translateX(-50%);z-index:900;
  display:flex;align-items:center;gap:.7rem;
  background:linear-gradient(180deg,#1a0d2e,#0a0418);
  border:2px solid var(--cyan);border-radius:10px;padding:.5rem .8rem;
  box-shadow:0 0 0 2px #000,0 0 24px rgba(0,240,255,.5),0 8px 24px rgba(0,0,0,.6);
  max-width:calc(100vw - 24px);}
.player-btn{cursor:pointer;background:var(--pink);color:#000;border:2px solid #fff;border-radius:6px;
  width:42px;height:42px;font-family:'VT323',monospace;font-size:1.3rem;flex:none;
  box-shadow:0 0 12px var(--pink);transition:transform .08s;}
.player-btn:hover{transform:scale(1.08);}
.player-meta{line-height:1.05;min-width:0;}
.player-now{color:var(--lime);font-size:.95rem;text-shadow:0 0 6px var(--lime);}
.player-song{color:var(--cyan);font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:32vw;}
.player-time{color:var(--yellow);font-size:.95rem;}
.player-eq{display:flex;align-items:flex-end;gap:2px;height:24px;}
.player-eq span{width:4px;background:linear-gradient(var(--lime),var(--cyan));animation:eq .8s ease-in-out infinite;}
.player-eq span:nth-child(2){animation-delay:.15s}
.player-eq span:nth-child(3){animation-delay:.3s}
.player-eq span:nth-child(4){animation-delay:.45s}
.player-eq span:nth-child(5){animation-delay:.6s}
@keyframes eq{0%,100%{height:6px}50%{height:24px}}
.player.paused .player-eq span{animation-play-state:paused;height:5px;}
.player-vol{width:84px;accent-color:var(--pink);}
@media (max-width:640px){ .player-vol,.player-eq{display:none} }

/* ════════════════ FOOTER ════════════════ */
.footer{position:relative;z-index:10;text-align:center;padding:2.2rem 1rem 3rem;color:var(--cyan);}
.footer-ring{letter-spacing:.3em;background:linear-gradient(90deg,var(--pink),var(--cyan),var(--yellow),var(--pink));
  background-size:200%;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:glitterShift 5s linear infinite;margin-bottom:.8rem;}
.footer p{margin:.35em 0;}
.footer-copy{color:var(--lime-dim);font-size:.95rem;}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;animation-iteration-count:1!important;}
  .page{animation:none;}
}
