:root{
  --hue: 320; /* modulated by audio */
  --bg0:#07000a;
  --bg1:#190016;
  --pink:hsl(var(--hue) 100% 72%);
  --pink2:hsl(calc(var(--hue) + 18) 100% 78%);
  --ice:hsl(calc(var(--hue) - 150) 100% 90%);
  --white:rgba(255,255,255,.92);
  --glass:rgba(255,255,255,.10);
  --glass2:rgba(255,255,255,.06);
  --stroke:rgba(255,182,193,.35);
  --shadow:rgba(0,0,0,.60);
  --radius:28px;
  --mx: 50%;
  --my: 30%;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html,body{ height:100%; }

body{
  font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--white);
  overflow:hidden;
  background:
    radial-gradient(1200px 700px at 20% 20%, color-mix(in oklab, var(--pink) 30%, transparent), transparent 55%),
    radial-gradient(900px 600px at 80% 75%, color-mix(in oklab, var(--pink2) 24%, transparent), transparent 60%),
    radial-gradient(700px 560px at 55% 30%, color-mix(in oklab, var(--ice) 14%, transparent), transparent 60%),
    linear-gradient(180deg, var(--bg1), var(--bg0));
}

/* Canvas covers screen */
#fx-canvas{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  z-index:0;
  pointer-events:none; /* don't block UI clicks (fixes hall back button) */
}

/* Pages that need scroll (e.g., /hall) */
body.hall-page{
  overflow:auto;
  -webkit-overflow-scrolling: touch;
}

/* Scanlines */
.scanlines{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.22;
  background:repeating-linear-gradient(
    to bottom,
    rgba(255,255,255,.045),
    rgba(255,255,255,.045) 1px,
    transparent 1px,
    transparent 3px
  );
}
.scanlines.off{ opacity:0 !important; }

/* Grain */
.grain{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:2;
  opacity:.14;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
  background-size:180px 180px;
  animation:grainMove 7s steps(2) infinite;
}
@keyframes grainMove{
  0%{ transform:translate3d(0,0,0); }
  20%{ transform:translate3d(-2%,1%,0); }
  40%{ transform:translate3d(1%,-2%,0); }
  60%{ transform:translate3d(2%,2%,0); }
  80%{ transform:translate3d(-1%,2%,0); }
  100%{ transform:translate3d(0,0,0); }
}

/* Vignette */
.vignette{
  position:fixed;
  inset:-10vh;
  pointer-events:none;
  z-index:3;
  background:radial-gradient(circle at 50% 30%, transparent 0 45%, rgba(0,0,0,.55) 75%, rgba(0,0,0,.80) 100%);
}

/* Center layout */
.wrap{
  position:relative;
  z-index:5;
  height:100%;
  display:grid;
  place-items:center;
  padding:22px;
}

/* Start overlay */
.start-overlay{
  position:fixed;
  inset:0;
  z-index:10;
  display:grid;
  place-items:center;
  background:rgba(0,0,0,.55);
  backdrop-filter: blur(16px) saturate(140%);
  transition: opacity .35s ease, visibility .35s ease;
}
.start-overlay.hidden{ opacity:0; visibility:hidden; }

.start-card{
  position:relative;
  width:min(440px, 92vw);
  padding:26px 22px 22px;
  border-radius:22px;
  border:1px solid rgba(255,182,193,.35);
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.06));
  box-shadow:0 24px 70px rgba(0,0,0,.65), 0 0 50px color-mix(in oklab, var(--pink) 26%, transparent);
  text-align:center;
  animation:startFloat 4.2s ease-in-out infinite;
}
@keyframes startFloat{ 0%,100%{ transform:translateY(0) scale(1);} 50%{ transform:translateY(-8px) scale(1.02);} }

.start-bow{
  position:absolute;
  top:-18px;
  right:-10px;
  font-size:40px;
  filter:drop-shadow(0 0 14px color-mix(in oklab, var(--pink) 70%, transparent));
}
.start-title{
  font-family:Pacifico,cursive;
  font-size:44px;
  letter-spacing:.5px;
  background:linear-gradient(90deg, #fff, var(--pink2), #fff);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.start-sub{
  margin-top:10px;
  font-weight:800;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.88);
}
.start-hint{
  margin-top:8px;
  font-size:13px;
  color:rgba(255,255,255,.70);
}
.start-hint2{
  margin-top:8px;
  font-size:12px;
  color:rgba(255,255,255,.62);
}
.start-ready{
  margin-top:10px;
  font-size:12px;
  letter-spacing:1px;
  color:rgba(255,255,255,.80);
  opacity:.9;
}

