@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  --bg:#0b0f14;
  --bg-soft:#0f151d;
  --surface:#141b24;
  --surface-2:#1a232e;
  --border:#222e3a;
  --text:#e6edf3;
  --muted:#8a99a8;
  --accent:#2dd4bf;       /* teal */
  --accent-2:#38bdf8;
  --cpu:#2dd4bf;
  --ram:#fbbf24;
  --disk:#a78bfa;
  --ok:#34d399;
  --warn:#fbbf24;
  --danger:#f87171;
  --radius:14px;
  --shadow:0 8px 30px rgba(0,0,0,.35);
  --font:'Sora',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(45,212,191,.08), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(56,189,248,.06), transparent 60%),
    var(--bg);
  color:var(--text);
  font-family:var(--font);
  -webkit-font-smoothing:antialiased;
  font-size:15px;
  line-height:1.5;
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.mono{font-family:var(--mono)}
.muted{color:var(--muted)}
.small{font-size:13px}
h1{font-size:20px;margin:0;font-weight:600}
h2{font-size:16px;margin:0 0 4px;font-weight:600}
code{font-family:var(--mono);background:var(--surface-2);padding:1px 6px;border-radius:6px;font-size:.85em}

/* ---------- Auth ---------- */
.auth-body{display:grid;place-items:center;min-height:100dvh;padding:20px}
.auth-card{
  width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);
  border-radius:18px;padding:28px;box-shadow:var(--shadow)
}
.auth-card h1{margin:14px 0 4px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px}
.brand-mark{
  display:grid;place-items:center;width:34px;height:34px;border-radius:9px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#04211d;font-weight:800;font-family:var(--mono);font-size:14px
}
form label{display:block;margin:14px 0 6px;font-size:13px;color:var(--muted)}
input[type=text],input[type=password],input:not([type]),select{
  width:100%;background:var(--bg-soft);border:1px solid var(--border);color:var(--text);
  border-radius:10px;padding:11px 13px;font-size:15px;font-family:inherit;outline:none
}
input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,212,191,.15)}
select{appearance:none;cursor:pointer}

/* baris subdomain: [input] . [dropdown] */
.subdomain-row{display:flex;align-items:center;gap:8px}
.subdomain-row input{flex:0 1 40%}
.subdomain-row select{flex:1 1 60%}
.subdomain-row .dot{color:var(--muted);font-weight:700;font-size:18px}

