:root{--bg: #0d0b14;--bg-2: #161226;--panel: #1d1830;--panel-2: #272040;--text: #ece8f5;--muted: #9b93b8;--accent: #b455ff;--accent-2: #7c3aed;--danger: #ef4444;--ok: #34d399;--gold: #f4c542;--border: #2e2747;--radius: 14px;--shadow: 0 6px 24px rgba(0, 0, 0, .4)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;min-height:100%;height:100%}body{background:radial-gradient(1200px 800px at 50% -10%,#1b1430 0%,var(--bg) 60%);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:17px;line-height:1.45}#root{display:flex;justify-content:center}.app{width:100%;max-width:560px;padding:env(safe-area-inset-top) 16px 32px;display:flex;flex-direction:column;min-height:100%}h1,h2,h3{margin:.2em 0;font-weight:700}h1{font-size:1.7rem}.muted{color:var(--muted)}.center{text-align:center}.spacer{flex:1}.brand{text-align:center;padding:20px 0 8px;letter-spacing:.06em}.brand .moon{font-size:2.4rem}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin:12px 0;box-shadow:var(--shadow)}.field{margin:14px 0;display:flex;flex-direction:column;gap:6px}label{color:var(--muted);font-size:.9rem}input,select{width:100%;padding:14px;border-radius:12px;border:1px solid var(--border);background:var(--bg-2);color:var(--text);font-size:1.05rem}input:focus,select:focus{outline:2px solid var(--accent-2);border-color:var(--accent)}button{font:inherit;cursor:pointer;border:none;border-radius:12px;padding:15px 18px;background:var(--panel-2);color:var(--text);transition:transform .05s ease,filter .15s ease}button:active{transform:scale(.98)}button:disabled{opacity:.45;cursor:default}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));font-weight:700;width:100%}.btn-block{width:100%}.btn-ghost{background:transparent;border:1px solid var(--border)}.btn-danger{background:var(--danger);font-weight:700}.btn-row{display:flex;gap:10px}.btn-row>button{flex:1}.toggle{display:flex;gap:8px}.toggle button{flex:1;border:1px solid var(--border);background:var(--bg-2)}.toggle button.on{background:var(--accent-2);border-color:var(--accent);font-weight:700}.error{background:#ef444426;border:1px solid var(--danger);color:#ffd7d7;padding:10px 14px;border-radius:10px;margin:10px 0}.pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.8rem;background:var(--panel-2);color:var(--muted)}.pill.alive{background:#34d39926;color:var(--ok)}.pill.dead{background:#ef444426;color:#ffb4b4}.pill.wolf{background:#ef444433;color:#ff9a9a}.pill.village{background:#7c3aed33;color:#d3b8ff}.pill.neutral{background:#f4c5422e;color:var(--gold)}.roster{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.roster li{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-2);border-radius:10px;border:1px solid var(--border)}.roster li.dimmed{opacity:.5}.choices{display:flex;flex-direction:column;gap:10px;margin-top:8px}.choices button{text-align:left;background:var(--bg-2);border:1px solid var(--border)}.choices button.selected{border-color:var(--accent);background:var(--panel-2)}.progress{height:10px;background:var(--bg-2);border-radius:999px;overflow:hidden;border:1px solid var(--border)}.progress>div{height:100%;background:linear-gradient(90deg,var(--accent-2),var(--accent));transition:width .3s ease}.rolecard{text-align:center;padding:28px 18px}.rolecard .emblem{font-size:3.4rem}.rolecard .rolename{font-size:2rem;margin:6px 0}.qr{background:#fff;padding:14px;border-radius:12px;display:inline-block}.roomcode{font-size:2rem;font-weight:800;letter-spacing:.12em;color:var(--gold)}.fade-in{animation:fade .5s ease}@keyframes fade{0%{opacity:0;transform:translateY(8px)}to{opacity:1}}.announce{text-align:center;font-size:1.2rem;padding:22px 16px}.banner{text-align:center;padding:30px 16px;border-radius:var(--radius)}.banner.village{background:linear-gradient(135deg,#3b2a6b,#7c3aed)}.banner.werewolf{background:linear-gradient(135deg,#5b1d1d,#b91c1c)}.reveal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#05040a;text-align:center;padding:24px}.reveal-overlay.animated{animation:revealBg 3.4s ease forwards}.reveal-inner{max-width:480px}.reveal-overlay.animated .reveal-inner{animation:revealPop 3.4s ease forwards}.reveal-title{font-size:1.4rem;color:var(--muted);letter-spacing:.04em}.reveal-names{font-size:2.4rem;font-weight:800;margin:14px 0;color:var(--text)}.reveal-win{font-size:1.5rem;font-weight:700;color:var(--gold);margin-top:10px}.reveal-skip{margin-top:28px;font-size:.85rem}.reveal-overlay.kind-death{background:radial-gradient(circle at 50% 40%,#2a0d0d,#05040a 70%)}.reveal-overlay.kind-win{background:radial-gradient(circle at 50% 40%,#1c1340,#05040a 70%)}@keyframes revealBg{0%{opacity:0}10%{opacity:1}90%{opacity:1}to{opacity:0}}@keyframes revealPop{0%,22%{opacity:0;transform:scale(.9);filter:blur(8px)}38%{opacity:1;transform:scale(1);filter:blur(0)}90%{opacity:1}to{opacity:0}}.mg-field{position:relative;height:200px;background:radial-gradient(circle at 50% 60%,#1a1530,#0d0b14);border-radius:12px;border:1px solid var(--border);overflow:hidden;margin-top:8px}.mg-firefly{position:absolute;background:transparent;border:none;color:var(--gold);font-size:1.8rem;padding:6px;filter:drop-shadow(0 0 8px var(--gold));transition:opacity .2s ease}.mg-flame{font-size:3rem;text-align:center;transition:transform .1s ease}.mg-runes{display:flex;gap:10px;justify-content:center;margin-top:10px}.mg-rune{width:56px;height:56px;border-radius:50%;border:2px solid var(--border);background:var(--bg-2);font-size:1.3rem;font-weight:700}.mg-rune.lit{border-color:var(--accent);background:var(--accent-2);color:#fff}.settings-panel{position:absolute;right:12px;top:44px;z-index:40;width:240px}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal-overlay{background:#05040a}}.statusbar{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--muted);padding:6px 2px}.dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:5px}.dot.on{background:var(--ok)}.dot.off{background:var(--danger)}
