/* ═══════════════════════════════════════════════
   BidQuiz — Stylesheet
   Theme: neon casino / CRT gold
═══════════════════════════════════════════════ */

/* ── Design tokens ───────────────────────────── */
:root {
  --bg:          #060608;
  --surface:     #0f0f18;
  --surface-2:   #161620;
  --surface-3:   #20202e;
  --border:      #2e2e42;
  --border-focus:#e8b84b;

  /* Casino gold — primary accent throughout */
  --gold:        #e8b84b;
  --gold-light:  #f5d06a;
  --gold-dim:    rgba(232,184,75,0.12);
  --gold-glow:   rgba(232,184,75,0.35);

  /* Supporting neon accents */
  --cyan:        #00f0ff;
  --green:       #39ff14;
  --green-dim:   rgba(57,255,20,0.12);
  --red:         #ff3355;
  --purple:      #bf00ff;
  --orange:      #ff9900;
  --blue:        #00f0ff;

  /* Text — warm cream, easy to read */
  --text:        #f0ece4;
  --text-muted:  #b0a888;
  --text-subtle: #7a7060;

  --radius-sm:   4px;
  --radius:      8px;
  --radius-lg:   10px;
  --radius-md:   8px;

  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  20px;
  --space-6:  24px;
  --space-8:  32px;
  --space-10: 40px;

  --font:      'Courier New', Courier, monospace;
  --font-mono: 'Courier New', Courier, monospace;

  --shadow-sm: 0 1px 3px rgba(0,0,0,.6);
  --shadow:    0 4px 12px rgba(0,0,0,.7);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.8);
}

/* ── Reset ───────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  height: 100%;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  min-height: 100%;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 16px;
  line-height: 1.5;
  overflow-x: hidden;
  -webkit-user-select: none;
  user-select: none;
}

/* ── Scanlines overlay ───────────────────────── */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  background: repeating-linear-gradient(
    to bottom,
    transparent 0px,
    transparent 3px,
    rgba(0,0,0,0.09) 3px,
    rgba(0,0,0,0.09) 4px
  );
}

/* ── Accessible focus ────────────────────────── */
:focus { outline: none; }
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* ══════════════════════════════════════════════
   SCREENS
══════════════════════════════════════════════ */
.screen {
  display: none;
  flex-direction: column;
  align-items: center;
  min-height: 100vh;
  padding: var(--space-6) var(--space-4) var(--space-10);
  gap: var(--space-5);
  animation: fadeIn 0.25s ease;
}
.screen.active { display: flex; }

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: none; }
}

/* ══════════════════════════════════════════════
   SHARED COMPONENTS
══════════════════════════════════════════════ */

/* Logo */
.logo {
  font-size: clamp(2rem, 6vw, 3rem);
  font-weight: 900;
  letter-spacing: 5px;
  color: var(--text);
  text-transform: uppercase;
  text-shadow: 0 0 20px var(--gold-glow);
}
.logo span {
  color: var(--gold-light);
  text-shadow: 0 0 18px var(--gold-glow), 0 0 40px rgba(232,184,75,0.2);
}

/* Card */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  width: 100%;
  max-width: 440px;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  box-shadow: var(--shadow);
}

/* Field */
.field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.field label {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.15em;
}

.field-hint {
  font-size: 0.8rem;
  color: var(--text-subtle);
  margin-top: var(--space-1);
}

.field-inline {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
}
.field-inline label { flex: none; }
.field-inline input { width: 80px; flex: none; }
.field-inline .field-hint { width: 100%; margin-top: 0; }

/* Inputs */
input[type="text"],
input[type="number"] {
  background: rgba(0,0,0,0.35);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-family: var(--font);
  font-size: 1rem;
  padding: 10px var(--space-3);
  width: 100%;
  transition: border-color 0.15s, box-shadow 0.15s;
}
input[type="text"]:focus,
input[type="number"]:focus {
  border-color: var(--gold);
  box-shadow: 0 0 10px rgba(232,184,75,0.25);
}
input::placeholder { color: var(--text-subtle); }

/* ── Buttons ─────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border: 2px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font);
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 10px var(--space-5);
  transition: all 0.15s ease;
  white-space: nowrap;
  -webkit-user-select: none;
  user-select: none;
}
.btn:hover:not(:disabled)  { filter: brightness(1.15); }
.btn:active:not(:disabled) { transform: scale(0.96); }
.btn:disabled { opacity: 0.35; cursor: not-allowed; }

/* Gold primary */
.btn-primary {
  color: #000;
  background: var(--gold);
  border-color: var(--gold);
  box-shadow: 0 0 14px var(--gold-glow);
}
.btn-primary:hover:not(:disabled) {
  background: var(--gold-light);
  box-shadow: 0 0 24px var(--gold-glow), 0 0 6px rgba(255,255,255,0.2);
}

/* Cyan secondary */
.btn-secondary {
  color: #000;
  background: var(--cyan);
  border-color: var(--cyan);
  box-shadow: 0 0 14px rgba(0,240,255,0.3);
}

/* Red danger */
.btn-danger {
  background: transparent;
  border-color: var(--red);
  color: var(--red);
  box-shadow: 0 0 10px rgba(255,51,85,0.2);
}
.btn-danger:hover:not(:disabled) {
  background: rgba(255,51,85,0.12);
  box-shadow: 0 0 20px rgba(255,51,85,0.4);
  filter: none;
}

/* Ghost */
.btn-ghost {
  background: transparent;
  color: var(--text-muted);
  border-color: var(--border);
}
.btn-ghost:hover:not(:disabled) {
  border-color: var(--gold);
  color: var(--gold);
  filter: none;
  box-shadow: 0 0 8px rgba(232,184,75,0.2);
}

.btn-full { width: 100%; }
.btn-lg   { padding: 14px var(--space-8); font-size: 1rem; }
.btn-sm   { padding: 5px var(--space-3); font-size: 0.78rem; }

.btn-row { display: flex; gap: var(--space-3); }
.btn-row .btn { flex: 1; }

/* Divider */
.divider {
  border: none;
  border-top: 1px solid var(--border);
  margin: var(--space-1) 0;
}

/* Chip (room code) */
.chip {
  display: inline-block;
  background: rgba(232,184,75,0.1);
  border: 1px solid var(--gold);
  border-radius: var(--radius-sm);
  color: var(--gold-light);
  font-family: var(--font-mono);
  font-size: 1.05rem;
  font-weight: 900;
  letter-spacing: 4px;
  padding: 2px 10px;
  text-shadow: 0 0 10px var(--gold-glow);
}

.muted { color: var(--text-muted); }

.section-label {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.18em;
}

.empty-state {
  color: var(--text-subtle);
  font-size: 0.88rem;
  padding: var(--space-3) 0;
  text-align: center;
}

/* ══════════════════════════════════════════════
   LOBBY SCREEN
══════════════════════════════════════════════ */

#screen-lobby {
  padding: 0;
  gap: 0;
  position: relative;
  overflow: hidden;
  justify-content: flex-start;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(232,184,75,0.07) 0%, transparent 55%),
    radial-gradient(ellipse at 50% 100%, rgba(191,0,255,0.04) 0%, transparent 50%),
    var(--bg);
}

/* Grid texture */
.lobby-felt {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 59px, rgba(232,184,75,0.025) 60px),
    repeating-linear-gradient(90deg, transparent, transparent 59px, rgba(232,184,75,0.025) 60px);
  -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}

/* Hero area */
.lobby-hero {
  position: relative;
  z-index: 1;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: clamp(44px, 7vw, 80px) var(--space-4) clamp(28px, 4vw, 44px);
  gap: var(--space-6);
  border-bottom: 1px solid rgba(232,184,75,0.15);
  background: linear-gradient(180deg, rgba(232,184,75,0.05) 0%, transparent 100%);
}

.lobby-logo-wrap {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}

.lobby-suits-row {
  font-size: 1.1rem;
  letter-spacing: 1.4rem;
  color: var(--gold);
  opacity: 0.5;
  -webkit-user-select: none;
  user-select: none;
  margin-right: -1.4rem;
  text-shadow: 0 0 10px var(--gold-glow);
}

