:root{--bg: #0f1226;--panel: #1a1f3d;--panel-2: #232a52;--line: #313a6b;--text: #e8ecff;--muted: #9aa3cc;--primary: #5b7cfa;--danger: #e74c3c;--ok: #2ecc71}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,PingFang SC,Microsoft YaHei,system-ui,sans-serif;background:radial-gradient(1200px 600px at 50% -10%,#20264f,var(--bg));color:var(--text);min-height:100vh}.app{max-width:1100px;margin:0 auto;padding:16px}.app.wide{max-width:1600px;padding:12px 20px}.ad-slot{margin-top:18px;min-height:70px;border-radius:12px;display:flex;align-items:center;justify-content:center;gap:10px;border:1px dashed var(--line);background:#ffffff05;color:var(--muted)}.ad-slot.filled{border:none;padding:0;overflow:hidden}.ad-tag{font-size:11px;font-weight:700;color:#11152e;background:var(--muted);padding:2px 8px;border-radius:6px}.ad-text{font-size:13px}.ad-img{width:100%;height:auto;display:block}.topbar{display:flex;align-items:center;gap:16px;padding:8px 4px 16px}.logo{font-size:20px;font-weight:700}.conn{font-size:13px;padding:2px 10px;border-radius:999px}.conn.on{background:#2ecc7126;color:var(--ok)}.conn.off{background:#e74c3c26;color:var(--danger)}.spacer{margin-left:auto}.room-code{font-size:14px;color:var(--muted)}.mute-btn{flex:none;width:36px;padding:6px 0;font-size:16px;border-radius:8px;background:var(--panel-2);border:1px solid var(--line);cursor:pointer}.notice{padding:10px 14px;border-radius:10px;margin-bottom:12px;font-size:14px}.notice.info{background:#5b7cfa26;color:#b9c6ff}.notice.error{background:#e74c3c26;color:#ffb4ab}.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:0 10px 40px #0000004d}.lobby{max-width:420px;margin:40px auto}.lobby h1{margin:0 0 4px;font-size:24px}.subtitle{color:var(--muted);margin:0 0 20px;font-size:14px}label{display:block;font-size:13px;color:var(--muted);margin-bottom:14px}input{width:100%;margin-top:6px;padding:11px 12px;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;color:var(--text);font-size:15px;outline:none}input:focus{border-color:var(--primary)}.lobby-actions{display:flex;gap:10px}.divider{text-align:center;color:var(--muted);margin:16px 0;font-size:13px;position:relative}button{flex:1;padding:11px 16px;border-radius:10px;cursor:pointer;border:1px solid var(--line);background:var(--panel-2);color:var(--text);font-size:15px;transition:.15s}button:hover:not(:disabled){border-color:var(--primary)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}button.big{width:100%;margin-top:18px;padding:14px}.roleselect{max-width:640px;margin:24px auto}.roleselect h2{margin-top:0}.hint{color:var(--muted);font-size:14px}.role-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:16px 0}.role-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:22px 16px;border-radius:14px;position:relative;text-align:center}.role-card.mine{border-color:var(--primary);background:#5b7cfa1f}.role-card.taken{opacity:.45}.role-icon{font-size:40px}.role-name{font-size:18px;font-weight:700}.role-desc{font-size:12px;color:var(--muted)}.badge{position:absolute;top:8px;right:8px;font-size:11px;background:var(--primary);color:#fff;padding:2px 8px;border-radius:999px}.badge.taken{background:var(--muted)}.players-status{display:flex;gap:12px;justify-content:center;margin-top:8px}.player-chip{font-size:13px;color:var(--muted)}.dev-bar{position:fixed;left:14px;bottom:14px;z-index:9999;display:flex;align-items:center;gap:10px;background:#141028eb;border:1px solid #6b4fd8;border-radius:12px;padding:8px 12px;box-shadow:0 8px 24px #0006}.dev-btn{flex:none;padding:8px 14px;font-size:14px;font-weight:700;background:#6b4fd8;border:1px solid #6b4fd8;color:#fff;border-radius:8px}.dev-btn:hover:not(:disabled){background:#7d63e6}.dev-desc{font-size:12px;color:#c9bfff;max-width:240px}.game{display:grid;grid-template-columns:minmax(0,1fr) 172px 300px;gap:16px;align-items:start}@media(max-width:1180px){.game{grid-template-columns:minmax(0,1fr) 300px}.game .kill-track{display:none}}.turn-banner{display:flex;gap:10px;margin-bottom:12px}.round-pill,.turn-pill{padding:7px 16px;border-radius:999px;font-weight:700;font-size:14px}.round-pill{background:var(--panel-2);border:1px solid var(--line);color:var(--text)}.turn-pill{background:linear-gradient(135deg,#5b7cfa,#7c5bfa);color:#fff}.board{display:grid;gap:10px}.cell{background:linear-gradient(180deg,#1c2244,#171c38);border:1px solid var(--line);border-radius:12px;min-height:168px;padding:10px;display:flex;flex-direction:column;gap:8px}.cell.has-car{border-color:#5b7cfa;box-shadow:0 0 0 1px #5b7cfa inset}.cell.blocked{background:linear-gradient(180deg,#2a1620,#1d1018);border-color:#7a2233}.blocked-tag{font-size:10px;font-weight:800;color:#fff;background:#c0392b;padding:1px 6px;border-radius:5px}.cell.evac-target{cursor:pointer;border-color:#2ecc71;box-shadow:0 0 0 2px #2ecc71 inset,0 0 12px #2ecc7159}.cell.evac-target:hover{background:#2ecc711f}.cell.move-target{cursor:pointer;border-color:#5b7cfa;box-shadow:0 0 0 2px #5b7cfa inset,0 0 12px #5b7cfa59}.cell.move-target:hover{background:#5b7cfa1f}.evac-hint{font-size:12px;color:#7cffb0;margin:8px 0 0}.cell-head{display:flex;align-items:center;gap:6px;min-height:20px}.district{font-size:12px;color:var(--muted);font-weight:600}.building{margin-left:auto;font-size:11px;font-weight:700;color:#fff;padding:1px 7px;border-radius:6px;white-space:nowrap}.car{font-size:16px}.occupants{display:flex;flex-wrap:wrap;gap:8px;flex:1;justify-content:center;align-content:center}.cz-card{position:relative;width:86px;border:2px solid #888;border-radius:8px;background:#11152e;overflow:hidden;display:flex;flex-direction:column;align-items:center;padding-bottom:3px}.cz-card.threatened{filter:grayscale(.85) brightness(.7)}.cz-faction{width:100%;font-size:10px;font-weight:700;color:#fff;text-align:center;padding:1px 0;text-shadow:0 1px 1px rgba(0,0,0,.4);line-height:1.4}.cz-portrait{width:100%;height:68px;object-fit:cover;display:block}.cz-portrait.placeholder{display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:800;color:#fff}.cz-name{font-size:13px;font-weight:700;margin-top:3px}.cz-attrs{display:flex;gap:4px;margin-top:4px;margin-bottom:2px}.cz-attr{font-size:11px;font-weight:700;color:#cfd6ff;background:#ffffff1a;border-radius:4px;padding:1px 4px;min-width:16px;text-align:center}.cz-tag{position:absolute;top:16px;left:50%;transform:translate(-50%) rotate(-8deg);font-size:10px;font-weight:800;padding:1px 6px;border-radius:4px;color:#fff}.cz-tag.threat{background:#282828e6;border:1px solid #777}.cz-tag.bug{background:#d35400;top:32px}.legend{margin-top:12px;font-size:12px;color:var(--muted);background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:8px 12px}.sidebar{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;position:sticky;top:12px}.side-title{margin:0 0 14px;font-size:17px}.secret{background:#e74c3c14;border:1px solid rgba(231,76,60,.3);border-radius:10px;padding:14px}.secret-title{color:#ffb4ab;font-size:13px;margin:0 0 10px;font-weight:700}.secret ul{margin:0;padding-left:18px;font-size:14px;line-height:1.9}.secret-foot{color:var(--muted);font-size:12px;margin:10px 0 0}.detective-panel{font-size:14px}.points{display:flex;gap:10px}.point-box{flex:1;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:12px;text-align:center;display:flex;flex-direction:column;gap:2px}.point-box .pv{font-size:26px;font-weight:800;color:#7c9bff}.point-box .pl{font-size:12px;color:var(--muted)}.factions{margin-top:20px}.factions h4{margin:0 0 10px;color:var(--muted);font-size:13px}.faction-tags{display:flex;flex-wrap:wrap;gap:6px}.faction-tag{display:inline-flex;align-items:center;gap:5px;font-size:12px;background:var(--panel-2);border:1px solid var(--line);border-radius:999px;padding:3px 10px 3px 6px}.faction-tag i{width:10px;height:10px;border-radius:50%;display:inline-block}.faction-tag.revealed{border-color:#2ecc71}.faction-tag.revealed em{font-style:normal;color:#2ecc71;font-size:10px;margin-left:2px}.faction-tag.supported{border-color:#ffd24a}.faction-tag em.sup{font-style:normal;color:#ffd24a;font-size:10px;margin-left:2px}.faction-tag em.board{font-style:normal;color:var(--muted);font-size:10px;margin-left:2px}.faction-hint{font-size:11px;color:var(--muted);margin:0 0 8px;line-height:1.5}.cz-card.selectable{cursor:pointer}.cz-card.selectable:hover{transform:translateY(-2px);box-shadow:0 6px 14px #0006}.cz-card.selected{box-shadow:0 0 0 2px #ffd24a,0 0 14px #ffd24a80}.cz-card.dimmed{opacity:.35;filter:grayscale(.6)}.cz-badge{position:absolute;top:1px;right:1px;font-size:9px;font-weight:800;background:#000000a6;color:#ffd24a;padding:0 4px;border-radius:4px}.crime-card{position:relative;width:62px;height:92px;border:2px solid #c0392b;border-radius:8px;display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(45deg,#1a1020,#1a1020 6px,#211222 6px,#211222 12px);overflow:hidden}.crime-art{width:100%;height:100%;object-fit:cover}.crime-outline{width:34px;height:48px;opacity:.9}.crime-no{position:absolute;top:3px;right:3px;font-size:12px;font-weight:800;color:#fff;background:#c0392b;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}.action-box{margin-top:14px;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:14px}.action-step{margin:0 0 6px;font-weight:800;color:#ffd24a;font-size:14px}.action-desc{margin:0 0 12px;font-size:13px;color:var(--text);line-height:1.6}.action-box.waiting{color:var(--muted);font-size:14px;text-align:center}.undo-move{width:100%;margin:0 0 10px;padding:8px;font-size:13px;font-weight:600;background:var(--panel);border:1px solid #5b7cfa;color:#9fb4ff}.undo-move:hover:not(:disabled){background:#5b7cfa26}button.danger{width:100%;background:#c0392b;border-color:#c0392b;color:#fff;font-weight:700}button.danger:hover:not(:disabled){background:#e74c3c}.action-box .primary{width:100%}.motive-text{color:#ffd24a}.kill-track{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:12px 10px;position:sticky;top:12px;display:flex;flex-direction:column;gap:8px}.kt-title{font-size:13px;color:#ffb4ab;margin:0 0 2px;font-weight:800;text-align:center}.kt-sub{font-size:11px;color:var(--muted);margin:0 0 6px;text-align:center;line-height:1.4}.kt-slot{display:flex;flex-direction:column;align-items:center;gap:5px;border:1px solid var(--line);border-radius:10px;padding:8px 6px;background:#c0392b0f;position:relative;min-height:46px;justify-content:center}.kt-slot.filled{background:#c0392b1f;border-color:#7a2233}.kt-no{position:absolute;top:4px;left:4px;width:20px;height:20px;border-radius:50%;background:#c0392b;color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center}.kt-empty{font-size:11px;color:var(--muted)}.kt-status{font-size:10px;font-weight:700;color:var(--muted)}.kt-status.threat{color:#ddd;background:#444;border-radius:4px;padding:0 5px}.victims{margin-top:18px}.victims h4{margin:0 0 10px;color:#ffb4ab;font-size:13px}.victim-list{display:flex;flex-wrap:wrap;gap:12px}.victim{display:flex;flex-direction:column;align-items:center;gap:4px}.victim-round{font-size:11px;font-weight:700;color:var(--muted)}.victim-status{font-size:10px;font-weight:700;color:var(--muted);background:var(--panel-2);border-radius:4px;padding:1px 6px}.victim-status.threat{color:#ddd;background:#444}.victims-hint{font-size:12px;color:var(--muted);margin:10px 0 0}.ask-box{margin-top:12px;border-top:1px solid var(--line);padding-top:12px}.ask-title{font-size:13px;font-weight:700;margin:0 0 8px;color:#9fd3ff}.qopts{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.qgroup{display:flex;flex-wrap:wrap;align-items:center;gap:5px}.qgroup-label{font-size:12px;color:var(--muted);width:32px;flex-shrink:0}.qchip{flex:none;font-size:12px;padding:3px 9px;border-radius:999px;background:var(--panel-2);border:1px solid var(--line);color:var(--text)}.qchip.on{background:#5b7cfa;border-color:#5b7cfa;color:#fff;font-weight:700}.ask-box .primary{width:100%}.endturn{width:100%;margin-top:14px;padding:12px;font-weight:700;background:#2e3a6b;border-color:#3a4a8b;color:#dbe2ff}.endturn:hover:not(:disabled){background:#3a4a8b}.result-box{background:linear-gradient(160deg,#20264f,#2a1630);border:1px solid #5b7cfa;border-radius:12px;padding:16px;margin-bottom:14px}.result-winner{font-size:22px;font-weight:800;margin:0 0 12px;text-align:center}.result-winner.detective{color:#7c9bff}.result-winner.killer{color:#ff6b6b}.reveal{font-size:14px;line-height:1.8}.reveal p{margin:0}.reveal .acc{margin-top:8px;padding-top:8px;border-top:1px solid var(--line);color:var(--muted);font-size:13px}.accuse-box{border:1px solid #c0392b}.accuse-label{font-size:12px;color:var(--muted);margin:10px 0 6px;font-weight:700}.accuse-box .danger{width:100%;margin-top:12px}.bld-box{margin-top:12px;border-top:1px solid var(--line);padding-top:12px}.bld-title{font-size:13px;font-weight:800;margin:0 0 8px}.bld-box.waiting{color:var(--muted);font-size:13px;text-align:center}.pick-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.pick-list.scroll{max-height:132px;overflow-y:auto}.pick{flex:none;font-size:12px;padding:4px 10px;border-radius:999px;background:var(--panel-2);border:1px solid var(--line);color:var(--text)}.pick.on{background:#5b7cfa;border-color:#5b7cfa;color:#fff;font-weight:700}.bld-box .primary{width:100%}.answer-panel{border:1px solid #5b7cfa}.answer-list{display:flex;flex-direction:column;gap:6px;margin:6px 0 12px}.answer-row{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:6px 10px}.ar-name{font-size:13px;font-weight:700}.ar-controls{display:flex;gap:6px}.ans-btn{flex:none;font-size:12px;padding:3px 8px;border-radius:6px;background:var(--panel-2);border:1px solid var(--line);color:var(--text)}.ans-btn.on{background:#2ecc71;border-color:#2ecc71;color:#08231a;font-weight:700}.ans-btn.lie.on{background:#e74c3c;border-color:#e74c3c;color:#fff}.ar-locked{font-size:12px;color:var(--muted)}.answer-panel .primary{width:100%}.qlog{margin-top:18px}.qlog h4{margin:0 0 8px;color:var(--muted);font-size:13px}.qlog-item{background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:8px 10px;margin-bottom:6px}.qlog-q{font-size:12px;font-weight:700;margin-bottom:5px}.qlog-a{display:flex;flex-wrap:wrap;gap:5px}.qa{font-size:11px;padding:1px 7px;border-radius:999px}.qa.yes{background:#2ecc712e;color:#8fe9b6}.qa.no{background:#e74c3c2e;color:#ffb4ab}.qa.lied{outline:1px solid #ffd24a;color:#ffd24a;font-weight:700}.faction-draw-list{display:flex;flex-direction:column;gap:5px}.fd-item{display:flex;align-items:center;gap:6px;font-size:12px;background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:5px 9px}.fd-name{font-weight:800}.fd-removed{font-size:10px;color:#ffb4ab;background:#e74c3c26;border-radius:4px;padding:1px 5px}.motives{margin-top:18px}.motives h4{margin:0 0 8px;color:var(--muted);font-size:13px}.motive-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.motive-list li{font-size:13px;background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:7px 10px;position:relative}.motive-list li.mine{border-color:#ffd24a;background:#ffd24a1a}.mine-tag{position:absolute;right:8px;top:7px;font-size:11px;font-weight:800;color:#11152e;background:#ffd24a;padding:0 6px;border-radius:4px}@media(max-width:820px){.game{grid-template-columns:1fr}.sidebar{position:static}}
