/* ═══════════════════════════════════════════════════════════════
   COMPONENTS — Who's That Fact? V2 (Spotlight Edition)
   ═══════════════════════════════════════════════════════════════
   All component styles using design tokens exclusively.
   Button naming: btn-primary, btn-secondary, btn-ghost, btn-danger.
   
   Designer's Intent: This file mirrors the Spotlight prototype's
   visual design exactly. Every value comes from tokens.css.
   ═══════════════════════════════════════════════════════════════ */

/* ─── SCREEN LAYOUT ─── */
.screen {
  display: none;
  position: relative;
  z-index: var(--z-content);
  flex-direction: column;
  align-items: center;
  min-height: 100vh;
  padding: var(--space-5) var(--space-4) var(--space-10);
}
.screen.active {
  display: flex;
}

/* ─── LOGO ─── */
.logo {
  font-family: var(--font-display);
  font-size: var(--text-5xl);
  letter-spacing: 3px;
  background: linear-gradient(135deg, var(--color-gold-500) 0%, var(--color-accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-align: center;
  margin-bottom: var(--space-1);
  filter: drop-shadow(0 0 18px rgba(245, 197, 24, .3));
}
.tagline {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  text-align: center;
  margin-bottom: var(--space-4);
}

/* ─── FLANK FLAIR BACKGROUND ─── */
@keyframes flankBlobDrift {
  0%   { transform: translate(0, 0) scale(1); }
  33%  { transform: translate(30px, -20px) scale(1.1); }
  66%  { transform: translate(-20px, 30px) scale(0.95); }
  100% { transform: translate(10px, -10px) scale(1.05); }
}
@keyframes flankPulseGlow {
  0%   { transform: scale(0.2); opacity: 0; }
  20%  { opacity: 1; }
  50%  { transform: scale(1); opacity: 0.9; }
  80%  { opacity: 0.4; }
  100% { transform: scale(1.3); opacity: 0; }
}
@keyframes flankBounceRipple {
  0%   { transform: scale(0.3); opacity: 0.7; }
  100% { transform: scale(2); opacity: 0; }
}

/* ─── BEACH BALL BACKGROUND ─── */
#beachBallBg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: var(--z-bg);
  pointer-events: none;
}

/* ─── BEACH BALL FOREGROUND (ball in front of wheel) ─── */
#beachBallFg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: var(--z-ball-fg);
  pointer-events: none;
}

/* ─── STARFIELD (replaced by flank-flair.js canvas particles) ─── */
/*
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: var(--z-bg);
  background-image:
    radial-gradient(1px 1px at 10% 20%, rgba(255,255,255,.3) 0%, transparent 100%),
    radial-gradient(1px 1px at 80% 10%, rgba(255,255,255,.2) 0%, transparent 100%),
    radial-gradient(1px 1px at 60% 80%, rgba(255,255,255,.25) 0%, transparent 100%),
    radial-gradient(1px 1px at 30% 55%, rgba(255,255,255,.15) 0%, transparent 100%),
    radial-gradient(2px 2px at 90% 50%, rgba(245,197,24,.3) 0%, transparent 100%),
    radial-gradient(1px 1px at 45% 35%, rgba(232,67,147,.2) 0%, transparent 100%);
}
*/