#screen-lobby .logo {
  font-size: clamp(3rem, 9vw, 5.5rem);
  letter-spacing: 10px;
  color: #fff;
  text-shadow: 0 0 30px var(--gold-glow), 0 2px 4px rgba(0,0,0,0.6);
}
#screen-lobby .logo span {
  color: var(--gold-light);
  text-shadow: 0 0 24px var(--gold-glow), 0 0 60px rgba(232,184,75,0.2);
}

.logo-rule {
  width: 100px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  margin-top: var(--space-1);
}

.tagline {
  color: var(--gold);
  font-size: 0.82rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  font-weight: 700;
  opacity: 0.75;
}

/* Name input */
.lobby-name-field {
  width: 100%;
  max-width: 380px;
}

.lobby-name-field label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.lobby-name-field input {
  background: rgba(0,0,0,0.4);
  border: 1.5px solid rgba(232,184,75,0.3);
  border-radius: var(--radius-sm);
  color: #fff;
  font-size: 1.1rem;
  font-weight: 600;
  padding: 13px var(--space-5);
  text-align: center;
  letter-spacing: 0.08em;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.lobby-name-field input:focus {
  border-color: var(--gold);
  background: rgba(232,184,75,0.05);
  box-shadow: 0 0 18px rgba(232,184,75,0.2);
  outline: none;
}
.lobby-name-field input::placeholder {
  color: rgba(255,255,255,0.2);
  font-weight: 400;
}

/* Two-card layout */
.lobby-cards {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
  width: 100%;
  max-width: 720px;
  padding: var(--space-8) var(--space-5) var(--space-10);
}

.lobby-card {
  background: linear-gradient(160deg, #14121c 0%, #0e0c16 100%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-lg);
  padding: 28px var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  position: relative;
  overflow: hidden;
  transition: border-color 0.25s, transform 0.25s, box-shadow 0.25s;
}

.lobby-card::after {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.3s;
  pointer-events: none;
  border-radius: var(--radius-lg);
}
.lobby-card--host::after { background: radial-gradient(ellipse at 50% -10%, rgba(232,184,75,.12) 0%, transparent 60%); }
.lobby-card--join::after  { background: radial-gradient(ellipse at 50% -10%, rgba(0,240,255,.08) 0%, transparent 60%); }
.lobby-card:hover::after  { opacity: 1; }

.lobby-card:hover { transform: translateY(-5px); }
.lobby-card--host:hover {
  border-color: rgba(232,184,75,0.5);
  box-shadow: 0 0 40px rgba(232,184,75,0.15), 0 16px 40px rgba(0,0,0,0.6);
}
.lobby-card--join:hover {
  border-color: rgba(0,240,255,0.4);
  box-shadow: 0 0 30px rgba(0,240,255,0.12), 0 16px 40px rgba(0,0,0,0.6);
}

.card-corner {
  position: absolute;
  font-size: 0.85rem;
  font-weight: 900;
  line-height: 1;
  -webkit-user-select: none;
  user-select: none;
  pointer-events: none;
  transition: opacity 0.2s;
}
.card-corner--tl { top: 11px; left: 13px; }
.card-corner--br { bottom: 11px; right: 13px; transform: rotate(180deg); }
.lobby-card--host .card-corner { color: var(--gold); opacity: 0.3; }
.lobby-card--join  .card-corner { color: var(--cyan); opacity: 0.25; }
.lobby-card:hover .card-corner  { opacity: 0.75; }

.lobby-card-eyebrow {
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--text-subtle);
}

.lobby-card-suit {
  font-size: 3.5rem;
  line-height: 1;
  color: var(--gold);
  text-shadow: 0 0 24px var(--gold-glow);
}
.lobby-card-suit--red {
  color: var(--cyan);
  text-shadow: 0 0 20px rgba(0,240,255,0.4);
}

.lobby-card-title {
  font-size: 1.25rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  color: #fff;
}

.lobby-card-desc {
  color: var(--text-muted);
  font-size: 0.88rem;
  line-height: 1.65;
  flex: 1;
}

/* Lobby-specific buttons */
.btn-host {
  background: linear-gradient(135deg, #c9922b 0%, var(--gold-light) 100%);
  border: 1px solid var(--gold);
  color: #000;
  font-weight: 800;
  letter-spacing: 0.12em;
  font-size: 0.9rem;
  box-shadow: 0 4px 16px rgba(232,184,75,0.35), inset 0 1px 0 rgba(255,255,255,0.2);
}
.btn-host:hover:not(:disabled) {
  filter: brightness(1.1);
  box-shadow: 0 6px 24px rgba(232,184,75,0.5), inset 0 1px 0 rgba(255,255,255,0.25);
}

.btn-join {
  background: transparent;
  border: 2px solid rgba(0,240,255,0.5);
  color: var(--cyan);
  font-weight: 800;
  letter-spacing: 0.12em;
  font-size: 0.9rem;
}
.btn-join:hover:not(:disabled) {
  background: rgba(0,240,255,0.08);
  border-color: var(--cyan);
  filter: none;
  box-shadow: 0 0 20px rgba(0,240,255,0.2);
}

.lobby-card--highlighted {
  border-color: rgba(0,240,255,0.45);
  box-shadow: 0 0 24px rgba(0,240,255,0.15);
  animation: cardPulse 1.3s ease 0.3s 2;
}

@keyframes cardPulse {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-6px); }
}

@media (max-width: 560px) {
  .lobby-cards {
    grid-template-columns: 1fr;
    max-width: 420px;
    padding: var(--space-5) var(--space-4) var(--space-8);
  }
  .lobby-card { padding: var(--space-5); }
  .lobby-card-suit { font-size: 2.6rem; }
  #screen-lobby .logo { letter-spacing: 6px; }
  .lobby-suits-row { letter-spacing: 0.9rem; margin-right: -0.9rem; }
}

/* ══════════════════════════════════════════════
   WAITING ROOM SCREEN
══════════════════════════════════════════════ */

#screen-waiting {
  padding: 0;
  gap: 0;
  align-items: stretch;
  min-height: 100vh;
}

/* Top bar */
.wr-topbar {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: 14px var(--space-6);
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  flex-wrap: wrap;
}

.wr-brand {
  font-size: 1.15rem;
  font-weight: 900;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #fff;
  text-shadow: 0 0 14px var(--gold-glow);
  flex-shrink: 0;
}
.wr-brand em {
  color: var(--gold-light);
  font-style: normal;
  text-shadow: 0 0 14px var(--gold-glow);
}

.wr-room-info {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
}
.wr-room-label {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-subtle);
}

.wr-share-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  background: rgba(0,0,0,0.3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 5px 5px 5px var(--space-3);
  flex: 1;
  min-width: 0;
}

.share-url-display {
  flex: 1;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

/* Two-column layout */
.wr-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

/* Shared panel */
.wr-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.wr-panel-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.wr-panel-title {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-subtle);
}

.wr-player-count {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--gold-light);
  font-family: var(--font-mono);
  text-shadow: 0 0 8px var(--gold-glow);
}

/* Players column */
.wr-players-panel {
  border-right: 1px solid var(--border);
  border-top: none;
  border-left: none;
  border-bottom: none;
}

.wr-player-list {
  display: flex;
  flex-direction: column;
  gap: 1px;
  overflow-y: auto;
  flex: 1;
  padding: var(--space-2);
}

.wr-player-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  transition: background 0.15s;
}
.wr-player-item:hover {
  background: rgba(232,184,75,0.04);
  border-color: rgba(232,184,75,0.1);
}

.wr-player-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--surface-3);
  border: 2px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 800;
  color: var(--text-muted);
  flex-shrink: 0;
  text-transform: uppercase;
}
.wr-player-item.is-host .wr-player-avatar {
  border-color: var(--gold);
  color: var(--gold-light);
  background: rgba(232,184,75,0.08);
  box-shadow: 0 0 8px rgba(232,184,75,0.25);
}

