:root{color-scheme:light;--brand-50: #eef2ff;--brand-100: #e0e7ff;--brand-200: #c7d2fe;--brand-300: #a5b4fc;--brand-400: #818cf8;--brand-500: #6366f1;--brand-600: #4f46e5;--brand-700: #4338ca;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--green-50: #ecfdf5;--green-500: #10b981;--green-600: #059669;--green-700: #047857;--amber-50: #fffbeb;--amber-500: #f59e0b;--amber-600: #d97706;--red-50: #fef2f2;--red-500: #ef4444;--red-600: #dc2626;--blue-50: #eff6ff;--blue-500: #3b82f6;--blue-600: #2563eb;--cyan-50: #ecfeff;--cyan-500: #06b6d4;--purple-50: #faf5ff;--purple-500: #a855f7;--bg: #f4f6fb;--surface: #ffffff;--surface-2: #f8fafc;--border: #e6eaf1;--border-strong: #d4dae6;--text: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--r-full: 999px;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 1px 3px rgba(15, 23, 42, .08), 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 12px rgba(15, 23, 42, .08);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .12);--shadow-xl: 0 24px 48px rgba(15, 23, 42, .18);--sidebar-w: 256px;--sidebar-w-collapsed: 72px;--topbar-h: 60px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--mono: "JetBrains Mono", "SF Mono", "Fira Code", ui-monospace, Menlo, Consolas, monospace}[data-theme=dark]{color-scheme:dark;--brand-50: rgba(99, 102, 241, .18);--brand-600: #6366f1;--brand-700: #4f46e5;--gray-50: #1a2336;--gray-100: #1e283d;--gray-200: #273349;--gray-300: #3a4760;--gray-400: #6b7a90;--gray-500: #94a3b8;--gray-600: #cbd5e1;--gray-700: #e2e8f0;--gray-800: #f1f5f9;--gray-900: #f8fafc;--green-50: rgba(16, 185, 129, .16);--green-500: #10b981;--green-600: #34d399;--green-700: #34d399;--amber-50: rgba(245, 158, 11, .16);--amber-500: #f59e0b;--amber-600: #fbbf24;--red-50: rgba(239, 68, 68, .16);--red-500: #f87171;--red-600: #ef4444;--blue-50: rgba(59, 130, 246, .16);--blue-500: #3b82f6;--blue-600: #60a5fa;--cyan-50: rgba(6, 182, 212, .16);--cyan-500: #22d3ee;--purple-50: rgba(168, 85, 247, .16);--purple-500: #c084fc;--bg: #0a1020;--surface: #111a2e;--surface-2: #0d1525;--border: #233047;--border-strong: #334155;--text: #e7edf6;--text-secondary: #aab6c8;--text-muted: #6f7d92;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .45);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .5);--shadow-xl: 0 24px 48px rgba(0, 0, 0, .6)}[data-theme=dark] .topbar{background:#111a2ed9}[data-theme=dark] .topbar-search:focus-within{background:var(--surface)}[data-theme=dark] .badge-cyan{color:#67e8f9}[data-theme=dark] .badge-purple,[data-theme=dark] .method-patch{color:#d8b4fe}[data-theme=dark] .alert-error{border-color:#ef444473}[data-theme=dark] .alert-info{border-color:#3b82f673}[data-theme=dark] .input.invalid,[data-theme=dark] .textarea.invalid{border-color:#f87171}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}h1,h2,h3,h4,h5{margin:0;font-weight:650;letter-spacing:-.01em;color:var(--text)}p{margin:0}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--r-full);border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}::-webkit-scrollbar-track{background:transparent}.flex{display:flex}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.mono{font-family:var(--mono)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grid{display:grid}.break-all{word-break:break-all}.app-shell{display:flex;min-height:100vh}.app-main{flex:1;min-width:0;display:flex;flex-direction:column;margin-left:var(--sidebar-w);transition:margin-left .2s ease}.app-main.collapsed{margin-left:var(--sidebar-w-collapsed)}.page{padding:24px 32px 64px;max-width:1600px;width:100%;margin:0 auto;animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);background:#0b1120;color:#cbd5e1;display:flex;flex-direction:column;z-index:40;transition:width .2s ease;border-right:1px solid rgba(255,255,255,.04)}.sidebar.collapsed{width:var(--sidebar-w-collapsed)}.sidebar-brand{height:var(--topbar-h);display:flex;align-items:center;gap:10px;padding:0 18px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.sidebar-logo{width:32px;height:32px;border-radius:8px;flex-shrink:0;background:linear-gradient(135deg,var(--brand-500),var(--cyan-500));display:grid;place-items:center;color:#fff}.sidebar-brand-text{display:flex;flex-direction:column;line-height:1.1;overflow:hidden}.sidebar-collapse-btn{margin-left:auto;width:28px;height:28px;border-radius:var(--r-sm);background:transparent;border:none;color:#64748b;display:grid;place-items:center;transition:color .15s,background .15s}.sidebar-collapse-btn:hover{color:#e2e8f0;background:#ffffff0f}.sidebar-expand-btn{width:calc(100% - 20px);height:34px;margin:6px 10px 2px;background:transparent;border:none;color:#64748b;border-radius:var(--r-md);display:grid;place-items:center;transition:color .15s,background .15s}.sidebar-expand-btn:hover{color:#e2e8f0;background:#ffffff0f}@media (max-width: 900px){.sidebar-expand-btn{display:none}}.sidebar-brand-text strong{color:#fff;font-size:15px}.sidebar-brand-text span{font-size:11px;color:#64748b}.sidebar-nav{flex:1;overflow-y:auto;padding:12px 10px}.sidebar-nav::-webkit-scrollbar-thumb{background:#1e293b;border-color:#0b1120}.nav-section-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:#475569;font-weight:600;padding:14px 12px 6px}.sidebar.collapsed .nav-section-label{text-align:center;padding:14px 0 6px;opacity:.5}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 12px;margin:2px 0;border-radius:var(--r-md);color:#94a3b8;font-size:13.5px;font-weight:500;transition:all .15s;position:relative;white-space:nowrap}.nav-item:hover{background:#ffffff0d;color:#e2e8f0}.nav-item.active{background:linear-gradient(90deg,#6366f138,#6366f10d);color:#fff}.nav-item.active:before{content:"";position:absolute;left:-10px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--brand-400)}.nav-item svg{flex-shrink:0}.nav-badge{margin-left:auto;background:var(--red-500);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:var(--r-full)}.sidebar.collapsed .nav-item{justify-content:center}.sidebar.collapsed .nav-item span,.sidebar.collapsed .nav-badge{display:none}.sidebar-footer{padding:12px;border-top:1px solid rgba(255,255,255,.06)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r-md);transition:background .15s}.sidebar-user:hover{background:#ffffff0d}.sidebar-user .meta{overflow:hidden}.sidebar-user .meta strong{color:#fff;font-size:13px;display:block}.sidebar-user .meta span{color:#64748b;font-size:11px}.sidebar.collapsed .sidebar-user .meta{display:none}.topbar{height:var(--topbar-h);background:#ffffffd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 24px;position:sticky;top:0;z-index:30}.topbar-title{font-size:15px;font-weight:650}.topbar-search{display:flex;align-items:center;gap:8px;background:var(--gray-100);border:1px solid transparent;border-radius:var(--r-md);padding:8px 12px;width:360px;max-width:40vw;color:var(--text-muted);transition:all .15s}.topbar-search:focus-within{background:#fff;border-color:var(--brand-300);box-shadow:0 0 0 3px var(--brand-50)}.topbar-search input{border:none;background:none;outline:none;flex:1;font-size:13.5px;color:var(--text)}.topbar-kbd{font-size:11px;font-family:var(--mono);background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:1px 5px;color:var(--text-muted)}.topbar-user{display:flex;flex-direction:column;line-height:1.2;text-align:right}.topbar-user strong{font-size:13px}.topbar-user span{font-size:11.5px;color:var(--text-muted)}.icon-btn{width:38px;height:38px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);display:grid;place-items:center;transition:all .15s;position:relative}.icon-btn:hover{background:var(--gray-100);color:var(--text);border-color:var(--border-strong)}.icon-btn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--red-500);border:2px solid var(--surface)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xs)}.card-pad{padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.card-header h3{font-size:14.5px}.card-header .subtitle{font-size:12px;color:var(--text-muted);margin-top:2px}.card-body{padding:20px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow-xs);transition:all .18s;position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--border-strong)}.stat-card .stat-top{display:flex;align-items:flex-start;justify-content:space-between}.stat-icon{width:42px;height:42px;border-radius:var(--r-md);display:grid;place-items:center}.stat-value{font-size:28px;font-weight:700;letter-spacing:-.02em;margin-top:14px;line-height:1}.stat-label{font-size:12.5px;color:var(--text-muted);margin-top:6px;font-weight:500}.stat-trend{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:600;margin-top:10px}.stat-trend.up{color:var(--green-600)}.stat-trend.down{color:var(--red-600)}.stat-trend.flat{color:var(--text-muted)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:var(--r-full);font-size:11.5px;font-weight:600;line-height:1.4;white-space:nowrap}.badge .badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge-green{background:var(--green-50);color:var(--green-700)}.badge-red{background:var(--red-50);color:var(--red-600)}.badge-amber{background:var(--amber-50);color:var(--amber-600)}.badge-blue{background:var(--blue-50);color:var(--blue-600)}.badge-cyan{background:var(--cyan-50);color:#0e7490}.badge-purple{background:var(--purple-50);color:#9333ea}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.badge-outline{background:transparent;border:1px solid var(--border-strong);color:var(--text-secondary)}.method{font-family:var(--mono);font-weight:700;font-size:11px;padding:2px 7px;border-radius:var(--r-sm)}.method-get{background:var(--blue-50);color:var(--blue-600)}.method-post{background:var(--green-50);color:var(--green-700)}.method-put{background:var(--amber-50);color:var(--amber-600)}.method-patch{background:var(--purple-50);color:#9333ea}.method-delete{background:var(--red-50);color:var(--red-600)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:8px 14px;border-radius:var(--r-md);font-size:13.5px;font-weight:600;border:1px solid transparent;transition:all .15s;white-space:nowrap;line-height:1.2}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand-600);color:#fff;box-shadow:var(--shadow-xs)}.btn-primary:hover:not(:disabled){background:var(--brand-700);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--surface);color:var(--text-secondary);border-color:var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);color:var(--text)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--text)}.btn-danger{background:var(--red-600);color:#fff}.btn-danger:hover:not(:disabled){background:var(--red-500)}.btn-sm{padding:6px 10px;font-size:12.5px}.btn-lg{padding:11px 20px;font-size:14.5px}.btn-icon{padding:8px}.btn-block{width:100%}.table-wrap{width:100%;overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:13.5px}.table thead th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600;padding:11px 16px;border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap}.table tbody td{padding:13px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.table tbody tr{transition:background .12s}.table tbody tr:hover{background:var(--surface-2)}.table tbody tr:last-child td{border-bottom:none}.table .row-link{cursor:pointer}.table-sortable th{cursor:pointer;-webkit-user-select:none;user-select:none}.table-sortable th:hover{color:var(--text-secondary)}.cell-strong{font-weight:600;color:var(--text)}.cell-sub{font-size:12px;color:var(--text-muted)}.table-card{overflow:hidden}.table-card .table thead th:first-child,.table-card .table tbody td:first-child{padding-left:20px}.field{margin-bottom:18px}.field label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.field label .req{color:var(--red-500);margin-left:2px}.field .hint{font-size:12px;color:var(--text-muted);margin-top:5px}.field .hint.error{color:var(--red-600)}.input,.select,.textarea{width:100%;padding:9px 12px;border:1px solid var(--border-strong);border-radius:var(--r-md);font-size:13.5px;color:var(--text);background:var(--surface);transition:all .15s;outline:none}.input:focus,.select:focus,.textarea:focus{border-color:var(--brand-400);box-shadow:0 0 0 3px var(--brand-50)}.input::placeholder,.textarea::placeholder{color:var(--text-muted)}.input.invalid,.textarea.invalid{border-color:var(--red-400, #f87171)}.textarea{resize:vertical;min-height:90px}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%2394a3b8' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:34px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 20px}.toggle{position:relative;display:inline-block;width:40px;height:22px}.toggle input{display:none}.toggle .track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gray-300);border-radius:var(--r-full);transition:.2s;cursor:pointer}.toggle .track:before{content:"";position:absolute;width:16px;height:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:var(--shadow-sm)}.toggle input:checked+.track{background:var(--brand-600)}.toggle input:checked+.track:before{transform:translate(18px)}.checkbox{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;color:var(--text-secondary);cursor:pointer;padding:4px 0}.checkbox input{width:16px;height:16px;accent-color:var(--brand-600);cursor:pointer}.segmented{display:inline-flex;background:var(--gray-100);border-radius:var(--r-md);padding:3px;gap:2px}.segmented button{border:none;background:transparent;padding:6px 14px;border-radius:7px;font-size:13px;font-weight:600;color:var(--text-secondary);transition:all .15s}.segmented button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-xs)}.filter-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:18px}.search-input{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:8px 12px;min-width:260px;color:var(--text-muted);transition:all .15s}.search-input:focus-within{border-color:var(--brand-400);box-shadow:0 0 0 3px var(--brand-50)}.search-input input{border:none;outline:none;background:none;flex:1;font-size:13.5px;color:var(--text)}.filter-select{padding:8px 32px 8px 12px;border:1px solid var(--border-strong);border-radius:var(--r-md);font-size:13px;font-weight:500;color:var(--text-secondary);background:var(--surface);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%2394a3b8' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;cursor:pointer;outline:none}.filter-select:focus{border-color:var(--brand-400)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.page-header h1{font-size:22px}.page-header .desc{color:var(--text-muted);font-size:13.5px;margin-top:4px;max-width:720px}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text-muted);margin-bottom:8px}.breadcrumb a:hover{color:var(--brand-600)}.back-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:16px;background:none;border:none;padding:0}.back-link:hover{color:var(--brand-600)}.dash-section{display:flex;align-items:baseline;gap:10px;margin:22px 0 14px}.dash-section:first-child{margin-top:0}.dash-section h2{font-size:12.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text-secondary);white-space:nowrap}.dash-section .dash-section-sub{font-size:12.5px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-section:after{content:"";flex:1 1 auto;height:1px;min-width:24px;background:var(--border)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:24px;overflow-x:auto}.tab{padding:11px 16px;font-size:13.5px;font-weight:600;color:var(--text-muted);border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none;display:inline-flex;align-items:center;gap:7px}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--brand-600);border-bottom-color:var(--brand-600)}.tab .tab-count{background:var(--gray-100);color:var(--text-muted);font-size:11px;padding:1px 7px;border-radius:var(--r-full);font-weight:600}.tab.active .tab-count{background:var(--brand-50);color:var(--brand-600)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .15s ease}.modal{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-xl);width:100%;max-width:540px;max-height:90vh;display:flex;flex-direction:column;animation:modalIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:16px}.modal-header p{font-size:13px;color:var(--text-muted);margin-top:4px}.modal-body{padding:24px;overflow-y:auto}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border);background:var(--surface-2);border-radius:0 0 var(--r-lg) var(--r-lg)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;display:flex;justify-content:flex-end;animation:fadeIn .15s ease}.drawer{background:var(--surface);width:100%;max-width:560px;height:100%;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;animation:drawerIn .22s cubic-bezier(.16,1,.3,1)}@keyframes drawerIn{0%{transform:translate(40px);opacity:.6}to{transform:none;opacity:1}}.drawer-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.drawer-body{padding:24px;overflow-y:auto;flex:1}.drawer-footer{padding:16px 24px;border-top:1px solid var(--border);background:var(--surface-2);display:flex;justify-content:flex-end;gap:10px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:56px 24px;text-align:center}.empty-state .empty-icon{width:56px;height:56px;border-radius:var(--r-lg);background:var(--gray-100);color:var(--gray-400);display:grid;place-items:center;margin-bottom:16px}.empty-state h4{font-size:15px;margin-bottom:6px}.empty-state p{color:var(--text-muted);font-size:13px;max-width:360px;margin-bottom:16px}.spinner{width:22px;height:22px;border:2.5px solid var(--gray-200);border-top-color:var(--brand-600);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 37%,var(--gray-100) 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite;border-radius:var(--r-sm)}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.avatar{border-radius:50%;display:grid;place-items:center;font-weight:600;color:#fff;flex-shrink:0}.avatar-stack{display:flex}.avatar-stack .avatar{border:2px solid var(--surface);margin-left:-8px}.avatar-stack .avatar:first-child{margin-left:0}.pagination{display:flex;align-items:center;justify-content:space-between;padding:14px 4px 0}.pagination .pages{display:flex;gap:4px}.page-btn{min-width:32px;height:32px;padding:0 8px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);font-size:13px;font-weight:500;color:var(--text-secondary)}.page-btn:hover:not(:disabled){background:var(--gray-50)}.page-btn.active{background:var(--brand-600);color:#fff;border-color:var(--brand-600)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.code-editor{background:#0f172a;border-radius:var(--r-md);overflow:hidden;border:1px solid #1e293b}.code-editor-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:#131c31;border-bottom:1px solid #1e293b}.code-editor-bar .dots{display:flex;gap:6px;align-items:center}.code-editor-bar .dots i{width:11px;height:11px;border-radius:50%;display:inline-block}.code-editor textarea{width:100%;background:transparent;border:none;outline:none;color:#e2e8f0;font-family:var(--mono);font-size:12.5px;line-height:1.7;padding:14px;resize:vertical;min-height:220px}.code-view{color:#e2e8f0;font-family:var(--mono);font-size:12.5px;line-height:1.7;padding:14px;white-space:pre-wrap;word-break:break-word;margin:0;max-height:420px;overflow:auto}.tok-key{color:#7dd3fc}.tok-str{color:#86efac}.tok-num{color:#fca5a5}.tok-bool{color:#c4b5fd}.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:10px}.toast{display:flex;align-items:flex-start;gap:12px;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--brand-500);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:14px 16px;min-width:300px;max-width:400px;animation:toastIn .25s cubic-bezier(.16,1,.3,1)}@keyframes toastIn{0%{transform:translate(40px);opacity:0}to{transform:none;opacity:1}}.toast.success{border-left-color:var(--green-500)}.toast.error{border-left-color:var(--red-500)}.toast.warning{border-left-color:var(--amber-500)}.toast strong{font-size:13.5px;display:block}.toast p{font-size:12.5px;color:var(--text-muted);margin-top:2px}.meter{height:7px;background:var(--gray-100);border-radius:var(--r-full);overflow:hidden}.meter>span{display:block;height:100%;border-radius:var(--r-full)}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--gray-100);border-radius:var(--r-full);font-size:12px;font-weight:500;color:var(--text-secondary)}.chip button{border:none;background:none;color:var(--text-muted);display:grid;place-items:center;padding:0}.divider{height:1px;background:var(--border);border:none;margin:20px 0}.kv{display:flex;flex-direction:column;gap:3px}.kv .k{font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-weight:600}.kv .v{font-size:14px;font-weight:600;color:var(--text)}.kv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px 24px}.alert{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--r-md);font-size:13px;font-weight:500}.alert-error{background:var(--red-50);color:var(--red-600);border:1px solid #fecaca}.alert-info{background:var(--blue-50);color:var(--blue-600);border:1px solid #bfdbfe}.health-dot{width:9px;height:9px;border-radius:50%;display:inline-block;position:relative}.health-dot.healthy{background:var(--green-500);box-shadow:0 0 0 3px var(--green-50)}.health-dot.degraded{background:var(--amber-500);box-shadow:0 0 0 3px var(--amber-50)}.health-dot.down{background:var(--red-500);box-shadow:0 0 0 3px var(--red-50)}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1200px 600px at 20% -10%,rgba(99,102,241,.18),transparent 60%),radial-gradient(900px 500px at 110% 110%,rgba(6,182,212,.16),transparent 55%),#0b1120}.auth-card{width:100%;max-width:400px;background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);padding:32px}.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px}.auth-brand .sidebar-logo{width:44px;height:44px;border-radius:12px}.auth-brand strong{font-size:18px;display:block}.auth-brand span{font-size:12.5px;color:var(--text-muted)}.auth-title{font-size:20px;margin-bottom:4px}.auth-sub{color:var(--text-muted);font-size:13.5px;margin-bottom:24px}.auth-hint{margin-top:20px;padding-top:18px;border-top:1px solid var(--border);font-size:12px;color:var(--text-muted);line-height:1.7}.auth-hint code{font-family:var(--mono);background:var(--gray-100);padding:1px 5px;border-radius:4px;color:var(--text-secondary)}.cols-5{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px}.cols-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.cols-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.cols-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px}.cols-5>*,.cols-4>*,.cols-3>*,.cols-2>*,.dash-grid>*{min-width:0}.chart-empty{display:flex;align-items:center;justify-content:center;min-height:240px;color:var(--text-muted);font-size:13px;text-align:center}.recharts-default-legend{font-size:12.5px}.recharts-cartesian-axis-tick text{fill:var(--text-muted)}.recharts-wrapper:focus,.recharts-wrapper:focus-visible,.recharts-surface:focus,.recharts-surface:focus-visible,.recharts-wrapper svg *:focus,.recharts-wrapper svg *:focus-visible,.recharts-sector:focus,.recharts-layer:focus{outline:none}@media (max-width: 1200px){.dash-grid{grid-template-columns:1fr}.kv-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.app-main{margin-left:0}.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:none}.form-grid{grid-template-columns:1fr}.page{padding:16px}.topbar-search{display:none}}@media (max-width: 600px){.kv-grid{grid-template-columns:1fr}}.mobile-menu-btn{display:none}@media (max-width: 900px){.mobile-menu-btn{display:grid}}