/* ─── CLIPPY (Full size — setup/done) ─── */
.clippy-row {
  display: flex;
  align-items: flex-end;
  gap: 0;
  width: 100%;
  max-width: 540px;
  margin: var(--space-3) auto;
}
.clippy-w {
  flex-shrink: 0;
  cursor: pointer;
  filter: drop-shadow(0 6px 18px rgba(0,0,0,.5));
  animation: clippySway 3.5s ease-in-out infinite;
  transform-origin: bottom center;
}
.clippy-img {
  display: block;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.clippy-w:hover .clippy-img {
  transform: scale(1.06, 0.94);
}
.clippy-img:not([src]) {
  visibility: hidden;
}

/* Gumby-like bendy idle sway — skew creates the "lean", scale adds squash/stretch */
@keyframes clippySway {
  0%, 100% { transform: translateY(0) rotate(0deg) skewX(0deg) scale(1); }
  15%      { transform: translateY(-6px) rotate(-2deg) skewX(-3deg) scale(0.98, 1.02); }
  35%      { transform: translateY(-2px) rotate(1.5deg) skewX(2.5deg) scale(1.02, 0.98); }
  55%      { transform: translateY(-7px) rotate(-1deg) skewX(-2deg) scale(0.99, 1.01); }
  75%      { transform: translateY(-3px) rotate(2deg) skewX(3deg) scale(1.01, 0.99); }
}

/* Rubbery wiggle on click — damped bend-and-snap */
@keyframes clippyWiggle {
  0%   { transform: rotate(0) skewX(0deg) scale(1); }
  15%  { transform: rotate(-8deg) skewX(-6deg) scale(0.92, 1.08); }
  30%  { transform: rotate(6deg) skewX(5deg) scale(1.06, 0.94); }
  45%  { transform: rotate(-5deg) skewX(-4deg) scale(0.95, 1.05); }
  60%  { transform: rotate(4deg) skewX(3deg) scale(1.03, 0.97); }
  75%  { transform: rotate(-2deg) skewX(-1.5deg) scale(0.98, 1.02); }
  90%  { transform: rotate(1deg) skewX(1deg) scale(1.01, 0.99); }
  100% { transform: rotate(0) skewX(0deg) scale(1); }
}

/* Springy excited bounce — squash on land, stretch on jump */
@keyframes clippyExcited {
  0%, 100% { transform: translateY(0) scale(1) skewX(0deg); }
  15%  { transform: translateY(-18px) scale(0.9, 1.12) skewX(-3deg); }
  30%  { transform: translateY(-4px) scale(1.1, 0.9) skewX(3deg); }
  50%  { transform: translateY(-14px) scale(0.93, 1.08) skewX(-2deg); }
  70%  { transform: translateY(-3px) scale(1.05, 0.95) skewX(2deg); }
  85%  { transform: translateY(-8px) scale(0.97, 1.03) skewX(-1deg); }
}

/* ─── CLIPPY SWAT ARM (extends LEFT, paperclip wire + cartoon glove) ─── */
.clippy-w, .cw { position: relative; }
.clippy-arm {
  position: absolute;
  left: -6px;
  top: 38%;
  width: 0;
  height: 4px;
  background: linear-gradient(180deg, #d4d4d8 0%, #a0a0a8 40%, #c8c8cc 100%);
  border: 0.5px solid rgba(120, 120, 128, 0.4);
  border-radius: 2px;
  transform-origin: right center;
  pointer-events: none;
  opacity: 0;
}
/* Cartoon white glove at the end of the arm */
.clippy-arm::after {
  content: '';
  position: absolute;
  left: -18px;
  top: -9px;
  width: 22px;
  height: 22px;
  background: radial-gradient(circle at 55% 45%, #ffffff 60%, #e8e8e8 100%);
  border-radius: 50%;
  border: 1.5px solid #d0d0d0;
  box-shadow:
    -5px -4px 0 -1px #ffffff,
    -4px -7px 0 -2px #f0f0f0,
    -8px -2px 0 -2px #ffffff,
    inset 0 2px 3px rgba(0,0,0,0.06);
}
/* Paperclip wire "wrist" connector */
.clippy-arm::before {
  content: '';
  position: absolute;
  left: -2px;
  top: -3px;
  width: 6px;
  height: 10px;
  border: 1.5px solid #a0a0a8;
  border-right: none;
  border-radius: 4px 0 0 4px;
  background: transparent;
}
.swatting .clippy-arm {
  animation: clippySwatArm 0.45s cubic-bezier(.2,.8,.3,1) forwards;
}
@keyframes clippySwatArm {
  0%   { width: 0; opacity: 0; transform: rotate(-30deg); }
  15%  { width: 30px; opacity: 1; transform: rotate(-30deg); }
  35%  { width: 40px; opacity: 1; transform: rotate(25deg); }
  55%  { width: 34px; opacity: 1; transform: rotate(-10deg); }
  75%  { width: 24px; opacity: 1; transform: rotate(5deg); }
  100% { width: 0; opacity: 0; transform: rotate(0deg); }
}

/* ─── CLIPPY SPEECH TOGGLE ─── */
.clippy-speech-toggle {
  background: none;
  border: none;
  font-size: 16px;
  cursor: pointer;
  padding: 2px 4px;
  opacity: 0.5;
  transition: opacity 0.2s;
  line-height: 1;
  flex-shrink: 0;
  align-self: flex-end;
  margin-bottom: var(--space-2);
}
.clippy-speech-toggle:hover { opacity: 1; }
.clippy-speech-toggle[aria-pressed='true'] { opacity: 0.9; }

/* Speech bubble */
.bubble {
  flex: 1;
  background: #fff;
  border-radius: var(--radius-lg) var(--radius-lg) var(--radius-lg) var(--space-1);
  padding: var(--space-3) var(--space-4);
  margin-left: var(--space-3);
  margin-bottom: var(--space-2);
  box-shadow: var(--shadow-md);
  min-height: 48px;
  display: flex;
  align-items: center;
  position: relative;
}
.bubble::before {
  content: "";
  position: absolute;
  left: -10px;
  bottom: 14px;
  width: 0;
  height: 0;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-right: 12px solid #fff;
}
.bubble-text {
  font-size: var(--text-base);
  color: var(--color-text-inverse);
  font-weight: 500;
  line-height: var(--leading-normal);
}
.bubble-text .hi {
  color: #7c3aed;
  font-weight: 700;
}

/* ─── CLIPPY MINI (game screen) ─── */
.clippy-mini {
  display: flex;
  align-items: flex-end;
  width: 100%;
  max-width: 480px;
  margin: var(--space-2) auto 0;
}
.clippy-mini .cw {
  flex-shrink: 0;
  width: 44px;
  animation: clippySway 3.5s ease-in-out infinite;
  transform-origin: bottom center;
  cursor: pointer;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,.5));
}
.clippy-mini .cw img {
  width: 100%;
  display: block;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.clippy-mini .cw:hover img {
  transform: scale(1.06, 0.94);
}
.clippy-mini .bbl {
  flex: 1;
  background: #fff;
  border-radius: var(--radius-md) var(--radius-md) var(--radius-md) var(--space-1);
  padding: var(--space-2) var(--space-3);
  margin-left: var(--space-2);
  margin-bottom: var(--space-1);
  box-shadow: 0 4px 16px rgba(0,0,0,.3);
  display: flex;
  align-items: center;
  position: relative;
}
.clippy-mini .bbl::before {
  content: "";
  position: absolute;
  left: -8px;
  bottom: 10px;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-right: 9px solid #fff;
}
.clippy-mini .bbl-text {
  font-size: var(--text-sm);
  color: var(--color-text-inverse);
  font-weight: 500;
  line-height: 1.4;
}

/* ─── BUTTONS ─── */
.btn {
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  font-family: var(--font-display);
  letter-spacing: 1.5px;
  transition: all var(--transition-base);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: 44px;
}
.btn:active:not(:disabled) {
  transform: scale(0.97);
}
.btn:disabled {
  opacity: .4;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
  pointer-events: none;
}

/* Primary (gold gradient) */
.btn-primary {
  background: linear-gradient(135deg, var(--color-gold-500), var(--color-gold-700));
  color: var(--color-text-inverse);
  padding: var(--space-3) var(--space-6);
  font-size: var(--text-lg);
}
#spinBtn {
  animation: spinPulse 2.1s ease-in-out infinite;
}
@media (hover: hover) {
  .btn-primary:hover:not(:disabled) {
    filter: brightness(1.1);
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(245, 197, 24, .4);
  }
  #spinBtn:hover {
    animation-play-state: paused;
  }
}
@keyframes spinPulse {
  0%, 100% {
    box-shadow: 0 0 0 rgba(245, 197, 24, 0);
  }
  50% {
    box-shadow: 0 0 24px rgba(245, 197, 24, 0.45);
  }
}

