:root{--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-card: #1a2035;--bg-card-hover: #1e2640;--bg-input: #0d1424;--bg-glass: rgba(26, 32, 53, .85);--text-primary: #e8edf5;--text-secondary: #8892a8;--text-muted: #5a6478;--accent-blue: #3b82f6;--accent-blue-soft: rgba(59, 130, 246, .15);--accent-green: #10b981;--accent-green-soft: rgba(16, 185, 129, .15);--accent-amber: #f59e0b;--accent-amber-soft: rgba(245, 158, 11, .15);--accent-red: #ef4444;--accent-red-soft: rgba(239, 68, 68, .15);--accent-purple: #8b5cf6;--accent-purple-soft: rgba(139, 92, 246, .15);--accent-cyan: #06b6d4;--border-color: rgba(255, 255, 255, .06);--border-focus: rgba(59, 130, 246, .5);--gradient-blue: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);--gradient-green: linear-gradient(135deg, #10b981 0%, #06b6d4 100%);--gradient-danger: linear-gradient(135deg, #ef4444 0%, #f97316 100%);--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 32px rgba(0,0,0,.5);--shadow-glow-blue: 0 0 20px rgba(59, 130, 246, .25);--shadow-glow-green: 0 0 20px rgba(16, 185, 129, .25);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}body{background-image:radial-gradient(ellipse at 0% 0%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(ellipse at 100% 100%,rgba(139,92,246,.06) 0%,transparent 50%);min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.app-container{display:flex;min-height:100vh;gap:0}.sidebar{width:360px;min-width:360px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow-y:auto;padding:0}.sidebar-header{padding:24px 24px 0;margin-bottom:8px}.sidebar-header h1{font-size:18px;font-weight:700;background:var(--gradient-blue);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.3px}.sidebar-header .subtitle{font-size:12px;color:var(--text-muted);margin-top:4px;letter-spacing:.5px;text-transform:uppercase}.sidebar-content{padding:16px 24px;flex:1;display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px}.form-group input,.form-group select,.form-group textarea{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text-primary);font-size:14px;font-family:var(--font-sans);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-blue-soft)}.form-group textarea{resize:vertical;min-height:80px;font-family:var(--font-sans)}.form-group select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238892a8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.btn-group{display:flex;gap:10px;margin-top:4px}.btn{padding:12px 20px;border-radius:var(--radius-sm);border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-sans)}.btn-primary{background:var(--gradient-blue);color:#fff;flex:1;box-shadow:var(--shadow-glow-blue)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 30px #3b82f666}.btn-danger{background:var(--gradient-danger);color:#fff;min-width:100px}.btn-danger:hover:not(:disabled){transform:translateY(-1px)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.tabs{display:flex;border-bottom:1px solid var(--border-color);padding:0 24px;background:var(--bg-secondary)}.tab{padding:14px 20px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast);letter-spacing:.3px}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}.tab .badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;font-size:11px;font-weight:700;margin-left:8px}.tab .badge-blue{background:var(--accent-blue-soft);color:var(--accent-blue)}.tab .badge-green{background:var(--accent-green-soft);color:var(--accent-green)}.tab-content{flex:1;overflow-y:auto;padding:20px 24px}.pipeline{display:flex;align-items:center;gap:0;padding:20px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);overflow-x:auto}.pipeline-step{display:flex;align-items:center;gap:0;flex-shrink:0}.step-node{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;color:var(--text-muted);background:transparent;border:1px solid var(--border-color);transition:all var(--transition-normal);white-space:nowrap}.step-node .step-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;background:var(--bg-card);border:1px solid var(--border-color);transition:all var(--transition-normal)}.step-node.completed{color:var(--accent-green);border-color:#10b9814d;background:var(--accent-green-soft)}.step-node.completed .step-icon{background:var(--accent-green);border-color:var(--accent-green);color:#fff}.step-node.active{color:var(--accent-blue);border-color:#3b82f666;background:var(--accent-blue-soft);box-shadow:var(--shadow-glow-blue)}.step-node.active .step-icon{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff;animation:pulse-glow 2s ease-in-out infinite}.step-node.error{color:var(--accent-red);border-color:#ef44444d;background:var(--accent-red-soft)}.step-connector{width:24px;height:2px;background:var(--border-color);flex-shrink:0;transition:background var(--transition-normal)}.step-connector.completed{background:var(--accent-green)}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px #3b82f64d}50%{box-shadow:0 0 16px #3b82f699}}.log-terminal{background:#0c0f1a;border-radius:var(--radius-md);border:1px solid var(--border-color);font-family:var(--font-mono);font-size:12px;line-height:1.7;color:var(--text-secondary);padding:16px;min-height:400px;max-height:600px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}.log-line{padding:1px 0}.log-line.success{color:var(--accent-green)}.log-line.error{color:var(--accent-red)}.log-line.warning{color:var(--accent-amber)}.log-line.debug{color:var(--text-muted)}.results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.result-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px;transition:all var(--transition-normal)}.result-card:hover{background:var(--bg-card-hover);border-color:#3b82f633;transform:translateY(-2px);box-shadow:var(--shadow-md)}.result-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.result-card-header .test-id{font-size:13px;font-weight:700;color:var(--accent-blue);background:var(--accent-blue-soft);padding:3px 10px;border-radius:6px}.result-card-header .status-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:6px}.status-badge.success{background:var(--accent-green-soft);color:var(--accent-green)}.status-badge.error{background:var(--accent-red-soft);color:var(--accent-red)}.result-card .description{font-size:14px;color:var(--text-primary);margin-bottom:16px;font-weight:500}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.metric-item{background:var(--bg-input);border-radius:8px;padding:10px 12px}.metric-item .metric-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px}.metric-item .metric-value{font-size:18px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;margin-top:2px}.metric-item .metric-unit{font-size:11px;color:var(--text-muted);font-weight:400}.report-controls{display:flex;justify-content:flex-end;gap:10px;margin-bottom:16px}.btn-sm{padding:8px 16px;font-size:12px;border-radius:6px}.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.btn-outline:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:var(--accent-blue-soft)}.report-preview{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:32px;min-height:400px;font-size:14px;line-height:1.8}.report-preview h1{font-size:24px;margin:24px 0 12px;color:var(--text-primary)}.report-preview h2{font-size:20px;margin:20px 0 10px;color:var(--text-primary);border-bottom:1px solid var(--border-color);padding-bottom:6px}.report-preview h3{font-size:16px;margin:16px 0 8px;color:var(--text-primary)}.report-preview p{margin:8px 0;color:var(--text-secondary)}.report-preview strong{color:var(--text-primary)}.report-preview ul,.report-preview ol{padding-left:24px;color:var(--text-secondary)}.report-preview li{margin:4px 0}.report-preview table{width:100%;border-collapse:collapse;margin:16px 0;font-size:13px}.report-preview th{background:var(--bg-input);padding:10px 14px;text-align:left;font-weight:600;color:var(--text-primary);border:1px solid var(--border-color)}.report-preview td{padding:8px 14px;border:1px solid var(--border-color);color:var(--text-secondary)}.report-preview code{background:var(--bg-input);padding:2px 6px;border-radius:4px;font-family:var(--font-mono);font-size:12px;color:var(--accent-cyan)}.report-preview pre{background:var(--bg-input);border-radius:var(--radius-sm);padding:16px;overflow-x:auto;margin:12px 0}.report-preview pre code{padding:0;background:none}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-muted);text-align:center}.empty-state .icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state .title{font-size:16px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.empty-state .desc{font-size:13px;max-width:320px}.progress-bar-container{padding:0 24px;background:var(--bg-secondary)}.progress-bar-wrapper{height:3px;background:var(--border-color);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--gradient-blue);border-radius:2px;transition:width .5s ease}.status-indicator{display:flex;align-items:center;gap:8px;padding:12px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);font-size:13px;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted)}.status-dot.running{background:var(--accent-blue);animation:status-pulse 1.5s ease-in-out infinite}.status-dot.completed{background:var(--accent-green)}.status-dot.error{background:var(--accent-red)}@keyframes status-pulse{0%,to{opacity:1}50%{opacity:.4}}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.fade-enter-active,.fade-leave-active{transition:opacity var(--transition-normal)}.fade-enter-from,.fade-leave-to{opacity:0}@media(max-width:1024px){.app-container{flex-direction:column}.sidebar{width:100%;min-width:unset;max-height:400px}.results-grid{grid-template-columns:1fr}}
