:root{--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a;--bg: var(--slate-100);--surface: #ffffff;--surface-2: var(--slate-50);--border: var(--slate-200);--border-strong: var(--slate-300);--text: var(--slate-900);--text-2: var(--slate-600);--text-3: var(--slate-400);--side-bg: var(--slate-900);--side-bg-2: #0b1220;--side-border: rgba(148, 163, 184, .12);--side-text: var(--slate-300);--side-text-dim: var(--slate-500);--side-hover-bg: rgba(148, 163, 184, .1);--side-active-bg: rgba(99, 102, 241, .16);--side-active-tx: #ffffff;--accent: #4f46e5;--accent-hover: #4338ca;--accent-active: #3730a3;--accent-soft: #eef2ff;--accent-tx: #4338ca;--accent-ring: rgba(79, 70, 229, .18);--success: #16a34a;--success-soft: #dcfce7;--success-tx: #166534;--warn: #d97706;--warn-soft: #fef3c7;--warn-tx: #92400e;--danger: #dc2626;--danger-soft: #fee2e2;--danger-tx: #991b1b;--info: #2563eb;--info-soft: #dbeafe;--info-tx: #1e40af;--r-sm: 6px;--r: 8px;--r-lg: 12px;--r-pill: 999px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow: 0 1px 3px rgba(15, 23, 42, .08), 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 6px 16px rgba(15, 23, 42, .1), 0 2px 6px rgba(15, 23, 42, .06);--shadow-lg: 0 20px 48px rgba(15, 23, 42, .28);--font: -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", Roboto, sans-serif;--font-mono: ui-monospace, "SF Mono", SFMono-Regular, Menlo, monospace;font-family:var(--font);line-height:1.5;color:var(--text);background:var(--bg);font-size:14px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;background:var(--bg)}h1,h2,h3,h4{color:var(--text);font-weight:650;letter-spacing:-.01em}a{color:var(--accent-tx);text-decoration:none}a:hover{text-decoration:underline}code,.mono{font-family:var(--font-mono);font-size:.92em}button{font:inherit;font-weight:550;padding:7px 13px;border:1px solid var(--border-strong);border-radius:var(--r-sm);background:var(--surface);color:var(--text);cursor:pointer;transition:background .12s,border-color .12s,box-shadow .12s,color .12s;box-shadow:var(--shadow-sm)}button:hover:not(:disabled){background:var(--surface-2);border-color:var(--slate-400)}button:active:not(:disabled){background:var(--slate-100)}button:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}button.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}button.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}button.btn-primary:active:not(:disabled){background:var(--accent-active)}button.danger{color:var(--danger-tx);border-color:#fecaca;background:#fff}button.danger:hover:not(:disabled){background:var(--danger-soft);border-color:#fca5a5}button.btn-sm{padding:4px 10px;font-size:12px}button.btn-ghost{background:transparent;border-color:transparent;box-shadow:none;color:var(--text-2)}button.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text)}button.link{background:none;border:none;padding:0;box-shadow:none;color:var(--accent-tx);text-decoration:underline;font-weight:500}button.link:hover{background:none;color:var(--accent-hover)}input,select,textarea{font:inherit;padding:8px 10px;border:1px solid var(--border-strong);border-radius:var(--r-sm);background:var(--surface);color:var(--text);transition:border-color .12s,box-shadow .12s}input::placeholder{color:var(--text-3)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.muted{color:var(--text-2)}.small{font-size:12px}.empty{text-align:center;color:var(--text-3);padding:28px;font-style:italic}.error{color:var(--danger-tx);background:var(--danger-soft);border:1px solid #fecaca;padding:10px 14px;border-radius:var(--r-sm);font-size:13px}.error.small{font-size:11px;padding:4px 0;background:none;border:none;color:var(--danger-tx)}.layout{display:grid;grid-template-columns:244px 1fr;min-height:100vh}.nav{background:linear-gradient(180deg,var(--side-bg) 0%,var(--side-bg-2) 100%);color:var(--side-text);padding:16px 12px;display:flex;flex-direction:column;gap:2px;border-right:1px solid var(--side-border);position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px}.brand-mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--accent) 0%,#7c3aed 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:15px;flex:none;box-shadow:0 2px 8px #4f46e566}.brand-text{display:flex;flex-direction:column;line-height:1.15}.brand-text .brand-name{color:#fff;font-weight:650;font-size:14px}.brand-text .brand-sub{color:var(--side-text-dim);font-size:10px;letter-spacing:.12em;text-transform:uppercase}.nav-section{color:var(--side-text-dim);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:16px 10px 6px}.nav a{display:flex;align-items:center;gap:10px;color:var(--side-text);text-decoration:none;padding:8px 10px;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;transition:background .12s,color .12s}.nav a:hover{background:var(--side-hover-bg);color:#fff;text-decoration:none}.nav a.active{background:var(--side-active-bg);color:var(--side-active-tx);font-weight:600}.nav-ico{width:17px;height:17px;flex:none;color:var(--side-text-dim)}.nav a:hover .nav-ico{color:inherit}.nav a.active .nav-ico{color:#a5b4fc}.nav-spacer{flex:1}.nav-user{border-top:1px solid var(--side-border);padding-top:12px;margin-top:8px;display:flex;align-items:center;gap:10px}.nav-avatar{width:30px;height:30px;border-radius:50%;background:var(--slate-700);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex:none;text-transform:uppercase}.nav-user-meta{display:flex;flex-direction:column;min-width:0;line-height:1.25}.nav-user-email{color:var(--side-text);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-user-meta button.link{color:var(--side-text-dim);font-size:11px;text-decoration:none;text-align:left}.nav-user-meta button.link:hover{color:#fff;text-decoration:underline}.main{padding:28px 32px;max-width:1320px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}.page-header h2{margin:0;font-size:21px}.page-header .subtitle{margin:4px 0 0;color:var(--text-2);font-size:13px;max-width:70ch}.page-title{display:flex;flex-direction:column}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm)}.card+.card{margin-top:16px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.card-title{margin:0;font-size:15px;font-weight:650}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.toolbar .count-pill{font-size:12px;color:var(--text-2);background:var(--surface);border:1px solid var(--border);padding:3px 10px;border-radius:var(--r-pill)}.data-table{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.data-table th,.data-table td{padding:11px 16px;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}.data-table th{background:var(--surface-2);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);white-space:nowrap}.data-table td{font-size:13px;color:var(--text)}.data-table tbody tr{transition:background .1s}.data-table tbody tr:hover{background:var(--surface-2)}.data-table tr:last-child td{border-bottom:none}.data-table tr.revoked{opacity:.5}.data-table .cell-strong{font-weight:600}.data-table .cell-sub{color:var(--text-3);font-size:11px;font-family:var(--font-mono);margin-top:2px}.row-actions{display:flex;gap:6px;align-items:center;justify-content:flex-end}.row-actions button{font-size:12px;padding:4px 10px}.badge{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;padding:2px 8px;border-radius:var(--r-pill);background:var(--slate-100);color:var(--text-2);text-transform:uppercase;letter-spacing:.03em;font-weight:600;border:1px solid transparent}.badge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.9}.badge.no-dot:before{display:none}.badge-muted{background:var(--slate-100);color:var(--slate-500)}.badge-running{background:var(--warn-soft);color:var(--warn-tx)}.badge-ok,.badge-success{background:var(--success-soft);color:var(--success-tx)}.badge-bad,.badge-danger{background:var(--danger-soft);color:var(--danger-tx);cursor:help}.badge-info{background:var(--info-soft);color:var(--info-tx);cursor:help}.badge-warn{background:var(--warn-soft);color:var(--warn-tx)}.reach-cell{display:inline-flex;align-items:center;gap:3px;font-size:10px;cursor:help}.reach-dot{width:7px;height:7px;border-radius:50%;display:inline-block}.reach-cell.dot-ok .reach-dot{background:#22c55e}.reach-cell.dot-warn .reach-dot{background:#f59e0b}.reach-cell.dot-bad .reach-dot{background:#ef4444}.reach-cell.dot-unknown .reach-dot{background:var(--slate-300)}.reach-cell.dot-ok .reach-label{color:var(--success-tx)}.reach-cell.dot-warn .reach-label{color:var(--warn-tx)}.reach-cell.dot-bad .reach-label{color:var(--danger-tx)}.reach-cell.dot-unknown .reach-label{color:var(--slate-500)}.card button.link,.kv button.link{background:none;border:0;padding:0;box-shadow:none;color:var(--accent-tx);text-decoration:underline;cursor:pointer;font:inherit}.card button.link:hover,.kv button.link:hover{color:var(--accent-hover);background:none}.card button.link:disabled,.kv button.link:disabled{color:var(--text-3);cursor:default}.create-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px;margin-bottom:20px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-sm)}.create-form .row{display:flex;gap:16px}.create-form label{display:flex;flex-direction:column;gap:5px;flex:1;font-size:12px;color:var(--text-2)}.create-form label.checkbox{flex-direction:row;align-items:center;font-size:14px;color:var(--text)}.create-form fieldset{border:1px solid var(--border);border-radius:var(--r);padding:16px;display:flex;flex-direction:column;gap:16px;margin:0;background:var(--surface-2)}.create-form fieldset legend{font-size:11px;font-weight:600;color:var(--text-2);padding:0 6px;text-transform:uppercase;letter-spacing:.04em}.create-form .row .checkbox{flex:0 0 auto;margin-top:18px}.create-form .form-intro{margin:0;font-size:13px;line-height:1.5;color:var(--text-2);background:var(--accent-soft);border:1px solid #e0e7ff;border-radius:var(--r);padding:12px 14px}.create-form .form-intro strong{color:var(--accent-tx)}.create-form label .field-label{font-weight:600;color:var(--text);font-size:12px}.create-form .field-hint{font-weight:400;font-size:11px;line-height:1.45;color:var(--text-3)}.create-form .field-block{display:flex;flex-direction:column;gap:5px}.create-form .field-block .checkbox{margin-top:0}.create-form .field-block .field-hint{margin-left:24px}.create-form .form-actions{display:flex;align-items:center;gap:12px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:20px}.tab{background:transparent;border:0;box-shadow:none;padding:9px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;font-size:14px;font-weight:500;color:var(--text-2)}.tab:hover{color:var(--text);background:transparent}.tab.active{color:var(--accent-tx);border-bottom-color:var(--accent);font-weight:600;background:transparent}.kv{display:grid;grid-template-columns:max-content 1fr;gap:8px 18px;margin:0}.kv dt{color:var(--text-2);font-size:12px;padding-top:2px}.kv dd{margin:0;font-size:13px}.json-pre{background:var(--slate-900);color:#e2e8f0;border:1px solid var(--slate-800);border-radius:var(--r);padding:12px 14px;font-size:11px;font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word;max-height:280px;overflow-y:auto;margin:0}.cred-section{margin-top:22px;padding-top:18px;border-top:1px solid var(--border)}.cred-section:first-of-type{border-top:0;padding-top:0}.cred-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.cred-section-header h3{margin:0;font-size:14px}.newkey-banner{background:var(--warn-soft);border:1px solid #fde68a;border-radius:var(--r);padding:14px 16px;margin-bottom:18px;display:flex;flex-direction:column;gap:8px}.newkey-banner .raw-key{font-size:13px;font-family:var(--font-mono);background:var(--surface);padding:9px 12px;border-radius:var(--r-sm);border:1px solid var(--border-strong);word-break:break-all}.login-shell{display:flex;align-items:center;justify-content:center;min-height:100vh;background:radial-gradient(1200px 600px at 50% -10%,#1e293b 0%,var(--slate-900) 55%)}.login-card{background:var(--surface);padding:36px;border-radius:var(--r-lg);width:380px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-lg)}.login-card .brand{padding:0 0 6px}.login-card h2{margin:0;font-size:20px}.login-card p{color:var(--text-2);font-size:13px;margin:0}.login-card input{padding:11px 12px}.login-card button.btn-primary{padding:11px 12px;font-size:14px}