.wr-player-name {
  font-size: 0.95rem;
  font-weight: 600;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text);
}

.wr-player-badge {
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold-light);
  background: rgba(232,184,75,0.1);
  border: 1px solid rgba(232,184,75,0.3);
  border-radius: 3px;
  padding: 2px 6px;
  flex-shrink: 0;
  text-shadow: 0 0 6px var(--gold-glow);
}

/* Right column */
.wr-right-col {
  display: flex;
  flex-direction: column;
  gap: 0;
  overflow: hidden;
  min-height: 0;
}

/* Settings panel (host) */
.wr-settings-panel {
  border-radius: 0;
  border: none;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.wr-settings-panel .wr-panel-hdr {
  background: rgba(232,184,75,0.04);
  border-bottom-color: rgba(232,184,75,0.15);
}
.wr-settings-panel .wr-panel-title {
  color: var(--gold);
  text-shadow: 0 0 8px var(--gold-glow);
}

.wr-setting-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4) var(--space-4) 0;
}

.wr-setting-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--text-subtle);
}

.wr-topics-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.wr-topic-chip {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: rgba(0,0,0,0.3);
  cursor: pointer;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-muted);
  transition: border-color 0.15s, background 0.15s, color 0.15s;
  -webkit-user-select: none;
  user-select: none;
}
.wr-topic-chip input { display: none; }
.wr-topic-chip:hover { border-color: var(--gold); color: var(--text); }
.wr-topic-chip.checked {
  border-color: var(--gold);
  background: rgba(232,184,75,0.1);
  color: var(--gold-light);
}

.wr-settings-row {
  display: flex;
  gap: var(--space-5);
  padding: var(--space-3) var(--space-4) 0;
  flex-wrap: wrap;
}
.wr-settings-row .wr-setting-group {
  padding: 0;
  flex: 1;
  min-width: 140px;
}

.wr-opts { display: flex; gap: var(--space-1); flex-wrap: wrap; }

.wr-opt {
  padding: 6px 13px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: rgba(0,0,0,0.3);
  color: var(--text-muted);
  font-size: 0.85rem;
  font-weight: 700;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, color 0.15s;
  font-family: var(--font-mono);
}
.wr-opt:hover { border-color: var(--gold); color: var(--text); }
.wr-opt.active {
  border-color: var(--gold);
  background: rgba(232,184,75,0.1);
  color: var(--gold-light);
  box-shadow: 0 0 8px rgba(232,184,75,0.2);
}

.wr-settings-panel .btn-host {
  margin: var(--space-4);
  width: calc(100% - 2 * var(--space-4));
}

/* Guest waiting panel */
.wr-guest-panel {
  border-radius: 0;
  border: none;
  border-bottom: 1px solid var(--border);
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: var(--space-6) var(--space-5);
  flex-shrink: 0;
  text-align: center;
}

.wr-guest-suit {
  font-size: 2.8rem;
  color: var(--gold);
  opacity: 0.3;
  line-height: 1;
  text-shadow: 0 0 20px var(--gold-glow);
}

.wr-guest-msg {
  color: var(--text-muted);
  font-size: 0.95rem;
}

.wr-settings-summary {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: center;
  margin-top: var(--space-2);
}

.wr-summary-chip {
  font-size: 0.78rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 12px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  color: var(--text-muted);
}

/* Chat panel */
.wr-chat-panel {
  border-radius: 0;
  border: none;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

.chat-messages {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-3) var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  min-height: 0;
}

.chat-msg { display: flex; flex-direction: column; gap: 2px; }

.chat-msg-meta {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
}

.chat-msg-name {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--gold-light);
  text-shadow: 0 0 6px var(--gold-glow);
}
.chat-msg-name.is-me {
  color: var(--green);
  text-shadow: 0 0 6px rgba(57,255,20,0.4);
}

.chat-msg-time {
  font-size: 0.68rem;
  color: var(--text-subtle);
  font-family: var(--font-mono);
}

.chat-msg-text {
  font-size: 0.9rem;
  color: var(--text);
  line-height: 1.45;
  word-break: break-word;
}

.chat-msg-system {
  font-size: 0.8rem;
  color: var(--text-subtle);
  text-align: center;
  font-style: italic;
  padding: var(--space-1) 0;
}

.chat-input-row {
  display: flex;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3) var(--space-3);
  border-top: 1px solid var(--border);
  flex-shrink: 0;
}
.chat-input-row input {
  flex: 1;
  font-size: 0.9rem;
  padding: 8px var(--space-3);
}

/* Responsive */
@media (max-width: 680px) {
  .wr-layout { grid-template-columns: 1fr; overflow: visible; }
  .wr-players-panel {
    border-right: none;
    border-bottom: 1px solid var(--border);
    max-height: 200px;
  }
  .wr-player-list { flex-direction: row; flex-wrap: wrap; gap: var(--space-2); }
  .wr-player-item { flex-direction: column; align-items: center; text-align: center; gap: var(--space-1); padding: var(--space-2); width: 80px; }
  .wr-player-name { font-size: 0.78rem; }
  .wr-player-badge { display: none; }
  .wr-topbar { padding: 10px var(--space-4); }
  .wr-share-row { display: none; }
}

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

#screen-game {
  padding: 0;
  gap: 0;
  align-items: stretch;
  min-height: 100vh;
}

/* Game top bar */
.game-topbar {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: 12px var(--space-6);
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.game-round-badge {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.game-topbar-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--text-subtle);
}

.game-round-num {
  font-size: 1.15rem;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  color: var(--gold-light);
  text-shadow: 0 0 10px var(--gold-glow);
}

.game-topbar-spacer { flex: 1; }

/* Game two-column layout */
.game-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

/* Main gameplay column */
.game-main {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  overflow-y: auto;
  min-height: 0;
  border-right: 1px solid var(--border);
}

/* Right sidebar */
.game-sidebar {
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
  background: var(--surface);
}

/* Shared game panel */
.game-panel {
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}

.game-panel-hdr {
  display: flex;
  align-items: center;
  padding: var(--space-2) var(--space-4);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  background: var(--surface);
}

.game-panel-hdr--tabs { gap: 0; padding: 0; }

.game-panel-title {
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-subtle);
}

/* Tabs */
.game-tab {
  flex: 1;
  padding: 10px var(--space-3);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--text-subtle);
  cursor: pointer;
  font-family: var(--font);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  transition: color 0.15s, border-color 0.15s;
}
.game-tab:hover { color: var(--text); }
.game-tab.active {
  color: var(--gold-light);
  border-bottom-color: var(--gold);
  text-shadow: 0 0 8px var(--gold-glow);
}
.game-tab.has-unread::after {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--red);
  box-shadow: 0 0 6px var(--red);
  margin-left: 5px;
  vertical-align: middle;
  margin-top: -2px;
}

.game-tab-pane {
  display: none;
  flex: 1;
  flex-direction: column;
  overflow: hidden;
  min-height: 0;
}
.game-tab-pane.active { display: flex; }

/* Players sidebar */
#screen-game .players-row {
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding: var(--space-1);
  overflow-y: auto;
}

#screen-game .player-token {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-2);
  text-align: left;
  min-width: unset;
  max-width: unset;
  flex: unset;
  padding: var(--space-2) var(--space-3);
  border-width: 1px;
  border-left-width: 3px;
  border-radius: var(--radius-sm);
  border-left-color: var(--border);
}
#screen-game .player-token.active-turn {
  border-left-color: var(--green);
  box-shadow: none;
  background: rgba(57,255,20,0.04);
}
#screen-game .player-token.active-turn::after { display: none; }
#screen-game .player-token.answering   { border-left-color: var(--orange); background: rgba(255,153,0,0.04); }
#screen-game .player-token.challenging { border-left-color: var(--red); }
#screen-game .player-token.me         { border-left-color: var(--gold); }