.loadbar{
  margin-top:14px;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,182,193,.20);
  overflow:hidden;
}
.loadfill{
  height:100%;
  width:0%;
  border-radius:inherit;
  background:linear-gradient(90deg, var(--pink), var(--pink2), var(--ice));
  box-shadow:0 0 18px color-mix(in oklab, var(--pink) 45%, transparent);
  transition: width .2s ease;
}

/* Card */
.card{
  position:relative;
  width:min(440px, 92vw);
  padding:22px 22px 18px;
  border-radius:var(--radius);
  border:1px solid rgba(255,182,193,.26);
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.04));
  backdrop-filter: blur(30px) saturate(160%);
  box-shadow:0 30px 90px rgba(0,0,0,.62);
  transform-style:preserve-3d;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, filter .18s ease;
  isolation:isolate;
  will-change: transform, box-shadow;
}

/* Specular highlight that follows the cursor */
.card-spec{
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  z-index:0;
  background:radial-gradient(520px 340px at var(--mx) var(--my), rgba(255,255,255,.22), transparent 55%);
  mix-blend-mode:screen;
  opacity:.65;
}

.card-glow{
  position:absolute;
  inset:-2px;
  border-radius:inherit;
  pointer-events:none;
  background:conic-gradient(from 180deg,
    color-mix(in oklab, var(--pink) 70%, transparent),
    color-mix(in oklab, var(--ice) 50%, transparent),
    color-mix(in oklab, var(--pink2) 60%, transparent),
    color-mix(in oklab, var(--pink) 70%, transparent)
  );
  filter: blur(22px);
  opacity:.28;
  z-index:-1;
}

.card.beat{
  animation: beatPop .22s ease-out;
  filter: saturate(1.12) brightness(1.06);
}
@keyframes beatPop{
  0%{ transform:perspective(950px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) scale(1); }
  55%{ transform:perspective(950px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) scale(1.03); }
  100%{ transform:perspective(950px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) scale(1); }
}

.top-row{ display:flex; align-items:center; justify-content:space-between; gap:12px; }

.brand-pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,182,193,.22);
  background:rgba(0,0,0,.18);
}
.dot{
  width:10px; height:10px; border-radius:50%;
  background:var(--pink2);
  box-shadow:0 0 14px color-mix(in oklab, var(--pink2) 75%, transparent);
}
.pill-text{ font-size:12px; letter-spacing:2px; font-weight:900; text-transform:uppercase; color:rgba(255,255,255,.88); }
.pill-divider{ width:1px; height:14px; background:rgba(255,255,255,.18); }
.pill-text.edgy{ color:rgba(201,241,255,.92); }

.bow{
  font-size:34px;
  filter:drop-shadow(0 0 14px color-mix(in oklab, var(--pink) 70%, transparent));
  transform: translateZ(16px);
}

/* Avatar */
.avatar-btn{
  margin:18px auto 10px;
  width:168px;
  height:168px;
  border-radius:50%;
  border:none;
  background:transparent;
  display:grid;
  place-items:center;
  cursor:pointer;
  position:relative;
  transform: translateZ(24px);
}
.avatar{
  width:154px;
  height:154px;
  border-radius:50%;
  object-fit:cover;
  border:1px solid rgba(255,182,193,.22);
  box-shadow:0 0 30px color-mix(in oklab, var(--pink) 55%, transparent), 0 0 80px color-mix(in oklab, var(--pink2) 25%, transparent);
  transition: transform .25s ease, box-shadow .25s ease;
}
.avatar-btn:hover .avatar{ transform: scale(1.04); box-shadow:0 0 40px color-mix(in oklab, var(--pink) 70%, transparent), 0 0 130px color-mix(in oklab, var(--pink2) 40%, transparent); }

.avatar-ring{
  position:absolute;
  inset:0;
  border-radius:50%;
  border:2px solid rgba(255,154,213,.35);
  box-shadow:0 0 18px color-mix(in oklab, var(--pink) 45%, transparent);
  animation:ring 2.6s ease-in-out infinite;
}
.avatar-ring2{
  position:absolute;
  inset:-8px;
  border-radius:50%;
  border:1px solid rgba(201,241,255,.22);
  box-shadow:0 0 26px rgba(201,241,255,.16);
  animation:ring2 3.4s ease-in-out infinite;
}
.avatar-spec{
  position:absolute;
  inset:0;
  border-radius:50%;
  pointer-events:none;
  background:radial-gradient(120px 80px at 35% 30%, rgba(255,255,255,.22), transparent 60%);
  mix-blend-mode:screen;
  opacity:.8;
}
@keyframes ring{ 0%,100%{ transform:scale(1); opacity:.65; } 50%{ transform:scale(1.05); opacity:.95; } }
@keyframes ring2{ 0%,100%{ transform:scale(1.02); opacity:.35; } 50%{ transform:scale(1.08); opacity:.65; } }

