/* ─── Flunkerei Display – Premium Dark Theme ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root {
  --bg-dark: #0a0a1a;
  --bg-mid: #12122a;
  --bg-card: rgba(255,255,255,0.06);
  --bg-glass: rgba(255,255,255,0.08);
  --border-glass: rgba(255,255,255,0.12);
  --text: #f0f0f8;
  --text-dim: #8888aa;
  --primary: #8b5cf6;
  --primary-glow: rgba(139,92,246,0.4);
  --secondary: #06b6d4;
  --accent: #f59e0b;
  --truth: #10b981;
  --truth-glow: rgba(16,185,129,0.5);
  --lie: #f43f5e;
  --lie-glow: rgba(244,63,94,0.4);
  --gold: #fbbf24;
  --silver: #9ca3af;
  --bronze: #d97706;
  --font-display: 'Outfit', sans-serif;
  --font-body: 'Inter', sans-serif;
}

html, body { height:100%; overflow:hidden; }
body {
  font-family: var(--font-body);
  background: linear-gradient(135deg, var(--bg-dark) 0%, #1a0a2e 50%, #0a1628 100%);
  color: var(--text);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ─── Background Particles ─── */
.bg-particles {
  position: fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden;
}
.bg-particles .particle {
  position: absolute;
  width: 3px; height: 3px;
  background: rgba(139,92,246,0.3);
  border-radius: 50%;
  animation: float linear infinite;
}
@keyframes float {
  0% { transform: translateY(100vh) scale(0); opacity:0; }
  10% { opacity:1; }
  90% { opacity:1; }
  100% { transform: translateY(-10vh) scale(1); opacity:0; }
}

/* ─── Screens ─── */
.screen { display:none; position:absolute; inset:0; z-index:1; padding:40px; flex-direction:column; align-items:center; justify-content:center; }
.screen.active { display:flex; animation: fadeIn .5s ease; }
@keyframes fadeIn { from{opacity:0;transform:scale(.97)} to{opacity:1;transform:scale(1)} }

/* ─── Logo ─── */
.logo {
  font-family: var(--font-display);
  font-weight: 900; font-size: 5rem;
  background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 50%, var(--accent) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 30px var(--primary-glow));
  letter-spacing: -2px;
}
.logo-sm { font-size: 2.2rem; }
.tagline { font-family:var(--font-display); font-size:1.4rem; color:var(--text-dim); margin-top:-8px; }

