:root{--bg:#0f1419;--panel:#1a2230;--panel2:#222c3c;--line:#2f3b4d;--ink:#e6edf3;--mut:#8b97a7;--accent:#3b82f6;--ok:#22c55e;--bad:#ef4444;--warn:#f59e0b}
*{box-sizing:border-box}
body{margin:0;font:15px/1.5 system-ui,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--ink)}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
code,.mono{font-family:ui-monospace,Consolas,monospace}
.muted{color:var(--mut)}.small{font-size:12px}
.topbar{display:flex;align-items:center;gap:20px;padding:12px 20px;background:var(--panel);border-bottom:1px solid var(--line)}
.brand a{font-weight:700;font-size:18px;color:var(--ink)}
.topbar nav{display:flex;gap:16px;flex:1}
.userbox{display:flex;align-items:center;gap:12px}.who{color:var(--mut);font-size:13px}
.wrap{max-width:980px;margin:24px auto;padding:0 20px}
.centered{min-height:80vh;display:flex;align-items:center;justify-content:center}
.foot{text-align:center;color:var(--mut);font-size:12px;padding:24px}
h1{font-size:22px;margin:0 0 16px}h2{font-size:17px;margin:24px 0 10px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:18px;margin-bottom:16px}
.cards{display:flex;gap:14px;flex-wrap:wrap}
.stat{flex:1;min-width:150px;text-align:center}
.stat .num{display:block;font-size:30px;font-weight:700}.stat .lbl{color:var(--mut);font-size:13px}
.login-card{width:340px;text-align:center}
label{display:block;margin:10px 0;font-size:13px;color:var(--mut)}
input,select{width:100%;margin-top:5px;padding:9px 10px;background:var(--panel2);border:1px solid var(--line);border-radius:7px;color:var(--ink);font-size:14px}
.row{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end}.row>label{flex:1;min-width:180px}
.btn{display:inline-block;background:var(--accent);color:#fff;border:0;border-radius:7px;padding:10px 16px;font-size:14px;cursor:pointer}
.btn:hover{filter:brightness(1.1);text-decoration:none}.btn.small{padding:5px 10px;font-size:12px}
.btn-link{background:none;border:0;color:var(--accent);cursor:pointer;padding:0;font-size:13px}
.btn-link:disabled{color:var(--mut);cursor:not-allowed}
.inline{display:inline}.inline-details{display:inline-block}
.flash{padding:11px 14px;border-radius:8px;margin-bottom:16px;border:1px solid}
.flash-info{background:#13243b;border-color:#284b7a}.flash-ok{background:#0f2a1a;border-color:#1d5e38;color:#bbf7d0}
.flash-error{background:#2a1313;border-color:#5e1d1d;color:#fecaca}
.integ-ok{border-color:#1d5e38}.integ-bad{border-color:#5e1d1d;background:#2a1313}
.ok{color:var(--ok)}.bad{color:var(--bad)}
.grid{width:100%;border-collapse:collapse;font-size:13px}
.grid th,.grid td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line);vertical-align:top}
.grid th{color:var(--mut);font-weight:600}
.grid td.actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.components{margin:14px 0}
.comp-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.comp-head input[type=search]{width:auto;display:inline-block;margin:0 0 0 8px;padding:4px 8px}
.comp-group{max-height:320px;overflow:auto;border:1px solid var(--line);border-radius:8px;padding:6px}
.comp-item{display:flex;align-items:center;gap:10px;margin:0;padding:5px 8px;border-radius:6px;color:var(--ink)}
.comp-item:hover{background:var(--panel2)}.comp-item input{width:auto;margin:0}
.comp-item .cid{font-family:ui-monospace,monospace;color:var(--mut);min-width:64px}
.token{display:block;word-break:break-all;background:var(--panel2);padding:10px;border-radius:6px;margin:8px 0}
.tag{font-size:11px;padding:2px 7px;border-radius:20px;background:var(--panel2);border:1px solid var(--line)}
.tag-auth{border-color:#284b7a}.tag-key{border-color:#1d5e38}.tag-user{border-color:#6b4d1d}.tag-audit{border-color:#5e1d1d}
