:root{
  --bg:#0a0a0a; --card:#141414; --card2:#1a1a1a; --border:#262626;
  --txt:#ededed; --muted:#8a8a8a; --violet:#7c5cff; --green:#3ecf8e;
  --red:#ff5c6c; --amber:#ffb454; --mono:ui-monospace,SFMono-Regular,Menlo,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);color:var(--txt);
  font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;
}
a{color:var(--violet);text-decoration:none}
.mono{font-family:var(--mono)}

/* ---- login ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:36px;width:100%;max-width:380px;text-align:center}
.login-card h1{font-size:22px;margin:0 0 6px}
.login-card p{color:var(--muted);margin:0 0 24px;font-size:13px}
.login-card input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px 14px;color:var(--txt);font-size:15px;outline:none}
.login-card input:focus{border-color:var(--violet)}
.login-card button{width:100%;margin-top:14px;background:var(--violet);color:#fff;border:0;border-radius:10px;padding:12px;font-weight:600;font-size:15px;cursor:pointer}
.login-card button:hover{filter:brightness(1.1)}
.err{color:var(--red);font-size:13px;margin-top:12px;min-height:18px}
.shake{animation:shake .4s}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-8px)}40%,80%{transform:translateX(8px)}}

/* ---- layout ---- */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;border-bottom:1px solid var(--border);position:sticky;top:0;background:rgba(10,10,10,.85);backdrop-filter:blur(8px);z-index:5}
.brand{font-weight:700;font-size:16px;letter-spacing:-.2px}
.brand .dot{color:var(--violet)}
.topbar .right{display:flex;gap:14px;align-items:center;color:var(--muted);font-size:12px}
.ghost{background:transparent;border:1px solid var(--border);color:var(--muted);border-radius:8px;padding:6px 12px;cursor:pointer;font-size:12px}
.ghost:hover{color:var(--txt);border-color:#3a3a3a}
.wrap{max-width:1200px;margin:0 auto;padding:24px 28px 60px}
.grid{display:grid;gap:16px}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-2{grid-template-columns:2fr 1fr}
@media(max-width:900px){.cols-3,.cols-2{grid-template-columns:1fr}}

.card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px}
.card h2{margin:0 0 2px;font-size:15px}
.card .sub{color:var(--muted);font-size:12.5px;margin:0 0 14px}
.welcome{background:linear-gradient(135deg,#1a1430,#141414);border-color:#2a2147}
.welcome h1{margin:0;font-size:24px;letter-spacing:-.4px}
.welcome p{color:var(--muted);margin:8px 0 0;font-style:italic}

/* ---- stat gauges ---- */
.stat-row{display:flex;gap:18px;flex-wrap:wrap}
.stat{flex:1;min-width:120px}
.stat .label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.stat .val{font-family:var(--mono);font-size:20px;margin-top:2px}
.bar{height:6px;background:var(--card2);border-radius:99px;margin-top:8px;overflow:hidden}
.bar>span{display:block;height:100%;background:var(--green);border-radius:99px;transition:width .4s}
.bar.warn>span{background:var(--amber)}
.bar.hot>span{background:var(--red)}

.cap{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.cap .pill{background:var(--card2);border:1px solid var(--border);border-radius:10px;padding:10px 14px;flex:1;min-width:120px}
.cap .pill .n{font-family:var(--mono);font-size:22px;color:var(--green)}
.cap .pill .t{color:var(--muted);font-size:11.5px}
.cap-note{color:var(--muted);font-size:11.5px;margin-top:10px}

/* ---- proxy grid ---- */
.proxies{grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.proxies{grid-template-columns:1fr}}
.pcard{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:12px}
.pcard .head{display:flex;align-items:center;gap:10px}
.pcard .emoji{font-size:22px}
.pcard .name{font-weight:600}
.pcard .host{color:var(--muted);font-size:12px;font-family:var(--mono)}
.pill-status{margin-left:auto;font-size:11px;font-weight:600;padding:4px 10px;border-radius:99px}
.alive{background:rgba(62,207,142,.12);color:var(--green)}
.dead{background:rgba(255,92,108,.12);color:var(--red)}
.degraded{background:rgba(255,180,84,.12);color:var(--amber)}
.meta{display:flex;gap:16px;color:var(--muted);font-size:12px;font-family:var(--mono)}
.dots{display:flex;gap:3px}
.dots i{width:9px;height:9px;border-radius:3px;background:#333;display:inline-block}
.dots i.ok{background:var(--green)}
.dots i.bad{background:var(--red)}
.actions{display:flex;gap:8px;margin-top:auto}
.actions button{flex:1;background:var(--card2);border:1px solid var(--border);color:var(--txt);border-radius:9px;padding:9px;font-size:12px;cursor:pointer}
.actions button:hover{border-color:var(--violet);color:#fff}

/* ---- modal ---- */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:20;padding:24px}
.modal-bg.show{display:flex}
.modal{background:var(--card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:760px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}
.modal .mhead{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.modal .mhead h3{margin:0;font-size:15px}
.modal .mbody{padding:18px 20px;overflow:auto}
.modal textarea{width:100%;height:380px;background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--txt);font-family:var(--mono);font-size:12px;padding:12px;resize:vertical}
.modal pre{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px;font-size:11.5px;overflow:auto;max-height:60vh;white-space:pre-wrap;word-break:break-word}
.modal .mfoot{display:flex;gap:10px;justify-content:flex-end;padding:14px 20px;border-top:1px solid var(--border)}
.btn{background:var(--violet);color:#fff;border:0;border-radius:9px;padding:10px 18px;font-weight:600;cursor:pointer}
.btn.sec{background:var(--card2);border:1px solid var(--border);color:var(--txt)}

/* ---- toast ---- */
#toasts{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:40}
.toast{background:var(--card2);border:1px solid var(--border);border-left:3px solid var(--green);border-radius:10px;padding:12px 16px;font-size:13px;max-width:340px;animation:slidein .25s}
.toast.bad{border-left-color:var(--red)}
@keyframes slidein{from{transform:translateX(20px);opacity:0}to{transform:none;opacity:1}}
.muted{color:var(--muted)}