.pt-avatar {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--surface-3);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--text-muted);
  flex-shrink: 0;
  text-transform: uppercase;
}
#screen-game .player-token.active-turn .pt-avatar { border-color: var(--green);  color: var(--green);  box-shadow: 0 0 6px var(--green); }
#screen-game .player-token.answering   .pt-avatar { border-color: var(--orange); color: var(--orange); }
#screen-game .player-token.me         .pt-avatar { border-color: var(--gold);   color: var(--gold-light); }

.pt-info { flex: 1; min-width: 0; }

#screen-game .pt-name {
  font-size: 0.85rem;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text);
}

.pt-you {
  color: var(--text-subtle);
  font-weight: 400;
  font-size: 0.72rem;
}

.pt-status-badge {
  display: inline-block;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 1px 5px;
  border-radius: 3px;
  margin-top: 2px;
}
.pt-status-badge--turn     { background: rgba(57,255,20,.1);  color: var(--green);  border: 1px solid rgba(57,255,20,.3); }
.pt-status-badge--answering{ background: rgba(255,153,0,.1);  color: var(--orange); border: 1px solid rgba(255,153,0,.3); }
.pt-status-badge--folded   { background: rgba(255,255,255,.04); color: var(--text-subtle); border: 1px solid var(--border); }
.pt-status-badge--out      { background: rgba(255,51,85,.1);  color: var(--red);    border: 1px solid rgba(255,51,85,.3); }

#screen-game .pt-stats {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  font-size: 0.72rem;
  flex-shrink: 0;
}
#screen-game .pt-tokens { color: var(--gold-light); font-weight: 700; font-family: var(--font-mono); text-shadow: 0 0 6px var(--gold-glow); }
#screen-game .pt-lives  { color: var(--red); letter-spacing: -1px; font-size: 0.68rem; }

/* Activity panel */
.game-activity-panel { flex: 1; min-height: 0; }
.game-activity-panel .game-tab-pane.active { overflow: hidden; }

#screen-game .event-log {
  flex: 1;
  max-height: none;
  overflow-y: auto;
  overflow-anchor: none;
  padding: var(--space-2) var(--space-3);
  background: none;
  border: none;
  border-radius: 0;
  gap: 2px;
}

#screen-game .chat-messages {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-3);
  gap: var(--space-2);
}

/* Timer ring */
.timer-ring {
  position: relative;
  width: 52px;
  height: 52px;
  flex-shrink: 0;
}
.timer-ring svg {
  width: 52px;
  height: 52px;
  transform: rotate(-90deg);
}
.timer-bg {
  fill: none;
  stroke: var(--surface-3);
  stroke-width: 5;
}
.timer-arc {
  fill: none;
  stroke: var(--gold);
  stroke-width: 5;
  stroke-linecap: round;
  stroke-dasharray: 163.36;
  stroke-dashoffset: 0;
  transition: stroke-dashoffset 0.9s linear, stroke 0.3s;
  filter: drop-shadow(0 0 4px var(--gold-glow));
}
.timer-arc.warn   { stroke: var(--orange); filter: drop-shadow(0 0 4px var(--orange)); }
.timer-arc.danger { stroke: var(--red);    filter: drop-shadow(0 0 4px var(--red)); }

.timer-ring span {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--text);
}

/* Phase badge */
.phase-badge {
  background: rgba(0,0,0,0.4);
  border: 1px solid rgba(232,184,75,0.35);
  border-radius: 20px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.15em;
  padding: 5px 14px;
  min-width: 80px;
  text-align: center;
  color: var(--gold-light);
  text-shadow: 0 0 10px var(--gold-glow);
}

/* Question card */
.question-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-4) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  box-shadow: inset 0 0 40px rgba(232,184,75,0.02);
}

.question-card-tags {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.category-tag {
  display: inline-block;
  background: rgba(191,0,255,0.12);
  border: 1px solid rgba(191,0,255,0.4);
  border-radius: 3px;
  color: #d084ff;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  padding: 2px 8px;
  text-transform: uppercase;
}

.max-answers-tag {
  display: inline-block;
  background: rgba(232,184,75,0.08);
  border: 1px solid rgba(232,184,75,0.3);
  border-radius: 3px;
  color: var(--gold);
  font-size: 0.72rem;
  font-weight: 700;
  padding: 2px 8px;
}

.question-text {
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1.55;
  color: var(--text);
}

/* Players row */
.players-row {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  justify-content: center;
}

.player-token {
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: var(--radius-sm);
  padding: var(--space-2) var(--space-3);
  text-align: center;
  min-width: 88px;
  flex: 1;
  max-width: 130px;
  transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
  position: relative;
}
.player-token.active-turn {
  border-color: var(--green);
  transform: translateY(-3px);
  box-shadow: 0 6px 18px rgba(57,255,20,.2), 0 0 10px rgba(57,255,20,.15);
}
.player-token.active-turn::after {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  box-shadow: 0 0 16px rgba(57,255,20,.4);
  animation: seatGlow 2s ease infinite;
  pointer-events: none;
}
.player-token.answering   { border-color: var(--orange); box-shadow: 0 4px 12px rgba(255,153,0,.2); }
.player-token.challenging { border-color: var(--red);    box-shadow: 0 4px 12px rgba(255,51,85,.2); }
.player-token.eliminated  { opacity: 0.3; }
.player-token.folded      { opacity: 0.4; border-style: dashed; }
.player-token.me          { border-color: var(--gold); }

.pt-name {
  font-size: 0.85rem;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text);
}
.pt-stats {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: var(--space-1);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
}
.pt-tokens { color: var(--gold-light); text-shadow: 0 0 6px var(--gold-glow); }
.pt-lives  { color: var(--red); letter-spacing: -1px; }

/* Game responsive */
@media (max-width: 820px) {
  .game-layout { grid-template-columns: 1fr; overflow: visible; }
  .game-sidebar {
    border-top: 1px solid var(--border);
    max-height: 320px;
    flex-direction: row;
    overflow: hidden;
  }
  .game-sidebar .game-panel:first-child {
    width: 140px;
    flex-shrink: 0;
    border-bottom: none;
    border-right: 1px solid var(--border);
  }
  .game-activity-panel { flex: 1; }
  #screen-game .players-row { overflow-y: auto; flex: 1; }
  #screen-game .player-token { padding: var(--space-1) var(--space-2); }
  .pt-avatar { width: 24px; height: 24px; font-size: 0.62rem; }
  .game-topbar { padding: 10px var(--space-4); }
}
@media (max-width: 520px) {
  .game-sidebar { max-height: 260px; }
  .game-main { padding: var(--space-3); }
  .game-topbar .wr-brand { display: none; }
}

/* ══════════════════════════════════════════════
   BID DISPLAY
══════════════════════════════════════════════ */
.bid-display {
  background: #080810;
  border: 2px solid rgba(232,184,75,0.2);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-4);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  position: relative;
  overflow: hidden;
}

.bid-display::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 60%, rgba(232,184,75,.05) 0%, transparent 70%);
  pointer-events: none;
}

.bid-display.bid-updated { animation: bidFlash 0.5s ease; }

.bid-eyebrow {
  font-size: 0.68rem;
  font-weight: 800;
  color: rgba(232,184,75,0.3);
  text-transform: uppercase;
  letter-spacing: 0.35em;
}

.bid-bidder {
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: var(--space-1);
}
.bid-bidder strong { color: var(--text); }

.bid-numbers {
  display: flex;
  align-items: stretch;
  justify-content: center;
}

.bid-number-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: var(--space-3) var(--space-5);
  flex: 1;
  max-width: 160px;
}

.bid-number-box--tokens { border-right: 1px solid rgba(232,184,75,0.1); }

.bid-number {
  font-size: 4rem;
  font-weight: 900;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -2px;
}

.bid-number-box--tokens .bid-number  {
  color: var(--gold-light);
  text-shadow: 0 0 24px var(--gold-glow);
}
.bid-number-box--answers .bid-number {
  color: var(--cyan);
  text-shadow: 0 0 20px rgba(0,240,255,0.35);
}

