:root{
  --bg:#070b14; --panel:#0c1322; --card:#0f1a2e; --cardhi:#15223c;
  --border:#1a2740; --text:#e8edf6; --dim:#8a99b5; --gold:#c9a227;
  --green:#3fb37f; --red:#e0556a; --amber:#d9a441;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Segoe UI',Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);display:flex;min-height:100vh}
body.center{display:flex;align-items:center;justify-content:center}
a{color:inherit;text-decoration:none}
h1{font-size:24px;margin:0 0 18px}
h2{font-size:16px;color:var(--dim);margin:26px 0 10px;font-weight:600}
code{font-family:ui-monospace,Consolas,monospace}

/* sidebar */
.side{width:220px;background:var(--panel);border-right:1px solid var(--border);padding:22px 14px;display:flex;flex-direction:column;gap:6px}
.brand{font-family:Georgia,serif;font-size:20px;font-weight:700;letter-spacing:4px;margin-bottom:18px}
.brand span{display:block;font-size:9px;letter-spacing:3px;color:var(--gold);font-family:'Segoe UI',sans-serif}
.brand.big{font-size:26px;text-align:center;margin-bottom:22px}
.side nav{display:flex;flex-direction:column;gap:4px;flex:1}
.side nav a{padding:11px 14px;border-radius:9px;color:var(--dim);font-weight:600}
.side nav a:hover{background:var(--card);color:var(--text)}
.side nav a.on{background:var(--cardhi);color:var(--text);border-left:3px solid var(--gold);padding-left:11px}
.logout{display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--border);padding-top:14px}
.logout .who{font-size:11px;color:var(--dim)}

/* main */
.main{flex:1;padding:30px 36px;overflow:auto}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:8px}
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px 18px}
.kpi{display:flex;flex-direction:column;gap:3px}
.kpi .lab{color:var(--dim);font-size:12px}
.kpi .val{font-size:26px;font-weight:800}
.kpi .val.gold{color:var(--gold)} .kpi .val.danger{color:var(--red)}
.kpi .sub{color:var(--dim);font-size:11px}

/* tables */
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;color:var(--dim);font-weight:600;padding:8px 10px;border-bottom:1px solid var(--border)}
td{padding:9px 10px;border-bottom:1px solid var(--border)}
td.dim{color:var(--dim)} td.acts{white-space:nowrap}
tr:last-child td{border-bottom:none}

/* badges / tags */
.badge{padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase}
.badge.unused{background:rgba(217,164,65,.15);color:var(--amber)}
.badge.used{background:rgba(63,179,127,.15);color:var(--green)}
.badge.revoked{background:rgba(224,85,106,.15);color:var(--red)}
.tag{background:var(--cardhi);color:var(--dim);padding:2px 8px;border-radius:6px;font-size:11px}

/* forms */
.row-actions{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:14px}
form.inline{display:flex;align-items:center;gap:8px;margin:0}
form.inline.right{margin-left:auto}
label{color:var(--dim);font-size:12px}
input,select{background:#0b1322;border:1px solid var(--border);border-radius:8px;padding:9px 11px;color:var(--text);font-size:13px}
input:focus,select:focus{outline:none;border-color:var(--gold)}
input.num{width:80px} .login input{width:100%;margin-bottom:6px}
.login label{display:block;margin:8px 0 2px}

/* buttons */
.btn{border:1px solid var(--border);background:transparent;color:var(--text);padding:9px 14px;border-radius:9px;font-weight:700;cursor:pointer;font-size:13px}
.btn:hover{border-color:var(--gold)}
.btn.sm{padding:5px 10px;font-size:12px}
.btn.full{width:100%;margin-top:14px}
.btn.primary{background:var(--gold);border-color:var(--gold);color:#0b1322}
.btn.ghost{color:var(--dim)}
.btn.warn{border-color:var(--amber);color:var(--amber)}
.btn.warn:hover{background:var(--amber);color:#0b1322}
.btn.danger{border-color:var(--red);color:var(--red)}
.btn.danger:hover{background:var(--red);color:#fff}
.btn.ok{border-color:var(--green);color:var(--green)}
.btn.ok:hover{background:var(--green);color:#0b1322}

/* login + alerts */
.card.login{width:340px;padding:30px}
.alert{padding:12px 14px;border-radius:9px;font-size:13px;margin-bottom:12px}
.alert.err{background:rgba(224,85,106,.12);color:var(--red);border:1px solid rgba(224,85,106,.3)}
.alert.ok{background:rgba(63,179,127,.10);color:var(--text);border:1px solid rgba(63,179,127,.3)}
.keys{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.key{background:#0b1322;border:1px solid var(--gold);color:var(--gold);padding:6px 10px;border-radius:7px;font-size:13px;letter-spacing:1px}
