:root{--bg: #0f1218;--surface: #1a1f2a;--border: #2a3344;--text: #e8ecf4;--muted: #8b95a8;--accent: #c45c5c;--accent-dim: #8b3a3a;--ok: #4a9d6f;--warn: #c9a227;font-family:Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.45;padding-bottom:env(safe-area-inset-bottom,0)}#app{max-width:1280px;margin:0 auto;padding:1rem max(1rem,env(safe-area-inset-left)) 2rem max(1rem,env(safe-area-inset-right));padding-bottom:max(2rem,env(safe-area-inset-bottom))}header.top{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border);margin-bottom:1rem}header.top h1{margin:0;font-size:1.35rem;font-weight:600;letter-spacing:.02em}.controls{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.controls label{display:flex;align-items:center;gap:.35rem;font-size:.875rem;color:var(--muted)}.controls label.seed-row{flex-wrap:wrap}.seed-random-btn{padding:.35rem .55rem;font-size:.8125rem;border-radius:6px;background:var(--surface-2, var(--surface));border:1px solid var(--border);color:var(--text)}input[type=number]{width:5.5rem;padding:.35rem .5rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text)}select{padding:.35rem .5rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:.875rem}button{cursor:pointer;border:none;border-radius:8px;padding:.45rem .85rem;font-size:.875rem;font-weight:500;background:var(--surface);color:var(--text);border:1px solid var(--border);transition:background .15s,border-color .15s}button:hover:not(:disabled){background:#242a38;border-color:#3d4a5f}button.primary{background:var(--accent-dim);border-color:var(--accent);color:#fff}button.primary:hover:not(:disabled){background:var(--accent)}button:disabled{opacity:.45;cursor:not-allowed}button:focus-visible{outline:2px solid var(--warn);outline-offset:2px}button.rules-open-btn{background:transparent;border-color:var(--muted);color:var(--muted)}button.rules-open-btn:hover:not(:disabled){color:var(--text);border-color:var(--warn);background:#c9a22714}.rules-dialog{margin:auto;padding:0;border:none;max-width:calc(100vw - 2rem);width:min(38rem,100%);background:transparent;color:inherit}.rules-dialog::backdrop{background:#0000008c}.rules-dialog__inner{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 40px #00000073;max-height:min(85vh,720px);display:flex;flex-direction:column}.rules-dialog__close{position:absolute;top:.5rem;right:.5rem;z-index:1;width:2.25rem;height:2.25rem;padding:0;line-height:1;font-size:1.35rem;border-radius:8px;min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center}.rules-dialog__title{margin:0;padding:1rem 2.75rem .5rem 1rem;font-size:1.15rem;font-weight:600;border-bottom:1px solid var(--border)}.rules-dialog__body{padding:.85rem 1rem 1rem;overflow-y:auto;flex:1;font-size:.875rem;color:var(--text)}.rules-dialog__body h3{margin:.85rem 0 .35rem;font-size:.95rem;font-weight:600;color:var(--warn)}.rules-dialog__body h3:first-of-type{margin-top:.35rem}.rules-dialog__body ul{margin:.25rem 0 0;padding-left:1.25rem;color:var(--muted)}.rules-dialog__body li{margin:.2rem 0}.rules-dialog__note{margin:0 0 .5rem;padding:.5rem .65rem;background:#c9a2271a;border-radius:8px;border:1px solid rgba(201,162,39,.25);color:var(--text);font-size:.8125rem}.rules-dialog__links{margin:1rem 0 0;font-size:.8125rem;line-height:1.5}.rules-dialog__links a{color:var(--ok)}.rules-dialog__links a:hover{text-decoration:underline}.rules-dialog__links code{font-size:.78rem}.rules-dialog__sep{color:var(--muted);margin:0 .35rem}.rules-dialog__footer{padding:.65rem 1rem 1rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.5rem}@media(prefers-reduced-motion:reduce){button{transition:none}}.layout{display:grid;grid-template-columns:minmax(220px,1fr) minmax(280px,1.2fr) minmax(240px,1fr);gap:1rem}@media(max-width:960px){.layout{display:flex;flex-direction:column;gap:1rem}.panel-game{order:1}.panel-actions{order:2}.panel-log{order:3}}@media(max-width:640px){input[type=text],input[type=number],select,textarea{font-size:1rem}button{font-size:1rem;min-height:44px;padding:.5rem .9rem}header.top h1{font-size:1.2rem;width:100%}.phase-strip,.player-card{font-size:.95rem}}.panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem;min-height:200px}.panel h2{margin:0 0 .65rem;font-size:.95rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.panel h2.panel-sub{margin-top:1rem}.panel h2.panel-sub{margin-top:1rem;margin-bottom:.4rem}.paste-json-label textarea{width:100%;min-height:5rem;padding:.45rem .55rem;border-radius:8px;border:1px solid var(--border);background:#12161e;color:var(--text);font-family:ui-monospace,monospace;font-size:.75rem;resize:vertical}.log{max-height:min(60vh,520px);overflow-y:auto;font-size:.875rem}.log-entry{padding:.35rem 0;border-bottom:1px solid var(--border);color:#c5cbd8}.log-entry:last-child{border-bottom:none}.badge{display:inline-block;font-size:.7rem;padding:.15rem .4rem;border-radius:4px;background:var(--border);color:var(--muted);margin-right:.35rem;vertical-align:middle}.phase-strip{font-size:.9rem;margin-bottom:.75rem;padding:.5rem .65rem;background:#12161e;border-radius:8px;border:1px solid var(--border)}.player-list{display:flex;flex-direction:column;gap:.5rem}.player-card{padding:.55rem .65rem;border-radius:8px;border:1px solid var(--border);background:#12161e;font-size:.82rem}.player-card.current{border-color:var(--warn);box-shadow:0 0 0 1px #c9a22740}.player-card.dead{opacity:.55}.player-card .name{font-weight:600;margin-bottom:.25rem}.traits{color:var(--muted);font-variant-numeric:tabular-nums}.room-grid{font-size:.8rem;color:var(--muted);margin-top:.5rem}.room-row{padding:.25rem 0;border-bottom:1px solid var(--border)}.card-spotlight{margin-top:.75rem;padding:.75rem;border-radius:8px;background:#12161e;border:1px solid var(--warn)}.card-spotlight h3{margin:0 0 .35rem;font-size:1rem}.card-spotlight p{margin:0;font-size:.875rem;color:#b8c0d0}.actions-grid{display:flex;flex-direction:column;gap:.45rem}.actions-grid .group-label{font-size:.75rem;color:var(--muted);margin-top:.35rem}.actions-grid .group-label:first-child{margin-top:0}.hint{font-size:.8rem;color:var(--muted);margin-top:.75rem;line-height:1.4}.gameover{margin-top:.75rem;padding:.65rem;border-radius:8px;background:#c45c5c26;border:1px solid var(--accent);font-weight:600}.scenario-box{margin-top:.65rem;padding:.65rem;font-size:.82rem;border-radius:8px;background:#12161e;border:1px solid var(--border);color:#b8c0d0}.monster-line{font-size:.82rem;color:var(--muted);margin-top:.5rem}.muted{color:var(--muted);font-size:.85rem}.map-main-column{max-width:min(100%,720px);margin-left:auto;margin-right:auto}.map-legend-summary{cursor:pointer;font-size:.8rem;color:var(--muted);-webkit-user-select:none;user-select:none;list-style:none}.map-legend-summary::-webkit-details-marker{display:none}.map-toolbar{margin-bottom:.5rem}.map-toolbar label{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--muted)}.map-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y;margin:0 auto;padding:0 .25rem;max-width:min(100%,52rem)}.map-legend-details{margin:0 0 .75rem;border:1px solid var(--border);border-radius:8px;padding:.35rem .5rem;background:var(--surface)}.map-legend-summary{cursor:pointer;font-size:.82rem;color:var(--muted);-webkit-user-select:none;user-select:none}.map-legend-details[open] .map-legend-summary{margin-bottom:.35rem}.ws-spectator-hint{margin:.35rem 0 0;max-width:40rem}.map-map-hint{margin-top:.5rem;margin-bottom:.35rem}.map-legend{list-style:none;margin:0 0 .75rem;padding:0;display:flex;flex-wrap:wrap;gap:.35rem 1rem;font-size:.78rem;color:var(--muted);line-height:1.35}.map-legend li{display:flex;align-items:center;gap:.35rem}.map-legend-swatch{display:inline-block;width:.65rem;height:.65rem;border-radius:3px;flex-shrink:0;border:1px solid var(--border)}.map-legend-swatch--acting{box-shadow:0 0 0 2px var(--warn);background:transparent}.map-legend-swatch--reach{background:#4a9d6f73;border-color:#4a9d6f}.map-legend-swatch--monster{background:#6b8cff66;border-color:#6b8cff}.map-legend-swatch--explore{background:transparent;border-color:var(--warn);border-width:2px}.map-legend-swatch--ghost{background:transparent;border:2px dashed #9b6bff}.map-map-empty{font-size:.85rem;margin:.25rem 0 .75rem}.floor-svg{display:block;max-width:100%;height:auto;background:#0c0e14;border-radius:10px;border:1px solid var(--border)}.floor-svg--thumb{border-radius:6px}.floor-svg--thumb .map-room-label,.floor-svg--thumb .map-pawn-label{font-size:7px}.map-thumbs{display:flex;flex-wrap:wrap;gap:.5rem;margin:.35rem 0 .65rem;align-items:flex-start}.map-thumb{flex:1 1 140px;min-width:min(100%,132px);max-width:200px;border:1px solid var(--border);border-radius:10px;padding:.35rem .45rem .5rem;background:var(--surface);cursor:pointer;min-height:44px;touch-action:manipulation}.map-thumb:focus-visible{outline:2px solid var(--warn);outline-offset:2px}.map-thumb--active{border-color:var(--ok);box-shadow:0 0 0 1px var(--ok)}.map-thumb-caption{display:block;font-size:.72rem;color:var(--muted);margin-bottom:.25rem}.map-thumb-inner{display:flex;align-items:center;justify-content:center;min-height:3.25rem}.map-thumb-empty{font-size:.78rem;color:var(--muted);text-align:center;padding:.35rem}.kick-seat-label{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--muted)}.ws-kick-btn{font-size:.8rem}.map-cell-empty{fill:none;stroke:#2f3a4d;stroke-dasharray:6 5;stroke-width:1}.map-room{fill:#1a2230;stroke:#3d4a5f;stroke-width:1.5}.map-room-reach{fill:#4a9d6f61;stroke:#4a9d6f;stroke-width:2}.map-room-reach-monster{fill:#6b8cff52;stroke:#6b8cff;stroke-width:2}.map-room-label{fill:var(--muted);font-size:11px;pointer-events:none}.map-acting-ring{fill:none;stroke:var(--warn);stroke-width:3}.map-door-open{stroke:var(--ok);stroke-width:5;stroke-linecap:round}.map-door-void{stroke:#5c677a;stroke-width:4;stroke-linecap:round;stroke-dasharray:5 4}.map-door-explore{stroke:var(--warn);stroke-width:5;stroke-linecap:round}.map-pawn{fill:#2d3a52;stroke:var(--border);stroke-width:1}.map-pawn-monster{fill:#4a2d3a;stroke:#8b3a4a}.map-pawn-label{fill:var(--text);font-size:10px;font-weight:600;pointer-events:none}.ws-bar{width:100%;margin-top:.35rem;padding-top:.5rem;border-top:1px solid var(--border)}.ws-url-wrap{flex:1;min-width:180px}input.ws-url{width:min(100%,16rem);margin-left:.35rem;padding:.35rem .5rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:.8rem}.floor-overview{display:flex;flex-wrap:wrap;gap:.4rem;margin:.35rem 0 .5rem;font-size:.78rem;color:var(--muted)}.floor-chip{border:1px solid var(--border);border-radius:8px;padding:.45rem .65rem;min-height:44px;background:var(--surface);cursor:pointer;font-size:.9rem;touch-action:manipulation}.floor-chip:focus-visible{outline:2px solid var(--warn);outline-offset:2px}.floor-chip.active{border-color:var(--ok);color:var(--text)}.action-group-title{font-size:.72rem;color:var(--muted);margin:.45rem 0 .2rem;letter-spacing:.06em;font-weight:600}.actions-panel .actions-grid-group:first-child .action-group-title{margin-top:0}.ws-status{font-size:.8rem}.map-cell-ghost{fill:#8b5cb41f;stroke:#9b7ec4;stroke-width:2;stroke-dasharray:6 4}.map-ghost-label{fill:#c4b5e0;font-size:10px;pointer-events:none}.map-door-ghost{stroke:#9b7ec4;stroke-width:4;stroke-linecap:round;stroke-dasharray:4 4}.save-replay-actions{display:flex;flex-wrap:wrap;gap:.45rem;margin:.5rem 0}.paste-json-label{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;color:var(--muted)}.paste-json-label textarea{width:100%;padding:.45rem .55rem;border-radius:8px;border:1px solid var(--border);background:#12161e;color:var(--text);font-family:ui-monospace,monospace;font-size:.75rem;resize:vertical}.cmd-btn{display:block;width:100%;min-height:44px;padding:.55rem .75rem;font-size:.9rem;text-align:left;line-height:1.35;touch-action:manipulation}.cmd-btn:focus-visible{outline:2px solid var(--warn);outline-offset:2px}@media(min-width:961px){.cmd-btn{width:auto;min-width:10rem;max-width:100%}.actions-grid-group{display:flex;flex-wrap:wrap;gap:.45rem}}
