:root{
  --bg:#0b1220; --panel:#111a2e; --panel-2:#16213b; --border:#243150;
  --text:#e6edf7; --muted:#8da2c0; --accent:#3b82f6; --accent-2:#0ea5e9;
  --green:#22c55e; --amber:#f59e0b; --red:#ef4444; --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;
}
a{color:var(--accent-2);text-decoration:none}
a:hover{text-decoration:underline}

/* ---------- layout ---------- */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{
  background:linear-gradient(180deg,#0e1730,#0b1220);border-right:1px solid var(--border);
  padding:22px 16px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;
}
.brand{font-weight:700;font-size:18px;display:flex;align-items:center;gap:10px;margin-bottom:24px}
.brand .dot{width:12px;height:12px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent)}
.nav a{
  display:flex;align-items:center;gap:11px;color:var(--muted);padding:11px 13px;
  border-radius:10px;margin-bottom:4px;font-weight:500;
}
.nav a:hover{background:var(--panel-2);color:var(--text);text-decoration:none}
.nav a.active{background:var(--accent);color:#fff}
.nav .ico{width:20px;text-align:center}
.sidebar .spacer{flex:1}
.userbox{border-top:1px solid var(--border);padding-top:14px;color:var(--muted);font-size:13px}
.userbox a{color:var(--red)}

.main{padding:28px 34px;max-width:1200px}
.page-title{font-size:24px;font-weight:700;margin:0 0 4px}
.page-sub{color:var(--muted);margin:0 0 24px}

/* ---------- cards / stats ---------- */
.grid{display:grid;gap:18px}
.grid.stats{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}
.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.stat .label{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.04em}
.stat .value{font-size:30px;font-weight:700;margin:6px 0 10px}
.stat .value small{font-size:15px;color:var(--muted);font-weight:500}
.bar{height:8px;border-radius:99px;background:var(--panel-2);overflow:hidden}
.bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .4s}
.bar.warn > i{background:linear-gradient(90deg,var(--amber),#fbbf24)}
.bar.crit > i{background:linear-gradient(90deg,var(--red),#f87171)}

/* ---------- tables ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}
table{width:100%;border-collapse:collapse;background:var(--panel)}
th,td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}
th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em;background:var(--panel-2)}
tr:last-child td{border-bottom:none}
td .domain{font-weight:600}
td .path{color:var(--muted);font-size:13px;font-family:ui-monospace,monospace}

/* ---------- badges / pills ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600}
.pill.ok{background:rgba(34,197,94,.15);color:#4ade80}
.pill.no{background:rgba(239,68,68,.15);color:#f87171}
.pill.muted{background:var(--panel-2);color:var(--muted)}
.pill.warn{background:rgba(245,158,11,.15);color:#fbbf24}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:9px;
  border:1px solid var(--border);background:var(--panel-2);color:var(--text);
  font-size:13.5px;font-weight:600;cursor:pointer;transition:.15s;text-decoration:none;
}
.btn:hover{border-color:var(--accent);text-decoration:none;transform:translateY(-1px)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{background:#2f6fe0}
.btn.danger{background:transparent;border-color:rgba(239,68,68,.5);color:#f87171}
.btn.danger:hover{background:rgba(239,68,68,.12);border-color:var(--red)}
.btn.sm{padding:6px 10px;font-size:12.5px}
.btn-row{display:flex;gap:8px;flex-wrap:wrap}
.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:12px;flex-wrap:wrap}

/* ---------- forms ---------- */
label{display:block;font-weight:600;margin:0 0 7px}
.hint{color:var(--muted);font-size:13px;font-weight:400}
input[type=text],input[type=password]{
  width:100%;padding:11px 13px;background:var(--bg);border:1px solid var(--border);
  border-radius:9px;color:var(--text);font-size:15px;
}
input:focus{outline:none;border-color:var(--accent)}
.field{margin-bottom:20px}
.suffix-input{display:flex;align-items:stretch}
.suffix-input input{border-radius:9px 0 0 9px;border-right:none}
.suffix-input .suffix{
  display:flex;align-items:center;padding:0 14px;background:var(--panel-2);
  border:1px solid var(--border);border-radius:0 9px 9px 0;color:var(--muted);font-family:ui-monospace,monospace;
}

/* env type selector */
.env-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.env-opt{position:relative}
.env-opt input{position:absolute;opacity:0;pointer-events:none}
.env-opt .box{
  border:2px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;height:100%;transition:.15s;
}
.env-opt .box .ic{font-size:26px}
.env-opt .box .name{font-weight:700;margin:8px 0 4px;display:flex;align-items:center;gap:8px}
.env-opt .box .desc{color:var(--muted);font-size:13px}
.env-opt input:checked + .box{border-color:var(--accent);background:rgba(59,130,246,.08)}
.env-opt.disabled .box{opacity:.5;cursor:not-allowed}
.env-opt .soon{font-size:11px;background:var(--panel-2);color:var(--amber);padding:2px 8px;border-radius:99px;font-weight:600}

/* ---------- flash / alerts ---------- */
.alert{padding:13px 16px;border-radius:10px;margin-bottom:16px;border:1px solid}
.alert.success{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.4);color:#86efac}
.alert.error{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.4);color:#fca5a5}
.alert.info{background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.4);color:#93c5fd}

/* ---------- console (live logs) ---------- */
.console{
  background:#05080f;border:1px solid var(--border);border-radius:12px;padding:16px;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;line-height:1.55;
  height:360px;overflow:auto;white-space:pre-wrap;color:#cbd5e1;
}
.console .ok{color:#4ade80}
.console .err{color:#f87171}
.console .step{color:#7dd3fc}

/* connection info box */
.creds{background:var(--bg);border:1px dashed var(--accent);border-radius:10px;padding:16px;margin-top:8px}
.creds .row{display:flex;justify-content:space-between;gap:14px;padding:5px 0;font-family:ui-monospace,monospace}
.creds .row b{color:var(--muted);font-weight:600}
.creds .row span{user-select:all}

/* ---------- login ---------- */
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-card{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:38px;width:100%;max-width:380px}
.login-card .brand{justify-content:center;font-size:22px}
.login-card .btn{width:100%;justify-content:center;margin-top:8px}

/* log viewer */
.log-view{background:#05080f;border:1px solid var(--border);border-radius:12px;padding:16px;
  font-family:ui-monospace,monospace;font-size:12.5px;line-height:1.5;max-height:70vh;overflow:auto;white-space:pre-wrap;color:#cbd5e1}

/* ---------- responsive ---------- */
@media(max-width:880px){
  .app{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center;gap:6px}
  .sidebar .brand{width:100%;margin-bottom:10px}
  .nav{display:flex;flex-wrap:wrap;gap:4px}
  .nav a{margin:0;padding:8px 11px}
  .sidebar .spacer{display:none}
  .userbox{border:none;padding:0;margin-left:auto}
  .main{padding:20px 16px}
}
