*{box-sizing:border-box}html,body,#app{width:100%;height:100%;margin:0;font-family:Inter,Segoe UI,Roboto,sans-serif;overflow:hidden}canvas{position:fixed;inset:0}#hud{z-index:10;color:#e8ecf4;text-shadow:0 1px 2px #00000080;-webkit-user-select:none;user-select:none;pointer-events:none;font-family:Inter,Segoe UI,Roboto,sans-serif;position:fixed;inset:0}#hud-top{grid-template-columns:minmax(200px,1fr) auto minmax(200px,1fr);align-items:start;gap:12px;padding:14px 18px 0;display:grid;position:absolute;top:0;left:0;right:0}#hud-bottom{justify-content:space-between;align-items:flex-end;gap:24px;padding:12px 18px 18px;display:flex;position:absolute;bottom:0;left:0;right:0}#hint{letter-spacing:.15px;background:#080c16b8;border:1px solid #ffffff1f;border-radius:8px;max-width:280px;margin-bottom:8px;padding:6px 10px;font-size:11px;line-height:1.35;display:inline-block}.hud-top-left{justify-self:start;min-width:0}.health-block{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0c1220c7;border:1px solid #ffffff1a;border-radius:10px;max-width:320px;padding:10px 12px 12px}.health-row{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:6px;display:flex}.hud-label-cyan{text-transform:uppercase;letter-spacing:1.1px;color:#8eb4d4;font-size:10px;font-weight:700}#hp-pct{color:#fff;letter-spacing:-.5px;font-size:28px;font-weight:800;line-height:1}#hp-segments{gap:3px;height:10px;display:flex}.hp-seg{background:#ffffff14;border:1px solid #00000059;border-radius:2px;flex:1;transition:background .12s,opacity .12s}.hp-seg.on{background:#d62839;box-shadow:0 0 6px #d6283973}.hp-seg.dim{opacity:.35}#shield-chips{gap:6px;margin-top:10px;display:flex}.shield-chip{text-align:center;background:#141a28f2;border:1px solid #ffffff1f;border-radius:6px;flex:1;min-width:0;padding:5px 4px 6px}.shield-chip .chip-ico{justify-content:center;align-items:center;height:18px;margin-bottom:2px;display:flex}.shield-chip .chip-name{text-transform:lowercase;letter-spacing:.4px;opacity:.85;font-size:8px;font-weight:700}.shield-chip .chip-val{margin-top:1px;font-size:12px;font-weight:800}.shield-chip.fire{background:linear-gradient(#3c1218f2 0%,#160e12fa 100%);border-color:#d6283973}.shield-chip.frost{background:linear-gradient(#122034f2 0%,#0e121cfa 100%);border-color:#4a90e273}.shield-chip.earth{background:linear-gradient(#242428f2 0%,#121216fa 100%);border-color:#a0a0aa59}.shield-chip.locked{opacity:.42;filter:grayscale(.35)}.shield-chip .ico-fire{color:#e63946}.shield-chip .ico-frost{color:#4a90e2}.shield-chip .ico-earth{color:#9aa0ab}#shield-pick-hint{color:#ffe37d;text-align:center;text-transform:uppercase;background:linear-gradient(#493406f2 0%,#2e2003fa 100%);border:1px solid #ffdd57f2;border-radius:8px;margin-top:10px;padding:7px 8px 8px;animation:.95s ease-in-out infinite shieldCtaPulse;box-shadow:inset 0 0 0 1px #ffc2404d,0 0 12px #ffc24059}#shield-pick-hint .hint-label{letter-spacing:.08em;font-size:10px;font-weight:800;display:block}#shield-pick-hint .hint-keys{letter-spacing:.2em;text-indent:.2em;color:#fff1ab;margin-top:2px;font-size:19px;font-weight:900;line-height:1;display:block}#shield-pick-hint.hidden{display:none}@keyframes shieldCtaPulse{0%{transform:scale(1);box-shadow:inset 0 0 0 1px #ffc2404d,0 0 10px #ffc24047}50%{transform:scale(1.03);box-shadow:inset 0 0 0 1px #ffd4608c,0 0 19px #ffd4608c}to{transform:scale(1);box-shadow:inset 0 0 0 1px #ffc2404d,0 0 10px #ffc24047}}.hud-title{letter-spacing:.55em;text-indent:.55em;color:#e63946;text-transform:uppercase;white-space:nowrap;justify-self:center;padding-top:2px;font-size:15px;font-weight:800}.hud-top-right{text-align:right;justify-self:end;min-width:0}.score-block{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0c1220c7;border:1px solid #ffffff1a;border-radius:10px;min-width:200px;padding:10px 12px 11px}.score-row{justify-content:flex-end;align-items:baseline;gap:10px;display:flex}.score-row .hud-label-cyan{padding-top:4px}#score{color:#fff;letter-spacing:-.5px;font-size:28px;font-weight:800;line-height:1}.tier-progress-row{color:#9aa8bc;text-transform:lowercase;justify-content:flex-end;align-items:center;gap:8px;margin-top:10px;font-size:10px;font-weight:600;display:flex}#tier-bar-track{background:#00000073;border:1px solid #ffffff14;border-radius:2px;flex:1;max-width:140px;height:4px;overflow:hidden}#tier-bar-fill{background:linear-gradient(90deg,#c9a227 0%,#f4e58a 100%);border-radius:1px;width:0%;height:100%;transition:width .15s ease-out}#tier-goal{font-variant-numeric:tabular-nums;color:#cfd6e6;text-align:right;min-width:3ch}.difficulty-row{color:#9aa8bc;text-transform:lowercase;justify-content:flex-end;align-items:center;gap:8px;margin-top:8px;font-size:10px;font-weight:600;display:flex}.diff-pips{align-items:flex-end;gap:3px;height:14px;display:flex}.diff-pip{background:#ffffff1f;border-radius:1px;align-self:stretch;width:4px}.diff-pip.filled{background:#d62839;box-shadow:0 0 4px #d6283959}#weapon-dock{pointer-events:auto;gap:8px;display:flex}#weapon-upgrade-hint{text-align:center;text-transform:uppercase;color:#ffe37d;background:linear-gradient(#493406f2 0%,#2e2003fa 100%);border:1px solid #ffdd57f2;border-radius:10px;align-self:center;margin-top:8px;padding:7px 12px 8px;animation:.95s ease-in-out infinite weaponCtaPulse;box-shadow:inset 0 0 0 1px #ffc2404d,0 0 12px #ffc24059}#weapon-upgrade-hint .hint-label{letter-spacing:.08em;font-size:10px;font-weight:800;display:block}#weapon-upgrade-hint .hint-keys{letter-spacing:.08em;margin-top:2px;font-size:17px;font-weight:900;line-height:1;display:block}#weapon-upgrade-hint .hint-sub{color:#fff1ab;letter-spacing:.04em;margin-top:2px;font-size:9px;display:block}#weapon-upgrade-hint.hidden{display:none}.weapon-slot{cursor:pointer;background:#0c1220d1;border:1px solid #ffffff1f;border-radius:12px;width:108px;padding:8px 8px 9px;transition:border-color .12s,box-shadow .12s}.weapon-slot:hover{border-color:#ffffff38}.weapon-slot.active{border-color:#d62839;box-shadow:0 0 0 1px #d6283959}.weapon-slot-inner{flex-direction:column;align-items:center;gap:4px;display:flex}.weapon-ico{opacity:.55;place-items:center;width:36px;height:28px;display:grid}.weapon-slot.active .weapon-ico{opacity:1}.weapon-slot-meta{color:#b4bcc8;text-transform:lowercase;letter-spacing:.2px;font-size:10px;font-weight:700}.weapon-slot.active .weapon-slot-meta{color:#eef2f8}.weapon-tier-badge{text-transform:lowercase;color:#e8d89a;background:#1e180c8c;border:1px solid #c9a227a6;border-radius:4px;padding:2px 8px;font-size:9px;font-weight:700}#kill-feed{flex-direction:column;align-items:flex-end;gap:4px;min-width:140px;max-width:220px;font-size:12px;font-weight:700;display:flex}.kill-feed-row{color:#ff7a95;white-space:nowrap;transition:opacity .15s}.kill-feed-row .kf-arrow{opacity:.85;margin:0 4px;font-size:10px}@keyframes weaponCtaPulse{0%{transform:scale(1);box-shadow:inset 0 0 0 1px #ffc2404d,0 0 10px #ffc24047}50%{transform:scale(1.03);box-shadow:inset 0 0 0 1px #ffd4608c,0 0 19px #ffd4608c}to{transform:scale(1);box-shadow:inset 0 0 0 1px #ffc2404d,0 0 10px #ffc24047}}#crosshair{pointer-events:none;z-index:9;width:22px;height:22px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.ch-arm{background:#ffffffeb;border-radius:1px;position:absolute}.ch-arm.ch-top{width:2px;height:6px;top:0;left:10px}.ch-arm.ch-bottom{width:2px;height:6px;bottom:0;left:10px}.ch-arm.ch-left{width:6px;height:2px;top:10px;left:0}.ch-arm.ch-right{width:6px;height:2px;top:10px;right:0}#crosshair-dot{opacity:0;background:#f34;border-radius:50%;width:4px;height:4px;margin:-2px 0 0 -2px;transition:opacity 50ms,transform 50ms;position:absolute;top:50%;left:50%;transform:scale(.6);box-shadow:0 0 6px #ff3344bf}#crosshair.hit #crosshair-dot{opacity:1;transform:scale(1)}#reload-indicator{z-index:11;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);text-align:center;background:#0a0e18db;border:1px solid #ffffff29;border-radius:8px;min-width:150px;padding:8px 10px;animation:.85s ease-in-out infinite reload-pulse;position:fixed;top:calc(50% + 34px);left:50%;transform:translate(-50%)}#reload-label{letter-spacing:.12em;text-transform:uppercase;color:#ffd18a;font-size:10px;font-weight:800}#reload-track{background:#0000008c;border:1px solid #ffffff1a;border-radius:999px;height:5px;margin-top:6px;overflow:hidden}#reload-fill{background:linear-gradient(90deg,#ff9f43 0%,#ffd166 100%);width:0%;height:100%;transition:width 40ms linear}#reload-key{color:#a6b4c8;margin-top:5px;font-size:10px;font-weight:700}@keyframes reload-pulse{0%,to{opacity:.88}50%{opacity:1}}#pause-menu{z-index:30;background:#070a109e;place-items:center;display:grid;position:fixed;inset:0}#pause-menu.hidden{display:none}#progression-menu{z-index:40;background:#06080cb8;place-items:center;display:grid;position:fixed;inset:0}#progression-menu.hidden{display:none}#progression-info{opacity:.95;font-size:13px;font-weight:600}.progression-buttons{gap:8px;display:grid}.progress-btn{color:#f4f7fb;cursor:pointer;background:#3b7dff26;border:1px solid #ffffff38;border-radius:8px;height:34px;font-size:13px;font-weight:700}.progress-btn:hover{background:#3b7dff47}.hidden{display:none!important}.menu-card{color:#f4f7fb;background:#0e141ceb;border:1px solid #fff3;border-radius:12px;gap:12px;width:min(92vw,400px);padding:18px;display:grid}.menu-card h2{margin:0;font-size:24px}.menu-card label{font-size:14px;font-weight:600}.menu-label{text-transform:uppercase;letter-spacing:.8px;opacity:.85;margin-bottom:6px;font-size:12px;font-weight:700}#weapon-buttons{gap:8px;display:grid}.weapon-btn{color:#f4f7fb;cursor:pointer;background:#ffffff14;border:1px solid #fff3;border-radius:8px;height:34px;font-size:13px;font-weight:700}.weapon-btn:hover{background:#ffffff29}.weapon-btn.active{background:#3e8cff38;border-color:#3e8cfff2}.menu-card input[type=range]{width:100%}#resume-btn{color:#f4f7fb;cursor:pointer;background:#2f77ff;border:1px solid #fff3;border-radius:8px;height:38px;margin-top:4px;font-size:14px;font-weight:700}#resume-btn:hover{background:#4385ff}
body{color:#f4f8ff;background:#070d14;margin:0;font-family:Inter,Segoe UI,Roboto,sans-serif}.overlay-panel{z-index:70;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;pointer-events:none;background:#080e18db;border:1px solid #fff3;border-radius:12px;gap:10px;width:min(340px,90vw);padding:14px;transition:opacity .12s,transform .12s;display:grid;position:fixed;top:16px;right:16px;transform:translateY(-8px)}body.game-paused .overlay-panel{opacity:1;pointer-events:auto;transform:translateY(0)}.overlay-panel h2,.overlay-panel h3,.overlay-panel p{margin:0}.inline-form{gap:6px;display:grid}.inline-form label{font-size:12px;font-weight:600}input{height:34px;color:inherit;background:#ffffff14;border:1px solid #ffffff40;border-radius:8px;padding:0 10px}button{color:#f4f7fb;cursor:pointer;background:#2f77ff;border:1px solid #fff3;border-radius:8px;height:34px;font-weight:700}button.secondary{background:#ffffff29}.leaderboard{gap:6px;margin:0;padding:0;list-style:none;display:grid}.leaderboard li{background:#ffffff0f;border-radius:8px;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:6px 8px;display:grid}.auth-page{background:radial-gradient(circle at 20% 22%,#20355947 0%,#070c1600 36%),radial-gradient(circle at 78% 78%,#102a5533 0%,#070c1600 42%),linear-gradient(#050e1c 0%,#061226 58%,#071124 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-shell{background:#050b18c2;border:1px solid #a4b6d824;border-radius:18px;grid-template-columns:1fr 1fr;width:min(1200px,96vw);min-height:min(760px,94vh);display:grid;overflow:hidden;box-shadow:0 24px 60px #00000073,inset 0 1px #ffffff0d}.auth-story{background:linear-gradient(#0a1223a3 0%,#080e1ce0 100%),radial-gradient(circle at 28% 65%,#3e5a9133 0%,#3e5a9100 34%);border-right:1px solid #ffffff0f;flex-direction:column;padding:64px 46px 44px;display:flex;position:relative}.auth-story:before{content:"";pointer-events:none;opacity:.42;background:linear-gradient(#ffffff05,#fff0),repeating-linear-gradient(0deg,#ffffff03 0 1px,#0000 1px 5px);position:absolute;inset:0}.auth-brand,.auth-copy,.auth-feature-list{z-index:1;position:relative}.auth-brand h1{letter-spacing:.015em;color:#f5f7fc;text-transform:lowercase;margin:0;font-size:clamp(31px,3.5vw,40px);font-weight:700;line-height:.95}.auth-brand h1 span{color:#e65961}.auth-brand p{letter-spacing:.28em;color:#d45d64;margin:9px 0 0;font-size:10px}.auth-copy{color:#a3b0c3;gap:8px;max-width:630px;margin-top:44px;font-size:18px;line-height:1.35;display:grid}.auth-copy p{margin:0}.auth-emphasis{color:#ef6c74;margin-top:6px}.auth-feature-list{color:#a5b4ca;border-top:1px solid #ffffff17;gap:12px;margin-top:auto;padding-top:24px;font-size:14px;display:grid}.auth-feature-list p{align-items:center;gap:10px;margin:0;display:flex}.dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dot.fire{background:#d95d68}.dot.gold{background:#d2bb73}.dot.blue{background:#58a5ff}.auth-card{background:0 0;border:none;border-radius:0;gap:12px;width:min(520px,100%);margin:auto;padding:56px 50px 44px;display:grid}.auth-card h2{color:#eef3fd;margin:0;font-size:22px;font-weight:650;line-height:1.08}.auth-card p{margin:0}.auth-subtitle{color:#7784a1;margin-bottom:16px;font-size:14px;line-height:1.35}.auth-card label{color:#8d9ab4;letter-spacing:.09em;text-transform:lowercase;margin-top:4px;font-size:10px}.auth-card input{color:#f4f7ff;background:#ffffff17;border:1px solid #fff3;border-radius:14px;height:46px;padding:0 16px;font-size:16px;font-weight:500}.auth-card input::placeholder{color:#ecf1fc80}.auth-card input:focus{border-color:#64a0ffb8;outline:none;box-shadow:0 0 0 2px #407fe72e}.auth-actions{gap:10px;margin-top:10px;display:grid}.auth-actions button{color:#f4f7ff;letter-spacing:.01em;background:#060d1cb8;border:1px solid #9fb5dc42;border-radius:14px;height:46px;font-size:16px;font-weight:500}.auth-actions button:hover{background:#081226e0;border-color:#c0d1ee70}.auth-actions .secondary{background:#060d1c9e}.auth-stats{border-top:1px solid #ffffff14;margin-top:14px;padding-top:16px}.auth-stats>p{color:#6f7e9f;text-align:center;margin-bottom:10px;font-size:13px}.stat-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.stat-card{text-align:center;background:#09101fc2;border:1px solid #9cb0d63d;border-radius:12px;place-items:center;gap:2px;min-height:68px;padding:8px;display:grid}.stat-card strong{font-size:34px;font-weight:600;line-height:1}.stat-card span{color:#7f8eac;font-size:12px}.stat-red{border-color:#c44f6059}.stat-red strong{color:#db616e}.stat-gold{border-color:#c1aa6059}.stat-gold strong{color:#d3be79}.stat-blue{border-color:#5995df59}.stat-blue strong{color:#64a9ff}.auth-error{color:#ff8080;margin-bottom:4px;font-size:13px}.auth-message{color:#9be39b;margin-bottom:4px;font-size:13px}@media (max-width:1120px){.auth-shell{grid-template-columns:1fr;width:min(760px,96vw);min-height:auto}.auth-story{border-bottom:1px solid #ffffff14;border-right:none;padding:40px 28px 28px}.auth-copy{margin-top:28px}.auth-feature-list{margin-top:24px}.auth-card{width:100%;padding:36px 28px 30px}}@media (max-width:700px){.auth-page{padding:10px}.auth-shell{border-radius:12px}.auth-brand h1{font-size:clamp(32px,7.2vw,42px)}.auth-brand p{font-size:11px}.auth-copy{font-size:clamp(17px,3.9vw,22px)}.auth-feature-list{gap:10px;font-size:clamp(15px,3.2vw,20px)}.auth-card h2{font-size:clamp(30px,6.8vw,46px)}.auth-subtitle{margin-bottom:14px;font-size:clamp(15px,3.5vw,21px)}.auth-card label{font-size:clamp(14px,3vw,18px)}.auth-card input{border-radius:10px;height:52px;padding:0 14px;font-size:clamp(18px,4.1vw,24px)}.auth-actions button{border-radius:12px;height:56px;font-size:clamp(20px,4.3vw,26px)}.auth-stats>p{font-size:clamp(14px,3.2vw,18px)}.stat-card{border-radius:10px;min-height:72px}.stat-card strong{font-size:clamp(22px,5.8vw,30px)}.stat-card span{font-size:clamp(12px,2.8vw,15px)}.auth-error,.auth-message{font-size:14px}}.score-toast{z-index:80;background:#101828e6;border:1px solid #fff3;border-radius:999px;padding:8px 12px;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}
