/* ═══════════════════════════════════════════════════════════
   BE:KI Jukebox — Host CSS  (80s Neon Design)
   ═══════════════════════════════════════════════════════════ */

/* ── Lobby Layout ─────────────────────────────────────────── */
.lobby-wrap{
  flex:1;display:grid;grid-template-columns:1fr 1fr;gap:0;overflow:hidden;
}
.lobby-left{
  padding:28px 28px 28px;display:flex;flex-direction:column;gap:18px;overflow-y:auto;
  border-right:1px solid var(--border);
  background:linear-gradient(160deg,rgba(0,200,255,.06) 0%,transparent 40%);
}
/* tighter logo→QR gap */
.lobby-brand{margin-bottom:-11px;}
.lobby-right{
  padding:32px 28px 0;display:flex;flex-direction:column;gap:6px;overflow-y:hidden;
  background:linear-gradient(200deg,rgba(255,16,144,.04) 0%,transparent 40%);
  position:relative;
}
/* all direct content children above the soundwave bg */
.lobby-right > *:not(.lobby-soundwave-deco){position:relative;z-index:1;}

/* ── Logo & Brand ─────────────────────────────────────────── */
.lobby-brand{display:flex;flex-direction:column;gap:0;}
.lobby-logo-img{
  width:70%;
  height:auto;
  display:block;
  mix-blend-mode:lighten;
}
.lobby-sub{
  font-size:11px;color:var(--gold-dim);font-family:sans-serif;
  text-transform:uppercase;letter-spacing:.16em;padding-left:2px;
  margin-top:-4px;
}
/* Legacy */
.lobby-title{font-size:30px;letter-spacing:4px;font-weight:700;text-transform:uppercase;
  color:var(--neon);text-shadow:0 0 12px rgba(0,200,255,.7);}
.lobby-jukebox-img{display:none;}

/* ── Room Code Block ──────────────────────────────────────── */
.lobby-room-block{}
.room-code-box{
  background:var(--bg-panel);
  border:1px solid var(--neon);
  border-radius:10px;
  padding:18px 20px;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  box-shadow:0 0 32px rgba(0,200,255,.4),inset 0 0 32px rgba(0,200,255,.1);
}
.room-code-hint{
  font-size:10px;color:var(--gold-dim);font-family:sans-serif;
  text-transform:uppercase;letter-spacing:.14em;
}
.room-code{
  font-size:54px;letter-spacing:14px;font-weight:700;
  color:var(--neon);
  text-shadow:0 0 10px var(--neon),0 0 30px rgba(0,200,255,.9),0 0 70px rgba(0,200,255,.6),0 0 120px rgba(0,200,255,.3);
}
.qr-img{
  width:148px;height:148px;border-radius:6px;
  border:1px solid var(--border);
  filter:invert(1) hue-rotate(180deg);/* makes QR neon-friendly */
  opacity:.9;
}
.controller-url{
  font-size:10px;color:var(--gold-faint);font-family:monospace;
  word-break:break-all;text-align:center;
}

/* ── Lobby Sections ───────────────────────────────────────── */
.section-title{
  font-size:10px;color:var(--gold-dim);font-family:sans-serif;
  text-transform:uppercase;letter-spacing:.14em;margin-bottom:2px;
}
.lobby-section{display:flex;flex-direction:column;gap:8px;}
.lobby-groups-section{position:relative;}
.lobby-vinyl-deco{
  width:130px;height:130px;position:absolute;bottom:-12px;right:-12px;
  opacity:.5;pointer-events:none;
}

/* ── Spotify Button ───────────────────────────────────────── */
.spotify-btn{
  background:transparent;
  border:1px solid var(--green);
  border-radius:7px;
  color:var(--green);
  font-family:sans-serif;font-size:13px;padding:9px 18px;
  box-shadow:0 0 10px rgba(57,255,20,.3);
}
.spotify-btn.connected{opacity:.55;cursor:default;box-shadow:none;}