/* Secondary (green gradient) */
.btn-secondary {
  background: linear-gradient(135deg, var(--color-green), var(--color-green-dark));
  color: var(--color-text-inverse);
  padding: var(--space-3) var(--space-6);
  font-size: var(--text-lg);
}
@media (hover: hover) {
  .btn-secondary:hover:not(:disabled) {
    filter: brightness(1.1);
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(0, 224, 160, .3);
  }
}

/* Ghost (outline) */
.btn-ghost {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, .18);
  color: var(--color-text-primary);
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-base);
}
@media (hover: hover) {
  .btn-ghost:hover {
    border-color: var(--color-gold-500);
    color: var(--color-gold-500);
  }
}

/* Danger (destructive) */
.btn-danger {
  background: rgba(255, 107, 107, .12);
  border: 1px solid rgba(255, 107, 107, .25);
  color: var(--color-red);
  border-radius: var(--radius-sm);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  min-height: 36px;
}
@media (hover: hover) {
  .btn-danger:hover {
    background: rgba(255, 107, 107, .28);
  }
}

/* ─── CARD ─── */
.card {
  background: var(--color-bg-card);
  border: 1px solid rgba(245, 197, 24, .15);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  width: 100%;
  box-shadow: var(--shadow-xl);
}
.card-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  letter-spacing: var(--tracking-widest);
  color: var(--color-gold-500);
  margin-bottom: var(--space-3);
}

