:root{
  --bg:#0f1419; --panel:#171d26; --panel2:#1e2632; --border:#2a3340;
  --text:#e6edf3; --muted:#8b97a7; --accent:#3b82f6; --accent2:#22d3ee;
  --ok:#22c55e; --warn:#f59e0b; --bad:#ef4444; --gap:#6b7280;
  --mx:#3b82f6; --ref:#a78bfa;
  --radius:10px; --font:'Segoe UI',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px}
a{color:var(--accent2);text-decoration:none}
h1,h2,h3{margin:0 0 .4em}
.muted{color:var(--muted)}
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.spacer{flex:1}

/* topbar */
.topbar{display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--panel);
  border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}
.topbar .brand{font-weight:700;font-size:16px;color:#fff}
.topbar .brand .dot{color:var(--accent2)}
.tabs a{padding:6px 12px;border-radius:8px;color:var(--muted)}
.tabs a.active,.tabs a:hover{background:var(--panel2);color:#fff}
.badge{font-size:11px;padding:2px 8px;border-radius:20px;background:var(--panel2);color:var(--muted)}
.badge.admin{background:#3b2f1a;color:var(--warn)}

main{max-width:1200px;margin:0 auto;padding:20px}
.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;margin-bottom:18px}
.card h2{font-size:15px;display:flex;align-items:center;gap:8px}
.card .sub{font-size:12px;color:var(--muted);font-weight:400}

/* controls */
select,input,button{font-family:inherit;font-size:13px;background:var(--panel2);color:var(--text);
  border:1px solid var(--border);border-radius:8px;padding:8px 10px;outline:none}
input:focus,select:focus{border-color:var(--accent)}
button{cursor:pointer;background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}
button:hover{filter:brightness(1.1)}
button.ghost{background:var(--panel2);border-color:var(--border);color:var(--text);font-weight:500}
button.danger{background:var(--bad);border-color:var(--bad)}
.seg{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.seg button{background:var(--panel2);border:none;border-radius:0;color:var(--muted);font-weight:500;padding:7px 14px}
.seg button.active{background:var(--accent);color:#fff}

/* table */
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--border)}
th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
tr:hover td{background:rgba(255,255,255,.02)}
.pill{font-size:11px;padding:2px 8px;border-radius:20px;font-weight:600}
.pill.mx{background:rgba(59,130,246,.15);color:#93c5fd}
.pill.ref{background:rgba(167,139,250,.15);color:#c4b5fd}
.dotcol{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:6px;vertical-align:middle}
.val-bad{color:var(--bad);font-weight:700}
.val-warn{color:var(--warn)}
.val-na{color:var(--gap)}

/* alerts */
.alert-banner{background:rgba(239,68,68,.12);border:1px solid var(--bad);border-radius:var(--radius);
  padding:12px 16px;margin-bottom:18px;color:#fecaca}
.alert-banner b{color:#fff}

/* chart */
.chartbox{position:relative;height:340px}
.legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;font-size:12px}
.legend span{display:inline-flex;align-items:center;gap:5px;color:var(--muted)}
.legend i{width:14px;height:3px;border-radius:2px;display:inline-block}

/* login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center}
.login-card{width:340px;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:28px}
.login-card h1{font-size:20px;text-align:center}
.login-card .field{margin:12px 0}
.login-card label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px}
.login-card input{width:100%}
.login-card button{width:100%;margin-top:10px;padding:11px}
.err{color:var(--bad);font-size:13px;min-height:18px;margin-top:8px;text-align:center}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:820px){.grid2{grid-template-columns:1fr}}
.formgrid{display:grid;grid-template-columns:160px 1fr;gap:10px 14px;align-items:center;max-width:560px}
.formgrid input,.formgrid select{width:100%}
.toast{position:fixed;bottom:20px;right:20px;background:var(--panel2);border:1px solid var(--border);
  padding:12px 16px;border-radius:10px;opacity:0;transition:.3s;z-index:50}
.toast.show{opacity:1}
.toast.ok{border-color:var(--ok)}.toast.bad{border-color:var(--bad)}
small.hint{color:var(--muted);font-size:11px}

/* modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;
  align-items:center;justify-content:center;z-index:100}
.modal-overlay.show{display:flex}
.modal{width:420px;max-width:92vw;background:var(--panel);border:1px solid var(--border);
  border-radius:14px;padding:22px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal h2{font-size:17px;margin-bottom:4px}
.modal .field{margin:12px 0}
.modal label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px}
.modal input,.modal select{width:100%}
.modal .actions{display:flex;gap:10px;margin-top:18px}
.modal .actions button{flex:1;padding:11px}
.modal .err{color:var(--bad);font-size:13px;min-height:16px;margin-top:6px}

/* tarjetas de clientes */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.ccard{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px;
  cursor:pointer;transition:.15s;border-left:4px solid var(--gap)}
.ccard:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.ccard.ok{border-left-color:var(--ok)} .ccard.slow{border-left-color:var(--warn)}
.ccard.down{border-left-color:var(--bad)} .ccard.nodata{border-left-color:var(--gap)}
.ccard-top{display:flex;align-items:center;gap:8px;margin-bottom:2px}
.ccard-top b{font-size:16px;color:#fff}
.ccard-host{color:var(--muted);font-size:12px;margin-bottom:14px;word-break:break-all}
.ccard-stats{display:flex;gap:18px;margin-bottom:12px}
.ccard-stats .s span{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.ccard-stats .s b{font-size:20px;font-variant-numeric:tabular-nums}
.ccard-foot{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);
  border-top:1px solid var(--border);padding-top:10px}
.st-dot{width:11px;height:11px;border-radius:50%;display:inline-block;flex:none}
.st-dot.ok{background:var(--ok)} .st-dot.slow{background:var(--warn)}
.st-dot.down{background:var(--bad)} .st-dot.nodata{background:var(--gap)}
.st-label{font-weight:600}
.summary-chips{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.schip{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px 18px;min-width:130px}
.schip span{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:3px}
.schip b{font-size:22px;font-variant-numeric:tabular-nums}
