*{box-sizing:border-box;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;margin:0;padding:0}body,html{color:#f5f5f7;background-color:#0b0b0f;width:100%;height:100%;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}.pixel-text{letter-spacing:.05em;font-family:VT323,monospace}#game-container{width:100vw;height:100vh;position:relative;overflow:hidden}#game-canvas{z-index:1;width:100%;height:100%;display:block}.vignette{pointer-events:none;z-index:5;opacity:0;mix-blend-mode:multiply;width:100%;height:100%;transition:opacity .15s ease-out;position:absolute;top:0;left:0}#damage-flash{background-color:#dc262626;box-shadow:inset 0 0 100px #dc2626b3}#damage-flash.flash-active{opacity:1}.overlay{z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:radial-gradient(circle,#101018d9 0%,#08080cf2 100%);justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .5s;display:flex;position:absolute;top:0;left:0}.overlay.hidden{opacity:0;pointer-events:none}.glass-panel{text-align:center;background:#12121ca6;border:1px solid #ffffff14;border-radius:16px;width:90%;max-width:580px;padding:3rem;transition:transform .3s;transform:translateY(0);box-shadow:0 20px 40px #0009,inset 0 1px #ffffff1a}.text-center{flex-direction:column;align-items:center;display:flex}.game-title{color:#fa0;text-shadow:0 4px #7f5500,0 8px 12px #00000080;margin-bottom:.5rem;font-size:4rem;font-weight:800;line-height:1}.animated-title{animation:4s ease-in-out infinite floatTitle}@keyframes floatTitle{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-8px)scale(1.02)}}.tagline{color:#a0a0ab;text-transform:uppercase;letter-spacing:.1em;margin-bottom:2rem;font-size:1.1rem}.subtitle{color:#71717a;margin-bottom:1.5rem;font-size:1rem}.progress-bar-container{background-color:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;width:100%;height:12px;margin-bottom:1rem;overflow:hidden}.progress-bar{background:linear-gradient(90deg,#fa0 0%,#fc0 100%);height:100%;transition:width .1s;box-shadow:0 0 8px #fa0}.status-text{color:#fc0;font-size:.9rem}.btn{color:#fff;cursor:pointer;text-shadow:0 2px 2px #00000080;background:linear-gradient(#3b82f6 0%,#1d4ed8 100%);border:none;border-radius:8px;outline:none;margin-top:1rem;padding:1rem 2.5rem;font-size:1.75rem;transition:all .1s;box-shadow:0 4px #1e3a8a,0 8px 16px #1d4ed84d}.btn:hover{background:linear-gradient(#60a5fa 0%,#2563eb 100%);transform:translateY(-2px);box-shadow:0 6px #1e3a8a,0 12px 20px #1d4ed866}.btn:active{transform:translateY(2px);box-shadow:0 2px #1e3a8a,0 4px 8px #1d4ed833}.controls-guide{background:#0000004d;border:1px solid #ffffff08;border-radius:12px;width:100%;margin-bottom:2rem;padding:1.25rem}.guide-item{color:#d4d4d8;justify-content:flex-start;align-items:center;margin-bottom:.75rem;font-size:.95rem;display:flex}.guide-item:last-child{margin-bottom:0}.key{color:#fff;text-align:center;background-color:#3f3f46;border:1px solid #71717a;border-bottom-width:3px;border-radius:4px;min-width:24px;margin-right:.3rem;padding:.2rem .5rem;font-size:.85rem;font-weight:600;display:inline-block}.mouse-btn{color:#38bdf8;background-color:#1e293b;border:1px solid #475569;border-bottom-width:3px;border-radius:4px;margin-right:.5rem;padding:.2rem .5rem;font-size:.85rem;font-weight:600;display:inline-block}#game-hud{pointer-events:none;z-index:8;flex-direction:column;justify-content:space-between;width:100%;height:100%;padding:2rem;transition:opacity .3s;display:flex;position:absolute;top:0;left:0}#game-hud.hidden{opacity:0}.hud-top-left{flex-direction:column;gap:.5rem;display:flex}.level-indicator{color:#fc0;text-shadow:2px 2px #000;font-size:2rem;font-weight:700}.hearts-container{filter:drop-shadow(2px 2px #000);gap:.25rem;display:flex}.heart{background-repeat:no-repeat;background-size:contain;width:26px;height:24px;display:inline-block}.hud-top-right{text-align:right;text-shadow:2px 2px #000;color:#fff;flex-direction:column;gap:.25rem;font-size:1.8rem;font-weight:700;display:flex;position:absolute;top:2rem;right:2rem}.score-display{color:#fc0}.wave-display{color:#5f5}.mobs-left-display{color:#f55}.hud-bottom-center{align-self:center;width:60%;max-width:600px;margin-bottom:1rem}.xp-bar-container{background-color:#0009;border:2px solid #555;border-radius:0;height:10px;overflow:hidden;box-shadow:0 4px 6px #00000080}.xp-bar-fill{background-color:#5f5;height:100%;transition:width .2s;box-shadow:0 0 6px #5f5}.hud-quickbar{pointer-events:auto;justify-content:center;gap:6px;margin-top:24px;display:flex}.quickbar-slot{background-color:#101018b3;border:4px solid #555;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;width:58px;height:58px;display:flex;position:relative;box-shadow:0 8px 16px #00000080}.quickbar-slot.active{background-color:#ffaa001a;border-color:#fa0;box-shadow:0 0 15px #fa06}.quickbar-slot.empty{box-shadow:none;background-color:#10101866;border-color:#5556}.quickbar-slot img{width:36px;height:36px;image-rendering:pixelated}.slot-label{color:#fa0;text-shadow:1px 1px #000;text-align:center;width:100px;font-size:1.1rem;position:absolute;top:-24px}.game-over-title{color:#f33;text-shadow:0 4px maroon,0 8px 16px #000000b3;margin-bottom:.5rem;font-size:5rem}.text-red{color:#ef4444}.text-yellow{color:#facc15}.text-green{color:#4ade80}.animated-pulse{animation:2s infinite alternate pulseRed}@keyframes pulseRed{0%{text-shadow:0 4px maroon,0 0 10px #ef444433}to{text-shadow:0 4px maroon,0 0 30px #ef4444cc}}.stats-panel{background:#0006;border:1px solid #ffffff0d;border-radius:8px;width:100%;margin:1.5rem 0;padding:1.5rem;font-size:1.6rem}.stat-row{justify-content:space-between;margin-bottom:.5rem;display:flex}.stat-row:last-child{margin-bottom:0}.fade-in{animation:.4s ease-out forwards fadeIn}.scale-up{animation:.3s cubic-bezier(.34,1.56,.64,1) forwards scaleUp}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.hidden{display:none!important}@keyframes heartBeat{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.heart-beat{animation:.6s infinite heartBeat}.pause-btn{pointer-events:auto;color:#fff;cursor:pointer;background:#12121ca6;border:1px solid #ffffff26;border-radius:8px;outline:none;align-self:flex-end;margin-bottom:.5rem;padding:.5rem 1rem;font-size:1.5rem;transition:all .1s;box-shadow:0 4px 10px #0000004d}.pause-btn:hover{background:#fa03;border-color:#fa0;transform:scale(1.05)}.pause-btn:active{transform:scale(.95)}.menu-buttons{flex-direction:column;gap:1rem;width:100%;max-width:320px;margin-top:1.5rem;display:flex}.btn-secondary{background:linear-gradient(#4b5563 0%,#1f2937 100%)!important;box-shadow:0 4px #111827,0 8px 16px #1f29374d!important}.btn-secondary:hover{background:linear-gradient(#6b7280 0%,#374151 100%)!important;box-shadow:0 6px #111827,0 12px 20px #1f293766!important}.settings-container{background:#00000059;border:1px solid #ffffff0d;border-radius:12px;flex-direction:column;gap:1.5rem;width:100%;margin:1.5rem 0;padding:2rem;font-size:1.4rem;display:flex}.setting-row{justify-content:space-between;align-items:center;gap:1.5rem;width:100%;display:flex}.setting-label{color:#a0a0ab;text-shadow:1px 1px #000;text-align:left;font-weight:600}.slider-val-container{align-items:center;gap:1rem;width:60%;display:flex}.game-slider{appearance:none;background:#ffffff1a;border:1px solid #fff3;border-radius:4px;outline:none;width:100%;height:8px}.game-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#fa0;border:2px solid #fff;border-radius:4px;width:18px;height:18px;transition:transform .1s;box-shadow:0 0 8px #fa0}.game-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.slider-value{color:#fa0;text-align:right;min-width:45px;font-weight:700}.switch{width:54px;height:28px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.switch-slider{cursor:pointer;background-color:#ffffff26;border:2px solid #fff3;border-radius:6px;transition:all .2s;position:absolute;inset:0}.switch-slider:before{content:"";background-color:#a1a1aa;border-radius:3px;width:18px;height:18px;transition:all .2s;position:absolute;bottom:3px;left:3px}input:checked+.switch-slider{background-color:#5f53;border-color:#5f5}input:checked+.switch-slider:before{background-color:#5f5;transform:translate(26px);box-shadow:0 0 8px #5f5}.game-select{color:#fff;cursor:pointer;background:#12121ce6;border:2px solid #fff3;border-radius:6px;outline:none;padding:.25rem .5rem;font-family:VT323,monospace;font-size:1.4rem}.game-select:focus{border-color:#fa0}#virtual-controls{pointer-events:none;z-index:9;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:flex-end;width:100%;height:240px;padding:2rem;display:flex;position:absolute;bottom:0;left:0}#joystick-zone{pointer-events:auto;touch-action:none;justify-content:center;align-items:center;width:150px;height:150px;display:flex}#joystick-base{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#12121c80;border:3px solid #ffffff40;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;display:flex;position:relative;box-shadow:0 10px 25px #00000080,inset 0 2px 5px #ffffff0d}#joystick-handle{cursor:pointer;background:linear-gradient(135deg,#fc0 0%,#fa0 100%);border:2px solid #fff;border-radius:50%;width:50px;height:50px;transition:transform 50ms;position:absolute;box-shadow:0 5px 15px #fa06}#action-buttons-zone{pointer-events:auto;flex-direction:column;align-items:flex-end;gap:1.25rem;display:flex}.btn-group-row{align-items:flex-end;gap:1.25rem;display:flex}.action-btn{color:#fff;cursor:pointer;text-shadow:0 2px 2px #00000080;touch-action:none;background:#12121ca6;border:3px solid #ffffff40;border-radius:50%;outline:none;justify-content:center;align-items:center;width:72px;height:72px;font-size:1.2rem;transition:all .15s cubic-bezier(.175,.885,.32,1.275);display:flex;box-shadow:0 8px 16px #0006}.action-btn:active{transform:scale(.88);box-shadow:0 3px 8px #0000004d}.btn-blue{background:#3b82f633;border-color:#3b82f6;width:62px;height:62px;font-size:1rem;box-shadow:0 8px 16px #3b82f633}.btn-blue:active{background:#3b82f680}.btn-green{background:#10b98133;border-color:#10b981;box-shadow:0 8px 16px #10b98133}.btn-green:active{background:#10b98180}.btn-red{background:#ef444433;border-color:#ef4444;width:88px;height:88px;margin-top:-15px;font-size:1.4rem;box-shadow:0 8px 16px #ef44444d}.btn-red:active{background:#ef444480}