.bid-unit {
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}
.bid-number-box--tokens .bid-unit  { color: rgba(232,184,75,0.35); }
.bid-number-box--answers .bid-unit { color: rgba(0,240,255,0.35); }

.bid-answers-max {
  font-size: 0.65rem;
  font-weight: 600;
  color: rgba(0,240,255,0.35);
  margin-top: -2px;
}

.bid-answers-track {
  height: 2px;
  background: rgba(255,255,255,0.05);
  border-radius: 2px;
  margin: var(--space-2) var(--space-4) 0;
  overflow: hidden;
}
.bid-answers-bar {
  height: 100%;
  width: 0%;
  border-radius: 2px;
  background: var(--cyan);
  box-shadow: 0 0 6px rgba(0,240,255,0.5);
  transition: width 0.4s ease, background 0.3s;
}
.bid-answers-bar.bar-mid  { background: var(--gold);   box-shadow: 0 0 6px var(--gold-glow); }
.bid-answers-bar.bar-high { background: var(--red);    box-shadow: 0 0 6px var(--red); }

.bid-connector-wrap {
  display: flex;
  align-items: center;
  padding: 0 var(--space-2) var(--space-5);
}
.bid-connector {
  font-size: 0.68rem;
  font-weight: 800;
  color: var(--text-subtle);
  text-transform: uppercase;
  letter-spacing: 0.2em;
}

/* ══════════════════════════════════════════════
   BID HISTORY
══════════════════════════════════════════════ */
.bid-history {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.bid-entry {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 10px var(--space-4);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
  border: 1px solid transparent;
  opacity: 0.45;
  transition: opacity 0.2s;
  animation: entrySlide 0.25s ease;
}

.bid-entry--latest {
  opacity: 1;
  background: rgba(232,184,75,0.04);
  border-color: rgba(232,184,75,0.18);
  box-shadow: 0 2px 10px rgba(0,0,0,0.4), inset 0 1px 0 rgba(232,184,75,0.04);
}

.bid-entry-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--surface-3);
  border: 1px solid var(--border);
  font-size: 0.72rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--text-muted);
}
.bid-entry--latest .bid-entry-avatar {
  border-color: var(--gold);
  color: var(--gold-light);
  background: rgba(232,184,75,0.08);
  box-shadow: 0 0 8px rgba(232,184,75,0.2);
}

.bid-entry-body {
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.9rem;
  flex-wrap: wrap;
  min-width: 0;
}

.bid-entry-name { font-weight: 700; color: var(--text); }
.bid-entry--latest .bid-entry-name { color: #fff; }
.bid-entry-verb { color: var(--text-subtle); font-size: 0.82rem; }

.ben-tokens  { color: var(--gold-light); font-weight: 700; text-shadow: 0 0 6px var(--gold-glow); }
.ben-answers { color: var(--cyan);       font-weight: 700; text-shadow: 0 0 6px rgba(0,240,255,0.3); }

.bid-entry-crown {
  font-size: 0.85rem;
  color: var(--gold-light);
  flex-shrink: 0;
  opacity: 0.85;
  text-shadow: 0 0 10px var(--gold-glow);
}

/* ══════════════════════════════════════════════
   CONTROLS PANEL
══════════════════════════════════════════════ */
.controls-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-4) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: border-color 0.3s, box-shadow 0.3s;
}
.controls-panel.my-turn {
  border-color: rgba(57,255,20,0.4);
  box-shadow: 0 0 0 1px rgba(57,255,20,0.08), inset 0 0 40px rgba(57,255,20,0.02);
}

/* ══════════════════════════════════════════════
   TURN BANNERS
══════════════════════════════════════════════ */
.turn-banner {
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  font-weight: 800;
  padding: 10px var(--space-4);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.turn-banner--mine {
  background: rgba(57,255,20,0.07);
  border: 1px solid rgba(57,255,20,0.45);
  color: var(--green);
  text-shadow: 0 0 8px rgba(57,255,20,0.5);
  animation: bannerPulse 2.5s ease infinite;
}

.turn-banner--theirs {
  background: var(--surface-2);
  border: 1px solid var(--border);
  color: var(--text-muted);
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
}

.pulse-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 6px var(--green);
  flex-shrink: 0;
  animation: dotPulse 1.4s ease infinite;
}

/* ══════════════════════════════════════════════
   STEPPERS
══════════════════════════════════════════════ */
.bid-builder {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-5);
  flex-wrap: wrap;
}

.stepper-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
}

.stepper-label {
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.15em;
}
.stepper-group--tokens  .stepper-label { color: var(--text-muted); }
.stepper-group--answers .stepper-label { color: var(--text-muted); }

.stepper {
  display: flex;
  align-items: center;
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--border);
}
.stepper--tokens  { border-color: rgba(232,184,75,0.25); }
.stepper--answers { border-color: rgba(0,240,255,0.2); }

.stepper-btn {
  background: var(--surface-2);
  border: none;
  cursor: pointer;
  font-size: 1.4rem;
  font-weight: 300;
  line-height: 1;
  padding: 10px 16px;
  color: var(--text-muted);
  transition: background 0.1s, color 0.1s;
  -webkit-user-select: none;
  user-select: none;
  min-height: 52px;
  font-family: var(--font);
}
.stepper-btn:hover:not(:disabled)  { background: var(--surface-3); color: var(--text); }
.stepper-btn:active:not(:disabled) { background: rgba(232,184,75,0.1); }
.stepper-btn:disabled { opacity: 0.2; cursor: not-allowed; }

.stepper-value {
  min-width: 64px;
  text-align: center;
  font-size: 2.2rem;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  padding: 4px var(--space-2);
  border-left: 1px solid var(--border);
  border-right: 1px solid var(--border);
  line-height: 1;
  transition: transform 0.15s;
}
.stepper--tokens  .stepper-value {
  color: var(--gold-light);
  border-color: rgba(232,184,75,0.2);
  text-shadow: 0 0 14px var(--gold-glow);
}
.stepper--answers .stepper-value {
  color: var(--cyan);
  border-color: rgba(0,240,255,0.15);
  text-shadow: 0 0 14px rgba(0,240,255,0.35);
}
.stepper-value.changed { animation: stepPop 0.22s ease; }

.stepper-on {
  font-size: 0.7rem;
  font-weight: 800;
  color: var(--text-subtle);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  padding-top: 24px;
}

.stepper-cap {
  font-size: 0.65rem;
  font-weight: 600;
  color: rgba(0,240,255,0.4);
  text-transform: none;
  margin-left: 4px;
}

/* ══════════════════════════════════════════════
   BID ACTION BUTTONS
══════════════════════════════════════════════ */
.bid-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

.btn-bid-raise {
  padding: 14px var(--space-4);
  font-size: 0.9rem;
  letter-spacing: 0.1em;
}

.btn-bid-call {
  padding: 14px var(--space-4);
  font-size: 0.9rem;
  letter-spacing: 0.1em;
}

.btn-bid-fold {
  width: 100%;
  font-size: 0.8rem;
  padding: 7px;
  opacity: 0.4;
  letter-spacing: 0.05em;
}
.btn-bid-fold:hover:not(:disabled) { opacity: 0.75; }

.hint-text {
  color: var(--text-muted);
  font-size: 0.82rem;
  min-height: 1em;
  text-align: center;
}

/* Challenge context */
.challenge-context {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: rgba(255,51,85,0.06);
  border: 1px solid rgba(255,51,85,0.25);
  border-radius: var(--radius-sm);
  flex-wrap: wrap;
}

.challenge-context-who,
.challenge-context-stake {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.challenge-context-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-subtle);
}

.challenge-challenger-name {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--red);
  text-shadow: 0 0 10px rgba(255,51,85,0.5);
}

.challenge-stake-amount {
  font-size: 1.15rem;
  font-weight: 900;
  color: var(--gold-light);
  font-variant-numeric: tabular-nums;
  text-shadow: 0 0 10px var(--gold-glow);
}

