*{box-sizing:border-box;margin:0;padding:0}body{color:#eee;background:#0d0d1a;width:100vw;height:100vh;font-family:Segoe UI,system-ui,sans-serif;overflow:hidden}.screen{width:100%;height:100%;display:none;position:absolute;top:0;left:0}.screen.active{justify-content:center;align-items:center;display:flex}.btn{cursor:pointer;text-transform:uppercase;letter-spacing:1.5px;border:none;border-radius:10px;padding:12px 32px;font-size:15px;font-weight:700;transition:all .2s}.btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0006}.btn:active{transform:translateY(0);box-shadow:0 2px 8px #0000004d}.btn-primary{color:#fff;background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 2px 12px #e74c3c40}.btn-primary:hover{box-shadow:0 6px 24px #e74c3c59}.btn-secondary{color:#fff;background:linear-gradient(135deg,#3498db,#2980b9);box-shadow:0 2px 12px #3498db33}.btn-secondary:hover{box-shadow:0 6px 24px #3498db4d}.btn-small{color:#aab;background:#3c3c5099;border:1px solid #ffffff14;padding:6px 16px;font-size:13px}.btn-small:hover{background:#505064b3}#menu-screen{background:radial-gradient(at 50% 30%,#1a1028 0%,#0d0d1a 70%);overflow:hidden}#menu-screen .menu-bg-canvas,#menu-model-container{pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;top:0;left:0}#menu-model-container canvas{width:100%;height:100%}.menu-container{z-index:1;text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#10102099;border:1px solid #ffffff0f;border-radius:20px;width:100%;max-width:480px;padding:40px 32px;position:relative;box-shadow:0 8px 40px #00000080,inset 0 1px #ffffff0a}.game-title{background:linear-gradient(135deg,#e74c3c,#f39c12);-webkit-text-fill-color:transparent;text-shadow:none;filter:drop-shadow(0 2px 8px #e74c3c4d);-webkit-background-clip:text;margin-bottom:36px;font-size:72px;font-weight:900;line-height:1}.game-title span{letter-spacing:8px;background:linear-gradient(135deg,#f39c12,#e67e22);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:36px}.name-input{margin-bottom:24px}.name-input input{color:#eee;text-align:center;background:#16213ecc;border:1px solid #ffffff1a;border-radius:10px;outline:none;width:100%;padding:14px 20px;font-size:18px;transition:border-color .2s,box-shadow .2s}.name-input input:focus{border-color:#e74c3c;box-shadow:0 0 0 3px #e74c3c26}.menu-buttons{justify-content:center;gap:12px;margin-bottom:28px;display:flex}.room-list{text-align:left;background:#16213e80;border:1px solid #ffffff0d;border-radius:14px;padding:18px}.room-list h3{color:#667;text-transform:uppercase;letter-spacing:2px;margin-bottom:12px;font-size:12px}.room-item{cursor:pointer;background:#1a1a2e99;border:1px solid #ffffff0a;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:8px;padding:14px 16px;transition:all .2s;display:flex}.room-item:hover{background:#2a2a4eb3;border-color:#e74c3c33;transform:translate(2px)}.room-item .room-info{flex:1}.room-item .room-players{color:#778;font-size:13px}.no-rooms{color:#556;text-align:center;padding:20px;font-style:italic}#lobby-screen{background:radial-gradient(at 50% 20%,#141428 0%,#0d0d1a 70%)}.lobby-container{width:100%;max-width:860px;max-height:100vh;padding:32px;overflow-y:auto}.lobby-header{border-bottom:1px solid #ffffff0f;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:16px;display:flex}.lobby-header h2{flex:1;font-size:22px;font-weight:700}.room-code{color:#f39c12;cursor:pointer;background:#32324699;border:1px solid #f39c1233;border-radius:6px;padding:6px 14px;font-family:monospace;font-size:16px;transition:background .2s}.room-code:hover{background:#323246e6}.lobby-rename{gap:8px;margin-bottom:20px;display:flex}.lobby-rename input{color:#eee;background:#16213e99;border:1px solid #ffffff1a;border-radius:8px;outline:none;flex:1;padding:8px 14px;font-size:14px;transition:border-color .2s,box-shadow .2s}.lobby-rename input:focus{border-color:#e74c3c;box-shadow:0 0 0 3px #e74c3c1a}.lobby-content{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px;display:grid}.player-list,.spell-select,.room-settings{background:#10142899;border:1px solid #ffffff0d;border-radius:14px;padding:18px}.lobby-settings{flex-direction:column;gap:12px;display:flex}.player-list h3,.spell-select h3,.room-settings h3{color:#667;text-transform:uppercase;letter-spacing:2px;margin-bottom:14px;font-size:12px}.room-settings #settings-host-only{color:#556;font-size:11px}.setting-toggle{cursor:pointer;color:#bbc;align-items:center;gap:10px;padding:6px 0;font-size:14px;display:flex}.setting-toggle input[type=checkbox]{accent-color:#e74c3c;cursor:pointer;width:18px;height:18px}.setting-toggle input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.lobby-player{background:#ffffff05;border-radius:8px;align-items:center;gap:12px;margin-bottom:4px;padding:10px 12px;transition:background .15s;display:flex}.lobby-player:hover{background:#ffffff0a}.lobby-player .color-dot{border-radius:50%;width:10px;height:10px;box-shadow:0 0 6px}.lobby-player .name{flex:1;font-size:15px}.lobby-player .ready-status{text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.lobby-player .ready-status.ready{color:#2ecc71}.lobby-player .ready-status.not-ready{color:#c0392b;opacity:.7}.spell-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.spell-option{cursor:pointer;background:#1a1a2e80;border:1px solid #ffffff0a;border-radius:8px;padding:10px 12px;transition:all .2s}.spell-option:hover{background:#2a2a4e80;border-color:#ffffff14}.spell-option.selected{background:#e74c3c14;border-color:#e74c3c80;box-shadow:inset 0 0 12px #e74c3c0d}.spell-option .spell-name{margin-bottom:2px;font-size:14px;font-weight:600}.spell-option .spell-desc{color:#778;font-size:11px}.lobby-footer{text-align:center}.lobby-footer .btn{min-width:180px;padding:14px 40px;font-size:18px}.btn-ready.is-ready{background:linear-gradient(135deg,#2ecc71,#27ae60)}#btn-start-game{background:linear-gradient(135deg,#f39c12,#e67e22);margin-left:12px;animation:1.5s ease-in-out infinite pulse-glow}#btn-start-game.hidden{display:none}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px #f39c1266}50%{box-shadow:0 0 20px #f39c12b3}}#game-screen{background:#111}#game-screen.active{display:block}#game-canvas{cursor:crosshair;width:100%;height:100%;display:block}#hud{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}#hud>*{pointer-events:auto}#hud-top{justify-content:center;align-items:flex-start;gap:32px;padding:16px;display:flex}#round-counter{background:#0009;border-radius:8px;padding:8px 24px;font-size:18px;font-weight:600}#kill-feed{z-index:100;pointer-events:none;flex-direction:column;gap:4px;display:flex;position:fixed;top:60px;left:16px}.kill-msg{color:#fff;white-space:nowrap;background:#000000b3;border-radius:4px;align-items:center;gap:6px;padding:4px 12px;font-size:13px;font-weight:600;animation:5s forwards killFadeInOut;display:flex}.kill-msg .kill-icon{color:#fff;text-shadow:0 1px 2px #00000080;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:800;display:inline-flex}.kill-msg .kill-icon-img{vertical-align:middle;filter:drop-shadow(0 1px 2px #00000080);flex-shrink:0;width:18px;height:18px}.kill-msg .kill-killer{color:#f39c12}.kill-msg .kill-victim{color:#ecf0f1}@keyframes killFadeInOut{0%{opacity:0;transform:translate(-10px)}8%{opacity:1;transform:translate(0)}75%{opacity:1}to{opacity:0}}#magick-popup{color:#f1c40f;text-shadow:0 0 20px #f1c40fcc,0 0 40px #f1c40f66;pointer-events:none;z-index:200;opacity:1;letter-spacing:2px;text-transform:uppercase;font-size:48px;font-weight:900;transition:opacity .5s;position:fixed;top:30%;left:50%;transform:translate(-50%,-50%)}#magick-popup.hidden{display:none}#magick-popup.fade-out{opacity:0}#hud-right{position:absolute;top:16px;right:16px}#scoreboard{background:#0009;border-radius:8px;min-width:200px;padding:12px 16px}.score-row{align-items:center;gap:12px;padding:4px 0;font-size:13px;display:flex}.score-row .color-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.score-row .name{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.score-row .kills,.score-row .points{text-align:right;width:30px}.score-row.dead{opacity:.4}#hud-bottom{flex-direction:column;align-items:center;gap:12px;display:flex;position:absolute;bottom:24px;left:50%;transform:translate(-50%)}#hp-bar-container{background:#0009;border-radius:10px;width:200px;height:20px;position:relative;overflow:hidden}#hp-bar{background:linear-gradient(90deg,#e74c3c,#2ecc71);width:100%;height:100%;transition:width .2s}#hp-text{text-shadow:0 1px 2px #000c;font-size:12px;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}#spell-bar{gap:8px;display:flex}.spell-slot{cursor:pointer;pointer-events:auto;background:#0009;border:2px solid #444;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;width:56px;height:56px;display:flex;position:relative}.spell-slot .spell-key{color:#f39c12;text-shadow:0 1px 3px #000000e6;letter-spacing:-.5px;font-size:13px;font-weight:800;position:absolute;top:2px;left:4px}.spell-slot .spell-icon{font-size:20px}.spell-slot .cooldown-overlay{background:#000000b3;width:100%;transition:height .1s linear;position:absolute;bottom:0;left:0}.spell-slot .cooldown-text{text-align:center;color:#f39c12;width:100%;font-size:11px;font-weight:700;position:absolute;bottom:2px}.overlay{z-index:100;pointer-events:auto;background:#000000b3;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.overlay.hidden{display:none}.overlay h1{background:linear-gradient(135deg,#f39c12,#e74c3c);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:16px;font-size:48px}.overlay h2{margin-bottom:16px;font-size:28px}#final-scores{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a0a14b3;border:1px solid #ffffff14;border-radius:14px;min-width:420px;margin:20px 0 28px;padding:0;overflow:hidden}.final-table{border-collapse:collapse;width:100%;font-size:15px}.final-table thead{background:#ffffff0a}.final-table th{text-align:center;text-transform:uppercase;letter-spacing:1.5px;color:#667;border-bottom:1px solid #ffffff0f;padding:10px 16px;font-size:11px;font-weight:600}.final-table th.name-col{text-align:left}.final-table td{text-align:center;color:#bbc;border-bottom:1px solid #ffffff08;padding:12px 16px}.final-table td.name-col{text-align:left;color:#eee;align-items:center;gap:10px;font-weight:600;display:flex}.final-table td.pts-col{color:#f39c12;font-size:17px;font-weight:800}.final-table tr:last-child td{border-bottom:none}.final-table .winner-row td{background:#f39c1214}.final-table .winner-row td.name-col{color:#f39c12}.rank-badge{color:#888;background:#ffffff0f;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:800;display:inline-flex}.rank-badge.rank-1{color:#fff;background:linear-gradient(135deg,#f39c12,#e67e22);box-shadow:0 0 10px #f39c1266}.rank-badge.rank-2{color:#fff;background:linear-gradient(135deg,#95a5a6,#7f8c8d)}.rank-badge.rank-3{color:#fff;background:linear-gradient(135deg,#cd7f32,#a0622e)}.spell-icon-badge{color:#fff;vertical-align:middle;text-shadow:0 1px 2px #0006;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;margin-right:6px;font-size:12px;font-weight:800;display:inline-flex}.spell-icon-hud{color:#fff;text-shadow:0 1px 2px #0006;border-radius:5px;justify-content:center;align-items:center;width:26px;height:26px;font-size:14px;font-weight:800;display:inline-flex}.spell-icon-img{vertical-align:middle;border-radius:4px;width:28px;height:28px;margin-right:6px}.spell-icon-hud-img{filter:drop-shadow(0 1px 3px #00000080);border-radius:5px;width:32px;height:32px}#scoreboard .score-header{border-bottom:1px solid #ffffff1a;margin-bottom:4px;padding-bottom:4px}#hud-left{pointer-events:auto;z-index:10;position:absolute;bottom:120px;left:16px}#global-audio{z-index:9999;pointer-events:auto;position:fixed;top:16px;left:16px}.audio-controls{background:#0009;border-radius:8px;flex-direction:column;gap:6px;padding:8px 12px;display:flex}.audio-row{align-items:center;gap:8px;display:flex}.audio-label{color:#aaa;letter-spacing:.5px;min-width:46px;font-size:11px;font-weight:700}.audio-slider{accent-color:#f39c12;cursor:pointer;pointer-events:auto;width:70px;height:4px}.setting-toggle input[type=range]{accent-color:#e74c3c;cursor:pointer;flex:1}.setting-toggle input[type=range]:disabled{opacity:.5;cursor:not-allowed}.game-overlay{pointer-events:none;z-index:50;position:absolute}.game-overlay.hidden{display:none}#countdown-overlay{color:#fff;text-shadow:0 3px 6px #000c;font-size:120px;font-weight:900;top:50%;left:50%;transform:translate(-50%,-50%)}#countdown-overlay.animate{animation:.667s ease-out countdownPulse}@keyframes countdownPulse{0%{opacity:1;transform:translate(-50%,-50%)scale(1.5)}to{opacity:.7;transform:translate(-50%,-50%)scale(1)}}#shrink-warning{color:#e74c3c;text-shadow:0 2px 4px #000c;font-size:28px;font-weight:700;animation:.4s ease-in-out infinite alternate shrinkPulse;top:40px;left:50%;transform:translate(-50%)}@keyframes shrinkPulse{0%{opacity:.5}to{opacity:1}}#lava-vignette{width:100%;height:100%;transition:box-shadow .2s;top:0;left:0}.mode-selector{justify-content:center;gap:8px;margin-bottom:16px;display:flex}.btn-mode{color:#aab;cursor:pointer;background:#28283c99;border:1px solid #ffffff14;border-radius:8px;padding:8px 20px;font-size:13px;transition:all .2s}.btn-mode:hover{background:#3c3c50b3}.btn-mode.active{color:#fff;background:linear-gradient(135deg,#e74c3c,#c0392b);border-color:#e74c3c66;box-shadow:0 2px 12px #e74c3c40}.mode-label{text-align:center;color:#889;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;font-size:13px;font-weight:600}.mode-tag{text-transform:uppercase;letter-spacing:.5px;vertical-align:middle;border-radius:4px;margin-left:6px;padding:2px 6px;font-size:10px;font-weight:700}.mode-tag.magicka{color:#e74c3c;background:#e74c3c33;border:1px solid #e74c3c4d}.element-reference{background:#10142899;border:1px solid #ffffff0d;border-radius:14px;padding:18px}.element-reference h3{color:#667;text-transform:uppercase;letter-spacing:2px;margin-bottom:14px;font-size:12px}.element-ref-grid{grid-template-columns:1fr 1fr;gap:6px;margin-bottom:12px;display:grid}.element-ref-item{background:#1a1a2e80;border-radius:6px;align-items:center;gap:8px;padding:6px 10px;display:flex}.eq-key{color:#f39c12;background:#ffffff14;border:1px solid #ffffff26;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:800;display:inline-flex}.eq-name{font-size:13px;font-weight:600}.element-ref-info{color:#778;font-size:11px;line-height:1.6}.element-ref-info p{margin-bottom:4px}.element-ref-info b{color:#aab}.element-queue{justify-content:center;gap:6px;display:flex}.eq-slot{border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .15s;display:flex}.eq-slot.empty{background:#ffffff0f;border:1px solid #ffffff1a}.eq-slot.filled{border:2px solid #ffffff4d}.eq-slot .eq-label{color:#fff;text-shadow:0 1px 3px #000c;font-size:14px;font-weight:800}.eq-slot.eq-slot-new{animation:.25s cubic-bezier(.34,1.56,.64,1) eqPopIn}@keyframes eqPopIn{0%{opacity:.5;transform:scale(.5)}60%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}.eq-hint{color:#667;text-align:center;margin-top:6px;font-size:10px}#element-queue-hud{flex-direction:column;align-items:center;display:flex}#status-effects{justify-content:center;gap:4px;min-height:20px;display:flex}.status-icon{color:#fff;text-shadow:0 1px 2px #00000080;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:14px;font-weight:800;animation:1s ease-in-out infinite alternate statusPulse;display:flex}@keyframes statusPulse{0%{opacity:.7;transform:scale(.95)}to{opacity:1;transform:scale(1.05)}}.status-icon-wrap{flex-direction:column;align-items:center;gap:2px;display:flex}.status-duration-bar{background:#0006;border-radius:2px;width:22px;height:3px;overflow:hidden}.status-duration-fill{border-radius:2px;height:100%;transition:width .2s linear}#charge-bar-container{background:#00000080;border:1px solid #ffffff26;border-radius:4px;width:200px;height:8px;margin:0 auto 6px;position:relative;overflow:hidden}#charge-bar{background:linear-gradient(90deg,#f39c12,#e74c3c,#f0f);border-radius:3px;width:0%;height:100%;transition:width .1s}#charge-text{color:#f39c12;text-shadow:0 1px 3px #000c;font-size:11px;font-weight:700;position:absolute;top:-3px;right:-40px}#element-key-helper{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border-radius:8px;flex-direction:column;gap:4px;padding:6px;display:flex}.ekh-row{gap:4px;display:flex}.ekh-btn{border:2px solid var(--el-color);cursor:pointer;width:52px;height:48px;box-shadow:0 0 8px color-mix(in srgb, var(--el-color) 30%, transparent);background:#0009;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;padding:2px;transition:background .15s,transform .1s;display:flex}.ekh-btn:hover{background:color-mix(in srgb, var(--el-color) 25%, #0009);transform:scale(1.08)}.ekh-btn:active{background:color-mix(in srgb, var(--el-color) 40%, #0009);transform:scale(.95)}.ekh-key{color:var(--el-color);text-shadow:0 0 6px var(--el-color);font-size:16px;font-weight:900;line-height:1}.ekh-name{color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:9px;font-weight:600;line-height:1}@media (max-width:768px){.game-title{margin-bottom:20px;font-size:48px}.game-title span{letter-spacing:4px;font-size:24px}.menu-container{-webkit-backdrop-filter:none;backdrop-filter:none;background:#101020d9;border-radius:14px;max-width:95vw;padding:24px 18px}.name-input input{padding:12px 16px;font-size:16px}.btn{padding:10px 22px;font-size:14px}.menu-buttons{flex-direction:column;gap:8px}.lobby-container{-webkit-overflow-scrolling:touch;max-width:100vw;padding:16px}.lobby-header{flex-wrap:wrap;gap:8px;margin-bottom:12px;padding-bottom:12px}.lobby-header h2{width:100%;font-size:18px}.lobby-content{grid-template-columns:1fr;gap:12px;margin-bottom:16px}.spell-grid{grid-template-columns:1fr 1fr;gap:4px}.spell-option{padding:8px 10px}.spell-option .spell-name{font-size:13px}.spell-option .spell-desc{font-size:10px}.lobby-footer .btn{min-width:140px;padding:12px 24px;font-size:16px}#hud-top,#hud-left,#hud-right{pointer-events:none}#hud-top{gap:8px;padding:8px}#round-counter{padding:6px 14px;font-size:14px}#kill-feed{top:40px;left:8px}.kill-msg{padding:3px 8px;font-size:11px}#magick-popup{font-size:32px}#hud-right{top:8px;right:8px}#scoreboard{min-width:140px;padding:8px 10px;font-size:11px}.score-row{gap:6px;font-size:11px}.score-row .kills,.score-row .points{width:22px}#hud-bottom{gap:8px;bottom:16px}#hp-bar-container{pointer-events:none;width:160px;height:16px}#hp-text{font-size:10px}.spell-slot{pointer-events:auto;width:50px;height:50px}.spell-slot .spell-key{font-size:11px}.spell-icon-hud-img{width:28px;height:28px}#global-audio{inset:auto 8px 8px auto}.audio-controls{padding:6px 8px}.audio-slider{width:50px}.audio-label{min-width:36px;font-size:10px}.overlay h1{font-size:32px}.overlay h2{font-size:20px}#final-scores{width:90vw;min-width:auto;max-width:400px}.final-table{font-size:13px}.final-table th,.final-table td{padding:8px 10px}#countdown-overlay{font-size:80px}#shrink-warning{font-size:20px;top:30px}}@media (max-width:480px){.game-title{margin-bottom:16px;font-size:36px}.game-title span{letter-spacing:3px;font-size:18px}.menu-container{padding:18px 14px}.lobby-header h2{font-size:16px}.spell-slot{width:44px;height:44px}.spell-icon-hud-img{width:24px;height:24px}#scoreboard{min-width:120px;padding:6px 8px}.score-row{gap:4px;font-size:10px}#hp-bar-container{width:130px;height:14px}#global-audio{bottom:80px;right:8px}}#respawn-timer{z-index:150;pointer-events:none;background:#0009;border:1px solid #2ecc7159;border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:18px 36px;display:flex;position:absolute;top:38%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 30px #2ecc7140}#respawn-timer.hidden{display:none}#respawn-timer .respawn-label{letter-spacing:2px;text-transform:uppercase;color:#aaa;font-size:14px;font-weight:600}#respawn-timer .respawn-seconds{color:#2ecc71;text-shadow:0 0 16px #2ecc7199;font-variant-numeric:tabular-nums;font-size:44px;font-weight:900;line-height:1}.match-end-actions{justify-content:center;align-items:center;gap:12px;margin-top:8px;display:flex}#btn-rematch.requested{opacity:.7;cursor:default}.rematch-status{color:#aaa;letter-spacing:1px;min-height:18px;margin-top:10px;font-size:13px}.rematch-status.full{color:#2ecc71;font-weight:700}
