:root{--bg-0: #050508;--bg-1: #0a0a12;--bg-2: #0f0f1a;--bg-3: #141422;--bg-4: #1a1a2e;--bg-glass: rgba(15, 15, 26, .75);--bg-glass-light: rgba(255, 255, 255, .03);--surface-0: #0a0a12;--surface-1: #0f0f1a;--surface-2: #141422;--surface-3: #1a1a2e;--surface-raised: #1e1e32;--border: rgba(255, 255, 255, .07);--border-hover: rgba(255, 255, 255, .14);--border-accent: rgba(99, 102, 241, .4);--border-strong: rgba(255, 255, 255, .18);--text-primary: #f0f0ff;--text-secondary: #8b8bb0;--text-muted: #4a4a6a;--text-inverse: #050508;--text-disabled: #2a2a45;--accent: #6366f1;--accent-2: #818cf8;--accent-hover: #7577fa;--accent-dim: rgba(99, 102, 241, .12);--accent-glow: rgba(99, 102, 241, .25);--accent-border: rgba(99, 102, 241, .35);--success: #34d399;--success-dim: rgba(52, 211, 153, .12);--success-border: rgba(52, 211, 153, .3);--warning: #fbbf24;--warning-dim: rgba(251, 191, 36, .12);--warning-border: rgba(251, 191, 36, .3);--danger: #f87171;--danger-dim: rgba(248, 113, 113, .12);--danger-border: rgba(248, 113, 113, .3);--info: #38bdf8;--info-dim: rgba(56, 189, 248, .12);--info-border: rgba(56, 189, 248, .3);--purple: #c084fc;--purple-dim: rgba(192, 132, 252, .12);--purple-border: rgba(192, 132, 252, .3);--orange: #fb923c;--orange-dim: rgba(251, 146, 60, .12);--grad-accent: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--grad-accent-h: linear-gradient(135deg, #7577fa 0%, #9f7aea 100%);--grad-subtle: linear-gradient(180deg, rgba(99,102,241,.08) 0%, transparent 100%);--grad-sidebar: linear-gradient(180deg, #0d0d1a 0%, #080810 100%);--grad-card: linear-gradient(145deg, rgba(255,255,255,.03) 0%, rgba(255,255,255,0) 100%);--grad-success: linear-gradient(135deg, #34d399, #059669);--grad-warning: linear-gradient(135deg, #fbbf24, #d97706);--grad-danger: linear-gradient(135deg, #f87171, #dc2626);--grad-info: linear-gradient(135deg, #38bdf8, #0284c7);--grad-purple: linear-gradient(135deg, #c084fc, #9333ea);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: 11px;--text-sm: 12px;--text-base: 14px;--text-md: 15px;--text-lg: 17px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--radius: 12px;--radius-sm: 8px;--radius-xs: 5px;--radius-lg: 16px;--radius-xl: 20px;--radius-pill: 999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.5), 0 1px 2px rgba(0,0,0,.4);--shadow: 0 4px 20px rgba(0,0,0,.6), 0 2px 8px rgba(0,0,0,.4);--shadow-lg: 0 12px 40px rgba(0,0,0,.7), 0 4px 16px rgba(0,0,0,.5);--shadow-accent: 0 0 0 1px var(--accent-border), 0 4px 24px var(--accent-glow);--shadow-card: 0 1px 3px rgba(0,0,0,.4), 0 4px 16px rgba(0,0,0,.3);--shadow-card-hover: 0 4px 24px rgba(0,0,0,.6), 0 1px 4px rgba(0,0,0,.5);--blur: blur(16px);--blur-sm: blur(8px);--transition: .18s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-spring: .25s cubic-bezier(.34, 1.56, .64, 1)}[data-theme=light]{--bg-0: #f8fafc;--bg-1: #ffffff;--bg-2: #f1f5f9;--bg-3: #e2e8f0;--bg-4: #cbd5e1;--bg-glass: rgba(255, 255, 255, .85);--bg-glass-light: rgba(0, 0, 0, .03);--surface-0: #ffffff;--surface-1: #f8fafc;--surface-2: #f1f5f9;--surface-3: #e2e8f0;--surface-raised: #ffffff;--border: rgba(0, 0, 0, .08);--border-hover: rgba(0, 0, 0, .15);--border-accent: rgba(99, 102, 241, .4);--border-strong: rgba(0, 0, 0, .22);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--text-inverse: #ffffff;--text-disabled: #94a3b8;--accent: #4f46e5;--accent-2: #6366f1;--accent-hover: #4338ca;--accent-dim: rgba(79, 70, 229, .12);--accent-glow: rgba(79, 70, 229, .25);--accent-border: rgba(79, 70, 229, .35);--success: #10b981;--success-dim: rgba(16, 185, 129, .15);--success-border: rgba(16, 185, 129, .3);--warning: #f59e0b;--warning-dim: rgba(245, 158, 11, .15);--warning-border: rgba(245, 158, 11, .3);--danger: #ef4444;--danger-dim: rgba(239, 68, 68, .12);--danger-border: rgba(239, 68, 68, .3);--info: #0ea5e9;--info-dim: rgba(14, 165, 233, .12);--info-border: rgba(14, 165, 233, .3);--purple: #a855f7;--purple-dim: rgba(168, 85, 247, .12);--purple-border: rgba(168, 85, 247, .3);--orange: #f97316;--orange-dim: rgba(249, 115, 22, .12);--grad-sidebar: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background:var(--bg-0);color:var(--text-primary);font-family:var(--font);font-size:var(--text-base);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideRight{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 #34d39966}50%{opacity:.8;box-shadow:0 0 0 5px #34d39900}}@keyframes glowPulse{0%,to{box-shadow:0 0 8px var(--accent-glow)}50%{box-shadow:0 0 20px var(--accent-glow),0 0 40px #6366f11a}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes countUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes borderGlow{0%,to{border-color:var(--accent-border)}50%{border-color:var(--accent)}}.app{display:flex;height:100vh;overflow:hidden;background:var(--bg-0)}.sidebar{width:232px;min-width:232px;background:var(--grad-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;position:relative;z-index:10}.sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.5}.sidebar-logo{padding:18px 16px 14px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(99,102,241,.06) 0%,transparent 100%)}.sidebar-logo-mark{display:flex;align-items:center;gap:10px;margin-bottom:2px}.sidebar-logo-icon{width:32px;height:32px;border-radius:9px;background:var(--grad-accent);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;box-shadow:0 0 16px #6366f166;animation:glowPulse 3s ease-in-out infinite}.sidebar-logo h1{font-size:15px;font-weight:800;color:var(--text-primary);letter-spacing:-.3px;line-height:1}.sidebar-logo-subtitle{font-size:10px;color:var(--text-muted);margin-left:42px;letter-spacing:.5px;text-transform:uppercase}.sidebar-status{display:flex;align-items:center;gap:7px;padding:8px 16px;font-size:11px;color:var(--text-secondary);border-bottom:1px solid var(--border)}.sidebar-user-badge{margin:8px 10px;padding:8px 10px;background:#ffffff08;border-radius:var(--radius-sm);border:1px solid var(--border);display:flex;align-items:center;gap:8px;transition:background var(--transition),border-color var(--transition)}.sidebar-user-badge:hover{background:#ffffff0d;border-color:var(--border-hover)}.sidebar-user-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 0 0 2px #ffffff1a}.sidebar-user-avatar.admin{background:linear-gradient(135deg,#f59e0b,#d97706)}.sidebar-user-avatar.vibe_coder{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.sidebar-user-avatar.client{background:linear-gradient(135deg,#06b6d4,#0284c7)}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:11px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{font-size:10px;line-height:1.3}.sidebar-user-role.admin{color:#f59e0b}.sidebar-user-role.vibe_coder{color:#818cf8}.sidebar-user-role.client{color:#22d3ee}.sidebar-logout-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:14px;padding:3px 4px;border-radius:4px;line-height:1;transition:color var(--transition),background var(--transition)}.sidebar-logout-btn:hover{color:var(--danger);background:var(--danger-dim)}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0}.nav-group-label{font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:10px 16px 4px;display:flex;align-items:center;gap:6px}.nav-group-label:after{content:"";flex:1;height:1px;background:var(--border);margin-left:4px}.nav-item{display:flex;align-items:center;gap:8px;padding:7px 14px;margin:1px 6px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all var(--transition);position:relative;-webkit-user-select:none;user-select:none;border:1px solid transparent}.nav-item:hover{background:#ffffff0d;color:var(--text-primary);transform:translate(1px);border-color:var(--border)}.nav-item.active{background:var(--accent-dim);color:var(--accent-2);font-weight:600;border-color:var(--accent-border);box-shadow:inset 2px 0 0 var(--accent)}.nav-icon{font-size:14px;width:18px;text-align:center;flex-shrink:0;transition:transform var(--transition-spring)}.nav-item:hover .nav-icon{transform:scale(1.15)}.nav-item.active .nav-icon{transform:scale(1.1)}.sidebar-footer{padding:10px 14px;border-top:1px solid var(--border);font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:8px}.sidebar-footer-icon{width:24px;height:24px;border-radius:6px;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-size:12px}.sidebar-footer-label{color:var(--text-secondary);font-weight:600;font-size:12px}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--success);flex-shrink:0;animation:pulse 2.4s ease-in-out infinite}.status-dot.offline{background:var(--danger);animation:none}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-1)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;min-height:52px;background:var(--bg-glass);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-bottom:1px solid var(--border);position:relative;z-index:5;flex-shrink:0}.topbar:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.3) 30%,rgba(99,102,241,.3) 70%,transparent);pointer-events:none}.topbar-left{display:flex;align-items:center;gap:10px}.topbar-screen-icon{font-size:16px;opacity:.7}.topbar h2{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.2px}.topbar-right{display:flex;align-items:center;gap:8px}.topbar-action{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-glass-light);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;color:var(--text-secondary);transition:all var(--transition);position:relative}.topbar-action:hover{background:var(--accent-dim);border-color:var(--accent-border);color:var(--accent-2);transform:translateY(-1px)}.page{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:4px;animation:slideUp .25s ease both}.page-header-left{display:flex;align-items:center;gap:12px}.page-header-icon{width:40px;height:40px;border-radius:11px;background:var(--grad-accent);display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 4px 16px var(--accent-glow);flex-shrink:0}.page-header-title{font-size:20px;font-weight:800;color:var(--text-primary);letter-spacing:-.4px;line-height:1.2}.page-header-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.page-header-actions{display:flex;gap:8px;align-items:center}.card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition);position:relative;overflow:hidden;flex-shrink:0}.card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--grad-card);pointer-events:none;border-radius:inherit}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-card-hover)}.card-hover:hover{transform:translateY(-2px);border-color:var(--border-accent);box-shadow:var(--shadow-card-hover),0 0 0 1px #6366f11a}.card-glass{background:var(--bg-glass);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid rgba(255,255,255,.08)}.card-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:12px;display:flex;align-items:center;gap:6px}.card-title:before{content:"";display:inline-block;width:3px;height:12px;background:var(--grad-accent);border-radius:2px;flex-shrink:0}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:16px;position:relative;overflow:hidden;transition:all var(--transition);animation:countUp .4s ease both}.stat-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--grad-accent);transform:scaleX(0);transform-origin:left;transition:transform var(--transition-slow)}.stat-card:hover{border-color:var(--border-accent);transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}.stat-card:hover:after{transform:scaleX(1)}.stat-card .label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:8px;display:flex;align-items:center;gap:6px}.stat-card .stat-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;background:var(--accent-dim)}.stat-card .value{font-size:26px;font-weight:800;color:var(--text-primary);letter-spacing:-.8px;line-height:1;margin-bottom:4px;animation:countUp .5s ease both}.stat-card .sub{font-size:11px;color:var(--text-muted)}.stat-card .trend{font-size:10px;font-weight:600;display:inline-flex;align-items:center;gap:2px;margin-top:4px}.stat-card .trend.up{color:var(--success)}.stat-card .trend.down{color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);border:1px solid transparent;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--transition);white-space:nowrap;position:relative;overflow:hidden;-webkit-user-select:none;user-select:none}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.08) 0%,transparent 100%);pointer-events:none;border-radius:inherit;opacity:0;transition:opacity var(--transition)}.btn:hover:after{opacity:1}.btn:active{transform:scale(.97)}.btn-primary{background:var(--grad-accent);color:#fff;box-shadow:0 2px 12px var(--accent-glow)}.btn-primary:hover{background:var(--grad-accent-h);box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:var(--surface-2);color:var(--text-secondary);border-color:var(--border)}.btn-secondary:hover{background:var(--surface-3);color:var(--text-primary);border-color:var(--border-hover)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:var(--border)}.btn-ghost:hover{background:var(--bg-glass-light);color:var(--text-primary);border-color:var(--border-hover)}.btn-danger{background:var(--danger-dim);color:var(--danger);border-color:var(--danger-border)}.btn-danger:hover{background:#f8717133;box-shadow:0 0 12px var(--danger-dim)}.btn-success{background:var(--success-dim);color:var(--success);border-color:var(--success-border)}.btn-success:hover{background:#34d39933}.btn-sm{padding:5px 10px;font-size:12px;border-radius:var(--radius-xs)}.btn-xs{padding:3px 8px;font-size:11px;border-radius:var(--radius-xs)}.btn-lg{padding:10px 20px;font-size:14px}.btn-icon{padding:7px;width:32px;height:32px}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-pill);font-size:11px;font-weight:600;letter-spacing:.02em;border:1px solid transparent;line-height:1.6}.badge-accent{background:var(--accent-dim);color:var(--accent-2);border-color:var(--accent-border)}.badge-success{background:var(--success-dim);color:var(--success);border-color:var(--success-border)}.badge-warning{background:var(--warning-dim);color:var(--warning);border-color:var(--warning-border)}.badge-danger{background:var(--danger-dim);color:var(--danger);border-color:var(--danger-border)}.badge-info{background:var(--info-dim);color:var(--info);border-color:var(--info-border)}.badge-purple{background:var(--purple-dim);color:var(--purple);border-color:var(--purple-border)}.badge-muted{background:#ffffff0d;color:var(--text-muted);border-color:var(--border)}.badge-orange{background:var(--orange-dim);color:var(--orange);border-color:#fb923c4d}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-pill);font-size:11px;font-weight:600;border:1px solid transparent}.status-badge:before{content:"";width:5px;height:5px;border-radius:50%;flex-shrink:0;background:currentColor}.status-badge.queued{background:#94a3b81f;color:#94a3b8;border-color:#94a3b840}.status-badge.in_progress,.status-badge.running{background:var(--info-dim);color:var(--info);border-color:var(--info-border)}.status-badge.ci_failed,.status-badge.failed{background:var(--danger-dim);color:var(--danger);border-color:var(--danger-border)}.status-badge.qc_review{background:var(--warning-dim);color:var(--warning);border-color:var(--warning-border)}.status-badge.waiting_for_user{background:var(--purple-dim);color:var(--purple);border-color:var(--purple-border)}.status-badge.approved{background:var(--success-dim);color:var(--success);border-color:var(--success-border)}.status-badge.completed{background:var(--accent-dim);color:var(--accent-2);border-color:var(--accent-border)}.status-badge.deployed{background:var(--success-dim);color:var(--success);border-color:var(--success-border)}.status-badge.scoping{background:var(--info-dim);color:var(--info);border-color:var(--info-border)}.status-badge.active{background:var(--success-dim);color:var(--success);border-color:var(--success-border)}.status-badge.on_hold{background:var(--warning-dim);color:var(--warning);border-color:var(--warning-border)}.status-badge.cancelled{background:var(--danger-dim);color:var(--danger);border-color:var(--danger-border)}.status-badge.pending{background:#94a3b81f;color:#94a3b8;border-color:#94a3b840}.status-badge.submitted{background:var(--info-dim);color:var(--info);border-color:var(--info-border)}.status-badge.paid{background:var(--success-dim);color:var(--success);border-color:var(--success-border)}.status-badge.open{background:var(--accent-dim);color:var(--accent-2);border-color:var(--accent-border)}.status-badge.resolved{background:var(--success-dim);color:var(--success);border-color:var(--success-border)}.status-badge.minor{background:var(--warning-dim);color:var(--warning);border-color:var(--warning-border)}.status-badge.major{background:var(--danger-dim);color:var(--danger);border-color:var(--danger-border)}.status-badge.security{background:#dc262626;color:#fca5a5;border-color:#dc262659}.tag{display:inline-flex;align-items:center;padding:2px 7px;background:var(--bg-glass-light);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:11px;color:var(--text-secondary);font-family:var(--font-mono);transition:all var(--transition)}.tag:hover{border-color:var(--border-hover);color:var(--text-primary)}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:12px;font-weight:600;color:var(--text-secondary);letter-spacing:.01em}.form-hint{font-size:11px;color:var(--text-muted);margin-top:3px}input,textarea,select,.form-input,.form-select,.form-textarea{width:100%;padding:8px 11px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-family:var(--font);outline:none;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);-webkit-appearance:none}input:focus,textarea:focus,select:focus,.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);background:var(--surface-3)}input::placeholder,textarea::placeholder{color:var(--text-muted)}select option{background:var(--surface-3);color:var(--text-primary)}textarea{resize:vertical;min-height:80px;line-height:1.6}.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-1)}table{width:100%;border-collapse:collapse;font-size:13px}th{padding:9px 14px;text-align:left;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap}td{padding:10px 14px;color:var(--text-secondary);border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff05;color:var(--text-primary)}.live-feed{display:flex;flex-direction:column;gap:2px;overflow-y:auto;max-height:420px;padding-right:2px}.feed-event{display:flex;gap:10px;padding:7px 10px;border-radius:var(--radius-sm);border-left:2px solid transparent;transition:all var(--transition);animation:slideIn .22s ease both}.feed-event:hover{background:#ffffff08;border-left-color:var(--accent)}.feed-event .meta{font-size:10px;color:var(--text-muted);white-space:nowrap;margin-top:1px;font-family:var(--font-mono)}.event-type{padding:2px 7px;border-radius:var(--radius-pill);font-size:10px;font-weight:700;white-space:nowrap;flex-shrink:0}.event-type.message_received{background:var(--accent-dim);color:var(--accent-2)}.event-type.rag_complete{background:var(--info-dim);color:var(--info)}.event-type.tool_call{background:var(--warning-dim);color:var(--warning)}.event-type.agent_response{background:var(--success-dim);color:var(--success)}.event-type.llm_start{background:var(--purple-dim);color:var(--purple)}.feed-content{font-size:12px;color:var(--text-secondary);line-height:1.5;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.health-overall{display:flex;align-items:center;gap:20px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px}.health-circle{width:80px;height:80px;border-radius:50%;background:conic-gradient(var(--accent) calc(var(--pct,0) * 1%),var(--bg-3) 0);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.health-circle-inner{width:60px;height:60px;border-radius:50%;background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800}.health-desc{flex:1}.health-desc h3{font-size:19px;font-weight:700;margin-bottom:4px;letter-spacing:-.5px}.health-desc p{color:var(--text-secondary);font-size:13px}.category-list{display:flex;flex-direction:column;gap:8px}.category-row{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition)}.category-row:hover{border-color:var(--border-hover)}.cat-label{font-size:12.5px;font-weight:500}.cat-bar{height:5px;background:var(--bg-0);border-radius:99px;overflow:hidden;flex:1}.cat-bar-fill{height:100%;border-radius:99px;transition:width .7s cubic-bezier(.4,0,.2,1)}.cat-pct{font-size:12px;font-weight:600;color:var(--text-secondary);width:36px;text-align:right}.cat-status{font-size:10px;font-weight:600;padding:2px 7px;border-radius:var(--radius-pill)}.cat-status.excellent{background:var(--success-dim);color:var(--success)}.cat-status.good{background:var(--info-dim);color:var(--info)}.cat-status.weak{background:var(--warning-dim);color:var(--warning)}.cat-status.missing{background:var(--danger-dim);color:var(--danger)}.metric-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.metric{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px}.metric .m-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.metric .m-value{font-size:20px;font-weight:700;color:var(--text-primary)}.metric .m-sub{font-size:11px;color:var(--text-muted)}.chat-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding:16px}.chat-bubble{max-width:82%;padding:10px 14px;border-radius:14px;font-size:13.5px;line-height:1.6;animation:slideUp .2s ease both;position:relative}.chat-bubble.user{background:var(--grad-accent);color:#fff;align-self:flex-end;border-bottom-right-radius:4px;box-shadow:0 2px 12px var(--accent-glow)}.chat-bubble.agent{background:var(--surface-2);border:1px solid var(--border);color:var(--text-primary);align-self:flex-start;border-bottom-left-radius:4px}.chat-bubble .source{font-size:10px;color:var(--text-muted);margin-top:4px}.chat-markdown p{margin-bottom:8px}.chat-markdown pre{background:var(--bg-0);border-radius:8px;padding:12px;overflow-x:auto;margin:8px 0;border:1px solid var(--border)}.chat-markdown code{font-family:var(--font-mono);font-size:12px}.chat-markdown :not(pre)>code{background:var(--bg-0);padding:2px 5px;border-radius:4px;font-size:12px}.chat-markdown ul,.chat-markdown ol{padding-left:18px;margin-bottom:8px}.chat-markdown li{margin-bottom:3px}.chat-markdown h1,.chat-markdown h2,.chat-markdown h3,.chat-markdown h4{font-weight:700;margin:12px 0 6px;color:var(--text-primary)}.chat-markdown h1{font-size:18px}.chat-markdown h2{font-size:16px}.chat-markdown h3{font-size:14px}.chat-markdown a{color:var(--accent-2);text-decoration:none}.chat-markdown a:hover{text-decoration:underline}.chat-markdown blockquote{border-left:3px solid var(--accent);padding-left:12px;color:var(--text-secondary);margin:8px 0}.chat-markdown table{width:100%;border-collapse:collapse;margin:8px 0}.chat-markdown th{background:var(--surface-3);padding:6px 10px;text-align:left;font-size:12px}.chat-markdown td{padding:6px 10px;border-top:1px solid var(--border)}.chat-input-row{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);background:var(--bg-glass);-webkit-backdrop-filter:var(--blur-sm);backdrop-filter:var(--blur-sm)}.chat-input{flex:1;min-height:40px;max-height:140px;padding:9px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:13px;font-family:var(--font);resize:none;outline:none;transition:border-color var(--transition),box-shadow var(--transition);line-height:1.5}.chat-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;-webkit-backdrop-filter:var(--blur-sm);backdrop-filter:var(--blur-sm);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .18s ease both}.modal-content{background:var(--surface-1);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg),0 0 0 1px #6366f11a;animation:slideUp .22s ease both}.modal-content h2{font-size:17px;font-weight:800;color:var(--text-primary);letter-spacing:-.3px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px;padding:4px;border-radius:6px;transition:color var(--transition),background var(--transition);line-height:1}.modal-close:hover{color:var(--danger);background:var(--danger-dim)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;animation:fadeIn .3s ease both}.empty-state .icon{width:64px;height:64px;border-radius:18px;background:var(--accent-dim);border:1px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:16px}.empty-state h3{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:6px}.empty-state p{font-size:13px;color:var(--text-muted);max-width:320px;line-height:1.6;margin-bottom:20px}.upload-zone{border:2px dashed var(--border-hover);border-radius:var(--radius);padding:32px;text-align:center;cursor:pointer;transition:all var(--transition);background:var(--bg-glass-light)}.upload-zone:hover{border-color:var(--accent);background:var(--accent-dim)}.pill-tabs{display:flex;gap:4px;background:var(--surface-2);border-radius:var(--radius-sm);padding:3px;border:1px solid var(--border)}.pill-tab{flex:1;padding:6px 12px;border-radius:var(--radius-xs);font-size:12px;font-weight:600;cursor:pointer;text-align:center;color:var(--text-secondary);transition:all var(--transition);border:none;background:none;font-family:var(--font)}.pill-tab.active{background:var(--accent-dim);color:var(--accent-2);border:1px solid var(--accent-border)}.pill-tab:hover:not(.active){background:#ffffff0a;color:var(--text-primary)}.progress-bar-track{height:5px;background:var(--surface-3);border-radius:99px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:99px;background:var(--grad-accent);transition:width .6s ease}.code-block{background:var(--bg-0);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);overflow-x:auto;line-height:1.6}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.section-header h3{font-size:13px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:6px}.divider{height:1px;background:var(--border);margin:12px 0}.info-banner{padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;border:1px solid;display:flex;gap:8px;align-items:flex-start;line-height:1.5}.info-banner.success{background:var(--success-dim);color:#6ee7b7;border-color:var(--success-border)}.info-banner.warning{background:var(--warning-dim);color:#fde68a;border-color:var(--warning-border)}.info-banner.danger{background:var(--danger-dim);color:#fca5a5;border-color:var(--danger-border)}.info-banner.info{background:var(--info-dim);color:#7dd3fc;border-color:var(--info-border)}.info-banner.accent{background:var(--accent-dim);color:var(--accent-2);border-color:var(--accent-border)}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}.glow-accent{box-shadow:var(--shadow-accent)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-col{display:flex;flex-direction:column}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.text-accent{color:var(--accent-2)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-info{color:var(--info)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-mono{font-family:var(--font-mono)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-md{font-size:var(--text-md)}.text-lg{font-size:var(--text-lg)}.text-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--surface-raised);color:var(--text-primary);font-size:11px;white-space:nowrap;padding:4px 8px;border-radius:5px;pointer-events:none;opacity:0;transition:opacity var(--transition);z-index:9999}[data-tooltip]:hover:after{opacity:1}@media (max-width: 900px){.sidebar{width:64px;min-width:64px}.sidebar-logo h1,.sidebar-logo-subtitle,.nav-item span,.sidebar-user-info,.sidebar-footer-label{display:none}.nav-item{justify-content:center;padding:9px}.stats-row{grid-template-columns:repeat(2,1fr)}}.sidebar.collapsed{width:64px;min-width:64px}.sidebar.collapsed .sidebar-logo h1,.sidebar.collapsed .sidebar-logo-subtitle,.sidebar.collapsed .nav-item span,.sidebar.collapsed .sidebar-user-info,.sidebar.collapsed .sidebar-footer-label{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:9px}@media (max-width: 600px){.stats-row,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page{padding:12px}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
