/* Minimal, clean UI — no build step needed */
:root {
  --bg: #0b0e13;
  --card: #11151c;
  --muted: #aab3c2;
  --text: #e8eef7;
  --primary: #7dd3fc;
  --primary-ink: #0b1220;
  --accent: #c4b5fd;
  --ring: rgba(125, 211, 252, 0.35);
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: radial-gradient(1200px 800px at 20% -10%, #111827 0, #0b0e13 60%, #06070a 100%);
  color: var(--text);
  line-height: 1.6;
}

.container { width: min(1100px, 92vw); margin: 0 auto; }

.site-header {
  padding: 32px 0 8px;
}
.site-header h1 { font-size: 2.2rem; margin: 0 0 6px; letter-spacing: -0.02em; }
.tagline { color: var(--muted); margin: 0 0 16px; }
.header-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.btn {
  appearance: none; border: 1px solid #263246; color: var(--text); background: #0f1420;
  padding: 10px 14px; border-radius: 999px; cursor: pointer; text-decoration: none; font-weight: 600;
  transition: transform .08s ease, box-shadow .08s ease, border-color .15s ease;
}
.btn:hover { transform: translateY(-1px); border-color: #334460; box-shadow: 0 0 0 4px var(--ring); }
.btn:active { transform: translateY(0); }
.btn-primary { background: linear-gradient(180deg, var(--primary), #60a5fa); color: var(--primary-ink); border: none; }

main { padding-bottom: 64px; }

.card {
  background: linear-gradient(180deg, #0f1320, #0b0f1a);
  border: 1px solid #263246;
  border-radius: 16px;
  padding: 22px 20px;
  margin: 16px 0;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}

.hero {
  display: grid; grid-template-columns: 1.2fr .8fr; gap: 20px; align-items: center;
}
.hero .timer-display {
  font-variant-numeric: tabular-nums;
  font-size: 42px; font-weight: 800; text-align: center; padding: 20px 0;
  background: #0a0f1a; border: 1px solid #1e293b; border-radius: 12px;
}
.timer-controls { display:flex; gap:8px; justify-content:center; }
.timer-marks { display:flex; gap:12px; justify-content:center; color: var(--muted); font-size: 12px; margin-top:8px; }
.mt-8 { margin-top: 12px; }

.mono { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; }

.host-steps { margin: 8px 0 0 0; padding-left: 18px; }
.host-steps li { margin: 6px 0; }

.grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px;
}

.cast-card {
  display:flex; gap: 12px; align-items: center; padding: 12px; border: 1px solid #223049; border-radius: 12px;
  background: radial-gradient(400px 200px at 20% 0%, #0f172a 0, #0a0f1a 80%);
}
.avatar {
  flex: 0 0 44px; height: 44px; width: 44px; border-radius: 50%;
  display:grid; place-items:center; font-weight:800; letter-spacing:-0.02em; background: #1f2937; border: 1px solid #374151;
}
.cast-card h4 { margin: 0; font-size: 16px; }
.cast-card p { margin: 0; color: var(--muted); font-size: 13px; }

.clue-grid {
  display:grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.clue-card { border-radius: 12px; border: 1px dashed #2a3a57; padding: 12px; }
.clue-list { margin: 8px 0 0; padding-left: 18px; }
.clue-list li { margin: 6px 0; }

.vote-card .vote-form {
  display:grid; gap: 12px;
}
fieldset { border: 1px solid #23324b; border-radius: 12px; padding: 12px; }
legend { padding: 0 6px; color: var(--muted); }
.suspects { display:grid; grid-template-columns: repeat(auto-fill, minmax(180px,1fr)); gap: 10px; }
.radio {
  border: 1px solid #223049; border-radius: 12px; padding: 8px 10px; background: #0a0f1a;
  display:flex; gap:8px; align-items: center;
}
.radio input { accent-color: #60a5fa; }
.why textarea {
  width: 100%; color: var(--text); background: #090e18; border: 1px solid #23324b; border-radius: 12px; padding: 10px;
}
.vote-actions { display:flex; gap: 12px; align-items: center; }
.muted { color: var(--muted); font-size: 12px; }
.hidden { display: none !important; }

.site-footer { color: var(--muted); margin-top: 16px; font-size: 14px; }

@media (max-width: 860px) {
  .hero { grid-template-columns: 1fr; }
}

/* Native select styling for reliability */
.select-wrap { display: grid; gap: 6px; }
.select-wrap select {
  width: 100%;
  background: #090e18;
  color: var(--text);
  border: 1px solid #23324b;
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 16px;
}
.select-wrap select:focus { outline: none; box-shadow: 0 0 0 4px var(--ring); }