.spectate-sub {
  font-size: 0.85rem;
  color: var(--gold-light);
  font-weight: 600;
  text-align: center;
  margin-top: calc(-1 * var(--space-1));
  text-shadow: 0 0 8px var(--gold-glow);
}

/* Answering controls */
.answering-header {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.lives-row {
  display: flex;
  gap: var(--space-1);
  font-size: 1.3rem;
  flex-shrink: 0;
}
.life-icon { transition: opacity 0.2s, transform 0.2s; }
.life-icon.lost { opacity: 0.15; transform: scale(0.85); }

/* Progress bar */
.progress-bar-wrap {
  flex: 1;
  min-width: 120px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: 20px;
  height: 26px;
  overflow: hidden;
  position: relative;
}
.answer-progress-bar {
  background: var(--green);
  box-shadow: 0 0 8px rgba(57,255,20,0.4);
  height: 100%;
  border-radius: 20px;
  width: 0%;
  transition: width 0.3s ease;
}
#answer-progress-label {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  font-weight: 800;
  color: #fff;
  text-shadow: 0 1px 3px rgba(0,0,0,.7);
}

/* Answers given */
.answers-given {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  min-height: 30px;
}
.answer-chip {
  border-radius: var(--radius-sm);
  font-size: 0.82rem;
  font-weight: 600;
  padding: 3px 10px;
  animation: pop 0.2s ease;
}
.answer-chip.correct {
  background: rgba(57,255,20,0.1);
  color: var(--green);
  border: 1px solid var(--green);
}
.answer-chip.wrong {
  background: rgba(255,51,85,0.1);
  color: var(--red);
  border: 1px solid var(--red);
}

/* Answer input */
.answer-input-row { display: flex; gap: var(--space-2); }
.answer-input-row input { flex: 1; }

/* Spectate */
.spectate-panel {
  background: rgba(13,13,20,0.5);
  border-style: dashed;
  gap: var(--space-3);
}
.spectate-msg {
  font-size: 0.92rem;
  color: var(--text-muted);
  text-align: center;
}

/* ── Power-ups ───────────────────────────────── */
.powerups-bar {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
  padding: var(--space-1) 0;
}

.powerup-btn {
  position: relative;
  flex: 1;
  max-width: 160px;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  color: #fff;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-4) var(--space-3) var(--space-3);
  font-family: var(--font);
  overflow: hidden;
  transition: transform .18s, box-shadow .18s, opacity .18s, filter .18s;
  background: var(--surface-2);
}

.pu--fifty {
  background: linear-gradient(145deg, #14082a 0%, #250e50 100%);
  border-color: rgba(191,0,255,.4);
  box-shadow: 0 0 16px rgba(191,0,255,.12);
}
.pu--pass {
  background: linear-gradient(145deg, #0a1520 0%, #102030 100%);
  border-color: rgba(0,240,255,.35);
  box-shadow: 0 0 16px rgba(0,240,255,.1);
}
.pu--life {
  background: linear-gradient(145deg, #220810 0%, #400d20 100%);
  border-color: rgba(255,51,85,.4);
  box-shadow: 0 0 16px rgba(255,51,85,.12);
}

.pu-glow {
  position: absolute;
  top: -18px;
  left: 50%;
  transform: translateX(-50%);
  width: 70px;
  height: 70px;
  border-radius: 50%;
  pointer-events: none;
  opacity: 0.2;
}
.pu--fifty .pu-glow { background: radial-gradient(circle, var(--purple) 0%, transparent 70%); }
.pu--pass  .pu-glow { background: radial-gradient(circle, var(--cyan)   0%, transparent 70%); }
.pu--life  .pu-glow { background: radial-gradient(circle, var(--red)    0%, transparent 70%); }

.powerup-btn:not(:disabled) .pu-glow { animation: puGlow 2.8s ease-in-out infinite; }

@keyframes puGlow {
  0%, 100% { opacity: 0.15; transform: translateX(-50%) scale(1);   }
  50%       { opacity: 0.35; transform: translateX(-50%) scale(1.2); }
}

.pu-icon {
  position: relative;
  font-size: 1.8rem;
  line-height: 1;
  margin-top: var(--space-1);
  transition: transform .15s;
}
.pu--fifty .pu-icon { color: #cc88ff; text-shadow: 0 0 10px var(--purple); }
.pu--pass  .pu-icon { color: var(--cyan); text-shadow: 0 0 10px rgba(0,240,255,0.5); }
.pu--life  .pu-icon { color: #ff6688; text-shadow: 0 0 10px var(--red); }

.pu-name {
  position: relative;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #fff;
}

.pu-desc {
  position: relative;
  font-size: 0.62rem;
  color: rgba(255,255,255,.45);
  text-align: center;
  line-height: 1.3;
}

.pu-used-label {
  display: none;
  position: absolute;
  inset: 0;
  align-items: center;
  justify-content: center;
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  color: rgba(255,255,255,.3);
  border-radius: inherit;
  background: rgba(0,0,0,.55);
  pointer-events: none;
}

.powerup-btn:not(:disabled):hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 22px rgba(0,0,0,.5);
  filter: brightness(1.2);
}
.powerup-btn:not(:disabled):hover .pu-icon { transform: scale(1.18); }
.powerup-btn:not(:disabled):active { transform: translateY(0); filter: brightness(.9); }

.powerup-btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
  filter: grayscale(0.65);
  box-shadow: none;
}
.powerup-btn:disabled .pu-glow { animation: none; }
.powerup-btn.pu-spent { opacity: 0.2; filter: grayscale(1); }
.powerup-btn.pu-spent .pu-used-label { display: flex; }

/* Event log */
.event-log {
  display: flex;
  flex-direction: column;
  gap: 3px;
  max-height: 100px;
  overflow-y: auto;
  padding: var(--space-2);
  background: rgba(0,0,0,0.2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.log-entry {
  color: var(--text-subtle);
  font-size: 0.78rem;
  padding: 2px var(--space-2);
  border-left: 2px solid var(--surface-3);
  line-height: 1.4;
}
.log-entry.highlight {
  color: var(--text);
  border-color: var(--gold);
}

/* ══════════════════════════════════════════════
   MODAL
══════════════════════════════════════════════ */
.modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  padding: var(--space-4);
}
.modal.hidden { display: none; }

.modal-box {
  background: var(--surface-2);
  border: 1px solid rgba(232,184,75,0.3);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  width: 100%;
  max-width: 360px;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  box-shadow: var(--shadow-lg), 0 0 30px rgba(232,184,75,0.08);
}
.modal-box h3 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--gold-light);
  text-shadow: 0 0 10px var(--gold-glow);
}

#pass-targets {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.pass-target-btn {
  background: var(--surface-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  cursor: pointer;
  font-family: var(--font);
  font-size: 0.95rem;
  padding: var(--space-3) var(--space-4);
  text-align: left;
  transition: border-color 0.15s, background 0.15s;
}
.pass-target-btn:hover {
  border-color: var(--gold);
  background: rgba(232,184,75,0.06);
}

/* ══════════════════════════════════════════════
   RESULT OVERLAY
══════════════════════════════════════════════ */
.overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 150;
  padding: var(--space-4);
}
.overlay.hidden { display: none; }

.overlay-box {
  background: var(--surface);
  border: 1px solid rgba(232,184,75,0.3);
  border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-6);
  width: 100%;
  max-width: 440px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  box-shadow: var(--shadow-lg), 0 0 50px rgba(232,184,75,0.08);
  animation: overlayIn 0.25s ease;
}

.result-icon { font-size: 3.5rem; line-height: 1; }

.overlay-box h2 {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  color: #fff;
}
.overlay-box p {
  color: var(--text-muted);
  font-size: 0.92rem;
  line-height: 1.6;
}

.result-answers {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: center;
  max-height: 130px;
  overflow-y: auto;
  margin-top: var(--space-2);
}

/* ══════════════════════════════════════════════
   TOAST
══════════════════════════════════════════════ */
#toast-area {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--space-2);
  z-index: 200;
  pointer-events: none;
}

