*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:#0b1622;color:#eef3f8}.screen{position:fixed;inset:0}.hidden{display:none!important}#login-screen,.overlay{display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 30%,#1e3a5f,#0b1622 70%)}.overlay{background:#070e16d1}.login-card{width:min(92vw,420px);background:#13212f;border:1px solid #24435f;border-radius:16px;padding:28px 26px;text-align:center;box-shadow:0 18px 60px #00000080}.login-card h1{font-size:30px;margin-bottom:8px}.subtitle{color:#9fb4c7;font-size:14px;margin-bottom:20px}#name-input{width:100%;padding:13px 14px;font-size:16px;border-radius:10px;border:1px solid #2c5278;background:#0d1925;color:#fff;outline:none;margin-bottom:12px}#name-input:focus{border-color:#46a0ff}button{width:100%;padding:13px;font-size:16px;font-weight:600;border:none;border-radius:10px;background:linear-gradient(180deg,#2f9bff,#1f7ce0);color:#fff;cursor:pointer;transition:filter .15s}button:hover{filter:brightness(1.08)}.hint{margin-top:16px;font-size:12px;color:#6f879b}.picker-label{text-align:left;font-size:12px;color:#6f879b;margin:4px 2px 8px;text-transform:uppercase;letter-spacing:.5px}.plane-picker{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;max-height:260px;overflow-y:auto}.picker-loading{text-align:center;color:#5c768c;font-size:13px;padding:18px}.plane-card{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#0d1925;border:1px solid #2c5278;border-radius:10px;cursor:pointer;transition:background .12s,border-color .12s,transform .06s;text-align:left}.plane-card:hover{background:#123}.plane-card.selected{border-color:#46a0ff;background:#15334d;box-shadow:0 0 0 2px #46a0ff38}.plane-card .swatch{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;flex:0 0 auto;overflow:hidden}.plane-card .swatch img{width:100%;height:100%;object-fit:cover}.plane-card .info{flex:1;display:flex;flex-direction:column;gap:2px}.plane-card .info strong{font-size:14px;color:#eef3f8}.plane-card .info small{font-size:11px;color:#8aa2b6}.plane-card .check{font-size:16px;color:#46a0ff;opacity:0}.plane-card.selected .check{opacity:1}button:disabled{opacity:.5;cursor:not-allowed}.ad-slot{margin-top:22px;height:110px;border:1px dashed #36506b;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#5c768c;font-size:13px;background:repeating-linear-gradient(45deg,#0e1b27,#0e1b27 10px,#101f2d 10px 20px)}.legal-footer{margin-top:14px;text-align:center;font-size:11px;color:#5c768c}.legal-footer a{color:#6f879b;text-decoration:none}.legal-footer a:hover{color:#46a0ff;text-decoration:underline}#pixi-container{position:absolute;inset:0}#pixi-container canvas{display:block}#hud{position:absolute;top:14px;left:14px;display:flex;flex-direction:column;gap:10px;pointer-events:none;text-shadow:0 2px 4px rgba(0,0,0,.6)}.hud-item{font-size:22px;font-weight:700}.hud-carried{font-size:18px;color:#ffd23f}.hud-water{display:flex;align-items:center;gap:8px;font-size:14px}.hud-water>span{min-width:22px}.water-bar{width:180px;height:16px;background:#0006;border:1px solid #3a6b95;border-radius:8px;overflow:hidden}#health-fill{height:100%;width:100%;background:linear-gradient(90deg,#4caf50,#ffc107 60%,#e53935);transition:width .1s linear}#armor-fill{height:100%;width:100%;background:linear-gradient(90deg,#0288d1,#4fc3f7);transition:width .1s linear}#conn-status{position:absolute;bottom:12px;left:14px;font-size:12px;color:#8aa2b6}.toast{position:fixed;top:18px;left:50%;transform:translate(-50%) translateY(-150%);background:#0b1622f0;color:#f0f6fc;padding:12px 22px;border-radius:10px;font-weight:600;font-size:14px;border:1px solid rgba(70,160,255,.35);box-shadow:0 6px 24px #00000073;z-index:9999;opacity:0;pointer-events:none;transition:transform .22s ease,opacity .22s ease;max-width:80vw;text-align:center}.toast.show{transform:translate(-50%) translateY(0);opacity:1}.ping-badge{position:absolute;bottom:12px;left:14px;font-size:12px;color:#8aa2b6;background:#0b16228c;padding:3px 8px;border-radius:6px;border:1px solid rgba(70,160,255,.22);font-variant-numeric:tabular-nums;pointer-events:none}.control-badge{position:absolute;top:14px;right:14px;font-size:12px;font-weight:600;letter-spacing:.3px;padding:5px 10px;border-radius:6px;background:#0b16229e;border:1px solid rgba(70,160,255,.28);color:#cfe1f3;backdrop-filter:blur(6px);pointer-events:none;user-select:none;transition:background .15s,border-color .15s}.control-badge.keyboard{border-color:#ffe14d8c;color:#ffe14d}#leaderboard{position:absolute;top:54px;right:14px;min-width:180px;max-width:240px;background:#0b16229e;border:1px solid rgba(70,160,255,.28);border-radius:10px;padding:10px 12px;backdrop-filter:blur(6px);pointer-events:none;font-size:13px}#leaderboard.hidden{display:none}.lb-title{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:#8aa2b6;margin-bottom:6px}#lb-list{list-style:none;margin:0;padding:0}#lb-list li{display:flex;align-items:center;gap:8px;padding:3px 0;color:#d8e6f0}#lb-list li .rank{width:18px;text-align:right;color:#6f879b;font-variant-numeric:tabular-nums}#lb-list li .name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#lb-list li .score{font-weight:700;font-variant-numeric:tabular-nums;color:#eef3f8}#lb-list li.self,#lb-list li.self .rank,#lb-list li.self .score{color:#ffe14d}.ghost-btn{margin-top:10px;background:transparent;border:1px solid #2c5278;color:#bcd2e6}.ghost-btn:hover{background:#15273a;filter:none}.htp-overlay{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:16px;background:#070e16d1;animation:htp-fade .18s ease}@keyframes htp-fade{0%{opacity:0}to{opacity:1}}.htp-card{position:relative;width:min(94vw,580px);background:#13212f;border:1px solid #24435f;border-radius:16px;padding:18px 18px 14px;box-shadow:0 18px 60px #0000008c}.htp-close{position:absolute;top:10px;right:12px;width:30px;height:30px;padding:0;border-radius:8px;background:transparent;border:none;color:#9fb4c7;font-size:16px;line-height:1;cursor:pointer}.htp-close:hover{background:#1b2c3d;color:#fff;filter:none}.htp-head{display:flex;align-items:center;justify-content:space-between;padding-right:34px;margin-bottom:12px}.htp-title{font-size:18px;font-weight:700;color:#eef3f8}.htp-step{font-size:12px;font-weight:500;color:#6f879b}.htp-next{width:auto;padding:7px 14px;font-size:13px;border-radius:8px}.htp-stage{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:12px;overflow:hidden;background:linear-gradient(#0a1840,#14365f 55%,#1c5a86 80%,#12598c)}.htp-stage>*{position:absolute;will-change:transform,opacity}.htp-arrow{position:absolute;top:50%;width:38px;height:38px;padding:0;transform:translateY(-50%);border-radius:50%;background:#0b162299;border:1px solid rgba(70,160,255,.35);color:#cfe1f3;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.htp-arrow.left{left:6px}.htp-arrow.right{right:6px}.htp-arrow:hover{background:#14283ce6;filter:none}.htp-arrow.disabled{opacity:.25;pointer-events:none}.htp-caption{margin:12px 8px 4px;min-height:42px;font-size:14px;line-height:1.45;color:#cfe1f3;text-align:center}.htp-caption strong{color:#ffe14d}.htp-dots{display:flex;gap:7px;justify-content:center;margin:6px 0 2px}.htp-dot{width:8px;height:8px;border-radius:50%;background:#2c5278}.htp-dot.active{background:#46a0ff}.htp-plane{width:76px;height:47px;overflow:visible}.htp-plane-img{width:108px;height:auto;filter:drop-shadow(0 3px 6px rgba(0,0,0,.35))}.htp-hook{width:3px;background:#3a2a18;border-radius:2px;transform-origin:top center}.htp-hooktip{position:absolute;top:100%;left:50%;transform:translate(-50%,-3px);line-height:0}.htp-hooktip svg{display:block}.htp-armor{width:48px;height:auto;filter:drop-shadow(0 0 6px rgba(120,200,255,.5))}.htp-flash{width:90px;height:90px;border-radius:50%;border:3px solid #4fc3f7}.htp-key{padding:8px 22px;background:#0d1925;border:1px solid #2c5278;border-bottom-width:4px;border-radius:8px;color:#dce8f2;font-weight:600;font-size:13px;white-space:nowrap}.htp-key.pressed{border-bottom-width:1px;background:#15334d;transform:translate(-50%,-50%) translateY(3px)!important}.htp-cursor{filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}.htp-aimline{height:0;border-top:2px dashed rgba(255,255,255,.4)}.htp-mouse{width:34px;height:50px;border:2px solid #cfe1f3;border-radius:17px;background:#0d1925}.htp-mouse-btn{position:absolute;top:1px;width:14px;height:20px}.htp-mouse-btn.left{left:1px;border-right:1px solid #2c5278;border-radius:13px 0 0}.htp-mouse-btn.right{right:1px}.htp-mouse.clicking .htp-mouse-btn.left{background:#46a0ff;border-radius:13px 0 0}.htp-mouse-wheel{position:absolute;top:9px;left:50%;transform:translate(-50%);width:3px;height:8px;border-radius:2px;background:#2c5278}.htp-bullet{width:12px;height:5px;border-radius:50%;background:#fff04a;box-shadow:0 0 6px 2px #ffc828b3}.htp-sea{width:100%;height:45%;background:linear-gradient(#12598c,#0e4674)}.htp-unit>*{position:absolute;left:0;top:0;transform:translate(-50%,-50%)}.htp-shield{overflow:visible;filter:drop-shadow(0 0 4px rgba(120,200,255,.5))}.htp-boom{width:54px;height:54px;border-radius:50%;background:radial-gradient(circle,#fff7cc,#ffd54f 35%,#ff7043 65%,#d8431500 80%)}.htp-spark{width:14px;height:14px;border-radius:50%;background:radial-gradient(circle,#fff,#ffd54f 50%,#ffc82800 75%)}.htp-flame{width:18px;height:22px;border-radius:50%/40% 40% 60% 60%;background:radial-gradient(circle at 50% 70%,#ffd54f,#ff7043 60%,#d84315);filter:drop-shadow(0 0 5px rgba(255,120,40,.7))}.htp-splash{width:40px;height:40px;border-radius:50%;border:3px solid rgba(180,220,255,.85)}.htp-drone{width:88px;height:auto;filter:drop-shadow(0 3px 7px rgba(0,0,0,.4))}.htp-droneflash{width:70px;height:70px;border-color:#ffd23f;box-shadow:0 0 18px 4px #ffc83c99}.htp-star{line-height:0;filter:drop-shadow(0 0 5px rgba(255,210,60,.75))}.htp-star svg{display:block}.htp-smoke{width:26px;height:26px;border-radius:50%;background:radial-gradient(circle,#787882b3,#5a5a6459 55%,#50505a00 75%)}.htp-pop{font-size:15px;font-weight:800;color:#ffe14d;text-shadow:0 1px 3px rgba(0,0,0,.6);pointer-events:none}.htp-starbadge{display:flex;align-items:center;gap:5px;padding:5px 11px;background:#0b1622b8;border:1px solid rgba(255,210,60,.4);border-radius:14px;filter:drop-shadow(0 0 6px rgba(255,210,60,.35))}.htp-starbadge svg{display:block}.htp-starnum{font-size:15px;font-weight:800;color:#ffe14d;min-width:12px;text-align:center}.htp-starbadge.pulse{animation:htp-badgepulse .32s ease}@keyframes htp-badgepulse{0%{transform:translate(-50%,-50%) scale(1)}45%{transform:translate(-50%,-50%) scale(1.22)}to{transform:translate(-50%,-50%) scale(1)}}@media (prefers-reduced-motion: reduce){.htp-overlay{animation:none}}
