:root{--bg-deep: #100f14;--bg-mid: #18242b;--bg-panel: rgba(16, 24, 30, .82);--bg-panel-strong: rgba(20, 30, 36, .92);--line: rgba(255, 226, 170, .28);--text-main: #fff3da;--text-muted: #dccfb2;--gold: #f2c56e;--amber: #f29d63;--teal: #8bded5;--lime: #9bce7c;--danger: #f7876e;--shadow-heavy: 0 22px 64px rgba(4, 5, 8, .48);--font-body: "Trebuchet MS", "Candara", sans-serif;--font-display: "Palatino Linotype", "Book Antiqua", Georgia, serif;--font-mono: "Courier New", monospace;--safe-top: env(safe-area-inset-top, 0px);--safe-right: env(safe-area-inset-right, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px)}*{box-sizing:border-box}[hidden]{display:none!important}html,body,#app{width:100%;height:100%;margin:0}body{overflow:hidden;background:radial-gradient(circle at top,rgba(255,197,116,.16),transparent 24%),radial-gradient(circle at 80% 0%,rgba(126,200,193,.12),transparent 26%),linear-gradient(180deg,#15161b,#0a0c10);color:var(--text-main);font-family:var(--font-body)}body[data-test-mode=true] *{animation:none!important;transition:none!important;scroll-behavior:auto!important}button,input,select{font:inherit}#app{position:relative}.game-root,.render-host,.hud-root{position:absolute;top:0;right:0;bottom:0;left:0}.render-host{overflow:hidden;touch-action:none}.game-canvas{display:block;image-rendering:auto}.hud-root{pointer-events:none}.hud-top,.message-banner,.prompt-bar,.interaction-layer,.controls-layer,.setup-layer,.class-layer,.battle-layer,.chest-puzzle-layer,.reward-layer,.ending-layer{position:absolute;pointer-events:none}.hud-top{top:18px;left:18px;right:18px;display:flex;justify-content:space-between;gap:16px}.objective-chip,.status-strip,.message-banner,.prompt-bar,.control-pad,.interaction-prompt,.enemy-card,.feedback-card,.setup-modal,.class-modal,.reward-card,.ending-card{background:radial-gradient(circle at top left,rgba(242,197,110,.12),transparent 34%),linear-gradient(180deg,#121a1feb,#0b1116e0);border:1px solid var(--line);box-shadow:var(--shadow-heavy);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.objective-chip,.status-strip{max-width:min(46vw,480px);padding:14px 16px;border-radius:18px}.status-strip{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px 16px;text-align:right}.status-strip span{color:var(--text-muted);font-size:.88rem}.eyebrow{margin:0 0 6px;color:var(--gold);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}.objective-chip strong{display:block;margin-bottom:4px;font-family:var(--font-display);letter-spacing:.02em;font-size:1.1rem}.objective-chip span{color:var(--text-muted);font-size:.92rem;line-height:1.4}.message-banner{left:20px;bottom:82px;max-width:min(34rem,calc(100vw - 40px));padding:12px 16px;border-radius:16px;color:var(--text-main)}.message-banner[data-tone=danger]{border-color:#ff7d6580}.message-banner[data-tone=success]{border-color:#92cf7280}.prompt-bar{left:50%;bottom:18px;transform:translate(-50%);min-width:min(680px,calc(100vw - 38px));max-width:calc(100vw - 32px);padding:12px 18px;border-radius:999px;text-align:center;color:var(--text-muted)}.interaction-layer{right:18px;bottom:244px}.interaction-layer[data-visible=false]{opacity:0;pointer-events:none;visibility:hidden;transform:translateY(8px)}.interaction-layer[data-visible=true]{opacity:1;visibility:visible;pointer-events:none}.interaction-prompt{pointer-events:none;min-width:240px;max-width:min(320px,calc(100vw - 36px));padding:12px 14px;border-radius:18px;display:grid;gap:4px;text-align:left}.interaction-prompt span{font-family:var(--font-display);font-size:1rem}.interaction-prompt small{color:var(--text-muted);line-height:1.35}.interaction-prompt strong{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:#f7c765eb}.hud-root[data-mode=battle] .hud-top,.hud-root[data-mode=battle] .message-banner,.hud-root[data-mode=battle] .prompt-bar,.hud-root[data-mode=battle] .interaction-layer{opacity:0;pointer-events:none}.hud-root[data-mode=setup] .hud-top,.hud-root[data-mode=setup] .message-banner,.hud-root[data-mode=setup] .prompt-bar,.hud-root[data-mode=setup] .interaction-layer{opacity:0;pointer-events:none;visibility:hidden}.setup-layer,.class-layer{top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:24px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y}.setup-modal,.class-modal{width:min(1120px,calc(100vw - 32px));padding:28px;border-radius:28px;background:radial-gradient(circle at top left,rgba(247,199,101,.12),transparent 24%),linear-gradient(180deg,#091114f2,#091012e6);display:grid;gap:22px;pointer-events:auto;touch-action:auto}.setup-copy h1,.class-copy h1,.ending-card h2,.enemy-card h2,.party-card h2{margin:0 0 10px;font-family:var(--font-display);letter-spacing:.02em;line-height:1.04}.setup-copy,.class-copy{display:grid;gap:12px}.intro-copy{max-width:56rem;color:var(--text-muted);line-height:1.55}.setup-toolbar,.class-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.setup-chip{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-main);font-family:var(--font-mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase}.profile-row,.preset-row{margin-top:22px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.profile-pill,.dungeon-card,.class-card,.slot-button,.answer-orb,.chest-puzzle-token,.chest-puzzle-button,.reward-option,.control-button,.restart-button,.start-run-button{pointer-events:auto;border:0;cursor:pointer;color:inherit}.setup-modal button,.setup-modal input,.class-modal button,.class-modal input{pointer-events:auto;touch-action:auto}.profile-pill{display:flex;flex-direction:column;gap:6px;border-radius:18px;padding:14px;background:#ffffff0a;text-align:left;transition:transform .14s ease,border-color .14s ease,background .14s ease;border:1px solid rgba(255,255,255,.08)}.profile-pill small{color:var(--text-muted);line-height:1.35}.profile-pill.is-active{background:#78d5d524;border-color:#78d5d56b}.dungeon-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.dungeon-card{padding:18px;border-radius:22px;background:radial-gradient(circle at top left,color-mix(in srgb,var(--dungeon-accent) 12%,transparent),transparent 38%),linear-gradient(180deg,#ffffff0f,#ffffff05),#ffffff08;border:1px solid color-mix(in srgb,var(--dungeon-accent) 48%,white 14%);text-align:left;display:grid;gap:12px;min-height:132px;transition:transform .14s ease,box-shadow .14s ease,background .14s ease}.dungeon-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.dungeon-name{font-family:var(--font-display);font-size:1.15rem}.dungeon-description{margin:0;color:var(--text-muted);line-height:1.5}.dungeon-theme-chip{padding:5px 10px;border-radius:999px;background:color-mix(in srgb,var(--dungeon-accent) 18%,rgba(255,255,255,.02));border:1px solid color-mix(in srgb,var(--dungeon-accent) 40%,transparent);color:color-mix(in srgb,var(--dungeon-accent) 72%,white 28%);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.settings-section{display:grid;gap:14px}.settings-heading{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px 12px}.settings-heading strong{font-family:var(--font-display);font-size:1.1rem}.settings-heading span,.preset-status{color:var(--text-muted);line-height:1.45}.preset-status{margin-left:auto;font-style:normal;font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;font-size:.74rem}.advanced-toggle{margin-left:auto;padding:10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:#ffffff0a;color:var(--text-main);pointer-events:auto}.advanced-toggle:before{content:"⚙ "}.advanced-toggle.is-active{background:#78d5d524;border-color:#78d5d56b}.math-settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.math-setting-card{display:grid;gap:14px;padding:18px;border-radius:22px;background:radial-gradient(circle at top,color-mix(in srgb,var(--operation-accent) 18%,transparent),transparent 42%),linear-gradient(180deg,#ffffff0f,#ffffff05),#ffffff08;border:1px solid color-mix(in srgb,var(--operation-accent) 38%,rgba(255,255,255,.14))}.math-setting-card.is-disabled{opacity:.66}.math-setting-head{display:flex;align-items:center;gap:12px}.math-setting-symbol{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:#ffffff0f;color:var(--operation-accent);font-family:var(--font-display);font-size:1.6rem}.math-setting-copy{display:grid;gap:4px}.math-setting-copy span,.math-toggle-row span,.math-number-field span{color:var(--text-muted)}.math-toggle-row{display:inline-flex;align-items:center;gap:10px}.math-toggle-row input{width:16px;height:16px;accent-color:var(--gold)}.math-control-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.math-number-field{display:grid;gap:6px}.math-number-field input{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#050c10b8;color:var(--text-main)}.class-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.class-card{padding:18px;border-radius:22px;background:linear-gradient(180deg,#ffffff0f,#ffffff05),#ffffff08;border:1px solid color-mix(in srgb,var(--class-accent) 46%,white 18%);text-align:left;display:flex;flex-direction:column;gap:8px;min-height:180px;transition:transform .14s ease,box-shadow .14s ease,background .14s ease}.setup-hero-card{cursor:default;min-height:auto;gap:6px}.class-card:hover,.dungeon-card:hover,.profile-pill:hover,.slot-button:hover,.chest-puzzle-token:hover,.chest-puzzle-button:hover,.reward-option:hover,.control-button:hover,.restart-button:hover{transform:translateY(-3px)}.class-card.setup-hero-card:hover{transform:none}.class-name{font-family:var(--font-display);font-size:1.25rem}.class-desc,.class-passive,.class-combo,.class-tree{color:var(--text-muted);line-height:1.4}.class-card.is-active{background:radial-gradient(circle at top,color-mix(in srgb,var(--class-accent) 16%,transparent),transparent 42%),linear-gradient(180deg,#ffffff17,#ffffff08),#ffffff0a;box-shadow:0 18px 36px #00000038;transform:translateY(-3px)}.dungeon-card.is-active{background:radial-gradient(circle at top left,color-mix(in srgb,var(--dungeon-accent) 18%,transparent),transparent 40%),linear-gradient(180deg,#ffffff17,#ffffff08),#ffffff0a;box-shadow:0 18px 36px #00000038;transform:translateY(-3px)}.setup-footer,.class-footer{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px}.footer-copy{margin:0;max-width:54rem;color:var(--text-muted);line-height:1.45}.start-run-button{padding:14px 20px;border-radius:999px;background:linear-gradient(180deg,#f7c765eb,#f29d63e0);color:#17110c;font-family:var(--font-display);font-size:1rem;letter-spacing:.04em;box-shadow:0 16px 30px #00000038}.start-run-button:disabled{cursor:not-allowed;opacity:.45;box-shadow:none}.battle-layer{top:0;right:0;bottom:0;left:0;display:flex;align-items:stretch;justify-content:center;padding:18px 22px 32px;pointer-events:none}.battle-layer:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,transparent 18%,rgba(4,7,10,.18) 62%,rgba(2,3,6,.64) 100%),linear-gradient(180deg,#04090e38,#0204077a);pointer-events:none}.reward-layer,.chest-puzzle-layer{top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:24px}.chest-puzzle-card{pointer-events:auto;width:min(720px,calc(100vw - 32px));padding:24px;border-radius:28px;background:radial-gradient(circle at top left,rgba(139,222,213,.14),transparent 28%),radial-gradient(circle at top right,rgba(247,199,101,.14),transparent 26%),linear-gradient(180deg,#091114f2,#091012e6);border:1px solid rgba(255,236,184,.18);box-shadow:var(--shadow-heavy)}.chest-puzzle-card h2{margin:0 0 10px;font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.5rem);letter-spacing:.04em}.chest-puzzle-copy,.chest-puzzle-note{margin:0;color:var(--text-muted);line-height:1.5}.chest-puzzle-preview{margin-top:16px;padding:16px 18px;border-radius:22px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(180deg,#ffffff12,#ffffff05),#ffffff08;border:1px solid rgba(255,236,184,.14)}.chest-puzzle-preview-value{font-family:var(--font-display);font-size:clamp(1.2rem,3vw,1.8rem);letter-spacing:.04em}.chest-puzzle-preview-count{color:var(--gold);font-family:var(--font-mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase}.chest-puzzle-grid{margin-top:18px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.chest-puzzle-token{aspect-ratio:1 / 1;border-radius:24px;padding:14px;display:grid;grid-template-rows:auto 1fr;align-items:start;justify-items:start;text-align:left;background:radial-gradient(circle at top,rgba(255,255,255,.14),transparent 44%),linear-gradient(180deg,#131f24eb,#0b1216d6);border:1px solid rgba(255,236,184,.18);box-shadow:inset 0 0 0 1px #ffffff0a;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}.chest-puzzle-token--number{border-color:#ffecb833}.chest-puzzle-token--operator{border-color:#8bded552}.chest-puzzle-token--equals{border-color:#f29d6352}.chest-puzzle-token.is-selected{border-color:#f7c765b3;box-shadow:0 0 28px #f7c76529}.chest-puzzle-token:disabled{cursor:default;opacity:.52}.chest-puzzle-token.is-selected:disabled{opacity:1}.chest-puzzle-token-index{color:var(--text-muted);font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase}.chest-puzzle-token-label{align-self:center;justify-self:center;font-family:var(--font-display);font-size:clamp(2rem,6vw,3.4rem);letter-spacing:.04em}.chest-puzzle-controls{margin-top:18px;display:flex;gap:12px}.chest-puzzle-button{flex:1 1 0;border-radius:18px;padding:14px 16px;border:1px solid rgba(255,255,255,.14);background:linear-gradient(180deg,#ffffff14,#ffffff08)}.chest-puzzle-button[data-variant=primary]{color:#17110c;border-color:#f7c76566;background:linear-gradient(180deg,#f7c765eb,#f29d63e0)}.chest-puzzle-button:disabled{cursor:not-allowed;opacity:.45;box-shadow:none;transform:none}.chest-puzzle-note{margin-top:14px;font-size:.94rem}.reward-card{pointer-events:auto;width:min(880px,calc(100vw - 32px));padding:24px;border-radius:28px;background:radial-gradient(circle at top left,rgba(247,199,101,.12),transparent 26%),linear-gradient(180deg,#091114f0,#091012e6)}.reward-card h2{margin:0 0 10px;font-family:Impact,Arial Black,sans-serif;letter-spacing:.04em}.reward-copy{margin:0;color:var(--text-muted);line-height:1.5}.reward-grid{margin-top:18px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.reward-option{min-height:210px;padding:18px;border-radius:22px;text-align:left;display:flex;flex-direction:column;gap:10px;background:linear-gradient(180deg,#ffffff12,#ffffff08),#ffffff08;border:1px solid rgba(255,236,184,.16)}.reward-option strong{font-family:var(--font-display);font-size:1.3rem;letter-spacing:.02em}.reward-option span{color:var(--text-muted);line-height:1.45}.reward-option em,.reward-badge{font-style:normal;color:var(--gold);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem}.battle-shell{pointer-events:none;width:100%;height:100%;display:grid;grid-template-rows:auto 1fr auto;gap:16px;position:relative;z-index:1}.battle-shell:before{content:"";position:absolute;top:-16px;right:-16px;bottom:-16px;left:-16px;border-radius:34px;background:radial-gradient(circle at 24% 22%,rgba(139,222,213,.08),transparent 24%),radial-gradient(circle at 76% 20%,rgba(242,157,99,.09),transparent 22%);pointer-events:none;filter:blur(28px)}.battle-head{display:grid;grid-template-columns:minmax(250px,300px) minmax(280px,1fr) minmax(250px,300px);align-items:start;gap:14px}.party-card,.enemy-card,.feedback-card{padding:15px 16px;border-radius:22px;background:radial-gradient(circle at top left,rgba(242,197,110,.1),transparent 36%),linear-gradient(180deg,#091017d6,#080e14b8);border:1px solid rgba(255,236,184,.18);box-shadow:0 18px 36px #0000002e,inset 0 0 0 1px #ffffff08;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.party-card{border-color:color-mix(in srgb,var(--hero-accent, var(--teal)) 42%,rgba(255,236,184,.22));background:radial-gradient(circle at top left,color-mix(in srgb,var(--hero-accent, var(--teal)) 18%,transparent),transparent 36%),linear-gradient(180deg,#081018db,#080f15b8)}.feedback-card{justify-self:center;width:min(100%,420px);align-self:center}.battle-compact-head{display:none}.battle-summary-card{padding:12px 14px;border-radius:20px;background:radial-gradient(circle at top left,rgba(242,197,110,.1),transparent 36%),linear-gradient(180deg,#091017db,#080e14c2);border:1px solid rgba(255,236,184,.18);box-shadow:0 18px 36px #0000002e,inset 0 0 0 1px #ffffff08;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.battle-summary-card.tone-danger{border-color:#ff7d6573}.battle-summary-card.tone-success{border-color:#92cf7273}.battle-summary-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.battle-summary-row+.battle-summary-row{margin-top:4px}.battle-summary-name{font-family:var(--font-display);font-size:1rem}.battle-summary-value{color:var(--text-muted);font-size:.88rem}.battle-summary-bars{display:grid;gap:8px;margin-top:10px}.battle-summary-feedback{display:grid;gap:4px;margin-top:10px}.battle-summary-feedback strong{font-size:.96rem}.battle-summary-feedback span{color:var(--text-muted);line-height:1.35}.enemy-card{justify-self:end}.party-card p,.enemy-card p,.feedback-card span{color:var(--text-muted);line-height:1.4}.feedback-card strong{display:block;font-size:1.08rem;margin-bottom:4px}.feedback-card.tone-danger{border-color:#ff7d6573}.feedback-card.tone-success{border-color:#92cf7273}.battle-bar-row{margin-top:10px;display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center}.battle-bar{width:100%;height:12px;border-radius:999px;overflow:hidden;background:#ffffff14}.battle-bar-fill{height:100%;border-radius:inherit;transition:width .18s ease}.battle-bar-fill.enemy{background:linear-gradient(90deg,var(--amber),var(--gold))}.battle-bar-fill.hero{background:linear-gradient(90deg,var(--hero-accent, var(--teal)),var(--gold))}.party-note{margin:10px 0 0;color:var(--text-muted);font-size:.86rem;line-height:1.45}.battle-arena{position:relative;min-height:0;overflow:visible;isolation:isolate}.battle-arena-content,.presentation-layer{position:absolute;top:0;right:0;bottom:0;left:0}.presentation-layer{z-index:3;pointer-events:none}.presentation-lane{position:absolute;display:flex;flex-direction:column;gap:10px;pointer-events:none}.presentation-lane--hero,.presentation-lane--enemy{top:12%;width:min(240px,28%)}.presentation-lane--hero{left:0;align-items:flex-start}.presentation-lane--enemy{right:0;align-items:flex-end}.presentation-lane--center{left:50%;top:4%;width:min(420px,72%);transform:translate(-50%);align-items:center}.battle-popup,.battle-banner{min-width:min(220px,100%);max-width:100%;padding:12px 14px;border-radius:18px;background:radial-gradient(circle at top left,rgba(247,199,101,.14),transparent 38%),linear-gradient(180deg,#0b1318eb,#090f14e0);border:1px solid rgba(255,236,184,.18);box-shadow:0 18px 36px #00000042;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);will-change:transform,opacity}.battle-popup{display:grid;gap:4px}.battle-popup--enemy{text-align:right}.battle-popup--hero{border-color:color-mix(in srgb,var(--hero-accent, var(--teal)) 44%,rgba(255,236,184,.2))}.battle-popup--enemy{border-color:#f29d6357}.battle-popup-primary,.battle-banner strong{font-family:var(--font-display);letter-spacing:.02em}.battle-popup-primary{font-size:1.7rem;line-height:1}.battle-popup-secondary,.battle-banner-detail{color:var(--text-muted);line-height:1.35;font-size:.88rem}.battle-popup-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.battle-popup--enemy .battle-popup-chips{justify-content:flex-end}.battle-popup-chip,.battle-banner-eyebrow{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase}.battle-popup-chip{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text-main)}.battle-popup-chip.tone-success{border-color:#92cf725c;color:#dff1b8}.battle-popup-chip.tone-danger{border-color:#ff7d655c;color:#ffd0c2}.battle-popup-chip.tone-info{border-color:#8bded55c;color:#cef6f0}.battle-banner{display:grid;justify-items:center;gap:4px;min-width:min(280px,100%);text-align:center}.battle-banner strong{font-size:1.3rem}.battle-banner-eyebrow{color:var(--gold)}.battle-banner--danger{border-color:#ff7d6566}.battle-banner--success{border-color:#92cf7266}.battle-stage{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.attack-picker{position:absolute;left:50%;bottom:0;width:min(760px,calc(100% - 24px));display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;transform:translate(-50%);transition:opacity .18s ease,transform .18s ease}.attack-picker.is-dimmed{opacity:.3;transform:translate(-50%) scale(.96)}.slot-button{min-height:0;aspect-ratio:1 / 1;border-radius:999px;padding:16px 12px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:6px;background:radial-gradient(circle at top,rgba(242,197,110,.14),transparent 42%),linear-gradient(180deg,#141e23e6,#0b1216cc);border:2px solid rgba(255,255,255,.12);box-shadow:inset 0 0 0 1px #ffffff0a;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}.slot-button.is-selected{border-color:#f7c765a8;box-shadow:0 0 28px #f7c76529}.slot-button.affinity-weak{border-color:#92cf72a6;box-shadow:0 0 32px #92cf7224}.slot-button.affinity-resist{border-color:#ff7d658a}.battle-shell[data-layout=compact] .battle-arena{padding-top:4px}.battle-shell[data-layout=compact] .presentation-lane--hero,.battle-shell[data-layout=compact] .presentation-lane--enemy{width:min(188px,32%)}.battle-shell[data-layout=compact] .presentation-lane--center{width:min(360px,84%)}.battle-shell[data-layout=compact] .center-stage{padding-bottom:132px}.battle-shell[data-layout=compact] .attack-picker{grid-template-columns:repeat(2,minmax(0,1fr));width:calc(100% - 4px);gap:10px}.battle-shell[data-layout=compact] .slot-button{aspect-ratio:auto;min-height:78px;border-radius:20px;padding:12px 10px;gap:4px}.battle-shell[data-layout=compact] .slot-symbol{font-size:1.85rem}.battle-shell[data-layout=compact] .slot-name,.battle-shell[data-layout=compact] .slot-affinity{font-size:.78rem}.battle-shell[data-layout=compact] .battle-compact-head{display:block}.slot-symbol,.problem-card strong,.answer-value{font-family:var(--font-display);letter-spacing:.03em}.slot-symbol{font-size:2.6rem;line-height:1}.slot-name{font-size:.95rem;letter-spacing:.05em;text-transform:uppercase}.slot-detail,.problem-supporting-copy{color:var(--text-muted);font-size:.82rem;line-height:1.35}.problem-supporting-copy{font-family:var(--font-display);font-size:1.2rem;color:var(--gold)}.slot-affinity,.problem-overline,.answer-index,.combo-tag{color:var(--text-muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem}.center-stage{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding-bottom:92px;opacity:0;transform:translateY(18px) scale(.94);transition:opacity .18s ease,transform .18s ease}.center-stage.is-active{opacity:1;transform:translateY(18px) scale(1)}.center-stage.is-hidden{pointer-events:none}.center-stage.is-idle,.center-stage.is-active{opacity:1}.problem-card{width:min(260px,calc(100% - 48px));margin:0;border-radius:28px;padding:18px 20px;text-align:center;background:radial-gradient(circle at top,rgba(242,197,110,.14),transparent 48%),linear-gradient(180deg,#1a272df0,#0d161be0);border:2px solid rgba(255,255,255,.16);box-shadow:0 18px 40px #00000047}.problem-card--floating{width:222px;min-height:222px;border-radius:50%;display:flex;flex-direction:column;justify-content:center;padding:24px;background:radial-gradient(circle at top,rgba(247,199,101,.12),transparent 44%),linear-gradient(180deg,#121e22e6,#091114e0)}.problem-focus{position:relative;width:440px;height:440px;display:flex;align-items:center;justify-content:center;transform:translateY(24px)}.problem-card strong{display:block;font-size:2.4rem}.danger-card{border-color:#ff7d6570}.answer-ring{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity .16s ease}.answer-ring.is-visible{opacity:1}.answer-orb{position:absolute;left:50%;top:50%;min-width:88px;min-height:88px;padding:10px 14px;border-radius:999px;background:radial-gradient(circle at top,rgba(255,246,230,.14),transparent 42%),linear-gradient(180deg,#f2c56e2e,#ffffff0a);border:1px solid rgba(247,199,101,.38);box-shadow:0 12px 26px #00000047;transform:translate(calc(-50% + var(--tx)),calc(-50% + var(--ty)));display:grid;place-items:center;gap:4px}.answer-orb:hover,.answer-orb:focus-visible{border-color:#f7c76594;box-shadow:0 16px 34px #00000057;background:linear-gradient(180deg,#f7c76547,#ffffff0f);outline:none}.answer-value{font-size:1.46rem}.planning-note{max-width:min(360px,calc(100% - 28px));padding:16px 20px;border-radius:22px;background:#0d181cc7;border:1px solid rgba(255,236,184,.16);box-shadow:var(--shadow-heavy);display:flex;flex-direction:column;gap:8px;text-align:center}.planning-note strong{font-family:var(--font-display);font-size:1.8rem;letter-spacing:.02em}.planning-note span{color:var(--text-muted);line-height:1.45}.planning-note--danger{border-color:#ff7d6557}.timer-panel{width:min(620px,calc(100% - 32px));margin:0 auto;padding:12px 16px;border-radius:18px;background:#0d181ccc;border:1px solid rgba(255,236,184,.14);box-shadow:0 16px 40px #0000003d;display:grid;gap:10px;position:relative;z-index:2}.timer-copy{display:flex;justify-content:space-between;gap:12px;align-items:center}.timer-copy span{color:var(--text-muted)}.timer-copy strong{font-family:var(--font-display);letter-spacing:.03em}.timer-track{position:relative;height:16px;border-radius:999px;overflow:visible;background:#ffffff14}.timer-fill{position:absolute;inset:0 auto 0 0;width:0%;border-radius:inherit;transition:width .1s linear}.timer-fill[data-mode=attack]{background:linear-gradient(90deg,var(--lime),var(--gold),var(--danger))}.timer-fill[data-mode=defense]{background:linear-gradient(90deg,var(--lime),var(--danger))}.timer-fill[data-mode=idle]{background:#ffffff14}.time-marker{position:absolute;top:20px;transform:translate(-50%);color:var(--text-muted)}.time-marker--end{transform:translate(-100%);text-align:right}.time-marker em{font-style:normal;font-size:.72rem;font-family:Courier New,monospace}.time-marker:before{content:"";position:absolute;top:-22px;left:50%;width:2px;height:18px;background:#ffffff2e;transform:translate(-50%)}.controls-layer{right:18px;bottom:84px}.controls-layer[data-visible=false]{opacity:0;transform:translateY(10px);pointer-events:none;visibility:hidden}.controls-layer[data-visible=true]{opacity:1;visibility:visible;pointer-events:auto}.control-pad{pointer-events:auto;display:grid;grid-template-columns:repeat(2,minmax(92px,1fr));gap:12px;padding:16px;border-radius:24px}.control-button,.restart-button{border-radius:16px;padding:14px 16px;background:linear-gradient(180deg,#ffffff14,#ffffff08);border:1px solid rgba(255,255,255,.14)}.ending-layer{top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:24px}.hud-root[data-mode=setup] .setup-layer,.hud-root[data-mode=chest-puzzle] .chest-puzzle-layer,.hud-root[data-mode=reward] .reward-layer,.hud-root[data-mode=victory] .ending-layer,.hud-root[data-mode=defeat] .ending-layer{pointer-events:auto}.ending-card{pointer-events:auto;width:min(480px,calc(100vw - 32px));border-radius:28px;padding:28px;text-align:center}.ending-card p{color:var(--text-muted);line-height:1.5}.hud-root[data-layout=compact] .hud-top{top:calc(12px + var(--safe-top));left:calc(12px + var(--safe-left));right:calc(12px + var(--safe-right))}.hud-root[data-layout=compact] .objective-chip,.hud-root[data-layout=compact] .status-strip{padding:12px 14px}.hud-root[data-layout=compact] .message-banner{left:calc(12px + var(--safe-left));right:calc(12px + var(--safe-right));bottom:calc(104px + var(--safe-bottom));max-width:none}.hud-root[data-layout=compact] .prompt-bar{bottom:calc(12px + var(--safe-bottom));min-width:calc(100vw - 24px - var(--safe-left) - var(--safe-right));border-radius:18px}.hud-root[data-layout=compact] .interaction-layer{left:calc(12px + var(--safe-left));right:calc(12px + var(--safe-right));bottom:calc(72px + var(--safe-bottom))}.hud-root[data-layout=compact] .interaction-prompt{width:100%;max-width:none}@media (max-width: 900px){.setup-layer,.class-layer{align-items:flex-start;padding:calc(12px + var(--safe-top)) calc(12px + var(--safe-right)) calc(12px + var(--safe-bottom)) calc(12px + var(--safe-left))}.setup-modal,.class-modal{width:100%;margin:0}.hud-top{flex-direction:column}.objective-chip,.status-strip{max-width:none}.class-grid,.math-settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dungeon-grid{grid-template-columns:1fr}.class-card{min-height:164px}.battle-layer{padding:16px 16px 26px}.chest-puzzle-card{width:min(680px,calc(100vw - 24px))}.battle-head{grid-template-columns:repeat(2,minmax(0,1fr))}.feedback-card{grid-column:1 / -1;width:100%}.enemy-card,.feedback-card,.party-card{max-width:none}.attack-picker{width:min(620px,calc(100% - 12px));gap:10px}.answer-orb{min-width:78px;min-height:78px}.presentation-lane--hero,.presentation-lane--enemy{width:min(204px,32%)}.presentation-lane--center{width:min(360px,82%)}}@media (max-width: 640px){.status-strip{justify-content:flex-start;text-align:left}.setup-modal,.class-modal{padding:20px;border-radius:24px;gap:18px}.chest-puzzle-layer{padding:12px}.chest-puzzle-card{width:100%;padding:20px;border-radius:24px}.chest-puzzle-preview,.chest-puzzle-controls{flex-direction:column;align-items:stretch}.chest-puzzle-grid{gap:10px}.chest-puzzle-token{border-radius:20px;padding:12px}.setup-footer,.class-footer,.settings-heading,.setup-toolbar,.class-toolbar{align-items:flex-start}.preset-status,.advanced-toggle{margin-left:0}.class-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.class-card{min-height:144px;padding:16px}.setup-footer,.class-footer{gap:12px}.setup-footer{position:sticky;bottom:0;z-index:1;padding-top:12px;background:linear-gradient(180deg,#09111400,#091114f5 24%)}.start-run-button{width:100%}.math-control-grid{grid-template-columns:1fr}.battle-layer{padding:12px 12px 52px}.message-banner{left:16px;right:16px;bottom:172px;max-width:none}.prompt-bar{bottom:16px;min-width:calc(100vw - 24px);border-radius:20px}.interaction-layer{left:16px;right:16px;bottom:252px}.interaction-prompt{width:100%;max-width:none}.battle-head{gap:8px;grid-template-columns:1fr}.enemy-card,.feedback-card,.party-card{max-width:none;width:100%;padding:10px 12px;border-radius:16px}.center-stage{padding-bottom:158px}.presentation-lane--hero,.presentation-lane--enemy{top:6%;width:calc(50% - 8px)}.presentation-lane--center{top:-44px;width:calc(100% - 72px)}.battle-popup,.battle-banner{min-width:0;padding:8px 11px;border-radius:16px}.battle-banner strong{font-size:1.08rem}.battle-banner-detail{font-size:.78rem}.battle-popup-primary{font-size:1.42rem}.problem-card--floating{width:188px;min-height:188px}.problem-focus{width:332px;height:332px;transform:translateY(8px)}.problem-card strong{font-size:2rem}.answer-ring{transform:scale(.84);transform-origin:center}.attack-picker{grid-template-columns:repeat(2,minmax(0,1fr));width:calc(100% - 4px);bottom:0}.slot-symbol{font-size:2.1rem}.battle-head .eyebrow,.timer-copy strong,.time-marker em{font-size:.64rem}.enemy-card h2{margin-bottom:6px;font-size:1.9rem}.feedback-card strong{font-size:.96rem;margin-bottom:2px}.feedback-card span{font-size:.94rem;line-height:1.3}.controls-layer{left:16px;right:16px;bottom:88px}.control-pad{grid-template-columns:repeat(2,1fr)}.timer-panel{margin-bottom:16px;width:calc(100% - 4px)}.time-marker{top:18px}}
