/* Stronghold VPS — admin suite shared shell styles.
   Single source of the admin visual language (extracted from the original
   credentials.html and extended with the dashboard vocabulary: tiles, gauges,
   status dots, mini-bars, tables). Every panel links this file. */
:root {
  --ink:#0A0E14; --panel:#11161F; --panel-2:#161C27; --line:#232b38;
  --green:#3EE6B0; --text:#E6E8EC; --muted:#8A8D96;
  --red:#F56B6B; --amber:#F5C542; --blue:#6BA3F5;
  --mono: ui-monospace,"SF Mono",Menlo,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--ink);color:var(--text);font-family:var(--sans);font-size:14px;padding:28px}
a{color:var(--blue);text-decoration:none}

/* header + logo */
.logo{font-family:var(--mono);font-size:16px;font-weight:700;color:var(--green)}
.logo span{color:var(--text)}
header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;flex-wrap:wrap;gap:12px}
h1{font-size:19px;font-weight:600}
.sub{color:var(--muted);font-size:12px;margin:2px 0 22px}
.head-right{display:flex;gap:10px;align-items:center}

/* admin nav (shared across panels) */
nav.adminnav{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:22px}
nav.adminnav a{font-size:12.5px;color:var(--muted);border:.5px solid var(--line);border-radius:6px;padding:6px 12px}
nav.adminnav a:hover{color:var(--text);border-color:var(--muted)}
nav.adminnav a.active{color:var(--green);border-color:rgba(62,230,176,.4);background:rgba(62,230,176,.08)}

/* buttons + inputs */
button{background:rgba(62,230,176,.12);color:var(--green);border:.5px solid rgba(62,230,176,.3);border-radius:6px;padding:7px 14px;cursor:pointer;font-size:13px}
button:hover{background:rgba(62,230,176,.2)}
button.ghost{background:transparent;color:var(--muted);border-color:var(--line)}
button.danger{background:rgba(245,107,107,.12);color:var(--red);border-color:rgba(245,107,107,.3)}
button:disabled{opacity:.4;cursor:not-allowed}
input,select{background:var(--panel-2);border:.5px solid var(--line);color:var(--text);border-radius:6px;padding:8px 11px;font-size:13px;font-family:var(--mono);width:100%}
label{display:block;color:var(--muted);font-size:12px;margin:10px 0 4px}

/* gate */
.gate{max-width:380px;margin:70px auto;text-align:center}
.gate input{margin:12px 0}
.gate button{width:100%;padding:10px}
.err{color:var(--red);font-size:12px;margin-top:8px;min-height:16px}
.ok{color:var(--green);font-size:12px;margin-top:8px;min-height:16px}
.hidden{display:none}

/* groups / cards */
.group{margin-bottom:22px}
.group h2{font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:10px;font-weight:600}
.card{background:var(--panel);border:.5px solid var(--line);border-radius:9px;padding:14px 16px;margin-bottom:9px}

/* badges + status dots */
.badge{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.5px;padding:2px 7px;border-radius:20px}
.b-ok{background:rgba(62,230,176,.15);color:var(--green)}
.b-warn{background:rgba(245,197,66,.15);color:var(--amber)}
.b-bad{background:rgba(245,107,107,.15);color:var(--red)}
.b-info{background:rgba(107,163,245,.15);color:var(--blue)}
.b-muted{background:rgba(138,141,150,.12);color:var(--muted)}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--muted);margin-right:6px}
.dot.ok{background:var(--green)} .dot.warn{background:var(--amber)} .dot.bad{background:var(--red)}

/* dashboard tiles */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:22px}
.tile{background:var(--panel);border:.5px solid var(--line);border-radius:10px;padding:16px}
.tile .k{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.tile .v{font-size:26px;font-weight:700;margin-top:6px;font-family:var(--mono)}
.tile a{display:block}
.navtile{background:var(--panel);border:.5px solid var(--line);border-radius:10px;padding:18px;transition:border-color .15s}
.navtile:hover{border-color:rgba(62,230,176,.4)}
.navtile .t{font-weight:600;color:var(--text);font-size:15px}
.navtile .d{color:var(--muted);font-size:12px;margin-top:5px;line-height:1.5}

/* mini resource bar (cap vs used) */
.bar{height:7px;background:var(--panel-2);border-radius:4px;overflow:hidden;margin-top:6px}
.bar > i{display:block;height:100%;background:var(--green)}
.bar > i.warn{background:var(--amber)} .bar > i.bad{background:var(--red)}

/* tables */
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px;padding:8px 10px;border-bottom:.5px solid var(--line);font-weight:600}
td{padding:9px 10px;border-bottom:.5px solid var(--line);vertical-align:middle}
tr:hover td{background:var(--panel)}
.mono{font-family:var(--mono)}
.muted{color:var(--muted)}
.right{text-align:right}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:50}
.modal{background:var(--panel);border:.5px solid var(--line);border-radius:12px;padding:24px;max-width:440px;width:90%}
.modal h3{font-size:16px;margin-bottom:6px}
.modal p{color:var(--muted);font-size:12.5px;line-height:1.6;margin-bottom:8px}
.modal .row{display:flex;gap:8px;margin-top:14px}

/* banners */
.warn-banner{background:rgba(245,197,66,.08);border:.5px solid rgba(245,197,66,.25);border-radius:8px;padding:11px 14px;font-size:12px;color:var(--amber);line-height:1.5;margin-bottom:18px}
.info-banner{background:rgba(107,163,245,.08);border:.5px solid rgba(107,163,245,.25);border-radius:8px;padding:11px 14px;font-size:12px;color:var(--blue);line-height:1.5;margin-bottom:18px}
