@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--color-bg-base:#0a0a0f;--color-bg-surface:#111118;--color-bg-elevated:#1a1a24;--color-bg-hover:#22222e;--color-bg-active:#2a2a38;--color-accent-primary:#7c3aed;--color-accent-primary-hover:#6d28d9;--color-accent-secondary:#06b6d4;--color-accent-success:#10b981;--color-accent-warning:#f59e0b;--color-accent-danger:#ef4444;--color-accent-info:#3b82f6;--color-text-primary:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-muted:#475569;--color-text-disabled:#334155;--color-border-subtle:#1e1e2e;--color-border-default:#2a2a3e;--color-border-strong:#3a3a52;--status-running:#10b981;--status-paused:#f59e0b;--status-stopped:#475569;--status-error:#ef4444;--status-starting:#3b82f6;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--font-size-xs:11px;--font-size-sm:12px;--font-size-base:14px;--font-size-md:15px;--font-size-lg:16px;--font-size-xl:18px;--font-size-2xl:22px;--font-size-3xl:28px;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 32px #0009;--shadow-glow-purple:0 0 20px #7c3aed4d;--shadow-glow-cyan:0 0 20px #06b6d44d;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--sidebar-width:240px;--topbar-height:60px}*,:before,:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;tab-size:4}body{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-bg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0;line-height:1.6}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.3}p{margin:0}a{color:var(--color-accent-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-accent-primary-hover)}img,svg{max-width:100%;display:block}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none;padding:0}ul,ol{margin:0;padding:0;list-style:none}table{border-collapse:collapse;border-spacing:0}::selection{color:var(--color-text-primary);background-color:#7c3aed4d}::-webkit-scrollbar{width:0;height:0;display:none}html{scrollbar-width:none}h1{font-size:var(--font-size-3xl);letter-spacing:-.02em;font-weight:700}h2{font-size:var(--font-size-2xl);letter-spacing:-.01em;font-weight:600}h3{font-size:var(--font-size-xl);font-weight:600}h4{font-size:var(--font-size-lg);font-weight:600}h5{font-size:var(--font-size-md);font-weight:500}h6{font-size:var(--font-size-base);font-weight:500}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-accent{color:var(--color-accent-primary)}.text-success{color:var(--color-accent-success)}.text-danger{color:var(--color-accent-danger)}.text-warning{color:var(--color-accent-warning)}.font-mono{font-family:var(--font-mono)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}@keyframes btn-spinner{to{transform:rotate(360deg)}}.btn{justify-content:center;align-items:center;gap:var(--space-2);font-family:var(--font-sans);font-size:var(--font-size-base);white-space:nowrap;border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);cursor:pointer;-webkit-user-select:none;user-select:none;height:36px;transition:background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);border:1px solid #0000;outline:none;font-weight:500;line-height:1;text-decoration:none;display:inline-flex;position:relative}.btn:focus-visible{box-shadow:0 0 0 3px #7c3aed4d}.btn-primary{background-color:var(--color-accent-primary);color:#fff;border-color:var(--color-accent-primary)}a.btn-primary,a.btn-primary:hover,a.btn-primary:active,a.btn-danger,a.btn-danger:hover,a.btn-danger:active{color:#fff;text-decoration:none}.btn-primary:hover{background-color:var(--color-accent-primary-hover);border-color:var(--color-accent-primary-hover);color:#fff;box-shadow:var(--shadow-glow-purple)}.btn-primary:active{box-shadow:none;background-color:#5b21b6;border-color:#5b21b6;transform:scale(.97)}.btn-secondary{color:var(--color-text-primary);border-color:var(--color-border-strong);background-color:#0000}.btn-secondary:hover{background-color:var(--color-bg-hover);border-color:var(--color-accent-primary);color:var(--color-accent-primary)}.btn-secondary:active{background-color:var(--color-bg-active);transform:scale(.97)}.btn-danger{background-color:var(--color-accent-danger);color:#fff;border-color:var(--color-accent-danger)}.btn-danger:hover{background-color:#dc2626;border-color:#dc2626;box-shadow:0 0 20px #ef44444d}.btn-danger:active{box-shadow:none;background-color:#b91c1c;border-color:#b91c1c;transform:scale(.97)}.btn-ghost{color:var(--color-text-secondary);background-color:#0000;border-color:#0000}.btn-ghost:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.btn-ghost:active{background-color:var(--color-bg-active);transform:scale(.97)}.btn-sm{font-size:var(--font-size-sm);padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);height:28px}.btn-lg{font-size:var(--font-size-lg);padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);height:44px}.btn:disabled,.btn[disabled],.btn.is-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn.is-loading{color:#0000;pointer-events:none;position:relative}.btn.is-loading:after{content:"";border-radius:var(--radius-full);border:2px solid #ffffff40;border-top-color:#fff;width:16px;height:16px;margin-top:-8px;margin-left:-8px;animation:.6s linear infinite btn-spinner;position:absolute;top:50%;left:50%}.btn-secondary.is-loading:after,.btn-ghost.is-loading:after{border-color:#94a3b840;border-top-color:var(--color-text-secondary)}.btn-sm.is-loading:after{width:12px;height:12px;margin-top:-6px;margin-left:-6px}.btn-lg.is-loading:after{width:20px;height:20px;margin-top:-10px;margin-left:-10px}.btn-icon{width:36px;padding:0}.btn-icon.btn-sm{width:28px}.btn-icon.btn-lg{width:44px}.btn-group{display:inline-flex}.btn-group .btn{border-radius:0}.btn-group .btn:first-child{border-radius:var(--radius-md) 0 0 var(--radius-md)}.btn-group .btn:last-child{border-radius:0 var(--radius-md) var(--radius-md) 0}.btn-group .btn+.btn{margin-left:-1px}.form-group{gap:var(--space-2);margin-bottom:var(--space-5);flex-direction:column;display:flex}.form-group:last-child{margin-bottom:0}.form-label{font-family:var(--font-sans);font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500;line-height:1}.form-label .required{color:var(--color-accent-danger);margin-left:var(--space-1)}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.4}.form-input,.form-textarea,.form-select{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);width:100%;height:38px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-input:hover,.form-textarea:hover,.form-select:hover{border-color:var(--color-border-strong)}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--color-accent-primary);background-color:var(--color-bg-elevated);box-shadow:0 0 0 3px #7c3aed4d}.form-textarea{resize:vertical;height:auto;min-height:80px;line-height:1.5}.form-select{appearance:none;cursor:pointer;padding-right:var(--space-10);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' viewBox='0 0 12 12'%3E%3Cpath d='M3 4.5l3 3 3-3' stroke='%2394a3b8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center}.form-input:disabled,.form-textarea:disabled,.form-select:disabled{opacity:.4;cursor:not-allowed;background-color:var(--color-bg-base)}.form-group.has-error .form-input,.form-group.has-error .form-textarea,.form-group.has-error .form-select,.form-input.is-error,.form-textarea.is-error,.form-select.is-error{border-color:var(--color-accent-danger)}.form-group.has-error .form-input:focus,.form-group.has-error .form-textarea:focus,.form-group.has-error .form-select:focus,.form-input.is-error:focus,.form-textarea.is-error:focus,.form-select.is-error:focus{box-shadow:0 0 0 3px #ef444440}.form-error{align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);color:var(--color-accent-danger);line-height:1;display:flex}.form-error:before{content:"";background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' viewBox='0 0 12 12'%3E%3Ccircle cx='6' cy='6' r='5' stroke='%23ef4444' stroke-width='1.2'/%3E%3Cpath d='M6 3.5v3M6 8h.005' stroke='%23ef4444' stroke-width='1.2' stroke-linecap='round'/%3E%3C/svg%3E");flex-shrink:0;width:12px;height:12px;display:inline-block}.form-input.is-success,.form-textarea.is-success,.form-select.is-success{border-color:var(--color-accent-success)}.form-input.is-success:focus,.form-textarea.is-success:focus,.form-select.is-success:focus{box-shadow:0 0 0 3px #10b98140}.form-input-wrapper{align-items:center;display:flex;position:relative}.form-input-wrapper .form-input{width:100%}.form-input-icon{left:var(--space-3);color:var(--color-text-muted);pointer-events:none;align-items:center;display:flex;position:absolute}.form-input-wrapper .form-input-icon+.form-input{padding-left:var(--space-10)}.form-toggle{align-items:center;gap:var(--space-3);cursor:pointer;-webkit-user-select:none;user-select:none;display:inline-flex}.form-toggle input{opacity:0;width:0;height:0;position:absolute}.form-toggle-track{background-color:var(--color-bg-active);border:1px solid var(--color-border-default);border-radius:var(--radius-full);width:40px;height:22px;transition:background-color var(--transition-fast), border-color var(--transition-fast);flex-shrink:0;position:relative}.form-toggle-track:after{content:"";background-color:var(--color-text-secondary);border-radius:var(--radius-full);width:16px;height:16px;transition:transform var(--transition-fast), background-color var(--transition-fast);position:absolute;top:2px;left:2px}.form-toggle input:checked+.form-toggle-track{background-color:var(--color-accent-primary);border-color:var(--color-accent-primary)}.form-toggle input:checked+.form-toggle-track:after{background-color:#fff;transform:translate(18px)}.form-toggle input:focus-visible+.form-toggle-track{box-shadow:0 0 0 3px #7c3aed4d}.form-toggle input:disabled+.form-toggle-track{opacity:.4;cursor:not-allowed}.form-toggle-label{font-size:var(--font-size-base);color:var(--color-text-primary)}.form-checkbox{align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;user-select:none;display:inline-flex}.form-checkbox input{opacity:0;width:0;height:0;position:absolute}.form-checkbox-box{background-color:var(--color-bg-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);width:18px;height:18px;transition:background-color var(--transition-fast), border-color var(--transition-fast);flex-shrink:0;position:relative}.form-checkbox-box:after{content:"";opacity:0;width:5px;height:9px;transition:opacity var(--transition-fast);border:2px solid #fff;border-width:0 2px 2px 0;position:absolute;top:3px;left:6px;transform:rotate(45deg)}.form-checkbox input:checked+.form-checkbox-box{background-color:var(--color-accent-primary);border-color:var(--color-accent-primary)}.form-checkbox input:checked+.form-checkbox-box:after{opacity:1}.form-checkbox input:focus-visible+.form-checkbox-box{box-shadow:0 0 0 3px #7c3aed4d}.form-checkbox input:disabled+.form-checkbox-box{opacity:.4;cursor:not-allowed}.form-checkbox-label{font-size:var(--font-size-base);color:var(--color-text-primary)}.password-strength{gap:var(--space-1);flex-direction:column;display:flex}.password-strength-bar{background-color:var(--color-bg-active);border-radius:var(--radius-full);height:4px;overflow:hidden}.password-strength-fill{border-radius:var(--radius-full);height:100%;transition:width var(--transition-base), background-color var(--transition-base);width:0%}.password-strength[data-strength=weak] .password-strength-fill{background-color:var(--color-accent-danger);width:25%}.password-strength[data-strength=fair] .password-strength-fill{background-color:var(--color-accent-warning);width:50%}.password-strength[data-strength=good] .password-strength-fill{background-color:var(--color-accent-info);width:75%}.password-strength[data-strength=strong] .password-strength-fill{background-color:var(--color-accent-success);width:100%}.password-strength-text{font-size:var(--font-size-xs);color:var(--color-text-muted)}.password-strength[data-strength=weak] .password-strength-text{color:var(--color-accent-danger)}.password-strength[data-strength=fair] .password-strength-text{color:var(--color-accent-warning)}.password-strength[data-strength=good] .password-strength-text{color:var(--color-accent-info)}.password-strength[data-strength=strong] .password-strength-text{color:var(--color-accent-success)}.form-row{gap:var(--space-4);display:flex}.form-row .form-group{flex:1}.card{background-color:var(--color-bg-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);overflow:hidden}.card:hover{border-color:var(--color-border-default)}.card-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;display:flex}.card-header-title{font-family:var(--font-sans);font-size:var(--font-size-lg);color:var(--color-text-primary);font-weight:600;line-height:1.2}.card-header-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.card-header-actions{align-items:center;gap:var(--space-2);display:flex}.card-body{padding:var(--space-5)}.card-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);border-top:1px solid var(--color-border-subtle);background-color:var(--color-bg-base);display:flex}.card-compact .card-header{padding:var(--space-3) var(--space-4)}.card-compact .card-body{padding:var(--space-4)}.card-compact .card-footer{padding:var(--space-2) var(--space-4)}.card-flat{box-shadow:none}.card-interactive{cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-strong)}.stat-card{background-color:var(--color-bg-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-5);gap:var(--space-3);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);flex-direction:column;display:flex}.stat-card:hover{border-color:var(--color-border-default);box-shadow:var(--shadow-sm)}.stat-card-header{justify-content:space-between;align-items:center;display:flex}.stat-card-icon{border-radius:var(--radius-md);background-color:var(--color-bg-elevated);width:40px;height:40px;color:var(--color-accent-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.stat-card-change{align-items:center;gap:var(--space-1);font-family:var(--font-mono);font-size:var(--font-size-xs);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-weight:500;line-height:1;display:inline-flex}.stat-card-change.is-positive{color:var(--color-accent-success);background-color:#10b9811a}.stat-card-change.is-positive:before{content:"↑"}.stat-card-change.is-negative{color:var(--color-accent-danger);background-color:#ef44441a}.stat-card-change.is-negative:before{content:"↓"}.stat-card-change.is-neutral{color:var(--color-text-muted);background-color:var(--color-bg-elevated)}.stat-card-value{font-family:var(--font-mono);font-size:var(--font-size-3xl);color:var(--color-text-primary);font-weight:700;line-height:1}.stat-card-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1}.stat-cards-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}@keyframes modal-slide-in{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes modal-slide-out{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(20px)scale(.98)}}@keyframes modal-overlay-in{0%{opacity:0}to{opacity:1}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:var(--space-6);opacity:0;visibility:hidden;transition:opacity var(--transition-base), visibility var(--transition-base);background-color:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.active{opacity:1;visibility:visible;animation:modal-overlay-in var(--transition-base) ease forwards}.modal{background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);opacity:0;width:100%;max-width:520px;max-height:85vh;transition:opacity var(--transition-base), transform var(--transition-base);flex-direction:column;display:flex;transform:translateY(20px)scale(.98)}.modal-overlay.active .modal{opacity:1;transform:translateY(0)scale(1)}.modal-sm{max-width:380px}.modal-lg{max-width:720px}.modal-xl{max-width:960px}.modal-full{max-width:calc(100vw - var(--space-12));max-height:calc(100vh - var(--space-12))}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.modal-title{font-family:var(--font-sans);font-size:var(--font-size-xl);color:var(--color-text-primary);font-weight:600;line-height:1.2}.modal-close{width:32px;height:32px;color:var(--color-text-muted);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background-color:#0000;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.modal-close:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.modal-close:before{content:"✕";font-size:var(--font-size-lg);line-height:1}.modal-body{padding:var(--space-6);color:var(--color-text-secondary);font-size:var(--font-size-base);flex:1;line-height:1.6;overflow-y:auto}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-subtle);background-color:var(--color-bg-base);border-radius:0 0 var(--radius-xl) var(--radius-xl);flex-shrink:0;display:flex}.modal-footer-left{justify-content:space-between}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:0 0}.modal-body::-webkit-scrollbar-thumb{background-color:var(--color-border-default);border-radius:var(--radius-full)}.modal-body::-webkit-scrollbar-thumb:hover{background-color:var(--color-border-strong)}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes badge-blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes badge-spinner{to{transform:rotate(360deg)}}.badge{align-items:center;gap:var(--space-1);font-family:var(--font-sans);font-size:var(--font-size-xs);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);white-space:nowrap;vertical-align:middle;color:var(--color-text-secondary);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-default);font-weight:600;line-height:1;display:inline-flex}.badge-success{color:var(--color-accent-success);background-color:#10b9811a;border-color:#10b98140}.badge-warning{color:var(--color-accent-warning);background-color:#f59e0b1a;border-color:#f59e0b40}.badge-danger{color:var(--color-accent-danger);background-color:#ef44441a;border-color:#ef444440}.badge-info{color:var(--color-accent-info);background-color:#3b82f61a;border-color:#3b82f640}.badge-muted{color:var(--color-text-muted);background-color:var(--color-bg-active);border-color:var(--color-border-subtle)}.badge-dot:before{content:"";border-radius:var(--radius-full);background-color:currentColor;flex-shrink:0;width:6px;height:6px;display:inline-block}.badge-running{color:var(--status-running);background-color:#10b9811a;border-color:#10b98140}.badge-running:before{content:"";border-radius:var(--radius-full);background-color:var(--status-running);flex-shrink:0;width:6px;height:6px;animation:1.5s ease-in-out infinite badge-pulse;display:inline-block}.badge-paused{color:var(--status-paused);background-color:#f59e0b1a;border-color:#f59e0b40}.badge-paused:before{content:"";border-radius:var(--radius-full);background-color:var(--status-paused);flex-shrink:0;width:6px;height:6px;display:inline-block}.badge-stopped{color:var(--status-stopped);background-color:var(--color-bg-active);border-color:var(--color-border-default)}.badge-stopped:before{content:"";border-radius:var(--radius-full);background-color:var(--status-stopped);flex-shrink:0;width:6px;height:6px;display:inline-block}.badge-error{color:var(--status-error);background-color:#ef44441a;border-color:#ef444440;animation:1s ease-in-out infinite badge-blink}.badge-error:before{content:"";border-radius:var(--radius-full);background-color:var(--status-error);flex-shrink:0;width:6px;height:6px;display:inline-block}.badge-starting{color:var(--status-starting);background-color:#3b82f61a;border-color:#3b82f640}.badge-starting:before{content:"";border:2px solid #3b82f640;border-top-color:var(--status-starting);border-radius:var(--radius-full);flex-shrink:0;width:10px;height:10px;animation:.7s linear infinite badge-spinner;display:inline-block}.badge-lg{font-size:var(--font-size-sm);padding:var(--space-1) var(--space-3)}.badge-lg:before{width:8px;height:8px}.table-responsive{-webkit-overflow-scrolling:touch;border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);width:100%;overflow-x:auto}.table-responsive::-webkit-scrollbar{height:6px}.table-responsive::-webkit-scrollbar-track{background:var(--color-bg-base)}.table-responsive::-webkit-scrollbar-thumb{background-color:var(--color-border-default);border-radius:var(--radius-full)}.table{border-collapse:collapse;width:100%;font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text-secondary)}.table thead{z-index:1;position:sticky;top:0}.table thead th{background-color:var(--color-bg-elevated);color:var(--color-text-muted);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;text-align:left;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-default);white-space:nowrap;-webkit-user-select:none;user-select:none;font-weight:600}.table thead th.sortable{cursor:pointer;transition:color var(--transition-fast)}.table thead th.sortable:hover{color:var(--color-text-primary)}.table thead th.sortable:after{content:"";width:0;height:0;margin-left:var(--space-2);vertical-align:middle;border-left:4px solid #0000;border-right:4px solid #0000;border-top:4px solid var(--color-text-muted);opacity:.3;display:inline-block}.table thead th.sort-asc:after{border-top:none;border-bottom:4px solid var(--color-accent-primary);opacity:1}.table thead th.sort-desc:after{border-top:4px solid var(--color-accent-primary);opacity:1}.table tbody td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-subtle);background-color:var(--color-bg-surface);vertical-align:middle;transition:background-color var(--transition-fast)}.table-striped tbody tr:nth-child(2n) td{background-color:var(--color-bg-base)}.table tbody tr:hover td{background-color:var(--color-bg-hover)}.table tbody tr.is-selected td{background-color:#7c3aed14;border-bottom-color:#7c3aed26}.table tbody tr:last-child td{border-bottom:none}.table .cell-mono{font-family:var(--font-mono);font-size:var(--font-size-sm)}.table .cell-primary{color:var(--color-text-primary);font-weight:500}.table .cell-right{text-align:right}.table .cell-center{text-align:center}.table .cell-nowrap{white-space:nowrap}.table-compact thead th,.table-compact tbody td{padding:var(--space-2) var(--space-3)}.table-compact{font-size:var(--font-size-sm)}.table-empty{padding:var(--space-16) var(--space-6);text-align:center;color:var(--color-text-muted)}.table-empty-icon{font-size:var(--font-size-3xl);margin-bottom:var(--space-3);opacity:.4}.table-empty-text{font-size:var(--font-size-base)}.table-pagination{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border-subtle);background-color:var(--color-bg-base);font-size:var(--font-size-sm);color:var(--color-text-muted);justify-content:space-between;align-items:center;display:flex}.table-pagination-info{align-items:center;gap:var(--space-2);display:flex}.table-pagination-pages{align-items:center;gap:var(--space-1);display:flex}.table-pagination-btn{min-width:32px;height:32px;padding:0 var(--space-2);font-family:var(--font-sans);font-size:var(--font-size-sm);color:var(--color-text-secondary);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);background-color:#0000;justify-content:center;align-items:center;display:flex}.table-pagination-btn:hover{background-color:var(--color-bg-hover);border-color:var(--color-border-default);color:var(--color-text-primary)}.table-pagination-btn.active{background-color:var(--color-accent-primary);border-color:var(--color-accent-primary);color:#fff}.table-pagination-btn:disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.table-pagination-ellipsis{width:32px;height:32px;color:var(--color-text-muted);font-size:var(--font-size-sm);justify-content:center;align-items:center;display:flex}.table-pagination-per-page{align-items:center;gap:var(--space-2);display:flex}.table-pagination-per-page select{font-family:var(--font-sans);font-size:var(--font-size-sm);color:var(--color-text-secondary);background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);cursor:pointer;outline:none}.sidebar{width:var(--sidebar-width);background-color:var(--color-bg-surface);border-right:1px solid var(--color-border-subtle);z-index:100;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-logo{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);height:var(--topbar-height);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0;display:flex}.sidebar-logo-icon{background-color:var(--color-accent-primary);border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.sidebar-logo-text{font-family:var(--font-sans);font-size:var(--font-size-lg);color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-weight:700;line-height:1;overflow:hidden}.sidebar-logo-version{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:400}.sidebar-nav{padding:var(--space-3) 0;flex:1;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background-color:var(--color-border-subtle);border-radius:var(--radius-full)}.sidebar-section{padding:var(--space-4) var(--space-5) var(--space-2);font-family:var(--font-sans);font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;line-height:1}.sidebar-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-5);margin:var(--space-1) var(--space-2);font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);width:calc(100% - var(--space-4));background:0 0;border:none;min-height:36px;text-decoration:none;display:flex;position:relative}.sidebar-item:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.sidebar-item.active{color:var(--color-accent-primary);background-color:#7c3aed14}.sidebar-item.active:before{content:"";left:-var(--space-2);left:0;top:var(--space-1);bottom:var(--space-1);background-color:var(--color-accent-primary);border-radius:0 var(--radius-full) var(--radius-full) 0;width:3px;position:absolute}.sidebar-item-icon{opacity:.7;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.sidebar-item.active .sidebar-item-icon{opacity:1}.sidebar-item-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.sidebar-item-badge{font-family:var(--font-mono);font-size:var(--font-size-xs);padding:1px var(--space-2);border-radius:var(--radius-full);background-color:var(--color-bg-active);color:var(--color-text-muted);flex-shrink:0;font-weight:600;line-height:1.4}.sidebar-item.active .sidebar-item-badge{color:var(--color-accent-primary);background-color:#7c3aed33}.sidebar-divider{background-color:var(--color-border-subtle);height:1px;margin:var(--space-2) var(--space-5)}.sidebar-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border-subtle);gap:var(--space-3);flex-direction:column;flex-shrink:0;display:flex}.sidebar-ws-status{align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);color:var(--color-text-muted);display:flex}.sidebar-ws-dot{border-radius:var(--radius-full);background-color:var(--status-stopped);width:8px;height:8px;transition:background-color var(--transition-base);flex-shrink:0}.sidebar-ws-dot.connected{background-color:var(--status-running);box-shadow:0 0 6px #10b98180}.sidebar-ws-dot.connecting{background-color:var(--status-paused);animation:1s ease-in-out infinite sidebar-ws-pulse}.sidebar-ws-dot.disconnected{background-color:var(--status-error);animation:1.5s ease-in-out infinite sidebar-ws-pulse}.sidebar-ws-dot.error{background-color:var(--status-error)}@keyframes sidebar-ws-pulse{0%,to{opacity:1}50%{opacity:.3}}.sidebar-bot-count{font-size:var(--font-size-xs);color:var(--color-text-muted);justify-content:space-between;align-items:center;display:flex}.sidebar-bot-count-value{font-family:var(--font-mono);color:var(--color-text-secondary);font-weight:600}.sidebar.collapsed{width:64px}.sidebar.collapsed .sidebar-logo-text,.sidebar.collapsed .sidebar-logo-version,.sidebar.collapsed .sidebar-item-label,.sidebar.collapsed .sidebar-item-badge,.sidebar.collapsed .sidebar-section,.sidebar.collapsed .sidebar-ws-status span,.sidebar.collapsed .sidebar-bot-count span{display:none}.sidebar.collapsed .sidebar-item{padding:var(--space-2);margin:var(--space-1) var(--space-2);width:calc(100% - var(--space-4));justify-content:center}.sidebar.collapsed .sidebar-logo{padding:var(--space-4);justify-content:center}.topbar{top:0;left:var(--sidebar-width);height:var(--topbar-height);background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border-subtle);padding:0 var(--space-6);z-index:90;justify-content:space-between;align-items:center;gap:var(--space-4);display:flex;position:fixed;right:0}.topbar-left{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.topbar-breadcrumb{align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-muted);display:flex}.topbar-breadcrumb a{color:var(--color-text-secondary);transition:color var(--transition-fast);text-decoration:none}.topbar-breadcrumb a:hover{color:var(--color-text-primary)}.topbar-breadcrumb-separator{color:var(--color-text-muted);opacity:.5}.topbar-breadcrumb-current{color:var(--color-text-primary);font-weight:500}.topbar-search{flex:1;max-width:480px;margin:0 auto;position:relative}.topbar-search-input{width:100%;height:36px;font-family:var(--font-sans);font-size:var(--font-size-sm);color:var(--color-text-primary);background-color:var(--color-bg-base);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);padding:0 var(--space-4) 0 var(--space-10);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);outline:none}.topbar-search-input::placeholder{color:var(--color-text-muted)}.topbar-search-input:hover{border-color:var(--color-border-default)}.topbar-search-input:focus{border-color:var(--color-accent-primary);background-color:var(--color-bg-surface);box-shadow:0 0 0 3px #7c3aed26}.topbar-search-icon{left:var(--space-4);color:var(--color-text-muted);pointer-events:none;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.topbar-search-shortcut{right:var(--space-3);font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--color-text-muted);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-default);border-radius:var(--radius-sm);padding:1px var(--space-2);pointer-events:none;line-height:1.4;position:absolute;top:50%;transform:translateY(-50%)}.topbar-right{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.topbar-notification{border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:relative}.topbar-notification:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.topbar-notification-badge{min-width:16px;height:16px;font-family:var(--font-mono);color:#fff;background-color:var(--color-accent-danger);border-radius:var(--radius-full);border:2px solid var(--color-bg-surface);justify-content:center;align-items:center;padding:0 4px;font-size:9px;font-weight:700;line-height:1;display:flex;position:absolute;top:4px;right:4px}.topbar-notification-badge:empty{display:none}.topbar-divider{background-color:var(--color-border-subtle);width:1px;height:24px;margin:0 var(--space-1)}.topbar-wallet{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--color-bg-elevated);border:1px solid var(--color-border-default);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);display:flex}.topbar-wallet svg{color:var(--color-accent-primary);flex-shrink:0}.topbar-wallet-amount{font-family:var(--font-mono);color:var(--color-text-primary);white-space:nowrap;font-weight:600}.topbar-user{position:relative}.topbar-user-trigger{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast);background:0 0;border:none;display:flex}.topbar-user-trigger:hover{background-color:var(--color-bg-hover)}.topbar-user-avatar{border-radius:var(--radius-full);background-color:var(--color-accent-primary);color:#fff;width:32px;height:32px;font-family:var(--font-sans);font-size:var(--font-size-sm);flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:flex;overflow:hidden}.topbar-user-avatar img{object-fit:cover;width:100%;height:100%}.topbar-user-name{font-family:var(--font-sans);font-size:var(--font-size-sm);color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-weight:500;overflow:hidden}.topbar-user-chevron{color:var(--color-text-muted);transition:transform var(--transition-fast)}.topbar-user.open .topbar-user-chevron{transform:rotate(180deg)}.topbar-user-dropdown{top:calc(100% + var(--space-2));background-color:var(--color-bg-elevated);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);min-width:200px;box-shadow:var(--shadow-lg);padding:var(--space-2) 0;opacity:0;visibility:hidden;transition:opacity var(--transition-fast), transform var(--transition-fast), visibility var(--transition-fast);z-index:200;position:absolute;right:0;transform:translateY(-4px)}.topbar-user.open .topbar-user-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.topbar-user-dropdown-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-family:var(--font-sans);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;width:100%;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;text-decoration:none;display:flex}.topbar-user-dropdown-item:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.topbar-user-dropdown-item.danger{color:var(--color-accent-danger)}.topbar-user-dropdown-item.danger:hover{background-color:#ef444414}.topbar-user-dropdown-divider{background-color:var(--color-border-subtle);height:1px;margin:var(--space-1) 0}.sidebar.collapsed~.topbar{left:64px}@keyframes bot-card-pulse-running{0%,to{border-left-color:var(--status-running)}50%{border-left-color:#10b98166}}.bot-card{background-color:var(--color-bg-surface);border:1px solid var(--color-border-subtle);border-left:3px solid var(--color-border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast), box-shadow var(--transition-base), border-color var(--transition-fast);flex-direction:column;display:flex;overflow:hidden}.bot-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-default);transform:translateY(-2px)}.bot-card.status-running{border-left-color:var(--status-running)}.bot-card.status-running:hover{box-shadow:var(--shadow-md), 0 0 16px #10b98126}.bot-card.status-running .bot-card-status-indicator{animation:2s ease-in-out infinite bot-card-pulse-running}.bot-card.status-paused{border-left-color:var(--status-paused)}.bot-card.status-paused:hover{box-shadow:var(--shadow-md), 0 0 16px #f59e0b1f}.bot-card.status-stopped{border-left-color:var(--status-stopped)}.bot-card.status-error{border-left-color:var(--status-error)}.bot-card.status-error:hover{box-shadow:var(--shadow-md), 0 0 16px #ef44441f}.bot-card.status-starting{border-left-color:var(--status-starting)}.bot-card-header{align-items:center;gap:var(--space-3);padding:var(--space-4);display:flex}.bot-card-icon{background-color:var(--color-bg-elevated);border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-accent-secondary);font-size:var(--font-size-lg);flex-shrink:0;justify-content:center;align-items:center;display:flex}.bot-card-info{flex:1;min-width:0}.bot-card-name{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-weight:600;line-height:1.2;overflow:hidden}.bot-card-exchange{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.bot-card-header .badge{flex-shrink:0}.bot-card-body{padding:var(--space-4);gap:var(--space-3);flex-direction:column;flex:1;display:flex}.bot-card-metrics{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.bot-card-metric{flex-direction:column;gap:2px;display:flex}.bot-card-metric-label{font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1}.bot-card-metric-value{font-family:var(--font-mono);font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:600;line-height:1.2}.bot-card-metric-value.pnl-positive{color:var(--color-accent-success)}.bot-card-metric-value.pnl-negative{color:var(--color-accent-danger)}.bot-card-signal{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--color-bg-base);border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);display:flex}.bot-card-signal-type{text-transform:uppercase;font-weight:600}.bot-card-signal-type.buy{color:var(--color-accent-success)}.bot-card-signal-type.sell{color:var(--color-accent-danger)}.bot-card-signal-time{color:var(--color-text-muted);font-family:var(--font-mono);margin-left:auto}.bot-card-footer{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background-color:var(--color-bg-base);display:flex}.bot-card-footer .btn{flex:1}.bot-card-list{border-radius:var(--radius-md);flex-direction:row;align-items:center}.bot-card-list .bot-card-header{padding:var(--space-3) var(--space-4);border-bottom:none;flex-shrink:0;min-width:200px}.bot-card-list .bot-card-body{padding:var(--space-3) var(--space-4);flex-direction:row;align-items:center}.bot-card-list .bot-card-metrics{gap:var(--space-6);grid-template-columns:repeat(3,auto)}.bot-card-list .bot-card-signal{margin-left:auto}.bot-card-list .bot-card-footer{border-top:none;border-left:1px solid var(--color-border-subtle);padding:var(--space-3);flex-direction:column;flex-shrink:0}.bot-card-list .bot-card-footer .btn{flex:none}.bot-cards-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.bot-cards-list{gap:var(--space-2);flex-direction:column;display:flex}@keyframes canvas-connection-flow{to{stroke-dashoffset:-20px}}@keyframes canvas-node-appear{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.canvas{background-color:var(--color-bg-base);cursor:grab;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:relative;overflow:hidden}.canvas:active{cursor:grabbing}.canvas-grid{background-image:radial-gradient(circle, var(--color-border-subtle) 1px, transparent 1px);pointer-events:none;background-size:24px 24px;width:15000px;height:15000px;position:absolute;top:-5000px;left:-5000px}.canvas-grid.zoom-fine{background-size:12px 12px}.canvas-viewport{transform-origin:0 0;position:absolute;inset:0}.canvas-zoom-controls{bottom:var(--space-6);left:var(--space-6);gap:var(--space-1);z-index:20;flex-direction:column;display:flex;position:absolute}.canvas-zoom-btn{background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-lg);transition:background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);justify-content:center;align-items:center;display:flex}.canvas-zoom-btn:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary);border-color:var(--color-border-strong)}.canvas-zoom-btn:active{background-color:var(--color-bg-active)}.canvas-zoom-level{height:28px;font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--color-text-muted);background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-md);padding:0 var(--space-2);cursor:pointer;justify-content:center;align-items:center;display:flex}.canvas-zoom-level:hover{color:var(--color-text-secondary)}.canvas-node{background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);width:220px;box-shadow:var(--shadow-sm);cursor:pointer;transition:box-shadow var(--transition-fast), border-color var(--transition-fast);animation:canvas-node-appear var(--transition-base) ease forwards;position:absolute}.canvas-node:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-md);z-index:10}.canvas-node.selected{border-color:var(--color-accent-primary);box-shadow:var(--shadow-glow-purple);z-index:11}.canvas-node.dragging{opacity:.85;box-shadow:var(--shadow-lg);z-index:100;cursor:grabbing}.canvas-node-header{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-3);display:flex}.canvas-node-icon{background-color:var(--color-bg-elevated);border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-accent-secondary);font-size:var(--font-size-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.canvas-node-name{font-size:var(--font-size-sm);color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:600;overflow:hidden}.canvas-node-body{padding:var(--space-3);gap:var(--space-2);flex-direction:column;display:flex}.canvas-node-stat{font-size:var(--font-size-xs);justify-content:space-between;align-items:center;display:flex}.canvas-node-stat-label{color:var(--color-text-muted)}.canvas-node-stat-value{font-family:var(--font-mono);color:var(--color-text-secondary);font-weight:600}.canvas-node-port{background-color:var(--color-bg-elevated);border:2px solid var(--color-border-strong);border-radius:var(--radius-full);z-index:5;cursor:crosshair;width:12px;height:12px;transition:background-color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);position:absolute}.canvas-node-port:hover{background-color:var(--color-accent-primary);border-color:var(--color-accent-primary);transform:scale(1.3)}.canvas-node-port.port-input{top:50%;left:-6px;transform:translateY(-50%)}.canvas-node-port.port-input:hover{transform:translateY(-50%)scale(1.3)}.canvas-node-port.port-output{top:50%;right:-6px;transform:translateY(-50%)}.canvas-node-port.port-output:hover{transform:translateY(-50%)scale(1.3)}.canvas-node-port.connected{background-color:var(--color-accent-secondary);border-color:var(--color-accent-secondary)}.canvas-connections{pointer-events:none;z-index:1;position:absolute;inset:0}.canvas-connections svg{width:100%;height:100%}.canvas-connection{fill:none;stroke:var(--color-border-strong);stroke-width:2px;stroke-linecap:round}.canvas-connection:hover{stroke:var(--color-text-secondary);stroke-width:2.5px;pointer-events:stroke;cursor:pointer}.canvas-connection.active{stroke:var(--color-accent-secondary)}.canvas-connection.flowing{stroke:var(--color-accent-secondary);stroke-dasharray:8 4;animation:.8s linear infinite canvas-connection-flow}.canvas-connection.error{stroke:var(--status-error);stroke-dasharray:4 4}.canvas-connection-temp{fill:none;stroke:var(--color-accent-primary);stroke-width:2px;stroke-dasharray:6 4;opacity:.6}.canvas-minimap{bottom:var(--space-6);right:var(--space-6);background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-md);width:180px;height:120px;box-shadow:var(--shadow-md);z-index:20;opacity:.85;transition:opacity var(--transition-fast);position:absolute;overflow:hidden}.canvas-minimap:hover{opacity:1}.canvas-minimap-viewport{border:1.5px solid var(--color-accent-primary);cursor:move;background-color:#7c3aed14;border-radius:2px;position:absolute}.canvas-minimap-node{background-color:var(--color-border-strong);border-radius:2px;min-width:4px;min-height:3px;position:absolute}.canvas-minimap-node.status-running{background-color:var(--status-running)}.canvas-minimap-node.status-error{background-color:var(--status-error)}.canvas-toolbar{top:var(--space-4);align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:50;display:flex;position:absolute;left:50%;transform:translate(-50%)}.canvas-toolbar-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:relative}.canvas-toolbar-btn:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.canvas-toolbar-btn.active{color:var(--color-accent-primary);background-color:#7c3aed1f}.canvas-toolbar-separator{background-color:var(--color-border-subtle);width:1px;height:24px;margin:0 var(--space-1)}.canvas-toolbar-btn:after{content:attr(data-tooltip);top:calc(100% + var(--space-2));font-family:var(--font-sans);font-size:var(--font-size-xs);color:var(--color-text-primary);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-default);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;transition:opacity var(--transition-fast), visibility var(--transition-fast);position:absolute;left:50%;transform:translate(-50%)}.canvas-toolbar-btn:hover:after{opacity:1;visibility:visible}.canvas-toolbar-btn:not([data-tooltip]):after{display:none}.canvas-selection-box{border:1px solid var(--color-accent-primary);pointer-events:none;z-index:50;background-color:#7c3aed0f;border-radius:2px;position:absolute}.canvas-empty{text-align:center;pointer-events:none;z-index:5;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.canvas-empty-icon{color:var(--color-border-default);margin-bottom:var(--space-4);opacity:.5;font-size:48px}.canvas-empty-title{font-family:var(--font-sans);font-size:var(--font-size-xl);color:var(--color-text-muted);margin-bottom:var(--space-2);font-weight:600}.canvas-empty-text{font-size:var(--font-size-base);color:var(--color-text-muted);opacity:.7}@keyframes drawer-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-overlay{z-index:500;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:opacity var(--transition-base), visibility var(--transition-base);background-color:#0009;position:fixed;inset:0}.drawer-overlay.open{opacity:1;visibility:visible}.drawer{background-color:var(--color-bg-surface);border-left:1px solid var(--color-border-default);width:540px;max-width:92vw;height:100vh;box-shadow:var(--shadow-lg);z-index:501;transition:transform var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;right:0;transform:translate(100%)}.drawer-overlay.open .drawer{transform:translate(0)}.drawer-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.drawer-title{font-size:var(--font-size-xl);color:var(--color-text-primary);font-weight:600}.drawer-close{width:32px;height:32px;color:var(--color-text-muted);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background-color:#0000;border:none;justify-content:center;align-items:center;display:flex}.drawer-close:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.drawer-body{padding:var(--space-6);flex:1;overflow-y:auto}.drawer-body::-webkit-scrollbar{width:6px}.drawer-body::-webkit-scrollbar-track{background:0 0}.drawer-body::-webkit-scrollbar-thumb{background-color:var(--color-border-default);border-radius:var(--radius-full)}.drawer-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-subtle);background-color:var(--color-bg-base);flex-shrink:0;display:flex}@media (width<=768px){.drawer{width:100vw;max-width:100vw}}.auth-layout{min-height:100vh;display:flex;overflow:hidden}.auth-branding{padding:var(--space-10);background:var(--color-accent-primary);flex-direction:column;flex:0 0 50%;justify-content:space-between;display:flex;position:relative;overflow:hidden}.auth-branding-inner{flex-direction:column;flex:1;justify-content:center;display:flex}.auth-branding-top{flex-shrink:0}.auth-branding-top .app-logo-text{color:#fff}.auth-headline{gap:var(--space-5);flex-direction:column;display:flex}.auth-headline h1{letter-spacing:-.03em;color:#f1f5f9;font-size:42px;font-weight:700;line-height:1.1}.auth-headline p{font-size:var(--font-size-base);color:#ffffffa6;max-width:380px;line-height:1.7}.auth-mobile-logo{display:none}.auth-proof{align-items:center;gap:var(--space-6);display:flex}.auth-proof-item{flex-direction:column;gap:2px;display:flex}.auth-proof-number{font-family:var(--font-mono);font-size:var(--font-size-2xl);color:#f1f5f9;font-weight:700}.auth-proof-label{font-size:var(--font-size-xs);color:#ffffff80;letter-spacing:.02em}.auth-proof-sep{background:#ffffff26;width:1px;height:32px}.auth-form-column{padding:var(--space-10);background:var(--color-bg-base);flex:0 0 50%;justify-content:center;align-items:center;display:flex}.auth-form-wrapper{width:100%;max-width:400px}.auth-form-header{margin-bottom:var(--space-8)}.auth-form-header h1{color:var(--color-text-primary);margin-bottom:var(--space-2);letter-spacing:-.02em;font-size:26px;font-weight:700}.auth-form-header p{font-size:var(--font-size-sm);color:#64748b;line-height:1.5}.auth-form{gap:var(--space-5);flex-direction:column;display:flex}.auth-form .form-group{margin-bottom:0}.auth-form-footer{margin-top:var(--space-6);text-align:center}.auth-form-footer p{font-size:var(--font-size-sm);color:#64748b}.auth-form-footer a{color:var(--color-accent-primary);font-weight:500}.auth-form-footer a:hover{text-decoration:underline}.auth-divider{align-items:center;gap:var(--space-4);color:#334155;font-size:var(--font-size-xs);display:flex}.auth-divider:before,.auth-divider:after{content:"";background:#1e293b;flex:1;height:1px}.auth-options{justify-content:space-between;align-items:center;display:flex}.auth-options a{font-size:var(--font-size-sm);color:#64748b}.auth-options a:hover{color:var(--color-accent-primary)}.auth-verify{text-align:center;padding:var(--space-10) 0}.auth-verify-icon{width:72px;height:72px;margin:0 auto var(--space-6);border-radius:var(--radius-full);color:var(--color-accent-primary);background:#7c3aed14;border:1px solid #7c3aed26;justify-content:center;align-items:center;display:flex}.auth-verify h2{margin-bottom:var(--space-3)}.auth-verify p{color:#64748b;margin-bottom:var(--space-6);max-width:340px;margin-left:auto;margin-right:auto;line-height:1.6}.two-factor-input{gap:var(--space-3);margin:var(--space-6) 0;justify-content:center;display:flex}.two-factor-input input{text-align:center;width:48px;height:56px;font-size:var(--font-size-2xl);font-weight:600;font-family:var(--font-mono);background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-md);color:var(--color-text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast)}.two-factor-input input:focus{border-color:var(--color-accent-primary);outline:none;box-shadow:0 0 0 3px #7c3aed4d}.password-strength{gap:var(--space-1);margin-top:var(--space-2);display:flex}.password-strength-bar{background:var(--color-border-default);border-radius:var(--radius-full);height:3px;transition:background var(--transition-fast);flex:1}.password-strength[data-strength="1"] .password-strength-bar:first-child{background:var(--color-accent-danger)}.password-strength[data-strength="2"] .password-strength-bar:nth-child(-n+2){background:var(--color-accent-warning)}.password-strength[data-strength="3"] .password-strength-bar:nth-child(-n+3){background:var(--color-accent-info)}.password-strength[data-strength="4"] .password-strength-bar{background:var(--color-accent-success)}.password-strength-text{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--space-1)}@media (width<=1200px){.auth-branding{flex:0 0 45%}.auth-form-column{flex:0 0 55%}.auth-headline h1{font-size:34px}.auth-branding-inner{padding:0 var(--space-8)}}@media (width<=768px){.auth-layout{flex-direction:column}.auth-branding{display:none}.auth-form-column{padding:var(--space-6);flex-direction:column;flex:1;align-items:center}.auth-mobile-logo{margin-bottom:var(--space-8);width:100%;max-width:400px;display:flex}.auth-form-wrapper{width:100%}}.app-layout{min-height:100vh;display:flex}.app-content{margin-left:var(--sidebar-width);padding-top:var(--topbar-height);flex:1;min-height:100vh}.app-main{padding:var(--space-6);max-width:1400px}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.page-header h1{font-size:var(--font-size-2xl)}.page-header-actions{align-items:center;gap:var(--space-3);display:flex}.grid-2{gap:var(--space-5);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-5);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-5);grid-template-columns:repeat(4,1fr);display:grid}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.tabs{border-bottom:1px solid var(--color-border-default);margin-bottom:var(--space-6);gap:0;display:flex}.tab{padding:var(--space-3) var(--space-5);font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:color var(--transition-fast), border-color var(--transition-fast);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;font-weight:500}.tab:hover{color:var(--color-text-primary)}.tab.active{color:var(--color-accent-primary);border-bottom-color:var(--color-accent-primary)}.tab-content{display:none}.tab-content.active{display:block}.alert{padding:var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.alert-success{color:var(--color-accent-success);background:#10b9811a;border:1px solid #10b98133}.alert-danger{color:var(--color-accent-danger);background:#ef44441a;border:1px solid #ef444433}.alert-warning{color:var(--color-accent-warning);background:#f59e0b1a;border:1px solid #f59e0b33}.alert-info{color:var(--color-accent-info);background:#3b82f61a;border:1px solid #3b82f633}@media (width<=1200px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.app-content{margin-left:0}.app-main{padding:var(--space-4)}.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.page-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}}.ob{height:100vh;display:flex;overflow:hidden}.ob-left{background:var(--color-accent-primary);max-height:100vh;padding:var(--space-10);flex-direction:column;flex:0 0 35%;justify-content:space-between;display:flex;position:relative;overflow:hidden}.ob-left-top{gap:var(--space-8);flex-direction:column;display:flex}.ob-step-indicator{align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);color:#fff9;letter-spacing:.05em;text-transform:uppercase;font-weight:500;display:flex}.ob-step-indicator span{color:#fff;font-weight:700}.ob-progress{border-radius:var(--radius-full);background:#ffffff26;width:100%;height:3px;overflow:hidden}.ob-progress-fill{border-radius:var(--radius-full);background:#fff;height:100%;transition:width .5s}.ob-explainer{justify-content:center;gap:var(--space-4);flex-direction:column;flex:1;display:flex}.ob-explainer h2{letter-spacing:-.02em;color:#fff;font-size:28px;font-weight:700;line-height:1.15}.ob-explainer p{font-size:var(--font-size-base);color:#ffffffb3;max-width:320px;line-height:1.7}.ob-tips{gap:var(--space-4);flex-direction:column;display:flex}.ob-tip{align-items:flex-start;gap:var(--space-3);font-size:var(--font-size-sm);color:#ffffffb3;line-height:1.5;display:flex}.ob-tip-icon{color:#ffffffe6;flex-shrink:0;width:20px;height:20px;margin-top:1px}.ob-right{background:var(--color-bg-base);flex-direction:column;flex:1;height:100vh;display:flex;overflow:hidden}.ob-right-content{padding:var(--space-8);flex:1;justify-content:center;align-items:center;display:flex;overflow-y:auto}.ob-form{width:100%;max-width:680px}.ob-form-title{font-size:var(--font-size-2xl);color:var(--color-text-primary);margin-bottom:var(--space-2);letter-spacing:-.02em;font-weight:700}.ob-form-subtitle{font-size:var(--font-size-sm);color:#64748b;margin-bottom:var(--space-8);line-height:1.5}.ob-form-section{margin-bottom:var(--space-6)}.ob-form-section-label{font-size:var(--font-size-xs);color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-4);font-weight:600}.ob-form-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.ob-options{gap:var(--space-2);flex-direction:column;display:flex}.ob-option{align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex}.ob-option:hover{border-color:var(--color-border-strong);background:var(--color-bg-hover)}.ob-option.selected{border-color:var(--color-accent-primary);background:#7c3aed0d}.ob-option-radio{border-radius:var(--radius-full);border:2px solid var(--color-border-strong);width:18px;height:18px;transition:all var(--transition-fast);flex-shrink:0;position:relative}.ob-option.selected .ob-option-radio{border-color:var(--color-accent-primary)}.ob-option.selected .ob-option-radio:after{content:"";border-radius:var(--radius-full);background:var(--color-accent-primary);width:8px;height:8px;position:absolute;top:3px;left:3px}.ob-option-text{flex:1}.ob-option-title{font-size:var(--font-size-base);color:var(--color-text-primary);margin-bottom:1px;font-weight:500}.ob-option-desc{font-size:var(--font-size-xs);color:#64748b}.ob-check-grid{gap:var(--space-2);grid-template-columns:1fr 1fr;display:grid}.ob-check-grid--4{grid-template-columns:repeat(4,1fr)}.ob-option--compact{padding:var(--space-3) var(--space-4);gap:var(--space-3)}.ob-option--compact .ob-option-title{font-size:var(--font-size-sm)}.ob-check{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-primary);transition:all var(--transition-fast);display:flex}.ob-check:hover{border-color:var(--color-border-strong)}.ob-check.selected{border-color:var(--color-accent-primary);background:#7c3aed0d}.ob-check-box{border-radius:var(--radius-sm);border:2px solid var(--color-border-strong);width:16px;height:16px;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.ob-check.selected .ob-check-box{border-color:var(--color-accent-primary);background:var(--color-accent-primary)}.ob-nav{margin-top:var(--space-8);justify-content:space-between;align-items:center;display:flex}.ob-nav-right{align-items:center;gap:var(--space-3);display:flex}.ob-success{text-align:center}.ob-success-icon{width:72px;height:72px;margin:0 auto var(--space-6);border-radius:var(--radius-full);color:var(--color-accent-success);opacity:0;background:#10b9811a;border:1px solid #10b98133;justify-content:center;align-items:center;transition:transform .4s,opacity .4s;display:flex;transform:scale(.5)}.ob-success-icon.visible{opacity:1;transform:scale(1)}@media (width<=1024px){.ob-left{padding:var(--space-6);flex:0 0 280px}.ob-explainer h2{font-size:22px}}@media (width<=768px){.ob{flex-direction:column}.ob-left{padding:var(--space-5) var(--space-6);flex:none}.ob-explainer,.ob-tips{display:none}.ob-right-content{padding:0 var(--space-5)}.ob-form-row,.ob-check-grid{grid-template-columns:1fr}}.dashboard-stats{gap:var(--space-5);margin-bottom:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}.dashboard-chart{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6)}.dashboard-chart-header{margin-bottom:var(--space-5);justify-content:space-between;align-items:center;display:flex}.dashboard-chart-header h3{font-size:var(--font-size-lg)}.chart-period-selector{gap:var(--space-1);background:var(--color-bg-elevated);border-radius:var(--radius-md);padding:2px;display:flex}.chart-period-btn{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;font-weight:500}.chart-period-btn:hover{color:var(--color-text-primary)}.chart-period-btn.active{background:var(--color-accent-primary);color:#fff}.chart-container{height:300px;position:relative}.dashboard-bottom{gap:var(--space-6);grid-template-columns:1fr 1fr;display:grid}.dashboard-bots{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg)}.dashboard-bots-header{padding:var(--space-5) var(--space-5) var(--space-4);justify-content:space-between;align-items:center;display:flex}.dashboard-bots-header h3{font-size:var(--font-size-md)}.bot-list-item{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border-subtle);transition:background var(--transition-fast);display:flex}.bot-list-item:hover{background:var(--color-bg-hover)}.bot-list-icon{border-radius:var(--radius-md);width:36px;height:36px;font-size:var(--font-size-lg);flex-shrink:0;justify-content:center;align-items:center;display:flex}.bot-list-info{flex:1;min-width:0}.bot-list-name{font-size:var(--font-size-sm);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.bot-list-type{font-size:var(--font-size-xs);color:var(--color-text-muted)}.bot-list-pnl{font-size:var(--font-size-sm);font-weight:600;font-family:var(--font-mono);text-align:right}.bot-list-pnl.positive{color:var(--color-accent-success)}.bot-list-pnl.negative{color:var(--color-accent-danger)}.bot-list-actions{gap:var(--space-1);display:flex}.bot-action-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-text-muted);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.bot-action-btn:hover{background:var(--color-bg-active);color:var(--color-text-primary)}.bot-action-btn.play:hover{color:var(--color-accent-success)}.bot-action-btn.pause:hover{color:var(--color-accent-warning)}.bot-action-btn.stop:hover{color:var(--color-accent-danger)}.dashboard-activity{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);flex-direction:column;max-height:500px;display:flex}.dashboard-activity-header{padding:var(--space-5) var(--space-5) var(--space-4);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.dashboard-activity-header h3{font-size:var(--font-size-md)}.activity-live-dot{border-radius:var(--radius-full);background:var(--color-accent-success);width:8px;height:8px;animation:2s ease-in-out infinite livePulse}@keyframes livePulse{0%,to{opacity:1;box-shadow:0 0 #10b98166}50%{opacity:.7;box-shadow:0 0 0 6px #10b98100}}.activity-list{padding:0 var(--space-5) var(--space-5);flex:1;overflow-y:auto}.activity-item{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border-subtle);display:flex}.activity-item:last-child{border-bottom:none}.activity-icon{border-radius:var(--radius-full);width:28px;height:28px;font-size:var(--font-size-xs);flex-shrink:0;justify-content:center;align-items:center;display:flex}.activity-icon.trade{color:var(--color-accent-primary);background:#7c3aed26}.activity-icon.alert{color:var(--color-accent-warning);background:#f59e0b26}.activity-icon.status{color:var(--color-accent-info);background:#3b82f626}.activity-icon.error{color:var(--color-accent-danger);background:#ef444426}.activity-content{flex:1;min-width:0}.activity-text{font-size:var(--font-size-sm);line-height:1.4}.activity-text strong{color:var(--color-text-primary);font-weight:600}.activity-time{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}@media (width<=1200px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}.dashboard-bottom{grid-template-columns:1fr}}@media (width<=768px){.dashboard-stats{grid-template-columns:1fr}}.bot-detail{gap:var(--space-6);grid-template-columns:1fr 300px;display:grid}.bot-detail-main{min-width:0}.bot-control-panel{top:calc(var(--topbar-height) + var(--space-6));background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-5);height:fit-content;position:sticky}.bot-control-status{text-align:center;padding-bottom:var(--space-5);border-bottom:1px solid var(--color-border-subtle);margin-bottom:var(--space-5)}.bot-status-indicator{border-radius:var(--radius-full);width:48px;height:48px;margin:0 auto var(--space-3);justify-content:center;align-items:center;display:flex}.bot-status-indicator.running{background:#10b98126;animation:2s ease-in-out infinite statusGlow}@keyframes statusGlow{0%,to{box-shadow:0 0 #10b9814d}50%{box-shadow:0 0 0 8px #10b98100}}.bot-status-indicator.stopped{background:#47556926}.bot-status-indicator.paused{background:#f59e0b26}.bot-status-indicator.error{background:#ef444426}.bot-control-actions{gap:var(--space-2);margin-bottom:var(--space-5);grid-template-columns:repeat(2,1fr);display:grid}.bot-control-metric{padding:var(--space-3) 0;border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;display:flex}.bot-control-metric:last-child{border-bottom:none}.bot-control-metric-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.bot-control-metric-value{font-size:var(--font-size-sm);font-weight:600;font-family:var(--font-mono)}.bot-logs{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);overflow:hidden}.bot-logs-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-default);justify-content:space-between;align-items:center;display:flex}.bot-logs-filters{gap:var(--space-2);display:flex}.log-filter-btn{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);border-radius:var(--radius-sm);color:var(--color-text-secondary);border:1px solid var(--color-border-default);cursor:pointer;transition:all var(--transition-fast);background:0 0;font-weight:500}.log-filter-btn:hover{border-color:var(--color-border-strong)}.log-filter-btn.active{background:var(--color-accent-primary);border-color:var(--color-accent-primary);color:#fff}.bot-logs-content{max-height:500px;padding:var(--space-3);font-family:var(--font-mono);font-size:var(--font-size-xs);background:var(--color-bg-base);line-height:1.8;overflow-y:auto}.log-entry{gap:var(--space-3);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);display:flex}.log-entry:hover{background:var(--color-bg-elevated)}.log-time{color:var(--color-text-muted);flex-shrink:0}.log-level{text-transform:uppercase;flex-shrink:0;width:55px;font-weight:600}.log-level.debug{color:var(--color-text-muted)}.log-level.info{color:var(--color-accent-info)}.log-level.warning{color:var(--color-accent-warning)}.log-level.error{color:var(--color-accent-danger)}.log-level.critical{color:var(--color-accent-danger);font-weight:700}.log-message{color:var(--color-text-secondary);word-break:break-word}.bot-create{max-width:640px}.bot-config-section{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-5)}.bot-config-section h3{font-size:var(--font-size-md);margin-bottom:var(--space-5);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-subtle)}@media (width<=1200px){.bot-detail{grid-template-columns:1fr}.bot-control-panel{position:static}}.stats-filters{align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.stats-filter-group{align-items:center;gap:var(--space-2);display:flex}.stats-filter-group label{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap}.stats-filter-group select{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs);background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-sm);color:var(--color-text-primary)}.stats-charts{gap:var(--space-5);margin-bottom:var(--space-6);grid-template-columns:1fr 1fr;display:grid}.stats-chart-card{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-5)}.stats-chart-card h4{font-size:var(--font-size-sm);margin-bottom:var(--space-4);color:var(--color-text-secondary)}.stats-chart-container{height:240px;position:relative}.stats-chart-card.full-width{grid-column:1/-1}.stats-metrics{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}.stats-metric{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center}.stats-metric-value{font-size:var(--font-size-2xl);font-weight:700;font-family:var(--font-mono);margin-bottom:var(--space-1)}.stats-metric-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.stats-heatmap{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-6);overflow-x:auto}.heatmap-grid{grid-template-columns:60px repeat(24,1fr);gap:2px;min-width:700px;display:grid}.heatmap-cell{aspect-ratio:1;border-radius:var(--radius-sm);font-size:9px;font-family:var(--font-mono);transition:transform var(--transition-fast);justify-content:center;align-items:center;display:flex}.heatmap-cell:hover{z-index:1;transform:scale(1.3)}.heatmap-cell.positive-1{color:var(--color-accent-success);background:#10b98133}.heatmap-cell.positive-2{color:var(--color-accent-success);background:#10b98166}.heatmap-cell.positive-3{color:#fff;background:#10b98199}.heatmap-cell.negative-1{color:var(--color-accent-danger);background:#ef444433}.heatmap-cell.negative-2{color:var(--color-accent-danger);background:#ef444466}.heatmap-cell.negative-3{color:#fff;background:#ef444499}.heatmap-cell.neutral{background:var(--color-bg-elevated);color:var(--color-text-muted)}.heatmap-label{font-size:var(--font-size-xs);color:var(--color-text-muted);align-items:center;display:flex}.heatmap-hour{text-align:center;font-size:var(--font-size-xs);color:var(--color-text-muted);padding-bottom:var(--space-1)}.stats-trades{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);overflow:hidden}.stats-trades-header{padding:var(--space-5);border-bottom:1px solid var(--color-border-default);justify-content:space-between;align-items:center;display:flex}.stats-export-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-bg-elevated);border:1px solid var(--color-border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-weight:500;display:flex}.stats-export-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}@media (width<=1200px){.stats-charts{grid-template-columns:1fr}.stats-metrics{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.stats-metrics{grid-template-columns:1fr}.stats-filters{flex-direction:column;align-items:flex-start}}#nprogress .spinner{top:auto!important;bottom:20px!important;right:20px!important}
