: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);font-size:14px;line-height:1.42}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-size:13px;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:224px;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}.haunt-logo-mark{justify-self:center;display:grid;place-items:center;width:124px;min-height:70px;margin-bottom:8px;border:1px solid #9c5c45;border-radius:8px 8px 3px 3px;color:#efd6a6;background:linear-gradient(180deg,#381f19f0,#120b0afa);box-shadow:0 10px 26px #00000057;font-weight:900}.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}.form-hint{margin:0;color:var(--muted);font-size:12px}.mvp-room-settings,.entry-shortcuts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.mvp-room-settings span,.entry-shortcuts button{display:grid;place-items:center;min-height:34px;border:1px solid rgba(213,163,84,.3);border-radius:8px;padding:0 8px;color:#f4ead7c7;background:#f4ead70e;font-size:12px;font-weight:800;text-align:center}.create-room-button{min-height:56px;font-size:16px}.room-entry-grid,.join-row{display:grid;grid-template-columns:1fr 102px;gap:8px}.utility-row{display:flex;gap:8px}.utility-row button{flex:1}.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}.lobby-room-card{display:grid;grid-template-columns:minmax(0,1fr) 70px;align-items:center;gap:10px;border:1px solid rgba(213,163,84,.32);border-radius:8px;padding:12px;color:#4b1916;background:#ecddbeeb}.lobby-room-card span,.lobby-room-card p{color:#6d3b2b}.lobby-room-card h2{margin-top:2px;color:#4b1916;font-size:24px}.lobby-room-card p{margin-top:4px;font-size:12px}.lobby-room-card button{min-height:34px;color:var(--text);background:#6e2b26}.lobby-list-heading{margin-top:14px}.seat-grid{display:grid;gap:8px}.seat-card{display:grid;grid-template-columns:32px minmax(0,1fr) auto;align-items:center;min-height:40px;gap:8px;border:1px solid var(--line);border-radius:var(--radius-card);padding:6px 8px;text-align:left;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:28px;height:28px;color:#1b1510;background:linear-gradient(180deg,#efd18a,var(--brass));font-size:12px}.seat-card strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seat-card small{color:var(--muted);white-space:nowrap}.seat-card button{min-height:34px;padding:0 9px;font-size:12px}.lobby-actions{display:grid;grid-template-columns:minmax(0,1fr) 104px 1.25fr 58px;align-items:center;gap:8px;margin-top:12px;border:1px solid rgba(213,163,84,.3);border-radius:8px;padding:10px;background:#0003}.lobby-actions div{display:grid;gap:2px}.lobby-actions div span{color:var(--muted);font-size:12px}.character-section-heading{display:flex;justify-content:space-between;gap:10px;margin-top:14px;color:var(--muted);font-size:12px}.character-section-heading strong{color:var(--text);font-size:14px}.character-picker{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:8px}.character-picker button{display:grid;grid-template-columns:1fr;justify-items:center;min-height:112px;align-content:start;gap:6px;border:1px solid var(--line);border-radius:var(--radius-card);padding:6px;text-align:center;background:#00000029}.character-portrait-block{width:62px;height:72px;border:1px solid rgba(244,234,215,.18);border-radius:8px;background:linear-gradient(135deg,rgba(255,255,255,.18),transparent 42%),var(--character-color, var(--brass))}.character-picker button.selected{border-color:#d5b365c7;background:#d5b36524}.character-picker button.occupied{filter:saturate(.45)}.character-picker button:disabled:not(.selected){opacity:.42}.character-picker strong{color:var(--text);font-size:12px;line-height:1.18}.character-picker span{color:var(--muted);font-size:11px;line-height:1.35}.character-detail-card{display:grid;grid-template-columns:72px minmax(0,1fr);gap:12px;margin-top:14px;border:1px solid rgba(213,163,84,.32);border-radius:8px;padding:10px;background:#f4ead70e}.character-detail-art{width:72px;min-height:96px;border:1px solid #d19167;border-radius:8px;background:linear-gradient(135deg,rgba(255,255,255,.18),transparent 42%),var(--character-color, var(--brass))}.character-detail-card h3{margin-top:3px;font-size:16px}.character-detail-card p{margin-top:7px;color:var(--muted);font-size:12px;line-height:1.4}.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}.turn-guidance{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;margin-top:10px;border:1px solid rgba(213,163,84,.34);border-radius:8px;padding:10px;background:#d5a35414}.turn-guidance.waiting{border-color:#f4ead729;background:#f4ead70b}.turn-guidance.choice{border-color:#d5a35494;background:#d5a3541f}.turn-guidance.ending{border-color:#9f2e2e80;background:#9f2e2e21}.turn-guidance span{color:var(--brass);font-size:11px;font-weight:900}.turn-guidance strong{display:block;margin-top:3px;font-size:15px}.turn-guidance p{margin:3px 0 0;color:var(--muted);font-size:12px;line-height:1.35}.turn-guidance button{min-width:82px;min-height:40px;padding:8px 10px}.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}.map-board.fixed-floor-grid{grid-template-columns:repeat(4,92px);grid-template-rows:repeat(5,92px)}.map-board.fixed-floor-grid .room-tile,.map-board.fixed-floor-grid .fog-slot{width:auto;height:auto;min-width:0}.room-tile{display:flex;flex-direction:column;gap:4px;border:1px solid var(--room-border, rgba(244,234,215,.22));border-radius:8px;padding:9px;background:linear-gradient(135deg,rgba(255,255,255,.055),transparent 38%),var(--room-fill, rgba(42, 33, 24, .98));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.mist{border-style:dashed;opacity:.72;background:repeating-linear-gradient(135deg,rgba(255,255,255,.045) 0 6px,transparent 6px 12px),var(--fog)}.room-tile.mist .door{opacity:.55}.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:50%;width:min(28px,32%);height:5px;transform:translate(-50%)}.door.north{top:-3px}.door.south{bottom:-3px}.door.east,.door.west{top:50%;width:5px;height:min(28px,32%);transform:translateY(-50%)}.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:var(--token-color, #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,var(--token-color, #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;grid-template-columns:46px 1fr;gap:8px;border:1px solid var(--line);border-radius:8px;padding:10px;background:linear-gradient(135deg,color-mix(in srgb,var(--card-accent, var(--brass)) 18%,transparent),transparent 44%),#f4ead70e}.inventory-card-art{grid-row:span 2;width:46px;min-height:58px;border:1px solid rgba(244,234,215,.16);border-radius:7px;background:radial-gradient(circle at 50% 28%,color-mix(in srgb,var(--card-accent, var(--brass)) 44%,transparent),transparent 58%),var(--card-background, rgba(0,0,0,.18))}.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;grid-column:2}.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%,340px);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:14px;background:linear-gradient(180deg,#f4ead717,#f4ead70a),var(--panel);box-shadow:0 24px 60px #0000007a}.card-modal{min-height:min(520px,calc(100dvh - 44px));display:grid;align-content:start;gap:10px;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:var(--card-accent, rgba(95,128,166,.5))}.card-modal.item span{color:#1b1510;background:var(--card-accent, var(--brass))}.card-modal.omen span{background:var(--card-accent, var(--danger))}.card-modal h2{font-size:26px}.card-illustration{display:grid;place-items:center;justify-self:center;width:min(226px,72vw);min-height:244px;border:1px solid var(--line);border-radius:8px;color:#f4ead76b;font-size:32px;font-weight:900;background:radial-gradient(circle,color-mix(in srgb,var(--card-accent, var(--brass)) 38%,transparent),transparent 58%),var(--card-background, rgba(0,0,0,.18))}.card-modal p{border:1px solid rgba(213,163,84,.24);border-radius:8px;padding:10px;color:#2c2116;background:#ecddbee6;text-align:left;line-height:1.55}.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-option-list,.choice-actions{display:grid;gap:8px}.dice-result-block,.result-summary-grid section,.battle-report-block{border:1px solid var(--line);border-radius:8px;padding:10px;background:linear-gradient(180deg,#ecddbe14,#ecddbe08),#00000029}.dice-result-block strong,.result-summary-grid strong,.battle-report-block strong{display:block;line-height:1.35}.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}.result-winner-line{margin:-4px 0 0;color:#f1d6a4;font-size:18px;font-weight:900}.result-meta-line{margin:0;color:var(--muted);font-size:12px;line-height:1.4}.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-summary-grid{display:grid;gap:8px}.result-summary-grid section{text-align:left}.result-panel h3{font-size:15px}.recap-timeline{display:grid;gap:6px;text-align:left}.battle-report-block{text-align:left}.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}.result-player-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.result-panel .result-player-grid li{display:grid;justify-items:center;gap:5px;min-width:0;text-align:center}.result-page .result-panel{width:100%;max-height:none;overflow:visible;border-radius:16px;padding:16px}.result-contribution-list li{display:grid;justify-content:stretch;text-align:left}.result-contribution-list span{color:var(--muted);font-size:12px;line-height:1.45}.result-avatar{display:grid;place-items:center;width:52px;height:68px;border:1px solid rgba(244,234,215,.18);border-radius:8px;color:#1b1510;background:linear-gradient(135deg,rgba(255,255,255,.18),transparent 42%),var(--character-color, var(--brass));font-weight:900}.result-player-grid strong,.result-player-grid span{min-width:0;max-width:100%;overflow-wrap:anywhere;font-size:11px;line-height:1.25}.battle-report-block p{margin-top:6px;color:var(--muted);font-size:12px;line-height:1.45}.result-actions{display:grid;grid-template-columns:.8fr .8fr 1.2fr;gap:8px}.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){body{font-size:13px}button,input{min-height:40px}.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}.line-screen{width:min(100%,410px);padding:calc(12px + env(safe-area-inset-top)) 10px calc(76px + env(safe-area-inset-bottom))}.line-card{border-radius:8px;padding:11px}.line-card+.line-card,.line-home-actions+.line-two-col,.line-card+.line-wide-primary,.line-wide-primary+.line-card{margin-top:9px}.line-card h2,.line-section-title{margin-bottom:8px;font-size:14px}.line-nav{grid-template-columns:36px minmax(0,1fr) 60px;min-height:40px;margin-bottom:8px}.line-nav button{width:36px;min-height:36px;font-size:24px}.line-nav h1{font-size:18px}.line-home-title{padding:34px 0 18px}.line-home-title h1{font-size:clamp(31px,9.5vw,40px)}.line-home-title p{margin-top:8px;font-size:12px}.line-main-button,.line-wide-primary{min-height:48px;border-radius:8px;font-size:15px}.line-home-actions{gap:8px;margin-top:22px}.mini-card{min-height:64px}.line-footer-tools button{min-height:40px}.scenario-body{grid-template-columns:74px minmax(0,1fr);gap:9px}.scenario-art{height:62px;font-size:21px}.line-input,.hidden-code-input{min-height:40px;font-size:13px}.code-box-row{grid-template-columns:repeat(6,1fr) 58px;gap:5px}.code-box-row span{min-height:40px;border-radius:7px;font-size:17px}.line-bottom-actions{gap:8px;width:min(100%,410px);padding:8px 10px calc(8px + env(safe-area-inset-bottom))}.line-bottom-actions button{min-height:42px;border-radius:8px;font-size:13px}.lobby-player-card .seat-card{grid-template-columns:34px minmax(0,1fr) auto auto;min-height:52px;gap:6px;padding:6px}.seat-token{width:30px;height:30px;font-size:11px}.seat-card button{min-height:30px;padding:0 7px;font-size:11px}.lobby-room-code strong{font-size:19px}.panel-heading,.section-title{gap:8px;margin-bottom:8px}.section-title{align-items:flex-start}.panel-heading h2,.section-title h2{font-size:15px}.seat-grid{gap:8px}.seat-card{min-height:40px;gap:5px;padding:6px 8px}.seat-token{width:28px;height:28px}.lobby-actions{position:sticky;bottom:calc(8px + env(safe-area-inset-bottom));z-index:10;grid-template-columns:1fr;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:repeat(3,minmax(0,1fr));gap:7px}.character-picker button{min-height:112px;padding:6px 4px}.character-portrait-block{width:58px;height:70px}.character-detail-card{grid-template-columns:70px minmax(0,1fr)}.mvp-room-settings,.entry-shortcuts{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),100px);grid-template-rows:repeat(var(--rows),96px);max-height:326px;min-height:214px;gap:8px;padding:12px}.map-section{margin-top:10px}.room-tile,.fog-slot{width:100px;height:96px}.room-tile{gap:3px;padding:6px}.room-tile strong{font-size:11px}.room-tile em{font-size:9px}.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;display:grid;place-items:center;margin:0;padding:calc(max(8px,env(safe-area-inset-top)) + 118px) 12px calc(172px + env(safe-area-inset-bottom)) 12px;overflow:hidden}.map-first-shell .section-title{position:fixed;top:calc(max(8px,env(safe-area-inset-top)) + 68px);right:12px;z-index:50;display:block;width:auto}.map-first-shell .section-title>div:first-child{display:none}.map-first-shell .map-tools{display:grid;grid-template-columns:repeat(3,34px);width:auto;gap:5px;border:1px solid rgba(244,234,215,.16);border-radius:999px;padding:5px;background:var(--hud-surface);box-shadow:var(--soft-elevation);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.map-first-shell .map-tools button{width:34px;min-width:34px;min-height:34px;border:0;border-radius:999px;padding:0;font-size:12px;background:transparent;box-shadow:none}.map-first-shell .icon-tool-button .ui-icon,.map-first-shell .icon-action-button .ui-icon{width:20px;height:20px;padding:3px}.map-first-shell .icon-tool-button small,.map-first-shell .icon-action-button small,.map-first-shell .latest-event-strip{display:none}.map-first-shell .floor-rail{position:fixed;top:calc(max(8px,env(safe-area-inset-top)) + 66px);left:12px;z-index:50;display:grid;grid-template-columns:repeat(3,34px);gap:5px;margin:0;padding:5px;border:1px solid rgba(244,234,215,.16);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{width:34px;min-width:34px;min-height:34px;padding:0;border-radius:999px;box-shadow:none;background:transparent}.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{--active-room-size: clamp(68px, 21vw, 92px);width:max-content;height:max-content;min-height:0;max-width:min(100%,calc(4 * var(--active-room-size) + 3 * 8px + 22px));max-height:min(100%,calc(5 * var(--active-room-size) + 4 * 8px + 22px));gap:8px;overflow:auto;border:1px solid rgba(213,163,84,.28);border-radius:14px;padding:10px;background:radial-gradient(circle at 30% 18%,rgba(213,163,84,.13),transparent 7rem),linear-gradient(90deg,rgba(244,234,215,.04) 1px,transparent 1px) 0 0 / calc(var(--active-room-size) + 8px) calc(var(--active-room-size) + 8px),linear-gradient(0deg,rgba(244,234,215,.035) 1px,transparent 1px) 0 0 / calc(var(--active-room-size) + 8px) calc(var(--active-room-size) + 8px),#090807b8;box-shadow:0 22px 54px #00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.map-first-shell .map-board.fixed-floor-grid{grid-template-columns:repeat(4,var(--active-room-size));grid-template-rows:repeat(5,var(--active-room-size))}.map-first-shell .room-tile,.map-first-shell .fog-slot{width:var(--active-room-size);height:var(--active-room-size)}.map-first-shell .room-tile{border-width:2px;gap:3px;padding:7px}.map-first-shell .room-tile strong{font-size:clamp(10px,3vw,12px)}.map-first-shell .room-tile em,.map-first-shell .fog-slot span{font-size:9px}.map-first-shell .icon-row{min-height:16px}.map-first-shell .room-icon{padding:1px 4px;font-size:9px}.map-first-shell .token-row{gap:3px}.map-first-shell .player-token,.map-first-shell .monster-token{width:18px;height:18px;font-size:9px}.map-first-shell .current-room-summary,.map-first-shell .haunt-banner{position:fixed;right:12px;left:12px;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{bottom:calc(76px + env(safe-area-inset-bottom));display:grid;grid-template-columns:minmax(0,1fr) auto;gap:7px 10px;max-height:86px;margin:0;padding:9px 10px;overflow:hidden}.map-first-shell .current-room-summary .room-summary-main strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:16px}.map-first-shell .current-room-summary .room-summary-main p,.map-first-shell .current-room-summary .room-summary-meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.map-first-shell .current-room-summary .room-summary-icons{grid-column:1;min-height:20px}.map-first-shell .current-room-summary .room-summary-action{grid-column:2;grid-row:2;min-width:92px;min-height:34px;padding:0 8px;font-size:12px}.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:12px;bottom:calc(8px + env(safe-area-inset-bottom));left:12px;z-index:55;display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-rows:auto;width:auto;max-height:none;overflow:visible;gap:8px;border:1px solid var(--line);border-radius:var(--radius-card);padding:8px;background:var(--hud-surface);box-shadow:var(--soft-elevation);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.map-first-shell .dock-command-stack,.map-first-shell .dock-secondary-row{display:grid;grid-column:auto;grid-template-columns:repeat(3,minmax(0,1fr));grid-row:auto;width:100%;min-width:0;max-width:none;gap:8px;flex:none}.map-first-shell .dock-secondary-row{grid-template-columns:repeat(2,38px);width:auto}.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:46px;max-height:none;max-width:none;border:1px solid rgba(244,234,215,.18);border-radius:8px;padding:0 7px;font-size:12px;background:#f4ead714;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.map-first-shell .dock-secondary-row>button{width:38px;min-width:38px;padding:0}.map-first-shell .icon-action-button small{display:block;margin-top:2px;font-size:10px;line-height:1}.map-first-shell .dock-secondary-row .icon-action-button small{display:none}.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:46px}.map-first-shell .end-turn-suggested em{font-size:9px}.map-first-shell .action-dock.readonly{right:12px;bottom:calc(8px + env(safe-area-inset-bottom));left:12px;display:grid;grid-template-columns:minmax(0,1fr) 42px;align-items:center;width:auto;max-width:none;min-height:0;max-height:none;overflow:visible;gap:8px}.map-first-shell .action-dock.readonly strong{display:grid;min-height:42px;max-width:none;align-items:center;border:0;border-radius:8px;padding:0 10px;overflow:hidden;color:#f4ead7c7;text-overflow:ellipsis;white-space:nowrap;background:#f4ead714;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;font-size:12px;font-weight:500;line-height:1}.map-first-shell .action-dock.readonly>button{width:42px;min-width:42px;min-height:42px}.line-screen{width:min(100%,430px);min-height:100dvh;margin:0 auto;padding:calc(16px + env(safe-area-inset-top)) 14px calc(86px + env(safe-area-inset-bottom))}.line-card{border:1px solid rgba(244,234,215,.18);border-radius:10px;padding:13px;background:linear-gradient(180deg,#f4ead714,#f4ead709),var(--panel);box-shadow:0 12px 30px #00000042}.line-card+.line-card,.line-home-actions+.line-two-col,.line-card+.line-wide-primary,.line-wide-primary+.line-card{margin-top:12px}.line-card h2,.line-section-title{margin:0 0 10px;font-size:15px;line-height:1.2}.haunt-reveal-page{display:flex;flex-direction:column;gap:12px}.haunt-reveal-hero{min-height:310px;border:1px solid rgba(141,51,42,.58);border-radius:18px;padding:26px 18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;background:radial-gradient(circle at 50% 26%,rgba(141,51,42,.32),transparent 44%),linear-gradient(180deg,#201112f5,#120e0cfa);box-shadow:0 22px 60px #0000006b}.haunt-reveal-hero h1{margin:0;color:var(--text);font-size:34px;line-height:1.08}.haunt-reveal-hero p{margin:0;color:var(--muted);font-size:14px}.identity-seal{width:92px;height:92px;border:2px solid currentColor;border-radius:50%;display:grid;place-items:center;font-size:42px;font-weight:800}.identity-seal.traitor{color:var(--danger);background:#8d332a29}.identity-seal.heroes{color:var(--brass);background:#d5a35421}.identity-objective-card strong{display:block;margin:8px 0;color:var(--text);font-size:18px;line-height:1.35}.bottom-action-stack{position:sticky;bottom:0;z-index:4;margin-top:auto;padding:12px 0 calc(8px + env(safe-area-inset-bottom));background:linear-gradient(180deg,rgba(18,14,12,0),var(--bg) 28%)}.line-nav{display:grid;grid-template-columns:40px minmax(0,1fr) 72px;align-items:center;min-height:46px;margin-bottom:10px}.line-nav button{width:40px;min-height:40px;border:0;padding:0;color:var(--text);background:transparent;font-size:28px}.line-nav h1{margin:0;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap;font-size:20px}.line-nav span{color:var(--muted);text-align:right;font-size:11px}.line-home-title{padding:52px 0 22px;text-align:center}.line-home-title h1{margin:0;color:var(--brass);font-size:clamp(36px,11vw,48px);line-height:.95;letter-spacing:0}.line-home-title p{margin:10px 0 0;color:var(--muted);font-size:13px}.continue-card{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px}.continue-card span,.continue-card p,.mini-card span,.setting-row span,.scenario-body p,.join-code-card p{color:var(--muted)}.continue-card strong,.continue-card p{display:block;margin-top:8px}.line-link-button{min-height:44px;border:0;color:var(--brass);background:transparent;font-size:14px;font-weight:900}.line-home-actions{display:grid;gap:9px;margin-top:28px}.line-main-button,.line-wide-primary{display:flex;align-items:center;justify-content:center;min-height:52px;gap:8px;border:1px solid rgba(244,234,215,.2);border-radius:10px;color:var(--text);background:#f4ead70f;font-size:16px;font-weight:900}.line-main-button.primary,.line-wide-primary,.line-bottom-actions .primary{border-color:#d5a354bf;color:#1b1510;background:linear-gradient(180deg,#e8c37b,var(--brass))}.line-main-button .ui-icon{width:21px;height:21px}.line-two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.mini-card{display:flex;align-items:center;min-height:72px;gap:9px;text-align:left}.mini-card .ui-icon{width:28px;height:28px;padding:7px;border-radius:9px;background:var(--paper-soft)}.line-footer-tools{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:20px;border:1px solid rgba(244,234,215,.18);border-radius:10px;background:#f4ead70b}.line-footer-tools button{min-height:44px;border:0;color:var(--text);background:transparent}.scenario-body{display:grid;grid-template-columns:88px minmax(0,1fr);gap:11px;align-items:center}.scenario-art,.character-portrait-block,.character-detail-art{display:grid;place-items:center;border-radius:12px;background:linear-gradient(135deg,color-mix(in srgb,var(--character-color, var(--brass)) 50%,transparent),transparent),#f4ead714}.scenario-art{height:76px;color:var(--brass);font-size:25px;font-weight:900}.segmented-row,.floor-rail.overview-floor-rail{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(244,234,215,.2);border-radius:12px;overflow:hidden}.segmented-row button,.floor-rail.overview-floor-rail button{min-height:48px;border:0;border-radius:0;background:transparent}.segmented-row .active,.floor-rail.overview-floor-rail .active{color:#1b1510;background:var(--brass)}.setting-row{display:flex;align-items:center;justify-content:space-between;min-height:62px;border-top:1px solid rgba(244,234,215,.12)}.setting-row:first-of-type{border-top:0}.setting-row strong,.setting-row span{display:block}.toggle-off{width:48px;height:28px;border-radius:999px;background:#f4ead72e}.line-input,.hidden-code-input{width:100%;min-height:42px;border:1px solid rgba(244,234,215,.18);border-radius:8px;padding:0 11px;color:var(--text);background:#0907056b;font-size:14px}.code-box-row{display:grid;grid-template-columns:repeat(6,1fr) 68px;gap:7px;align-items:center}.code-box-row span{display:grid;place-items:center;min-height:46px;border:1px dashed rgba(244,234,215,.28);border-radius:8px;font-size:20px;font-weight:900}.code-box-row span.filled{border-style:solid;color:var(--brass);background:#d5a3541f}.hidden-code-input{margin-top:12px;text-transform:uppercase}.recent-room-row{display:grid;grid-template-columns:62px minmax(0,1fr) 46px;align-items:center;width:100%;min-height:58px;border:0;border-top:1px solid rgba(244,234,215,.12);color:var(--text);background:transparent;text-align:left}.recent-room-row em{color:var(--brass);font-style:normal;text-align:right}.line-bottom-actions{position:fixed;right:0;bottom:0;left:0;z-index:80;display:grid;grid-template-columns:1fr 1.6fr;gap:9px;width:min(100%,430px);margin:0 auto;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:linear-gradient(180deg,transparent,rgba(9,7,5,.94) 18%)}.line-bottom-actions button{min-height:46px;border:1px solid rgba(244,234,215,.2);border-radius:10px;color:var(--text);background:#f4ead712;font-size:14px;font-weight:900}.lobby-bottom-actions{grid-template-columns:repeat(4,minmax(0,1fr))}.line-stepper{display:grid;grid-template-columns:repeat(3,1fr);align-items:start;gap:8px;margin:4px 0 14px}.line-stepper span{position:relative;display:grid;justify-items:center;gap:6px}.line-stepper span:before{content:"";position:absolute;top:17px;right:50%;left:-50%;height:2px;background:#f4ead729}.line-stepper span:first-child:before{display:none}.line-stepper b{display:grid;place-items:center;width:30px;height:30px;border:1px solid rgba(244,234,215,.25);border-radius:50%;background:var(--paper)}.line-stepper .active b{color:#1b1510;background:var(--brass)}.line-stepper em{font-style:normal;font-weight:900}.lobby-meta-card{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.lobby-metric{display:flex;gap:7px;align-items:center;min-width:0}.lobby-metric span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lobby-settings-summary header,.lobby-player-card header,.overview-room-detail header{display:flex;align-items:center;justify-content:space-between;gap:12px}.lobby-settings-summary header button{border:0;color:var(--brass);background:transparent}.lobby-settings-summary>div{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;color:var(--muted)}.lobby-player-card .seat-grid{display:grid;gap:7px}.lobby-player-card .seat-card{display:grid;grid-template-columns:38px minmax(0,1fr) auto auto;align-items:center;gap:7px;min-height:58px;border:1px solid rgba(244,234,215,.14);border-radius:9px;padding:7px;background:#f4ead70b}.seat-token{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;color:#1b1510;background:var(--token-color, var(--brass));font-weight:900}.seat-card small,.seat-card em{color:var(--muted);font-style:normal}.seat-card button{min-height:32px;border-radius:8px;white-space:nowrap}.danger-inline{color:#ffd8d1;border-color:#8d332a99;background:var(--danger-soft)}.lobby-room-code{display:flex;align-items:center;justify-content:space-between;gap:9px}.lobby-room-code strong{display:block;color:var(--brass);font-size:22px}.lobby-ready-hint{margin:10px 0 0;color:var(--muted);text-align:center;font-size:12px}.role-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.role-select-lock{margin:-2px 0 10px;border:1px solid rgba(213,163,84,.28);border-radius:8px;padding:8px 10px;color:var(--muted);background:#d5a35414;font-size:12px;line-height:1.45}.role-card{position:relative;display:grid;grid-template-columns:48px minmax(0,1fr);gap:10px;min-height:126px;border:1px solid rgba(244,234,215,.18);border-radius:12px;padding:10px;color:var(--text);background:#f4ead70b;text-align:left}.role-card.selected{border-color:var(--brass);box-shadow:0 0 0 2px var(--brass-soft)}.role-card.occupied{opacity:.52}.role-card .character-portrait-block{grid-row:1 / span 3;width:48px;height:48px;background:linear-gradient(135deg,var(--character-color),transparent),#f4ead714}.role-card strong,.role-card em{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-card em{color:var(--muted);font-style:normal}.role-card i{position:absolute;top:8px;right:8px;color:var(--brass);font-style:normal}.mini-traits,.role-detail-traits{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;grid-column:1 / -1}.mini-traits span,.role-detail-traits span{border:1px solid rgba(244,234,215,.12);border-radius:8px;padding:5px 2px;text-align:center;font-size:12px}.role-detail-card{display:grid;grid-template-columns:84px minmax(0,1fr);gap:14px;margin-top:12px}.character-detail-art{width:84px;height:84px}.role-detail-card ul{margin:8px 0 0;padding-left:18px}.map-first-shell .map-tools{grid-template-columns:repeat(4,34px)}.map-first-shell .map-section{padding-top:calc(max(8px,env(safe-area-inset-top)) + 116px)}.map-first-shell .floor-rail{left:50%;transform:translate(-50%)}.map-first-shell .section-title{top:calc(max(8px,env(safe-area-inset-top)) + 67px)}.room-tile .door{position:absolute;z-index:3;display:block;background:var(--brass);box-shadow:0 0 0 1px #090705cc}.room-tile .door.north,.room-tile .door.south{left:50%;width:18px;height:6px;transform:translate(-50%)}.room-tile .door.north{top:-4px}.room-tile .door.south{bottom:-4px}.room-tile .door.east,.room-tile .door.west{top:50%;width:6px;height:18px;transform:translateY(-50%)}.room-tile .door.east{right:-4px}.room-tile .door.west{left:-4px}.map-overview-backdrop{align-items:stretch;overflow:auto}.map-overview-screen{min-height:100dvh}.overview-floor-rail{grid-template-columns:repeat(3,1fr);margin:0 0 14px}.overview-board{--active-room-size: min(19vw, 76px);width:max-content;margin:0 auto;gap:8px;padding:10px;border:1px solid rgba(213,163,84,.28);border-radius:14px;background:#090705b8}.overview-board .room-tile{width:var(--active-room-size);height:var(--active-room-size);padding:6px}.overview-board .room-tile strong{font-size:11px}.overview-room-detail{margin-top:12px}.overview-room-detail button{min-height:42px;margin-top:10px}.overview-legend{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px;padding:14px;border:1px solid rgba(244,234,215,.18);border-radius:12px;background:#f4ead70b}.version-warning{position:fixed;top:calc(58px + env(safe-area-inset-top));right:12px;left:12px;z-index:90;margin:0;border:1px solid rgba(141,51,42,.68);border-radius:12px;padding:10px 12px;color:#ffd8d1;background:#200a08eb;font-size:13px}@media(max-width:380px){.line-screen{padding-right:12px;padding-left:12px}.role-grid,.line-two-col,.lobby-meta-card{grid-template-columns:1fr}.code-box-row{grid-template-columns:repeat(6,1fr)}.code-box-row button{grid-column:1 / -1}}
