:root{--bg0: #0b0e1a;--bg1: #141a2e;--ink: #eef1ff;--muted: #97a0c4;--panel: #1a2138;--line: #2b3458;--gold: #e8c15a;--moon: #cfe0ff;--good: #4dabf7;--evil: #ff5d6c;--accent: #8b6cff}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;height:100%}body{font-family:Nunito,system-ui,sans-serif;color:var(--ink);background:radial-gradient(120% 80% at 50% -10%,#2a2350 0%,var(--bg1) 45%,var(--bg0) 100%);min-height:100%}#app{min-height:100dvh}.screen.center{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:16px}.card{width:100%;max-width:440px;background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:24px;text-align:center;box-shadow:0 20px 60px #00000073}.card.wide{max-width:520px}.brand{font-family:Cinzel,serif;font-weight:800;font-size:2.4rem;letter-spacing:4px;color:var(--gold)}.brand.small{font-size:1.4rem;letter-spacing:3px}.tag{color:var(--muted);font-weight:700;margin:8px 0 14px}.lbl{display:block;text-align:left;font-weight:800;font-size:.75rem;color:var(--muted);margin:12px 0 6px;text-transform:uppercase;letter-spacing:.5px}.field{width:100%;padding:13px 15px;font:inherit;font-weight:700;border:2px solid var(--line);border-radius:13px;background:#0f1424;color:var(--ink)}.field.mini{width:80px}.field:focus{outline:none;border-color:var(--accent)}.btn{font:inherit;font-weight:800;padding:12px 18px;border-radius:14px;border:none;cursor:pointer;background:var(--accent);color:#fff;box-shadow:0 4px #5b43c4;transition:transform .05s,box-shadow .05s}.btn:active{transform:translateY(3px);box-shadow:0 1px #5b43c4}.btn.big{width:100%;margin-top:14px;font-size:1.1rem;padding:15px}.btn.ghost{background:#232b46;color:var(--ink);box-shadow:0 4px #161c30}.btn.ghost:active{box-shadow:0 1px #161c30}.btn.small{padding:8px 14px;font-size:.85rem}.or{margin:14px 0 10px;color:var(--muted);font-weight:700;font-size:.85rem}.row{display:flex;gap:10px}.row.center{justify-content:center;margin-top:16px}.row.wrap{flex-wrap:wrap}.row .field{flex:1}.foot{margin-top:14px;color:var(--muted);font-weight:700;font-size:.78rem}.code{font-family:Cinzel,serif;font-weight:800;font-size:2rem;letter-spacing:8px;color:var(--gold);background:#0f1424;border-radius:14px;padding:10px;margin:6px 0 12px}.players{display:flex;flex-direction:column;gap:7px;margin:12px 0}.player{display:flex;align-items:center;gap:10px;background:#0f1424;border-radius:12px;padding:9px 13px;font-weight:800;text-align:left}.player .host{margin-left:auto;color:var(--gold);font-size:.8rem}.pa{font-size:1.3rem}.config{background:#0f1424;border-radius:14px;padding:12px;margin:8px 0}.role-toggles{display:flex;gap:8px;flex-wrap:wrap}.chip{padding:8px 13px;border-radius:999px;border:2px solid var(--line);background:#161d33;font:inherit;font-weight:800;color:var(--muted);cursor:pointer}.chip.on{background:var(--accent);border-color:var(--accent);color:#fff}.hint{color:var(--muted);font-weight:700;text-align:center;padding:6px 0}.screen.stage{min-height:100dvh;display:flex;flex-direction:column}.banner{position:relative;height:30dvh;min-height:160px;overflow:hidden}.banner-img{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.62);transition:background-image .4s}.banner:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,var(--bg0))}.banner-txt{position:absolute;left:0;right:0;bottom:10px;text-align:center;z-index:1;padding:0 14px}.phase-title{font-family:Cinzel,serif;font-weight:800;font-size:1.5rem;color:var(--moon);text-shadow:0 2px 12px #000}.phase-text{color:#dfe6ff;font-weight:700;text-shadow:0 1px 8px #000}.day-badge{position:absolute;top:10px;left:12px;z-index:1;background:#0006;padding:5px 11px;border-radius:999px;font-weight:800;font-size:.8rem}.mute{position:absolute;top:10px;right:12px;z-index:1;background:#0006;border:none;color:#fff;font-size:1.1rem;width:38px;height:38px;border-radius:50%;cursor:pointer}.village{flex:1 1 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:10px;padding:14px;align-content:start;overflow-y:auto}.pcard{background:var(--panel);border:2px solid var(--line);border-radius:16px;padding:12px 6px;text-align:center;transition:transform .08s}.pcard.me{border-color:var(--gold)}.pcard.dead{opacity:.42}.pcard.target{cursor:pointer;border-color:var(--accent);box-shadow:0 0 0 3px #8b6cff40}.pcard.target:active{transform:scale(.96)}.pcard.sel{background:#2b2350;border-color:var(--gold)}.pc-ava{font-size:1.8rem}.pc-name{font-weight:800;font-size:.82rem;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pc-role{font-size:.72rem;color:var(--gold);font-weight:800}.pc-votes{font-size:.72rem;color:var(--moon);font-weight:800}.panel{flex:0 0 auto;background:var(--panel);border-top:1px solid var(--line);padding:14px;max-height:42dvh;overflow-y:auto}.rolecard{display:flex;gap:12px;align-items:center;background:#0f1424;border:2px solid var(--line);border-radius:16px;padding:10px;margin-bottom:10px}.rolecard.evil{border-color:var(--evil)}.rolecard.good{border-color:var(--good)}.rc-img{width:64px;height:64px;border-radius:12px;background-size:cover;background-position:center;flex:0 0 auto}.rc-body{text-align:left}.rc-name{font-family:Cinzel,serif;font-weight:800;font-size:1.15rem}.rc-desc{color:var(--muted);font-weight:700;font-size:.85rem}.rc-lover{color:var(--evil);font-weight:800;font-size:.85rem;margin-top:3px}.nar-title{font-family:Cinzel,serif;font-weight:800;color:var(--gold);text-align:center;margin-bottom:8px}.nar-log{background:#0f1424;border-radius:12px;padding:10px;font-size:.85rem;color:var(--muted);font-weight:700;max-height:22dvh;overflow-y:auto;margin-bottom:10px}.nar-log div{padding:2px 0}.finish-banner{text-align:center;font-family:Cinzel,serif;font-weight:800;font-size:1.2rem;padding:14px;border-radius:14px}.finish-banner.good{color:var(--good)}.finish-banner.evil{color:var(--evil)}.toast{position:fixed;top:16px;left:50%;transform:translate(-50%);background:var(--gold);color:#1a1400;font-weight:800;padding:10px 18px;border-radius:999px;box-shadow:0 8px 24px #0006;z-index:50;max-width:90vw;text-align:center}