/* ─── Lobby ─── */
.lobby-header { text-align:center; margin-bottom:40px; }
.lobby-content { display:flex; gap:60px; align-items:flex-start; max-width:1200px; width:100%; }
.lobby-left { display:flex; flex-direction:column; align-items:center; gap:24px; }
.code-box {
  display:flex; flex-direction:column; align-items:center;
  background:var(--bg-glass); backdrop-filter:blur(20px);
  border:1px solid var(--border-glass); border-radius:20px; padding:24px 48px;
}
.code-label { font-size:.9rem; color:var(--text-dim); text-transform:uppercase; letter-spacing:3px; }
.code-value { font-family:var(--font-display); font-size:4rem; font-weight:900; letter-spacing:8px; color:var(--accent); }
.qr-box { text-align:center; }
.qr-box img { width:200px; height:200px; border-radius:12px; }
.qr-hint { font-size:.8rem; color:var(--text-dim); margin-top:8px; word-break:break-all; max-width:250px; }
.lobby-right { flex:1; }
.lobby-right h2 { font-family:var(--font-display); font-size:1.6rem; margin-bottom:16px; display:flex; align-items:center; gap:12px; }
.player-count-badge {
  background:var(--primary); color:#fff; font-size:.9rem; padding:2px 12px; border-radius:20px;
}
.player-list { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:24px; min-height:60px; }
.player-pill {
  display:flex; align-items:center; gap:8px;
  background:var(--bg-glass); backdrop-filter:blur(10px);
  border:1px solid var(--border-glass); border-radius:30px; padding:8px 18px;
  animation: popIn .3s cubic-bezier(.34,1.56,.64,1);
}
@keyframes popIn { from{opacity:0;transform:scale(.5)} to{opacity:1;transform:scale(1)} }
.player-pill .dot { width:12px; height:12px; border-radius:50%; flex-shrink:0; }
.player-pill span { font-weight:500; }
.lobby-settings {
  display:flex; gap:16px; margin-bottom:20px; flex-wrap:wrap;
}
.lobby-settings label {
  display:flex; align-items:center; gap:8px; font-size:.85rem; color:var(--text-dim);
}
.lobby-settings select {
  background:var(--bg-glass); border:1px solid var(--border-glass);
  color:var(--text); padding:6px 10px; border-radius:8px; font-size:.85rem;
}
.btn-primary {
  font-family:var(--font-display); font-weight:700; font-size:1.2rem;
  padding:16px 48px; border:none; border-radius:16px; cursor:pointer;
  background:linear-gradient(135deg, var(--primary), #a78bfa);
  color:#fff; transition:all .3s; position:relative; overflow:hidden;
}
.btn-primary:hover:not(:disabled) { transform:translateY(-2px); box-shadow:0 8px 30px var(--primary-glow); }
.btn-primary:disabled { opacity:.4; cursor:not-allowed; }
.min-players-hint { font-size:.85rem; color:var(--text-dim); margin-top:8px; }

/* ─── Answering Phase ─── */
.answering-box { text-align:center; }
.phase-icon { font-size:4rem; margin-bottom:16px; }
.answering-box h2 { font-family:var(--font-display); font-size:2.4rem; }
.subtitle { color:var(--text-dim); font-size:1.1rem; margin-top:8px; }
.progress-ring-container { margin-top:40px; text-align:center; }
.progress-ring {
  width:140px; height:140px; border-radius:50%; margin:0 auto 16px;
  background: conic-gradient(var(--primary) 0%, var(--bg-glass) 0%);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  border:3px solid var(--border-glass); position:relative;
}
.progress-ring::before {
  content:''; position:absolute; inset:8px; border-radius:50%; background:var(--bg-dark);
}
.progress-number { position:relative; z-index:1; font-family:var(--font-display); font-size:2.8rem; font-weight:900; }
.progress-total { position:relative; z-index:1; font-size:.9rem; color:var(--text-dim); }

/* ─── Round Header ─── */
.round-header {
  position:absolute; top:24px; left:40px; right:40px;
  display:flex; justify-content:space-between; align-items:center;
}
.round-badge {
  background:var(--bg-glass); backdrop-filter:blur(10px);
  border:1px solid var(--border-glass); border-radius:30px;
  padding:8px 20px; font-size:.9rem; font-weight:600; color:var(--text-dim);
}

/* ─── Timer ─── */
.timer-display {
  font-family:var(--font-display); font-weight:900; font-size:2.4rem;
  color:var(--accent); min-width:80px; text-align:center;
}
.timer-display.urgent { color:var(--lie); animation: pulse .5s ease infinite alternate; }
@keyframes pulse { from{transform:scale(1)} to{transform:scale(1.1)} }

/* ─── Question Box ─── */
.question-box {
  background:var(--bg-glass); backdrop-filter:blur(20px);
  border:1px solid var(--border-glass); border-radius:24px;
  padding:48px; text-align:center; max-width:800px; width:100%;
}
.question-box-sm { padding:24px; max-width:700px; }
.question-subject { display:flex; align-items:center; justify-content:center; gap:16px; margin-bottom:24px; }
.subject-avatar {
  width:56px; height:56px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:900; font-size:1.4rem; color:#fff;
}
.subject-name { font-family:var(--font-display); font-size:1.8rem; font-weight:700; }
.question-text {
  font-family:var(--font-display); font-size:2.2rem; font-weight:600; line-height:1.4;
}
.question-text-sm { font-family:var(--font-display); font-size:1.3rem; font-weight:600; }

/* ─── Typewriter ─── */
.typewriter { overflow:hidden; white-space:nowrap; border-right:3px solid var(--primary);
  animation: typewriter 2s steps(40) 1s forwards, blink .7s step-end infinite; width:0; }
@keyframes typewriter { from{width:0} to{width:100%} }
@keyframes blink { 50%{border-color:transparent} }

/* ─── Lie Collection ─── */
.lie-progress { text-align:center; margin-top:32px; }
.lie-progress h2 { font-family:var(--font-display); font-size:1.8rem; margin-top:12px; }
.lie-status { color:var(--text-dim); margin-top:8px; font-size:1.1rem; }
.lie-progress-bar {
  width:400px; max-width:90vw; height:8px; background:var(--bg-glass);
  border-radius:4px; margin:16px auto 0; overflow:hidden;
}
.lie-progress-fill { height:100%; background:linear-gradient(90deg, var(--primary), var(--secondary)); border-radius:4px; transition:width .3s ease; width:0; }

/* ─── Voting / Answers Grid ─── */
.vote-title, .reveal-title { font-family:var(--font-display); font-size:1.6rem; margin:20px 0; }
.answers-grid, .reveal-grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:16px; max-width:1100px; width:100%; padding:0 20px;
}
.answer-card {
  background:var(--bg-glass); backdrop-filter:blur(10px);
  border:2px solid var(--border-glass); border-radius:16px;
  padding:20px 24px; display:flex; align-items:flex-start; gap:14px;
  animation: slideUp .4s cubic-bezier(.34,1.56,.64,1) both;
  transition: border-color .3s, box-shadow .3s;
}
.answer-card:nth-child(1){animation-delay:.1s} .answer-card:nth-child(2){animation-delay:.2s}
.answer-card:nth-child(3){animation-delay:.3s} .answer-card:nth-child(4){animation-delay:.4s}
.answer-card:nth-child(5){animation-delay:.5s} .answer-card:nth-child(6){animation-delay:.6s}
.answer-card:nth-child(7){animation-delay:.7s} .answer-card:nth-child(8){animation-delay:.8s}
@keyframes slideUp { from{opacity:0;transform:translateY(40px)} to{opacity:1;transform:translateY(0)} }
.answer-letter {
  font-family:var(--font-display); font-weight:900; font-size:1.4rem;
  background:var(--primary); color:#fff; width:36px; height:36px;
  border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.answer-text { font-size:1.05rem; line-height:1.4; flex:1; }
.vote-status { margin-top:16px; color:var(--text-dim); font-size:1rem; }

/* ─── Reveal ─── */
.reveal-card {
  background:var(--bg-glass); backdrop-filter:blur(10px);
  border:2px solid var(--border-glass); border-radius:16px;
  padding:20px 24px; opacity:.5; transition:all .6s ease;
}
.reveal-card.active { opacity:1; border-color:var(--primary); box-shadow:0 0 30px var(--primary-glow); transform:scale(1.03); }
.reveal-card.truth { border-color:var(--truth); box-shadow:0 0 40px var(--truth-glow); background:rgba(16,185,129,.1); }
.reveal-card.lie-revealed { border-color:var(--lie); box-shadow:0 0 20px var(--lie-glow); background:rgba(244,63,94,.08); }
.reveal-card-header { display:flex; align-items:center; gap:12px; margin-bottom:8px; }
.reveal-letter {
  font-family:var(--font-display); font-weight:900; font-size:1.2rem;
  background:var(--primary); color:#fff; width:32px; height:32px;
  border-radius:8px; display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.reveal-text { font-size:1rem; line-height:1.4; margin-bottom:10px; }
.reveal-voters { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.voter-chip {
  font-size:.75rem; padding:3px 10px; border-radius:20px; font-weight:600;
  animation: popIn .3s cubic-bezier(.34,1.56,.64,1) both;
}
.reveal-meta {
  margin-top:8px; font-size:.85rem; font-weight:600;
  display:flex; align-items:center; gap:6px;
}
.reveal-meta.truth-meta { color:var(--truth); }
.reveal-meta.lie-meta { color:var(--lie); }
.truth-banner {
  display:inline-block; font-family:var(--font-display); font-weight:900;
  font-size:1.1rem; color:var(--truth); padding:4px 16px; border-radius:8px;
  background:rgba(16,185,129,.15); border:1px solid var(--truth);
  animation: truthPulse 1s ease infinite alternate;
}
@keyframes truthPulse { from{box-shadow:0 0 10px var(--truth-glow)} to{box-shadow:0 0 30px var(--truth-glow)} }

/* ─── Scoreboard ─── */
.scores-title { font-family:var(--font-display); font-size:2rem; margin:16px 0 24px; }
.scoreboard { max-width:700px; width:100%; display:flex; flex-direction:column; gap:12px; }
.score-row {
  display:flex; align-items:center; gap:16px;
  background:var(--bg-glass); backdrop-filter:blur(10px);
  border:1px solid var(--border-glass); border-radius:14px;
  padding:12px 20px; animation:slideUp .4s cubic-bezier(.34,1.56,.64,1) both;
}
.score-rank { font-family:var(--font-display); font-weight:900; font-size:1.4rem; width:36px; text-align:center; }
.score-avatar { width:40px; height:40px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; color:#fff; font-size:1rem; flex-shrink:0; }
.score-name { flex:1; font-weight:600; font-size:1.1rem; }
.score-points { font-family:var(--font-display); font-weight:900; font-size:1.4rem; color:var(--accent); }
.score-delta { font-size:.85rem; color:var(--truth); margin-left:4px; }

/* ─── Game Over ─── */
.gameover-title { font-family:var(--font-display); font-size:2.4rem; margin:8px 0 32px; }
.final-podium {
  display:flex; align-items:flex-end; justify-content:center; gap:20px; margin-bottom:32px;
}
.podium-entry { text-align:center; animation:slideUp .6s cubic-bezier(.34,1.56,.64,1) both; }
.podium-entry:nth-child(1){animation-delay:.2s} .podium-entry:nth-child(2){animation-delay:0s} .podium-entry:nth-child(3){animation-delay:.4s}
.podium-avatar {
  width:80px; height:80px; border-radius:50%; margin:0 auto 8px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:900; font-size:2rem; color:#fff;
}
.podium-name { font-weight:700; font-size:1.1rem; }
.podium-score { font-family:var(--font-display); font-weight:900; font-size:1.6rem; color:var(--accent); }
.podium-bar {
  width:120px; border-radius:12px 12px 0 0; margin:12px auto 0;
}
.podium-1 .podium-bar { height:180px; background:linear-gradient(180deg, var(--gold), #b8860b); }
.podium-2 .podium-bar { height:130px; background:linear-gradient(180deg, var(--silver), #6b7280); }
.podium-3 .podium-bar { height:90px; background:linear-gradient(180deg, var(--bronze), #92400e); }
.podium-crown { font-size:2.5rem; animation: bounce 1s ease infinite; }
@keyframes bounce { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }

.awards {
  display:flex; gap:20px; flex-wrap:wrap; justify-content:center; margin-bottom:32px;
}
.award-card {
  background:var(--bg-glass); backdrop-filter:blur(10px);
  border:1px solid var(--border-glass); border-radius:16px;
  padding:16px 24px; text-align:center; min-width:200px;
  animation: popIn .4s cubic-bezier(.34,1.56,.64,1) both;
}
.award-icon { font-size:2rem; }
.award-title { font-family:var(--font-display); font-weight:700; font-size:.9rem; color:var(--text-dim); margin:4px 0; }
.award-name { font-weight:700; font-size:1.1rem; }

/* ─── Confetti ─── */
.confetti-container { position:absolute; inset:0; pointer-events:none; overflow:hidden; z-index:0; }
.confetti-piece {
  position:absolute; width:10px; height:10px; top:-10px;
  animation: confettiFall linear forwards;
}
@keyframes confettiFall {
  0% { transform:translateY(0) rotate(0deg); opacity:1; }
  100% { transform:translateY(110vh) rotate(720deg); opacity:0; }
}
