:root{--bg:#0f172a;--panel:#1e293b;--ink:#e2e8f0;--muted:#94a3b8;--accent:#22d3ee;--ok:#10b981;--warn:#f59e0b;--err:#ef4444;--border:#334155}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--ink);line-height:1.5}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.topbar{display:flex;align-items:center;gap:1.5rem;padding:.8rem 1.5rem;background:var(--panel);border-bottom:1px solid var(--border)}
.topbar .brand{font-weight:600;font-size:1.05rem;color:var(--ink)}
.topbar nav{display:flex;gap:1rem;flex:1}
.topbar nav a{color:var(--muted);font-size:.95rem}
.topbar nav a:hover{color:var(--ink)}
.topbar-right{display:flex;align-items:center;gap:1rem}
.topbar .logout{color:var(--muted);font-size:.9rem}
.user-chip{display:flex;align-items:center;gap:.4rem;color:var(--muted);font-size:.9rem}
.user-chip:hover{color:var(--ink)}
.role-badge{font-size:.72rem;padding:.1rem .4rem;border-radius:3px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.role-badge.role-admin{background:#4c1d95;color:#ddd6fe}
.role-badge.role-viewer{background:#1e3a5f;color:#bae6fd}
.you-badge{color:var(--muted);font-size:.82rem;font-weight:400}
.row-inactive td{opacity:.45}
.card-form{background:var(--panel);border:1px solid var(--border);padding:1.4rem;border-radius:8px;margin-bottom:1.5rem}
.card-form h2{margin-top:0;font-size:1rem;color:var(--muted);border-bottom:1px solid var(--border);padding-bottom:.4rem;margin-bottom:1rem}
.add-user-form .form-row{display:flex;flex-wrap:wrap;gap:.8rem;align-items:flex-end}
.add-user-form .form-row label{flex:1;min-width:160px;margin:0}
.add-user-form .form-row button{align-self:flex-end;white-space:nowrap}
.actions{display:flex;align-items:flex-start;gap:.4rem;flex-wrap:wrap}
.btn-sm{padding:.25rem .6rem;font-size:.82rem;background:#475569;color:var(--ink);border:none;border-radius:4px;cursor:pointer;font:inherit}
.btn-sm:hover{filter:brightness(1.15)}
.btn-sm.danger{background:#7f1d1d;color:#fecaca}
.btn-sm.ok{background:#064e3b;color:#a7f3d0}
.reset-form{margin-top:.4rem;width:100%}
.reset-form .inline-row{display:flex;gap:.4rem;align-items:center}
.reset-form .inline-row input{width:180px}
.hidden{display:none!important}
.role-select{background:#0b1322;color:var(--ink);border:1px solid var(--border);border-radius:4px;padding:.2rem .4rem;font:inherit;font-size:.85rem}
.container{max-width:1200px;margin:0 auto;padding:1.5rem}
h1{margin-top:0;font-size:1.6rem}
h2{font-size:1.2rem;margin-top:2rem;border-bottom:1px solid var(--border);padding-bottom:.4rem}
h3{font-size:1rem;margin-top:1.2rem;color:var(--muted)}
.muted{color:var(--muted)}
.empty{color:var(--muted);padding:1rem;font-style:italic}
.note{background:#3a2c12;border:1px solid #65430a;color:#fde68a;padding:.6rem .8rem;border-radius:6px;font-size:.9rem}
.flash{padding:.6rem .9rem;border-radius:6px;margin-bottom:1rem;font-size:.95rem}
.flash-success{background:#064e3b;color:#a7f3d0;border:1px solid #047857}
.flash-error{background:#7f1d1d;color:#fecaca;border:1px solid #b91c1c}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}
.card{background:var(--panel);border:1px solid var(--border);padding:1.1rem;border-radius:8px;display:flex;flex-direction:column}
.card .num{font-size:1.8rem;font-weight:700;color:var(--accent)}
.card span:last-child{color:var(--muted);font-size:.9rem}

table.data{width:100%;border-collapse:collapse;background:var(--panel);border-radius:8px;overflow:hidden;font-size:.92rem}
table.data th,table.data td{padding:.55rem .7rem;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
table.data th{background:#293548;color:var(--muted);font-weight:500;font-size:.85rem;text-transform:uppercase;letter-spacing:.03em}
table.data tr:last-child td{border-bottom:none}
table.data tr:hover td{background:#243044}

.kw{display:inline-block;background:#0e7490;color:#cffafe;padding:.1rem .5rem;border-radius:4px;font-size:.82rem;font-weight:600}
.ok{color:var(--ok);font-weight:600}
.pending{color:var(--warn)}
.status{font-weight:600}
.status-ok{color:var(--ok)}
.status-error{color:var(--err)}
.status-running{color:var(--warn)}

form label{display:block;margin-bottom:1rem}
form input,form textarea,form select{width:100%;padding:.55rem .7rem;background:#0b1322;color:var(--ink);border:1px solid var(--border);border-radius:6px;font:inherit}
form input:focus,form textarea:focus{outline:none;border-color:var(--accent)}
form textarea{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9rem}
button{padding:.5rem 1rem;background:var(--accent);color:#042f37;border:none;border-radius:6px;font-weight:600;cursor:pointer;font:inherit}
button:hover{filter:brightness(1.1)}
button.danger{background:var(--err);color:#fee2e2}
.inline-form{display:flex;gap:.5rem;margin-bottom:1.5rem;align-items:center}
.inline-form input{flex:1}
form.inline{display:inline}
form.inline button{padding:.25rem .6rem;font-size:.85rem;background:#475569;color:var(--ink)}
form.inline button.danger{background:#7f1d1d;color:#fecaca}

.login-card{max-width:340px;margin:5rem auto;background:var(--panel);padding:2rem;border-radius:8px;border:1px solid var(--border)}
.login-card h1{font-size:1.3rem;text-align:center;margin-bottom:1.5rem}

.source-block{background:var(--panel);border:1px solid var(--border);padding:1.2rem;border-radius:8px;margin-bottom:1.5rem}
.source-block h2{margin-top:0;border-bottom:none;padding-bottom:0}

small{color:var(--muted);font-size:.8rem}
code{background:#0b1322;padding:.1rem .35rem;border-radius:3px;font-size:.88em}