/* ─── INPUTS ─── */
input[type="text"],
textarea {
  width: 100%;
  background: var(--color-bg-card-alt);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: var(--radius-sm);
  color: var(--color-text-primary);
  font-family: var(--font-body);
  font-size: var(--text-base);
  padding: var(--space-2) var(--space-3);
  transition: border-color var(--transition-base);
}
input[type="text"]:focus:not(:focus-visible),
textarea:focus:not(:focus-visible) {
  outline: none;
}
input[type="text"]:focus,
textarea:focus {
  border-color: var(--color-gold-500);
}
input[type="text"]:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--color-gold-500);
  outline-offset: 2px;
}
textarea {
  resize: none;
  height: 100px;
  line-height: var(--leading-normal);
}

/* ─── SETUP: Entry rows ─── */
.entry-row {
  display: grid;
  grid-template-columns: 1fr 36px;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
  align-items: center;
}
.setup-footer {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-4);
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}
.pcount {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.manual-entry-form {
  display: grid;
  gap: var(--space-3);
}

.manual-entry-actions {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.manual-submit-btn {
  font-size: var(--text-base);
  padding: var(--space-2) var(--space-4);
  min-height: 40px;
}

/* ─── MODE SELECTOR ─── */
.mode-selector {
  display: flex;
  gap: var(--space-3);
  width: 100%;
  max-width: 560px;
  margin-bottom: var(--space-4);
}
.mode-btn {
  flex: 1;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 2px solid rgba(255, 255, 255, .1);
  background: var(--color-bg-card);
  color: var(--color-text-muted);
  cursor: pointer;
  font-family: var(--font-body);
  font-size: var(--text-base);
  text-align: center;
  transition: all var(--transition-base);
  line-height: var(--leading-tight);
}
.mode-btn.active,
.mode-btn[aria-selected="true"] {
  border-color: var(--color-gold-500);
  color: var(--color-text-primary);
  background: rgba(245, 197, 24, .07);
}
.mode-btn:active { transform: scale(0.97); }
.mode-icon { font-size: var(--text-2xl); display: block; margin-bottom: var(--space-1); }
.mode-label {
  font-family: var(--font-display);
  letter-spacing: 1.5px;
  font-size: var(--text-base);
}

/* ─── LIVE QR ─── */
.session-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--color-bg-card);
  border: 1px solid rgba(245, 197, 24, .15);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  margin-bottom: var(--space-4);
}
.session-code {
  font-family: var(--font-display);
  font-size: 2.4rem;
  letter-spacing: 6px;
  color: var(--color-gold-500);
  line-height: 1;
}
#qrContainer {
  background: #fff;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  width: 128px;
  height: 128px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.waiting-room {
  background: var(--color-bg-card);
  border: 1px solid rgba(255, 255, 255, .07);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  min-height: 80px;
}
.live-badge {
  background: rgba(0, 224, 160, .12);
  border: 1px solid rgba(0, 224, 160, .25);
  border-radius: var(--radius-sm);
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  color: var(--color-green);
  letter-spacing: 1px;
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}
.live-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-green);
  animation: pulse 1.4s ease-in-out infinite;
}
.player-chips { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.player-chip {
  background: rgba(245, 197, 24, .1);
  border: 1px solid rgba(245, 197, 24, .2);
  border-radius: var(--radius-xl);
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  animation: chipIn .3s ease forwards;
}
@keyframes chipIn { from { opacity: 0; transform: scale(.8); } to { opacity: 1; transform: scale(1); } }

/* ─── IMPORT ─── */
.import-zone {
  border: 2px dashed rgba(255, 255, 255, .12);
  border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-5);
  text-align: center;
  cursor: pointer;
  transition: all var(--transition-base);
  margin-bottom: var(--space-4);
  position: relative;
}
.import-zone.drag-over,
.import-zone:hover {
  border-color: var(--color-gold-500);
  background: rgba(245, 197, 24, .03);
}
.import-icon { font-size: 2.5rem; margin-bottom: var(--space-3); }
.import-title {
  font-family: var(--font-display);
  letter-spacing: var(--tracking-widest);
  font-size: var(--text-xl);
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
}
.import-sub {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
}
#fileInput {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
}
.preview-row {
  display: grid;
  grid-template-columns: 120px 1fr 28px;
  gap: var(--space-2);
  align-items: center;
  border-bottom: 1px solid rgba(255, 255, 255, .05);
  padding: var(--space-2) 0;
  font-size: var(--text-sm);
}
.preview-name { color: var(--color-gold-500); font-weight: 600; }
.preview-fact { color: var(--color-text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.preview-remove {
  background: none;
  border: none;
  color: var(--color-red);
  cursor: pointer;
  font-size: 1rem;
  opacity: .6;
  transition: opacity var(--transition-base);
  padding: 0;
  min-height: auto;
}
.preview-remove:hover { opacity: 1; }

/* ─── SPOTLIGHT GAME LAYOUT ─── */
.spotlight {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 700px;
  min-height: 70vh;
}
.topbar {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-2);
}
.round-badge {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  letter-spacing: 2px;
  color: var(--color-gold-500);
}

/* Wheel hero */
.wheel-hero {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-bottom: var(--space-2);
  transition: opacity .5s;
}
#wheelCanvas {
  border-radius: 50%;
  box-shadow: 0 0 60px rgba(245, 197, 24, .2), 0 0 120px rgba(0,0,0,.8);
  display: block;
  opacity: 0.95;
}
.pointer {
  position: absolute;
  top: -13px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  border-top: 28px solid var(--color-gold-500);
  filter: drop-shadow(0 0 8px var(--color-gold-500));
  z-index: var(--z-pointer);
}
.hub {
  position: absolute;
  width: 40px;
  height: 40px;
  background: radial-gradient(circle, #fff 0%, var(--color-gold-500) 60%, var(--color-gold-700) 100%);
  border-radius: 50%;
  box-shadow: 0 0 14px var(--color-gold-500);
  z-index: var(--z-hub);
  cursor: pointer;
}

/* Fact overlay */
.fact-overlay {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% - 2rem);
  max-width: 560px;
  z-index: 20;
  background: var(--color-bg-card);
  border: 1px solid rgba(245, 197, 24, .25);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-glow-gold), 0 -8px 32px rgba(0,0,0,.6);
  text-align: center;
  display: none;
}
.fact-overlay.show {
  display: block;
}
.fact-label {
  font-family: var(--font-display);
  letter-spacing: var(--tracking-widest);
  font-size: var(--text-lg);
  color: var(--color-gold-500);
  margin-bottom: var(--space-3);
}
.fact-text {
  background: var(--color-bg-card-alt);
  border-left: 4px solid var(--color-gold-500);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: var(--space-3) var(--space-4);
  font-size: 1.05rem;
  line-height: var(--leading-relaxed);
  color: var(--color-text-primary);
  text-align: left;
  margin-bottom: var(--space-4);
  max-width: 60ch;
}
.thinking {
  color: var(--color-text-muted);
  font-size: var(--text-base);
  letter-spacing: 1px;
  animation: pulse 1.4s ease-in-out infinite;
  margin-bottom: var(--space-3);
}
@keyframes pulse { 0%, 100% { opacity: .5; } 50% { opacity: 1; } }

