*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-width: 224px;--sidebar-bg: #111827;--sidebar-border: #1f2937;--sidebar-text: #9ca3af;--sidebar-text-active: #f9fafb;--sidebar-hover-bg: rgba(255, 255, 255, .05);--sidebar-active-bg: rgba(255, 255, 255, .1);--bg: #f3f4f6;--surface: #ffffff;--border: #e5e7eb;--text: #111827;--text-muted: #6b7280;--text-subtle: #9ca3af;--accent: #4f46e5;--accent-hover: #4338ca;--accent-light: #eef2ff;--crash: #dc2626;--crash-bg: #fef2f2;--crash-border: #fecaca;--error-c: #d97706;--error-bg: #fffbeb;--error-border: #fed7aa;--warn: #ca8a04;--warn-bg: #fefce8;--warn-border: #fef08a;--radius: 8px;--radius-sm: 4px;--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}.shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;overflow-y:auto}.main{flex:1;overflow-y:auto;display:flex;flex-direction:column}.sidebar-brand{padding:20px 16px 16px;border-bottom:1px solid var(--sidebar-border)}.sidebar-brand h1{font-size:16px;font-weight:700;color:#f9fafb;letter-spacing:-.01em}.sidebar-brand .tagline{font-size:11px;color:var(--sidebar-text);margin-top:2px}.switcher{padding:14px 16px;border-bottom:1px solid var(--sidebar-border)}.switcher-label{display:block;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#4b5563;margin-bottom:4px}.switcher-select{width:100%;height:32px;padding:0 8px;background:#0b1220;color:#e5e7eb;border:1px solid var(--sidebar-border);border-radius:var(--radius-sm);font-size:13px;outline:none;cursor:pointer}.switcher-select:focus{border-color:var(--accent)}.switcher-empty{font-size:12px;color:var(--sidebar-text);line-height:1.5}.role-badge{display:inline-block;margin-left:8px;padding:1px 6px;border-radius:99px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:#6366f133;color:#a5b4fc;vertical-align:middle}.mobile-topbar{display:none}@media (max-width: 768px){.shell{flex-direction:column;height:auto;min-height:100vh}.mobile-topbar{display:flex;align-items:center;gap:12px;height:52px;padding:0 14px;flex-shrink:0;background:var(--sidebar-bg);color:#f9fafb;position:sticky;top:0;z-index:40}.hamburger{background:none;border:none;color:#f9fafb;font-size:22px;line-height:1;cursor:pointer;padding:4px 8px}.mobile-brand{font-weight:700;font-size:15px}.sidebar{position:fixed;top:52px;left:0;bottom:0;width:250px;z-index:50;transform:translate(-100%);transition:transform .2s ease}.sidebar.open{transform:translate(0);box-shadow:0 0 0 100vmax #00000073}.main{width:100%}.page-header,.page-content{padding-left:14px;padding-right:14px}.filters-bar{flex-wrap:wrap}table{font-size:13px}}.nav-section{padding:16px 0 8px}.nav-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#4b5563;padding:0 16px 6px}.nav-item{display:flex;align-items:center;gap:8px;padding:7px 16px;color:var(--sidebar-text);text-decoration:none;font-size:13.5px;transition:background .1s,color .1s;cursor:pointer;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--sidebar-hover-bg);color:#d1d5db}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-text-active)}.nav-icon{width:16px;height:16px;flex-shrink:0;opacity:.7}.nav-item.active .nav-icon{opacity:1}.sidebar-footer{margin-top:auto;padding:12px 16px;border-top:1px solid var(--sidebar-border)}.sidebar-user{font-size:12px;color:var(--sidebar-text);margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-signout{width:100%;padding:6px 12px;background:#ffffff0f;color:var(--sidebar-text);border:1px solid var(--sidebar-border);border-radius:var(--radius-sm);font-size:12px;cursor:pointer;transition:background .1s}.btn-signout:hover{background:#ffffff1a;color:#d1d5db}.page-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:16px}.page-title{font-size:18px;font-weight:600;color:var(--text)}.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}.page-content{padding:20px 24px;flex:1}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.filters-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;align-items:center}.filter-select,.filter-input{height:34px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:13px;outline:none;transition:border-color .15s}.filter-select:focus,.filter-input:focus{border-color:var(--accent)}.filter-input{min-width:200px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead th{text-align:left;font-weight:600;font-size:12px;color:var(--text-muted);padding:10px 12px;border-bottom:1px solid var(--border);white-space:nowrap;background:#f9fafb}tbody tr{border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}tbody tr:hover{background:#f9fafb}tbody tr:last-child{border-bottom:none}tbody td{padding:10px 12px;vertical-align:middle}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.badge-crash{background:var(--crash-bg);color:var(--crash);border:1px solid var(--crash-border)}.badge-error{background:var(--error-bg);color:var(--error-c);border:1px solid var(--error-border)}.badge-warn{background:var(--warn-bg);color:var(--warn);border:1px solid var(--warn-border)}.chip{display:inline-flex;align-items:center;padding:2px 7px;border-radius:var(--radius-sm);font-size:11px;font-weight:500;background:#f3f4f6;color:var(--text-muted);border:1px solid var(--border);white-space:nowrap}.state-empty,.state-loading,.state-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--text-muted);text-align:center;gap:8px}.state-error{color:var(--crash)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--sidebar-bg)}.auth-card{background:var(--surface);border-radius:var(--radius);padding:40px;width:100%;max-width:380px;box-shadow:0 4px 24px #0000004d}.auth-logo{font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px}.auth-tagline{font-size:13px;color:var(--text-muted);margin-bottom:28px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:500;color:var(--text);margin-bottom:6px}.form-input{width:100%;height:38px;padding:0 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.btn-primary{width:100%;height:38px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s;margin-top:8px}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.form-error{font-size:13px;color:var(--crash);margin-top:12px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.detail-field{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.detail-value{font-size:14px;color:var(--text)}.detail-stack{background:#1e1e2e;color:#cdd6f4;padding:16px;border-radius:var(--radius);font-family:Cascadia Code,JetBrains Mono,Consolas,monospace;font-size:12px;line-height:1.6;overflow-x:auto;white-space:pre-wrap;word-break:break-all}.btn-back{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);font-size:13px;text-decoration:none;padding:4px 0;background:none;border:none;cursor:pointer;transition:color .1s;margin-bottom:4px}.btn-back:hover{color:var(--text)}.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:16px}.settings-card h3{font-size:15px;font-weight:600;margin-bottom:4px}.settings-card .hint{font-size:12.5px;color:var(--text-muted);margin-bottom:16px}.inline-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.field-row{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin-bottom:12px}.field-row label{font-size:13px;font-weight:500;min-width:130px}.btn{height:34px;padding:0 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;background:var(--accent);color:#fff;transition:background .15s,opacity .15s}.btn:hover:not(:disabled){background:var(--accent-hover)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:#f9fafb}.btn-danger{background:var(--surface);color:var(--crash);border-color:var(--crash-border)}.btn-danger:hover:not(:disabled){background:var(--crash-bg)}.btn-sm{height:28px;padding:0 10px;font-size:12px}.token-reveal{background:#1e1e2e;color:#a6e3a1;padding:12px 14px;border-radius:var(--radius);font-family:Consolas,monospace;font-size:13px;word-break:break-all;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}.token-warn{font-size:12px;color:var(--error-c);margin-top:8px}.checkbox-list{display:flex;flex-wrap:wrap;gap:8px 16px}.checkbox-list label{display:flex;align-items:center;gap:6px;font-size:13px;min-width:auto;cursor:pointer}.pill{display:inline-block;padding:1px 8px;border-radius:99px;font-size:11px;background:var(--accent-light);color:var(--accent);margin:1px 3px 1px 0}.pill-muted{background:#f3f4f6;color:var(--text-muted)}.revoked{opacity:.5;text-decoration:line-through}.live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;color:#16a34a;font-weight:500}.live-dot{width:7px;height:7px;border-radius:50%;background:#16a34a;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.text-muted{color:var(--text-muted)}.text-mono{font-family:Consolas,monospace}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:320px}
