:root{color-scheme:dark;font-family:var(--font-ui);background:#0f0b08;color:#f4ead3;--font-ui: "Palatino Linotype", "Book Antiqua", "Iowan Old Style", Georgia, serif;--font-fantasy: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;--panel: rgba(22, 15, 11, .86);--panel-strong: rgba(18, 12, 8, .96);--stone: #3b3328;--stone-light: #73664e;--text: #f4ead3;--muted: #b8a989;--gold: #d8ad5f;--red: #cf3e34;--green: #7ee787;--blue: #45b6d9;--violet: #9b6de3}*{box-sizing:border-box}html,body,#app,#game-root,#ui-root{width:100%;height:100%;min-height:100%;margin:0;overflow:hidden;overscroll-behavior:none}body{display:grid;place-items:center;background:radial-gradient(circle at 50% 40%,rgba(119,84,46,.22),transparent 42%),#0f0b08;touch-action:none;-webkit-user-drag:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}#app{position:relative;background:#2b2116;height:100dvh;max-height:100dvh;overflow:hidden;overscroll-behavior:none;touch-action:none}#game-root,#ui-root{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;overscroll-behavior:none;touch-action:none}#game-root canvas{display:block;touch-action:none;-webkit-user-select:none;user-select:none}#ui-root{pointer-events:none;z-index:10}.boot-screen{min-height:100%;display:grid;place-content:center;gap:12px;text-align:center;background:linear-gradient(135deg,rgba(255,255,255,.04) 0 1px,transparent 1px 46px),radial-gradient(circle at 20% 25%,rgba(216,173,95,.18),transparent 28%),radial-gradient(circle at 78% 72%,rgba(69,182,217,.12),transparent 28%),#0f0b08}.boot-screen h1{margin:0;font-family:var(--font-fantasy);font-size:34px;line-height:1;color:#f7dfaa;text-shadow:0 3px 0 #000}.boot-screen p{margin:0;color:var(--muted)}.hud,.weapon-strip,.boss-panel,.mode-chip,.boss-quote,.touch-controls,.toast,.overlay{pointer-events:auto}.hud{position:absolute;top:max(12px,env(safe-area-inset-top));left:max(12px,env(safe-area-inset-left));right:max(12px,env(safe-area-inset-right));display:flex;align-items:stretch;gap:8px;z-index:20}.hud-card{min-width:136px;padding:9px 10px;border:1px solid rgba(216,173,95,.34);border-radius:8px;background:linear-gradient(180deg,rgba(115,102,78,.2),transparent 42%),linear-gradient(135deg,rgba(255,255,255,.06) 0 1px,transparent 1px 14px),var(--panel);box-shadow:inset 0 0 0 1px #0009,0 12px 28px #0000006b;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hud-card.small{min-width:80px}.hud-card span,.mode-chip span,.boss-panel span{display:block;font-size:11px;line-height:1.2;color:var(--muted);letter-spacing:.02em}.hud-card strong{display:block;margin-top:3px;font-family:var(--font-fantasy);font-size:17px;line-height:1.1}.bar{height:8px;margin-top:8px;overflow:hidden;border:1px solid rgba(0,0,0,.72);border-radius:4px;background:#040302b8;transform:translateZ(0)}.bar i{display:block;width:100%;height:100%;border-radius:3px;background:linear-gradient(90deg,#7e1716,var(--red),#e67e55);transform-origin:left center;transition:transform .12s linear}.bar.xp i{background:linear-gradient(90deg,#174f70,var(--blue),var(--green))}.bar.boss{width:min(420px,calc(100vw - 32px));height:10px}.bar.boss i{background:linear-gradient(90deg,#ff5a66,#fc6)}.icon-button{width:46px;min-width:46px;border:1px solid rgba(216,173,95,.34);border-radius:8px;background:linear-gradient(180deg,#d8ad5f29,#0000001f),var(--panel);color:var(--text);font-weight:800;cursor:pointer;box-shadow:inset 0 0 0 1px #000000a3}.weapon-strip{position:absolute;top:max(82px,calc(env(safe-area-inset-top) + 74px));left:max(12px,env(safe-area-inset-left));max-width:min(560px,calc(100vw - 24px));padding:7px 10px;border:1px solid rgba(216,173,95,.22);border-radius:8px;background:#160f0bb8;color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;z-index:18}.boss-panel{position:absolute;top:max(86px,calc(env(safe-area-inset-top) + 78px));left:50%;transform:translate(-50%);display:grid;gap:7px;justify-items:center;padding:9px 12px;border:1px solid rgba(216,173,95,.58);border-radius:8px;background:linear-gradient(180deg,rgba(92,21,21,.24),transparent 52%),var(--panel-strong);box-shadow:inset 0 0 0 1px #0000009e,0 14px 42px #00000080;z-index:22}.boss-panel span{color:var(--gold);font-weight:800;font-size:14px}.mode-chip{position:absolute;right:max(12px,env(safe-area-inset-right));bottom:max(12px,env(safe-area-inset-bottom));display:flex;gap:10px;padding:7px 10px;border-radius:8px;border:1px solid rgba(216,173,95,.22);background:#160f0bb8;font-size:12px;z-index:18}.mode-chip span{display:inline}.boss-quote{position:absolute;left:50%;top:27%;width:min(720px,calc(100vw - 28px));transform:translate(-50%);padding:18px 22px;border:2px solid rgba(216,173,95,.76);border-radius:8px;background:linear-gradient(180deg,rgba(92,21,21,.46),transparent),#120907e6;color:#ffe4ad;font-size:clamp(24px,5vw,52px);font-weight:900;line-height:1.05;text-align:center;text-shadow:0 3px 0 #000;z-index:40}.mini-map{position:absolute;top:max(16px,env(safe-area-inset-top));right:max(16px,env(safe-area-inset-right));width:118px;height:118px;border:1px solid rgba(216,173,95,.62);border-radius:8px;background:#100b07c7;box-shadow:inset 0 0 0 1px #000000b8,0 10px 28px #0000006b;z-index:25;pointer-events:none}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:none;place-items:center;padding:18px;background:radial-gradient(circle at center,#1a120c4d,#050403c7),#0a070594;z-index:50}#ui-root[data-phase=menu] .overlay.menu,#ui-root[data-phase=paused] .overlay.paused,#ui-root[data-phase=levelUp] .overlay.level-up,#ui-root[data-phase=gameOver] .overlay.result,#ui-root[data-phase=victory] .overlay.result{display:grid}#ui-root[data-phase=menu] .hud,#ui-root[data-phase=menu] .weapon-strip,#ui-root[data-phase=menu] .touch-controls,#ui-root[data-phase=menu] .mode-chip,#ui-root[data-phase=menu] .mini-map{display:none}.menu-panel{width:min(520px,100%);padding:26px;border:1px solid rgba(216,173,95,.42);border-radius:8px;background:linear-gradient(135deg,rgba(255,255,255,.055) 0 1px,transparent 1px 18px),linear-gradient(180deg,#5b482e2e,#0003),var(--panel-strong);box-shadow:inset 0 0 0 2px #00000094,0 28px 90px #00000094;text-align:center}.menu-panel.compact{width:min(360px,100%)}.menu-panel h1,.menu-panel h2{margin:0;font-family:var(--font-fantasy);font-size:clamp(30px,7vw,56px);line-height:1;color:#f7dfaa;text-shadow:0 3px 0 #000}.menu-panel h2{font-size:clamp(25px,5vw,38px)}.menu-panel p{margin:14px 0 22px;color:var(--muted);line-height:1.45}.difficulty-picker{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:0 0 16px}.difficulty-button{min-height:88px;padding:10px;border:1px solid rgba(216,173,95,.24);border-radius:8px;background:linear-gradient(180deg,rgba(216,173,95,.08),transparent 52%),#1c140ee6;color:var(--text);text-align:left;cursor:pointer;box-shadow:inset 0 0 0 1px #0000008a}.difficulty-button.is-active{border-color:#f7dfaac2;background:linear-gradient(180deg,rgba(216,173,95,.26),transparent 58%),#301f12f5}.difficulty-button strong,.difficulty-button span{display:block}.difficulty-button strong{font-size:14px;line-height:1.12}.difficulty-button span{margin-top:6px;color:var(--muted);font-size:12px;line-height:1.25}.primary-button,.secondary-button,.upgrade-card,.active-skill{min-height:46px;border:0;border-radius:8px;font:inherit;font-family:var(--font-fantasy);font-weight:800;color:#16100a;cursor:pointer}.primary-button{width:100%;border:1px solid rgba(255,233,172,.56);background:linear-gradient(180deg,#f0d389,#c08333 56%,#7f3c20);box-shadow:inset 0 1px #ffffff57,0 10px 26px #7f3c2042}.secondary-button{width:100%;margin-top:10px;border:1px solid rgba(216,173,95,.26);background:linear-gradient(180deg,#ffffff14,#00000029),#2c2218d6;color:var(--text)}.upgrades-panel{width:min(760px,100%)}.upgrades-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:18px}.upgrade-card{display:grid;gap:8px;align-content:start;min-height:132px;padding:14px;border:1px solid rgba(216,173,95,.3);background:linear-gradient(180deg,rgba(216,173,95,.12),transparent 42%),#281d14eb;color:var(--text);text-align:left;box-shadow:inset 0 0 0 1px #0000008f}.upgrade-card strong{font-size:17px;line-height:1.12}.upgrade-card span{color:var(--muted);font-size:13px;line-height:1.3}.result-panel dl{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:18px 0}.result-panel dl div{padding:11px;border-radius:8px;border:1px solid rgba(216,173,95,.18);background:#281d14bd}.result-panel dt,.result-panel dd{margin:0}.result-panel dt{color:var(--muted);font-size:12px}.result-panel dd{margin-top:3px;font-family:var(--font-fantasy);font-size:20px;font-weight:900}.touch-controls{position:absolute;left:max(18px,env(safe-area-inset-left));right:max(18px,env(safe-area-inset-right));bottom:max(24px,calc(env(safe-area-inset-bottom) + 16px));display:flex;align-items:end;justify-content:space-between;z-index:24}.joystick{position:relative;width:126px;height:126px;border:1px solid rgba(216,173,95,.32);border-radius:999px;background:radial-gradient(circle at 50% 50%,rgba(216,173,95,.2),transparent 44%),#0e0a0794;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.joystick i{position:absolute;left:50%;top:50%;width:54px;height:54px;border-radius:inherit;border:1px solid rgba(255,232,178,.54);background:radial-gradient(circle at 35% 30%,#f7dfaa,#9b6f32 62%,#3b2014);transform:translate(-50%,-50%)}.active-skill{position:relative;width:100px;height:100px;overflow:hidden;border-radius:999px;border:1px solid rgba(166,232,255,.48);background:radial-gradient(circle at 35% 25%,rgba(255,255,255,.15),transparent 34%),#21140d;color:#ffe8b4;box-shadow:inset 0 0 18px #ffffff29,0 12px 30px #802a1652}.active-skill:before{content:"";position:absolute;left:0;right:0;bottom:0;height:var(--charge, 100%);background:radial-gradient(circle at 50% 10%,rgba(255,240,181,.9),transparent 22%),linear-gradient(180deg,#ffcf63,#d84a2a 58%,#7b1712);transition:height .16s linear}.active-skill:after{content:"";position:absolute;top:9px;right:9px;bottom:9px;left:9px;border:1px solid rgba(255,232,178,.28);border-radius:inherit}.active-skill span{position:relative;z-index:2;text-shadow:0 2px 0 rgba(0,0,0,.55)}.active-skill.is-ready{border-color:#ffe8b2d1;animation:rage-ready .9s ease-in-out infinite}.active-skill.is-active{color:#fff7d6;box-shadow:inset 0 0 22px #ffffff47,0 0 34px #ff4b2a75}@keyframes rage-ready{0%,to{box-shadow:inset 0 0 18px #ffffff29,0 12px 30px #802a1652}50%{box-shadow:inset 0 0 24px #fff0b54d,0 0 34px #ff5f2a8f}}.toast{position:absolute;left:50%;bottom:max(160px,calc(env(safe-area-inset-bottom) + 140px));transform:translate(-50%);padding:10px 13px;border-radius:8px;border:1px solid rgba(216,173,95,.32);background:var(--panel-strong);color:var(--text);z-index:80}.rotate-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:none;place-items:center;padding:22px;background:radial-gradient(circle at center,#38261557,#080503f0),#0f0b08;z-index:120}.rotate-hint div{width:min(360px,100%);padding:24px;border:1px solid rgba(216,173,95,.46);border-radius:8px;background:var(--panel-strong);text-align:center;box-shadow:0 24px 70px #00000094}.rotate-hint strong,.rotate-hint span{display:block}.rotate-hint strong{font-family:var(--font-fantasy);font-size:34px;line-height:1;color:#f7dfaa;text-shadow:0 3px 0 #000}.rotate-hint span{margin-top:12px;color:var(--muted);line-height:1.35}.is-hidden{display:none!important}@media(max-width:720px){.hud{flex-wrap:wrap;right:auto;max-width:calc(100vw - 24px)}.hud-card{min-width:118px;padding:8px}.hud-card.small{min-width:74px}.weapon-strip,.mode-chip{display:none}.pause-button{position:absolute;top:86px;right:max(12px,env(safe-area-inset-right));width:44px;height:34px;min-width:44px;z-index:26}.boss-panel{top:122px}.upgrades-grid,.difficulty-picker{grid-template-columns:1fr}.upgrade-card{min-height:86px}.menu-panel{padding:20px}.joystick{width:112px;height:112px}.active-skill{width:88px;height:88px}.mini-map{top:max(12px,env(safe-area-inset-top));right:max(12px,env(safe-area-inset-right));width:96px;height:96px}}@media(orientation:portrait)and (max-width:720px){.rotate-hint{display:grid}}@media(pointer:fine)and (min-width:900px){#app{width:min(1180px,calc(100vh * 16 / 9));height:auto;min-height:0;aspect-ratio:16 / 9;border:1px solid rgba(216,173,95,.28);border-radius:18px;box-shadow:0 0 0 1px #0009,0 30px 90px #000000b8}.bar.boss{width:min(320px,calc(100vw - 32px))}}@media(max-height:520px)and (orientation:landscape){.overlay{padding:10px}.menu-panel{max-height:calc(100% - 20px);overflow:auto;padding:16px}.menu-panel h1{font-size:42px}.menu-panel h2{font-size:30px}.menu-panel p{margin:10px 0 12px}.upgrades-panel{width:min(760px,calc(100% - 20px))}.upgrades-grid{gap:8px;margin-top:12px}.upgrade-card{min-height:112px;padding:12px}}