/* kotak kredensial WP */
.cred-box{display:flex;gap:14px;flex-wrap:wrap;margin:10px 0}
.cred-box>div{flex:1 1 140px;background:var(--bg-soft);border:1px solid var(--border);border-radius:10px;padding:10px 12px}
.cred-box .mono{font-size:15px;word-break:break-all;margin-top:3px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;
  border:1px solid var(--border);background:var(--surface-2);color:var(--text);
  border-radius:10px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:500;
  transition:.15s;white-space:nowrap
}
.btn:hover{border-color:#34465a}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;color:#04211d;font-weight:600}
.btn-primary:hover{filter:brightness(1.07)}
.btn-ghost{background:transparent}
.btn-danger{background:transparent;border-color:#5c2b2b;color:var(--danger)}
.btn-danger:hover{background:rgba(248,113,113,.1)}
.btn-tiny{padding:5px 10px;font-size:12px}
.btn.block{width:100%;margin-top:18px;padding:12px}

/* ---------- Alerts ---------- */
.alert{border-radius:10px;padding:12px 14px;margin-bottom:16px;font-size:14px;border:1px solid}
.alert-error{background:rgba(248,113,113,.08);border-color:#5c2b2b;color:#fca5a5}
.alert-warn{background:rgba(251,191,36,.07);border-color:#5c4a1e;color:#fcd34d}

/* ---------- App shell ---------- */
.app{display:flex;min-height:100dvh}
.sidebar{display:none}
.main{flex:1;min-width:0;display:flex;flex-direction:column;padding-bottom:78px}
.topbar{
  position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px;background:rgba(11,15,20,.8);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border)
}
.topbar-right{display:flex;gap:8px}
.conn-dot{
  font-size:11px;color:var(--muted);border:1px solid var(--border);border-radius:20px;
  padding:4px 10px;display:flex;align-items:center;gap:6px
}
.conn-dot::before{content:'';width:7px;height:7px;border-radius:50%;background:#445}
.conn-dot.on::before{background:var(--ok);box-shadow:0 0 8px var(--ok)}
.conn-dot.off::before{background:var(--danger)}
.content{padding:18px;max-width:1100px;width:100%;margin:0 auto}

/* ---------- Bottom nav (mobile) ---------- */
.bottomnav{
  position:fixed;bottom:0;left:0;right:0;z-index:20;display:flex;
  background:rgba(15,21,29,.94);backdrop-filter:blur(14px);border-top:1px solid var(--border);
  padding:8px 6px calc(8px + env(safe-area-inset-bottom))
}
.bottomnav a{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--muted);
  font-size:11px;padding:4px;border-radius:10px
}
.bottomnav a svg{width:22px;height:22px}
.bottomnav a.active{color:var(--accent)}
.bottomnav a:hover{text-decoration:none}

/* ---------- Cards & grid ---------- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.grid{display:grid;gap:14px;margin-bottom:18px}
.stats-grid{grid-template-columns:repeat(3,1fr)}
.info-grid{grid-template-columns:repeat(2,1fr)}
.settings-grid{grid-template-columns:1fr}

/* ---------- Gauges ---------- */
.gauge-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}
.gauge{position:relative;width:118px;height:118px}
.gauge svg{transform:rotate(-90deg);width:100%;height:100%}
.gauge circle{fill:none;stroke-width:9;stroke-linecap:round}
.gauge .track{stroke:var(--surface-2)}
.gauge .bar{stroke:var(--accent);stroke-dasharray:327;stroke-dashoffset:327;transition:stroke-dashoffset .6s ease}
#g-cpu .bar{stroke:var(--cpu)} #g-ram .bar{stroke:var(--ram)} #g-disk .bar{stroke:var(--disk)}
.gauge-val{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:26px;font-weight:700}
.gauge-val small{font-size:13px;color:var(--muted);margin-left:2px}
.gauge-label{font-weight:600}
.gauge-sub{font-size:12px;color:var(--muted);font-family:var(--mono)}

.mini{display:flex;flex-direction:column;gap:4px}
.mini-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.mini-val{font-size:24px;font-weight:700}
.mini-sub{font-size:12px;color:var(--muted)}

/* ---------- Tables ---------- */
.page-actions{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.table-card{padding:0;overflow:hidden}
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;padding:12px 14px;color:var(--muted);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border)}
.table td{padding:13px 14px;border-bottom:1px solid var(--border)}
.table tr:last-child td{border-bottom:none}
.table tbody tr:hover{background:var(--bg-soft)}
.empty{text-align:center;color:var(--muted);padding:32px!important}
.row-actions{text-align:right}
.pill{font-size:11px;padding:3px 9px;border-radius:20px;font-weight:600}
.pill-ok{background:rgba(52,211,153,.13);color:var(--ok)}
.pill-mut{background:var(--surface-2);color:var(--muted)}

/* ---------- Forms (modal) ---------- */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.check{display:flex!important;align-items:center;gap:9px;margin:12px 0 0;color:var(--text);font-size:14px;cursor:pointer}
.check input{width:auto}
fieldset{border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-top:16px}
legend{padding:0 6px;color:var(--muted);font-size:12px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}

/* ---------- Modal ---------- */
.modal-backdrop{position:fixed;inset:0;z-index:50;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:grid;place-items:center;padding:16px;animation:fade .15s}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;width:100%;max-width:520px;max-height:90dvh;overflow:auto;box-shadow:var(--shadow);animation:pop .18s}
@keyframes fade{from{opacity:0}}
@keyframes pop{from{opacity:0;transform:translateY(12px)}}

/* ---------- Provision log ---------- */
.prov-log{margin-top:18px;border-top:1px solid var(--border);padding-top:14px;font-family:var(--mono);font-size:13px}
.prov-step{display:flex;gap:10px;padding:6px 0;align-items:flex-start}
.prov-step .ic{flex:none;width:18px;height:18px;border-radius:50%;display:grid;place-items:center;font-size:11px;margin-top:1px}
.prov-step.ok .ic{background:rgba(52,211,153,.15);color:var(--ok)}
.prov-step.fail .ic{background:rgba(248,113,113,.15);color:var(--danger)}
.prov-step.run .ic{background:var(--surface-2);color:var(--muted)}
.ns-result,.prov-log .ns{background:var(--bg-soft);border:1px solid var(--border);border-radius:8px;padding:10px;margin-top:12px;font-family:var(--mono);font-size:12px;word-break:break-all}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);z-index:80;background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:12px 18px;border-radius:12px;font-size:14px;opacity:0;pointer-events:none;transition:.25s;box-shadow:var(--shadow);max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{border-color:#1f6b52}
.toast.err{border-color:#5c2b2b}

.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Desktop ---------- */
@media(min-width:880px){
  .main{padding-bottom:0}
  .bottomnav{display:none}
  .sidebar{
    display:flex;flex-direction:column;width:240px;flex:none;
    background:var(--bg-soft);border-right:1px solid var(--border);padding:20px 14px;position:sticky;top:0;height:100dvh
  }
  .sidebar .brand{padding:6px 8px 22px}
  .nav{display:flex;flex-direction:column;gap:4px;flex:1}
  .nav-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;color:var(--muted);font-weight:500}
  .nav-item svg{width:20px;height:20px}
  .nav-item:hover{background:var(--surface);color:var(--text);text-decoration:none}
  .nav-item.active{background:var(--surface);color:var(--accent)}
  .sidebar-foot{border-top:1px solid var(--border);padding-top:14px;display:flex;justify-content:space-between;align-items:center;font-size:13px}
  .sidebar-foot .user{color:var(--text);font-weight:500}
  .sidebar-foot .logout{color:var(--muted)}
  .settings-grid{grid-template-columns:1fr 1fr}
  .info-grid{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:560px){
  .form-row{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr}
  .gauge{width:130px;height:130px}
}
