:root{--bg: #14100c;--bg-deep: #090705;--panel: rgba(37, 29, 20, .92);--paper: #2a2118;--paper-soft: rgba(244, 234, 215, .075);--brass: #d5a354;--brass-soft: rgba(213, 163, 84, .22);--danger: #8d332a;--danger-soft: rgba(141, 51, 42, .24);--moss: #87b36a;--moss-soft: rgba(135, 179, 106, .2);--fog: rgba(164, 174, 150, .16);--text: #f4ead7;--muted: #b7a98f;--line: rgba(244, 234, 215, .16);--shadow: rgba(0, 0, 0, .38);--hud-surface: rgba(18, 13, 9, .78);--hud-surface-strong: rgba(12, 9, 6, .92);--hud-cell: rgba(244, 234, 215, .055);--hud-cell-active: rgba(213, 163, 84, .14);--sheet-surface: linear-gradient(180deg, rgba(244,234,215,.09), rgba(244,234,215,.04)), var(--panel);--soft-elevation: 0 12px 28px rgba(0,0,0,.24);--sheet-elevation: 0 24px 60px rgba(0,0,0,.48);--radius-card: 8px;--radius-hud: 12px;--radius-sheet: 14px;color:var(--text);background:var(--bg);font-family:Microsoft YaHei,PingFang SC,Noto Sans SC,sans-serif}*{box-sizing:border-box}body{margin:0;min-width:320px;background:radial-gradient(circle at 18% -8%,rgba(213,163,84,.16),transparent 20rem),radial-gradient(circle at 100% 0,rgba(141,51,42,.24),transparent 18rem),linear-gradient(135deg,rgba(255,255,255,.025),transparent 22%),var(--bg)}button,input{min-height:44px;border:1px solid var(--line);border-radius:var(--radius-card);color:inherit;background:var(--paper-soft);font:inherit}button{padding:0 12px;font-weight:800;cursor:pointer;touch-action:manipulation}button.primary{border-color:#d5a354c7;color:#1b1510;background:linear-gradient(180deg,#e8c37b,var(--brass));box-shadow:0 10px 22px #d5a3542e}button.danger{border-color:#bf4c3dad;background:linear-gradient(180deg,#9f3b31,var(--danger))}button.ghost,.ghost-button{background:var(--hud-cell)}button:disabled{cursor:not-allowed;opacity:.42;box-shadow:none}button:focus-visible,input:focus-visible,summary:focus-visible{outline:2px solid rgba(213,163,84,.72);outline-offset:2px}input{width:100%;padding:0 12px;background:#0000003d}label{display:grid;gap:6px;color:var(--muted);font-size:13px;text-align:left}h1,h2,h3,p{margin:0}.app-shell{width:min(100%,480px);min-height:100vh;margin:0 auto;padding:10px 10px 188px;background:linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px) 0 0 / 32px 32px,radial-gradient(circle at 0 0,rgba(213,163,84,.1),transparent 18rem)}.app-shell.phase-haunt{--bg: #0d1410;--panel: rgba(20, 31, 25, .94);--paper: #1a251e;--paper-soft: rgba(143, 191, 115, .08);--brass: #9dbb75;--brass-soft: rgba(143, 191, 115, .2);--danger: #9f2e2e;--danger-soft: rgba(159, 46, 46, .3);--moss: #8fbf73;background:radial-gradient(circle at 100% 0,rgba(143,191,115,.16),transparent 18rem),radial-gradient(circle at 0 20%,rgba(159,46,46,.14),transparent 16rem),var(--bg)}.top-hud{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:1.1fr 1.3fr .9fr 1fr;gap:6px;border:1px solid var(--line);border-radius:var(--radius-card);padding:7px;background:var(--hud-surface-strong);box-shadow:0 10px 28px var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hud-cell{min-width:0;border-radius:7px;padding:6px 7px;background:var(--hud-cell)}button.hud-cell{min-height:0;display:block;width:100%;text-align:left}.hud-cell span,.landing-hero span,.panel-heading span,.section-title span,.room-tile small{display:block;color:var(--muted);font-size:11px;line-height:1.2}.hud-cell strong{display:block;margin-top:3px;overflow:visible;overflow-wrap:anywhere;white-space:normal;font-size:13px;line-height:1.18}.room-code strong{color:var(--brass);letter-spacing:.08em}.room-code:not(:disabled){cursor:pointer}.room-code:not(:disabled):active{border-color:#d5a354c7;background:var(--hud-cell-active)}.sync-badge{display:flex;align-items:center;justify-content:space-between;gap:4px}.sync-badge small{border-radius:999px;padding:2px 5px;color:#1b1510;background:#f4ead7c7;font-size:10px}.sync-badge.open{color:#a8d88f}.sync-badge.connecting{color:#e9cb82}.sync-badge.error{color:#f19b87}.sync-badge.closed{color:var(--muted)}.landing-hero{min-height:218px;display:grid;align-content:end;gap:8px;margin-top:12px;border:1px solid var(--line);border-radius:8px;padding:20px 16px;background:linear-gradient(180deg,transparent 15%,rgba(8,6,4,.78) 78%),radial-gradient(circle at 50% 12%,rgba(213,163,84,.2),transparent 7rem),linear-gradient(135deg,#211810,#090705);box-shadow:inset 0 0 0 1px #ffffff06,0 18px 42px #00000052}.landing-hero h1{font-size:46px;line-height:.95;letter-spacing:.02em}.landing-hero p{color:#f4ead7c2;line-height:1.5}.paper-panel{margin-top:12px;border:1px solid var(--line);border-radius:var(--radius-card);padding:12px;background:linear-gradient(180deg,#f4ead713,#f4ead709),var(--panel);box-shadow:inset 0 0 0 1px #ffffff06,0 16px 34px #0000003d}.entry-panel{display:grid;gap:10px}.join-row{display:grid;grid-template-columns:1fr 86px;gap:8px}.recovery-card{display:grid;gap:8px;border:1px solid rgba(213,163,84,.36);border-radius:8px;padding:10px;background:#d5a3541a}.recovery-card span,.inline-error{color:var(--muted);font-size:13px;line-height:1.45}.inline-error{color:#f4a28f}.status-rail{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}.status-card{display:grid;align-content:center;justify-items:start;gap:2px;min-width:0;border:1px solid var(--line);border-radius:var(--radius-card);padding:7px;text-align:left;background:var(--hud-cell)}.status-rail span{display:block;color:var(--muted);font-size:11px}.status-rail strong{display:block;min-width:0;margin-top:3px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;line-height:1.18}.status-card small{display:block;max-width:100%;overflow:hidden;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:10px;font-weight:800;line-height:1.05}.status-card:active{border-color:#d5a354b8;background:#d5a3541f}.current-room-summary{display:grid;grid-template-columns:1fr auto;gap:8px 10px;margin-top:10px;border:1px solid rgba(213,163,84,.34);border-radius:8px;padding:10px;background:linear-gradient(135deg,rgba(213,163,84,.1),transparent 48%),#f4ead70e}.room-summary-main,.room-summary-meta{min-width:0}.room-summary-main span,.room-summary-meta span{display:block;overflow:visible;overflow-wrap:anywhere;color:var(--muted);white-space:normal;font-size:12px}.room-summary-main strong{display:block;margin-top:3px;overflow:visible;overflow-wrap:anywhere;white-space:normal;font-size:18px}.room-summary-meta{display:grid;align-content:center;justify-items:end;gap:3px}.room-summary-icons{display:flex;flex-wrap:wrap;gap:4px;grid-column:1}.room-summary-action{grid-column:2;grid-row:2;min-height:36px;align-self:end;padding:0 10px;font-size:12px}.panel-heading,.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.sheet-overlay>.panel-heading,.log-overlay>.panel-heading{position:sticky;top:-10px;z-index:3;margin:-10px -10px 8px;border-bottom:1px solid var(--line);padding:10px;background:linear-gradient(180deg,#f4ead717,#f4ead709),var(--panel)}.panel-heading h2,.section-title h2{margin-top:2px;font-size:19px}.panel-heading p{border-radius:999px;padding:5px 9px;color:#1b1510;background:var(--brass);font-weight:800}.seat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.seat-card{display:grid;min-height:142px;align-content:center;justify-items:center;gap:7px;border:1px solid var(--line);border-radius:var(--radius-card);padding:10px;text-align:center;background:#0000002e}.seat-card.ready{border-color:#87b36a94;box-shadow:0 0 0 1px #87b36a2e}.seat-token,.player-token,.monster-token{display:inline-grid;place-items:center;border-radius:999px;font-weight:900}.seat-token{width:46px;height:46px;color:#1b1510;background:linear-gradient(180deg,#efd18a,var(--brass))}.seat-card small{color:var(--muted)}.seat-card button{min-height:34px;padding:0 9px;font-size:12px}.lobby-actions{display:grid;grid-template-columns:1fr 1.4fr;gap:8px;margin-top:12px}.lobby-actions button:last-child{grid-column:1 / -1}.character-picker{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px}.character-picker button{display:grid;min-height:68px;align-content:center;gap:5px;border:1px solid var(--line);border-radius:var(--radius-card);padding:8px;text-align:left;background:#00000029}.character-picker button.selected{border-color:#d5b365c7;background:#d5b36524}.character-picker button:disabled:not(.selected){opacity:.42}.character-picker strong{color:var(--paper);font-size:14px}.character-picker span{color:var(--muted);font-size:12px;line-height:1.35}.haunt-banner{margin-top:12px;border:1px solid rgba(159,46,46,.62);border-radius:8px;padding:13px;background:radial-gradient(circle at 100% 0,rgba(143,191,115,.18),transparent 8rem),#9f2e2e29}.haunt-banner span{color:#f3a18f;font-size:12px;font-weight:900}.haunt-banner h2{margin:2px 0 8px;font-size:24px}.haunt-banner p,.haunt-banner strong{display:block;margin-top:7px;color:#f4ead7cc;line-height:1.42}.player-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin:0}.player-tabs button{min-width:0;padding:6px 5px;font-size:12px}.player-tabs button span{display:block;margin:0 auto 4px;width:24px;height:24px;border-radius:999px;color:#1b1510;background:var(--brass);line-height:24px}.player-tabs .selected,.ghost-button:hover{border-color:#d5a354c7;box-shadow:0 0 0 1px var(--brass-soft)}.status-sheet-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.status-sheet-grid section,.status-sheet-player{min-width:0;border:1px solid var(--line);border-radius:8px;padding:8px;background:#f4ead70e}.status-sheet-grid span{display:block;color:var(--muted);font-size:11px}.status-sheet-grid strong{display:block;margin-top:4px;overflow-wrap:anywhere;font-size:15px;line-height:1.15}.status-sheet-grid p,.status-sheet-player p{margin-top:5px;color:var(--muted);font-size:12px;line-height:1.35}.status-sheet-player{display:grid;gap:6px;margin-top:8px}.map-section{margin-top:10px}.map-tools{display:grid;grid-template-columns:repeat(3,minmax(42px,1fr));gap:6px;min-width:0}.map-tools button{min-height:38px;padding:0 9px;font-size:12px}.icon-tool-button,.icon-action-button{display:grid;place-items:center;align-content:center;gap:2px;min-width:46px;min-height:46px;padding:4px;border-radius:999px;line-height:1}.ui-icon{width:22px;height:22px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.icon-tool-button .ui-icon,.icon-action-button .ui-icon{display:grid;place-items:center;padding:4px;color:var(--text);box-sizing:content-box}.icon-tool-button small,.icon-action-button small{display:block;max-width:100%;overflow:visible;overflow-wrap:anywhere;color:var(--muted);white-space:normal;line-height:1.05;font-size:10px;font-weight:900}.latest-event-strip{width:100%;min-height:44px;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:9px;margin-bottom:8px;padding:7px 10px;text-align:left;background:#f4ead70e}.latest-event-strip span{font-size:12px}.latest-event-strip strong{min-width:0;overflow:visible;overflow-wrap:anywhere;white-space:normal;font-size:13px;line-height:1.25}.map-board{display:grid;grid-template-columns:repeat(var(--cols),118px);grid-template-rows:repeat(var(--rows),112px);gap:12px;min-height:286px;overflow:auto;border:1px solid var(--line);border-radius:8px;padding:18px;background:radial-gradient(circle at 20% 15%,rgba(213,163,84,.09),transparent 7rem),#0000003d;scroll-snap-type:both proximity}.room-tile,.fog-slot{position:relative;width:118px;height:112px;scroll-snap-align:center}.room-tile{display:flex;flex-direction:column;gap:4px;border:1px solid rgba(244,234,215,.22);border-radius:8px;padding:9px;background:linear-gradient(135deg,rgba(255,255,255,.055),transparent 38%),#2a2118fa;box-shadow:0 12px 20px #00000038}.room-tile.current{border-color:#d5a354e6;box-shadow:0 0 0 2px var(--brass-soft),0 12px 20px #00000042}.room-tile.legal{border-color:#87b36ae6}.room-tile strong{display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-height:1.18;overflow-wrap:anywhere;font-size:13px}.room-tile em{color:var(--muted);font-size:11px;font-style:normal}.door{position:absolute;background:var(--brass);box-shadow:0 0 9px var(--brass-soft)}.door.north,.door.south{left:44px;width:24px;height:5px}.door.north{top:-3px}.door.south{bottom:-3px}.door.east,.door.west{top:38px;width:5px;height:24px}.door.east{right:-3px}.door.west{left:-3px}.icon-row{display:flex;flex-wrap:wrap;gap:4px;min-height:19px}.room-icon{border-radius:999px;padding:2px 5px;font-size:10px;font-weight:800}.room-icon.event{color:#dcecff;background:#5f80a673}.room-icon.item{color:#1b1510;background:#d5a354e6}.room-icon.omen{color:#ffe0d8;background:#8d332ab3}.token-row{display:flex;align-items:center;gap:3px;min-height:20px;margin-top:auto}.player-token,.monster-token{position:relative;z-index:0;width:20px;height:20px;color:#1b1510;background:#e7c87e;font-size:11px}.player-token.owned{z-index:2;width:28px;height:28px;transform:translateY(-4px) scale(1.04);border:2px solid #fff7cf;color:#1b1510;background:linear-gradient(180deg,#fff4bd,#d5a354);box-shadow:0 0 0 2px #140c05e0,0 0 0 5px #d5a35447,0 11px 18px #0000005c;font-size:12px}.player-token.owned:before{content:"";position:absolute;right:2px;bottom:-8px;left:2px;height:5px;border-radius:999px;background:#ffe897b8;box-shadow:0 0 12px #d5a354b8;pointer-events:none}.player-token.owned:after{content:"★";position:absolute;top:-12px;right:-9px;z-index:3;display:grid;place-items:center;width:18px;height:18px;border:1px solid rgba(20,12,5,.9);border-radius:999px;color:#1b1510;background:#fff6d1;box-shadow:0 2px 6px #00000047;font-size:11px;line-height:1;pointer-events:none}.player-token.turn{outline:2px solid var(--brass);box-shadow:0 0 12px var(--brass-soft)}.player-token.turn:not(.owned):before{content:"";position:absolute;right:-4px;top:-4px;z-index:-1;width:8px;height:8px;border:1px solid rgba(20,12,5,.85);border-radius:999px;background:var(--brass);pointer-events:none}.player-token.owned.turn{outline:2px solid var(--brass);outline-offset:4px;box-shadow:0 0 0 2px #140c05e0,0 0 0 5px #d5a35452,0 0 20px var(--brass-soft)}.player-token.zombie_lord,.monster-token{color:#fff1df;background:var(--danger)}.monster-token.stunned{color:#1b1510;background:var(--brass)}.player-token.zombie{color:#102016;background:var(--moss)}.player-token.owned.zombie,.player-token.owned.zombie_lord{color:#fff1df;background:linear-gradient(180deg,#8d332a,#331814);box-shadow:0 0 0 2px #140c05d9,0 0 18px #8d332abf}@media(prefers-reduced-motion:reduce){.dice-result-strip{animation:none}}.fog-slot{display:grid;place-content:center;border:1px dashed rgba(213,163,84,.58);border-radius:8px;color:#f4ead7c7;text-align:center;background:radial-gradient(circle,rgba(213,163,84,.14),transparent 55%),repeating-linear-gradient(135deg,rgba(255,255,255,.04) 0 6px,transparent 6px 12px),var(--fog)}.fog-slot span{color:var(--muted);font-size:11px}.fog-slot strong{margin-top:2px}.map-legend{display:flex;flex-wrap:wrap;gap:9px;margin-top:8px;color:var(--muted);font-size:12px}.legend{display:inline-block;width:10px;height:10px;margin-right:4px;border-radius:999px;vertical-align:-1px}.legend.current{background:var(--brass)}.legend.move{background:var(--moss)}.legend.fog{border:1px dashed var(--brass);background:var(--fog)}.room-panel p,.task-block p,.empty-note{margin-top:6px;color:#f4ead7c2;line-height:1.4}.room-detail-body{display:grid;gap:8px}.detail-section{border:1px solid var(--line);border-radius:8px;padding:8px;background:#00000024}.flat-section{border:0;padding:0;background:transparent}.detail-section h3{margin:0 0 6px;color:var(--brass);font-size:13px}.chips{display:flex;flex-wrap:wrap;gap:6px;margin:7px 0}.chips span,.chips button{min-height:34px;border-radius:7px;padding:6px 8px;color:var(--text);background:#f4ead714;font-size:12px;font-weight:800;line-height:1.15}.compact-chips{gap:5px}.card-action-list{display:grid;gap:8px}.card-action-list article{border:1px solid rgba(244,234,215,.12);border-radius:8px;padding:8px;background:#0000001f}.card-action-list strong{display:block;color:var(--paper);font-size:13px}.inventory-list{display:grid;gap:8px}.inventory-card{display:grid;gap:8px;border:1px solid var(--line);border-radius:8px;padding:10px;background:#f4ead70e}.inventory-card.event{border-color:#5f80a661}.inventory-card.item{border-color:#d5a3546b}.inventory-card.omen{border-color:#8d332a7a}.inventory-card span{display:block;color:var(--muted);font-size:11px;font-weight:900}.inventory-card strong{display:block;margin-top:2px;color:var(--paper);font-size:15px}.inventory-card-actions{display:flex;flex-wrap:wrap;gap:6px}.inventory-card-actions button{min-height:34px;border-radius:7px;padding:0 9px;font-size:12px}.trait-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;margin-top:7px}.trait-summary span{border:1px solid var(--line);border-radius:8px;padding:5px 3px;text-align:center;color:var(--paper);background:#00000024;font-size:11px;font-weight:800}.trait-summary.compact{margin-top:4px}.trait-tracks{display:grid;gap:5px;margin-top:7px}.trait-track{display:grid;grid-template-columns:34px 1fr;align-items:center;gap:5px}.trait-track strong{color:var(--paper);font-size:11px}.trait-cells{display:grid;grid-template-columns:repeat(6,minmax(18px,1fr));gap:3px}.trait-cells span{display:grid;min-height:22px;place-items:center;border:1px solid rgba(244,234,215,.16);border-radius:5px;color:#f4ead7ad;background:#00000029;font-size:10px;font-weight:900}.trait-cells span.skull{color:#f0a093;border-color:#9f2e2e7a}.trait-cells span.current{color:#1b1510;border-color:var(--brass);background:var(--brass)}.task-block{margin-top:10px;border-top:1px solid var(--line);padding-top:10px}.task-block strong{display:block;margin-top:8px;color:var(--brass)}.room-action{display:grid;gap:6px}.room-action+.room-action{margin-top:8px;border-top:1px solid var(--line);padding-top:8px}.room-action strong{color:var(--paper);font-size:13px}.wide{width:100%;margin-top:10px}.event-log ol{display:grid;gap:8px;margin:0;padding:0;color:#f4ead7c2;list-style:none;line-height:1.42}.event-log li{display:grid;grid-template-columns:auto 1fr;align-items:start;gap:7px;border-left:2px solid var(--brass-soft);padding-left:8px}.event-log li>span:last-child{min-width:0;overflow-wrap:anywhere}.dice-result-strip{display:inline-grid;place-items:center;min-width:36px;height:24px;border:1px solid rgba(213,163,84,.42);border-radius:999px;padding:0 7px;color:#1b1510;background:var(--brass);font-size:11px;font-weight:900;line-height:1;white-space:nowrap;transform-origin:center;animation:dice-result-pop .48s cubic-bezier(.2,1.4,.34,1) both}.dice-result-strip.fail{color:#ffe6dd;border-color:#9f2e2e85;background:#9f2e2eb8}.dice-result-strip.attack{color:#fff1df;background:#8d332adb}.dice-result-strip.empty{color:var(--muted);background:#f4ead712;animation:none}@keyframes dice-result-pop{0%{opacity:.42;transform:rotate(-10deg) scale(.72);filter:blur(1px)}58%{opacity:1;transform:rotate(3deg) scale(1.12);filter:blur(0)}to{opacity:1;transform:rotate(0) scale(1);filter:blur(0)}}.log-backdrop{align-items:end}.log-overlay,.sheet-overlay{width:min(100%,430px);max-height:min(88dvh,760px);overflow:auto;border:1px solid var(--line);border-radius:var(--radius-sheet) var(--radius-sheet) var(--radius-card) var(--radius-card);padding:10px;background:var(--sheet-surface);box-shadow:var(--sheet-elevation)}.icon-close-button{display:grid;place-items:center;width:36px;min-width:36px;height:36px;min-height:36px;border-radius:999px;padding:0;color:var(--text);background:var(--hud-cell);font-size:24px;font-weight:700;line-height:1}.modal-close-button{position:absolute;top:10px;right:10px;z-index:2}.sheet-backdrop{align-items:end;padding:8px}.sheet-overlay .room-panel,.sheet-overlay .player-tabs{margin-top:0}.log-overlay .event-log{margin-top:0;box-shadow:none}.log-overlay .event-log>.panel-heading{display:none}.mobile-disclosure{margin-top:0;border:1px solid var(--line);border-radius:var(--radius-card);background:#f4ead70b;overflow:hidden}.mobile-disclosure summary{position:relative;min-height:44px;display:grid;grid-template-columns:52px 1fr;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;list-style:none;touch-action:manipulation}.mobile-disclosure summary::-webkit-details-marker{display:none}.mobile-disclosure summary:after{content:"+";position:absolute;top:50%;right:10px;width:28px;height:28px;display:grid;place-items:center;transform:translateY(-50%);border:1px solid var(--line);border-radius:999px;padding:0;color:var(--muted);font-size:16px;font-weight:800}.mobile-disclosure[open] summary:after{content:"-";color:#1b1510;background:var(--brass)}.mobile-disclosure summary span{color:var(--muted);font-size:12px}.mobile-disclosure summary strong{min-width:0;overflow:visible;overflow-wrap:anywhere;padding-right:34px;white-space:normal;font-size:13px;line-height:1.18}.mobile-disclosure-body{margin:0 8px 8px}.mobile-disclosure .paper-panel{margin-top:0}.action-dock{position:fixed;right:0;bottom:0;left:0;z-index:30;display:flex;flex-wrap:wrap;justify-content:center;gap:8px;border-top:1px solid var(--line);padding:10px max(10px,env(safe-area-inset-right)) calc(10px + env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left));background:#0c0906f0;box-shadow:0 -14px 32px #00000057;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.action-dock.readonly{min-height:66px;align-items:center;color:var(--muted)}.action-dock>button,.dock-command-stack>button,.dock-secondary-row>button{flex:1 1 104px;max-width:152px}.dock-command-stack{display:grid;grid-template-columns:minmax(126px,1fr);gap:7px;flex:1 1 132px;max-width:170px}.dock-command-stack>button,.dock-secondary-row>button{width:100%;max-width:none}.dock-secondary-row{display:grid;grid-template-columns:repeat(2,minmax(84px,1fr));gap:7px;flex:1 1 100%;max-width:330px}.dock-secondary-row>button{min-height:38px;font-size:12px}.end-turn-suggested{position:relative;outline:2px solid rgba(244,234,215,.3)}.end-turn-suggested em{display:block;margin-top:2px;color:#1b1510c7;font-size:10px;font-weight:900;font-style:normal;line-height:1.15}.overlay-backdrop{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:18px;background:#040302b8;-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px)}.card-modal,.choice-modal,.haunt-transition,.result-panel{position:relative;width:min(100%,430px);max-height:calc(100dvh - 28px - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow:auto;border:1px solid var(--line);border-radius:8px;padding:16px;background:linear-gradient(180deg,#f4ead717,#f4ead70a),var(--panel);box-shadow:0 24px 60px #0000007a}.card-modal{min-height:min(430px,calc(100dvh - 44px));display:grid;align-content:center;gap:12px;text-align:center}.card-modal span{justify-self:center;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:900}.card-modal.event span{background:#5f80a680}.card-modal.item span{color:#1b1510;background:var(--brass)}.card-modal.omen span{background:var(--danger)}.card-modal h2{font-size:30px}.card-illustration{display:grid;place-items:center;min-height:150px;border:1px solid var(--line);border-radius:8px;color:#f4ead76b;font-size:32px;font-weight:900;background:radial-gradient(circle,var(--brass-soft),transparent 58%),#0000002e}.card-modal strong{color:#f0b49f}.choice-modal{display:grid;gap:12px;text-align:center}.choice-modal span{justify-self:center;border-radius:999px;padding:5px 10px;color:#1b1510;font-size:12px;font-weight:900;background:var(--brass)}.choice-modal p{margin:0;color:var(--muted);line-height:1.5}.choice-actions{display:grid;gap:8px}.choice-modal strong{color:#f0b49f}.haunt-transition,.result-panel{display:grid;gap:11px;text-align:center;background:radial-gradient(circle at 50% 24%,rgba(143,191,115,.18),transparent 9rem),#161c17f5}.haunt-transition span,.result-panel span{color:#f3a18f;font-weight:900}.haunt-transition h2,.result-panel h2{font-size:32px}.zombie-lord-emblem{display:grid;place-items:center;justify-self:center;width:82px;height:82px;border-radius:999px;border:2px solid rgba(244,234,215,.25);background:var(--danger);box-shadow:0 0 30px #9f2e2e6b;font-size:38px;font-weight:900}.haunt-transition strong{border:1px solid var(--line);border-radius:8px;padding:9px;background:#00000029;line-height:1.45}.result-panel ol{display:grid;gap:8px;margin:0;padding:0;list-style:none}.result-panel li{display:flex;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:8px;padding:9px;background:#00000029}.player-readonly-list{display:grid;gap:8px}.player-readonly-list article{display:grid;grid-template-columns:34px 1fr;align-items:center;gap:9px;border:1px solid var(--line);border-radius:8px;padding:8px;background:#f4ead70e}.player-readonly-list article.owned,.player-readonly-list article.turn{border-color:#d5a35494}.player-readonly-list article>span{display:grid;place-items:center;width:34px;height:34px;border-radius:999px;color:#1b1510;background:var(--brass);font-weight:900}.player-readonly-list strong,.player-readonly-list p{min-width:0;overflow:visible;overflow-wrap:anywhere;white-space:normal}.player-readonly-list p{margin-top:2px;color:var(--muted);font-size:12px}.error-toast,.copy-toast{position:fixed;right:12px;bottom:158px;left:12px;z-index:60;max-width:456px;margin:0 auto;border:1px solid rgba(213,163,84,.38);border-radius:8px;padding:10px 12px;color:var(--text);background:#8d332af5;box-shadow:0 18px 36px #0000005c}.copy-toast{border-color:#87b36a94;background:#275b35f5}@media(max-width:480px){.app-shell{padding:6px 6px 142px}.top-hud{grid-template-columns:repeat(4,minmax(0,1fr));gap:3px;padding:4px;border-radius:7px}.hud-cell{border-radius:6px;padding:4px 5px}.hud-cell span{font-size:9px;line-height:1}.hud-cell strong{margin-top:2px;font-size:11px;line-height:1.1}.sync-badge{display:block}.sync-badge small{display:none}.landing-hero{min-height:178px;padding:18px 14px}.paper-panel{margin-top:10px;padding:10px}.status-rail{grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;margin-top:6px}.status-rail article{min-height:34px;border-radius:7px;padding:4px 5px}.status-rail span{font-size:9px;line-height:1}.status-rail strong{margin-top:2px;font-size:11px;line-height:1.15}.status-card small{font-size:9px}.current-room-summary{grid-template-columns:minmax(0,1fr) auto;gap:6px 8px;margin-top:6px;padding:8px}.room-summary-meta{max-width:116px;justify-items:end}.room-summary-main span,.room-summary-meta span{font-size:11px}.room-summary-main strong{font-size:16px}.room-summary-icons{grid-column:1}.room-summary-action{grid-column:2;grid-row:2;width:100%;min-width:96px;min-height:34px;padding:0 8px}.panel-heading,.section-title{gap:8px;margin-bottom:8px}.section-title{align-items:flex-start}.panel-heading h2,.section-title h2{font-size:17px}.seat-grid{gap:8px}.seat-card{min-height:116px;gap:5px;padding:8px}.seat-token{width:38px;height:38px}.lobby-actions{position:sticky;bottom:calc(8px + env(safe-area-inset-bottom));z-index:10;border:1px solid var(--line);border-radius:8px;padding:8px;background:#0c0906eb;box-shadow:0 14px 28px #00000052;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.character-picker{grid-template-columns:1fr}.room-panel .panel-heading{align-items:flex-start}.room-panel .icon-row{justify-content:flex-end;max-width:116px}.map-tools{grid-template-columns:repeat(3,minmax(40px,1fr));width:min(176px,54vw);gap:4px}.map-tools button{min-height:34px;padding:0 6px;font-size:11px}.map-board{grid-template-columns:repeat(var(--cols),112px);grid-template-rows:repeat(var(--rows),106px);max-height:356px;min-height:214px;gap:10px;padding:14px}.map-section{margin-top:10px}.room-tile,.fog-slot{width:112px;height:106px}.room-tile{gap:3px;padding:7px}.room-tile strong{font-size:12px}.room-tile em{font-size:10px}.action-dock{display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:auto auto;align-items:center;gap:6px 8px;padding:7px max(8px,env(safe-area-inset-right)) calc(7px + env(safe-area-inset-bottom)) max(8px,env(safe-area-inset-left))}.action-dock.readonly{display:flex;min-height:70px}.dock-command-stack{grid-column:1;grid-row:1;gap:6px;width:100%;max-width:none}.dock-command-stack>button{min-height:40px}.dock-secondary-row{grid-column:1;grid-row:2;gap:5px;width:100%;max-width:none}.dock-secondary-row>button{min-height:32px;border-radius:7px;padding:0 7px;font-size:11px}.error-toast,.copy-toast{bottom:130px}}@media(max-width:380px){.landing-hero h1{font-size:40px}.app-shell{padding-bottom:136px}.top-hud{gap:2px}.hud-cell{padding:4px}.action-dock{gap:5px 7px}}.floor-rail{display:flex;gap:6px;margin-bottom:8px}.floor-rail button{min-height:36px;min-width:42px;padding:0 10px}.floor-rail button.active,.floor-rail button[aria-pressed=true]{border-color:#d5a354e6;color:#1b1510;background:var(--brass)}.room-tile{min-height:0;color:var(--text);text-align:left}.room-tile.legal:after{position:absolute;right:8px;bottom:7px;content:"可移动";border:1px solid rgba(135,179,106,.56);border-radius:999px;padding:2px 6px;color:#d8f0c6;background:#3159278c;font-size:10px}.fog-slot{min-height:0;padding:0}.map-first-shell{width:100%;max-width:none;min-height:100dvh;margin:0;padding:0;overflow:hidden}.map-first-shell .top-hud{position:fixed;top:max(8px,env(safe-area-inset-top));left:8px;right:auto;z-index:60;width:136px;grid-template-columns:58px minmax(0,1fr);gap:0;border-right:0;border-radius:var(--radius-hud) 0 0 var(--radius-hud);padding:4px;background:var(--hud-surface);box-shadow:var(--soft-elevation);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.map-first-shell .phase-cell,.map-first-shell .turn-cell{display:none}.map-first-shell .hud-cell{min-height:42px;border-radius:9px;padding:5px 6px}.map-first-shell .hud-cell+.hud-cell{border-left:1px solid rgba(244,234,215,.12);border-radius:0}.map-first-shell .hud-cell span{font-size:9px}.map-first-shell .hud-cell strong{margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;line-height:1.05}.map-first-shell .status-rail{position:fixed;top:max(8px,env(safe-area-inset-top));right:8px;left:144px;z-index:60;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));width:auto;gap:0;margin-top:0;border:1px solid rgba(244,234,215,.18);border-left:0;border-radius:0 var(--radius-hud) var(--radius-hud) 0;padding:4px;background:var(--hud-surface);box-shadow:var(--soft-elevation);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.map-first-shell .status-card{display:block;min-width:0;width:auto;min-height:42px;border:0;padding:5px 6px;border-radius:9px;text-align:left;background:var(--hud-cell)}.map-first-shell .status-card+.status-card{border-left:1px solid rgba(244,234,215,.12);border-radius:0}.map-first-shell .status-card strong{display:block;margin:1px 0 0;max-width:100%;overflow:hidden;text-overflow:ellipsis;font-size:12px;line-height:1.05;white-space:nowrap}.map-first-shell .status-card small{display:block;max-width:100%;overflow:hidden;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:9px;font-weight:800;line-height:1.2}.map-first-shell .map-section{position:fixed;inset:0;z-index:1;margin:0}.map-first-shell .section-title{position:fixed;top:calc(max(8px,env(safe-area-inset-top)) + 68px);right:8px;z-index:50;display:block;width:48px}.map-first-shell .section-title>div:first-child{display:none}.map-first-shell .map-tools{display:grid;grid-template-columns:1fr;width:48px;gap:8px}.map-first-shell .map-tools button{width:48px;min-height:48px;border:1px solid rgba(244,234,215,.18);border-radius:999px;padding:0;font-size:12px;background:var(--hud-surface);box-shadow:var(--soft-elevation);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.map-first-shell .icon-tool-button .ui-icon,.map-first-shell .icon-action-button .ui-icon{width:22px;height:22px;padding:4px}.map-first-shell .icon-tool-button small,.map-first-shell .icon-action-button small{display:none}.map-first-shell .latest-event-strip{position:fixed;right:72px;bottom:calc(10px + env(safe-area-inset-bottom));left:60px;z-index:45;width:auto;min-height:46px;margin:0;border:1px solid var(--line);border-radius:var(--radius-card);background:var(--hud-surface);box-shadow:var(--soft-elevation);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.map-first-shell .floor-rail{position:fixed;top:calc(max(8px,env(safe-area-inset-top)) + 68px);left:8px;z-index:50;display:grid;gap:6px;margin:0}.map-first-shell .floor-rail button{width:44px;min-width:44px;min-height:44px;padding:0;border-radius:999px;background:var(--hud-surface);box-shadow:var(--soft-elevation);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.map-first-shell .floor-rail button.active,.map-first-shell .floor-rail button[aria-pressed=true]{border-color:#d5a354e6;color:#1b1510;background:var(--brass)}.map-first-shell .map-board{width:100vw;height:100dvh;min-height:100dvh;max-height:none;gap:16px;border:0;border-radius:0;padding:140px 72px 96px 68px;background:linear-gradient(90deg,rgba(244,234,215,.045) 1px,transparent 1px) 0 0 / 36px 36px,linear-gradient(0deg,rgba(244,234,215,.035) 1px,transparent 1px) 0 0 / 36px 36px,#00000042}.map-first-shell .room-tile,.map-first-shell .fog-slot{width:132px;height:126px}.map-first-shell .room-tile{border-width:2px}.map-first-shell .current-room-summary,.map-first-shell .haunt-banner{position:fixed;right:74px;left:74px;z-index:44;border:1px solid var(--line);border-radius:var(--radius-card);background:var(--hud-surface);box-shadow:var(--soft-elevation);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.map-first-shell .current-room-summary{display:none}.map-first-shell .haunt-banner{top:calc(max(8px,env(safe-area-inset-top)) + 68px)}.map-first-shell .map-legend{display:none}.map-first-shell .action-dock{right:8px;bottom:calc(8px + env(safe-area-inset-bottom));left:auto;z-index:55;display:grid;grid-template-columns:1fr;grid-template-rows:auto auto;width:48px;max-height:min(46dvh,calc(100dvh - 260px));overflow-y:auto;overscroll-behavior:contain;gap:8px;border:0;border-radius:0;padding:0;background:transparent}.map-first-shell .dock-command-stack,.map-first-shell .dock-secondary-row{display:grid;grid-column:auto;grid-template-columns:1fr;grid-row:auto;width:100%;min-width:0;max-width:none;gap:8px;flex:none}.map-first-shell .action-dock>button,.map-first-shell .dock-command-stack>button,.map-first-shell .dock-secondary-row>button{flex:none;width:100%;min-width:0;min-height:48px;max-height:none;max-width:none;border:1px solid rgba(244,234,215,.18);border-radius:999px;padding:0;font-size:12px;background:var(--hud-surface);box-shadow:var(--soft-elevation);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.map-first-shell .action-dock .primary:not(:disabled),.map-first-shell .dock-command-stack .primary:not(:disabled),.map-first-shell .dock-secondary-row .primary:not(:disabled){border-color:#d5a354c7;color:#1b1510;background:linear-gradient(180deg,#e8c37b,var(--brass))}.map-first-shell .action-dock .danger:not(:disabled),.map-first-shell .dock-command-stack .danger:not(:disabled),.map-first-shell .dock-secondary-row .danger:not(:disabled){border-color:#bf4c3dad;color:var(--text);background:linear-gradient(180deg,#9f3b31,var(--danger))}.map-first-shell .end-turn-suggested{min-height:66px}.map-first-shell .end-turn-suggested em{font-size:9px}.map-first-shell .action-dock.readonly{right:8px;bottom:calc(64px + env(safe-area-inset-bottom));left:auto;display:flex;align-items:center;width:auto;max-width:calc(100vw - 76px);min-height:0;max-height:none;overflow:visible;gap:8px}.map-first-shell .action-dock.readonly strong{display:grid;min-height:34px;max-width:min(210px,calc(100vw - 136px));align-items:center;border:1px solid rgba(244,234,215,.18);border-radius:999px;padding:0 11px;overflow:hidden;color:#f4ead7c7;text-overflow:ellipsis;white-space:nowrap;background:var(--hud-surface);box-shadow:var(--soft-elevation);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);font-size:12px;font-weight:500;line-height:1}.map-first-shell .action-dock.readonly>button{width:42px;min-width:42px;min-height:42px}