/* Timer */
.timer-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-2);
}
.timer-label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--color-text-muted);
}
.timer-sec {
  color: var(--color-gold-500);
  font-family: var(--font-display);
  font-size: var(--text-xl);
}
.timer-bg {
  background: rgba(255, 255, 255, .07);
  border-radius: var(--radius-full);
  height: 7px;
  overflow: hidden;
}
.timer-fill {
  height: 100%;
  border-radius: var(--radius-full);
  width: 100%;
  transition: width .25s linear;
  background: linear-gradient(90deg, var(--color-green), var(--color-gold-500));
}
.timer-actions {
  display: flex;
  gap: var(--space-2);
}
.timer-actions button {
  min-height: 36px;
  min-width: 36px;
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  padding: var(--space-1) var(--space-3);
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .12);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: all var(--transition-fast);
}
.timer-actions button:hover {
  border-color: var(--color-gold-500);
  color: var(--color-gold-500);
}

#revealPrompt {
  margin-top: var(--space-3);
}

/* Reveal overlay content */
.reveal-overlay {
  display: none;
  text-align: center;
}
.reveal-overlay.show {
  display: block;
}
.reveal-icon { font-size: 3rem; margin-bottom: var(--space-2); }
.reveal-was {
  font-family: var(--font-display);
  font-size: var(--text-base);
  letter-spacing: 2px;
  color: var(--color-text-muted);
}
.reveal-name {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  letter-spacing: 4px;
  margin-bottom: var(--space-2);
}
.speaker-label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--color-gold-500);
  display: flex;
  justify-content: space-between;
  margin: var(--space-3) 0 var(--space-2);
}
.speaker-fill {
  height: 7px;
  border-radius: var(--radius-full);
  background: linear-gradient(90deg, var(--color-gold-500), var(--color-accent));
  transition: width .25s linear;
}