/* Username */
.username{
  text-align:center;
  margin-top:8px;
  font-family:Pacifico,cursive;
  font-size:46px;
  line-height:1;
}
.shine{
  display:inline-block;
  background:linear-gradient(90deg, #fff, var(--pink2), #fff);
  background-size:240% 100%;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:shine 3s linear infinite;
  text-shadow:0 0 12px color-mix(in oklab, var(--pink) 40%, transparent), 0 0 26px color-mix(in oklab, var(--pink2) 28%, transparent);
}
@keyframes shine{ 0%{ background-position:220% 0; } 100%{ background-position:-220% 0; } }

.tagline{ text-align:center; margin-top:8px; font-size:13px; letter-spacing:1px; color:rgba(255,255,255,.70); }

/* Links */
.links{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin:18px 0 10px;
}
.link-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 12px;
  border-radius:16px;
  border:1px solid rgba(255,182,193,.22);
  text-decoration:none;
  color:rgba(255,255,255,.92);
  background:rgba(0,0,0,.16);
  backdrop-filter: blur(10px) saturate(140%);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, filter .18s ease;
  will-change: transform;
}
.link-btn i{ font-size:18px; }
.link-btn:hover{ transform:translateY(-3px) scale(1.02); border-color: rgba(255,154,213,.55); box-shadow:0 0 26px color-mix(in oklab, var(--pink) 22%, transparent); }
.link-btn.discord:hover{ border-color: rgba(201,241,255,.45); box-shadow:0 0 24px rgba(201,241,255,.12), 0 0 26px rgba(255,110,199,.10); }

.chip{ font-size:11px; font-weight:900; letter-spacing:1.5px; padding:4px 8px; border-radius:999px; border:1px solid rgba(255,182,193,.22); color:rgba(255,255,255,.78); }

/* Player */
.player{
  margin-top:10px;
  padding:14px 14px 12px;
  border-radius:18px;
  border:1px solid rgba(255,182,193,.18);
  background:linear-gradient(180deg, rgba(0,0,0,.22), rgba(0,0,0,.10));
}
.player-row{ display:flex; align-items:center; gap:12px; }
.player-row.bottom{ margin-top:10px; justify-content:space-between; }

.icon-btn{
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(255,182,193,.18);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.92);
  cursor:pointer;
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
  will-change: transform;
}
.icon-btn:hover{ transform:translateY(-2px) scale(1.06); border-color: rgba(255,154,213,.55); box-shadow:0 0 20px color-mix(in oklab, var(--pink) 18%, transparent); }

.track{ flex:1; min-width:0; }
.track-title{ font-size:13px; font-weight:800; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.track-meta{ margin-top:2px; font-size:12px; color:rgba(255,255,255,.70); display:flex; align-items:center; gap:8px; }
.sep{ opacity:.6; }

.progress-wrap{ margin-top:12px; }
.progress{
  position:relative;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,182,193,.16);
  cursor:pointer;
  outline:none;
}
.progress-fill{
  height:100%;
  width:0%;
  border-radius:inherit;
  background:linear-gradient(90deg, color-mix(in oklab, var(--pink) 90%, transparent), color-mix(in oklab, var(--pink2) 88%, transparent), color-mix(in oklab, var(--ice) 55%, transparent));
  box-shadow:0 0 18px color-mix(in oklab, var(--pink) 45%, transparent);
}
.progress-knob{
  position:absolute;
  top:50%;
  left:0%;
  transform:translate(-50%,-50%);
  width:18px;
  height:18px;
  border-radius:50%;
  background:rgba(255,255,255,.90);
  box-shadow:0 0 20px color-mix(in oklab, var(--pink) 35%, transparent);
  border:1px solid color-mix(in oklab, var(--pink) 35%, rgba(255,110,199,.35));
}

.vol{ display:flex; align-items:center; gap:10px; color:rgba(255,255,255,.80); }
.vol-slider{ width:150px; accent-color: var(--pink2); }

.small-btn{
  border:1px solid rgba(255,182,193,.16);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.86);
  padding:9px 10px;
  border-radius:12px;
  cursor:pointer;
  font-weight:900;
  letter-spacing:1px;
  font-size:11px;
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
  will-change: transform;
}
.small-btn:hover{ transform:translateY(-2px) scale(1.04); border-color: rgba(255,154,213,.55); box-shadow:0 0 18px color-mix(in oklab, var(--pink) 16%, transparent); }

