
:root {
  --bg: #0b1020;
  --panel: #0e1530;
  --text: #e5e7eb;
  --muted: #9ca3af;
  --accent: #be185d;
  --accent2: #1e40af;
  --border: #374151;
  --danger: #7f1d1d;
}
* { box-sizing: border-box; }
html, body { background: var(--bg); color: var(--text); font-family: system-ui, -apple-system, Segoe UI, Roboto, sans-serif; margin:0; }
.top {
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:12px 16px; border-bottom:1px solid var(--border); background:#0a0f1d; position:sticky; top:0; z-index:10;
}
.brand { font-weight:800; letter-spacing:.3px; }
.ver { font-weight:600; color:#a3e635; margin-left:6px; }
.session { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.session input { background:#111827; color:var(--text); border:1px solid var(--border); border-radius:10px; padding:8px 10px; }
.session button { background:#111827; color:var(--text); border:1px solid var(--border); border-radius:10px; padding:8px 10px; }
.role button#roleMan.active { background:#991b1b; color:#fff; }
.role button#roleVrouw.active { background:#1e40af; color:#fff; }
.dot { padding:4px 8px; border-radius:999px; font-size:12px; border:1px solid var(--border); }
.dot.offline { background:#111827; color:#aaa; }
.dot.online { background:#14532d; color:#ecfdf5; border-color:#166534; }
.container { max-width:1000px; margin:24px auto; padding:0 16px; display:grid; gap:16px; }
.panel { background:var(--panel); border:1px solid var(--border); border-radius:16px; padding:16px; }
h2 { margin:0 0 12px 0; }
.wheel-wrap { display:grid; gap:8px; }
.row { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.pill { background:#111827; border:1px solid var(--border); border-radius:999px; padding:6px 10px; }
.muted { color:var(--muted); font-size:13px; }
.chips { display:flex; gap:8px; flex-wrap:wrap; margin-top:8px; }
.chip { background:#111827; border:1px solid var(--border); border-radius:999px; padding:6px 10px; display:inline-flex; align-items:center; gap:8px; }
.chip button { background:#1f2937; border:1px solid var(--border); border-radius:8px; color:var(--text); padding:2px 6px; font-size:12px; }
.add-cat input { min-width:260px; }
.card { border:1px solid var(--border); border-radius:12px; padding:12px; background:#0b1126; margin:8px 0; }
.card h4 { margin:0 0 8px 0; }
.card .task-row { display:flex; gap:8px; align-items:center; margin:6px 0; }
.card .task-row .status { color:var(--muted); font-size:12px; }
.card input { background:#111827; border:1px solid var(--border); border-radius:10px; padding:8px 10px; color:#e5e7eb; flex:1; }
.card button { background:#111827; border:1px solid var(--border); border-radius:10px; padding:6px 10px; color:#e5e7eb; }
button.primary { background:var(--accent); color:#fff; border-color:#9d174d; }
button.danger { background:var(--danger); color:#fff; border-color:#7f1d1d; }
button:disabled { opacity:.5; pointer-events:none; }
.won { margin-top:12px; padding-top:8px; border-top:1px dashed var(--border); }
#wheel1 svg, #wheel2 svg { max-width: 100%; height: auto; }
.deadline { font-size:12px; color:#eab308; } /* amber */
.overdue { color:#f87171; font-weight:700; } /* red */
.rew { border:1px solid var(--border); border-radius:12px; padding:12px; background:#0b1126; margin:8px 0; }
.rew h4 { margin:0 0 6px 0; }
.rew input { background:#111827; border:1px solid var(--border); border-radius:10px; padding:8px 10px; color:#e5e7eb; width:100%; }
.rew .row { margin-top:8px; }
.scores { display:flex; align-items:center; gap:10px; }
.scores span { padding:4px 8px; border:1px solid var(--border); border-radius:10px; background:#111827; }
