@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap");:root{--bg-primary:#05060a;--bg-secondary:#0d0f17;--bg-card:rgba(13,15,23,.8);--bg-glass:hsla(0,0%,100%,.02);--bg-glass-hover:hsla(0,0%,100%,.05);--border-glass:hsla(0,0%,100%,.06);--border-glass-hover:hsla(0,0%,100%,.12);--text-primary:#fff;--text-secondary:#9499b3;--text-muted:#5d617a;--accent-blue:#3b82f6;--accent-blue-glow:rgba(59,130,246,.3);--accent-purple:#8b5cf6;--accent-purple-glow:rgba(139,92,246,.25);--accent-green:#10b981;--accent-green-glow:rgba(16,185,129,.2);--accent-red:#ef4444;--accent-red-glow:rgba(239,68,68,.2);--accent-amber:#f59e0b;--accent-amber-glow:rgba(245,158,11,.2);--accent-cyan:#06b6d4;--accent-cyan-glow:rgba(6,182,212,.2);--gradient-blue:linear-gradient(135deg,#1d4ed8,#3b82f6);--gradient-purple:linear-gradient(135deg,#7c3aed,#a855f7);--gradient-green:linear-gradient(135deg,#059669,#10b981);--gradient-red:linear-gradient(135deg,#dc2626,#ef4444);--gradient-dark:linear-gradient(180deg,#0d0f17,#05060a);--gradient-glass:linear-gradient(135deg,hsla(0,0%,100%,.05),hsla(0,0%,100%,0));--sidebar-width:280px;--radius-sm:10px;--radius-md:14px;--radius-lg:20px;--radius-xl:32px;--shadow-sm:0 2px 10px rgba(0,0,0,.4);--shadow-md:0 10px 30px rgba(0,0,0,.5);--shadow-lg:0 20px 60px rgba(0,0,0,.6);--shadow-glow-blue:0 0 40px rgba(59,130,246,.2);--shadow-glow-purple:0 0 40px rgba(139,92,246,.15);--shadow-glow-green:0 0 30px rgba(16,185,129,.2);--shadow-glow-red:0 0 30px rgba(239,68,68,.2);--transition-fast:200ms cubic-bezier(0.23,1,0.32,1);--transition-base:400ms cubic-bezier(0.23,1,0.32,1);--font-mono:"JetBrains Mono","Fira Code",monospace}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-family:Inter,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;-webkit-font-smoothing:antialiased}body{background:var(--bg-primary);background-image:radial-gradient(at 0 0,rgba(59,130,246,.06) 0,transparent 50%),radial-gradient(at 100% 0,rgba(139,92,246,.06) 0,transparent 50%),radial-gradient(at 50% 100%,rgba(6,182,212,.04) 0,transparent 50%);color:var(--text-primary);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background-image:linear-gradient(hsla(0,0%,100%,.012) 1px,transparent 0),linear-gradient(90deg,hsla(0,0%,100%,.012) 1px,transparent 0);background-size:60px 60px;pointer-events:none;z-index:0}.app-layout,.auth-container{display:flex;min-height:100vh}.auth-container{width:100%;background:var(--bg-primary);background-image:radial-gradient(circle at 20% 30%,rgba(59,130,246,.08) 0,transparent 40%),radial-gradient(circle at 80% 70%,rgba(139,92,246,.08) 0,transparent 40%);align-items:center;justify-content:center;padding:40px 20px;position:relative;z-index:10}.auth-card{width:100%;max-width:460px;padding:48px;background:rgba(13,15,23,.7);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(32px);backdrop-filter:blur(32px);box-shadow:0 40px 100px -20px rgba(0,0,0,.8),0 0 50px rgba(59,130,246,.1)}.main-content{flex:1 1;margin-left:var(--sidebar-width);padding:40px 60px;min-height:100vh;position:relative;z-index:1}.page-header{margin-bottom:40px}.page-header h1{font-size:32px;font-weight:800;letter-spacing:-1px}.page-header p{color:var(--text-secondary);font-size:15px;margin-top:8px}.glass-card{background:var(--bg-glass);background-image:var(--gradient-glass);border:1px solid var(--border-glass);border-radius:var(--radius-lg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);transition:all var(--transition-base)}.glass-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:var(--shadow-lg)}.glass-card-static{background:var(--bg-glass);background-image:var(--gradient-glass);border:1px solid var(--border-glass);border-radius:var(--radius-lg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:20px;gap:20px;margin-bottom:32px}.metric-card{padding:24px;position:relative;overflow:hidden}.metric-card .metric-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:16px}.metric-card .metric-value{font-size:32px;font-weight:800;letter-spacing:-1px;line-height:1}.metric-card .metric-label{font-size:13px;color:var(--text-secondary);margin-top:6px;font-weight:500}.metric-card:after{content:"";position:absolute;top:0;right:0;width:120px;height:120px;border-radius:50%;filter:blur(50px);opacity:.15;pointer-events:none}.metric-blue .metric-icon{background:var(--accent-blue-glow);color:var(--accent-blue)}.metric-blue .metric-value{color:var(--accent-blue)}.metric-blue:after{background:var(--accent-blue)}.metric-purple .metric-icon{background:var(--accent-purple-glow);color:var(--accent-purple)}.metric-purple .metric-value{color:var(--accent-purple)}.metric-purple:after{background:var(--accent-purple)}.metric-green .metric-icon{background:var(--accent-green-glow);color:var(--accent-green)}.metric-green .metric-value{color:var(--accent-green)}.metric-green:after{background:var(--accent-green)}.metric-red .metric-icon{background:var(--accent-red-glow);color:var(--accent-red)}.metric-red .metric-value{color:var(--accent-red)}.metric-red:after{background:var(--accent-red)}.metric-amber .metric-icon{background:var(--accent-amber-glow);color:var(--accent-amber)}.metric-amber .metric-value{color:var(--accent-amber)}.metric-amber:after{background:var(--accent-amber)}.metric-cyan .metric-icon{background:var(--accent-cyan-glow);color:var(--accent-cyan)}.metric-cyan .metric-value{color:var(--accent-cyan)}.metric-cyan:after{background:var(--accent-cyan)}.data-grid{display:grid;grid-gap:20px;gap:20px;margin-bottom:32px}.data-grid-2{grid-template-columns:repeat(2,1fr)}.data-grid-3{grid-template-columns:repeat(3,1fr)}.status-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:30px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid transparent}.status-badge:before{content:"";width:6px;height:6px;border-radius:50%}.status-running{background:var(--accent-blue-glow);color:var(--accent-blue);border-color:rgba(59,130,246,.2)}.status-running:before{background:var(--accent-blue);animation:pulse-dot 1.5s infinite}.status-completed{background:var(--accent-green-glow);color:var(--accent-green);border-color:rgba(16,185,129,.2)}.status-completed:before{background:var(--accent-green)}.status-failed{background:var(--accent-red-glow);color:var(--accent-red);border-color:rgba(239,68,68,.2)}.status-failed:before{background:var(--accent-red)}.status-pending{background:hsla(0,0%,100%,.03);color:var(--text-secondary);border-color:hsla(0,0%,100%,.05)}.status-pending:before{background:var(--text-secondary)}.status-idle{background:hsla(0,0%,100%,.03);color:var(--text-secondary);border-color:hsla(0,0%,100%,.05)}.status-idle:before{background:var(--text-secondary)}.status-waiting,.status-waiting_for_approval{background:var(--accent-amber-glow);color:var(--accent-amber);border-color:rgba(245,158,11,.2)}.status-waiting:before,.status-waiting_for_approval:before{background:var(--accent-amber);animation:pulse-dot 1.5s infinite}.status-error{background:var(--accent-red-glow);color:var(--accent-red);border-color:rgba(239,68,68,.2)}.status-error:before{background:var(--accent-red);animation:pulse-dot 2s infinite}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 24px;border-radius:var(--radius-sm);font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;border:1px solid transparent;transition:all var(--transition-base);text-decoration:none;white-space:nowrap;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,hsla(0,0%,100%,.1),transparent 50%);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:after{opacity:1}.btn:disabled{opacity:.4;cursor:not-allowed}.btn:disabled:after{display:none}.btn-primary{background:var(--gradient-blue);color:#fff;box-shadow:0 4px 15px rgba(59,130,246,.25)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px rgba(59,130,246,.4)}.btn-success{background:var(--gradient-green);color:#fff;box-shadow:0 4px 15px rgba(16,185,129,.25)}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px rgba(16,185,129,.4)}.btn-danger{background:var(--gradient-red);color:#fff;box-shadow:0 4px 15px rgba(239,68,68,.2)}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px rgba(239,68,68,.35)}.btn-ghost{background:var(--bg-glass);color:var(--text-primary);border:1px solid var(--border-glass)}.btn-ghost:hover:not(:disabled){background:var(--bg-glass-hover);border-color:var(--border-glass-hover);transform:translateY(-2px)}.btn-sm{padding:7px 14px;font-size:12px;border-radius:8px;gap:6px}.btn-xs{padding:4px 10px;font-size:11px;border-radius:6px;gap:4px}.form-group{margin-bottom:24px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:10px;letter-spacing:.5px;text-transform:uppercase}.form-control,.form-input,.form-textarea{width:100%;padding:14px 18px;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-sm);color:var(--text-primary);font-family:inherit;font-size:15px;transition:all var(--transition-base);outline:none}.form-control:focus,.form-input:focus,.form-textarea:focus{background:hsla(0,0%,100%,.05);border-color:var(--accent-blue);box-shadow:0 0 0 4px rgba(59,130,246,.15)}.form-textarea{resize:vertical;min-height:100px}.form-select{width:100%;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-sm);color:var(--text-primary);font-family:inherit;font-size:15px;transition:all var(--transition-base);outline:none;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='16' height='16' fill='%238b8fa3' viewBox='0 0 16 16'%3e%3cpath d='M8 11L3 6h10l-5 5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 14px center;padding:14px 40px 14px 18px}.form-select:focus{background-color:hsla(0,0%,100%,.05);border-color:var(--accent-blue);box-shadow:0 0 0 4px rgba(59,130,246,.15)}.form-select option{background:var(--bg-secondary);color:var(--text-primary);padding:8px}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:hsla(0,0%,100%,.08);border-radius:3px;outline:none;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--gradient-blue);border:2px solid hsla(0,0%,100%,.3);box-shadow:0 0 10px rgba(59,130,246,.4);cursor:pointer;-webkit-transition:all var(--transition-fast);transition:all var(--transition-fast)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 18px rgba(59,130,246,.6)}input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--gradient-blue);border:2px solid hsla(0,0%,100%,.3);box-shadow:0 0 10px rgba(59,130,246,.4);cursor:pointer}input[type=number]{-moz-appearance:textfield}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.progress-bar{width:100%;height:6px;background:hsla(0,0%,100%,.05);border-radius:3px;overflow:hidden}.progress-bar .progress-fill{height:100%;border-radius:3px;transition:width var(--transition-base);background:var(--gradient-blue)}.progress-bar .progress-fill.progress-complete{background:var(--gradient-green)}.progress-bar .progress-fill.progress-error{background:var(--gradient-red)}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:12px 16px;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border-glass)}.data-table td{padding:14px 16px;font-size:14px;border-bottom:1px solid hsla(0,0%,100%,.03);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-glass-hover)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border-glass);border-radius:var(--radius-xl);padding:32px;width:90%;max-width:560px;max-height:85vh;overflow-y:auto;animation:slideUp .3s ease}.modal h2{font-size:20px;font-weight:700;margin-bottom:24px;background:linear-gradient(135deg,var(--text-primary),var(--accent-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:28px}.section-card{padding:24px;margin-bottom:24px}.section-card .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.section-card .section-title{font-size:16px;font-weight:700;color:var(--text-primary)}.empty-state{text-align:center;padding:60px 20px}.empty-state .empty-icon{font-size:48px;margin-bottom:16px;opacity:.6}.empty-state h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.empty-state p{color:var(--text-secondary);font-size:14px;margin-bottom:20px}.log-viewer{background:rgba(0,0,0,.3);border-radius:var(--radius-sm);padding:16px;max-height:300px;overflow-y:auto;font-family:JetBrains Mono,Fira Code,monospace;font-size:12px;line-height:1.8}.log-entry{display:flex;gap:12px}.log-time{color:var(--text-muted);white-space:nowrap}.log-level{width:44px;text-align:center;font-weight:700;text-transform:uppercase;font-size:10px}.log-level.info{color:var(--accent-blue)}.log-level.warn{color:var(--accent-amber)}.log-level.error{color:var(--accent-red)}.log-level.debug{color:var(--text-muted)}.log-message{color:var(--text-secondary);word-break:break-word}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-in{animation:slideUp .4s ease forwards}.page-transition{transition:opacity .2s ease,transform .2s ease,filter .2s ease;will-change:opacity,transform,filter}.page-transition-enter{animation:pageEnter .35s cubic-bezier(.22,1,.36,1) forwards}.page-transition-exit{animation:pageExit .2s cubic-bezier(.22,1,.36,1) forwards}@keyframes pageEnter{0%{opacity:0;transform:translateY(16px) scale(.99);filter:blur(4px)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}@keyframes pageExit{0%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}to{opacity:0;transform:translateY(-10px) scale(.995);filter:blur(3px)}}.stagger-in>*{opacity:0;animation:slideUp .45s ease forwards}.stagger-in>:first-child{animation-delay:0ms}.stagger-in>:nth-child(2){animation-delay:50ms}.stagger-in>:nth-child(3){animation-delay:.1s}.stagger-in>:nth-child(4){animation-delay:.15s}.stagger-in>:nth-child(5){animation-delay:.2s}.stagger-in>:nth-child(6){animation-delay:.25s}.stagger-in>:nth-child(7){animation-delay:.3s}.stagger-in>:nth-child(8){animation-delay:.35s}.nav-item-active:active,.nav-item:active{transform:scale(.97);transition-duration:80ms}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.1);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,100%,.2)}.toast-container{position:fixed;top:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:14px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;animation:slideInLeft .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid;min-width:280px;max-width:400px}.toast-success{background:rgba(52,211,153,.1);border-color:rgba(52,211,153,.3);color:var(--accent-green)}.toast-error{background:hsla(0,91%,71%,.1);border-color:hsla(0,91%,71%,.3);color:var(--accent-red)}.toast-info{background:rgba(79,124,255,.1);border-color:rgba(79,124,255,.3);color:var(--accent-blue)}@media (max-width:1200px){.data-grid-2{grid-template-columns:1fr}.data-grid-3{grid-template-columns:1fr 1fr}}@media (max-width:768px){.main-content{margin-left:0;padding:20px}.metrics-grid{grid-template-columns:1fr 1fr}.data-grid-3{grid-template-columns:1fr}}.ws-indicator{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:500;padding:6px 12px;border-radius:20px}.ws-connected{background:var(--accent-green-glow);color:var(--accent-green)}.ws-disconnected{background:var(--accent-red-glow);color:var(--accent-red)}.nav-item,.nav-item-active{display:flex;align-items:center;gap:14px;padding:12px 18px;border-radius:var(--radius-sm);text-decoration:none;font-size:14px;transition:all var(--transition-base);position:relative;overflow:hidden}.nav-item{color:var(--text-secondary);background:transparent;border:1px solid transparent}.nav-item:hover{color:var(--text-primary);background:hsla(0,0%,100%,.04);border-color:hsla(0,0%,100%,.06);transform:translateX(4px)}.nav-item:hover .nav-icon{transform:scale(1.1)}.nav-item-active{color:var(--text-primary);font-weight:700;background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.2)}.nav-item-active:before{content:"";position:absolute;left:0;top:25%;bottom:25%;width:3px;background:var(--accent-blue);border-radius:0 2px 2px 0;box-shadow:0 0 12px var(--accent-blue)}.nav-icon{width:20px;height:20px;flex-shrink:0;transition:transform var(--transition-fast);display:flex;align-items:center;justify-content:center}.hover-glass:hover{background:hsla(0,0%,100%,.06)!important;border-color:hsla(0,0%,100%,.1)!important}.loading-spinner{width:40px;height:40px;border:3px solid hsla(0,0%,100%,.08);border-top:3px solid var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner-sm{width:18px;height:18px;border:2px solid hsla(0,0%,100%,.15);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.glass-card{position:relative}.glass-card:hover{background:var(--bg-glass-hover);border-color:var(--border-glass-hover);transform:translateY(-4px) scale(1.005);box-shadow:var(--shadow-lg),0 0 60px rgba(59,130,246,.06)}.glass-card:before{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.03),transparent);transition:left .6s ease;pointer-events:none;z-index:1}.glass-card:hover:before{left:100%}.pulse{animation:breathe 2s ease-in-out infinite}@keyframes breathe{0%,to{opacity:.5}50%{opacity:1}}