.toast {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 0.88rem;
  line-height: 1.4;
  padding: var(--space-3) var(--space-4);
  max-width: 300px;
  box-shadow: var(--shadow);
  animation: slideIn 0.2s ease;
}
.toast.success { border-color: var(--green); color: var(--green); box-shadow: 0 0 16px rgba(57,255,20,0.15); }
.toast.error   { border-color: var(--red);   color: var(--red);   box-shadow: 0 0 16px rgba(255,51,85,0.15); }
.toast.info    { border-color: var(--gold);  color: var(--gold-light); box-shadow: 0 0 16px rgba(232,184,75,0.15); }

/* ══════════════════════════════════════════════
   END GAME SCREEN
══════════════════════════════════════════════ */
.screen-ended {
  flex-direction: column;
  align-items: center;
  overflow-y: auto;
  padding: 0 var(--space-4) var(--space-8);
  position: relative;
  background: var(--bg);
}

.ended-felt {
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(232,184,75,0.06) 0%, transparent 70%),
    radial-gradient(ellipse 60% 40% at 50% 100%, rgba(191,0,255,0.04) 0%, transparent 65%);
  pointer-events: none;
  z-index: 0;
}

.ended-topbar {
  width: 100%;
  max-width: 900px;
  padding: var(--space-4) 0 var(--space-2);
  display: flex;
  align-items: center;
  position: relative;
  z-index: 1;
}

/* Winner hero */
.ended-winner-hero {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  margin: var(--space-6) 0 var(--space-5);
  padding: var(--space-6) var(--space-10);
  background: linear-gradient(135deg, #131005 0%, #1c1808 50%, #131005 100%);
  border: 2px solid var(--gold);
  border-radius: var(--radius-lg);
  box-shadow: 0 0 60px rgba(232,184,75,0.3), inset 0 1px 0 rgba(245,208,106,0.1);
  text-align: center;
  min-width: 280px;
  max-width: 500px;
  width: 100%;
  animation: endHeroIn 0.7s cubic-bezier(.22,1,.36,1) both;
}

.ended-winner-hero--me {
  border-color: var(--gold-light);
  box-shadow: 0 0 80px rgba(245,208,106,0.4), inset 0 1px 0 rgba(245,208,106,0.15);
}

@keyframes endHeroIn {
  from { opacity: 0; transform: translateY(-28px) scale(.94); }
  to   { opacity: 1; transform: none; }
}

.ended-crown {
  font-size: 3rem;
  line-height: 1;
  animation: crownPulse 2.5s ease-in-out infinite;
  color: var(--gold-light);
  text-shadow: 0 0 24px var(--gold-glow);
}

@keyframes crownPulse {
  0%,100% { transform: scale(1) rotate(-4deg); }
  50%      { transform: scale(1.08) rotate(4deg); }
}

.ended-winner-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  text-shadow: 0 0 10px var(--gold-glow);
}

.ended-winner-name {
  font-size: 2.4rem;
  font-weight: 900;
  color: #fff;
  text-shadow: 0 0 28px rgba(232,184,75,0.35);
  line-height: 1.1;
  letter-spacing: 0.05em;
}

.ended-winner-tokens {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--gold-light);
  text-shadow: 0 0 10px var(--gold-glow);
  margin-top: var(--space-1);
}

.ended-confetti {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: space-around;
  font-size: 1.4rem;
  opacity: 0.07;
  pointer-events: none;
  overflow: hidden;
  border-radius: inherit;
  color: var(--gold-light);
}

/* Awards row */
.ended-awards {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
  width: 100%;
  max-width: 900px;
  margin-bottom: var(--space-5);
}

.ended-award-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-3);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  text-align: center;
  transition: border-color .2s, box-shadow .2s;
  animation: awardIn 0.5s cubic-bezier(.22,1,.36,1) both;
}
.ended-award-card:nth-child(1) { animation-delay: .08s; }
.ended-award-card:nth-child(2) { animation-delay: .16s; }
.ended-award-card:nth-child(3) { animation-delay: .24s; }
.ended-award-card:nth-child(4) { animation-delay: .32s; }

@keyframes awardIn {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: none; }
}

.ended-award-card--me {
  border-color: rgba(232,184,75,0.5);
  box-shadow: 0 0 18px rgba(232,184,75,0.15);
}

.award-icon {
  font-size: 1.6rem;
  line-height: 1;
  color: var(--gold-light);
  text-shadow: 0 0 10px var(--gold-glow);
}

.award-label {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-subtle);
}

.award-winner {
  font-size: 0.92rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.2;
}

.award-value {
  font-size: 0.82rem;
  color: var(--gold);
  font-weight: 600;
  text-shadow: 0 0 6px var(--gold-glow);
}

/* Player standings */
.ended-roster {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 700px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-5);
}

.ended-roster-hdr {
  padding: var(--space-3) var(--space-5);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
  border-bottom: 1px solid var(--border);
  background: rgba(232,184,75,0.03);
}

.ended-player-list { display: flex; flex-direction: column; }

.ended-player-row {
  display: grid;
  grid-template-columns: 32px 36px 1fr auto auto auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--border);
  animation: rowIn 0.4s ease both;
}
.ended-player-row:last-child { border-bottom: none; }

.ended-player-row--me {
  background: rgba(232,184,75,0.05);
  border-left: 3px solid var(--gold);
}

.ended-player-row--out { opacity: .5; filter: grayscale(.4); }

@keyframes rowIn {
  from { opacity: 0; transform: translateX(-12px); }
  to   { opacity: 1; transform: none; }
}

.ended-rank {
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--text-muted);
  text-align: center;
}

.ended-avatar {
  width: 36px;
  height: 36px;
  min-width: 36px;
  border-radius: 50%;
  background: var(--surface-3);
  border: 1px solid var(--border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--text-muted);
}

.ended-pname {
  font-size: 0.95rem;
  font-weight: 600;
  color: #fff;
}
.ended-pname em {
  font-style: normal;
  color: var(--text-muted);
  font-weight: 400;
  font-size: 0.82rem;
}

.ended-lives { font-size: 0.78rem; color: var(--red); letter-spacing: .04em; }
.ended-skull { font-size: 1rem; }

.ended-ptokens {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--gold-light);
  text-shadow: 0 0 8px var(--gold-glow);
  min-width: 60px;
  text-align: right;
}

.ended-pstats {
  font-size: 0.75rem;
  color: var(--text-subtle);
  min-width: 60px;
  text-align: right;
}

.ended-eliminated-divider {
  padding: var(--space-2) var(--space-5);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--red);
  background: rgba(255,51,85,0.03);
  border-bottom: 1px solid rgba(255,51,85,0.18);
  border-top: 1px solid rgba(255,51,85,0.18);
}

.ended-actions {
  position: relative;
  z-index: 1;
  margin-bottom: var(--space-6);
}

/* ══════════════════════════════════════════════
   UTILITY
══════════════════════════════════════════════ */
.hidden { display: none !important; }

.float-label {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.9rem;
  font-weight: 900;
  pointer-events: none;
  animation: tokenFloat 0.9s ease forwards;
  white-space: nowrap;
}
.float-label.gain { color: var(--green); text-shadow: 0 0 8px var(--green); }
.float-label.loss { color: var(--red);   text-shadow: 0 0 8px var(--red); }

/* ══════════════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════════════ */
@keyframes pop {
  0%   { transform: scale(0.65); opacity: 0; }
  70%  { transform: scale(1.08); }
  100% { transform: scale(1); opacity: 1; }
}

@keyframes slideIn {
  from { transform: translateX(110%); opacity: 0; }
  to   { transform: translateX(0); opacity: 1; }
}

