/* ── Display / Streamer screen styles ─────────────────────────────────────── */

body.display-mode {
  overflow: hidden;
  height: 100vh;
  width: 100vw;
}

.display-screen {
  width: 100vw;
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 40px;
}

/* ── Lobby display ─────────────────────────────────────────────────────────── */

.display-eyebrow {
  font-family: 'Space Mono', monospace;
  font-size: clamp(11px, 1.4vw, 18px);
  color: var(--muted);
  letter-spacing: 4px;
  text-transform: uppercase;
  margin-bottom: 8px;
  text-align: center;
}

.display-code {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(80px, 16vw, 200px);
  color: var(--neon-cyan);
  text-shadow: 0 0 60px var(--neon-cyan), 0 0 120px rgba(0,245,255,0.25);
  letter-spacing: 12px;
  line-height: 1;
  text-align: center;
}

.display-invite-url {
  font-family: 'Space Mono', monospace;
  font-size: clamp(14px, 1.8vw, 26px);
  color: rgba(255,255,255,0.55);
  letter-spacing: 2px;
  text-align: center;
  margin-top: 10px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  padding: 8px 20px;
  display: inline-block;
}

.display-player-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  max-width: 85vw;
  margin: 44px auto 0;
}

.display-player-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 40px;
  padding: 10px 22px 10px 12px;
  transition: border-color 0.3s;
}

.display-player-chip.is-host {
  border-color: rgba(0,245,255,0.35);
}

.display-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 18px;
  font-family: 'Bebas Neue', sans-serif;
  flex-shrink: 0;
}

.display-player-name {
  font-family: 'Space Mono', monospace;
  font-size: clamp(13px, 1.5vw, 20px);
  color: #fff;
}

.display-host-badge {
  font-family: 'Space Mono', monospace;
  font-size: 9px;
  color: var(--neon-cyan);
  letter-spacing: 2px;
  text-transform: uppercase;
  display: block;
  margin-top: 2px;
}

.display-footer {
  position: absolute;
  bottom: 36px;
  left: 0; right: 0;
  text-align: center;
  font-family: 'Space Mono', monospace;
  font-size: clamp(11px, 1.2vw, 16px);
  color: var(--muted);
  letter-spacing: 3px;
  text-transform: uppercase;
}

/* ── FL Display — common ───────────────────────────────────────────────────── */

.fld-section {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px;
  gap: 24px;
}

.fld-round-badge {
  font-family: 'Space Mono', monospace;
  font-size: clamp(11px, 1.3vw, 17px);
  color: var(--fl-amber);
  letter-spacing: 4px;
  text-transform: uppercase;
}

.fld-fact {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(36px, 5.5vw, 88px);
  text-align: center;
  line-height: 1.1;
  max-width: 80vw;
  color: #fff;
  text-shadow: 0 0 40px rgba(255,255,255,0.15);
}

/* ── FL Display — lying ────────────────────────────────────────────────────── */

.fld-timer-big {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(80px, 14vw, 180px);
  color: var(--neon-yellow);
  text-shadow: 0 0 60px var(--neon-yellow), 0 0 120px rgba(245,255,0,0.2);
  line-height: 1;
  transition: color 0.3s;
}

.fld-timer-big.warning { color: var(--fl-red, #f87171); text-shadow: 0 0 60px #f87171; }

.fld-progress-wrap {
  width: clamp(240px, 50vw, 600px);
  text-align: center;
}

.fld-progress-bar-track {
  height: 6px;
  background: rgba(255,255,255,0.08);
  border-radius: 3px;
  overflow: hidden;
  margin-top: 10px;
}

.fld-progress-bar-fill {
  height: 100%;
  background: var(--fl-amber);
  border-radius: 3px;
  transition: width 0.4s ease;
  width: 0%;
}

.fld-progress-label {
  font-family: 'Space Mono', monospace;
  font-size: clamp(12px, 1.4vw, 18px);
  color: var(--muted);
  letter-spacing: 2px;
}

/* ── FL Display — voting ───────────────────────────────────────────────────── */

.fld-answers-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  width: min(84vw, 1200px);
}

.fld-answer-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: 14px;
  padding: 18px 22px;
  display: flex;
  align-items: center;
  gap: 14px;
  position: relative;
  overflow: hidden;
}

.fld-answer-letter {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(28px, 3.5vw, 52px);
  color: var(--fl-amber);
  flex-shrink: 0;
  width: 1.1em;
  text-align: center;
}

.fld-answer-text {
  font-family: 'Syne', sans-serif;
  font-size: clamp(15px, 1.8vw, 26px);
  font-weight: 700;
  flex: 1;
  line-height: 1.25;
}

.fld-vote-count {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(28px, 3.5vw, 52px);
  color: rgba(255,255,255,0.25);
  flex-shrink: 0;
  min-width: 1.5em;
  text-align: right;
  transition: color 0.3s;
}

.fld-answer-card.has-votes .fld-vote-count { color: var(--fl-amber); }

.fld-vote-bar {
  position: absolute;
  left: 0; bottom: 0;
  height: 3px;
  background: var(--fl-amber);
  border-radius: 0 2px 2px 0;
  transition: width 0.5s ease;
  width: 0%;
}

/* ── FL Display — reveal ───────────────────────────────────────────────────── */

.fld-reveal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(280px, 42vw), 1fr));
  gap: 18px;
  width: min(92vw, 1400px);
}

.fld-reveal-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  padding: 18px 20px;
}

.fld-reveal-card.is-truth {
  border-color: rgba(0,245,255,0.35);
  background: rgba(0,245,255,0.04);
}

.fld-reveal-letter {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(20px, 2.5vw, 36px);
  color: var(--fl-amber);
}

.fld-reveal-text {
  font-family: 'Syne', sans-serif;
  font-size: clamp(14px, 1.7vw, 24px);
  font-weight: 700;
  margin-top: 4px;
}

.fld-reveal-meta {
  font-family: 'Space Mono', monospace;
  font-size: clamp(10px, 1vw, 13px);
  color: var(--muted);
  letter-spacing: 1px;
  margin-top: 8px;
}

.fld-reveal-pts {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(22px, 2.8vw, 40px);
  color: var(--neon-yellow);
}

.fld-reveal-truth-label {
  font-family: 'Space Mono', monospace;
  font-size: clamp(9px, 0.9vw, 12px);
  color: var(--neon-cyan);
  letter-spacing: 2px;
  text-transform: uppercase;
}

/* ── FL Display — leaderboard ──────────────────────────────────────────────── */

.fld-leaderboard { width: min(60vw, 800px); }

.fld-lb-row {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 14px 24px;
  border-radius: 12px;
  margin-bottom: 10px;
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(22px, 3vw, 48px);
}

.fld-lb-row.rank-1 { background: rgba(255,215,0,0.12); border: 1px solid rgba(255,215,0,0.3); }
.fld-lb-row.rank-2 { background: rgba(192,192,192,0.08); border: 1px solid rgba(192,192,192,0.2); }
.fld-lb-row.rank-3 { background: rgba(205,127,50,0.08); border: 1px solid rgba(205,127,50,0.2); }
.fld-lb-row.rank-other { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.05); }

.fld-lb-rank { color: var(--muted); min-width: 60px; }
.fld-lb-name { flex: 1; }
.fld-lb-score { color: var(--neon-yellow); }

.fld-finished-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(48px, 8vw, 120px);
  color: var(--neon-yellow);
  text-shadow: 0 0 60px var(--neon-yellow);
  letter-spacing: 4px;
  text-align: center;
  margin-bottom: 40px;
}