/* Tracker drawer */
.tracker-line {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--color-bg-card);
  border-top: 1px solid rgba(245, 197, 24, .15);
  padding: var(--space-3) var(--space-4);
  display: none;
  justify-content: space-between;
  align-items: center;
  z-index: 50;
  cursor: pointer;
}
.tracker-line.show {
  display: flex;
}
.tracker-text {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.tracker-text strong {
  color: var(--color-green);
}
.tracker-drawer {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 54px;
  background: var(--color-bg-card);
  border-top: 1px solid rgba(245, 197, 24, .15);
  border-bottom: 1px solid rgba(245, 197, 24, .15);
  padding: var(--space-3) var(--space-4);
  z-index: 49;
  box-shadow: 0 -8px 24px rgba(0, 0, 0, .25);
  max-height: 42vh;
  overflow: auto;
}
.tracker-drawer-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}
.tracker-col {
  min-width: 0;
}
.tracker-col-label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}
.tracker-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.tracker-chip {
  border: 1px solid rgba(255, 255, 255, .14);
  background: rgba(255, 255, 255, .06);
  color: var(--color-text-primary);
  border-radius: var(--radius-full);
  padding: var(--space-1) var(--space-2);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: transform .12s ease, border-color .12s ease, background .12s ease;
}
.tracker-chip:hover {
  transform: translateY(-1px);
  border-color: rgba(245, 197, 24, .45);
}
.tracker-chip.remaining {
  background: rgba(0, 224, 160, .13);
  border-color: rgba(0, 224, 160, .45);
  color: var(--color-green);
}
.tracker-chip.revealed {
  color: var(--color-text-muted);
  text-decoration: line-through;
}

@media (max-width: 820px) {
  .tracker-drawer-grid {
    grid-template-columns: 1fr;
  }
}

/* ─── DONE SCREEN ─── */
.trophy {
  font-size: 4.5rem;
  animation: bob 1.2s ease-in-out infinite;
}
@keyframes bob { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-14px); } }
.done-title {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  letter-spacing: 4px;
  color: var(--color-gold-500);
}
.winner-card {
  background: var(--color-bg-card);
  border: 2px solid var(--color-gold-500);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-8);
  box-shadow: var(--shadow-glow-gold);
}
.winner-label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}
.winner-name {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  letter-spacing: 3px;
  color: var(--color-text-primary);
}
.awards-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(180px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-4);
  width: 100%;
  max-width: 560px;
}
.award-card {
  background: var(--color-bg-card);
  border: 1px solid rgba(245, 197, 24, .22);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  box-shadow: var(--shadow-sm);
}
.award-title {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}
.award-name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  letter-spacing: 2px;
  color: var(--color-text-primary);
}
.award-time {
  margin-top: var(--space-1);
  font-size: var(--text-sm);
  color: var(--color-gold-500);
}

/* Confetti */
.confetti-wrap {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: var(--z-confetti);
  overflow: hidden;
}
.confetti-piece {
  position: absolute;
  width: 10px;
  height: 10px;
  top: -20px;
  animation: confetti-fall linear forwards;
}
@keyframes confetti-fall {
  0% { transform: translateY(0) rotate(0deg); opacity: 1; }
  100% { transform: translateY(100vh) rotate(720deg); opacity: 0; }
}
@keyframes flash-gold {
  0%, 100% { background: var(--color-bg-card); }
  50% { background: rgba(245, 197, 24, .15); }
}

