/* Roux Tool — dark base + glassmorphism. Usability > estetika: kontras terjaga. */
:root{
  --bg:#0b0f14; --bg2:#12161c;
  --glass:rgba(255,255,255,.055); --glass-strong:rgba(255,255,255,.09);
  --border:rgba(255,255,255,.12); --text:#e7edf3; --muted:#9aa7b4;
  --accent:#35d0ba; --accent2:#7c8cff;
  --online:#31d07a; --offline:#f0596a; --quarantine:#f5b544;
  --login:#7c8cff; --update_pause:#c9a2ff; --unknown:#6b7683;
  --radius:16px; --shadow:0 8px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg); color:var(--text); min-height:100vh; line-height:1.5;
}
.bg-orbs{position:fixed;inset:0;z-index:-1;overflow:hidden;background:
  radial-gradient(40rem 40rem at 15% -10%,rgba(53,208,186,.12),transparent 60%),
  radial-gradient(40rem 40rem at 110% 10%,rgba(124,140,255,.12),transparent 55%),var(--bg2);}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:1.2rem}
h1{font-size:1.4rem;margin:.2rem 0 1rem}h2{font-size:1.05rem;margin:1.4rem 0 .6rem}
.muted{color:var(--muted)} .small{font-size:.82rem} .mono{font-family:ui-monospace,Menlo,Consolas,monospace}

/* --- Glass --- */
.glass{
  background:var(--glass); backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
  border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow);
}
.card{padding:1rem;margin-bottom:1rem}
.topbar{position:sticky;top:.6rem;z-index:5;margin:.6rem auto;max-width:1200px;
  display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;
  border-radius:var(--radius);}
.topbar nav{display:flex;gap:1rem;align-items:center}
.brand{font-weight:700;letter-spacing:.5px}

/* --- Layout helpers --- */
.row-between{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.inline{display:inline-flex;gap:.4rem;align-items:center;margin:0}
.stack{display:flex;flex-direction:column;gap:.7rem}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:720px){.two-col{grid-template-columns:1fr}}
.center-screen{min-height:80vh;display:grid;place-items:center}

/* --- Forms --- */
label{display:block;font-size:.9rem;margin-bottom:.15rem}
input,select,textarea{width:100%;margin-top:.25rem;padding:.55rem .7rem;color:var(--text);
  background:rgba(0,0,0,.25);border:1px solid var(--border);border-radius:10px;font-size:.95rem}
input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);border-color:transparent}
label.check{display:flex;align-items:center;gap:.5rem}
label.check input{width:auto;margin:0}
fieldset.inst-edit{border:1px solid var(--border);border-radius:12px;padding:.8rem;margin:.5rem 0}
legend{padding:0 .4rem;color:var(--accent)}
.flags{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.4rem}

/* --- Buttons --- */
.btn,.btn-ghost,.btn-danger,.btn-sm{cursor:pointer;border-radius:10px;border:1px solid var(--border);
  padding:.55rem .9rem;font-size:.9rem;font-weight:600;color:var(--text);background:var(--glass-strong);
  transition:.15s;display:inline-block}
.btn{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#07130f;border:none}
.btn:hover{filter:brightness(1.08)}
.btn-ghost:hover,.btn-sm:hover{background:rgba(255,255,255,.16)}
.btn-danger{background:rgba(240,89,106,.18);border-color:rgba(240,89,106,.4);color:#ffd7dc}
.btn-sm{padding:.35rem .6rem;font-size:.8rem}
.btn-ghost{background:transparent}
summary.btn{list-style:none}summary::-webkit-details-marker{display:none}
.add-device{position:relative}
.add-device[open]>summary{margin-bottom:.6rem}
.add-device .stack{padding:1rem;min-width:260px}
details.add-device{border-radius:var(--radius)}

/* --- Status dots & pills --- */
.dot{display:inline-block;width:.7rem;height:.7rem;border-radius:50%;margin-right:.15rem;vertical-align:middle}
.dot-online{background:var(--online);box-shadow:0 0 8px var(--online)}
.dot-offline{background:var(--offline);box-shadow:0 0 8px var(--offline)}
.dot-quarantine{background:var(--quarantine);box-shadow:0 0 8px var(--quarantine)}
.state-label{margin-left:auto;font-size:.78rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.pill{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.75rem;border:1px solid var(--border)}
.pill-online{background:rgba(49,208,122,.16);color:#b6f2d0}
.pill-offline{background:rgba(240,89,106,.16);color:#ffc9cf}
.pill-quarantine{background:rgba(245,181,68,.16);color:#ffe4b0}
.pill-login{background:rgba(124,140,255,.16);color:#cdd4ff}
.pill-update_pause{background:rgba(201,162,255,.16);color:#e6d6ff}
.pill-unknown{background:rgba(107,118,131,.16);color:#c3ccd6}
.tag{padding:.1rem .45rem;border-radius:6px;font-size:.7rem}
.tag-danger{background:rgba(240,89,106,.2);color:#ffc9cf}

/* --- Cards --- */
.card.device{display:block;transition:transform .12s,border-color .12s}
.card.device:hover{transform:translateY(-2px);border-color:var(--accent)}
.card-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}
.dname{font-size:1rem}
.inst-list{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}
.metrics-row{display:flex;flex-wrap:wrap;gap:1.4rem}
.cmd-row{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.6rem}

/* --- Gallery --- */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.7rem}
.shot{margin:0;padding:.4rem;border-radius:12px}
.shot img{width:100%;border-radius:8px;display:block;aspect-ratio:9/16;object-fit:cover;background:#000}
.shot figcaption{margin-top:.3rem}

/* --- Tables --- */
.tbl{width:100%;border-collapse:collapse;overflow:hidden}
.tbl th,.tbl td{padding:.45rem .6rem;text-align:left;border-bottom:1px solid var(--border);font-size:.85rem}
.tbl th{color:var(--muted);font-weight:600}

/* --- Alerts --- */
.alert{background:rgba(240,89,106,.15);border:1px solid rgba(240,89,106,.35);
  padding:.6rem .8rem;border-radius:10px;margin-bottom:.6rem;font-size:.9rem}
.alert-warn{background:rgba(245,181,68,.15);border-color:rgba(245,181,68,.4)}
.login{width:min(92vw,360px)}
.login h1{margin-bottom:.2rem}
