*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;background:#0a0e1a;font-family:Segoe UI,system-ui,sans-serif;color:#c8d8f0;cursor:default;-webkit-user-select:none;user-select:none}#app{width:100%;height:100%;position:relative}#game-canvas{display:block;width:100%;height:100%;z-index:0}#ui-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:10}#ui-overlay.interactive{pointer-events:auto}#ui-overlay:not(.interactive) .hud-container,#ui-overlay:not(.interactive) .gameplay-hint{pointer-events:none}.screen{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#0f1a2e,#060a12 70%);pointer-events:auto}.menu-screen{background:linear-gradient(180deg,#060a12cc,#0a1020aa 40%,#060a12ee),url(./cover-front-CI4nWmN8.png) center / cover no-repeat}.screen.hidden{display:none}.title-main{font-size:clamp(2.5rem,8vw,5rem);font-weight:900;letter-spacing:.15em;color:#4a9eff;text-shadow:0 0 30px #1a5fcc,0 0 60px #0a2a66;margin-bottom:.2em}.title-sub{font-size:clamp(.9rem,2.5vw,1.3rem);color:#6a8ab0;letter-spacing:.3em;text-transform:uppercase;margin-bottom:2.5rem}.brand{position:absolute;bottom:1.5rem;font-size:.75rem;color:#3a5070;letter-spacing:.2em}.menu-buttons{display:flex;flex-direction:column;gap:.75rem;min-width:280px}.btn{padding:.85rem 2rem;font-size:1rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border:2px solid #2a5080;background:linear-gradient(180deg,#142238,#0c1525);color:#8ab4e8;cursor:pointer;transition:all .15s;text-align:center}.btn:hover,.btn.focused{border-color:#4a9eff;color:#fff;background:linear-gradient(180deg,#1a3a60,#102040);box-shadow:0 0 20px #1a5fcc44}.btn.primary{border-color:#4a9eff;color:#fff}.btn:disabled{opacity:.4;cursor:not-allowed}.credits-display{margin-bottom:1.5rem;font-size:1.1rem;color:#ffd060;letter-spacing:.05em}.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;max-width:900px;width:90%;max-height:55vh;overflow-y:auto;padding:.5rem;margin-bottom:1.5rem}.shop-item{border:2px solid #2a4060;background:#0c1525;padding:1rem;cursor:pointer;transition:border-color .15s}.shop-item:hover,.shop-item.focused{border-color:#4a9eff}.shop-item.owned{border-color:#2a6040;opacity:.7}.shop-item.cant-afford{opacity:.5}.shop-item h3{font-size:.95rem;color:#4a9eff;margin-bottom:.3rem}.shop-item p{font-size:.8rem;color:#6a8ab0;margin-bottom:.5rem}.shop-item .price{font-size:.9rem;color:#ffd060;font-weight:700}.shop-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.tab{padding:.5rem 1.2rem;border:1px solid #2a4060;background:#0c1525;color:#6a8ab0;cursor:pointer;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em}.tab.active,.tab:hover{border-color:#4a9eff;color:#fff}.mission-list{display:flex;flex-direction:column;gap:.6rem;max-width:500px;width:90%;margin-bottom:1.5rem}.mission-card{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.2rem;border:2px solid #2a4060;background:#0c1525;cursor:pointer;transition:border-color .15s}.mission-card:hover,.mission-card.focused{border-color:#4a9eff}.mission-card.locked{opacity:.4;cursor:not-allowed}.mission-card.completed{border-color:#2a6040}.mission-card h3{font-size:1rem;color:#8ab4e8}.mission-card span{font-size:.8rem;color:#ffd060}.hud{position:absolute;pointer-events:none}.hud-p1{top:0;left:0;width:100%;height:50%}.hud-p2{top:50%;left:0;width:100%;height:50%}.hud-solo{top:0;right:0;bottom:0;left:0}.hud-bar{position:absolute;height:8px;background:#1a2030;border:1px solid #2a4060}.hud-hp{top:12px;left:12px;width:160px}.hud-hp .fill{height:100%;background:linear-gradient(90deg,#c03030,#ff5050);transition:width .2s}.hud-shield{top:24px;left:12px;width:160px}.hud-shield .fill{height:100%;background:linear-gradient(90deg,#3060c0,#50a0ff);transition:width .2s}.hud-ammo{position:absolute;bottom:12px;right:12px;font-size:1.2rem;font-weight:700;color:#ffd060;text-shadow:0 0 8px #000}.hud-weapon{position:absolute;bottom:36px;right:12px;font-size:.75rem;color:#6a8ab0;text-shadow:0 0 8px #000}.hud-score{position:absolute;top:12px;right:12px;font-size:.9rem;color:#ffd060;text-shadow:0 0 8px #000}.hud-label{position:absolute;top:4px;left:12px;font-size:.65rem;color:#4a9eff;letter-spacing:.15em;text-transform:uppercase}.hud-p2 .hud-label{top:calc(50% + 4px)}.hud-p2 .hud-hp{top:calc(50% + 12px)}.hud-p2 .hud-shield{top:calc(50% + 24px)}.hud-p2 .hud-ammo{bottom:calc(50% + 12px)}.hud-p2 .hud-weapon{bottom:calc(50% + 36px)}.hud-p2 .hud-score{top:calc(50% + 12px)}.hud-crosshair{position:absolute;width:24px;height:24px;left:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:15}.crosshair-solo{top:50%}.crosshair-p1{top:25%}.crosshair-p2{top:75%}.hud-crosshair:before,.hud-crosshair:after{content:"";position:absolute;background:#6bfc;box-shadow:0 0 6px #4a9eff}.hud-crosshair:before{width:2px;height:100%;left:50%;transform:translate(-50%)}.hud-crosshair:after{height:2px;width:100%;top:50%;transform:translateY(-50%)}.gameplay-hint{position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%);background:#0a1020dd;border:1px solid #2a5080;padding:.75rem 1.25rem;font-size:.8rem;color:#8ab4e8;text-align:center;line-height:1.5;pointer-events:none;z-index:20;animation:hintFade 6s forwards}@keyframes hintFade{0%,70%{opacity:1}to{opacity:0}}#game-canvas:focus{outline:none}.pause-overlay,.result-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000a;pointer-events:auto}.pause-overlay h2,.result-overlay h2{font-size:2rem;color:#4a9eff;margin-bottom:1.5rem;letter-spacing:.1em}.result-overlay .reward{font-size:1.2rem;color:#ffd060;margin-bottom:1rem}.controls-hint{margin-top:1.5rem;font-size:.75rem;color:#4a6080;text-align:center;line-height:1.6;max-width:500px}.screen h2{font-size:1.5rem;color:#4a9eff;margin-bottom:1rem;letter-spacing:.1em}.back-btn{margin-top:.5rem}