/* ── Groups Preview (Lobby) ───────────────────────────────── */
.groups-preview{display:flex;flex-direction:column;gap:5px;}
.group-preview-row{display:flex;align-items:center;gap:8px;font-family:sans-serif;font-size:13px;}
.gp-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.gp-waiting{color:var(--gold-faint);font-style:italic;}

/* ── Category Grid ────────────────────────────────────────── */
.category-grid{display:flex;flex-direction:column;gap:8px;}
.cat-group-label{
  font-size:11px;color:var(--gold-dim);font-family:sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.14em;padding-top:24px;
  text-shadow:0 0 6px rgba(106,158,196,.4);
}
.cat-group{display:flex;flex-wrap:wrap;gap:5px;padding-top:4px;}
.btn-cat{
  background:var(--bg-panel);border:1px solid var(--border);border-radius:5px;
  padding:6px 10px;font-family:sans-serif;font-size:12px;color:var(--gold-dim);
  white-space:nowrap;
  transition:border-color .15s,color .15s,box-shadow .15s;
}
.btn-cat:hover{border-color:var(--neon-pink);color:var(--neon-pink);}
.btn-cat.active{
  border-color:var(--neon-pink);color:var(--neon-pink);
  background:rgba(255,16,144,.08);
  box-shadow:0 0 8px rgba(255,16,144,.5);
}
.cat-label{font-size:12px;}
.cat-song-count{
  font-size:11px;color:var(--gold-faint);font-family:sans-serif;
  font-style:italic;padding-top:4px;
}
.btn-cat-alle{
  border-style:dashed;
}

/* ── Mode Buttons ─────────────────────────────────────────── */
.mode-row{display:flex;gap:8px;}
.btn-mode{
  flex:1;background:var(--bg-panel);border:1px solid var(--border);border-radius:7px;
  padding:10px 6px;display:flex;flex-direction:column;gap:3px;text-align:center;
  transition:border-color .15s,box-shadow .15s;
}
.btn-mode:hover{border-color:var(--neon);}
.btn-mode.active{
  border-color:var(--neon);
  box-shadow:0 0 12px rgba(0,200,255,.4);
}
.mode-lbl{font-size:13px;color:var(--neon);font-family:sans-serif;font-weight:700;}
.mode-detail{font-size:10px;color:var(--gold-dim);font-family:sans-serif;}

/* ── Lobby Footer ─────────────────────────────────────────── */
.lobby-footer{padding-top:8px;display:flex;flex-direction:column;align-items:center;gap:6px;}
.version-tag{
  position:absolute;bottom:8px;right:22px;
  font-size:11px;color:var(--gold-faint);font-family:sans-serif;
  opacity:.5;letter-spacing:.04em;
}
.loading-msg{
  font-size:13px;color:var(--neon);font-family:sans-serif;text-align:center;
  padding:12px;animation:neonPulse 1.2s ease-in-out infinite;
}

/* ── Start-Button als Grafik ──────────────────────────────── */
.btn-start-graphic{
  background:transparent;border:none;padding:0;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  cursor:pointer;width:100%;
  transition:transform .2s,filter .2s;
}
.btn-start-graphic:not(:disabled):hover{
  transform:scale(1.04);
  filter:brightness(1.2);
}
.btn-start-graphic:disabled{
  opacity:.28;cursor:not-allowed;
}
.btn-start-graphic img{
  width:250px;max-width:81%;height:auto;
  mix-blend-mode:lighten;
}
.btn-start-label{
  font-family:'Trebuchet MS',Arial,sans-serif;font-size:13px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  color:var(--neon-pink);
  text-shadow:0 0 8px rgba(255,16,144,.7);
}
.btn-start-graphic:not(:disabled) .btn-start-label{
  animation:neonPulse 2.5s ease-in-out infinite;
}

