*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-void: #08080f;--bg-surface: #111119;--bg-surface-2: #1a1a25;--bg-surface-3: #252530;--text-primary: #e8e4dc;--text-secondary: #a09888;--text-dim: #605848;--el-fire: #E85D3A;--el-fire-dark: #8B2500;--el-fire-light: #FF9966;--el-spirit: #4A90D9;--el-spirit-dark: #1A3A6B;--el-spirit-light: #7FB8E8;--el-nature: #5BAD5B;--el-nature-dark: #1A4A1A;--el-nature-light: #8FD88F;--el-storm: #E8C83A;--el-storm-dark: #8B7500;--el-storm-light: #FFE066;--el-shadow: #9B59B6;--el-shadow-dark: #4A1A6B;--el-shadow-light: #C490D9;--el-steel: #C0C0C0;--el-steel-dark: #606060;--el-steel-light: #E8E8E8;--el-colorless: #B8926A;--el-colorless-dark: #6B5339;--el-colorless-light: #D4B896;--el-rainbow: #E8C83A;--el-rainbow-dark: #8B7500;--el-rainbow-light: #FFE066;--accent-gold: #c9a44e;--accent-gold-light: #f7e7b6;--border-subtle: rgba(255, 255, 255, .06);--border-medium: rgba(255, 255, 255, .1);--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 24px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--bg-dark: var(--bg-void);--bg-panel: var(--bg-surface);--bg-card: var(--bg-surface-2);--border-glow: rgba(201, 164, 78, .25);--text-gold: var(--accent-gold-light);--text-muted: var(--text-dim);--gap-xs: var(--space-xs);--gap-sm: var(--space-sm);--gap-md: var(--space-md);--gap-lg: var(--space-lg);--gap-xl: var(--space-xl);--hp-green: #2ecc71;--hp-red: #e74c3c;--block-blue: #5dade2;--font-mono: "Courier New", monospace;--phone-width: 390px;--phone-height: 844px;--font-title: "Bangers", cursive;--font-heading: "Bree Serif", "Segoe UI", sans-serif;--font-body: "Alegreya Sans", "Segoe UI", sans-serif;--font-number: "Alegreya Sans", "Segoe UI", sans-serif;--font-size-floor: .75rem;--font-size-sm: .8rem;--font-size-md: .875rem;--overlay-light: rgba(0, 0, 0, .3);--overlay-medium: rgba(0, 0, 0, .5);--overlay-heavy: rgba(0, 0, 0, .7);--overlay-dense: rgba(0, 0, 0, .85)}html,body{height:100%;min-height:100dvh;background:var(--bg-void);color:var(--text-primary);font-family:var(--font-body);font-size:16px;line-height:1.4;-webkit-font-smoothing:antialiased;overflow:hidden;width:100%}*{scrollbar-width:none}*::-webkit-scrollbar{display:none}#root{height:100%;min-height:100dvh}#root:has(.landing){height:auto}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}img{display:block;max-width:100%}.app-frame-stage{display:flex;align-items:center;justify-content:center;height:100%;min-height:100dvh;padding:8px}.app-frame-shell{display:flex;flex-direction:column;overflow:hidden;width:var(--phone-width);height:var(--phone-height);max-height:100%;max-height:calc(100dvh - 16px);background:#000;border-radius:40px;padding:6px;box-shadow:0 0 0 2px #1a1a20,0 20px 60px #000000b3}.app-frame-screen{flex:1;background:var(--bg-void);overflow:hidden;display:flex;flex-direction:column;position:relative;min-height:0;border-radius:34px}.app-screen-loading{flex:1;min-height:0;display:grid;place-items:center;padding:var(--space-xl);background:radial-gradient(circle at top,rgba(201,164,78,.18),transparent 50%),linear-gradient(180deg,#111119fa,#08080f);color:var(--accent-gold-light);font-family:var(--font-heading);font-size:1.05rem;letter-spacing:.08em;text-transform:uppercase}@media(max-width:430px){.app-frame-stage{min-height:100dvh;padding:0}.app-frame-shell{width:100%;height:100dvh;max-height:100dvh;border-radius:0;padding:env(safe-area-inset-top,0px) env(safe-area-inset-right,0px) env(safe-area-inset-bottom,0px) env(safe-area-inset-left,0px);box-shadow:none;background:var(--bg-void)}.app-frame-screen{border-radius:0}}.app-frame-stage--desktop{padding:0}.app-frame-shell--desktop{width:100%;max-width:1200px;height:100dvh;max-height:100dvh;border-radius:0;padding:0;box-shadow:none;background:var(--bg-void)}.app-frame-screen--desktop{border-radius:0;overflow:hidden}.app-frame-shell--desktop .app-frame-screen>*{min-height:0;max-height:100%}.app-frame-stage--reduced-motion *,.app-frame-stage--reduced-motion *:before,.app-frame-stage--reduced-motion *:after{animation-delay:0ms!important;animation-duration:1ms!important;animation-iteration-count:1!important;transition-delay:0ms!important;transition-duration:1ms!important;scroll-behavior:auto!important}.app-frame-mode-toggle{position:fixed;bottom:12px;right:12px;z-index:9999;width:40px;height:40px;border-radius:50%;border:1px solid var(--border-medium);background:var(--bg-surface);color:var(--text-secondary);font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #00000080;transition:border-color .15s,transform .1s;opacity:.7}.app-frame-mode-toggle:hover{opacity:1;border-color:var(--accent-gold)}.app-frame-mode-toggle:active{transform:scale(.92)}.app-frame-mode-toggle:focus-visible{opacity:1;border-color:var(--accent-gold-light);outline:2px solid var(--accent-gold-light);outline-offset:2px}@media(max-width:430px){.app-frame-mode-toggle{display:none}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.icon-inline{width:16px;height:16px;object-fit:contain;vertical-align:middle}.icon-inline--sm{width:12px;height:12px;object-fit:contain;vertical-align:middle}.icon-inline--md{width:20px;height:20px;object-fit:contain;vertical-align:middle}.icon-inline--lg{width:24px;height:24px;object-fit:contain;vertical-align:middle}.block-icon-img{width:12px;height:12px;object-fit:contain;vertical-align:middle}.card-modifier-icon-img{width:14px;height:14px;object-fit:contain}.enemy-intent-icon{width:16px;height:16px;object-fit:contain}.reward-icon-img{width:24px;height:24px;object-fit:contain}.app-frame-shell--desktop .combat-space-floor{width:min(180vw,1600px);height:clamp(180px,36vh,360px)}.app-frame-shell--desktop .combat-enemies{gap:16px;padding:var(--gap-lg) var(--gap-xl)}.app-frame-shell--desktop .enemy-card{min-width:130px;padding:var(--gap-md) var(--gap-lg)}.app-frame-shell--desktop .enemy-portrait{width:110px;height:110px}.app-frame-shell--desktop .combat-hand{flex-wrap:wrap;justify-content:center;overflow-x:visible;mask-image:none;-webkit-mask-image:none;padding:var(--gap-sm) var(--gap-lg);gap:var(--gap-sm)}.app-frame-shell--desktop .card{width:100px;min-height:170px;font-size:.8rem}.app-frame-shell--desktop .card-art{height:56px}.app-frame-shell--desktop .player-strip{padding:10px 24px;gap:16px}.app-frame-shell--desktop .mana-pip{width:34px;height:34px}.app-frame-shell--desktop .mana-pip-icon{width:34px;height:34px;font-size:1.1rem}.app-frame-shell--desktop .combat-powers-list{flex-wrap:wrap;overflow-x:visible;justify-content:center}.app-frame-shell--desktop .combat-bottom-bar{padding:var(--gap-sm) var(--gap-xl)}.app-frame-shell--desktop .combat-potion-slot{width:38px;height:38px}.app-frame-shell--desktop .map-top-bar{padding:var(--space-sm) var(--space-xl);gap:var(--space-lg)}.app-frame-shell--desktop .map-info-item{font-size:.85rem}.app-frame-shell--desktop .map-content{max-width:800px;margin:0 auto}.app-frame-shell--desktop .map-node{width:52px;height:52px}.app-frame-shell--desktop .map-node-icon{width:28px;height:28px;font-size:1.3rem}.app-frame-shell--desktop .map-node--boss{width:60px;height:60px}.app-frame-shell--desktop .map-node--boss .map-node-icon{width:36px;height:36px;font-size:1.6rem}.app-frame-shell--desktop .map-legend{gap:var(--space-md) var(--space-xl);padding:var(--space-md) var(--space-xl)}.app-frame-shell--desktop .shop-screen{padding:var(--space-xl)}.app-frame-shell--desktop .shop-tabs{max-width:600px;margin:0 auto}.app-frame-shell--desktop .shop-buy-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-md);max-width:700px}.app-frame-shell--desktop .shop-potion-grid{grid-template-columns:repeat(3,minmax(0,1fr));max-width:700px}.app-frame-shell--desktop .shop-relic-grid,.app-frame-shell--desktop .shop-remove-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-sm);max-width:700px}.app-frame-shell--desktop .forge-screen>*{max-width:800px}.app-frame-shell--desktop .forge-card-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-sm)}.app-frame-shell--desktop .forge-modifier-options{flex-direction:row;gap:var(--space-md)}.app-frame-shell--desktop .forge-modifier-option{flex:1}.app-frame-shell--desktop .forge-fuse-preview{max-width:480px}.app-frame-shell--desktop .rewards-list{max-width:500px}.app-frame-shell--desktop .rewards-card-choices{max-width:540px;gap:var(--space-md)}.app-frame-shell--desktop .rewards-card{width:140px;min-height:200px}.app-frame-shell--desktop .boss-reward-section{max-width:600px}.app-frame-shell--desktop .boss-relic-choices{flex-direction:row;gap:var(--space-md)}.app-frame-shell--desktop .boss-relic-card{flex:1}.app-frame-shell--desktop .boss-potion-choices{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.app-frame-shell--desktop .element-select-screen{flex-direction:row;flex-wrap:wrap;align-items:flex-start;justify-content:center;overflow:hidden;padding:var(--space-md) var(--space-xl);gap:var(--space-md)}.app-frame-shell--desktop .element-select-actions{width:100%;max-width:none;justify-content:center}.app-frame-shell--desktop .element-select-title{width:100%;text-align:center}.app-frame-shell--desktop .element-select-grid{flex:0 0 auto;width:320px;max-width:320px;gap:var(--space-xs);grid-template-columns:repeat(2,1fr);align-self:flex-start}.app-frame-shell--desktop .element-card{min-height:0;padding:var(--space-xs)}.app-frame-shell--desktop .hero-portrait-wrapper{width:44px;height:44px;margin-bottom:2px}.app-frame-shell--desktop .hero-detail-panel{flex:1 1 300px;max-width:420px;max-height:calc(100vh - 120px);overflow-y:auto;padding:var(--space-md);gap:var(--space-sm);align-self:flex-start}.app-frame-shell--desktop .hero-detail-section{padding:var(--space-xs) var(--space-sm)}.app-frame-shell--desktop .hero-confirm-btn{padding:8px 24px;position:sticky;bottom:0;z-index:2}.app-frame-shell--desktop .boon-choice-list{flex-direction:row;max-width:900px;gap:var(--space-lg)}.app-frame-shell--desktop .boon-card{flex:1}.app-frame-shell--desktop .boon-hero-copy{max-width:600px}.app-frame-shell--desktop .rest-choices{flex-direction:row;max-width:700px}.app-frame-shell--desktop .rest-choice-card{flex:1}.app-frame-shell--desktop .rest-hp-section{max-width:500px}.app-frame-shell--desktop .rest-upgrade-list,.app-frame-shell--desktop .rest-brew-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-sm)}.app-frame-shell--desktop .town-services{flex-direction:row;max-width:800px;gap:var(--space-md)}.app-frame-shell--desktop .town-service-card{flex:1}.app-frame-shell--desktop .town-hp-section{max-width:500px}.app-frame-shell--desktop .town-brew-section{max-width:600px}.app-frame-shell--desktop .event-description{max-width:500px;font-size:1rem}.app-frame-shell--desktop .event-choices,.app-frame-shell--desktop .event-outcome,.app-frame-shell--desktop .gameover-hero,.app-frame-shell--desktop .gameover-stats,.app-frame-shell--desktop .gameover-seed-panel,.app-frame-shell--desktop .gameover-achievement-panel,.app-frame-shell--desktop .gameover-unlock-note{max-width:500px}.app-frame-shell--desktop .menu-buttons{max-width:340px}.app-frame-shell--desktop .menu-settings-panel{max-width:500px}.app-frame-shell--desktop .records-screen{max-width:900px;margin:0 auto}.app-frame-shell--desktop .inspect-modal{max-width:400px}.app-frame-shell--desktop .pile-viewer{max-width:500px}.app-frame-shell--desktop .codex-panel{max-width:700px;max-height:85%;border-radius:var(--radius-lg)}.app-frame-shell--desktop .pause-menu{max-width:500px}.loading-screen{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;background:var(--bg-void, #08080f);z-index:9999}.loading-title{font-family:Skranji,Bangers,cursive;font-size:clamp(2rem,6vw,3.5rem);color:var(--text-primary, #e8e4dc);letter-spacing:2px;text-shadow:0 0 20px rgba(201,164,78,.4)}.loading-bar-track{width:min(80vw,400px);height:12px;background:var(--bg-surface-2, #1a1a25);border-radius:6px;overflow:hidden;border:1px solid var(--bg-surface-3, #252530)}.loading-bar-fill{height:100%;background:linear-gradient(90deg,var(--el-fire, #E85D3A),var(--el-storm, #9b7ed4));border-radius:6px;transition:width 80ms ease-out}.loading-label{font-family:Alegreya Sans,sans-serif;font-size:.85rem;color:var(--text-secondary, #a09888);letter-spacing:1px}
