:root{--bg: #050d0b;--bg-deep: #020504;--panel: rgba(8, 24, 19, .92);--paper: #0d1d17;--paper-soft: rgba(229, 225, 207, .06);--brass: #9bd56f;--brass-soft: rgba(155, 213, 111, .18);--danger: #b84b42;--danger-soft: rgba(184, 75, 66, .22);--moss: #9bd56f;--moss-soft: rgba(155, 213, 111, .18);--fog: rgba(143, 155, 135, .14);--text: #e5e1cf;--muted: #8f9b87;--line: rgba(151, 179, 136, .22);--line-strong: rgba(174, 217, 128, .48);--shadow: rgba(0, 0, 0, .38);--hud-surface: rgba(7, 18, 14, .78);--hud-surface-strong: rgba(5, 13, 11, .94);--hud-cell: rgba(229, 225, 207, .045);--hud-cell-active: rgba(155, 213, 111, .13);--sheet-surface: linear-gradient(180deg, rgba(229,225,207,.07), rgba(229,225,207,.025)), 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: 8px;--radius-sheet: 10px;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(155,213,111,.12),transparent 20rem),radial-gradient(circle at 100% 0,rgba(184,75,66,.16),transparent 18rem),linear-gradient(135deg,rgba(229,225,207,.025),transparent 22%),var(--bg);font-size:14px;line-height:1.42}button,input{min-height:38px;border:1px solid var(--line);border-radius:var(--radius-card);color:inherit;background:var(--paper-soft);font:inherit}button{padding:0 10px;font-size:12px;font-weight:800;cursor:pointer;touch-action:manipulation}button.primary{border-color:#9bd56fb8;color:#06100c;background:linear-gradient(180deg,#b4df87,var(--brass));box-shadow:0 10px 22px #9bd56f24}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:8px 10px 112px;background:linear-gradient(90deg,rgba(229,225,207,.025) 1px,transparent 1px) 0 0 / 32px 32px,radial-gradient(circle at 0 0,rgba(155,213,111,.08),transparent 18rem),var(--bg)}.app-shell.phase-haunt{--bg: #050d0b;--panel: rgba(8, 24, 19, .94);--paper: #0b1b15;--paper-soft: rgba(143, 191, 115, .08);--brass: #9dbb75;--brass-soft: rgba(143, 191, 115, .2);--danger: #b84b42;--danger-soft: rgba(184, 75, 66, .28);--moss: #9bd56f;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:104px minmax(0,1fr) 56px 52px;gap:0;border:1px solid var(--line);border-radius:8px;padding:0;background:var(--hud-surface-strong);box-shadow:0 10px 28px var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden}.hud-cell{min-width:0;border-right:1px solid var(--line);border-radius:0;padding:7px 8px;background:#e5e1cf09}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:2px;overflow:visible;overflow-wrap:anywhere;white-space:normal;font-size:13px;line-height:1.18}.room-code strong{display:flex;align-items:center;justify-content:space-between;gap:4px;color:var(--brass);letter-spacing:.08em}.sync-dot{position:relative;display:block;margin-top:4px;padding-left:12px;color:var(--muted);font-size:11px;font-style:normal;font-weight:900;line-height:1}.sync-dot:before{content:"";position:absolute;left:0;top:50%;width:8px;height:8px;transform:translateY(-50%);border-radius:999px;background:var(--muted)}.sync-dot.open{color:#a8d88f}.sync-dot.open:before{background:#9dcc76}.sync-dot.connecting:before{background:#e9cb82}.sync-dot.error:before,.sync-dot.closed:before{background:#c46b5c}.self-cell{display:grid;grid-template-columns:minmax(0,1fr);align-items:center;gap:4px}.self-identity-line{display:grid;grid-template-columns:28px minmax(0,1fr);align-items:center;gap:7px;min-width:0}.self-cell b{display:grid;place-items:center;width:28px;height:28px;border:1px solid rgba(155,213,111,.38);border-radius:7px;color:var(--text);background:radial-gradient(circle at 50% 38%,rgba(229,225,207,.18),transparent 48%),#0000006b;font-size:13px}.self-cell strong{margin:0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px}.self-cell>div>span{display:none}.self-cell>div>span.self-identity-line{display:grid}.self-cell .attribute-strip{margin-top:4px}.omen-cell{display:grid;align-content:center;justify-items:center;text-align:center}.omen-cell strong{margin:0;color:#d8b86a;font-size:20px;line-height:1}.omen-cell small{margin-top:2px;color:var(--muted);font-size:10px;font-weight:900}.more-menu-button{display:grid!important;place-items:center;gap:2px;border-right:0;text-align:center!important}.more-menu-button .ui-icon{width:22px;height:22px}.more-menu-backdrop{position:fixed;inset:0;z-index:42;background:#0000002e}.more-menu-popover{position:fixed;top:calc(62px + env(safe-area-inset-top));right:max(10px,env(safe-area-inset-right));display:grid;grid-template-columns:repeat(2,minmax(94px,1fr));gap:6px;width:min(238px,calc(100vw - 20px));border:1px solid var(--line-strong);border-radius:8px;padding:10px;background:#07120efa;box-shadow:0 18px 42px #00000073}.more-menu-tip{position:absolute;top:-7px;right:24px;width:12px;height:12px;transform:rotate(45deg);border-left:1px solid var(--line-strong);border-top:1px solid var(--line-strong);background:#07120efa}.more-menu-popover button{min-height:54px;display:grid;place-items:center;gap:4px;border-radius:7px;color:var(--text);font-weight:900}.more-menu-popover button:disabled{opacity:.36}.more-menu-popover button.danger{border-color:#bf4c3dad;color:#ff9f92;background:#8d332a2e}.more-menu-popover .ui-icon{width:22px;height:22px}.room-code .ui-icon{width:16px;height:16px;flex:0 0 auto;color:var(--muted);letter-spacing:0}.room-code:not(:disabled){cursor:pointer}.room-code:not(:disabled):active{border-color:var(--line-strong);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:minmax(0,1fr) auto auto;align-items:center;gap:6px 10px;width:100%;margin-top:8px;border:1px solid rgba(213,163,84,.34);border-radius:8px;padding:9px 10px;text-align:left;background:linear-gradient(135deg,rgba(213,163,84,.1),transparent 48%),#f4ead70e}.current-room-summary:active{border-color:#d5a354b3;background:#d5a3541a}.room-summary-main,.room-summary-meta{min-width:0}.room-summary-main span,.room-summary-meta span{display:block;overflow:hidden;overflow-wrap:anywhere;text-overflow:ellipsis;color:var(--muted);white-space:nowrap;font-size:12px}.room-summary-main strong{display:block;margin-top:3px;overflow:hidden;overflow-wrap:anywhere;text-overflow:ellipsis;white-space:normal;font-size:20px;line-height:1.1}.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 / -2}.room-summary-chevron{grid-column:3;grid-row:1 / span 2;color:var(--muted);font-size:28px;line-height:1}.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,#e5e1cf12,#e5e1cf06),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:8px;border:1px solid rgba(184,75,66,.58);border-radius:8px;padding:7px 9px;background:linear-gradient(90deg,#b84b422e,#07120e94)}.haunt-banner-heading{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px}.haunt-banner-heading button{min-height:30px;border-color:var(--line);padding:0 10px;color:var(--text);background:#e5e1cf0f;font-size:12px;font-weight:900}.haunt-banner span{color:#d8b86a;font-size:12px;font-weight:900}.haunt-banner h2{margin:1px 0 0;overflow:hidden;font-size:17px;text-overflow:ellipsis;white-space:nowrap}.haunt-banner p,.haunt-banner strong{display:block;margin-top:4px;overflow:hidden;color:#f4ead7cc;font-size:12px;line-height:1.42;text-overflow:ellipsis;white-space:nowrap}.haunt-banner-detail{display:grid;gap:5px;margin-top:8px;border-top:1px solid rgba(229,225,207,.12);padding-top:8px}.haunt-banner.expanded p,.haunt-banner.expanded strong{white-space:normal}.haunt-banner-detail span{color:var(--muted);font-size:11px;line-height:1.35}.haunt-objective-panel{display:grid;gap:12px}.haunt-objective-grid{display:grid;gap:10px}.haunt-objective-grid article{border:1px solid rgba(213,163,84,.28);border-radius:8px;padding:11px;background:#f4ead70e}.haunt-objective-grid span,.haunt-progress-row span{color:var(--brass);font-size:11px;font-weight:900}.haunt-objective-grid p{margin-top:6px;color:#f4ead7db;line-height:1.45}.haunt-progress-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:8px}.haunt-progress-row div{display:grid;min-width:0;gap:3px;border:1px solid rgba(244,234,215,.14);border-radius:8px;padding:9px;background:#00000029}.haunt-progress-row strong{overflow:hidden;color:var(--text);font-size:13px;text-overflow:ellipsis;white-space:nowrap}.turn-guidance{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;margin-top:8px;border:1px solid var(--line);border-radius:8px;padding:8px 9px;background:#081813b8}.turn-guidance.waiting{border-color:#f4ead729;background:#f4ead70b}.turn-guidance.choice{border-color:#d8b86a94;background:#d8b86a1a}.turn-guidance.ending{border-color:#b84b4280;background:#b84b4221}.turn-guidance span{color:var(--brass);font-size:11px;font-weight:900}.turn-guidance strong{display:block;margin-top:0;overflow:hidden;font-size:15px;text-overflow:ellipsis;white-space:nowrap}.turn-guidance p{margin:2px 0 0;overflow:hidden;color:var(--muted);font-size:12px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.turn-guidance button{min-width:82px;min-height:36px;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)}.player-readonly-list article{border:1px solid var(--line);border-radius:8px;background:#f4ead70b;overflow:hidden}.player-readonly-list article.owned{border-color:#d5a3548c}.player-readonly-list article.turn{box-shadow:inset 3px 0 0 var(--moss)}.player-row-button{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;width:100%;min-height:46px;border:0;border-radius:0;padding:8px;text-align:left;background:transparent}.player-row-button>span{display:grid;place-items:center;width:28px;height:28px;border-radius:999px;color:#1b1510;background:var(--brass);font-size:12px;font-weight:900}.player-row-button div{min-width:0}.player-row-button strong{display:block;overflow:hidden;text-overflow:ellipsis;color:var(--paper);font-size:13px;white-space:nowrap}.player-row-button p{margin:3px 0 0;overflow:hidden;text-overflow:ellipsis;color:var(--muted);font-size:12px;white-space:nowrap}.player-row-button em{color:var(--brass);font-size:11px;font-style:normal;font-weight:900}.player-expanded-detail{display:grid;gap:7px;border-top:1px solid var(--line);padding:8px}.player-expanded-detail dl{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin:0}.player-expanded-detail dl div{min-width:0}.player-expanded-detail dt{color:var(--muted);font-size:10px;font-weight:900}.player-expanded-detail dd{margin:2px 0 0;overflow-wrap:anywhere;color:var(--paper);font-size:12px;line-height:1.25}.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,.monster-status-list{display:grid;gap:6px;margin-top:8px}.monster-status-list article{min-width:0;border:1px solid var(--line);border-radius:7px;padding:8px;background:#f4ead70b}.monster-status-list article div{display:flex;align-items:center;justify-content:space-between;gap:8px}.monster-status-list strong{overflow:hidden;text-overflow:ellipsis;color:var(--paper);font-size:13px;white-space:nowrap}.monster-status-list span{flex:0 0 auto;border:1px solid rgba(213,163,84,.38);border-radius:999px;padding:2px 6px;color:var(--brass);font-size:10px;font-weight:900}.monster-status-list p{margin:5px 0 0;overflow-wrap:anywhere;color:var(--muted);font-size:11px;line-height:1.35}.map-section{margin-top:8px}.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:8px;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}.map-header-controls{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;min-width:0}.map-header-controls>span{min-width:0;overflow:hidden;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-weight:800}.floor-tabs{display:grid;grid-template-columns:repeat(3,46px);border:1px solid var(--line);border-radius:7px;overflow:hidden;background:#0000002e}.floor-tabs button{min-height:34px;border:0;border-right:1px solid var(--line);border-radius:0;color:var(--muted);background:transparent;font-size:14px}.floor-tabs button:last-child{border-right:0}.floor-tabs button.active{color:#06100c;background:var(--moss);box-shadow:inset 0 0 0 1px #f4ead738}.map-board{position:relative;display:grid;grid-template-columns:repeat(var(--cols),118px);grid-template-rows:repeat(var(--rows),112px);gap:10px;min-height:286px;overflow:auto;border:1px solid var(--line);border-radius:8px;padding:12px;background:radial-gradient(circle at 20% 15%,rgba(155,213,111,.08),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,minmax(0,1fr));grid-template-rows:repeat(5,minmax(74px,1fr));aspect-ratio:4 / 5;min-height:0;overflow:visible}.map-board.fixed-floor-grid .room-tile,.map-board.fixed-floor-grid .fog-slot{width:auto;height:auto;min-width:0}.room-tile{z-index:1;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:var(--line-strong);box-shadow:0 0 0 2px var(--brass-soft),0 0 18px #9bd56f2e,0 12px 20px #00000042}.room-tile.can-move{border-color:#9bd56fe0;background:linear-gradient(135deg,rgba(155,213,111,.12),transparent 42%),var(--room-fill, rgba(13, 29, 23, .98))}.room-tile.can-explore{border-style:dashed;border-color:#d8b86ac7;background:repeating-linear-gradient(135deg,rgba(216,184,106,.08) 0 6px,transparent 6px 12px),#d8b86a14,var(--fog)}.room-tile.danger-room{border-color:#b84b42d6;box-shadow:inset 0 0 0 1px #b84b423d,0 0 18px #b84b4229}.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:14px}.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}.room-icon.transit{display:inline-grid;grid-template-columns:auto auto;align-items:center;gap:3px;color:#dff0ff;background:#486e8499}.room-action-tag{position:absolute;right:5px;bottom:5px;border:1px solid rgba(229,225,207,.16);border-radius:999px;padding:1px 5px;color:#06100c;background:var(--moss);font-size:10px;font-weight:900;line-height:1.3}.room-tile.can-explore .room-action-tag{background:#d8b86a}.room-icon.transit .ui-icon{width:12px;height:12px}.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);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:10px;font-weight:900}.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:11px}.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 var(--line-strong);border-radius:8px;color:#f4ead7c7;text-align:center;background:radial-gradient(circle,rgba(155,213,111,.12),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:none;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}.room-facts{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.room-facts div{min-width:0;border:1px solid var(--line);border-radius:7px;padding:6px;background:#f4ead70b}.room-facts span{display:block;color:var(--muted);font-size:10px;font-weight:800}.room-facts strong{display:block;margin-top:3px;overflow-wrap:anywhere;color:var(--paper);font-size:12px;line-height:1.15}.compact-action{min-height:34px;border-radius:7px;padding:0 10px;font-size:12px}.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}.room-rule-summary{display:grid;gap:6px;margin:0;padding:0;list-style:none}.room-rule-summary li{border:1px solid rgba(229,225,207,.12);border-radius:7px;padding:7px 8px;color:#efebd5e0;background:#00000029;font-size:12px;line-height:1.35}.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}.compact-chips strong,.compact-chips em{display:block}.compact-chips em{margin-top:3px;color:#f4ead79e;font-style:normal;font-weight:700}.danger-chip{border-color:#9f2e2e70!important;background:#9f2e2e29!important}.action-disabled-reason{margin-top:5px;color:#f0c09a;font-size:12px;font-weight:800}.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.used{opacity:.78}.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-copy{min-width:0}.inventory-card-copy p{margin:5px 0 0;color:#f4ead7b8;font-size:12px;line-height:1.35;overflow-wrap:anywhere}.inventory-card-copy em{display:inline-block;margin-top:6px;border:1px solid rgba(213,163,84,.38);border-radius:999px;padding:2px 7px;color:var(--brass);font-size:11px;font-style:normal;font-weight:900}.inventory-card-actions{display:flex;flex-wrap:wrap;gap:6px;grid-column:2}.inventory-card .action-disabled-reason{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-move-list{display:grid;gap:7px}.room-move-list button{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;min-height:38px;border:1px solid rgba(135,179,106,.36);border-radius:7px;padding:7px 9px;text-align:left;background:#87b36a17}.room-move-list button:disabled{opacity:.52}.room-move-list span{min-width:0;overflow-wrap:anywhere;color:var(--paper);font-weight:900}.room-move-list em{color:var(--muted);font-size:11px;font-style:normal;white-space:nowrap}.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:6px;margin:0;padding:0;color:#f4ead7c2;list-style:none;font-size:12px;line-height:1.34}.event-log li{display:grid;align-items:start;gap:5px;border-left:1px solid var(--brass-soft);padding-left:7px}.event-log li.expanded{border-left-color:var(--moss)}.event-log-entry{display:grid;grid-template-columns:42px auto minmax(0,1fr);align-items:start;gap:6px;width:100%;border:none;padding:0;text-align:left;background:transparent;color:inherit;font:inherit;line-height:1.42;cursor:default}.event-sequence{color:var(--muted);font-size:10px;font-weight:900;line-height:22px}.event-log li.inspectable .event-log-entry{cursor:pointer;border-radius:6px}.event-log li.inspectable .event-log-entry:hover{background:#d5a3541a}.event-log-entry>span:last-child{min-width:0;overflow-wrap:anywhere}.event-log-detail{display:grid;gap:6px;border:1px solid var(--line);border-radius:7px;padding:7px;background:#f4ead70b}.event-log-detail dl{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin:0}.event-log-detail dt{color:var(--muted);font-size:10px;font-weight:900}.event-log-detail dd{margin:2px 0 0;overflow-wrap:anywhere;color:#e5e1cfe0;font-size:11px;line-height:1.25}.event-card-link{justify-self:start;min-height:28px;border-radius:6px;padding:0 8px;color:var(--brass);font-size:11px}.log-local-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin-bottom:8px}.log-local-actions button{min-height:32px;border-radius:7px;font-size:11px}.latest-event-strip{width:100%;min-height:40px;display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;gap:6px;margin-top:6px;border:1px solid rgba(213,163,84,.32);border-radius:8px;padding:6px 8px;text-align:left;color:var(--paper);background:#f4ead70b}.latest-event-icon{display:grid;place-items:center;min-width:36px;min-height:24px;border:1px solid rgba(135,179,106,.34);border-radius:6px;color:var(--moss);background:#87b36a1a;font-size:11px;font-weight:900}.latest-event-strip strong{min-width:0;display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow-wrap:anywhere;font-size:12px;line-height:1.25}.latest-event-strip em{color:var(--muted);font-size:24px;font-style:normal;line-height:1}.event-log-entry:disabled{cursor:default}.dice-result-strip{display:inline-grid;place-items:center;min-width:36px;height:24px;border:1px solid rgba(213,163,84,.42);border-radius:6px;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.dice{grid-template-columns:1fr auto;gap:4px;height:auto;min-height:24px;min-width:82px;border-radius:6px;padding:3px 5px}.dice-icons{display:flex;flex-wrap:wrap;gap:2px}.dice-icons i{display:grid;place-items:center;width:15px;height:15px;border:1px solid rgba(27,21,16,.34);border-radius:4px;background:#fff6d1b8;font-size:10px;font-style:normal;line-height:1}.dice-result-strip.dice strong{font-size:13px}.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:7px;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:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;border-top:1px solid var(--line);padding:8px max(10px,env(safe-area-inset-right)) calc(8px + 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.compact{width:100%;max-width:480px;margin:0 auto}.action-dock.readonly{min-height:66px;align-items:center;color:var(--muted)}.action-dock.waiting-dock{align-items:stretch}.dock-state-label{flex:1 1 100%;color:var(--muted);font-size:12px;line-height:1.2;text-align:center}.action-dock>button,.dock-command-stack>button,.dock-secondary-row>button{width:100%;max-width:none}.action-dock.compact>button{min-height:50px;border-radius:8px}.action-dock.compact .end-turn-button{max-width:none}.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:none;margin-top:2px;color:#1b1510c7;font-size:10px;font-weight:900;font-style:normal;line-height:1.15}.attack-target-list{display:grid;gap:8px}.attack-context{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;padding:8px;background:#f4ead70b}.attack-context span,.weapon-picker>span{color:var(--muted);font-size:11px;font-weight:900}.attack-context strong{min-width:0;overflow:hidden;text-overflow:ellipsis;color:var(--paper);white-space:nowrap}.attack-context em{color:var(--muted);font-size:11px;font-style:normal}.attack-target-button{display:grid;grid-template-columns:32px minmax(0,1fr) auto;align-items:center;gap:10px;width:100%;min-height:52px;text-align:left}.attack-target-button.selected{border-color:#87b36ab8;background:#87b36a29}.attack-target-button .ui-icon{width:24px;height:24px}.attack-target-button span{grid-column:2;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:900}.attack-target-button small{grid-column:2 / -1;min-width:0;overflow-wrap:anywhere;color:var(--muted);font-size:11px;line-height:1.25}.attack-target-button em{color:#f4ead7b8;font-size:11px;font-style:normal;font-weight:800}.weapon-picker{display:grid;gap:7px;margin-top:8px}.weapon-picker>div{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.weapon-picker button{display:grid;gap:4px;min-height:58px;border:1px solid var(--line);border-radius:8px;padding:8px;text-align:left;background:#f4ead70b}.weapon-picker button.selected{border-color:#d5a354a8;background:#d5a3541f}.weapon-picker strong{color:var(--paper);font-size:13px}.weapon-picker em{color:var(--muted);font-size:11px;font-style:normal;line-height:1.25}.attack-result-toast{position:fixed;right:max(10px,env(safe-area-inset-right));bottom:calc(92px + env(safe-area-inset-bottom));left:max(10px,env(safe-area-inset-left));z-index:31;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;max-width:456px;margin:0 auto;border:1px solid rgba(244,234,215,.22);border-radius:8px;padding:8px;background:#100c08f5;box-shadow:0 12px 28px #0006;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.attack-result-toast.hit{border-color:#b4383894;background:linear-gradient(90deg,rgba(159,46,46,.2),transparent 62%),#100c08f5}.attack-result-toast.miss{border-color:#d5a3545c}.attack-result-main{display:grid;grid-template-columns:28px minmax(0,1fr) auto;align-items:center;gap:8px;min-width:0;min-height:0;border:0;padding:0;color:var(--text);background:transparent;box-shadow:none;text-align:left}.attack-score-grid{grid-column:1 / -1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.attack-score-grid span{border:1px solid var(--line);border-radius:7px;padding:6px;text-align:center;background:#f4ead70b}.attack-score-grid b,.attack-score-grid strong{display:block}.attack-score-grid b{color:var(--muted);font-size:10px}.attack-score-grid strong{margin-top:2px;color:var(--paper);font-size:16px}.attack-result-main .ui-icon{width:22px;height:22px;color:var(--danger)}.attack-result-main span{min-width:0}.attack-result-main strong,.attack-result-main small{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attack-result-main strong{font-size:13px;line-height:1.2}.attack-result-main small{margin-top:2px;color:var(--muted);font-size:11px;line-height:1.25}.attack-result-main em{border-radius:999px;padding:4px 6px;color:#1b1510;background:#f4ead7db;font-size:12px;font-style:normal;font-weight:900}.attack-result-outcome{grid-column:1 / -1;justify-self:start;border-radius:999px;padding:5px 7px;color:#f4ead7;background:#9f2e2eb8;font-size:12px;font-weight:900;line-height:1;white-space:nowrap}.attack-result-toast p{grid-column:1 / -1;margin:0;color:var(--muted);font-size:12px;line-height:1.35;overflow-wrap:anywhere}.attack-result-log{grid-column:1 / -1;min-height:34px;border-radius:7px;font-size:12px}.attack-result-toast.miss .attack-result-outcome{color:#1b1510;background:#d5a354db}.attack-result-close{grid-column:2;grid-row:1;width:28px;min-width:28px;height:28px;min-height:28px;border-radius:999px;padding:0;color:var(--muted);background:#f4ead714;font-size:13px;line-height:1}.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,.random-character-modal{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{width:min(100%,380px);display:grid;align-content:start;gap:9px;text-align:center}.card-modal span{justify-self:center;border-radius:6px;padding:4px 9px;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{padding-inline:32px;font-size:22px;line-height:1.18}.reveal-card-frame{display:grid;gap:8px;border:1px solid rgba(213,163,84,.34);border-radius:8px;padding:10px;background:#06120e94}.reveal-card-frame header{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;text-align:left}.reveal-card-frame header b{border:1px solid rgba(213,163,84,.42);border-radius:5px;padding:3px 7px;color:var(--brass);font-size:11px}.reveal-card-frame header strong{min-width:0;overflow-wrap:anywhere;color:var(--paper);font-size:16px}.card-illustration{display:grid;place-items:center;justify-self:center;width:min(176px,58vw);min-height:min(128px,24dvh);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{display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:3;border:1px solid rgba(213,163,84,.24);border-radius:8px;margin:0;padding:10px;color:#2c2116;background:#ecddbee6;text-align:left;line-height:1.55}.card-modal p.card-outcome{font-weight:700;background:#ecddbeb8}.reveal-card-frame .card-illustration{width:100%;min-height:138px}.reveal-card-meta{display:grid;gap:6px;margin:0;text-align:left}.reveal-card-meta div{display:grid;grid-template-columns:64px minmax(0,1fr);gap:8px}.reveal-card-meta dt{color:var(--muted);font-size:11px;font-weight:900}.reveal-card-meta dd{margin:0;overflow-wrap:anywhere;color:var(--paper);font-size:12px;font-weight:800}.card-detail-list{display:grid;gap:6px;margin:0;border:1px solid rgba(213,163,84,.24);border-radius:8px;padding:9px 10px;color:#2c2116;background:#ecddbedb;text-align:left}.card-detail-list div{display:grid;grid-template-columns:52px minmax(0,1fr);gap:8px;align-items:start}.card-detail-list dt{color:#2c2116ad;font-weight:900}.card-detail-list dd{min-width:0;margin:0;font-weight:800;line-height:1.45;overflow-wrap:anywhere}.card-dice-result{display:grid;grid-template-columns:minmax(0,1fr);align-items:start;gap:8px;border:1px solid rgba(213,163,84,.36);border-radius:8px;padding:9px 10px;color:var(--paper);background:#00000038;text-align:left}.card-dice-result strong{min-width:0;display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2;color:var(--paper);overflow-wrap:anywhere}.haunt-dice-row,.card-dice-row,.pending-roll-dice-row{display:grid;grid-template-columns:repeat(6,minmax(28px,1fr));gap:6px}.haunt-dice-row i,.card-dice-row i,.pending-roll-dice-row i{display:grid;place-items:center;min-height:32px;border:1px solid rgba(244,234,215,.24);border-radius:6px;color:var(--paper);background:#00000038;font-size:14px;font-style:normal;font-weight:900}.haunt-dice-row i.success,.card-dice-row i.success{color:#152112;background:var(--moss)}.haunt-dice-row i.fail,.card-dice-row i.fail{color:#ffe0d8;background:#9f2e2eb3}.card-modal strong{color:#f0b49f}.card-modal .choice-option-list:empty{display:none}.choice-modal{display:grid;gap:12px;text-align:center}.choice-context-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.choice-context-grid section{min-width:0;border:1px solid var(--line);border-radius:7px;padding:7px;text-align:left;background:#f4ead70b}.choice-context-grid span{display:block;color:var(--muted);font-size:11px;font-weight:900}.choice-context-grid strong{display:block;margin-top:3px;overflow-wrap:anywhere;color:var(--paper);font-size:13px}.choice-option-card{display:grid;gap:4px;min-height:56px;border:1px solid rgba(135,179,106,.38);border-radius:8px;padding:8px 10px;text-align:left;background:#87b36a14}.choice-option-card span,.modifier-card-button span{color:var(--paper);font-weight:900}.choice-option-card em,.modifier-card-button em{color:var(--muted);font-size:11px;font-style:normal;line-height:1.25}.pending-roll-modal small{color:var(--paper-muted);font-weight:800}.pending-roll-action{display:grid;grid-template-columns:minmax(0,1fr);gap:8px}.modifier-card-button{display:grid;gap:3px;min-height:46px;border:1px solid rgba(213,163,84,.36);border-radius:8px;padding:8px 10px;text-align:left;background:#d5a35414}.pending-roll-action select{width:100%;min-height:42px;border:1px solid var(--line);border-radius:8px;padding:0 10px;color:var(--paper);background:#00000047;font:inherit;font-weight:800}.room-zoom-overlay{position:relative;width:min(96vw,460px);max-height:calc(100dvh - 28px - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow:auto;border:1px solid var(--line);border-radius:12px;padding:16px;display:grid;gap:12px;text-align:center;background:linear-gradient(180deg,#f4ead717,#f4ead70a),var(--panel);box-shadow:0 24px 60px #0000007a}.room-zoom-tile{position:relative;display:grid;gap:8px;justify-items:center;padding:18px;min-height:min(58vw,300px);border:1.5px solid var(--room-border, var(--brass));border-radius:12px;background:var(--room-fill, rgba(0,0,0,.18))}.room-zoom-tile .door{position:absolute;background:var(--brass);border-radius:2px}.room-zoom-tile .door.north{top:-3px;left:50%;width:36px;height:6px;transform:translate(-50%)}.room-zoom-tile .door.south{bottom:-3px;left:50%;width:36px;height:6px;transform:translate(-50%)}.room-zoom-tile .door.east{right:-3px;top:50%;width:6px;height:36px;transform:translateY(-50%)}.room-zoom-tile .door.west{left:-3px;top:50%;width:6px;height:36px;transform:translateY(-50%)}.room-zoom-tile .icon-row{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.room-zoom-drops,.room-zoom-transits,.room-zoom-moves{display:grid;gap:8px;text-align:left}.drop-card-list{display:grid;gap:8px}.drop-card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;padding:8px 10px;text-align:left;background:#f4ead70f}.drop-card:disabled{opacity:.55}.transit-action-list{display:grid;gap:8px}.transit-action-button{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;min-height:42px;border:1px solid rgba(72,110,132,.56);border-radius:8px;padding:8px 10px;text-align:left;background:#486e8429}.transit-action-button span{min-width:0;overflow-wrap:anywhere;color:var(--text);font-weight:800}.transit-action-button em{color:var(--muted);font-size:12px;font-style:normal;white-space:nowrap}.transit-action-button:disabled{opacity:.52}.seat-rename-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:6px;align-items:center}.seat-rename-form input{min-width:0;padding:5px 8px;border:1px solid var(--brass-soft);border-radius:6px;background:#00000040;color:var(--text);font:inherit;font-size:13px}.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}.random-character-modal{display:grid;gap:12px;text-align:center}.random-character-modal .screen-kicker{justify-self:center;border-radius:999px;padding:5px 10px;color:#1b1510;font-size:12px;font-weight:900;background:var(--brass)}.random-character-modal h2{font-size:18px;line-height:1.35}.random-character-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.random-character-card{min-height:132px}.random-character-card .character-portrait-block{grid-row:1 / span 3;width:48px;height:48px;border-radius:8px;background:linear-gradient(135deg,var(--character-color),transparent),#f4ead714}.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}.haunt-transition-grid,.haunt-camp-grid,.result-kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.haunt-transition-grid section,.result-kpi-grid section{min-width:0;border:1px solid var(--line);border-radius:8px;padding:8px;background:#f4ead70b}.haunt-transition-grid span,.result-kpi-grid span{display:block;color:var(--muted);font-size:11px}.haunt-transition-grid strong,.result-kpi-grid strong{display:block;margin-top:4px;border:0;padding:0;overflow-wrap:anywhere;background:transparent;color:var(--paper);font-size:13px}.haunt-camp-grid{grid-template-columns:1fr}.haunt-rules-card p+p{margin-top:8px;border-top:1px solid var(--line);padding-top:8px;color:#f0c09a}.result-summary-grid{display:grid;gap:8px}.result-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.result-summary-grid section{text-align:left}.result-panel h3{font-size:15px}.recap-timeline{display:grid;gap:6px;text-align:left}.recap-timeline li{display:grid;gap:6px}.recap-timeline button{display:grid;gap:4px}.recap-timeline button strong{color:var(--brass);font-size:11px}.recap-timeline button span,.recap-timeline p{margin:0;color:var(--muted);font-size:12px;line-height:1.35;overflow-wrap:anywhere}.battle-report-block{text-align:left}.result-panel ol{display:grid;gap:8px;margin:0;padding:0;list-style:none}.result-panel li{display:grid;gap:12px;border:1px solid var(--line);border-radius:8px;padding:9px;background:#00000029}.result-panel li>button,.recap-timeline button{width:100%;border:0;padding:0;color:inherit;background:transparent;text-align:inherit}.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-player-grid li>button{display:grid;justify-items:center;gap:5px}.result-player-detail{width:100%;border-top:1px solid var(--line);padding-top:7px}.result-player-detail p{margin:6px 0 0;color:var(--muted);font-size:11px}.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}.haunt-objective-panel{display:grid;gap:10px}.haunt-rule-list{display:grid;gap:8px}.haunt-rule-list article{border:1px solid var(--line);border-radius:8px;padding:9px;background:#f4ead70b}.haunt-rule-list span{display:block;color:var(--brass);font-size:12px;font-weight:900}.haunt-rule-list p{margin:6px 0 0;color:var(--muted);font-size:12px;line-height:1.45}.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;top:calc(40px + env(safe-area-inset-top));left:50%;z-index:60;width:min(calc(100vw - 24px),456px);margin:0;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;text-align:center;transform:translate(-50%)}.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(4,minmax(34px,1fr));width:min(210px,64vw);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{top:calc(40px + env(safe-area-inset-top))}}.map-first-shell .section-title{position:static;right:auto;left:auto;top:auto;z-index:auto;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;column-gap:12px;width:100%;margin-bottom:8px;padding:0;border:0;background:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.map-first-shell .section-title h2{overflow:visible;white-space:nowrap;font-size:20px}.map-first-shell.phase-haunt .map-section,.map-first-shell .map-section{position:static;inset:auto;width:auto;height:auto;padding-top:0}.map-first-shell .map-board{width:100%;height:auto;max-width:none;max-height:none;overflow:visible;border-radius:8px;padding:12px;box-shadow:none}.map-first-shell .map-board.fixed-floor-grid{grid-template-columns:repeat(4,minmax(0,1fr));grid-template-rows:repeat(5,minmax(78px,1fr));aspect-ratio:1 / 1.52}.map-first-shell.phase-haunt .map-section,.map-first-shell .map-section{position:static!important;inset:auto!important;width:auto!important;height:auto!important;display:block!important;margin-top:8px;padding:0!important;overflow:visible!important;place-items:initial!important}.map-first-shell.phase-haunt .turn-guidance{top:auto}@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)) + 168px) 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(4,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)) + 76px);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 .turn-guidance{position:fixed;top:calc(max(8px,env(safe-area-inset-top)) + 126px);right:12px;left:12px;z-index:45;min-height:34px;margin:0;padding:7px 9px;grid-template-columns:minmax(0,1fr) auto;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 .turn-guidance span{display:none}.map-first-shell .turn-guidance strong,.map-first-shell .turn-guidance p{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.map-first-shell .turn-guidance strong{margin-top:0;font-size:13px}.map-first-shell .turn-guidance p{margin-top:1px;font-size:11px}.map-first-shell .turn-guidance button{min-width:72px;min-height:32px;padding:0 8px;font-size:12px}.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:20px;height:20px;font-size:10px;font-weight:1000}.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)) + 126px);display:grid;grid-template-columns:minmax(0,1fr);gap:3px;max-height:76px;padding:8px 10px;overflow:auto}.map-first-shell .haunt-banner h2{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px}.map-first-shell .haunt-banner span,.map-first-shell .haunt-banner p,.map-first-shell .haunt-banner strong{margin:0;font-size:11px;line-height:1.2}.map-first-shell.phase-haunt .map-section{padding-top:calc(max(8px,env(safe-area-inset-top)) + 252px)}.map-first-shell.phase-haunt .turn-guidance{top:calc(max(8px,env(safe-area-inset-top)) + 208px)}.map-first-shell .error-toast,.map-first-shell .copy-toast{top:auto;right:12px;bottom:calc(150px + env(safe-area-inset-bottom));left:12px;width:auto;transform:none}.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}@media(min-width:381px)and (max-width:440px)and (min-height:800px){body{overscroll-behavior-y:none;-webkit-tap-highlight-color:transparent}button{touch-action:manipulation}.map-first-shell{min-height:100dvh;padding:0}.map-first-shell .top-hud{top:max(7px,env(safe-area-inset-top));left:max(8px,env(safe-area-inset-left));width:128px;padding:3px}.map-first-shell .status-rail{top:max(7px,env(safe-area-inset-top));right:max(8px,env(safe-area-inset-right));left:calc(max(8px,env(safe-area-inset-left)) + 132px);padding:3px}.map-first-shell .hud-cell,.map-first-shell .status-card{min-height:38px;padding:4px 6px}.map-first-shell .hud-cell strong,.map-first-shell .status-card strong{font-size:11px}.map-first-shell .section-title{top:calc(max(7px,env(safe-area-inset-top)) + 61px);right:max(10px,env(safe-area-inset-right))}.map-first-shell .floor-rail{top:calc(max(7px,env(safe-area-inset-top)) + 61px);left:max(10px,env(safe-area-inset-left))}.map-first-shell .map-tools{grid-template-columns:repeat(4,44px);gap:4px;padding:4px}.map-first-shell .map-tools button,.map-first-shell .floor-rail button{width:44px;min-width:44px;min-height:44px}.map-first-shell .turn-guidance{top:calc(max(7px,env(safe-area-inset-top)) + 124px);right:max(10px,env(safe-area-inset-right));left:calc(max(10px,env(safe-area-inset-left)) + 62px);min-height:36px;padding:7px 9px}.map-first-shell .turn-guidance strong{font-size:12px}.map-first-shell .turn-guidance p{font-size:10px}.map-first-shell .turn-guidance button{min-width:68px;min-height:32px}.map-first-shell .map-section{padding:calc(max(7px,env(safe-area-inset-top)) + 168px) max(10px,env(safe-area-inset-right)) calc(152px + env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left))}.map-first-shell.phase-haunt .map-section{padding-top:calc(max(7px,env(safe-area-inset-top)) + 276px)}.map-first-shell.phase-haunt .turn-guidance{top:calc(max(7px,env(safe-area-inset-top)) + 204px)}.map-first-shell .map-board{--active-room-size: clamp(70px, 20vw, 88px);max-width:min(100%,calc(4 * var(--active-room-size) + 3 * 7px + 20px));max-height:min(100%,calc(5 * var(--active-room-size) + 4 * 7px + 20px));gap:7px;padding:9px;overscroll-behavior:contain;scroll-padding:18px;-webkit-overflow-scrolling:touch}.map-first-shell .room-tile,.map-first-shell .fog-slot{touch-action:manipulation}.map-first-shell .room-tile{padding:6px}.map-first-shell .player-token,.map-first-shell .monster-token{width:21px;height:21px}.map-first-shell .player-token.owned{width:27px;height:27px;transform:translateY(-3px) scale(1.03)}.map-first-shell .current-room-summary{right:max(10px,env(safe-area-inset-right));bottom:calc(78px + env(safe-area-inset-bottom));left:max(10px,env(safe-area-inset-left));grid-template-columns:minmax(0,1fr) 88px;max-height:72px;padding:8px 9px}.map-first-shell .current-room-summary .room-summary-main strong{font-size:15px}.map-first-shell .current-room-summary .room-summary-main p{display:none}.map-first-shell .current-room-summary .room-summary-action{min-width:84px;min-height:36px}.map-first-shell .action-dock{right:max(10px,env(safe-area-inset-right));bottom:calc(7px + env(safe-area-inset-bottom));left:max(10px,env(safe-area-inset-left));grid-template-columns:minmax(0,1fr) auto;gap:7px;padding:7px}.map-first-shell .dock-command-stack{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px}.map-first-shell .dock-secondary-row{grid-template-columns:repeat(2,44px);gap:6px}.map-first-shell .action-dock>button,.map-first-shell .dock-command-stack>button,.map-first-shell .dock-secondary-row>button{min-height:48px;border-radius:9px;font-size:11px}.map-first-shell .dock-secondary-row>button{width:44px;min-width:44px;padding:0}.map-first-shell .icon-action-button .ui-icon{width:21px;height:21px}.map-first-shell .icon-action-button small{font-size:10px}.map-first-shell .action-dock.readonly{right:max(10px,env(safe-area-inset-right));bottom:calc(7px + env(safe-area-inset-bottom));left:max(10px,env(safe-area-inset-left))}.overlay-backdrop{align-items:end;padding:calc(10px + env(safe-area-inset-top)) max(10px,env(safe-area-inset-right)) calc(10px + env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left))}.sheet-overlay,.log-overlay,.card-modal,.choice-modal,.haunt-transition,.result-panel,.random-character-modal,.room-zoom-overlay{width:min(100%,410px);max-height:calc(100dvh - 20px - env(safe-area-inset-top) - env(safe-area-inset-bottom));border-radius:12px}.card-modal{min-height:0;gap:8px;padding:12px}.card-modal h2{padding-inline:28px;font-size:22px}.card-illustration{min-height:min(164px,27dvh)}.choice-option-list button,.inventory-card-actions button,.chips button,.transit-action-button{min-height:44px}.inventory-card{grid-template-columns:42px minmax(0,1fr);gap:8px;padding:9px}.inventory-card-art{width:42px;min-height:54px}.map-first-shell .haunt-banner{top:calc(max(7px,env(safe-area-inset-top)) + 124px);right:max(10px,env(safe-area-inset-right));left:calc(max(10px,env(safe-area-inset-left)) + 62px);max-height:72px}.map-first-shell.phase-haunt .turn-guidance{top:calc(max(7px,env(safe-area-inset-top)) + 222px)}.map-first-shell.phase-haunt .map-board{--active-room-size: clamp(66px, 18.5vw, 80px)}.map-first-shell .error-toast,.map-first-shell .copy-toast{right:max(10px,env(safe-area-inset-right));bottom:calc(150px + env(safe-area-inset-bottom));left:max(10px,env(safe-area-inset-left))}}.map-first-shell{padding:8px 10px calc(84px + env(safe-area-inset-bottom))}.map-first-shell .top-hud{position:sticky;top:0;left:auto;width:100%;grid-template-columns:104px minmax(0,1fr) 56px 52px;gap:0;padding:0;border-radius:8px}.map-first-shell .hud-cell{border-radius:0;padding:7px 8px}.map-first-shell .latest-event-strip{display:grid}.map-first-shell .section-title{position:static;right:auto;left:auto;top:auto;z-index:auto;display:flex;width:100%;margin-bottom:8px;padding:0;border:0;background:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.map-first-shell .map-header-controls{width:100%}.map-first-shell .turn-guidance,.map-first-shell .current-room-summary,.map-first-shell .haunt-banner{position:static;inset:auto;z-index:auto;margin-top:8px;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.map-first-shell.phase-haunt .map-section,.map-first-shell .map-section{position:static;inset:auto;width:auto;height:auto;display:block;margin-top:8px;padding:0}.map-first-shell.phase-haunt .turn-guidance,.map-first-shell .turn-guidance{top:auto}.map-first-shell .map-board{width:100%;height:auto;max-width:none;max-height:none;overflow:visible;border-radius:8px;padding:10px;box-shadow:none}.map-first-shell .map-board.fixed-floor-grid{grid-template-columns:repeat(4,minmax(0,1fr));grid-template-rows:repeat(5,76px);aspect-ratio:auto}.map-first-shell .room-tile,.map-first-shell .fog-slot{width:auto;height:auto}.map-first-shell .room-tile strong{font-size:clamp(12px,3.5vw,15px)}.map-first-shell .current-room-summary{display:grid;grid-template-columns:minmax(0,1fr) auto auto;max-height:none;padding:9px 10px}.map-first-shell .current-room-summary .room-summary-icons{grid-column:1 / -2}.map-first-shell .action-dock.compact{right:0;bottom:0;left:0;display:flex;width:100%;max-width:480px;border-right:0;border-left:0;border-bottom:0;border-radius:0;padding:8px max(10px,env(safe-area-inset-right)) calc(8px + env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left))}.map-first-shell .action-dock.compact>button{flex:0 1 84px;min-height:52px;width:auto}.map-first-shell .action-dock.compact .end-turn-button{flex:1 1 150px}.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;min-height:auto}.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%)}.haunt-reveal-page .bottom-action-stack{display:flex;justify-content:center}.haunt-reveal-page .bottom-action-stack .primary{width:min(240px,78vw)}.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}.home-screen,.flow-screen{max-width:430px;margin:0 auto}.line-home-title{position:relative;padding:42px 0 18px}.home-kicker,.screen-kicker{display:block;color:var(--moss);font-size:12px;font-weight:900;letter-spacing:0}.line-home-title h1{margin-top:8px;color:var(--text);text-shadow:0 0 24px rgba(155,213,111,.18)}.line-home-title p{color:var(--muted)}.line-card{border-color:var(--line);border-radius:8px;background:linear-gradient(180deg,#e5e1cf0b,#e5e1cf05),#050d0b8a;box-shadow:none}.continue-card{grid-template-columns:62px minmax(0,1fr) auto;gap:10px;min-height:92px}.home-scenario-art{width:58px;height:58px;border-radius:8px}.continue-card strong{color:var(--text);font-size:15px}.continue-card p{margin-top:4px;font-size:12px;line-height:1.35}.line-link-button{min-height:34px;border:1px solid var(--line);border-radius:7px;padding:0 10px;background:#9bd56f17}.recovery-card{display:grid;gap:6px;border-color:#d8b86a57;color:var(--muted)}.recovery-card strong{color:var(--text)}.recovery-card button{justify-self:start;min-height:32px}.line-home-actions{gap:8px;margin-top:16px}.line-main-button,.line-wide-primary{min-height:42px;border-radius:8px;border-color:var(--line);background:#e5e1cf0b;font-size:14px}.line-main-button.primary,.line-wide-primary,.line-bottom-actions .primary{border-color:#9bd56fb8;color:#06100c;background:linear-gradient(180deg,#b4df87,var(--brass))}.home-recent-list{margin-top:16px}.compact-section-heading{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.compact-section-heading h2{margin:0;color:var(--text);font-size:15px;line-height:1.2}.compact-section-heading span{color:var(--muted);font-size:12px;font-weight:800}.compact-section-heading button{min-height:28px;border:0;padding:0 8px;color:var(--muted);background:transparent}.recent-room-row{grid-template-columns:68px minmax(0,1fr) 64px;min-height:48px;border-top-color:var(--line);padding:0}.recent-room-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-room-row em{font-size:12px;white-space:nowrap}.line-footer-tools{margin-top:14px;border-color:var(--line);border-radius:8px}.line-footer-tools button{min-height:36px;color:var(--muted)}.scenario-card{margin-top:10px}.scenario-body{grid-template-columns:78px minmax(0,1fr)}.scenario-art{height:70px;border:1px solid var(--line);border-radius:8px;color:var(--moss);background:radial-gradient(circle at 50% 18%,rgba(229,225,207,.18),transparent 45%),linear-gradient(180deg,#9bd56f29,#00000029),#07120ed1}.scenario-body strong{display:block;color:var(--text);font-size:16px}.scenario-body p,.map-rules-card p{margin-top:4px;font-size:12px;line-height:1.45}.segmented-row{border-color:var(--line);border-radius:8px}.segmented-row button{min-height:36px;color:var(--muted)}.segmented-row .active{color:#06100c;background:var(--moss)}.line-input,.hidden-code-input{min-height:38px;border-color:var(--line);background:#0000003d}.line-bottom-actions{gap:8px}.line-bottom-actions button{min-height:40px;border-radius:8px}.code-box-row{grid-template-columns:repeat(6,minmax(0,1fr)) 56px;gap:6px}.code-box-row span{min-height:42px;border-color:var(--line);border-radius:7px;font-size:18px}.code-box-row span.filled{color:var(--moss);background:#9bd56f1a}.join-help-card details{color:var(--muted);font-size:12px}.join-help-card summary{cursor:pointer;color:var(--text);font-weight:900}.join-help-card p{margin-top:8px;line-height:1.45}.inline-error{border:1px solid rgba(210,83,68,.48);border-radius:8px;padding:8px 10px;color:#f0b5aa;background:#75251f3d;font-size:12px}.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{position:relative;display:grid;place-items:center;width:34px;height:34px;border-radius:50%;color:#1b1510;background:var(--token-color, var(--brass));font-weight:900}.seat-token.ready{box-shadow:0 0 0 2px #87b36ab3}.seat-edit-button{display:inline-grid;place-items:center;width:24px;min-width:24px;min-height:24px;height:24px;border:0;border-radius:999px;padding:0;color:var(--brass);background:transparent;box-shadow:none}.seat-edit-button .ui-icon{width:16px;height:16px}.seat-name-line{display:inline-flex;align-items:center;max-width:100%;gap:4px}.seat-name-line strong{min-width:0;overflow:hidden;text-overflow:ellipsis}.seat-ready-check{position:absolute;top:-5px;right:-5px;display:grid;place-items:center;width:16px;height:16px;border-radius:50%;border:1.5px solid var(--panel);color:#1b1510;font-size:10px;font-weight:900;background:#8fb373}.seat-card small,.seat-card em{color:var(--muted);font-style:normal}.seat-card em.ready-badge{justify-self:end;padding:2px 8px;border-radius:999px;border:1px solid rgba(135,179,106,.6);color:#cfe6b8;background:#87b36a2e;font-size:11px;white-space:nowrap}.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}.copy-room-code-button{display:grid;place-items:center;width:44px;min-width:44px;padding:0}.copy-room-code-button .ui-icon{width:21px;height:21px}.lobby-ready-hint{margin:10px 0 0;color:var(--muted);text-align:center;font-size:12px}.lobby-spectator-note{color:var(--muted);flex:1 1 100%;font-size:12px;text-align:center}.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 strong{font-size:12px;line-height:1.15}.role-card em{color:var(--muted);font-size:10px;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}.lobby-screen,.role-select-screen{max-width:430px;margin:0 auto}.lobby-room-code{display:grid;grid-template-columns:64px minmax(0,1fr) 42px;align-items:center;min-height:86px;border-color:var(--line)}.lobby-scenario-art{width:58px;height:58px;border-radius:8px}.lobby-room-code strong{color:var(--moss);font-size:24px;letter-spacing:.08em}.lobby-room-code p{margin-top:3px;color:var(--muted);font-size:12px;line-height:1.35}.copy-room-code-button{width:38px;min-width:38px;min-height:38px;border-radius:8px}.lobby-status-strip{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:6px;margin-top:8px}.lobby-status-strip span{min-width:0;overflow:hidden;border:1px solid var(--line);border-radius:7px;padding:6px 8px;color:var(--muted);background:#e5e1cf09;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:800}.lobby-status-strip span:last-child{grid-column:1 / -1;color:var(--text)}.lobby-readonly-banner,.lobby-ready-hint,.role-select-lock{border:1px solid rgba(216,184,106,.34);border-radius:8px;padding:8px 10px;color:var(--muted);background:#d8b86a14;font-size:12px;line-height:1.35}.lobby-player-card{margin-top:8px}.lobby-player-card .seat-grid{gap:6px}.lobby-player-card .seat-card{grid-template-columns:36px minmax(0,1fr) auto;min-height:64px;border-color:var(--line);border-radius:8px;background:#e5e1cf08}.lobby-player-card .seat-card.owned{border-color:var(--line-strong);background:#9bd56f14}.lobby-player-card .seat-card.host{box-shadow:inset 3px 0 #d8b86ab8}.lobby-player-card .seat-card.empty{opacity:.7;background:#00000029}.seat-token{width:32px;height:32px;color:#06100c;background:linear-gradient(180deg,rgba(255,255,255,.2),transparent),var(--token-color, var(--moss))}.seat-card>div{min-width:0}.seat-card small{display:block;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seat-card .attribute-strip{margin-top:5px}.seat-card>button,.danger-inline{grid-column:2 / -1;justify-self:stretch;min-height:30px;border-radius:7px}.seat-action-row{grid-column:1 / -1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.seat-action-row button{min-height:32px;border-radius:7px;padding:0 6px;font-size:11px}.seat-action-row .ui-icon{width:14px;height:14px;margin-right:3px;vertical-align:-2px}.seat-card em{justify-self:end;border:1px solid var(--line);border-radius:999px;padding:2px 7px;font-size:11px;white-space:nowrap}.seat-card em.ready-badge{border-color:#9bd56f94;color:#cfe6b8;background:#9bd56f1f}.seat-card em.pending-badge{border-color:#d8b86a6b;color:#d8b86a;background:#d8b86a14}.seat-card em.empty-badge{color:var(--muted)}.lobby-bottom-actions{grid-template-columns:repeat(3,minmax(0,1fr))}.lobby-bottom-actions button{min-height:38px;border-radius:8px;padding:0 8px;font-size:12px}.lobby-spectator-note{grid-column:1 / -1}.role-current-card{display:grid;grid-template-columns:48px minmax(0,1fr);align-items:center;gap:9px;padding:8px}.role-current-card .character-detail-art{width:46px;height:46px;border-radius:8px}.role-current-card strong{display:block;margin:3px 0 7px;overflow:hidden;color:var(--text);text-overflow:ellipsis;white-space:nowrap}.role-section-heading{margin-top:8px}.role-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;max-height:min(42vh,360px);overflow-y:auto;padding-right:2px;overscroll-behavior:contain}.role-card{grid-template-columns:34px minmax(0,1fr);min-height:86px;border-color:var(--line);border-radius:8px;padding:7px;background:#e5e1cf09}.role-card .character-portrait-block{grid-row:1 / span 3;width:34px;height:34px;border-radius:8px}.role-card .attribute-strip{grid-column:1 / -1;margin-top:2px}.role-card i{position:absolute;top:auto;right:6px;bottom:6px;border:1px solid var(--line);border-radius:999px;padding:1px 6px;color:var(--muted);font-size:10px}.role-card.selected{border-color:var(--line-strong);background:#9bd56f14}.role-card.selected i{border-color:#9bd56f94;color:var(--moss)}.role-card.occupied{opacity:.55}.role-card[aria-disabled=true]{cursor:default}.role-detail-card{grid-template-columns:64px minmax(0,1fr);border-color:var(--line);border-radius:8px;gap:10px;margin-top:8px;padding:9px}.role-detail-card .character-detail-art{width:60px;height:60px;border-radius:8px}.sticky-role-detail{position:sticky;top:0;z-index:5;background:#091b15fa}.role-detail-card h2{margin:0;font-size:18px;line-height:1.15}.role-detail-card p{display:-webkit-box;margin:5px 0;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2;color:var(--muted);font-size:12px;line-height:1.35}.role-detail-card ul{display:flex;flex-wrap:wrap;gap:4px;margin:6px 0 0;padding:0;list-style:none}.role-detail-card li{border:1px solid var(--line);border-radius:999px;padding:2px 6px;color:var(--muted);font-size:10px}.role-detail-traits{grid-template-columns:repeat(4,minmax(0,1fr))}.random-character-modal{width:min(360px,calc(100vw - 28px))}.random-character-list{display:grid;gap:8px;margin-top:12px}.rename-player-modal{width:min(340px,calc(100vw - 28px))}.rename-player-form{display:grid;gap:12px;margin-top:10px}.rename-player-form label{display:grid;gap:6px;color:var(--muted);font-size:12px;font-weight:800}.rename-player-form input{min-height:40px;border:1px solid var(--line);border-radius:8px;padding:0 10px;color:var(--text);background:#00000038;font-size:14px;font-weight:900}.rename-player-form small{justify-self:end;color:var(--muted)}.rename-player-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.rename-player-actions button{min-height:38px;border-radius:8px}.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)}@media(min-width:381px)and (max-width:440px)and (min-height:800px){.map-first-shell .map-tools{grid-template-columns:repeat(4,44px)}.map-first-shell .floor-rail{left:max(10px,env(safe-area-inset-left));grid-template-columns:44px;grid-auto-flow:row;transform:none}.map-first-shell .map-section{padding-top:calc(max(7px,env(safe-area-inset-top)) + 168px)}.map-first-shell.phase-haunt .map-section{padding-top:calc(max(7px,env(safe-area-inset-top)) + 276px)}.map-first-shell .section-title{top:calc(max(7px,env(safe-area-inset-top)) + 61px)}}.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-summary-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin-bottom:10px}.overview-summary-strip span{min-width:0;border:1px solid var(--line);border-radius:7px;padding:6px;background:#f4ead70b}.overview-summary-strip b{display:block;color:var(--muted);font-size:10px;font-weight:900}.overview-summary-strip strong{display:block;margin-top:3px;overflow:hidden;text-overflow:ellipsis;color:var(--paper);font-size:12px;white-space:nowrap}.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;display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:8px}.version-warning span,.version-warning strong,.version-warning p{display:block}.version-warning span{color:#f0c09a;font-size:11px;font-weight:900}.version-warning strong{margin-top:2px;color:#ffd8d1;line-height:1.25}.version-warning p{margin:3px 0 0;color:#ffd8d1b8;font-size:11px}.version-warning button{min-height:30px;border-radius:7px;padding:0 8px;font-size:12px}@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}}.attribute-strip{display:flex;flex-wrap:wrap;gap:4px}.attribute-strip span{display:inline-grid;grid-template-columns:auto auto;align-items:center;gap:3px;min-height:22px;border:1px solid var(--line);border-radius:5px;padding:2px 5px;color:var(--text);background:#00000038;font-size:11px;font-weight:800;line-height:1}.attribute-strip b{color:var(--muted);font-weight:900}.attribute-strip strong{margin:0;color:var(--text);font-size:11px}.attribute-strip.compact span{min-height:18px;padding:2px 4px}.game-sheet{color:var(--text);background:var(--sheet-surface)}.game-modal{position:relative;width:min(352px,calc(100vw - 32px));max-height:calc(100vh - 72px);overflow:auto;border:1px solid var(--line-strong);border-radius:var(--radius-sheet);padding:18px;color:var(--text);background:var(--sheet-surface);box-shadow:var(--sheet-elevation)}.game-modal>h2{margin-top:4px;font-size:20px;line-height:1.2}.game-toast{position:fixed;right:max(12px,env(safe-area-inset-right));bottom:calc(84px + env(safe-area-inset-bottom));left:max(12px,env(safe-area-inset-left));z-index:60;max-width:456px;margin:0 auto;border:1px solid var(--line-strong);border-radius:8px;padding:10px 12px;color:var(--text);background:#07120ef5;box-shadow:0 14px 34px #0000006b;font-size:13px;font-weight:800;line-height:1.35;display:grid;gap:6px}.game-toast span,.game-toast strong{display:block}.game-toast button{min-height:30px;border-radius:7px;padding:0 10px;font-size:12px}.toast-actions{display:flex;gap:6px;justify-content:flex-end}.game-toast.success{border-color:#92c9747a;background:linear-gradient(90deg,#2a5d326b,#07120ef5)}.game-toast.error{border-color:#d2534485;background:linear-gradient(90deg,#75251f70,#07120ef5)}.game-toast.warning{border-color:#d8b86a80}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}body{color:var(--text)}.game-page-shell{max-width:100vw;overflow-x:hidden}.game-page-shell.full-screen-flow{height:100dvh;min-height:100dvh;overflow-x:hidden;overflow-y:auto;overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch}.game-page-shell:not(.map-first-shell){min-height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch}.line-screen,.lobby-screen,.role-select-screen{width:min(100%,430px);max-width:100vw;min-height:100dvh;overflow-x:hidden;overflow-y:auto;padding-bottom:calc(82px + env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch}.line-bottom-actions{position:sticky;bottom:0;z-index:12;width:100%;max-width:430px;margin:10px auto 0;padding:8px 0 calc(8px + env(safe-area-inset-bottom));background:linear-gradient(180deg,#050d0b00,#050d0bf5 32%)}.map-first-shell{width:min(100%,430px);min-height:100dvh;padding:calc(6px + env(safe-area-inset-top)) 8px calc(70px + env(safe-area-inset-bottom))}.map-first-shell .top-hud{position:sticky;top:env(safe-area-inset-top);z-index:20;display:grid;grid-template-columns:82px minmax(0,1fr) 42px 40px;min-height:64px;gap:0;border:1px solid rgba(229,225,207,.14);border-radius:7px;padding:0;overflow:hidden;background:#05110df2;box-shadow:0 8px 18px #0000004d}.map-first-shell .hud-cell{min-height:0;border-right:1px solid rgba(229,225,207,.12);border-radius:0;padding:5px 6px;background:#e5e1cf07}.map-first-shell .hud-cell:last-child{border-right:0}.map-first-shell .hud-cell span{font-size:10px;line-height:1.1}.map-first-shell .hud-cell strong{margin-top:2px;overflow:hidden;overflow-wrap:normal;text-overflow:ellipsis;white-space:nowrap;font-size:12px;line-height:1.16}.map-first-shell .room-code strong{letter-spacing:.04em}.map-first-shell .sync-dot{margin-top:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:10px}.map-first-shell .self-cell{grid-template-columns:minmax(0,1fr);gap:3px;align-content:center}.map-first-shell .self-cell>div{min-width:0;overflow:hidden}.map-first-shell .self-identity-line{grid-template-columns:24px minmax(0,1fr);gap:5px}.map-first-shell .self-cell b{width:24px;height:24px;border-radius:6px;font-size:12px}.map-first-shell .self-cell strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.map-first-shell .self-cell .attribute-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:2px;margin-top:3px}.map-first-shell .self-cell .attribute-strip span{min-width:0;min-height:16px;display:flex;justify-content:center;gap:1px;border-radius:4px;padding:1px 2px;font-size:9px;line-height:1}.map-first-shell .self-cell .attribute-strip strong,.map-first-shell .self-cell .attribute-strip b{font-size:9px;line-height:1}.map-first-shell .omen-cell{padding:6px 4px}.map-first-shell .omen-cell strong{color:var(--brass);font-size:17px}.map-first-shell .omen-cell small{font-size:9px}.map-first-shell .more-menu-button{padding:5px 3px}.map-first-shell .more-menu-button .ui-icon{width:16px;height:16px}.map-first-shell .section-title{position:static;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;width:100%;margin:8px 0 6px;padding:0;border:0;background:transparent;box-shadow:none}.map-first-shell .section-title>div:first-child{display:block}.map-first-shell .section-title h2{margin:0;font-size:18px;line-height:1;white-space:nowrap}.map-first-shell .map-header-controls{display:grid;grid-template-columns:auto minmax(0,1fr);gap:6px}.map-first-shell .map-header-controls>span{font-size:10px}.map-first-shell .floor-tabs{grid-template-columns:repeat(3,38px);border-radius:6px}.map-first-shell .floor-tabs button{min-height:30px;padding:0;font-size:12px}.map-first-shell .turn-guidance,.map-first-shell .haunt-banner,.map-first-shell .current-room-summary{position:static;margin-top:6px;border-radius:7px;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.map-first-shell .turn-guidance{min-height:42px;grid-template-columns:minmax(0,1fr) auto;gap:7px;padding:6px 8px}.map-first-shell .turn-guidance span{display:block;font-size:10px}.map-first-shell .turn-guidance strong{margin-top:1px;font-size:13px}.map-first-shell .turn-guidance p{margin-top:1px;font-size:11px;line-height:1.25}.map-first-shell .turn-guidance button{min-width:64px;min-height:30px;border-radius:6px;padding:0 7px;font-size:11px}.map-first-shell .map-section{position:static!important;display:block!important;width:auto!important;height:auto!important;margin-top:6px;padding:0!important;overflow:visible!important}.map-first-shell .map-board{width:100%;max-width:none;max-height:none;gap:6px;border:1px solid rgba(213,163,84,.2);border-radius:7px;padding:7px;overflow:visible;background:linear-gradient(90deg,rgba(244,234,215,.035) 1px,transparent 1px) 0 0 / 40px 40px,linear-gradient(0deg,rgba(244,234,215,.03) 1px,transparent 1px) 0 0 / 40px 40px,#040c09c2;box-shadow:none}.map-first-shell .map-board.fixed-floor-grid{grid-template-columns:repeat(4,minmax(0,1fr));grid-template-rows:repeat(5,minmax(58px,1fr));aspect-ratio:4 / 5}.map-first-shell .room-tile,.map-first-shell .fog-slot{width:auto;height:auto;min-width:0}.map-first-shell .room-tile{gap:2px;border-width:1px;border-color:#e5e1cf2e;border-radius:7px;padding:6px;box-shadow:none}.map-first-shell .room-tile.current{border-color:#9bd56fdb;box-shadow:inset 0 0 0 1px #9bd56f59,0 0 12px #9bd56f24}.map-first-shell .room-tile.can-move{border-color:#9bd56fb8}.map-first-shell .room-tile.can-explore,.map-first-shell .room-tile.mist,.map-first-shell .fog-slot{border-width:1px;border-style:dashed;border-color:#9769b2b3}.map-first-shell .room-tile.danger-room{border-color:#b84b42b8;box-shadow:inset 0 0 0 1px #b84b423d}.map-first-shell .room-tile strong{font-size:clamp(10px,2.8vw,12px);line-height:1.13;word-break:keep-all;overflow-wrap:anywhere}.map-first-shell .room-tile em,.map-first-shell .fog-slot span{font-size:9px;line-height:1.15}.map-first-shell .icon-row{min-height:14px;gap:2px}.map-first-shell .room-icon{padding:1px 3px;font-size:8px;line-height:1.2}.map-first-shell .room-action-tag{right:3px;bottom:3px;padding:1px 4px;font-size:9px}.map-first-shell .door.north,.map-first-shell .door.south{height:3px}.map-first-shell .door.east,.map-first-shell .door.west{width:3px}.map-first-shell .token-row{min-height:16px;gap:2px}.map-first-shell .player-token,.map-first-shell .monster-token{width:16px;height:16px;border-width:1px;font-size:9px}.map-first-shell .player-token.owned{width:21px;height:21px;transform:translateY(-2px);border-width:1px;box-shadow:0 0 0 1px #140c05d9,0 0 0 3px #d5a35433;font-size:10px}.map-first-shell .player-token.owned:before,.map-first-shell .player-token.owned:after{display:none}.map-first-shell .current-room-summary{grid-template-columns:minmax(0,1fr) minmax(78px,auto) 16px;gap:3px 7px;min-height:48px;padding:6px 7px}.map-first-shell .current-room-summary .room-summary-main strong{margin-top:1px;font-size:14px;white-space:nowrap}.map-first-shell .current-room-summary .room-summary-main span,.map-first-shell .current-room-summary .room-summary-meta span{font-size:10px}.map-first-shell .current-room-summary .room-summary-icons{grid-column:1 / -1;min-height:0;gap:3px}.map-first-shell .current-room-summary .room-summary-icons:empty{display:none}.map-first-shell .room-summary-chevron{grid-column:3;grid-row:1;font-size:20px}.map-first-shell .latest-event-strip{display:grid!important;min-height:34px;grid-template-columns:auto minmax(0,1fr) auto;gap:6px;margin-top:6px;border-radius:7px;padding:5px 7px}.map-first-shell .latest-event-icon{min-width:34px;min-height:22px;border-radius:5px;font-size:10px}.map-first-shell .latest-event-strip strong{display:-webkit-box;font-size:11px;line-height:1.2;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2;white-space:normal;overflow-wrap:anywhere;color:#efebd5f0}.map-first-shell .latest-event-strip strong span{display:inline;color:#efebd5f0;text-shadow:0 0 12px rgba(135,179,106,.16)}.map-first-shell .latest-event-strip .dice-result-strip{display:none}.map-first-shell .latest-event-strip em{font-size:18px}.map-first-shell .action-dock.compact{right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;width:100%;max-width:430px;margin:0 auto;border-top:1px solid rgba(229,225,207,.14);border-radius:0;padding:6px max(8px,env(safe-area-inset-right)) calc(6px + env(safe-area-inset-bottom)) max(8px,env(safe-area-inset-left));background:#050d0af5}.map-first-shell .action-dock.compact>button{width:100%;min-width:0;min-height:44px;border-radius:7px;padding:4px 3px}.map-first-shell .action-dock.compact .end-turn-button{width:100%;min-width:0}.map-first-shell .icon-action-button .ui-icon{width:19px;height:19px;padding:2px}.map-first-shell .icon-action-button small{font-size:10px;word-break:keep-all}.sheet-backdrop{align-items:end;padding:6px}.sheet-overlay,.log-overlay{display:flex;flex-direction:column;width:min(100%,430px);max-height:calc(90dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;border-width:1px;border-radius:9px 9px 7px 7px;padding:9px}.panel-heading{flex:0 0 auto;gap:8px;margin-bottom:8px}.panel-heading h2{margin:0;font-size:18px;line-height:1.12}.panel-heading span{font-size:11px}.icon-close-button{width:30px;min-width:30px;height:30px;min-height:30px;border-radius:6px;font-size:18px}.overlay-backdrop{position:fixed;inset:0;z-index:80;display:grid;place-items:center;max-width:100vw;overflow:hidden;padding:max(10px,env(safe-area-inset-top)) max(10px,env(safe-area-inset-right)) max(10px,env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left))}.game-modal,.card-modal,.choice-modal,.haunt-transition,.room-zoom-overlay,.result-panel,.random-character-modal{width:min(100%,372px);max-width:calc(100vw - 20px);max-height:calc(90dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;border-radius:8px;padding:12px;color:var(--text);font-size:12px;font-weight:500;line-height:1.35}.game-modal h2,.card-modal h2,.choice-modal h2,.haunt-transition h2,.random-character-modal h2{margin:0;padding-right:28px;color:var(--text);font-size:17px;font-weight:800;line-height:1.18}.game-modal p,.card-modal p,.choice-modal p,.haunt-transition p,.game-modal dd,.card-modal dd,.choice-modal dd{color:#e5e1cfd1;font-size:11px;font-weight:500}.card-modal{grid-template-columns:112px minmax(0,1fr);gap:8px 10px;text-align:left}.card-modal>.screen-kicker,.card-modal>span:first-child,.card-modal>h2,.card-modal>p,.card-modal>.card-dice-result,.card-modal>.card-detail-list,.card-modal>.choice-option-list,.card-modal>strong{grid-column:1 / -1}.card-modal .card-illustration{width:104px;min-height:128px;font-size:22px}.card-modal .reveal-card-frame{grid-column:1 / -1;grid-template-columns:104px minmax(0,1fr);align-items:start;gap:8px 10px;padding:8px}.reveal-card-frame header,.reveal-card-frame .reveal-card-meta{grid-column:2}.reveal-card-frame .card-illustration{grid-column:1;grid-row:1 / span 2;width:100%;min-height:148px}.reveal-card-frame .reveal-card-meta div{grid-template-columns:48px minmax(0,1fr)}.card-modal p,.card-detail-list{border-color:#e5e1cf24;color:#e5e1cfd1;background:#0003}.card-detail-list dt,.card-detail-list dd{color:#e5e1cfc7;font-weight:600}.reveal-card-frame .reveal-card-meta dt{color:#e5e1cf99;font-size:10px}.reveal-card-frame .reveal-card-meta dd{color:#e5e1cfdb;font-size:11px;font-weight:700}.card-dice-row{display:grid;grid-template-columns:repeat(6,minmax(24px,1fr));gap:5px}.card-dice-row i{min-height:28px;border:1px solid rgba(229,225,207,.18);border-radius:6px;color:#efebd5e6;background:#e5e1cf12;font-size:12px;font-style:normal;font-weight:800}.card-detail-list{padding:8px}.card-detail-list div{grid-template-columns:44px minmax(0,1fr)}.choice-option-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.choice-option-list>button,.choice-option-list .pending-roll-action,.inventory-card-actions button,.card-action-list button,.room-move-list button,.transit-action-button{min-width:0;min-height:32px;border-radius:7px;padding:6px 8px;font-size:11px}.choice-option-list>button:only-child,.choice-option-list .pending-roll-action:only-child{grid-column:1 / -1}.pending-roll-action{min-width:0}.inventory-card{grid-template-columns:54px minmax(0,1fr);gap:8px;padding:8px}.inventory-card-art{width:54px;min-width:54px;min-height:68px}.inventory-card strong{font-size:13px}.inventory-card span,.inventory-card-copy p,.inventory-card-copy em{font-size:11px}.inventory-card-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-column:1 / -1;gap:6px}.inventory-card .action-disabled-reason{grid-column:1 / -1}.room-detail-body{gap:7px}.room-facts strong,.card-action-list strong,.inventory-card strong,.event-log-detail dd{color:#e5e1cfe6!important}.room-facts span,.detail-section h3,.event-log-detail dt{color:#9bd56fc7!important}.game-page-shell,.overlay-backdrop,.sheet-overlay,.game-modal,.card-modal,.choice-modal,.room-zoom-overlay,.more-menu-popover,.room-panel,.room-detail-body,.room-move-list,.transit-action-list,.drop-card-list,.inventory-list{color:#e5e1cfe6}.sheet-overlay :where(p,span,strong,small,em,dt,dd,li,summary),.game-modal :where(p,span,strong,small,em,dt,dd,li),.card-modal :where(p,span,strong,small,em,dt,dd,li),.choice-modal :where(p,span,strong,small,em,dt,dd,li),.room-zoom-overlay :where(p,span,strong,small,em,dt,dd,li),.room-detail-body :where(p,span,strong,small,em,dt,dd,li),.more-menu-popover :where(span,strong,small,em){color:inherit}.more-menu-popover{width:min(220px,calc(100vw - 20px));gap:5px;padding:8px}.more-menu-popover button{min-height:46px;gap:2px;border-radius:7px;font-size:11px}.more-menu-popover .ui-icon{width:18px;height:18px}.sheet-overlay button:not(.primary),.game-modal button:not(.primary),.card-modal button:not(.primary),.choice-modal button:not(.primary),.room-zoom-overlay button:not(.primary),.more-menu-popover button:not(.primary),.room-move-list button,.transit-action-button,.drop-card,.inventory-card-actions button:not(.primary),.card-action-list button:not(.primary){color:#e5e1cfe6!important}.room-move-list button span,.room-move-list button em,.transit-action-button span,.transit-action-button em,.drop-card span,.drop-card strong,.drop-card em{color:#e5e1cfdb!important}.sheet-overlay button:disabled,.game-modal button:disabled,.card-modal button:disabled,.choice-modal button:disabled,.room-zoom-overlay button:disabled{color:#e5e1cf6b!important}.room-facts{grid-template-columns:repeat(2,minmax(0,1fr))}.mobile-disclosure summary{min-height:34px;grid-template-columns:44px minmax(0,1fr);padding:7px 8px}.mobile-disclosure summary strong{font-size:12px}.role-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.role-card{grid-template-columns:34px minmax(0,1fr);min-height:92px;gap:6px;padding:7px}.role-card .character-portrait-block{grid-row:1 / span 2;width:34px;height:34px}.role-card strong{font-size:12px}.role-card em,.role-card i{font-size:10px}.role-card .attribute-strip{grid-column:1 / -1}.role-card .attribute-strip span{min-height:17px;padding:1px 3px;font-size:10px}.role-current-card,.role-detail-card{grid-template-columns:54px minmax(0,1fr);gap:9px;padding:9px}.role-current-card .character-detail-art,.role-detail-card .character-detail-art{width:52px;height:52px}.role-detail-card h2{font-size:15px}.role-detail-card p,.role-detail-card li,.role-detail-traits span{font-size:11px}.haunt-reveal-page{min-height:auto;padding-bottom:calc(94px + env(safe-area-inset-bottom))}.haunt-reveal-page .haunt-reveal-hero{min-height:246px;border-radius:9px;padding:18px 14px}.haunt-reveal-page .haunt-reveal-hero h1{font-size:27px}.haunt-reveal-page .identity-seal{width:72px;height:72px;border-width:1px;font-size:32px}.haunt-reveal-page .bottom-action-stack{display:flex;justify-content:center;margin-top:6px;padding:10px 0 calc(10px + env(safe-area-inset-bottom))}.haunt-reveal-page .bottom-action-stack .primary{width:min(230px,78vw);min-height:40px;border-radius:7px}.pending-choice-modal{gap:9px;border-radius:8px;padding:12px;background:linear-gradient(180deg,#e5e1cf12,#e5e1cf06),#081812fa}.pending-choice-modal .screen-kicker{justify-self:start;border-radius:5px;padding:3px 8px;color:var(--moss);background:#87b36a1f;font-size:11px}.pending-choice-modal h2{padding-right:34px;font-size:16px;line-height:1.22;text-align:left}.choice-context-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.choice-context-strip section{min-width:0;border:1px solid rgba(229,225,207,.12);border-radius:6px;padding:6px;background:#00000029;text-align:left}.choice-context-strip span{display:block;color:#e5e1cf94;font-size:10px;font-weight:700}.choice-context-strip strong{display:block;min-width:0;margin-top:2px;overflow:hidden;color:#efebd5e6;font-size:11px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.choice-helper-block{border:1px solid rgba(229,225,207,.11);border-radius:7px;padding:7px 8px;background:#00000024;text-align:left}.choice-helper-block p{margin:0;font-size:11px;line-height:1.35}.choice-selection-list{grid-template-columns:repeat(2,minmax(0,1fr))}.choice-selection-list .choice-option-card{min-height:54px;border-radius:7px;padding:7px 8px;background:#e5e1cf0a}.choice-selection-list .choice-option-card.selected{border-color:#9bd56fdb;background:#87b36a24;box-shadow:inset 0 0 0 1px #9bd56f38}.choice-selection-list .choice-option-card span{font-size:12px;line-height:1.2}.choice-selection-list .choice-option-card em{font-size:10px;line-height:1.25}.choice-modal-actions{position:sticky;bottom:-12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;margin:2px -2px -2px;padding-top:8px;background:linear-gradient(180deg,#08181200,#081812fa 36%)}.choice-modal-actions button{min-height:38px;border-radius:7px;font-size:12px}.players-sheet .player-readonly-list{gap:7px}.players-sheet .player-readonly-list article{display:block;grid-template-columns:minmax(0,1fr)!important;border-radius:7px}.players-sheet .player-row-button{grid-column:1 / -1;min-height:42px;width:100%!important;gap:7px;padding:7px}.players-sheet .player-row-button>span{width:26px;height:26px;font-size:11px}.players-sheet .player-row-button strong,.players-sheet .player-row-button p{word-break:keep-all;overflow-wrap:normal}.players-sheet .player-row-button strong{font-size:13px}.players-sheet .player-row-button p{margin-top:2px;font-size:11px}.players-sheet .player-expanded-detail{grid-column:1 / -1;gap:6px;width:100%;padding:7px}.players-sheet .trait-summary{grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;margin-top:0}.players-sheet .trait-summary span{border-radius:6px;padding:3px 2px;font-size:10px;line-height:1.1;word-break:keep-all}.players-sheet .trait-tracks{gap:4px;margin-top:5px}.players-sheet .trait-track{grid-template-columns:26px minmax(0,1fr);gap:4px}.players-sheet .trait-track strong{font-size:10px;word-break:keep-all}.players-sheet .trait-cells{display:flex;gap:3px;overflow-x:auto;scrollbar-width:none}.players-sheet .trait-cells::-webkit-scrollbar{display:none}.players-sheet .trait-cells span{flex:0 0 25px;min-height:20px;border-radius:5px;font-size:10px}.players-sheet .player-expanded-detail dl{grid-template-columns:repeat(2,minmax(0,1fr));gap:5px}.players-sheet .player-expanded-detail dt{font-size:10px}.players-sheet .player-expanded-detail dd{font-size:11px;line-height:1.22}.status-sheet .status-sheet-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.status-sheet .status-sheet-grid section,.status-sheet .status-sheet-player{border-radius:7px;padding:7px}.status-sheet .status-sheet-grid strong{font-size:13px;word-break:keep-all;overflow-wrap:anywhere}.status-sheet .status-sheet-grid p,.status-sheet .status-sheet-player p{font-size:11px;line-height:1.28}@media(max-width:374px){.map-first-shell{padding-inline:6px}.map-first-shell .top-hud{grid-template-columns:72px minmax(0,1fr) 38px 36px}.map-first-shell .map-board.fixed-floor-grid{grid-template-rows:repeat(5,minmax(54px,1fr))}.map-first-shell .room-tile{padding:5px}.map-first-shell .self-cell .attribute-strip{gap:2px}.map-first-shell .self-cell .attribute-strip span{padding-inline:2px}}@media(max-width:374px){.role-grid{grid-template-columns:1fr}}