@keyframes overlayIn {
  from { transform: scale(0.92); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20%       { transform: translateX(-5px); }
  60%       { transform: translateX(5px); }
}
.shake { animation: shake 0.3s ease; }

@keyframes tokenFloat {
  0%   { transform: translateX(-50%) translateY(0) scale(1); opacity: 1; }
  100% { transform: translateX(-50%) translateY(-28px) scale(1.2); opacity: 0; }
}

@keyframes seatGlow {
  0%, 100% { opacity: 0.4; }
  50%       { opacity: 0.9; }
}

@keyframes bidFlash {
  0%   { transform: scale(1.015); opacity: 0.7; }
  50%  { transform: scale(1.005); opacity: 1; }
  100% { transform: scale(1);     opacity: 1; }
}

@keyframes stepPop {
  0%   { transform: scale(0.8); opacity: 0.4; }
  60%  { transform: scale(1.15); opacity: 1; }
  100% { transform: scale(1);    opacity: 1; }
}

@keyframes bannerPulse {
  0%, 100% { opacity: 0.8; }
  50%       { opacity: 1; }
}

@keyframes dotPulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%       { transform: scale(1.5); opacity: 0.5; }
}

@keyframes entrySlide {
  from { transform: translateX(-8px); opacity: 0; }
  to   { transform: translateX(0); opacity: 1; }
}

/* ══════════════════════════════════════════════
   SCROLLBARS
══════════════════════════════════════════════ */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: rgba(232,184,75,0.3); }

/* ══════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
@media (max-width: 520px) {
  .screen { padding: var(--space-4) var(--space-3) var(--space-8); }
  .card { padding: var(--space-4); }
  .controls-panel { padding: var(--space-3) var(--space-4); }
  .player-token { min-width: 72px; padding: var(--space-2); }
  .pt-name { font-size: 0.78rem; }
  .powerups-bar { gap: var(--space-2); }
  .powerup-btn { padding: var(--space-3) var(--space-2); max-width: 110px; }
  .pu-desc { display: none; }
  .pu-icon { font-size: 1.5rem; }
  .answering-header { flex-direction: column; align-items: stretch; gap: var(--space-2); }
  #toast-area { right: var(--space-3); bottom: var(--space-3); }
  .toast { max-width: calc(100vw - var(--space-6)); }
  .ended-winner-hero { padding: var(--space-5) var(--space-6); }
  .ended-winner-name { font-size: 1.8rem; }
  .ended-awards { grid-template-columns: repeat(2, 1fr); }
  .ended-player-row { grid-template-columns: 28px 32px 1fr auto auto; gap: var(--space-2); padding: var(--space-2) var(--space-3); }
  .ended-pstats { display: none; }
}

@media (max-width: 360px) {
  .btn-row { flex-direction: column; }
  .ended-awards { grid-template-columns: 1fr 1fr; }
  .ended-player-row { grid-template-columns: 24px 28px 1fr auto; }
  .ended-ptokens { display: none; }
}

/* ══════════════════════════════════════════════
   AUDIO WIDGET
══════════════════════════════════════════════ */
.audio-widget {
  position: fixed;
  bottom: var(--space-4);
  left: var(--space-4);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-2);
}

.audio-widget-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--surface-2);
  border: 1px solid var(--border);
  color: var(--text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  transition: background .15s, border-color .15s, color .15s, box-shadow .15s;
  box-shadow: 0 2px 8px rgba(0,0,0,.5);
}
.audio-widget-btn:hover {
  background: var(--surface);
  border-color: var(--gold);
  color: var(--gold-light);
  box-shadow: 0 0 12px rgba(232,184,75,0.2);
}
.audio-widget-btn--muted { color: var(--text-subtle); opacity: .6; }
.audio-widget-icon { line-height: 1; }

.audio-panel {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  min-width: 220px;
  box-shadow: 0 4px 20px rgba(0,0,0,.6), 0 0 20px rgba(232,184,75,0.05);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  animation: audioSlideIn .15s ease both;
}

@keyframes audioSlideIn {
  from { opacity: 0; transform: translateY(8px) scale(.97); }
  to   { opacity: 1; transform: none; }
}

.audio-panel-title {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--border);
}

.audio-row {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  gap: var(--space-1) var(--space-2);
  align-items: center;
}

.audio-row-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text);
  grid-column: 1;
  grid-row: 1;
}

.audio-onoff {
  grid-column: 2;
  grid-row: 1;
  padding: 3px 10px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text-muted);
  font-size: 0.75rem;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
  white-space: nowrap;
  font-family: var(--font);
}
.audio-onoff--on {
  background: rgba(232,184,75,0.12);
  border-color: var(--gold);
  color: var(--gold-light);
}

.audio-slider {
  grid-column: 1 / -1;
  grid-row: 2;
  width: 100%;
  accent-color: var(--gold);
  cursor: pointer;
  height: 4px;
  margin-top: var(--space-1);
}
.audio-slider:disabled { opacity: .35; cursor: default; }

/* ── Help button ─────────────────────────────── */
.btn-help {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1.5px solid var(--gold);
  background: transparent;
  color: var(--gold);
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  transition: background .15s, color .15s, transform .1s, box-shadow .15s;
  flex-shrink: 0;
  font-family: var(--font);
}
.btn-help:hover {
  background: var(--gold);
  color: #000;
  transform: scale(1.1);
  box-shadow: 0 0 14px var(--gold-glow);
}

/* ── Help modal ──────────────────────────────── */
.help-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.8);
  backdrop-filter: blur(4px);
  padding: var(--space-4);
}
.help-modal.hidden { display: none; }

.help-modal-box {
  background: var(--surface);
  border: 1px solid var(--gold);
  border-radius: var(--radius-lg);
  box-shadow: 0 0 50px rgba(232,184,75,0.2), var(--shadow-lg);
  width: 100%;
  max-width: 560px;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.help-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  background: linear-gradient(135deg, rgba(232,184,75,0.08) 0%, transparent 60%);
}

.help-modal-title {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--gold-light);
  letter-spacing: 0.06em;
  text-shadow: 0 0 12px var(--gold-glow);
}

.help-modal-close {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 1rem;
  cursor: pointer;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  line-height: 1;
  transition: color .15s, background .15s;
  font-family: var(--font);
}
.help-modal-close:hover { color: var(--text); background: var(--surface-3); }

.help-modal-body {
  overflow-y: auto;
  padding: var(--space-4) var(--space-6) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.help-modal-body::-webkit-scrollbar { width: 4px; }
.help-modal-body::-webkit-scrollbar-track { background: transparent; }
.help-modal-body::-webkit-scrollbar-thumb { background: var(--surface-3); border-radius: 3px; }

/* Help section rows */
.help-section {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  padding: var(--space-3);
  border-radius: var(--radius);
  background: var(--surface-2);
  border: 1px solid var(--border);
  transition: border-color .15s;
}
.help-section:hover { border-color: rgba(232,184,75,0.3); }

.help-section-icon {
  width: 38px;
  height: 38px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
  background: var(--surface-3);
  border: 1px solid var(--border);
}

.help-section-icon.pu-icon-fifty {
  background: rgba(191,0,255,0.15);
  border-color: rgba(191,0,255,0.4);
  color: #cc88ff;
  font-weight: 800;
  font-size: 1rem;
}
.help-section-icon.pu-icon-pass {
  background: rgba(0,240,255,0.1);
  border-color: rgba(0,240,255,0.3);
  color: var(--cyan);
  font-size: 1.1rem;
}
.help-section-icon.pu-icon-life {
  background: rgba(255,51,85,0.12);
  border-color: rgba(255,51,85,0.35);
  color: #ff6688;
}

.help-section-content { flex: 1; min-width: 0; }

.help-section-title {
  margin: 0 0 var(--space-1) 0;
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.04em;
}

.help-section-text {
  margin: 0;
  font-size: 0.85rem;
  color: var(--text-muted);
  line-height: 1.6;
}

.help-section-text strong { color: var(--gold-light); text-shadow: 0 0 6px var(--gold-glow); }
.help-section-text em { color: var(--text); font-style: normal; font-weight: 600; }

/* Phase dividers */
.help-divider {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin: var(--space-2) 0 0;
  color: var(--text-subtle);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}
.help-divider::before,
.help-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}

.help-divider-sub {
  font-size: 0.62rem;
  color: var(--text-subtle);
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
}
