:root{--bg0:#05060b;--bg1:#0a0f1a;--fg:#e6f0ff;--muted:#9bb0c2;--brand:#7c5cff;--brand2:#00e1ff;--danger:#ff3d6e;--ok:#00ffa3;--glass:rgba(255,255,255,.06);--glass-stroke:rgba(255,255,255,.12)}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;background:radial-gradient(1200px 800px at 20% -10%,#0c1430 0%,transparent 60%),radial-gradient(1200px 800px at 120% 10%,#061d2f 0%,transparent 60%),linear-gradient(180deg,var(--bg1),var(--bg0));color:var(--fg);overflow-x:hidden}
.bg{position:fixed;inset:0;pointer-events:none;background:conic-gradient(from 0deg at 50% 50%,rgba(124,92,255,.05),rgba(0,225,255,.05),rgba(124,92,255,.05));filter:blur(60px);animation:spin 30s linear infinite;opacity:.9}
@keyframes spin{to{transform:rotate(360deg)}}
.nav{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;padding:14px 22px;background:linear-gradient(180deg,rgba(10,15,26,.8),rgba(10,15,26,.4));backdrop-filter:blur(14px) saturate(160%);border-bottom:1px solid rgba(255,255,255,.06)}
.brand{display:flex;align-items:center;gap:12px}
.logo{width:36px;height:36px;border-radius:12px;background:linear-gradient(135deg,rgba(124,92,255,.35),rgba(0,225,255,.35));position:relative;box-shadow:0 0 0 1px rgba(255,255,255,.08) inset,0 8px 24px rgba(0,0,0,.5)}
.logo .spark{position:absolute;width:6px;height:6px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,rgba(255,255,255,.2));box-shadow:0 0 16px 6px rgba(124,92,255,.5)}
.logo .a{left:8px;top:8px;animation:flick 1.8s ease-in-out infinite}
.logo .b{right:8px;top:14px;animation:flick 2.1s ease-in-out infinite .25s}
.logo .c{left:14px;bottom:8px;animation:flick 1.6s ease-in-out infinite .5s}
@keyframes flick{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(2px,-2px) scale(1.2)}}
.brand-text h1{margin:0;font-size:18px;letter-spacing:.3px;background:linear-gradient(90deg,#fff,var(--brand2));-webkit-background-clip:text;background-clip:text;color:transparent}
.brand-text p{margin:0;margin-top:-2px;font-size:12px;color:var(--muted);letter-spacing:.4px}
.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12)}
.pill .dot{width:8px;height:8px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#0f0,#093);box-shadow:0 0 12px 4px rgba(0,255,163,.6);animation:pulse 1.2s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.25)}}
.wrap{max-width:1280px;margin:0 auto;padding:28px 18px}
.hero{display:flex;flex-direction:column;gap:12px;margin:8px 0 20px}
.hero h2{margin:0;font-size:44px;line-height:1.05;background:linear-gradient(90deg,#fff,var(--brand2) 40%,var(--brand) 80%);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:.5px;animation:shine 6s linear infinite}
@keyframes shine{0%{filter:hue-rotate(0deg)}100%{filter:hue-rotate(360deg)}}
.hero p{margin:0;color:var(--muted);font-size:14px}
.hero-stats{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}
.kpi{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:14px;box-shadow:0 6px 24px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.06)}
.kpi-label{font-size:11px;color:var(--muted);letter-spacing:.4px}
.kpi-value{font-size:20px;letter-spacing:.3px}
.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:12px}
.card{position:relative;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:16px;box-shadow:0 10px 32px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.06);overflow:hidden}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.card h3{margin:0;font-size:14px;letter-spacing:.4px;color:#fff}
.legend{display:flex;gap:10px}
.key{font-size:11px;color:var(--muted);padding:4px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.12)}
.k1{background:rgba(124,92,255,.12);border-color:rgba(124,92,255,.4);color:#cdbaff}
.k2{background:rgba(0,225,255,.12);border-color:rgba(0,225,255,.4);color:#bdf7ff}
.span-2{grid-column:span 2}
.chart-wrap{position:relative;height:280px;border-radius:12px;overflow:hidden;background:radial-gradient(1200px 300px at 10% 100%,rgba(124,92,255,.08),transparent 50%),radial-gradient(1200px 300px at 90% 100%,rgba(0,225,255,.08),transparent 50%),linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.02))}
#rpsChart{width:100%;height:100%;display:block}
.chart-wrap .glow{pointer-events:none;position:absolute;inset:0;background:radial-gradient(600px 120px at 40% 60%,rgba(124,92,255,.25),transparent 60%),radial-gradient(600px 120px at 70% 70%,rgba(0,225,255,.25),transparent 60%);filter:blur(36px);mix-blend-mode:screen;animation:glide 8s ease-in-out infinite alternate}
@keyframes glide{0%{transform:translateX(-8%)}100%{transform:translateX(8%)}}
.dial-wrap{position:relative;width:100%;height:240px;display:flex;align-items:center;justify-content:center}
.dial-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.dial-value{font-size:28px}
.dial-label{font-size:12px;color:var(--muted)}
.ticker{height:220px;overflow:auto;mask-image:linear-gradient(to bottom,transparent,black 10%,black 90%,transparent)}
#blockedList{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
#blockedList li{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:10px;background:rgba(255,61,110,.08);border:1px solid rgba(255,61,110,.25);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}
#blockedList .ip{color:#ffd1dc}
#blockedList .time{color:var(--muted);font-size:12px}
.pill.danger{background:rgba(255,61,110,.1);border-color:rgba(255,61,110,.3);color:#ffb3c3}
.stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px 12px}
.stat-label{font-size:11px;color:var(--muted)}
.stat-value{font-size:14px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}
.actions{display:flex;gap:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:12px;background:linear-gradient(90deg,rgba(124,92,255,.7),rgba(0,225,255,.7));color:#001018;text-decoration:none;font-weight:600;letter-spacing:.3px;box-shadow:0 8px 24px rgba(0,0,0,.45),0 0 0 1px rgba(255,255,255,.12) inset;transition:transform .2s ease,filter .2s ease}
.btn:hover{transform:translateY(-2px);filter:saturate(120%)}
.btn:active{transform:translateY(0)}
.btn.outline{background:transparent;color:#d2e9ff;border:1px solid rgba(255,255,255,.18)}
.foot{padding:40px 18px;color:var(--muted);text-align:center}
.live{animation:pr 8s linear infinite}
@keyframes pr{0%{filter:hue-rotate(0deg)}100%{filter:hue-rotate(360deg)}}
@media (max-width:1100px){.hero-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.grid{grid-template-columns:repeat(2,minmax(0,1fr))}.span-2{grid-column:span 2}}
@media (max-width:640px){.hero-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.grid{grid-template-columns:1fr}}

#adminPanel{margin-top:6px}
#adminPanel .stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
@media (max-width:1100px){#adminPanel .stats{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){#adminPanel .stats{grid-template-columns:1fr}}

#routesList{display:flex;flex-direction:column;gap:10px}
#routesList>div{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12)}
#routesList>div{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#routesList .btn{flex-shrink:0}
#routesList .btn.outline{border-color:rgba(255,61,110,.35);color:#ffb3c3}
#routesList .btn.outline:hover{background:rgba(255,61,110,.18)}

#adminPanel .actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
#adminPanel input{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);color:var(--fg);border-radius:10px;padding:10px 12px;outline:none;width:100%}
#adminPanel input:focus{border-color:rgba(124,92,255,.6);box-shadow:0 0 0 2px rgba(124,92,255,.18)}

.btn.danger{background:linear-gradient(90deg,rgba(255,61,110,.9),rgba(255,61,110,.7));border-color:rgba(255,61,110,.35);color:#14010a}
.btn.small{padding:6px 10px;font-size:12px}