*{box-sizing:border-box}:root{color-scheme:dark;--bg: #08070d;--panel: rgba(17, 20, 30, .74);--panel-soft: rgba(24, 20, 33, .58);--line: rgba(246, 200, 97, .2);--line-strong: rgba(246, 200, 97, .42);--text: #fff7df;--muted: #b8ad9c;--gold: #f6c861;--ember: #ff7348;--purple: #7a49ff;--blue: #6bb8ff;--red: #f06a84;--green: #86efac}html,body{margin:0;height:100%;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}body{height:100vh;background:radial-gradient(circle at 50% 0%,rgba(122,73,255,.3),transparent 28%),radial-gradient(circle at 16% 24%,rgba(255,115,72,.15),transparent 24%),linear-gradient(180deg,#111018,#07070d 62%,#050507);overflow:hidden}button,a{font:inherit}button{cursor:pointer}a{color:var(--gold);text-decoration:none}.game-shell{height:100svh;min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr);gap:12px;padding:14px;overflow:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:linear-gradient(180deg,#141823e6,#090a10e6);box-shadow:0 24px 70px #00000059}.brand-lockup{display:flex;align-items:center;gap:12px}.brand-mark{width:38px;height:38px;border:1px solid var(--line-strong);border-radius:8px;background:radial-gradient(circle,rgba(246,200,97,.95),transparent 32%),conic-gradient(from 45deg,var(--purple),#111827,var(--ember),#111827,var(--purple));transform:rotate(45deg);box-shadow:0 0 28px #7a49ff6b}.brand-lockup strong{display:block;font-size:20px;letter-spacing:0}.brand-lockup span:last-child{display:block;margin-top:3px;color:var(--muted);font-size:12px}.top-actions{display:flex;align-items:center;gap:10px}.settings-wrap{position:relative}.top-actions a,.top-actions button{border:1px solid var(--line);border-radius:8px;padding:9px 12px;background:#ffffff09;color:var(--text)}.settings-popover{position:absolute;top:calc(100% + 8px);right:0;z-index:80;width:244px}.settings-popover[hidden]{display:none}.settings-panel{display:grid;gap:12px;border:1px solid rgba(246,200,97,.3);border-radius:8px;padding:12px;background:#090a10f0;box-shadow:0 18px 54px #0000007a;backdrop-filter:blur(12px)}.volume-control{display:grid;gap:7px}.volume-control span{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--text)}.volume-control strong{font-size:13px}.volume-control em{color:var(--gold);font-size:12px;font-style:normal}.volume-control input{width:100%;accent-color:var(--gold)}.play-layout{display:grid;grid-template-columns:minmax(190px,240px) minmax(0,1fr) minmax(260px,320px);gap:12px;align-items:stretch;min-height:0;overflow:hidden}.hud-column,.side-column{display:flex;flex-direction:column;gap:12px;min-width:0;min-height:0;height:100%;overflow:hidden}.stage-wrap{position:relative;min-height:0;height:100%;display:grid;place-items:center;width:100%;border:1px solid var(--line);border-radius:10px;background:linear-gradient(180deg,#13101be6,#08080cf5),repeating-linear-gradient(90deg,rgba(246,200,97,.04) 0 1px,transparent 1px 48px);box-shadow:0 28px 78px #00000075;overflow:hidden}#game-root{width:100%;height:100%;min-height:0;display:grid;place-items:center}#game-root canvas{image-rendering:pixelated;max-width:100%;max-height:100%}.panel{border:1px solid var(--line);border-radius:8px;background:linear-gradient(180deg,var(--panel),rgba(9,10,16,.72));box-shadow:0 14px 36px #00000038;padding:12px}.hud-column .panel,.side-column .panel{border-color:#f6c86124;background:linear-gradient(180deg,#11141ead,#090a109e);min-height:0}.toast-root{position:absolute;left:50%;bottom:clamp(16px,3vh,28px);z-index:20;width:min(560px,calc(100% - 32px));pointer-events:none;transform:translate(-50%)}.game-toast{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:4px 12px;max-width:100%;border:1px solid rgba(246,200,97,.28);border-radius:8px;padding:10px 12px;background:#090a10b8;box-shadow:0 14px 36px #0000006b;backdrop-filter:blur(8px);opacity:1;transform:translateY(0);transition:opacity .18s ease,transform .18s ease}.game-toast.is-hidden{opacity:0;transform:translateY(-6px)}.game-toast .toast-label{color:var(--gold);font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.game-toast strong{grid-column:1;color:var(--text);font-size:14px;line-height:1.45}.toast-repeat{grid-column:2;grid-row:1 / 3;align-self:center;border:1px solid rgba(246,200,97,.24);border-radius:999px;padding:3px 7px;color:var(--gold);background:#ffffff0d;font-size:12px;font-style:normal;font-weight:800}.toast-repeat:empty{display:none}.control-hint{position:absolute;left:50%;top:16px;z-index:18;transform:translate(-50%);border:1px solid rgba(246,200,97,.2);border-radius:999px;padding:7px 11px;color:#fff7dfd1;background:#08070d94;backdrop-filter:blur(8px);font-size:12px;white-space:nowrap;pointer-events:none}.victory-root{position:absolute;inset:0;z-index:30;display:grid;place-items:center;pointer-events:none}.victory-panel{width:min(440px,calc(100% - 36px));border:1px solid rgba(246,200,97,.48);border-radius:10px;padding:18px;background:linear-gradient(180deg,#1c1422e6,#08090edb),radial-gradient(circle at 50% 0%,rgba(122,73,255,.28),transparent 55%);box-shadow:0 22px 60px #0000007a;backdrop-filter:blur(12px);pointer-events:auto}.victory-panel h2{margin:0 0 8px;font-size:26px}.victory-panel p{margin:0;color:var(--muted);line-height:1.55}.victory-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:7px;margin-top:14px}.victory-stats span{border:1px solid rgba(246,200,97,.18);border-radius:8px;padding:8px;color:var(--muted);background:#ffffff0b;font-size:11px}.victory-stats strong{display:block;margin-top:3px;color:var(--text);font-size:16px}.victory-actions{display:flex;gap:8px;margin-top:14px}.victory-actions button{flex:1;border:1px solid rgba(246,200,97,.32);border-radius:8px;padding:10px 12px;color:var(--text);background:#ffffff0e}.victory-actions button:first-child{color:#180d08;background:var(--gold)}@keyframes toast-rise{0%{opacity:0;transform:translateY(10px)}11%,78%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.eyebrow{margin:0 0 8px;color:var(--gold);font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.hero-status h1{margin:0 0 14px;font-size:22px;line-height:1.1}.objective-strip{display:grid;gap:10px;margin-bottom:14px;border:1px solid rgba(246,200,97,.16);border-radius:8px;padding:10px;background:#ffffff09}.objective-strip div>span{display:block;margin-bottom:4px;color:var(--gold);font-size:11px;font-weight:800}.objective-strip strong{display:block;color:var(--text);font-size:16px;line-height:1.2}.objective-strip p{display:-webkit-box;margin:5px 0 0;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2;color:var(--muted);font-size:12px;line-height:1.45}.objective-strip ol{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:4px;margin:0;padding:0;list-style:none}.objective-strip li{position:relative;min-width:0;border-radius:999px;padding:4px 5px;color:#fff7df80;background:#ffffff0d;font-size:10px;font-weight:800;text-align:center}.objective-strip li.done{color:#170d05;background:linear-gradient(90deg,var(--gold),#ffe08a)}.objective-strip li span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hp-readout{display:grid;grid-template-columns:auto 1fr;gap:8px 12px;align-items:baseline}.hp-readout span{color:var(--muted);font-size:13px}.hp-readout strong{font-size:26px;color:var(--text)}.hp-readout i{grid-column:1 / -1;height:9px;border-radius:999px;background:#ffffff14;overflow:hidden}.hp-readout i:after{content:"";display:block;width:var(--value);height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--red),var(--ember),var(--gold))}.stats-panel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.stat-row,.key-badge,.gear-row{border:1px solid rgba(255,255,255,.07);border-radius:8px;padding:9px;background:#ffffff09}.stat-row span,.gear-row span{display:block;color:var(--muted);font-size:12px}.stat-row strong,.gear-row strong{display:block;margin-top:4px;font-size:18px}.key-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.key-badge{text-align:center}.key-badge span{display:inline-flex;width:24px;height:24px;justify-content:center;align-items:center;border-radius:6px;color:#160e06;background:var(--gold);font-weight:800}.key-badge.blue span{background:var(--blue)}.key-badge.red span{background:var(--red)}.key-badge strong{display:block;margin-top:6px;font-size:18px}.equipment-panel{display:grid;gap:8px}.unlock-row{display:flex;gap:6px;flex-wrap:wrap}.unlock-row span,.unlock-row em{border:1px solid rgba(246,200,97,.2);border-radius:999px;padding:5px 8px;color:var(--muted);font-size:12px;font-style:normal}.battle-panel p,.story-panel p,.shop-panel p,.npc-panel p{margin:0;color:var(--muted);line-height:1.6}.story-panel{border-color:#f6c86157;background:linear-gradient(180deg,#251921eb,#0c0d14eb)}.story-panel h2{margin:0 0 8px;font-size:20px}.story-panel strong{display:block;margin-bottom:3px;color:var(--gold)}.story-followups{display:grid;gap:8px;margin-top:12px}.story-followups article{border-left:2px solid rgba(246,200,97,.34);padding-left:10px}.story-followups h3{margin:0 0 4px;color:var(--text);font-size:14px}.reward-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.reward-chips span{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(246,200,97,.24);border-radius:999px;padding:5px 8px;background:#ffffff0b}.reward-chips em{color:var(--muted);font-size:11px;font-style:normal}.reward-chips strong{margin:0;color:var(--gold);font-size:12px}.reward-chips .key strong{color:var(--red)}.reward-chips .stat strong{color:var(--green)}.shop-panel{border-color:#f6c86161}.shop-panel h2{margin:0 0 8px;font-size:20px}.shop-panel p strong{display:block;margin-bottom:3px;color:var(--gold)}.shop-options{display:grid;gap:8px;margin-top:12px}.shop-options button{display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid rgba(246,200,97,.25);border-radius:8px;padding:9px 10px;color:var(--text);background:#ffffff0b}.shop-options button:disabled{cursor:not-allowed;opacity:.45}.shop-options strong{color:var(--gold);font-size:12px}.npc-panel{border-color:#6bb8ff57;background:linear-gradient(180deg,#101b2beb,#0a0d14eb)}.npc-panel h2{margin:0 0 8px;font-size:20px}.npc-panel strong{display:block;margin-bottom:3px;color:var(--blue)}.battle-panel h2{margin:0 0 10px;font-size:22px}.monster-book-panel h2{margin:0 0 8px;font-size:19px}.monster-book-panel.locked{border-color:#6bb8ff33}.book-list{display:grid;gap:8px}.book-entry{border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:9px;background:#ffffff09}.book-entry.can-win{border-color:#86efac3d}.book-entry.danger{border-color:#f06a8459}.book-entry header,.book-entry div{display:flex;align-items:center;justify-content:space-between;gap:8px}.book-entry header span{color:var(--gold);font-size:12px;font-weight:800}.book-entry div{flex-wrap:wrap;justify-content:flex-start;margin-top:7px}.book-entry div span{border:1px solid rgba(255,255,255,.08);border-radius:999px;padding:4px 7px;color:var(--muted);font-size:11px}.battle-panel.can-win{border-color:#86efac52}.battle-panel.danger{border-color:#f06a846b}.monster-stats{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.monster-stats span{border:1px solid rgba(255,255,255,.08);border-radius:999px;padding:5px 8px;color:var(--muted);font-size:12px}.loss-line{display:flex;justify-content:space-between;align-items:center;margin:10px 0;padding:10px 12px;border-radius:8px;background:#ffffff0b}.loss-line span{color:var(--muted)}.loss-line strong{font-size:24px;color:var(--gold)}.result-panel strong,.result-panel span{display:block}.result-panel strong{margin-bottom:6px}.result-panel span{color:var(--muted);font-size:13px}.save-panel{display:grid;gap:8px}.save-row{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid rgba(255,255,255,.07);border-radius:8px;padding:9px;background:#ffffff09}.save-row span{display:flex;gap:5px}.save-row button{border:1px solid rgba(246,200,97,.2);border-radius:7px;padding:5px 7px;color:var(--text);background:#ffffff09;font-size:12px}.story-panel,.npc-panel,.battle-panel,.monster-book-panel,.result-panel,.shop-panel{overflow:hidden}.story-panel p,.npc-panel p,.battle-panel p,.monster-book-panel p{display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:3}.fatal{min-height:100vh;display:grid;align-content:center;gap:16px;padding:48px;color:var(--text);background:linear-gradient(180deg,#14101cf5,#08080cfa),repeating-linear-gradient(90deg,rgba(246,200,97,.04) 0 1px,transparent 1px 48px)}.fatal h1,.fatal p{max-width:760px;margin:0}.fatal h1{font-size:28px;line-height:1.15}.fatal p{color:var(--muted)}.fatal-assets ul{max-width:820px;margin:0;padding:0;display:grid;gap:10px;list-style:none}.fatal-assets li{display:grid;gap:4px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#ffffff09}.fatal-assets li span{color:var(--muted);font-size:12px;overflow-wrap:anywhere}@media(max-width:1180px)and (min-aspect-ratio:3/4){.play-layout{grid-template-columns:206px minmax(420px,1fr)}.side-column{grid-column:1 / -1;display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px),(max-aspect-ratio:3/4){.game-shell{--mobile-stage: min(54svh, calc(100vw - 8px) );gap:4px;padding:4px}.topbar{align-items:center;padding:5px 7px;border-radius:7px;min-height:0}.brand-mark{width:clamp(28px,6vw,42px);height:clamp(28px,6vw,42px)}.brand-lockup strong{font-size:clamp(15px,2.6vw,28px)}.brand-lockup span:last-child{display:none}.top-actions button{padding:clamp(6px,1.4vw,12px) clamp(8px,2vw,18px);font-size:clamp(12px,2.3vw,22px)}.top-actions{gap:5px}.settings-popover{position:fixed;top:52px;right:4px;width:min(280px,calc(100vw - 8px))}.settings-panel{gap:9px;padding:10px}.play-layout{grid-template-rows:var(--mobile-stage) auto minmax(0,1fr);grid-template-columns:1fr;gap:4px}.stage-wrap{order:1;height:var(--mobile-stage);min-height:0;border-radius:7px}.hud-column{order:2;height:auto}.side-column{order:3;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:minmax(0,1fr);gap:4px;height:100%;overflow:hidden}.hud-column{display:grid;grid-template-areas:"hero keys" "stats equipment";grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr);gap:4px}#game-root{height:100%;min-height:0}#game-root canvas{max-height:100%}.hero-status{grid-area:hero;display:grid;grid-template-columns:minmax(0,1fr);gap:2px;padding:clamp(5px,1.1vw,9px)}.hero-status .eyebrow{margin-bottom:0}.hero-status h1{margin:0;font-size:clamp(15px,3vw,30px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.objective-strip{gap:3px;margin-bottom:3px;padding:4px}.objective-strip div>span{margin-bottom:2px;font-size:clamp(8px,1.5vw,13px)}.objective-strip strong{overflow:hidden;font-size:clamp(11px,2vw,18px);text-overflow:ellipsis;white-space:nowrap}.objective-strip p{margin-top:2px;font-size:clamp(9px,1.6vw,14px);line-height:1.25;-webkit-line-clamp:1}.objective-strip ol{gap:3px}.objective-strip li{padding:2px 4px;font-size:clamp(7px,1.35vw,12px)}.hp-readout{min-width:0;grid-template-columns:auto auto minmax(0,1fr);gap:2px 7px;align-items:center}.hp-readout strong{font-size:clamp(18px,3.8vw,36px)}.hp-readout i{grid-column:auto;height:clamp(5px,.9vw,9px)}.stats-panel{grid-area:stats;grid-template-columns:repeat(4,minmax(0,1fr));gap:3px}.keys-panel{grid-area:keys}.equipment-panel{grid-area:equipment}.stat-row{padding:clamp(4px,.9vw,7px)}.stat-row span,.gear-row span{font-size:clamp(9px,1.7vw,15px)}.stat-row strong{margin-top:2px;font-size:clamp(12px,2vw,20px)}.keys-panel,.equipment-panel{padding:clamp(5px,1vw,8px)}.key-grid{gap:4px}.key-badge{padding:clamp(4px,.9vw,7px)}.key-badge span{width:clamp(18px,3.4vw,30px);height:clamp(18px,3.4vw,30px);font-size:clamp(10px,1.9vw,17px)}.key-badge strong,.gear-row strong{margin-top:2px;font-size:clamp(13px,2.2vw,20px)}.equipment-panel{grid-template-columns:repeat(2,minmax(0,1fr));gap:3px}.equipment-panel .eyebrow,.equipment-panel .unlock-row{grid-column:1 / -1}.toast-root{bottom:8px;width:min(460px,calc(100% - 20px))}.game-toast{padding:6px 8px}.game-toast strong{font-size:clamp(11px,2vw,18px);display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.control-hint{top:8px;max-width:calc(100% - 18px);overflow:hidden;text-overflow:ellipsis;font-size:clamp(10px,1.9vw,18px)}.panel{padding:clamp(5px,1vw,8px);border-radius:6px}.eyebrow{margin-bottom:4px;font-size:clamp(9px,1.7vw,15px)}.side-column .panel{display:grid;align-content:start;gap:3px}.side-column h2,.battle-panel h2,.monster-book-panel h2,.shop-panel h2,.npc-panel h2,.story-panel h2{margin:0;font-size:clamp(13px,2.6vw,24px);line-height:1.12}.side-column p,.battle-panel p,.story-panel p,.shop-panel p,.npc-panel p{font-size:clamp(10px,1.9vw,17px);line-height:1.35;-webkit-line-clamp:2}.story-followups,.reward-chips{display:none}.monster-stats{gap:3px;margin-bottom:4px}.monster-stats span,.book-entry div span,.unlock-row span,.unlock-row em{padding:3px 5px;font-size:clamp(8px,1.5vw,13px)}.loss-line{margin:4px 0;padding:5px 7px}.loss-line strong{font-size:clamp(16px,3vw,28px)}.book-list{gap:4px;overflow:hidden}.book-entry{padding:5px}.book-entry:nth-of-type(n+4){display:none}.book-entry div{gap:3px;margin-top:4px}.save-panel{grid-column:1 / -1;grid-template-columns:auto repeat(3,minmax(0,1fr));align-items:center;gap:5px}.save-panel .eyebrow{margin:0}.save-row{padding:5px;gap:4px}.save-row strong{font-size:clamp(11px,2vw,17px);white-space:nowrap}.save-row span{gap:3px}.save-row button{padding:4px 5px;font-size:clamp(10px,1.7vw,14px)}.victory-panel{width:min(460px,calc(100% - 24px));padding:clamp(12px,2.4vw,22px)}.victory-panel h2{font-size:clamp(22px,4.4vw,40px)}.victory-panel p{font-size:clamp(12px,2.2vw,18px)}.victory-stats{gap:5px;margin-top:10px}.victory-stats span{padding:6px}.victory-actions{margin-top:10px}}@media(min-width:761px)and (max-aspect-ratio:3/4){.hud-column{grid-template-areas:"hero stats keys equipment";grid-template-columns:minmax(0,1.45fr) minmax(0,.95fr) minmax(0,.75fr) minmax(0,1.1fr);align-items:stretch}.hero-status h1{font-size:clamp(20px,2.35vw,26px)}.objective-strip p{-webkit-line-clamp:1}.stats-panel{grid-template-columns:repeat(2,minmax(0,1fr))}.keys-panel,.equipment-panel{align-content:start}.gear-row{padding:6px}}@media(max-width:520px){.top-actions a{display:none}.hero-status h1{font-size:15px}.objective-strip p{display:none}}
