:root{--yellow: #ffc700;--yellow-dark: #e6a700;--ink: #1a1a1a;--muted: #6b6660;--bg: #faf8f3;--card: #ffffff;--line: #ece7df;--choco: #5c3a21}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--ink)}.app{max-width:1100px;margin:0 auto;padding:20px 18px 40px}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.topbar h1{font-size:28px;margin:0}.logo{background:var(--yellow);padding:2px 10px;border-radius:10px}.status{font-size:13px;font-weight:600;padding:4px 10px;border-radius:999px}.status.on{background:#e3f6ec;color:#1d7a4d}.status.off{background:#fde8e8;color:#b23b3b}.grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.wheel-card{grid-row:span 2}@media (max-width: 820px){.grid{grid-template-columns:1fr}.wheel-card{grid-row:auto}}.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:0 1px 3px #0000000a}.card h2{margin:0 0 14px;font-size:19px}.hint{color:var(--muted);font-size:14px;margin:6px 0}.wheel-card{display:flex;flex-direction:column;align-items:center}.wheel-stage{position:relative;width:360px;max-width:100%;margin:6px 0 18px}.wheel-canvas{width:100%;height:auto;display:block;filter:drop-shadow(0 6px 16px rgba(0,0,0,.12))}.wheel-pointer{position:absolute;top:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;border-top:24px solid var(--ink);z-index:2}.winner-banner{margin-top:16px;padding:12px 18px;border:2px solid var(--yellow);border-radius:12px;background:#fffdf3;font-size:17px}.btn{border:1px solid var(--line);background:#fff;border-radius:10px;padding:8px 14px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .05s,background .15s}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--yellow);border-color:var(--yellow-dark)}.btn-primary:hover:not(:disabled){background:var(--yellow-dark)}.btn-spin{font-size:18px;padding:12px 32px}.btn-ghost{background:transparent;color:var(--muted);border-color:transparent}.btn-ghost:hover{color:#b23b3b}.btn-round{width:34px;height:34px;padding:0;font-size:20px;line-height:1}.btn-plus{background:var(--choco);color:#fff;border-color:var(--choco)}.choco-list,.team-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.choco-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--line);border-radius:10px}.choco-rank{width:22px;color:var(--muted);font-weight:700}.choco-name{flex:1;font-weight:600}.choco-count{font-variant-numeric:tabular-nums;font-weight:700;min-width:56px;text-align:right}.choco-actions{display:flex;gap:6px}.dot{width:14px;height:14px;border-radius:50%;flex:none}.add-form{display:flex;gap:8px;margin-bottom:14px}.add-form input{flex:1;padding:9px 12px;border:1px solid var(--line);border-radius:10px;font-size:15px}.team-row{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border-radius:10px}.team-row:hover{background:#faf8f3}.team-toggle{display:flex;align-items:center;gap:9px;cursor:pointer;font-weight:600}.team-toggle .inactive{color:var(--muted);text-decoration:line-through}.foot{text-align:center;color:var(--muted);font-size:13px;margin-top:28px}.topbar-right{display:flex;align-items:center;gap:10px}.wheel-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px;width:100%}.wheel-head h2{margin:0}.btn-mini{padding:5px 10px;font-size:13px}.btn-sel{background:var(--yellow);border-color:var(--yellow-dark)}.role-filter{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}.role-filter select,.role-select{padding:5px 8px;border:1px solid var(--line);border-radius:8px;font-size:13px;background:#fff}.kbd-hint{margin-top:6px}.attendance{display:flex;flex-wrap:wrap;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 16px;margin-bottom:18px}.attendance-label{font-weight:700;font-size:14px;margin-right:4px}.att-chip{border:2px solid var(--line);background:#fff;border-radius:999px;padding:5px 12px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .05s}.att-chip:active{transform:scale(.95)}.att-chip.absent{opacity:.4;text-decoration:line-through}.recent{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:16px}.recent-label{font-size:13px;color:var(--muted)}.recent-chip{background:#f3efe6;border-radius:999px;padding:3px 10px;font-size:13px}.recent-chip:first-of-type{background:var(--yellow);font-weight:700}.timer-card{text-align:center}.timer-display{font-size:56px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:1px;margin:8px 0 14px}.timer-display.over{color:#b23b3b}.timer-controls{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.export-btns{display:flex;gap:6px}.team-row{gap:8px}.team-toggle{flex:1}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:100%;max-width:360px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:32px 28px;display:flex;flex-direction:column;gap:16px;box-shadow:0 8px 30px #0000000f}.login-card h1{margin:0;font-size:28px}.login-hint{margin:0;color:var(--muted);font-size:14px}.login-card input{padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-size:16px}.login-card input:focus{outline:none;border-color:var(--yellow-dark)}.login-error{color:#b23b3b;font-size:14px}
