*{box-sizing:border-box}:root{color:#20221d;background:#161713;font-family:Inter,PingFang SC,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}body{margin:0;min-width:320px;min-height:100vh;display:grid;place-items:center;overflow:hidden;background:#11130f}#haunting-root{width:min(100vw,calc(100vh * 16 / 9));height:min(100vh,56.25vw);overflow:hidden}.intro-shell{align-items:stretch;background:linear-gradient(180deg,#1d2a2d47,#20221db8),linear-gradient(135deg,#5f705f,#9b5f55);color:#fffaf0;display:grid;height:100%;padding:28px}.intro-stage{align-self:end;max-width:920px;padding:10px 4px 18px}.intro-kicker{color:#e7d8b9;font-size:14px;margin-bottom:10px}.intro-stage h1{font-size:42px;margin:0 0 14px}.intro-text,.intro-thought{font-size:18px;line-height:1.7;max-width:860px}.intro-dialogue{display:grid;gap:10px;margin:22px 0;max-width:840px}.intro-line{border-left:3px solid rgba(255,250,240,.56);padding-left:12px}.intro-line span{color:#e7d8b9;display:block;font-size:13px;margin-bottom:2px}.intro-line p{margin-bottom:0}.intro-thought{color:#f4e8cf}.intro-actions{margin-top:24px}button{background:#f9f5ec;border:1px solid #9c9a8e;border-radius:6px;color:#20221d;cursor:pointer;font:inherit;min-height:38px;padding:8px 10px}button:hover{border-color:#4d6559}button:disabled{cursor:not-allowed;opacity:.48}button.primary{background:#334d40;border-color:#334d40;color:#fffaf0}.shell{display:grid;gap:12px;grid-template-columns:minmax(0,1fr) 300px;height:100%;overflow:hidden;padding:12px;--ui-paper: rgba(255, 250, 240, .88);--ui-paper-strong: rgba(255, 250, 240, .96);--ui-border: #c8bca8;--ui-muted: #686758;--ui-accent: #415f4f;--ui-danger: #8a3b22;--scene-a: #607760;--scene-b: #c69a6c;--scene-text: #fffaf0;background:radial-gradient(circle at 24% 16%,rgba(255,235,190,.18),transparent 30%),linear-gradient(135deg,#d9d2c1,#8b8f76 48%,#52463d)}.shell.tone-uneasy{--ui-paper: rgba(245, 237, 220, .9);--ui-paper-strong: rgba(248, 240, 222, .97);--ui-border: #b99d82;--ui-accent: #5b5840;--scene-a: #5e6d63;--scene-b: #9b725d;background:radial-gradient(circle at 18% 10%,rgba(255,229,170,.12),transparent 26%),linear-gradient(135deg,#cfc5ad,#747766 45%,#3f3c35)}.shell.tone-horror{--ui-paper: rgba(234, 225, 210, .9);--ui-paper-strong: rgba(243, 233, 216, .97);--ui-border: #8e756c;--ui-muted: #615550;--ui-accent: #533a37;--ui-danger: #7e251f;--scene-a: #39383a;--scene-b: #803b33;background:radial-gradient(circle at 70% 20%,rgba(128,59,51,.26),transparent 28%),linear-gradient(135deg,#5d5550,#353533 48%,#1d1a1a)}.playfield,.drawer-stack{min-height:0}.playfield{display:grid;gap:10px;grid-template-rows:auto 150px minmax(0,1fr) auto;min-width:0;overflow:hidden}.drawer-stack{display:flex;flex-direction:column;gap:8px;overflow:hidden}.location-list,.log{display:flex;flex-direction:column}.location-list,.log{gap:6px}.brand h1,.topbar h2,.scene-hero h2,h2,h3,p{margin-top:0}.brand h1{font-size:22px;margin-bottom:4px}.brand p,.muted,.location-pill small{color:var(--ui-muted)}.location-pill{align-items:flex-start;display:flex;flex-direction:column;gap:3px;text-align:left;width:100%}.location-pill.active{background:#dce5d7e6;border-color:var(--ui-accent)}.topbar{align-items:center;background:var(--ui-paper);border:1px solid var(--ui-border);border-radius:8px;display:grid;gap:10px;grid-template-columns:170px minmax(0,1fr) auto;min-height:70px;padding:10px}.top-actions{gap:12px;justify-content:flex-end}.topbar h2,.scene-hero h2{font-size:23px;margin-bottom:6px}.stats{display:grid;gap:6px;grid-template-columns:repeat(6,minmax(82px,1fr));min-width:0}.stat{background:#fffaf08f;border:1px solid rgba(120,112,95,.22);border-radius:6px;min-width:0;padding:6px 7px}.stat span{color:var(--ui-muted);display:block;font-size:12px}.stat strong{display:block;font-size:16px}.scene-hero{align-items:flex-end;background:linear-gradient(180deg,transparent,rgba(0,0,0,.22)),linear-gradient(135deg,var(--scene-a),var(--scene-b));border-radius:8px;color:var(--scene-text);display:flex;min-height:0;overflow:hidden;padding:18px}.scene-hero.role-medical,.scene-hero.role-work{background:linear-gradient(135deg,#697966,#c6a974);color:#1f231e}.scene-hero.role-spiritual{background:linear-gradient(135deg,#554d5e,#b79c72)}.scene-hero.role-transport{background:linear-gradient(135deg,#576c78,#b87862)}.scene-hero.role-outdoor{background:linear-gradient(135deg,#4f6c61,#aa8566)}.scene-hero.pressure-high{background:linear-gradient(135deg,#463c3c,#9b4f43)}.scene-hero span{display:block;font-size:13px;margin-bottom:8px}.scene-hero p{margin-bottom:0;max-width:760px}.panel{min-width:0}.focus-panel{min-height:0;overflow:hidden}.first-morning-panel{background:var(--ui-paper-strong);border:1px solid #b69c76;border-radius:8px;height:100%;overflow:hidden;padding:14px}.first-morning-panel p{font-size:16px;line-height:1.65;margin-bottom:0}.approach-panel{background:linear-gradient(135deg,var(--ui-paper-strong),rgba(232,216,190,.86));border:1px solid var(--ui-border);border-radius:8px;box-shadow:0 18px 44px #352a1f29;display:grid;gap:12px;grid-template-columns:minmax(0,1fr) 82px;height:100%;overflow:hidden;padding:14px}.approach-copy{min-width:0}.approach-kicker{color:#765a42;font-size:13px;margin-bottom:8px}.approach-panel h2{font-size:22px;margin-bottom:8px}.approach-panel p{display:-webkit-box;font-size:16px;line-height:1.6;margin-bottom:0;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:4}.approach-npc{align-items:center;display:flex;flex-direction:column;gap:8px;justify-content:start}.approach-npc img{background:#d7d0c0;border:1px solid #a58d73;border-radius:8px;height:72px;object-fit:cover;width:72px}.approach-npc span{color:#765a42;font-size:12px}.approach-choices{display:grid;gap:10px;grid-column:1 / -1;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));min-height:0}.approach-choice{align-items:stretch;background:#fffaf0f0;border-color:#b49b7b;display:flex;flex-direction:column;gap:7px;min-height:96px;overflow:hidden;padding:10px;text-align:left}.approach-choice:hover,.approach-choice:focus-visible{background:#f4ead8;border-color:#334d40}.approach-choice strong{font-size:16px}.approach-choice span{color:#3f4138;display:-webkit-box;line-height:1.5;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.approach-choice small{color:#765a42;margin-top:auto}.drawer{background:var(--ui-paper);border:1px solid var(--ui-border);border-radius:8px;min-height:0;overflow:hidden;padding:0}.drawer summary{align-items:center;cursor:pointer;display:flex;gap:8px;justify-content:space-between;list-style:none;min-height:40px;padding:9px 11px}.drawer summary::-webkit-details-marker{display:none}.drawer summary span{color:var(--ui-muted);font-size:13px}.drawer summary strong{font-size:14px}.drawer[open]{flex:1 1 auto}.drawer[open] summary{border-bottom:1px solid rgba(125,105,85,.22)}.drawer>:not(summary){margin:9px 11px 11px}.drawer:not([open])>:not(summary){display:none!important}.drawer[open]>:not(summary){max-height:500px;overflow:hidden}.drawer p{line-height:1.5;margin-bottom:0}.location-list.compact{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.location-list.compact .location-pill{min-height:42px;padding:6px 7px}.location-list.compact .location-pill small{display:none}.quiet-focus{align-items:stretch;background:var(--ui-paper-strong);border:1px solid var(--ui-border);border-radius:8px;display:grid;gap:12px;grid-template-columns:minmax(0,1fr) minmax(190px,.38fr);height:100%;overflow:hidden;padding:14px}.quiet-focus h2{font-size:20px;margin-bottom:8px}.quiet-focus p{display:-webkit-box;line-height:1.55;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:5}.quick-actions{align-content:start;display:grid;gap:8px}.quick-actions button{text-align:left}.status-line{align-items:center;background:#fffaf0b8;border:1px solid rgba(190,176,150,.5);border-radius:8px;display:flex;gap:8px;min-height:34px;overflow:hidden;padding:7px 10px}.status-line span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.section-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.section-head h2,.panel h2{font-size:18px;margin-bottom:8px}.section-head span{color:#666758;font-size:13px}.grid,.action-grid{display:grid;gap:8px;grid-template-columns:1fr}.compact-grid{max-height:360px;overflow:hidden}.npc,.action-card,.empty{background:#fffaf0e0;border:1px solid #d0c8b7;border-radius:8px;padding:10px}.action-card{display:flex;flex-direction:column;justify-content:space-between;min-height:118px}.npc.status-awakened{border-color:#7d5c48}.npc-head{align-items:center;display:flex;gap:10px;margin-bottom:10px}.npc-head img{background:#d7d0c0;border-radius:6px;height:58px;object-fit:cover;width:58px}.npc h3,.action-card h3{font-size:15px;margin-bottom:4px}.npc>p,.action-card p{display:-webkit-box;line-height:1.45;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.mini-stats,.tag-row,.actions,.effect-row{display:flex;flex-wrap:wrap;gap:8px}.mini-stats span,.tag-row span,.effect-row span{background:#ece5d7;border-radius:999px;color:#4f5145;font-size:12px;padding:4px 7px}.progress-grid{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.progress-chip span{color:#666758;display:block;font-size:12px}.progress-chip strong{display:block}.elsewhere{border-top:1px solid #d8d0c0;padding-top:10px}.elsewhere:first-of-type{border-top:0;padding-top:0}.log{max-height:none;overflow:hidden}.log-item{border-left:3px solid #56685d;padding-left:8px}.warning{color:var(--ui-danger)}@media (max-width: 1180px){.shell{grid-template-columns:minmax(0,1fr) 270px}}@media (max-width: 760px){.shell{gap:8px;grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) 140px;padding:8px}.topbar{grid-template-columns:1fr auto}.stats{grid-column:1 / -1;grid-template-columns:repeat(3,minmax(0,1fr))}.scene-hero{padding:14px}.approach-panel{grid-template-columns:1fr}.approach-npc{align-items:flex-start;flex-direction:row}.drawer-stack{flex-direction:row}.drawer{flex:1 1 0}.drawer[open]{flex:2 1 0}}