/* ─── EASTER EGG: Block Breaker ─── */
#breakoutContainer {
  position: fixed;
  inset: 0;
  display: none;
  z-index: var(--z-breakout);
  pointer-events: none;
}
#breakoutContainer.active {
  display: block;
}
#breakoutPaddle {
  position: fixed;
  bottom: 60px;
  width: 120px;
  height: 14px;
  border-radius: 7px;
  background: linear-gradient(180deg, #F5C518 0%, #d4a800 100%);
  box-shadow:
    0 0 16px rgba(245,197,24,0.5),
    0 2px 6px rgba(0,0,0,0.4),
    inset 0 2px 2px rgba(255,255,255,0.3);
  pointer-events: none;
}
#breakoutField {
  position: fixed;
  inset: 0;
  pointer-events: none;
}
.breakout-block {
  position: fixed;
  border-radius: 4px;
  box-shadow:
    inset 0 2px 2px rgba(255,255,255,0.25),
    inset 0 -2px 2px rgba(0,0,0,0.15),
    0 2px 8px rgba(0,0,0,0.3);
  transition: opacity 0.2s, transform 0.2s;
}
.breakout-block.hit {
  opacity: 0;
  transform: scale(1.3);
}
#breakoutScore {
  position: fixed;
  top: 20px;
  right: 20px;
  background: rgba(0,0,0,.7);
  color: var(--color-gold-500);
  font-family: var(--font-display);
  font-size: 1.8rem;
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-md);
  z-index: var(--z-breakout-score);
  display: none;
  letter-spacing: 2px;
}
#breakoutScore.active {
  display: block;
}
.score-flash {
  animation: score-pop .4s ease-out;
}
@keyframes score-pop {
  0% { transform: scale(1); }
  50% { transform: scale(1.3); color: #00E0A0; }
  100% { transform: scale(1); }
}

/* ─── INTAKE FORM ─── */
.intake-card {
  background: var(--color-bg-card);
  border: 1px solid rgba(245, 197, 24, .2);
  border-radius: var(--radius-xl);
  padding: var(--space-8) var(--space-6);
  width: 100%;
  max-width: 420px;
  box-shadow: var(--shadow-xl), var(--shadow-glow-gold);
}
.session-badge {
  text-align: center;
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  color: var(--color-text-muted);
  text-transform: uppercase;
  margin-bottom: var(--space-6);
}
.session-badge span {
  color: var(--color-gold-500);
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: 3px;
}
.char-count {
  text-align: right;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-1);
}
.char-count.warn { color: var(--color-gold-500); }
.char-count.over { color: var(--color-red); }
.btn-submit {
  width: 100%;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  font-family: var(--font-display);
  letter-spacing: var(--tracking-widest);
  font-size: var(--text-xl);
  padding: var(--space-4);
  background: linear-gradient(135deg, var(--color-gold-500), var(--color-gold-700));
  color: var(--color-text-inverse);
  transition: all var(--transition-base);
  margin-top: var(--space-1);
  min-height: 44px;
}
.view { display: none; }
.view.show { display: block; }

/* ─── INLINE STYLE EXTRACTION (ROOT PAGES) ─── */
.version-badge {
  position: fixed;
  bottom: 8px;
  right: 8px;
  background: rgba(245, 197, 24, .9);
  color: #000;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 4px;
  z-index: 9999;
  pointer-events: none;
}
.setup-clippy-size {
  width: 80px;
}
.setup-shell {
  width: 100%;
  max-width: 560px;
}
.session-meta-label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-text-muted);
}
.session-url-text {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-1);
  word-break: break-all;
}
.live-actions-row {
  display: flex;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}
