/* ════════════════════════════════════════════════════════════
   curl your endpoints :: Y2K terminal-glamour net-art
   ════════════════════════════════════════════════════════════ */

: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;
  cursor:none;
  -webkit-font-smoothing:none;
}
@media (max-width:640px){ body{cursor:auto;} .cursor,.cursor-trail{display: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;}

/* ── animated tiled background ───────────────────────────── */
.page{ position:relative; min-height:100vh;
  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);}

/* ════════════════ SPLASH ════════════════ */
#splash{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;}
.splash-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)}}
.splash-inner{position:relative;z-index:2;padding:2rem;max-width:680px;}
.splash-ascii{color:var(--lime);font-size:13px;line-height:1.1;text-shadow:0 0 8px var(--lime);margin:0 auto 1rem;
  filter:drop-shadow(0 0 2px var(--lime));animation:flickerLite 6s infinite;}
.splash-title{font-family:'Bungee Shade',cursive;font-size:clamp(2.2rem,8vw,4.2rem);margin:.2em 0;
  color:var(--pink);line-height:1;}
.splash-sub{font-size:1.3rem;color:var(--cyan);margin:.4rem 0 1rem;}
.splash-sub b{color:var(--yellow);}
.splash-meta code{display:inline-block;font-size:1.1rem;color:var(--lime);background:#000;border:1px solid var(--lime-dim);padding:.4em .8em;margin-bottom:1.4rem;}
.blink{animation:blink 1s steps(2) infinite;color:var(--hot);}
@keyframes blink{50%{opacity:0}}

.enter-btn{display:inline-flex;gap:.5em;align-items:center;cursor:pointer;
  font-family:'VT323',monospace;font-size:2rem;letter-spacing:.15em;color:#000;
  background:linear-gradient(180deg,var(--cyan),var(--lime));
  border:3px solid #fff;padding:.45em 1.4em;border-radius:6px;
  box-shadow:0 0 0 3px var(--pink),0 0 26px var(--cyan),6px 6px 0 #000;
  text-shadow:0 0 1px #fff;transition:transform .08s,box-shadow .2s;animation:btnPulse 1.6s ease-in-out infinite;}
.enter-btn:hover{transform:translate(-2px,-2px) scale(1.04);box-shadow:0 0 0 3px var(--yellow),0 0 40px var(--lime),8px 8px 0 #000;}
.enter-btn:active{transform:translate(2px,2px) scale(.98);}
@keyframes btnPulse{50%{box-shadow:0 0 0 3px var(--yellow),0 0 40px var(--pink),6px 6px 0 #000;}}
.enter-spark{animation:spin 3s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.splash-foot{margin-top:1.2rem;color:var(--purple);font-size:1.1rem;}
#splash.gone{opacity:0;transform:scale(1.15);pointer-events:none;transition:opacity .6s,transform .6s;}

/* 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)}}

/* ════════════════ CUSTOM CURSOR ════════════════ */
.cursor{position:fixed;z-index:2000;width:22px;height:22px;margin:-11px 0 0 -11px;pointer-events:none;
  background:radial-gradient(circle,var(--lime) 30%,transparent 32%);mix-blend-mode:screen;
  transition:transform .08s;}
.cursor::after{content:"✧";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--cyan);font-size:14px;text-shadow:0 0 6px var(--cyan);}
.cursor.click{transform:scale(1.7);}
.cursor-trail{position:fixed;z-index:1999;width:8px;height:8px;margin:-4px 0 0 -4px;pointer-events:none;
  background:var(--hot);border-radius:50%;filter:blur(1px);opacity:.7;mix-blend-mode:screen;transition:transform .14s ease-out;}

/* ════════════════ 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 24s 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%)}}

/* ════════════════ 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:none;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-btn:active{transform:scale(.94);}
.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-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);cursor:none;}
@media (max-width:640px){ .player-meta,.player-vol{display:none} .player-btn{cursor:auto} }

/* ════════════════ HERO ════════════════ */
.page{padding-bottom:90px;}
.hero{position:relative;z-index:10;text-align:center;padding:3rem 1rem 1.5rem;}
.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,6rem);line-height:.95;margin:.2em 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}.w4{color:var(--cyan)}
.w2{animation-delay:.2s}.w3{animation-delay:.4s}.w4{animation-delay:.6s}.w5{animation-delay:.8s}
@keyframes bob{50%{transform:translateY(-8px)}}

.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}}

.hero-tag{color:var(--cyan);font-size:1.25rem;margin:.3rem 0;}
.hero-status{color:var(--lime);font-size:1.1rem;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:1rem;max-width:1180px;margin:0 auto;}
.gif-uc{background:repeating-linear-gradient(45deg,#000 0 14px,var(--yellow) 14px 28px);
  color:#000;font-weight:bold;padding:.35em 1em;border:2px solid #000;letter-spacing:.05em;
  text-shadow:0 0 2px var(--yellow);}
.gif-uc .uc-cone{filter:none;-webkit-text-fill-color:initial;}
.uc-cone{animation:blink 1.4s steps(2) infinite;}
.counter{background:#000;border:2px solid var(--lime);padding:.3em .7em;color:var(--lime);box-shadow:0 0 14px rgba(57,255,20,.4);}
.counter-label{color:var(--cyan);font-size:1rem;}
.counter-digits{font-family:'Micro 5',monospace;letter-spacing:.12em;font-size:1.6rem;color:var(--lime);
  text-shadow:0 0 8px var(--lime);background:#020;padding:0 .25em;}
.webring{display:flex;gap:.4em;align-items:center;background:var(--panel);border:2px solid var(--purple);padding:.25em .5em;box-shadow:0 0 14px rgba(176,38,255,.35);}
.ring-btn{cursor:none;background:var(--purple);color:#fff;border:1px solid #fff;font-family:inherit;font-size:1rem;padding:.1em .5em;border-radius:3px;}
.ring-btn:hover{background:var(--hot);}
.ring-name{color:var(--cyan);font-size:1rem;}
@media (max-width:640px){.ring-btn{cursor:auto}}

/* ════════════════ GRID ════════════════ */
.grid{position:relative;z-index:10;display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:1.2rem;
  max-width:1180px;margin:1rem auto;padding:0 1rem;align-items:start;}
@media (max-width:980px){.grid{grid-template-columns:1fr;}}
.col{display:flex;flex-direction:column;gap:1.2rem;}

/* panels */
.panel{background:var(--panel);border:2px solid #000;box-shadow:var(--shadow);}
.panel-bar{font-size:1.1rem;color:#000;padding:.2em .6em;letter-spacing:.05em;text-align:center;font-weight:bold;}
.panel-pink .panel-bar{background:linear-gradient(90deg,var(--hot),var(--magenta));}
.panel-cyan .panel-bar{background:linear-gradient(90deg,var(--cyan),#7df9ff);}
.panel-lime .panel-bar{background:linear-gradient(90deg,var(--lime),#aaff66);}
.panel-pink{border-color:var(--hot);}
.panel-cyan{border-color:var(--cyan);}
.panel-lime{border-color:var(--lime);}
.panel-body{padding:.8em 1em;}
.panel-pink .panel-body{color:#ffd9f2;}
.bullets{list-style:none;padding:0;margin:.6em 0 0;}
.bullets li{margin:.25em 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;}

/* blinkies */
.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}
.b5{background:var(--purple);color:#fff;animation-delay:.8s}.b6{background:var(--cyan);color:#000;animation-delay:1s}
@keyframes blinkyFlash{50%{filter:brightness(1.6) saturate(1.5)}}

/* now playing / cassette */
.nowplaying{text-align:center;}
.cassette{display:flex;justify-content:center;align-items:center;gap:8px;margin:.4em auto;width:140px;height:60px;
  background:#1a1030;border:2px solid var(--cyan);border-radius:6px;}
.reel{width:26px;height:26px;border-radius:50%;border:3px solid var(--pink);border-top-color:var(--yellow);animation:spin 1.2s linear infinite;}
.tape{flex:1;height:4px;background:var(--cyan);box-shadow:0 0 8px var(--cyan);}
.player.paused ~ .page .reel,.paused-global .reel{animation-play-state:paused;}
.player.awaiting-sound{box-shadow:0 0 18px var(--yellow),var(--shadow);animation:awaitPulse 1.2s ease-in-out infinite;}
.player.awaiting-sound .player-now{color:var(--yellow);text-shadow:0 0 8px var(--yellow);}
@keyframes awaitPulse{0%,100%{filter:brightness(1)}50%{filter:brightness(1.25)}}
.np-title{font-size:1.3rem;margin:.3em 0 0;}
.np-sub{color:var(--cyan);font-size:.95rem;}

/* ════════════════ TERMINAL ════════════════ */
.terminal{background:#000;border:2px solid var(--lime);border-radius:8px;box-shadow:0 0 24px rgba(57,255,20,.3),var(--shadow);overflow:hidden;}
.term-bar{display:flex;align-items:center;gap:.6em;background:#0a160a;padding:.3em .7em;border-bottom:1px solid var(--lime-dim);}
.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}
.term-title{color:var(--lime-dim);font-size:.95rem;}
.term-body{padding:.8em 1em;min-height:230px;font-size:1.05rem;color:var(--lime);text-shadow:0 0 4px rgba(57,255,20,.6);white-space:pre-wrap;word-break:break-word;}
.term-body .prompt{color:var(--cyan);}
.term-body .cmd{color:#fff;}
.term-body .ok{color:var(--lime);}
.term-body .hdr{color:var(--yellow);}
.term-body .dim{color:var(--lime-dim);}
.term-cursor{display:inline-block;width:9px;height:1.05em;background:var(--lime);vertical-align:text-bottom;animation:blink 1s steps(2) infinite;}

/* lyrics */
.lyrics .lyric{margin:.25em 0;color:#d6ffcf;}
.lyrics .big{font-size:1.5rem;margin-bottom:.5em;}
.lyrics .hl{color:var(--hot);font-weight:bold;}

/* api card */
.api-card{background:#0a0618;border:2px dashed var(--cyan);border-radius:8px;padding:1em;box-shadow:var(--shadow);}
.api-method{display:inline-block;background:var(--hot);color:#fff;font-weight:bold;padding:.1em .6em;border-radius:4px;}
.api-path{display:inline-block;color:var(--cyan);margin-left:.4em;font-size:1.2rem;}
.api-body pre{margin:.6em 0;color:var(--yellow);font-size:1rem;background:#000;padding:.6em;border-radius:4px;border:1px solid #222;overflow-x:auto;}
.api-send{cursor:none;background:linear-gradient(180deg,var(--lime),var(--cyan));color:#000;border:2px solid #fff;
  font-family:inherit;font-size:1.15rem;padding:.3em 1em;border-radius:5px;box-shadow:0 0 14px var(--lime);transition:transform .08s;}
.api-send:hover{transform:scale(1.04);} .api-send:active{transform:scale(.96);}
.api-resp{margin-top:.7em;color:var(--lime);font-size:1.05rem;min-height:1.4em;white-space:pre-wrap;}
@media (max-width:640px){.api-send{cursor:auto}}

/* ════════════════ GUESTBOOK ════════════════ */
.gb-form{display:flex;flex-direction:column;gap:.4em;}
.gb-form input,.gb-form textarea{font-family:'VT323',monospace;font-size:1.05rem;background:#000;color:var(--lime);
  border:1px solid var(--hot);padding:.35em .5em;border-radius:4px;resize:vertical;cursor:none;}
.gb-form input::placeholder,.gb-form textarea::placeholder{color:var(--lime-dim);}
@media (max-width:640px){.gb-form input,.gb-form textarea{cursor:auto}}
.gb-submit{cursor:none;align-self:flex-start;background:var(--hot);color:#fff;border:2px solid #fff;font-family:inherit;font-size:1.05rem;padding:.25em 1em;border-radius:5px;box-shadow:0 0 12px var(--hot);transition:transform .08s;}
.gb-submit:hover{transform:scale(1.05);} .gb-submit:active{transform:scale(.95);}
.gb-status{display:block;margin-top:.35em;color:var(--cyan);font-size:.95rem;min-height:1.2em;}
.gb-list{margin-top:.8em;display:flex;flex-direction:column;gap:.5em;max-height:340px;overflow-y:auto;}
.gb-entry{background:#100a22;border-left:3px solid var(--cyan);padding:.4em .6em;font-size:1rem;animation:slideIn .35s ease;}
@keyframes slideIn{from{opacity:0;transform:translateX(14px)}to{opacity:1;transform:translateX(0)}}
.gb-entry .gb-h{color:var(--yellow);}
.gb-entry .gb-t{color:var(--lime-dim);font-size:.8rem;float:right;}
.gb-entry .gb-m{color:#e6ffe0;display:block;clear:both;}

/* stickers */
.stickers{display:flex;flex-wrap:wrap;gap:.5em;justify-content:center;}
.sticker{font-size:.85rem;padding:.3em .6em;border:2px solid #000;box-shadow:2px 2px 0 #000;}
.s1{background:var(--lime);color:#000;transform:rotate(-3deg)}
.s2{background:var(--hot);color:#fff;transform:rotate(2deg)}
.s3{background:var(--cyan);color:#000;transform:rotate(-1deg)}
.s4{background:var(--yellow);color:#000;transform:rotate(3deg)}
.sticker:hover{transform:rotate(0) scale(1.08);transition:transform .15s;}

.headers pre{margin:0;color:var(--lime);font-size:1rem;line-height:1.3;}
.headers .panel-body{background:#000;}

/* ════════════════ FOOTER ════════════════ */
.footer{position:relative;z-index:10;text-align:center;padding:2.5rem 1rem 3rem;color:var(--cyan);}
.footer-ring{color:var(--pink);letter-spacing:.3em;animation:glitterShift 5s linear infinite;
  background:linear-gradient(90deg,var(--pink),var(--cyan),var(--yellow),var(--pink));background-size:200%;
  -webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:.8rem;}
.footer p{margin:.35em 0;}
.footer-curl code{font-size:1.05rem;}
.footer-copy{color:var(--lime-dim);font-size:.95rem;}
.footer-badges{display:flex;gap:.5em;justify-content:center;flex-wrap:wrap;margin-top:1rem;}
.vbadge{background:#000;border:1px solid var(--cyan);color:var(--cyan);font-size:.8rem;padding:.2em .5em;}

@keyframes flickerLite{0%,97%,100%{opacity:1}98%{opacity:.6}99%{opacity:.85}}

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