: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;background:linear-gradient(#0b0e1abd,#0b0e1ae6),url(../assets/images/scene_menu.png) center/cover no-repeat}.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}.chip.evil{border-color:#5a2230}.chip.evil.on{background:var(--evil);border-color:var(--evil);color:#2a0008}.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}.timer-bar{position:absolute;left:0;bottom:0;height:4px;width:100%;z-index:2;background:linear-gradient(90deg,var(--gold),var(--accent));transform-origin:left}.timer-bar.hidden{opacity:0}.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}.journal{background:#0f1424;border:1px solid var(--line);border-radius:14px;padding:10px 12px;margin-top:10px}.journal-title{font-weight:800;font-size:.78rem;color:var(--gold);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.journal-item{font-weight:700;font-size:.86rem;color:#dfe6ff;padding:3px 0;border-top:1px solid #1b2238}.journal-item:first-of-type{border-top:none}.phase-intro{position:fixed;inset:0;z-index:60;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;cursor:pointer;background-size:cover;background-position:center}.phase-intro:before{content:"";position:absolute;inset:0;background:linear-gradient(#0b0e1a80,#0b0e1ad1)}.phase-intro>*{position:relative;z-index:1}.pi-title{font-family:Cinzel,serif;font-weight:800;font-size:2rem;color:var(--moon);text-shadow:0 2px 16px #000}.pi-text{color:#dfe6ff;font-weight:700;margin-top:8px;text-shadow:0 1px 8px #000;max-width:30ch}.phase-intro.in{animation:piIn .5s ease both}.phase-intro.out{animation:piOut .4s ease both}@keyframes piIn{0%{opacity:0;transform:scale(1.06)}to{opacity:1;transform:scale(1)}}@keyframes piOut{0%{opacity:1}to{opacity:0}}.pcard.dying{animation:dieShake .7s ease both;z-index:1}@keyframes dieShake{0%,to{transform:translate(0)}12%{transform:translate(-5px) rotate(-2deg)}26%{transform:translate(5px) rotate(2deg)}42%{transform:translate(-4px)}60%{transform:translate(3px)}80%{transform:translate(-1px);filter:grayscale(1) brightness(.65)}}.rolecard.reveal{animation:cardReveal .6s cubic-bezier(.2,.8,.2,1) both}@keyframes cardReveal{0%{opacity:0;transform:perspective(700px) rotateX(26deg) translateY(12px) scale(.96)}to{opacity:1;transform:none}}.banner-img{animation:kenburns 20s ease-in-out infinite alternate}@keyframes kenburns{0%{transform:scale(1)}to{transform:scale(1.08)}}@media(prefers-reduced-motion:reduce){.phase-intro.in,.phase-intro.out,.pcard.dying,.rolecard.reveal,.banner-img{animation:none!important}.timer-bar{transition:none!important}}:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:6px}.btn.small{min-height:40px}.card.scroll{max-height:86dvh;overflow-y:auto;text-align:left}.card.scroll .brand,.card.scroll>.tag{text-align:center;display:block}.rules-sec{background:#0f1424;border:1px solid var(--line);border-radius:12px;padding:10px 12px;margin:8px 0}.rs-t{font-weight:800;color:var(--moon)}.rs-d{color:var(--muted);font-weight:700;font-size:.9rem;margin-top:3px}.rc-goal{color:var(--gold);font-weight:800;font-size:.82rem;margin-top:4px}.codex{display:flex;flex-direction:column;gap:8px;margin:10px 0}.codex-tile{display:flex;gap:10px;align-items:center;background:#0f1424;border:2px solid var(--line);border-radius:14px;padding:8px}.codex-tile.evil{border-color:var(--evil)}.codex-tile.good{border-color:var(--good)}.ct-img{width:56px;height:56px;border-radius:10px;background-size:cover;background-position:center;flex:0 0 auto}.ct-name{font-family:Cinzel,serif;font-weight:800}.ct-desc{color:var(--muted);font-weight:700;font-size:.82rem}.presets{display:flex;gap:6px;flex-wrap:wrap}.presets .chip{background:#161d33}.field.mini2{width:auto;padding:9px 11px}.pc-roleimg{width:100%;height:30px;border-radius:8px;background-size:cover;background-position:center 22%;margin:4px 0 2px}
