.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,#f8fafc,#e2e8f0)}.auth-card{width:min(560px,100%)}.auth-form{display:grid;gap:10px}.auth-form label{font-size:13px;font-weight:600}.totp-setup-card{margin-top:14px;padding:12px;border:1px solid #d1d5db;border-radius:8px;background:#f8fafc}.totp-setup-card h4{margin:0 0 8px;font-size:16px}.totp-qr{display:block;width:220px;height:220px;max-width:100%;margin:10px auto;border:1px solid #cbd5e1;border-radius:8px;background:#fff;padding:6px}:root{font-family:Segoe UI,sans-serif;color:#1f2937;background:#f3f4f6}*{box-sizing:border-box}body{margin:0}.layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:#111827;color:#e5e7eb;padding:20px 16px;display:flex;flex-direction:column;gap:10px}.sidebar h1{font-size:16px;margin:0 0 20px}.sidebar-brand{display:flex;align-items:center;gap:10px}.sidebar-brand-mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#2563eb,#0ea5e9);color:#fff;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.sidebar-brand-subtitle{margin:2px 0 0;font-size:12px;color:#9ca3af}.sidebar-identity{border:1px solid #1f2937;border-radius:8px;padding:8px 10px;background:#0f172a}.sidebar-actor,.sidebar-role{margin:0;font-size:12px;word-break:break-word}.sidebar a{color:#d1d5db;display:block;text-decoration:none;padding:8px 10px;border-radius:6px;margin-bottom:6px}.sidebar a.active,.sidebar a:hover{background:#1f2937;color:#fff}.sidebar-sections{margin-top:10px;flex:1;overflow:auto}.sidebar-section{margin-bottom:8px}.sidebar-section-trigger{width:100%;background:transparent;border:none;color:#9ca3af;padding:8px 10px;display:flex;justify-content:space-between;align-items:center;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.sidebar-section-trigger:hover{color:#e5e7eb;background:#111827}.sidebar-section-caret{color:#6b7280}.sidebar-subnav{border-left:1px solid #1f2937;margin-left:10px;padding-left:8px}.sidebar-subnav a{margin-bottom:4px}.sidebar-actions{border-top:1px solid #1f2937;padding-top:10px}.sidebar-actions button{width:100%}.main{display:flex;flex-direction:column;min-height:100vh;background:#f8fafc}.main-content{flex:1;padding:20px}.shell-header{position:sticky;top:0;z-index:20;border-bottom:1px solid #e5e7eb;background:#fff;padding:10px 20px}.shell-header-row{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}.shell-header-actions{margin-top:8px}.shell-context,.shell-user-menu,.shell-quick-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.shell-pill{display:inline-flex;align-items:center;border-radius:999px;border:1px solid #d1d5db;background:#f8fafc;color:#111827;padding:4px 10px;font-size:12px}.shell-pill-env{border-color:#93c5fd;background:#eff6ff;color:#1d4ed8}.shell-pill-actor{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shell-pill-ok{background:#ecfdf5;border-color:#6ee7b7;color:#065f46}.shell-pill-warn{background:#fffbeb;border-color:#fcd34d;color:#92400e}.shell-pill-danger{background:#fef2f2;border-color:#fca5a5;color:#991b1b}.shell-pill-muted{background:#f3f4f6;border-color:#d1d5db;color:#6b7280}.shell-search{display:inline-flex;gap:8px;align-items:center}.shell-search input{min-width:260px}.utility-footer{border-top:1px solid #e5e7eb;background:#fff;color:#4b5563;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;font-size:12px}.utility-footer-links{display:inline-flex;gap:10px;align-items:center;flex-wrap:wrap}.utility-footer-links a{color:#1d4ed8;text-decoration:none}.utility-footer-links a:hover{text-decoration:underline}.card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.grid{display:grid;gap:16px}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.toolbar{display:flex;gap:8px;margin-bottom:12px}input:not([type=checkbox]),select,button{padding:8px 10px;border-radius:6px;border:1px solid #d1d5db}input[type=checkbox]{width:16px;height:16px}button{background:#2563eb;color:#fff;cursor:pointer}button.small{padding:6px 8px;font-size:12px}button.secondary{background:#4b5563}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:10px;border-bottom:1px solid #e5e7eb}.row-active{background:#f8fafc}.row-muted{opacity:.6}.muted{color:#6b7280}.code-block{background:#0f172a;color:#e2e8f0;padding:12px;border-radius:8px;font-size:12px;max-height:240px;overflow:auto}.status{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px;border:1px solid #d1d5db}.status-ok{background:#ecfdf5;border-color:#6ee7b7;color:#065f46}.status-warn{background:#fffbeb;border-color:#fcd34d;color:#92400e}.status-danger{background:#fef2f2;border-color:#fca5a5;color:#991b1b}.status-muted{background:#f3f4f6;border-color:#d1d5db;color:#6b7280}.bars{display:flex;align-items:flex-end;gap:6px;min-height:160px;overflow-x:auto}.barWrap{display:flex;flex-direction:column;align-items:center;gap:4px}.bar{width:10px;border-radius:3px 3px 0 0;background:#2563eb}.bar.ok{background:#2563eb}.bar.fail{background:#dc2626}.barLabel{font-size:10px;color:#4b5563}.firewall-warning{border:1px solid #f59e0b;background:#fffbeb;border-radius:8px;padding:12px;margin-bottom:12px;color:#92400e}.firewall-warning ul{margin:8px 0;padding-left:20px}.toolbar a{display:inline-flex;align-items:center;justify-content:center;border:1px solid #2563eb;border-radius:6px;padding:8px 10px;text-decoration:none;color:#1d4ed8;background:#eff6ff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;padding:16px;z-index:1000}.modal-card{width:min(520px,100%);border-radius:10px;border:1px solid #d1d5db;background:#fff;padding:16px;box-shadow:0 20px 40px #0f172a2e}@media (max-width: 1024px){.layout{grid-template-columns:210px 1fr}.shell-search input{min-width:180px}}@media (max-width: 768px){.layout{grid-template-columns:1fr}.sidebar{position:static;max-height:280px;overflow:auto}}.list-template{display:grid;gap:10px}.list-template-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.list-template-toolbar label{font-size:12px}.list-template-toolbar input{min-width:180px}.list-template-toolbar select{min-width:120px}.list-template-table{width:100%;overflow-x:auto}.list-template-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.list-template-controls{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.list-template-controls select{min-width:70px}