/* ── Kategorien-Zeile mit großem Tape rechts ─────────────── */
.lobby-cat-row{
  display:flex;align-items:flex-start;gap:12px;
}
.lobby-cat-row > .lobby-section{flex:1;min-width:0;}
.lobby-cat-deco-wrap{
  width:min(350px,32%);flex-shrink:0;align-self:flex-start;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  transition:transform .2s,filter .2s;
}
.lobby-cat-deco-wrap:hover{transform:scale(1.05);filter:brightness(1.2);}
.anleitung-blink{
  margin-top:52px;margin-bottom:2px;
  font-family:'Trebuchet MS',Arial,sans-serif;
  font-size:15px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:#00c8ff;
  text-shadow:0 0 6px #00c8ff,0 0 20px #00c8ff,0 0 40px rgba(0,200,255,.5);
  animation:anlBlink 1.5s ease-in-out infinite;
  position:relative;z-index:2;
}
@keyframes anlBlink{
  0%,100%{color:#00c8ff;text-shadow:0 0 6px #00c8ff,0 0 20px #00c8ff,0 0 40px rgba(0,200,255,.5);}
  50%{color:#ff1090;text-shadow:0 0 6px #ff1090,0 0 20px #ff1090,0 0 40px rgba(255,16,144,.5);}
}
.lobby-cat-deco{
  width:100%;height:auto;
  opacity:.82;
}
.lobby-soundwave-deco{
  position:absolute;
  top:calc(23.3vw - 21px);
  left:28px;right:28px;
  width:calc(100% - 56px);height:auto;
  opacity:.55;
  mix-blend-mode:lighten;   /* dark PNG background becomes invisible */
  animation:swPulse 2.6s ease-in-out infinite;
  pointer-events:none;
  z-index:0;
}
.lobby-soundwave-deco.playing{
  opacity:.85;
  animation:swPulse 1.6s ease-in-out infinite;
}

/* ── Spielanleitung Modal ────────────────────────────────── */
.modal-overlay{
  display:none;position:fixed;inset:0;z-index:10000;
  background:rgba(4,8,20,.88);
  backdrop-filter:blur(6px);
  justify-content:center;align-items:center;
  padding:24px;
}
.modal-overlay.open{display:flex;}

.modal-anleitung{
  background:var(--bg-dark);
  border:1px solid var(--neon);
  border-radius:14px;
  box-shadow:0 0 40px rgba(0,200,255,.25),0 0 80px rgba(0,200,255,.08);
  max-width:660px;width:100%;max-height:85vh;overflow-y:auto;
  padding:32px 28px 28px;
  position:relative;
  scrollbar-width:thin;
  scrollbar-color:var(--border) transparent;
}
.modal-close{
  position:absolute;top:12px;right:16px;
  background:none;border:none;
  color:var(--gold-dim);font-size:28px;line-height:1;
  cursor:pointer;transition:color .15s;
}
.modal-close:hover{color:var(--neon-pink);}

.modal-title{
  font-family:'Trebuchet MS',Arial,sans-serif;
  font-size:22px;letter-spacing:2px;text-transform:uppercase;
  color:var(--neon);
  text-shadow:0 0 10px rgba(0,200,255,.6);
  margin-bottom:24px;text-align:center;
}

.anl-section{
  display:flex;gap:14px;align-items:flex-start;
  padding:14px 0;
  border-bottom:1px solid var(--border);
}
.anl-section:last-child{border-bottom:none;}

.anl-icon{
  font-size:22px;flex-shrink:0;width:32px;text-align:center;
  padding-top:2px;
}
.anl-section h3{
  font-family:'Trebuchet MS',Arial,sans-serif;
  font-size:14px;font-weight:700;color:var(--neon-pink);
  text-transform:uppercase;letter-spacing:.08em;
  margin-bottom:6px;
}
.anl-section p{
  font-family:sans-serif;font-size:13px;color:var(--gold);
  line-height:1.6;margin-bottom:4px;
}
.anl-section strong{color:var(--neon);}

.anl-roles{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.anl-role{
  background:var(--bg-panel);
  border:1px solid var(--border);border-radius:8px;
  padding:10px 12px;
  font-family:sans-serif;font-size:12px;color:var(--gold);
  line-height:1.55;
}
.anl-role strong{color:var(--neon-pink);font-size:12px;}

.anl-steps,.anl-list{
  padding-left:18px;margin:0;
  font-family:sans-serif;font-size:13px;color:var(--gold);
  line-height:1.7;
}
.anl-steps li,.anl-list li{margin-bottom:3px;}
.anl-steps li::marker{color:var(--neon-pink);}
.anl-list li::marker{color:var(--neon);}

.anl-modes{
  display:flex;gap:10px;margin:6px 0;
}
.anl-modes > div{
  flex:1;
  background:var(--bg-panel);
  border:1px solid var(--border);border-radius:7px;
  padding:8px 10px;text-align:center;
  font-family:sans-serif;font-size:12px;color:var(--gold);
}
.anl-modes > div strong{display:block;color:var(--neon);font-size:13px;margin-bottom:2px;}
.anl-modes > div span{color:var(--gold-dim);font-size:11px;}

.anl-hint{
  font-family:sans-serif;font-size:11px;color:var(--gold-faint);
  font-style:italic;margin-top:6px;line-height:1.5;
}

@media (max-width:560px){
  .modal-anleitung{padding:20px 16px 16px;}
  .anl-roles{grid-template-columns:1fr;}
  .anl-modes{flex-direction:column;}
  .anl-icon{display:none;}
}

/* ═══════════════════════════════════════════════════════════
   GAME SCREEN
   ═══════════════════════════════════════════════════════════ */

/* ── Top Bar ──────────────────────────────────────────────── */
.game-topbar{
  background:var(--bg-dark);
  border-bottom:1px solid var(--border);
  padding:6px 16px;
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0;
}
.round-info{
  color:var(--gold-dim);font-size:14px;font-family:sans-serif;
  letter-spacing:.04em;flex:1;
}
.group-dots-top{display:flex;gap:5px;}
.gdot{width:8px;height:8px;border-radius:50%;}

/* ── Game Main Layout ─────────────────────────────────────── */
.game-main{display:flex;overflow:hidden;flex:1;min-height:0;}
.side-panel{display:none;}

/* ── Info-Block (Song + Gruppen-Tipps) ────────────────────── */
.game-info-block{
  flex-shrink:0;background:var(--bg-dark);
  border-bottom:1px solid var(--border);
  padding:14px 20px;display:flex;flex-direction:column;gap:10px;
}
.ib-top-row{display:flex;align-items:center;gap:16px;}
.ib-song{flex:1;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;}
.ib-unknown{color:var(--gold-faint);font-size:32px;font-family:sans-serif;font-style:italic;}
.ib-artist{font-size:40px;font-weight:700;color:var(--gold);}
.ib-sep{color:var(--gold-dim);font-size:28px;}
.ib-title{font-size:24px;color:var(--gold-dim);font-style:italic;}
.ib-year{
  font-size:62px;font-weight:700;color:var(--neon);line-height:1;
  text-shadow:0 0 14px var(--neon),0 0 40px rgba(0,200,255,.6);
}
.ib-result{
  font-size:14px;font-family:sans-serif;padding:5px 14px;
  border-radius:5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
}
.ib-action{flex-shrink:0;display:flex;align-items:center;}
.ib-btn{padding:14px 28px;font-size:16px;}
.ib-hint{color:var(--gold-dim);font-size:15px;font-family:sans-serif;}
.ib-groups{display:flex;gap:10px;}
.ib-group{
  flex:1;border:1px solid var(--border);border-radius:8px;
  overflow:hidden;display:flex;flex-direction:column;
}
.ib-group-active{background:rgba(255,255,255,.02);}
.ib-group-name{
  font-size:18px;font-family:sans-serif;font-weight:700;
  padding:9px 12px;text-align:center;
  text-transform:uppercase;letter-spacing:.08em;
}
.ib-group-body{padding:6px 12px;display:flex;flex-direction:column;gap:3px;}
.ib-line{font-size:14px;font-family:sans-serif;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

/* ── Karten-Reihen (füllen den Spielfeld-Mittelbereich) ─────── */
.game-cards-rows{
  flex:1;display:flex;flex-direction:column;
  padding:5px 10px;gap:4px;overflow:hidden;
}
.host-cards-row{
  flex:1;display:flex;align-items:center;gap:10px;
  border-radius:8px;padding:4px 8px;min-height:0;
  transition:border-color .3s,box-shadow .3s;
  position:relative;overflow:hidden;
}
.hcr-active::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(90deg,transparent 0%,currentColor 50%,transparent 100%);
  opacity:.04;
  animation:activeGlow 2.5s ease-in-out infinite;
}
@keyframes activeGlow{
  0%,100%{opacity:.03;transform:translateX(-60%);}
  50%{opacity:.08;transform:translateX(60%);}
}
.host-cards-label{
  width:62px;flex-shrink:0;
  display:flex;flex-direction:column;align-items:flex-end;gap:2px;
  padding-right:7px;border-right:1px solid var(--border);
}
.hcl-name{
  font-size:10px;font-family:sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.05em;text-align:right;
}
.hcl-score{
  font-size:26px;font-weight:700;line-height:1;
  text-shadow:0 0 10px currentColor;
}
.hcl-bp{
  font-size:9px;font-family:sans-serif;font-weight:700;
  opacity:.7;text-align:right;letter-spacing:.03em;
}
.host-cards-list{
  flex:1;display:flex;flex-direction:row;align-items:center;
  gap:6px;overflow-x:auto;flex-wrap:nowrap;padding:4px 0;
}
.host-cards-list::-webkit-scrollbar{height:3px;}
.host-cards-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.hcr-empty{font-size:12px;color:var(--gold-faint);font-family:sans-serif;font-style:italic;}
.side-panel,.panel-left,.panel-right{display:none;}
.center-area{
  flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-dark);
}

/* ── Soundwave-Dekoration (Game, unten rechts) ────────────── */
.soundwave-deco{
  position:absolute;
  bottom:50px;
  right:18px;
  width:38%;
  max-width:360px;
  height:auto;
  pointer-events:none;
  z-index:2;
  opacity:0;
  mix-blend-mode:lighten;
  transition:opacity .6s ease;
  transform-origin:center bottom;
}
.soundwave-deco.playing{
  opacity:.65;
  animation:swPulse 1.8s ease-in-out infinite;
}
@keyframes swPulse{
  0%,100%{opacity:.45;transform:scaleY(1);}
  50%{opacity:.75;transform:scaleY(1.1);}
}

/* ── Bottom Bar ───────────────────────────────────────────── */
.game-bottombar{
  background:var(--bg-dark);border-top:1px solid var(--border);
  padding:6px 18px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;
}
.bottom-hint{color:var(--gold-faint);font-size:12px;font-family:sans-serif;}
.bottom-actions{display:flex;gap:7px;}

/* ── Now Playing ──────────────────────────────────────────── */
.now-playing{
  background:var(--bg-dark);border-bottom:1px solid var(--border);
  padding:12px 18px;display:flex;align-items:center;gap:14px;flex-shrink:0;
}
.vinyl{
  width:70px;height:70px;border-radius:50%;
  background:var(--bg-deep);
  border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  position:relative;flex-shrink:0;
  box-shadow:0 0 14px rgba(0,200,255,.3);
}
.vr1{position:absolute;width:52px;height:52px;border-radius:50%;border:1px solid var(--border);}
.vr2{position:absolute;width:32px;height:32px;border-radius:50%;border:1px solid var(--border);}
.vc{
  width:11px;height:11px;border-radius:50%;
  background:var(--bg-deep);border:1.5px solid var(--neon);
  box-shadow:0 0 4px var(--neon);
}
.vinyl.spinning{animation:spin 3s linear infinite;}
.now-info{flex:1;min-width:0;}
.now-title{
  font-size:26px;font-weight:700;letter-spacing:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  color:var(--gold);
}
.now-sub{color:var(--gold-dim);font-size:12px;font-family:sans-serif;margin-top:2px;}
.progress-wrap{margin-top:7px;display:flex;align-items:center;gap:7px;}
.progress-bar{
  flex:1;height:4px;background:var(--bg-mid);border-radius:2px;
  border:1px solid var(--border);overflow:hidden;
}
.progress-fill{
  height:100%;width:0;border-radius:3px;
  background:linear-gradient(90deg,var(--neon),var(--neon-pink));
  box-shadow:0 0 8px rgba(0,200,255,.8);
  transition:width .1s linear;
}
.progress-time{color:var(--gold-faint);font-size:11px;font-family:sans-serif;white-space:nowrap;}
.active-badge{
  font-size:11px;font-family:sans-serif;padding:5px 12px;border-radius:5px;
  white-space:nowrap;border:1px solid currentColor;
  font-weight:700;text-transform:uppercase;letter-spacing:.06em;
}
.guessing-countdown{
  font-size:11px;color:var(--neon);font-family:sans-serif;margin-top:4px;
  animation:neonPulse 1.5s ease-in-out infinite;
}

/* ── Guess Bar ────────────────────────────────────────────── */
.bonus-bar{
  background:rgba(0,0,0,.3);border-bottom:1px solid var(--border);
  padding:6px 12px;display:flex;align-items:stretch;gap:8px;flex-shrink:0;flex-wrap:wrap;
}
.guess-group{
  flex:1;min-width:120px;border:1px solid var(--border);border-radius:5px;
  padding:5px 10px;display:flex;flex-direction:column;gap:2px;
}
.guess-group-active{background:rgba(255,255,255,.03);}
.guess-group-name{
  font-size:10px;font-family:sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
}
.guess-group-text{
  font-size:15px;font-family:sans-serif;color:var(--gold);
  display:flex;flex-direction:column;gap:1px;
}
.guess-group-text .guess-title-part{font-size:12px;color:var(--gold-dim);}
.guess-label{font-size:10px;color:var(--gold-faint);font-family:sans-serif;font-weight:400;}
.guess-empty .guess-empty-text{color:var(--gold-faint);font-size:13px;}

/* ── Bonus Point Rows ─────────────────────────────────────── */
.rv-bp-row{
  display:flex;align-items:center;gap:8px;font-family:sans-serif;font-size:13px;
  padding:4px 8px;border-left:3px solid var(--border);flex-wrap:wrap;
}
.rv-bp-name{font-weight:600;font-size:13px;min-width:60px;}
.rv-bp-ok{color:var(--green);}
.rv-bp-wrong{color:var(--red);}
.rv-bp-badge{
  background:var(--neon);color:var(--bg-deep);font-size:11px;font-weight:700;
  padding:2px 6px;border-radius:10px;margin-left:auto;
}
.rv-steal-row{
  width:100%;font-family:sans-serif;font-size:13px;color:var(--gold-dim);
  padding:4px 8px;font-style:italic;
}

/* ── Group Panels (Side) ──────────────────────────────────── */
.group-panel{
  display:flex;flex-direction:column;gap:3px;
  border-radius:8px;padding:5px;
  transition:box-shadow .3s,border .3s;
}
.gp-active-badge{
  font-size:10px;font-weight:700;font-family:sans-serif;text-align:center;
  border-radius:4px;padding:3px 6px;letter-spacing:1px;margin-bottom:3px;
  text-transform:uppercase;color:#000;
}
.gp-name{
  font-size:13px;font-family:sans-serif;font-weight:700;text-align:center;
  padding:4px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em;
}
.gp-score{
  font-size:40px;font-weight:700;text-align:center;line-height:1.1;
  text-shadow:0 0 14px currentColor;
}
.gp-timebank{
  font-size:12px;font-family:sans-serif;text-align:center;font-weight:700;
  padding:1px 0;letter-spacing:.04em;
}
.gp-divider{height:1px;background:var(--border);margin:3px 0;}
.gp-bp-label{font-size:10px;color:var(--gold-faint);text-align:center;font-family:sans-serif;}
.bp-dots{display:flex;gap:3px;justify-content:center;flex-wrap:wrap;margin-top:2px;}
.bp-dot{
  width:10px;height:10px;border-radius:50%;
  background:transparent;border:1.5px solid var(--border);
}
.bp-count{font-size:12px;color:var(--gold-dim);text-align:center;font-family:sans-serif;}
.gp-cards{
  display:flex;flex-direction:row;gap:4px;margin-top:4px;
  overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;
}
.gp-cards::-webkit-scrollbar{height:3px;}
.gp-cards::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.mini-card{
  flex-shrink:0;
  min-width:170px;height:150px;
  border-radius:8px;padding:12px 8px 8px;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  font-family:sans-serif;
  border:1px solid rgba(255,255,255,.14);
  overflow:hidden;
}
.mc-year{font-size:44px;font-weight:700;line-height:1;flex-shrink:0;}
.mc-title{
  font-size:13px;font-weight:600;opacity:.9;text-align:center;
  overflow:hidden;white-space:nowrap;text-overflow:ellipsis;
  width:100%;max-width:154px;
}
.mc-artist{
  font-size:11px;opacity:.65;text-align:center;
  overflow:hidden;white-space:nowrap;text-overflow:ellipsis;
  width:100%;max-width:154px;
}
/* Host-Timeline: komplett per Inline-Style in host.js gerendert — kein CSS hier */
.tl-dot-lbl{font-size:11px;font-family:sans-serif;font-weight:700;white-space:nowrap;}
.tl-card-seed{background:#111520 !important;border:1px solid #1e3060 !important;}
.no-cards{font-size:10px;color:var(--gold-faint);text-align:center;font-family:sans-serif;}
.group-sep{height:1px;background:var(--border);margin:5px 0;}

/* ═══════════════════════════════════════════════════════════
   REVEAL STAGE 1 — Aktive Gruppe (center-area full height)
   ═══════════════════════════════════════════════════════════ */
.reveal-stage{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:22px;padding:24px 32px;overflow:hidden;
}
.reveal-stage-who{
  font-size:18px;font-family:sans-serif;font-weight:700;letter-spacing:3px;
  text-align:center;padding:10px 32px;border-radius:7px;
  width:100%;max-width:520px;
  text-transform:uppercase;color:#000;
  /* box-shadow set inline by JS with group color */
}
.reveal-stage-guess{
  background:var(--bg-panel);
  border:1px solid var(--border);border-radius:10px;
  padding:20px 28px;display:flex;flex-direction:column;gap:16px;
  width:100%;max-width:520px;
  box-shadow:0 0 20px rgba(0,200,255,.1);
}
.reveal-guess-row{display:flex;align-items:baseline;gap:14px;}
.reveal-guess-lbl{
  font-size:10px;color:var(--gold-faint);font-family:sans-serif;
  text-transform:uppercase;letter-spacing:.12em;width:70px;flex-shrink:0;
}
.reveal-guess-val{font-size:24px;color:var(--gold);font-weight:600;}
.reveal-waiting-hint{
  font-size:13px;color:var(--gold-dim);font-family:sans-serif;font-style:italic;text-align:center;
  animation:neonPulse 2s ease-in-out infinite;
}
.reveal-stage-btn{width:100%;max-width:360px;padding:14px;font-size:15px;}

/* ═══════════════════════════════════════════════════════════
   REVEAL STAGE 2 — Vollständige Auflösung
   ═══════════════════════════════════════════════════════════ */
.full-reveal-stage{
  flex:1;display:flex;flex-direction:column;gap:14px;
  padding:18px 22px;overflow:hidden;
}
.full-reveal-answer{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  background:var(--bg-panel);
  border:1px solid var(--neon);border-radius:10px;
  padding:14px 24px;flex-shrink:0;
  box-shadow:0 0 22px rgba(0,200,255,.3),inset 0 0 22px rgba(0,200,255,.06);
}
.fra-artist{
  font-size:24px;font-weight:700;text-align:center;letter-spacing:2px;
  text-shadow:0 0 8px rgba(0,200,255,.5);
}
.fra-title{
  font-size:14px;color:var(--gold-dim);font-family:sans-serif;font-style:italic;text-align:center;
}
.fra-year{
  font-size:56px;font-weight:700;line-height:1.1;
  color:var(--neon);
  text-shadow:0 0 10px var(--neon),0 0 30px rgba(0,200,255,.7),0 0 60px rgba(0,200,255,.4);
}
.fra-result{
  font-size:12px;font-family:sans-serif;padding:5px 16px;border-radius:5px;
  margin-top:2px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
}
.reveal-correct{
  background:rgba(57,255,20,.08);color:var(--green);
  border:1px solid var(--green);box-shadow:0 0 8px rgba(57,255,20,.5);
}
.reveal-wrong{
  background:rgba(255,64,96,.08);color:var(--red);
  border:1px solid var(--red);box-shadow:0 0 8px rgba(255,64,96,.5);
}
.full-reveal-groups{display:flex;gap:8px;overflow-x:auto;flex-shrink:0;}
.full-reveal-group{
  flex:1;min-width:110px;
  border:2px solid var(--border);border-radius:8px;
  overflow:hidden;display:flex;flex-direction:column;
}
.frg-name{
  font-size:10px;font-family:sans-serif;font-weight:700;text-align:center;
  padding:6px 8px;text-transform:uppercase;letter-spacing:.08em;color:#000;
}
.frg-body{flex:1;padding:8px;display:flex;flex-direction:column;gap:4px;}
.frg-line{font-size:12px;font-family:sans-serif;padding:2px 0;}
.frg-ok{color:var(--green);}
.frg-wrong{color:var(--red);}
.frg-empty{color:var(--gold-faint);font-style:italic;}
.frg-bp{
  font-size:10px;font-family:sans-serif;font-weight:700;
  color:var(--neon);background:rgba(0,200,255,.1);
  padding:2px 6px;border-radius:10px;align-self:flex-start;margin-top:2px;
  box-shadow:0 0 5px rgba(0,200,255,.5);
}
.full-reveal-actions{
  display:flex;align-items:center;justify-content:flex-end;gap:10px;
  padding-top:2px;flex-shrink:0;
}

/* Legacy overlay (compat) */
.reveal-overlay{
  position:absolute;inset:0;background:rgba(0,0,0,.88);
  display:flex;align-items:center;justify-content:center;z-index:90;
}
.reveal-box{
  background:var(--bg-panel);border:1px solid var(--neon);border-radius:10px;
  padding:24px 32px;text-align:center;display:flex;flex-direction:column;gap:10px;
  min-width:360px;max-width:600px;width:90%;
  box-shadow:0 0 30px rgba(0,200,255,.4);
}
.rv-artist{font-size:22px;}
.rv-title{font-size:14px;color:var(--gold-dim);font-family:sans-serif;}
.rv-year{font-size:44px;font-weight:700;color:var(--neon);text-shadow:0 0 12px var(--neon);}
.rv-result{font-size:13px;font-family:sans-serif;padding:6px 14px;border-radius:5px;margin:0 auto;}
.result-ok{background:rgba(57,255,20,.08);color:var(--green);border:1px solid var(--green);}
.result-wrong{background:rgba(255,64,96,.08);color:var(--red);border:1px solid var(--red);}

/* ═══════════════════════════════════════════════════════════
   WINNER SCREEN
   ═══════════════════════════════════════════════════════════ */
.winner-wrap{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  background:radial-gradient(ellipse at center,rgba(0,200,255,.06) 0%,transparent 65%);
}
.winner-trophy{
  font-size:68px;
  animation:neonPulse 1.5s ease-in-out infinite;
  filter:drop-shadow(0 0 16px gold);
}
.winner-name{
  font-size:46px;font-weight:700;letter-spacing:5px;text-transform:uppercase;
  text-shadow:0 0 16px currentColor,0 0 44px currentColor;
}
.winner-sub{
  font-size:14px;color:var(--gold-dim);font-family:sans-serif;
  letter-spacing:.12em;text-transform:uppercase;
}
