:root{--bg: #050510;--surface: rgba(10,12,24,.9);--border: rgba(60,80,140,.3);--gold: #FFD700;--green: #4ade80;--red: #ef4444;--blue: #3b82f6;--text: #e2e8f0;--muted: #94a3b8;--mono: "SF Mono","Fira Code",ui-monospace,monospace}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--mono);background:var(--bg);color:var(--text);overflow:hidden}.app{width:100vw;height:100vh;position:relative;overflow:hidden}.grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;opacity:.25;background-image:linear-gradient(rgba(60,80,140,.15) 1px,transparent 1px),linear-gradient(90deg,rgba(60,80,140,.15) 1px,transparent 1px);background-size:40px 40px}.scanline{position:absolute;left:0;right:0;height:120px;pointer-events:none;z-index:2;top:-120px;background:linear-gradient(180deg,transparent,rgba(59,130,246,.06),transparent);animation:scan 6s linear infinite}@keyframes scan{0%{top:-120px}to{top:100vh}}.globe-stage{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:0}.globe-svg{width:min(78vw,1000px);height:auto}.hq-pin{animation:hq-glow 1.6s ease-in-out infinite}@keyframes hq-glow{0%,to{opacity:1}50%{opacity:.6}}.hq-pulse{transform-origin:center;transform-box:fill-box;animation:hq-ring 2s ease-out infinite}@keyframes hq-ring{0%{transform:scale(1);opacity:.9}to{transform:scale(3.5);opacity:0}}.attack-arc{stroke-dasharray:200;stroke-dashoffset:200;animation:arc-fly .8s ease-out forwards}@keyframes arc-fly{to{stroke-dashoffset:0}}.shield-ring{transform-origin:center;transform-box:fill-box;animation:ring-in .5s ease-out}@keyframes ring-in{0%{opacity:0;transform:scale(.6)}to{opacity:.55;transform:scale(1)}}.top-hud{position:fixed;top:1rem;left:50%;transform:translate(-50%);z-index:20;text-align:center}.counters{display:flex;gap:2.5rem;margin-bottom:.6rem}.counter{text-align:center}.c-num{font-size:2rem;font-weight:800;line-height:1}.c-lbl{font-size:.58rem;letter-spacing:.15em;color:var(--muted);margin-top:.2rem}.alert-banner{background:#dc2626;color:#fff;padding:.4rem 1.6rem;border-radius:4px;font-weight:800;letter-spacing:.1em;font-size:.85rem;display:inline-block}.secured-banner{background:linear-gradient(135deg,#15803d,#16a34a);color:#fff;padding:.4rem 1.6rem;border-radius:4px;font-weight:800;letter-spacing:.1em;font-size:.85rem;display:inline-block;box-shadow:0 0 40px #4ade8066}.log-wall{position:fixed;top:0;left:0;bottom:0;width:270px;background:var(--surface);border-right:1px solid var(--border);z-index:15;padding:1rem .8rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column}.wall-title{font-size:.6rem;letter-spacing:.15em;color:var(--muted);margin-bottom:.8rem}.log-scroll{flex:1;overflow:hidden;display:flex;flex-direction:column;gap:.2rem}.log-row{display:flex;align-items:center;gap:.4rem;font-size:.62rem;padding:.2rem .3rem;border-radius:3px;background:#ffffff05}.log-row.cracked{background:#15803d33}.log-row.banned{background:#7f1d1d55}.log-row.shattered{opacity:.5}.log-flag{font-size:.75rem}.log-ip{color:var(--muted);flex:1}.log-cred{color:#7dd3fc;font-size:.58rem}.log-code{font-weight:700}.code-200{color:#4ade80}.code-401,.code-403,.code-429{color:#f59e0b}.log-row.banned .log-code{color:#ef4444}.chart-wall{position:fixed;top:0;right:0;bottom:0;width:230px;background:var(--surface);border-left:1px solid var(--border);z-index:15;padding:1rem .8rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.chart-box{margin-bottom:1rem}.chart-lbl{font-size:.6rem;color:var(--muted);margin-bottom:.3rem}.leaderboard{position:fixed;bottom:5.5rem;right:1rem;width:230px;background:var(--surface);border:1px solid var(--border);border-radius:8px;z-index:18;padding:.8rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);max-height:280px;overflow-y:auto}.lb-head{font-size:.6rem;letter-spacing:.12em;color:var(--muted);margin-bottom:.6rem;cursor:pointer}.lb-row{display:flex;align-items:center;gap:.4rem;font-size:.64rem;padding:.22rem 0}.lb-rank{color:var(--muted);width:14px}.lb-flag{font-size:.8rem}.lb-ip{flex:1;color:var(--text)}.lb-count{color:var(--red);font-weight:700}.lb-banned{background:#ef4444;color:#fff;font-size:.52rem;padding:.08rem .3rem;border-radius:2px;font-weight:700}.lb-empty{font-size:.64rem;color:#475569}.lb-collapsed{position:fixed;bottom:5.5rem;right:1rem;z-index:18;background:var(--surface);border:1px solid var(--border);color:var(--muted);padding:.5rem 1rem;border-radius:6px;font-family:inherit;font-size:.62rem;cursor:pointer}.defence-panel{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);display:flex;gap:.6rem;z-index:20}.def-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;background:#1e293b;border:1px solid var(--border);color:var(--muted);padding:.6rem .9rem;border-radius:8px;font-family:inherit;cursor:pointer;min-width:96px;transition:all .2s}.def-btn.active{background:#0c2a4d;border-color:var(--blue);color:var(--text);box-shadow:0 0 16px #3b82f644}.def-icon{font-size:1.3rem}.def-name{font-size:.62rem;font-weight:600}.def-badge{font-size:.5rem;padding:.08rem .4rem;border-radius:2px;font-weight:700;letter-spacing:.05em}.def-badge.off{background:#7f1d1d;color:#fca5a5}.def-badge.on{background:#15803d;color:#86efac}.controls{position:fixed;bottom:1rem;left:1rem;display:flex;flex-direction:column;gap:.5rem;z-index:20}.launch-btn{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;border:none;padding:.8rem 1.4rem;font-size:.85rem;font-weight:800;letter-spacing:.08em;border-radius:6px;cursor:pointer;font-family:inherit;box-shadow:0 0 22px #ef444455;animation:launch-pulse 2s ease-in-out infinite}.launch-btn:disabled{opacity:.6;cursor:not-allowed;animation:none}@keyframes launch-pulse{0%,to{box-shadow:0 0 22px #ef444455}50%{box-shadow:0 0 40px #ef444588}}.reset-btn{background:var(--surface);border:1px solid var(--border);color:var(--muted);padding:.5rem 1rem;font-size:.72rem;border-radius:5px;cursor:pointer;font-family:inherit}.def-count{font-size:.62rem;color:var(--muted);text-align:center}.gold-burst{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:40}.gold-pt{position:absolute;top:0;left:0;width:10px;height:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold)}