.player-actions{ display:flex; gap:10px; }

/* Footer */
.footer{ margin-top:14px; border-top:1px solid rgba(255,182,193,.14); padding-top:12px; }
.footer-link{ display:flex; align-items:center; justify-content:center; gap:10px; text-decoration:none; color:rgba(255,255,255,.86); letter-spacing:2px; font-weight:900; font-size:12px; text-transform:uppercase; }
.footer-text{ padding:8px 12px; border-radius:999px; background:rgba(0,0,0,.16); border:1px solid rgba(255,182,193,.18); box-shadow:0 0 22px color-mix(in oklab, var(--pink) 10%, transparent); }
.footer-badge{ filter:drop-shadow(0 0 10px color-mix(in oklab, var(--pink) 40%, transparent)); }

/* Mobile */
@media (max-width:420px){
  .username{ font-size:42px; }
  .vol-slider{ width:120px; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .avatar-ring, .avatar-ring2, .shine, .start-card, .grain { animation:none !important; }
}

/* HALL highlight button */
.hall-btn{
  border-color:rgba(255,154,213,.6) !important;
  box-shadow:0 0 22px rgba(255,110,199,.25);
}

.hall-btn:hover{
  box-shadow:0 0 34px rgba(255,110,199,.45);
  transform:translateY(-3px) scale(1.02);
}

.hall-icon{
  animation:hallPulse 2.6s ease-in-out infinite;
}

@keyframes hallPulse{
  0%,100%{filter:drop-shadow(0 0 0 rgba(255,110,199,0));}
  50%{filter:drop-shadow(0 0 8px rgba(255,110,199,.65));}
}

/* NEW chip */
.chip.new{
  background:linear-gradient(90deg,var(--pink),var(--pink2));
  color:#000;
  font-weight:900;
  box-shadow:0 0 14px rgba(255,110,199,.35);
}


/* ===== Accessibility & UX polish ===== */
.skip-link{
  position:absolute;
  left:12px;
  top:-60px;
  z-index:9999;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(0,0,0,.72);
  border:1px solid rgba(255,255,255,.22);
  color:var(--white);
  text-decoration:none;
  backdrop-filter: blur(10px);
  transition: transform .18s ease, top .18s ease, opacity .18s ease;
  opacity:0;
}
.skip-link:focus{
  top:12px;
  opacity:1;
  outline:2px solid color-mix(in oklab, var(--pink) 70%, white);
  outline-offset:2px;
}

:focus-visible{
  outline:2px solid color-mix(in oklab, var(--pink) 70%, white);
  outline-offset:3px;
}

/* Bigger hit area on mobile */
.icon-btn, .small-btn, .link-btn{
  -webkit-tap-highlight-color: transparent;
}

/* Footer */
.footer{
  margin-top:14px;
  display:flex;
  justify-content:center;
  gap:10px;
  align-items:center;
  opacity:.92;
  font-size:12px;
  letter-spacing:.02em;
  text-shadow:0 10px 30px rgba(0,0,0,.65);
}
.footer-link{
  color:color-mix(in oklab, var(--pink2) 70%, white);
  text-decoration:none;
}
.footer-link:hover{
  text-decoration:underline;
}
.footer-dot{ opacity:.65; }

/* Mobile viewport stability */
html, body{
  height:100%;
  min-height:100svh;
}
@supports (height: 100dvh){
  html, body{ min-height:100dvh; }
}
body{
  overscroll-behavior:none;
  touch-action: manipulation;
}

/* Reduce motion support */
@media (prefers-reduced-motion: reduce){
  *{
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 1ms !important;
    scroll-behavior: auto !important;
  }
  .scanlines, .grain{ display:none !important; }
}

/* Micro interaction helpers */
.ripple{
  position:absolute;
  inset:auto;
  border-radius:999px;
  pointer-events:none;
  transform: translate(-50%,-50%);
  opacity:.8;
  filter: blur(.2px);
  animation: ripple .55s ease-out forwards;
  background: radial-gradient(circle, color-mix(in oklab, var(--pink) 70%, white) 0%, transparent 62%);
}
@keyframes ripple{
  from{ width:10px; height:10px; opacity:.72; }
  to{ width:220px; height:220px; opacity:0; }
}

/* Magnetic hover feel */
.magnet{
  will-change: transform;
  transition: transform .12s ease;
}

/* Low power indicator class (optional subtle) */
body.low-power .scanlines{ opacity:.45; }
body.low-power .grain{ opacity:.35; }
