.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:12px;max-width:380px;pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:12px;padding:16px 20px;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-md);color:var(--text-primary);font-size:.9rem;line-height:1.4}.toast svg{flex-shrink:0;margin-top:1px}.toast span{flex:1}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;flex-shrink:0;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.toast-close:hover{background:var(--bg-card-hover);color:var(--text-primary)}.toast--success{border-left:4px solid var(--color-success)}.toast--success svg{color:var(--color-success)}.toast--error{border-left:4px solid var(--color-danger)}.toast--error svg{color:var(--color-danger)}.toast--info{border-left:4px solid var(--color-accent)}.toast--info svg{color:var(--color-accent)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:440px;box-shadow:var(--shadow-lg)}.modal-title{font-size:1.25rem;font-weight:600;margin-bottom:12px;color:var(--text-primary)}.modal-body{font-size:.95rem;color:var(--text-muted);margin-bottom:24px;line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:12px}.btn{padding:10px 18px;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;cursor:pointer;border:none;font-family:var(--font-sans);transition:all var(--transition-fast)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-secondary:hover{background:var(--bg-card-hover)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:var(--color-danger-hover)}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover{background:var(--color-accent-hover)}.table-responsive{width:100%;overflow-x:auto;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.process-table{width:100%;border-collapse:collapse;text-align:left}.process-table th,.process-table td{padding:16px 20px;vertical-align:middle}.process-table th{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-primary);background:var(--bg-elevated)}.process-table td{border-bottom:1px solid var(--border-subtle);font-size:.95rem}.process-table tr:last-child td{border-bottom:none}.process-table tr:hover td{background:var(--bg-card-hover)}.row-offline td{opacity:.7}.process-name{font-weight:600;color:var(--text-primary);margin-bottom:4px}.process-mode{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.font-mono{font-family:var(--font-mono);font-size:.9rem}.text-muted{color:var(--text-secondary)}.text-right{text-align:right}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-badge .status-dot{width:6px;height:6px;border-radius:50%}.status-online{background:var(--color-online-bg);color:var(--color-online);border:1px solid rgba(34,197,94,.2)}.status-online .status-dot{background:var(--color-online);box-shadow:0 0 6px var(--color-online)}.status-stopped{background:var(--color-stopped-bg);color:var(--color-stopped);border:1px solid rgba(100,116,139,.2)}.status-stopped .status-dot{background:var(--color-stopped)}.status-errored{background:var(--color-errored-bg);color:var(--color-errored);border:1px solid rgba(239,68,68,.2)}.status-errored .status-dot{background:var(--color-errored)}.action-buttons{display:flex;align-items:center;justify-content:flex-end;gap:8px}.btn-icon{background:transparent;border:1px solid var(--border-primary);color:var(--text-secondary);border-radius:var(--radius-md);width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--text-muted)}.btn-icon.text-danger:hover{color:var(--color-danger);border-color:#ef44444d;background:var(--color-errored-bg)}.btn-icon.text-success:hover{color:var(--color-online);border-color:#22c55e4d;background:var(--color-online-bg)}.log-viewer{border-radius:var(--radius-md);border:1px solid var(--border-primary);display:flex;flex-direction:column;overflow:hidden;margin-top:24px}.log-header{background:var(--bg-elevated);padding:12px 16px;border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between}.log-title{font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:8px;color:var(--text-primary)}.log-controls{display:flex;align-items:center;gap:16px}.tab-group{display:flex;background:var(--bg-input);border-radius:var(--radius-md);padding:2px;border:1px solid var(--border-primary)}.tab-btn{background:transparent;border:none;color:var(--text-muted);padding:4px 12px;font-size:.75rem;font-weight:600;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{background:var(--bg-elevated);color:var(--text-primary);box-shadow:var(--shadow-sm)}.action-group{display:flex;gap:8px}.btn-icon-small{background:transparent;border:1px solid transparent;color:var(--text-muted);width:26px;height:26px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.btn-icon-small:hover{background:var(--bg-card-hover);color:var(--text-primary)}.btn-icon-small.active{background:var(--bg-input);border-color:var(--border-primary)}.text-warning{color:var(--color-launching)}.text-accent{color:var(--color-accent)}.log-content-wrapper{background:#0f141e;height:300px;overflow-y:auto;position:relative}.log-content{padding:16px;margin:0;font-family:var(--font-mono);font-size:.8rem;line-height:1.5;color:#e2e8f0;white-space:pre-wrap;word-break:break-all}.log-line{min-height:1.5em}.log-out{color:#cbd5e1}.log-err{color:#fca5a5}.log-loading,.log-error,.log-empty{padding:40px;text-align:center;font-size:.9rem;color:var(--text-muted)}.panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;display:flex;justify-content:flex-end}.detail-panel{width:100%;max-width:500px;background:var(--bg-secondary);height:100%;box-shadow:-4px 0 24px #00000080;display:flex;flex-direction:column;border-left:1px solid var(--border-primary)}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.slide-in-right{animation:slideInRight var(--transition-base) cubic-bezier(.16,1,.3,1) forwards}.panel-header{padding:24px;border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between}.panel-title-group h3{font-size:1.25rem;font-weight:600;margin-bottom:4px}.panel-id{font-size:.85rem;color:var(--text-muted);font-family:var(--font-mono)}.btn-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.btn-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.panel-content{padding:24px;flex:1;overflow-y:auto}.detail-grid{display:flex;flex-direction:column;gap:24px}.detail-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:20px}.detail-card h4{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:16px;text-transform:uppercase;letter-spacing:.05em;padding-bottom:8px;border-bottom:1px solid var(--border-subtle)}.kv-list{display:flex;flex-direction:column;gap:12px}.kv{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.kv .k{color:var(--text-muted);font-size:.9rem;min-width:80px}.kv .v{color:var(--text-primary);font-size:.95rem;text-align:right;word-break:break-all}.text-sm{font-size:.8rem}.status-text-online{color:var(--color-online);font-weight:500}.status-text-stopped{color:var(--color-stopped);font-weight:500}.status-text-errored{color:var(--color-errored);font-weight:500}.panel-loading,.panel-error{text-align:center;padding:40px 0;color:var(--text-muted)}.dashboard{min-height:100vh;display:flex;flex-direction:column}.dashboard-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-content{display:flex;align-items:center;justify-content:space-between;padding:16px 0}.header-brand{display:flex;align-items:center;gap:12px}.brand-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-accent-bg);color:var(--color-accent);border-radius:var(--radius-md)}.header-brand h1{font-size:1.25rem;font-weight:600;letter-spacing:-.02em}.header-status{display:flex;align-items:center;gap:8px;padding:6px 14px;background:var(--color-online-bg);border-radius:var(--radius-full);border:1px solid rgba(34,197,94,.2)}.status-dot{width:8px;height:8px;border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}.status-dot--online{background:var(--color-online);box-shadow:0 0 6px var(--color-online)}.status-text{font-size:.8rem;font-weight:500;color:var(--color-online)}.dashboard-main{flex:1;padding-top:28px;padding-bottom:40px}.dashboard-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.toolbar-left{display:flex;align-items:center;gap:10px}.toolbar-title{font-size:1.35rem;font-weight:600;letter-spacing:-.01em}.toolbar-badge{font-size:.8rem;font-weight:600;padding:2px 10px;background:var(--bg-elevated);border-radius:var(--radius-full);color:var(--text-secondary)}.toolbar-right{display:flex;align-items:center;gap:12px}.search-box{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:var(--text-muted);pointer-events:none}.search-input{background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:8px 12px 8px 38px;font-size:.875rem;color:var(--text-primary);font-family:var(--font-sans);width:260px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-bg)}.process-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center}.empty-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border-radius:var(--radius-lg);color:var(--text-muted);margin-bottom:20px;border:1px solid var(--border-primary)}.process-empty h3{font-size:1.1rem;font-weight:600;margin-bottom:6px;color:var(--text-primary)}.process-empty p{font-size:.9rem;color:var(--text-muted);max-width:360px}@media(max-width:640px){.dashboard-toolbar{flex-direction:column;align-items:stretch}.search-input,.toolbar-right,.search-box{width:100%}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:radial-gradient(ellipse at 30% 20%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(139,92,246,.06) 0%,transparent 50%),var(--bg-primary)}.login-card{width:100%;max-width:400px;padding:48px 40px;border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-lg)}.login-brand{margin-bottom:36px}.login-icon{width:64px;height:64px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-accent),#8b5cf6);color:#fff;border-radius:var(--radius-lg);margin-bottom:20px;box-shadow:0 4px 16px #3b82f64d}.login-brand h1{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:6px}.login-brand p{font-size:.9rem;color:var(--text-muted)}.login-button{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 24px;background:linear-gradient(135deg,var(--color-accent),#2563eb);color:#fff;border:none;border-radius:var(--radius-md);font-size:.95rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:0 2px 8px #3b82f64d}.login-button:hover{transform:translateY(-1px);box-shadow:0 4px 16px #3b82f666}.login-button:active{transform:translateY(0)}.login-footer{margin-top:24px;font-size:.8rem;color:var(--text-muted)}:root{--bg-primary: #0a0e17;--bg-secondary: #111827;--bg-card: #1a2234;--bg-card-hover: #1f2a3f;--bg-elevated: #243049;--bg-input: #0d1321;--border-primary: #1e2d45;--border-subtle: #162032;--border-focus: #3b82f6;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--color-online: #22c55e;--color-online-bg: rgba(34, 197, 94, .12);--color-stopped: #64748b;--color-stopped-bg: rgba(100, 116, 139, .12);--color-errored: #ef4444;--color-errored-bg: rgba(239, 68, 68, .12);--color-launching: #f59e0b;--color-launching-bg: rgba(245, 158, 11, .12);--color-accent: #3b82f6;--color-accent-hover: #2563eb;--color-accent-bg: rgba(59, 130, 246, .12);--color-danger: #ef4444;--color-danger-hover: #dc2626;--color-success: #22c55e;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 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: 0 0 20px rgba(59, 130, 246, .15);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-primary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.container{max-width:1400px;margin:0 auto;padding:0 24px}.glass{background:#1a223499;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fade-in{animation:fadeIn var(--transition-base) ease forwards}.slide-in{animation:slideIn var(--transition-base) ease forwards}