.clear-session-btn {
  color: var(--color-red);
  border-color: rgba(255, 107, 107, .25);
}
.waiting-header {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.waiting-empty {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  text-align: center;
  padding: var(--space-4) 0;
}
.player-count-text {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-2);
  text-align: right;
}
.import-preview-label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
}
.import-actions-row {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
  margin-top: var(--space-4);
}
#importPreview {
  display: none;
}
#clearImportBtn {
  display: none;
}
.unified-play-bar {
  margin-top: var(--space-4);
  text-align: center;
}
.total-count-text {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-2);
}
.unified-play-btn {
  width: 100%;
  font-size: var(--text-lg);
  padding: var(--space-3) var(--space-6);
}
.topbar-actions {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  flex-wrap: wrap;
}
.sfx-control {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-2);
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, .04);
  min-height: 36px;
}
.sfx-control-label,
.sfx-control-value {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: .5px;
}
.sfx-control-value {
  min-width: 34px;
  text-align: right;
}
.sfx-volume-range {
  width: 88px;
  accent-color: var(--color-gold-500);
}
.edit-btn-compact {
  font-size: var(--text-sm);
  padding: var(--space-2) var(--space-3);
}
.spin-btn-large {
  font-size: 2rem;
  padding: var(--space-4) var(--space-12);
  letter-spacing: 4px;
  margin-bottom: var(--space-2);
}
.skip-btn-accent {
  color: var(--color-gold-500);
}
.reveal-prompt-copy {
  color: var(--color-text-muted);
  font-size: var(--text-base);
  margin-bottom: var(--space-3);
  line-height: 1.7;
}
.reveal-prompt-copy strong {
  color: var(--color-text-primary);
}
.reveal-fact-margin {
  margin: var(--space-2) auto 0;
}
.speaker-sec-text {
  font-family: var(--font-display);
  font-size: var(--text-xl);
}
.next-btn-margin {
  margin-top: var(--space-4);
}
.tracker-arrow {
  color: var(--color-gold-500);
}
.done-center {
  text-align: center;
}
.done-copy {
  color: var(--color-text-muted);
  margin: var(--space-3) 0 var(--space-5);
  font-size: var(--text-base);
}
.done-clippy-row {
  max-width: 440px;
  margin: var(--space-4) auto 0;
}
.done-clippy-size {
  width: 56px;
}
.play-again-btn {
  margin-top: var(--space-5);
  font-size: var(--text-xl);
  padding: var(--space-4) var(--space-8);
}

.intake-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px 20px;
  min-height: 100vh;
}
.intake-logo-small {
  font-size: var(--text-3xl);
}
.intake-intro-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
}
.intake-intro-copy {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-5);
  line-height: var(--leading-normal);
}
.intake-already-badge {
  background: rgba(0, 224, 160, .08);
  border: 1px solid rgba(0, 224, 160, .2);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  color: var(--color-green);
  text-align: center;
  margin-bottom: var(--space-4);
  display: none;
}
.intake-field-wrap {
  margin-bottom: var(--space-1);
}
.intake-field-wrap-top {
  margin-top: var(--space-3);
}
.intake-label {
  display: block;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--color-text-muted);
  margin-bottom: var(--space-2);
}
.loading-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid rgba(245, 197, 24, .2);
  border-top-color: var(--color-gold-500);
  border-radius: 50%;
  animation: spin .8s linear infinite;
  margin: var(--space-8) auto;
}
.loading-text {
  text-align: center;
  color: var(--color-text-muted);
  font-size: var(--text-base);
}
.success-emoji {
  font-size: 4rem;
  text-align: center;
  margin-bottom: var(--space-4);
  animation: bob 1.2s ease-in-out infinite;
}
.success-title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  letter-spacing: 3px;
  color: var(--color-green);
  text-align: center;
  margin-bottom: var(--space-3);
}
.success-copy {
  color: var(--color-text-muted);
  font-size: var(--text-base);
  text-align: center;
  margin-bottom: var(--space-4);
  line-height: 1.6;
}
.submitted-name {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-align: center;
  margin-top: var(--space-3);
}
.error-emoji {
  font-size: 3rem;
  text-align: center;
  margin-bottom: var(--space-3);
}
.error-msg {
  color: var(--color-red);
  text-align: center;
  font-size: var(--text-base);
  line-height: 1.6;
  margin-bottom: var(--space-4);
}
.btn-full-width {
  width: 100%;
}
.closed-emoji {
  text-align: center;
  font-size: 3rem;
  margin-bottom: var(--space-3);
}
.closed-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--color-gold-500);
  text-align: center;
  margin-bottom: var(--space-3);
}
.closed-copy {
  color: var(--color-text-muted);
  text-align: center;
  font-size: var(--text-base);
  line-height: 1.6;
}
.intake-footer-note {
  margin-top: var(--space-5);
  text-align: center;
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, .15);
  letter-spacing: 1px;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

/* ─── RESPONSIVE ─── */
@media (max-width: 479px) {
  .entry-row {
    grid-template-columns: 1fr;
    gap: var(--space-2);
  }
  .mode-selector {
    flex-direction: column;
  }
  .awards-grid {
    grid-template-columns: 1fr;
  }
  .fact-overlay {
    margin-top: -60px;
  }
  .session-header {
    flex-direction: column;
    gap: var(--space-4);
    text-align: center;
  }
}

@media (min-width: 768px) {
  .clippy-w { width: 100px; }
  .fact-overlay { padding: var(--space-8); }
}

@media (min-width: 1024px) {
  .clippy-w { width: 120px; }
}
