:root{--bg:#0d1117;--surface:#161e2a;--border:#1f2d3d;--border-mid:#2a3a4d;--text:#e8eef4;--muted:#6b7e91;--accent:#3d9bff;--accent-hover:#5aabff;--accent-subtle:#3d9bff1f;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--font-display:"Satoshi",system-ui,sans-serif;--font-body:"Plus Jakarta Sans",system-ui,sans-serif;--font-mono:"Geist Mono",monospace;--font-code:"JetBrains Mono",monospace}[data-theme=light]{--bg:#f8fafc;--surface:#fff;--border:#e2e8f0;--border-mid:#cbd5e1;--text:#0f172a;--muted:#64748b;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-subtle:#eff6ff}body{background:#0d1117;background:var(--bg);color:#e8eef4;color:var(--text);font-family:var(--font-body)}code{font-family:JetBrains Mono,monospace;font-family:var(--font-code)}:root{--top-toolbar-height:60px;--top-toolbar-offset:72px;--floating-toolbar-bottom:24px;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--color-primary-light:#3b82f626;--color-primary-glow:#3b82f64d;--color-secondary:#64748b;--color-secondary-hover:#475569;--color-secondary-light:#64748b26;--color-accent:#10b981;--color-accent-hover:#059669;--color-accent-light:#10b98126;--color-warning:#f59e0b;--color-warning-hover:#d97706;--color-warning-light:#f59e0b26;--color-error:#ef4444;--color-error-hover:#dc2626;--color-error-light:#ef444426;--color-success:#22c55e;--color-success-light:#22c55e26;--color-background:#0a0a0b;--color-surface:#111113;--color-surface-secondary:#1a1a1d;--color-surface-tertiary:#252529;--color-surface-elevated:#2a2a2f;--color-surface-hover:#303037;--color-border:#2a2a2f;--color-border-light:#353540;--color-border-focus:#3b82f6;--color-border-hover:#404048;--color-text-primary:#f8fafc;--color-text-secondary:#cbd5e1;--color-text-tertiary:#94a3b8;--color-text-muted:#64748b;--color-text-inverse:#0f172a;--glass-bg:#111113cc;--glass-border:#ffffff1a;--glass-shadow:0 8px 32px #0000004d;--shadow-sm:0 1px 3px #0003,0 1px 2px #0000001a;--shadow-md:0 4px 6px #0000004d,0 2px 4px #0003;--shadow-lg:0 10px 15px #0006,0 4px 6px #0000004d;--shadow-xl:0 20px 25px #00000080,0 10px 10px #0000004d;--shadow-glow:0 0 20px #3b82f64d;--radius-sm:0.5rem;--radius-md:0.75rem;--radius-lg:1rem;--radius-xl:1.5rem;--radius-2xl:2rem;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:0.75rem;--space-lg:1rem;--space-xl:1.5rem;--space-2xl:2rem;--space-3xl:3rem;--transition-fast:0.15s ease-out;--transition-normal:0.2s ease-out;--transition-slow:0.3s ease-out}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0a0b;background:var(--color-background);color:#f8fafc;color:var(--color-text-primary);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-weight:400;line-height:1.6;margin:0;padding:0}.canvas-container-fullscreen{background:linear-gradient(135deg,#0a0a0b,#111113);height:100vh;overflow:hidden;position:relative;width:100vw}.top-toolbar{align-items:center;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:#0a0a0bc7;border-bottom:1px solid #ffffff14;display:flex;gap:.75rem;gap:var(--space-md);height:60px;height:var(--top-toolbar-height);left:0;overflow-x:auto;overflow-y:hidden;padding:0 1.5rem;padding:0 var(--space-xl);position:fixed;right:0;top:0;z-index:120}.top-toolbar:after{background:linear-gradient(90deg,#0000,#94a3b82e,#0000);bottom:0;content:"";height:1px;left:0;pointer-events:none;position:absolute;right:0}.secondary-toolbar-shell{bottom:24px;bottom:var(--floating-toolbar-bottom);display:flex;justify-content:center;left:0;pointer-events:none;position:fixed;right:0;z-index:140}.secondary-toolbar{align-items:stretch;backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);background:#0c121cd1;border:1px solid #94a3b829;border-radius:28px;box-shadow:0 24px 80px #0206177a,inset 0 1px 0 #ffffff0d;display:flex;gap:.75rem;gap:var(--space-md);min-height:78px;overflow-x:auto;overflow-y:hidden;padding:.85rem 1rem;pointer-events:auto;position:relative;width:min(calc(100vw - 32px),1520px)}.secondary-toolbar .toolbar-btn{font-size:.78rem;padding:.38rem .68rem}.secondary-toolbar::-webkit-scrollbar{height:6px}.secondary-toolbar::-webkit-scrollbar-thumb{background:#94a3b840;border-radius:999px}.secondary-toolbar::-webkit-scrollbar-track{background:#0000}.quick-start-panel{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#0a0f1ef0;border:1px solid #64748b73;border-radius:14px;box-shadow:0 16px 48px #00000073;left:50%;padding:1.25rem 1.25rem 1.1rem;position:fixed;top:50%;transform:translate(-50%,-42%);width:min(700px,calc(100vw - 32px));z-index:450}.quick-start-dismiss{background:#0000;border:none;color:#94a3b8;color:var(--color-text-tertiary);cursor:pointer;font-size:1.4rem;line-height:1;position:absolute;right:10px;top:8px}.quick-start-dismiss:hover,.quick-start-title{color:#f8fafc;color:var(--color-text-primary)}.quick-start-title{font-size:1.1rem;font-weight:700;margin:0 0 .35rem}.quick-start-subtitle{color:#cbd5e1;color:var(--color-text-secondary);font-size:.9rem;margin:0 0 .9rem}.quick-start-limits-text{font-feature-settings:"tnum";color:var(--muted);font-family:var(--font-mono);font-size:.75rem;font-variant-numeric:tabular-nums;line-height:1.4;margin:.75rem 0 0;text-align:center}.quick-start-actions{grid-gap:.65rem;display:grid;gap:.65rem;grid-template-columns:repeat(3,minmax(0,1fr))}.quick-start-action{background:#0f172ad1;border:1px solid #2563eb59;border-radius:10px;color:#dbeafe;cursor:pointer;font-size:.85rem;font-weight:600;padding:.65rem .75rem;transition:border-color .2s ease,transform .2s ease,background .2s ease}.quick-start-action:hover{background:#1e40af73;border-color:#38bdf8bf;transform:translateY(-1px)}.toolbar-spacer{flex:1 1;min-width:1rem;min-width:var(--space-lg)}.toolbar-section-nav{flex-wrap:nowrap}.toolbar-section-nav .toolbar-btn{background:hsla(0,0%,100%,.025);border-color:#94a3b81f;border-radius:12px;box-shadow:none;color:#e2e8f0c7;min-height:36px;padding:.4rem .8rem}.toolbar-section-nav .toolbar-btn:hover:not(:disabled){background:#ffffff0d;border-color:#94a3b833}.toolbar-section-right{align-items:center;display:flex;flex-wrap:nowrap;gap:.5rem;gap:var(--space-sm);margin-left:auto}.toolbar-section{align-items:center;display:flex;flex-shrink:1;flex-wrap:wrap;gap:.45rem;justify-content:flex-start}.floating-toolbar-group{display:flex;flex-direction:column;gap:.45rem;justify-content:center;min-width:-webkit-fit-content;min-width:fit-content}.floating-toolbar-group-compact{flex-shrink:0}.floating-toolbar-label{color:#94a3b8d1;font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif);font-size:.64rem;font-weight:700;letter-spacing:.12em;padding-left:.15rem;text-transform:uppercase}.toolbar-separator{align-self:stretch;background:linear-gradient(180deg,#0000,#94a3b861,#0000);margin:0;opacity:1;width:1px}.toolbar-separator-small{background:#2a2a2f;background:var(--color-border);height:24px;margin:0 .25rem;margin:0 var(--space-xs);width:1px}.toolbar-btn-account{align-items:center;background:#1a1a1d;background:var(--color-surface-secondary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:1rem;border-radius:var(--radius-lg);color:#f8fafc;color:var(--color-text-primary);cursor:pointer;display:flex;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-size:.875rem;font-weight:500;gap:.25rem;gap:var(--space-xs);height:36px;min-width:36px;padding:.25rem .5rem;padding:var(--space-xs) var(--space-sm);transition:all .2s ease-out;transition:all var(--transition-normal)}.toolbar-version{color:#ffffff73;font-family:Geist Mono,monospace;font-family:var(--font-mono,"Geist Mono",monospace);font-size:.7rem;letter-spacing:.02em}.toolbar-fork-section{flex-wrap:wrap;gap:8px}.toolbar-fork-label{color:#f8fafc;color:var(--color-text-primary)}.toolbar-fork-label,.toolbar-fork-status{font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-size:.78rem;letter-spacing:.02em}.toolbar-fork-status{color:#cbd5e1;color:var(--color-text-secondary)}.toolbar-fork-status-stale{color:#f59e0b;color:var(--color-warning)}.toolbar-quota-badge{align-items:center;background:#78350f33;border:1px solid #f59e0b73;border-radius:999px;color:#fde68a;display:inline-flex;font-size:.75rem;font-weight:600;height:30px;letter-spacing:.01em;padding:0 10px;white-space:nowrap}.toolbar-quota-badge.disabled{background:#33415540;border-color:#94a3b859;color:#cbd5e1}.toolbar-btn{align-items:center;background:#111113;background:var(--color-surface);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:.5rem;border-radius:var(--radius-sm);color:#cbd5e1;color:var(--color-text-secondary);cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-size:clamp(.6rem,.5rem + .25vw,.75rem);font-weight:500;gap:.25rem;gap:var(--space-xs);justify-content:center;min-height:34px;min-width:auto;overflow:hidden;padding:clamp(.2rem,.5vw,.4rem) clamp(.4rem,1vw,.6rem);position:relative;transition:all .2s ease-out;transition:all var(--transition-normal);white-space:nowrap}.toolbar-btn:before{background:linear-gradient(90deg,#0000,#ffffff0d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .3s ease-out;transition:left var(--transition-slow);width:100%}.toolbar-btn:hover:before{left:100%}.toolbar-btn:hover:not(:disabled){background:#303037;background:var(--color-surface-hover);border-color:#404048;border-color:var(--color-border-hover);box-shadow:0 4px 6px #0000004d,0 2px 4px #0003;box-shadow:var(--shadow-md);color:#f8fafc;color:var(--color-text-primary);transform:translateY(-1px)}.toolbar-btn:disabled{cursor:not-allowed;opacity:.4;transform:none}.toolbar-btn.active{background:linear-gradient(135deg,#3d9bff,#2563eb);border-color:#3d9bff;box-shadow:0 12px 28px #2563eb52;color:#0f172a;color:var(--color-text-inverse);transform:translateY(-1px)}.toolbar-shape-switcher{align-items:center;background:#111113;background:var(--color-surface);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:999px;display:inline-flex;gap:4px;padding:4px}.toolbar-shape-btn{background:#0000;border:0;border-radius:999px;color:#cbd5e1;color:var(--color-text-secondary);cursor:pointer;font:inherit;font-size:clamp(.6rem,.5rem + .2vw,.72rem);font-weight:600;padding:.25rem .6rem;transition:all .2s ease-out;transition:all var(--transition-normal);white-space:nowrap}.toolbar-shape-btn:hover:not(:disabled){color:#f8fafc;color:var(--color-text-primary)}.toolbar-shape-btn.active{background:linear-gradient(135deg,#3d9bff,#2563eb);box-shadow:0 10px 24px #2563eb42;color:#0f172a;color:var(--color-text-inverse)}.toolbar-shape-btn:disabled{cursor:not-allowed;opacity:.4}.toolbar-btn-primary{background:linear-gradient(135deg,#3d9bff,#2563eb);border-color:#3d9bff;box-shadow:0 14px 32px #2563eb57;color:#0f172a;color:var(--color-text-inverse);font-weight:600}.toolbar-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#60a5fa,#1d4ed8);box-shadow:0 18px 36px #2563eb66,0 10px 15px #0006,0 4px 6px #0000004d;box-shadow:0 18px 36px #2563eb66,var(--shadow-lg);transform:translateY(-2px)}.toolbar-btn-danger,.toolbar-btn-danger:hover:not(:disabled){border-color:#ef4444;border-color:var(--color-error);color:#ef4444;color:var(--color-error)}.toolbar-btn-danger:hover:not(:disabled){background:#ef444426;background:var(--color-error-light);box-shadow:0 0 20px #ef44444d}.toolbar-btn.loading{opacity:.8;pointer-events:none}.spinner{animation:spin 1s cubic-bezier(.68,-.55,.265,1.55) infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:initial;display:inline-block;height:16px;width:16px}.mode-indicator{align-items:center;background:#0000;border:1px solid #0000;border-radius:20px;cursor:pointer;display:inline-flex;font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif);font-size:.78rem;font-weight:600;gap:6px;letter-spacing:.04em;padding:4px 12px;text-transform:uppercase;transition:opacity .15s ease}.mode-indicator.draw{background:#ffffff2e;border-color:#ffffffa6;color:#fff}.mode-indicator.visualize{background:#06b6d414;border-color:#06b6d459;color:#06b6d4}.mode-indicator:hover:not(:disabled){opacity:.8}.mode-indicator:disabled{cursor:not-allowed;opacity:.4}.mode-indicator-dot{background:currentColor;border-radius:50%;height:7px;width:7px}.form-group{margin-bottom:1.5rem;margin-bottom:var(--space-xl)}.form-label{display:block;font-weight:600;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.form-input,.form-label{color:#f8fafc;color:var(--color-text-primary);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-size:.875rem}.form-input{background:#1a1a1d;background:var(--color-surface-secondary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:.75rem;border-radius:var(--radius-md);padding:.75rem 1rem;padding:var(--space-md) var(--space-lg);transition:all .2s ease-out;transition:all var(--transition-normal);width:100%}.form-input:focus{background:#252529;background:var(--color-surface-tertiary);border-color:#3b82f6;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f626,0 4px 6px #0000004d,0 2px 4px #0003;box-shadow:0 0 0 3px var(--color-primary-light),var(--shadow-md);outline:none}.form-select{background:#1a1a1d;background:var(--color-surface-secondary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:.75rem;border-radius:var(--radius-md);color:#f8fafc;color:var(--color-text-primary);cursor:pointer;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-size:.875rem;padding:.75rem 1rem;padding:var(--space-md) var(--space-lg);transition:all .2s ease-out;transition:all var(--transition-normal);width:100%}.form-select:focus{border-color:#3b82f6;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f626;box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.btn{align-items:center;border:none;border-radius:.75rem;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-size:.875rem;font-weight:600;gap:.5rem;gap:var(--space-sm);justify-content:center;overflow:hidden;padding:.75rem 1.5rem;padding:var(--space-md) var(--space-xl);position:relative;text-decoration:none;transition:all .2s ease-out;transition:all var(--transition-normal)}.btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .3s ease-out;transition:left var(--transition-slow);width:100%}.btn:hover:before{left:100%}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);box-shadow:0 0 20px #3b82f64d;box-shadow:var(--shadow-glow);color:#0f172a;color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1e40af);background:linear-gradient(135deg,var(--color-primary-hover) 0,#1e40af 100%);box-shadow:0 0 30px #3b82f666,0 10px 15px #0006,0 4px 6px #0000004d;box-shadow:0 0 30px #3b82f666,var(--shadow-lg);transform:translateY(-2px)}.btn-secondary{background:#1a1a1d;background:var(--color-surface-secondary);border:1px solid #2a2a2f;border:1px solid var(--color-border);color:#f8fafc;color:var(--color-text-primary)}.btn-secondary:hover:not(:disabled){background:#252529;background:var(--color-surface-tertiary);border-color:#404048;border-color:var(--color-border-hover);transform:translateY(-1px)}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.status-card{background:#1a1a1d;background:var(--color-surface-secondary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:1rem;border-radius:var(--radius-lg);margin-bottom:1.5rem;margin-bottom:var(--space-xl);overflow:hidden;padding:1.5rem;padding:var(--space-xl);position:relative}.status-card:before{background:linear-gradient(90deg,#3b82f6,#10b981);background:linear-gradient(90deg,var(--color-primary),var(--color-accent));content:"";height:3px;left:0;position:absolute;right:0;top:0}.status-card-success{background:#22c55e26;background:var(--color-success-light);border-color:#22c55e;border-color:var(--color-success);color:#22c55e;color:var(--color-success)}.status-card-success:before{background:linear-gradient(90deg,#22c55e,#10b981);background:linear-gradient(90deg,var(--color-success),var(--color-accent))}.status-card-warning{background:#f59e0b26;background:var(--color-warning-light);border-color:#f59e0b;border-color:var(--color-warning);color:#f59e0b;color:var(--color-warning)}.status-card-warning:before{background:linear-gradient(90deg,#f59e0b,#f97316);background:linear-gradient(90deg,var(--color-warning),#f97316)}.status-card-error{background:#ef444426;background:var(--color-error-light);border-color:#ef4444;border-color:var(--color-error);color:#ffe4e6}.status-card-error:before{background:linear-gradient(90deg,#ef4444,#dc2626);background:linear-gradient(90deg,var(--color-error),#dc2626)}.status-card-error .status-card-title,.status-card-error li,.status-card-error p{color:inherit}.status-card-title{font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-weight:700;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.stats-grid{grid-gap:1rem;grid-gap:var(--space-lg);display:grid;gap:1rem;gap:var(--space-lg);grid-template-columns:1fr 1fr;margin-bottom:1.5rem;margin-bottom:var(--space-xl)}.stat-item{background:#252529;background:var(--color-surface-tertiary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:1rem;border-radius:var(--radius-lg);overflow:hidden;padding:1rem;padding:var(--space-lg);position:relative;text-align:center;transition:all .2s ease-out;transition:all var(--transition-normal)}.stat-item:before{background:linear-gradient(90deg,#3b82f6,#10b981);background:linear-gradient(90deg,var(--color-primary),var(--color-accent));content:"";height:2px;left:0;position:absolute;right:0;top:0}.stat-item:hover{border-color:#404048;border-color:var(--color-border-hover);box-shadow:0 10px 15px #0006,0 4px 6px #0000004d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#10b981);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;background-clip:text;color:#3b82f6;color:var(--color-primary);display:block;font-size:2rem;font-weight:800}.stat-label,.stat-value{font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif)}.stat-label{color:#94a3b8;color:var(--color-text-tertiary);font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}.distribution-list{max-height:240px;overflow-y:auto;padding-right:.5rem;padding-right:var(--space-sm)}.distribution-list::-webkit-scrollbar{width:6px}.distribution-list::-webkit-scrollbar-track{background:#111113;background:var(--color-surface);border-radius:3px}.distribution-list::-webkit-scrollbar-thumb{background:#404048;background:var(--color-border-hover);border-radius:3px}.distribution-list::-webkit-scrollbar-thumb:hover{background:#3b82f6;background:var(--color-primary)}.distribution-item{align-items:center;background:#252529;background:var(--color-surface-tertiary);border:1px solid #0000;border-radius:.75rem;border-radius:var(--radius-md);cursor:pointer;display:flex;justify-content:space-between;margin-bottom:.5rem;margin-bottom:var(--space-sm);overflow:hidden;padding:1rem;padding:var(--space-lg);position:relative;transition:all .2s ease-out;transition:all var(--transition-normal)}.distribution-item:before{background:linear-gradient(90deg,#0000,#3b82f61a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .2s ease-out;transition:left var(--transition-normal);width:100%}.distribution-item:hover:before{left:100%}.distribution-item:hover{background:#2a2a2f;background:var(--color-surface-elevated);border-color:#3b82f6;border-color:var(--color-primary);box-shadow:0 4px 6px #0000004d,0 2px 4px #0003;box-shadow:var(--shadow-md);transform:translateX(4px)}.distribution-item.configured{background:#22c55e26;background:var(--color-success-light);border-color:#22c55e;border-color:var(--color-success)}.distribution-item.unconfigured{background:#ef444426;background:var(--color-error-light);border-color:#ef4444;border-color:var(--color-error)}.distribution-agents{font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif);font-size:.875rem;font-weight:700}.parameters-panel,.parameters-panel-routing{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#111113cc;background:var(--glass-bg);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:22px;box-shadow:0 24px 64px #02061761;height:calc(100vh - 88px);height:calc(100vh - var(--top-toolbar-offset) - 16px);left:16px;overflow-y:auto;position:fixed;top:72px;top:var(--top-toolbar-offset);transform:translateX(calc(-100% - 16px));transition:transform .3s ease-out;transition:transform var(--transition-slow);width:min(420px,calc(100vw - 32px));z-index:999}.parameters-panel-routing.open,.parameters-panel.open{transform:translateX(0)}.parameters-panel.right-panel{left:auto;right:16px;transform:translateX(calc(100% + 16px))}.parameters-panel.right-panel.open{transform:translateX(0)}.parameters-panel-header{backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:linear-gradient(180deg,#1a1a1df5,#161e2ae0);border-bottom:1px solid #94a3b824;padding:1.4rem 1.5rem 1.15rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.parameters-panel-title{color:#f8fafc;color:var(--color-text-primary);font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif);font-size:1.15rem;font-weight:700;letter-spacing:.01em;margin:0}.parameters-panel-content{padding:1.35rem 1.5rem 1.75rem}.sidebar-section{margin-bottom:2rem;margin-bottom:var(--space-2xl)}.sidebar-section-title{border-bottom:1px solid #2a2a2f;border-bottom:1px solid var(--color-border);color:#cbd5e1;color:var(--color-text-secondary);font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif);font-size:1rem;font-weight:600;letter-spacing:.01em;margin-bottom:1rem;margin-bottom:var(--space-lg);padding-bottom:.5rem;padding-bottom:var(--space-sm)}.sidebar-button-grid{grid-gap:.75rem;grid-gap:var(--space-md);display:grid;gap:.75rem;gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.sidebar-button-column{display:flex;flex-direction:column;gap:.75rem;gap:var(--space-md)}.sidebar-btn{align-items:center;background:#1a1a1d;background:var(--color-surface-secondary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:.75rem;border-radius:var(--radius-md);color:#cbd5e1;color:var(--color-text-secondary);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;justify-content:center;padding:.75rem 1rem;padding:var(--space-md) var(--space-lg);text-align:center;transition:all .2s ease-out;transition:all var(--transition-normal);width:100%}.sidebar-btn:hover:not(:disabled){background:#303037;background:var(--color-surface-hover);border-color:#404048;border-color:var(--color-border-hover);box-shadow:0 4px 6px #0000004d,0 2px 4px #0003;box-shadow:var(--shadow-md);color:#f8fafc;color:var(--color-text-primary);transform:translateY(-1px)}.sidebar-btn.active{background:#3b82f6;background:var(--color-primary);border-color:#3b82f6;border-color:var(--color-primary);box-shadow:0 0 20px #3b82f64d;box-shadow:var(--shadow-glow);color:#0f172a;color:var(--color-text-inverse)}.sidebar-btn:disabled{cursor:not-allowed;opacity:.4;transform:none}.sidebar-btn-danger{border-color:#ef4444;border-color:var(--color-error);color:#ef4444;color:var(--color-error)}.sidebar-btn-danger:hover:not(:disabled){background:#ef444426;background:var(--color-error-light);color:#ef4444;color:var(--color-error)}.simulation-controls{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#111113cc;background:var(--glass-bg);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:2rem;border-radius:var(--radius-2xl);bottom:3rem;bottom:var(--space-3xl);box-shadow:0 8px 32px #0000004d;box-shadow:var(--glass-shadow);color:#f8fafc;color:var(--color-text-primary);left:50%;padding:1.5rem 3rem;padding:var(--space-xl) var(--space-3xl);position:absolute;transform:translateX(-50%);transition:left .3s ease-out,transform .3s ease-out;transition:left var(--transition-slow),transform var(--transition-slow);z-index:1000}.simulation-controls.panel-open{left:65%;transform:translateX(-50%)}.simulation-btn{align-items:center;border:none;border-radius:1rem;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-size:.875rem;font-weight:700;justify-content:center;min-width:100px;overflow:hidden;padding:1rem 2rem;padding:var(--space-lg) var(--space-2xl);position:relative;transition:all .2s ease-out;transition:all var(--transition-normal)}.simulation-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .3s ease-out;transition:left var(--transition-slow);width:100%}.simulation-btn:hover:before{left:100%}.simulation-btn-play{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 0 20px #22c55e4d;color:#0f172a;color:var(--color-text-inverse)}.simulation-btn-play:hover{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 0 30px #22c55e66,0 10px 15px #0006,0 4px 6px #0000004d;box-shadow:0 0 30px #22c55e66,var(--shadow-lg);transform:translateY(-2px)}.simulation-btn-reset{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 0 20px #ef44444d;color:#0f172a;color:var(--color-text-inverse)}.simulation-btn-reset:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 0 30px #ef444466,0 10px 15px #0006,0 4px 6px #0000004d;box-shadow:0 0 30px #ef444466,var(--shadow-lg);transform:translateY(-2px)}.simulation-btn-close{background:linear-gradient(135deg,#64748b,#475569);background:linear-gradient(135deg,var(--color-secondary) 0,#475569 100%);color:#0f172a;color:var(--color-text-inverse)}.simulation-btn-close:hover{background:linear-gradient(135deg,#475569,#334155);transform:translateY(-2px)}.frame-control{align-items:center;display:flex;gap:1rem;gap:var(--space-lg);min-width:300px}.frame-slider{-webkit-appearance:none;appearance:none;background:#1a1a1d;background:var(--color-surface-secondary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:4px;flex:1 1;height:8px;outline:none}.frame-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));border-radius:50%;box-shadow:0 4px 6px #0000004d,0 2px 4px #0003;box-shadow:var(--shadow-md);cursor:pointer;height:20px;-webkit-transition:all .2s ease-out;transition:all .2s ease-out;-webkit-transition:all var(--transition-normal);transition:all var(--transition-normal);width:20px}.frame-slider::-webkit-slider-thumb:hover{background:linear-gradient(135deg,#2563eb,#1e40af);background:linear-gradient(135deg,var(--color-primary-hover),#1e40af);box-shadow:0 0 15px #3b82f680;transform:scale(1.1)}.frame-info{color:#cbd5e1;color:var(--color-text-secondary);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-size:.8rem;font-weight:600;min-width:80px;text-align:right}.speed-control{align-items:center;display:flex;gap:1rem;gap:var(--space-lg)}.speed-select{border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:.75rem;border-radius:var(--radius-md);cursor:pointer;font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif);font-size:.8rem;font-weight:500;padding:.5rem .75rem;padding:var(--space-sm) var(--space-md)}.speed-select,.speed-select option{background:#1a1a1d;background:var(--color-surface-secondary);color:#f8fafc;color:var(--color-text-primary)}.simulation-info{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#111113cc;background:var(--glass-bg);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:1.5rem;border-radius:var(--radius-xl);box-shadow:0 8px 32px #0000004d;box-shadow:var(--glass-shadow);font-size:.875rem;max-height:calc(100vh - 120px);min-width:320px;overflow-y:auto;padding:1.5rem;padding:var(--space-xl);pointer-events:auto;position:absolute;right:20px;top:90px;z-index:1000}.simulation-info,.simulation-info-title{color:#f8fafc;color:var(--color-text-primary)}.simulation-info-title{font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-size:1.1rem;font-weight:800;margin-bottom:1rem;margin-bottom:var(--space-lg)}.simulation-info-grid{grid-gap:1rem;grid-gap:var(--space-lg);display:grid;gap:1rem;gap:var(--space-lg);grid-template-columns:1fr 1fr}.simulation-info-item{display:flex;flex-direction:column}.simulation-info-label{color:#94a3b8;color:var(--color-text-tertiary);font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif);font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.25rem;margin-bottom:var(--space-xs);text-transform:uppercase}.simulation-info-value{color:#f8fafc;color:var(--color-text-primary);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-size:1rem;font-weight:700}.modal-overlay{align-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.modal{background:#111113;background:var(--color-surface);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:2rem;border-radius:var(--radius-2xl);box-shadow:0 20px 25px #00000080,0 10px 10px #0000004d;box-shadow:var(--shadow-xl);max-width:550px;min-width:450px;overflow:hidden;padding:3rem;padding:var(--space-3xl);position:relative}.modal:before{background:linear-gradient(90deg,#3b82f6,#10b981);background:linear-gradient(90deg,var(--color-primary),var(--color-accent));content:"";height:4px;left:0;position:absolute;right:0;top:0}.modal-title{color:#f8fafc;color:var(--color-text-primary);font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif);font-size:1.5rem;font-weight:800;margin:0 0 2rem;margin:0 0 var(--space-2xl) 0}.modal-actions{display:flex;gap:1rem;gap:var(--space-lg);justify-content:flex-end;margin-top:2rem;margin-top:var(--space-2xl)}.clear-confirm-modal{max-width:620px;min-width:520px}.clear-confirm-message{color:#f8fafc;color:var(--color-text-primary);font-size:1.125rem;line-height:1.5;margin:0 0 .5rem;margin:0 0 var(--space-sm) 0}.clear-confirm-submessage{color:#dc2626;font-size:.95rem;margin:0}[data-theme=light] .clear-confirm-submessage{color:#b91c1c}.app-alert-modal{max-width:680px;min-width:520px}.app-alert-card{margin-bottom:0}.app-alert-message{color:inherit;font-family:inherit;font-size:1rem;line-height:1.6;margin:0;white-space:pre-wrap}.simulation-error-card{margin-bottom:0}.simulation-error-message{color:#f8fafc;color:var(--color-text-primary);font-size:1.125rem;line-height:1.5;margin:0}.simulation-error-tip{color:#fecaca;font-size:.95rem;line-height:1.5;margin:.5rem 0 0;margin:var(--space-sm) 0 0 0}.data-panel{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#111113cc;background:var(--glass-bg);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:2rem;border-radius:var(--radius-2xl);bottom:1.5rem;bottom:var(--space-xl);box-shadow:0 8px 32px #0000004d;box-shadow:var(--glass-shadow);left:400px;max-height:250px;overflow:hidden;position:absolute;right:1.5rem;right:var(--space-xl);z-index:1000}.data-panel-header{align-items:center;background:#1a1a1d;background:var(--color-surface-secondary);border-bottom:1px solid #2a2a2f;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:1.5rem 2rem;padding:var(--space-xl) var(--space-2xl)}.data-panel-title{color:#f8fafc;color:var(--color-text-primary);font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif);font-size:1.1rem;font-weight:700;margin:0}.data-panel-close{align-items:center;background:none;border:none;border-radius:.5rem;border-radius:var(--radius-sm);color:#cbd5e1;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;padding:.5rem;padding:var(--space-sm);transition:all .2s ease-out;transition:all var(--transition-normal);width:32px}.data-panel-close:hover{background:#252529;background:var(--color-surface-tertiary);color:#f8fafc;color:var(--color-text-primary);transform:scale(1.1)}.data-panel-content{display:flex;height:180px}.data-section{border-right:1px solid #2a2a2f;border-right:1px solid var(--color-border);flex:1 1;padding:1.5rem;padding:var(--space-xl)}.data-section:last-child{border-right:none}.data-section-title{font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif);font-size:.9rem;font-weight:700;margin:0 0 1rem;margin:0 0 var(--space-lg) 0}.data-section-title,.data-textarea{color:#f8fafc;color:var(--color-text-primary)}.data-textarea{background:#252529;background:var(--color-surface-tertiary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:.75rem;border-radius:var(--radius-md);font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:.75rem;height:120px;line-height:1.4;padding:1rem;padding:var(--space-lg);resize:none;width:100%}.data-textarea:focus{border-color:#3b82f6;border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f626;box-shadow:0 0 0 2px var(--color-primary-light);outline:none}.canvas-container-fullscreen canvas{left:0;position:absolute}@keyframes spin{to{transform:rotate(1turn)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}@keyframes slideOutLeft{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(-100%)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1400px){.top-toolbar{gap:.75rem;gap:var(--space-md);padding:0 1rem;padding:0 var(--space-lg)}.toolbar-section{gap:.25rem;gap:var(--space-xs)}.toolbar-btn{font-size:.75rem;min-width:auto;padding:.25rem .5rem;padding:var(--space-xs) var(--space-sm)}.parameters-panel,.parameters-panel-routing{width:350px}}@media (max-width:1024px){.top-toolbar{gap:.75rem;gap:var(--space-md);padding:0 .75rem;padding:0 var(--space-md)}.toolbar-section{gap:.25rem;gap:var(--space-xs);margin-bottom:0}.toolbar-btn{font-size:.75rem;min-width:auto;padding:.25rem .5rem;padding:var(--space-xs) var(--space-sm)}.secondary-toolbar{gap:.75rem;gap:var(--space-md);padding:.75rem .85rem}.parameters-panel,.parameters-panel-routing{width:min(320px,calc(100vw - 32px))}.data-panel{left:340px}}@media (max-width:900px){.secondary-toolbar{width:calc(100vw - 24px)}.secondary-toolbar-shell{bottom:18px}.secondary-toolbar .toolbar-btn{font-size:.73rem;padding:.35rem .55rem}}@media (max-width:768px){.top-toolbar{gap:.5rem;gap:var(--space-sm);padding:0 .5rem;padding:0 var(--space-sm)}.toolbar-section{display:flex;flex-wrap:wrap;gap:.25rem;gap:var(--space-xs);justify-content:center;margin-bottom:0}.toolbar-btn{min-height:28px}.secondary-toolbar-shell{bottom:14px}.secondary-toolbar{border-radius:22px;gap:.5rem;gap:var(--space-sm);min-height:auto;padding:.75rem}.floating-toolbar-group{gap:.35rem}.floating-toolbar-label{font-size:.58rem;letter-spacing:.1em}.parameters-panel,.parameters-panel-routing{border-radius:20px;height:calc(100vh - 84px);height:calc(100vh - var(--top-toolbar-offset) - 12px);left:12px;right:12px;width:auto}.data-panel{bottom:1rem;bottom:var(--space-lg);left:1rem;left:var(--space-lg)}.quick-start-panel{transform:translate(-50%,-45%)}.quick-start-actions{grid-template-columns:1fr}.simulation-controls{bottom:1.5rem;bottom:var(--space-xl);left:1rem;left:var(--space-lg);right:1rem;right:var(--space-lg);transform:none}.simulation-controls-inner{flex-wrap:wrap;gap:1rem;gap:var(--space-lg)}.toolbar-section-right{gap:.35rem}}@media (max-width:480px){.top-toolbar{gap:.35rem}.toolbar-btn{min-width:auto;padding:.25rem;padding:var(--space-xs)}.secondary-toolbar{padding:.65rem;width:calc(100vw - 16px)}.toolbar-separator{opacity:.45}.parameters-panel-content{padding:1rem;padding:var(--space-lg)}.modal{margin:1rem;margin:var(--space-lg);min-width:320px}}.progress-container{margin:1rem 0;width:100%}.progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.progress-stage{align-items:center;display:flex;gap:.5rem}.stage-label{color:#f8fafc;color:var(--color-text-primary);font-size:.875rem;font-weight:600}.stage-badge{border-radius:.375rem;color:#fff;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.progress-percentage{color:#cbd5e1;color:var(--color-text-secondary);font-size:.875rem;font-weight:600}.progress-bar-container{background:#252529;background:var(--color-surface-tertiary);height:8px;width:100%}.progress-bar-container,.progress-bar-fill{border-radius:4px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;transition:width .3s cubic-bezier(.4,0,.2,1)}.progress-shimmer{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d 50%,#0000);bottom:0;left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.progress-message{color:#94a3b8;color:var(--color-text-tertiary);font-size:.8125rem;margin-bottom:0;margin-top:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.simulation-progress-modal{max-width:600px;min-width:500px}.modal-header{margin-bottom:1.5rem}.modal-header,.simulation-progress-header{align-items:center;display:flex;justify-content:space-between}.simulation-progress-header{margin-bottom:1rem}.simulation-progress-title{color:#f8fafc;color:var(--color-text-primary);font-size:1.875rem;font-weight:800;margin:0}.simulation-progress-content{margin-bottom:.5rem}.modal-close-btn,.simulation-progress-close-btn{background:none;border:none;border-radius:.25rem;color:#cbd5e1;color:var(--color-text-secondary);cursor:pointer;font-size:1.25rem;padding:.25rem;transition:all .2s ease}.modal-close-btn:hover,.simulation-progress-close-btn:hover{background:#252529;background:var(--color-surface-tertiary);color:#f8fafc;color:var(--color-text-primary)}.simulation-progress-actions{border-top:1px solid #2a2a2f;border-top:1px solid var(--color-border);display:flex;gap:1rem;gap:var(--space-lg);justify-content:flex-end;margin-top:1.5rem;margin-top:var(--space-xl);padding-top:1rem;padding-top:var(--space-lg)}.results-grid{grid-gap:.5rem;color:#cbd5e1;color:var(--color-text-secondary);display:grid;font-size:.875rem;gap:.5rem;grid-template-columns:1fr 1fr;margin-top:.5rem}.model-info{background:#252529;background:var(--color-surface-tertiary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:.75rem;border-radius:var(--radius-md);margin-top:.5rem;margin-top:var(--space-sm);padding:1rem;padding:var(--space-lg)}.model-description{color:#cbd5e1;color:var(--color-text-secondary);font-size:.875rem;line-height:1.5;margin-bottom:.75rem;margin-bottom:var(--space-md)}.model-characteristics{color:#94a3b8;color:var(--color-text-tertiary);font-size:.8125rem}.model-characteristics ul{list-style-type:disc;margin:.5rem 0 0;margin:var(--space-sm) 0 0 0;padding-left:1rem;padding-left:var(--space-lg)}.model-characteristics li{margin-bottom:.25rem;margin-bottom:var(--space-xs)}.model-parameters{display:flex;flex-direction:column;gap:.75rem;gap:var(--space-md);margin-top:.5rem;margin-top:var(--space-sm)}.parameter-item{grid-gap:.25rem .5rem;grid-gap:var(--space-xs) var(--space-sm);align-items:center;background:#252529;background:var(--color-surface-tertiary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:.5rem;border-radius:var(--radius-sm);display:grid;gap:.25rem .5rem;gap:var(--space-xs) var(--space-sm);grid-template-columns:1fr 120px;grid-template-rows:auto auto;padding:.75rem;padding:var(--space-md)}.parameter-label{font-weight:500;grid-column:1}.parameter-input,.parameter-label{color:#f8fafc;color:var(--color-text-primary);font-size:.8125rem;grid-row:1}.parameter-input{background:#111113;background:var(--color-surface);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:.5rem;border-radius:var(--radius-sm);grid-column:2;padding:.25rem .5rem;padding:var(--space-xs) var(--space-sm)}.parameter-input:focus{border-color:#3b82f6;border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f626;box-shadow:0 0 0 2px var(--color-primary-light);outline:none}.parameter-description{color:#64748b;color:var(--color-text-muted);font-size:.75rem;font-style:italic;grid-column:1/-1;grid-row:2;line-height:1.4}.model-recommendations{display:flex;flex-direction:column;gap:.25rem;gap:var(--space-xs);margin-top:.5rem;margin-top:var(--space-sm)}.recommendation-item{background:#252529;background:var(--color-surface-tertiary);border-left:3px solid #3b82f6;border-left:3px solid var(--color-primary);border-radius:.5rem;border-radius:var(--radius-sm);color:#cbd5e1;color:var(--color-text-secondary);font-size:.8125rem;padding:.5rem;padding:var(--space-sm)}@media (max-width:1024px){.parameter-item{grid-template-columns:1fr;grid-template-rows:auto auto auto}.parameter-input{grid-column:1;grid-row:2}.parameter-description{grid-row:3}}.distribution-tooltip{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#111113f2;border:1px solid #ffffff1a;border-radius:8px;box-shadow:0 4px 12px #0000004d;color:#fff;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-size:12px;max-width:400px;padding:12px;white-space:nowrap}[data-theme=light] .distribution-tooltip{background:#faf9f5fa;border:1px solid #0000001a;box-shadow:0 4px 12px #00000026;color:#141413}[data-theme=light] .distribution-tooltip-title{border-bottom-color:#0000001a;color:#4f46e5}[data-theme=light] .distribution-tooltip-params{color:#2c2b25}.distribution-tooltip-title{border-bottom:1px solid #ffffff1a;color:#22c55e;font-size:13px;font-weight:600;margin-bottom:8px;padding-bottom:4px}.distribution-tooltip-params{display:flex;flex-direction:column;gap:4px}.param-row{align-items:center;display:flex;gap:6px}.param-label{color:#cbd5e1;font-weight:500}.param-value{font-feature-settings:"tnum";color:#fff;font-variant-numeric:tabular-nums;font-weight:600}[data-theme=light] .param-label{color:#6b7280}[data-theme=light] .param-value{color:#141413}.distribution-tooltip{animation:tooltipFadeIn .2s ease-out}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.parameter-group{background:#1a1a1d;background:var(--color-surface-secondary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:1rem;border-radius:var(--radius-lg);margin-bottom:3rem;margin-bottom:var(--space-3xl);padding:1.5rem;padding:var(--space-xl)}.parameter-group-title{border-bottom:2px solid #3b82f6;border-bottom:2px solid var(--color-primary);color:#f8fafc;color:var(--color-text-primary);font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif);font-size:1rem;font-weight:700;margin:0 0 1.5rem;margin:0 0 var(--space-xl) 0;padding-bottom:.5rem;padding-bottom:var(--space-sm)}.elements-overview-panel{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#111113cc;background:var(--glass-bg);border-bottom:1px solid #ffffff1a;border-bottom:1px solid var(--glass-border);border-bottom-left-radius:1.5rem;border-bottom-left-radius:var(--radius-xl);border-left:1px solid #ffffff1a;border-left:1px solid var(--glass-border);box-shadow:0 8px 32px #0000004d;box-shadow:var(--glass-shadow);max-height:200px;overflow:hidden;position:fixed;right:0;top:72px;top:var(--top-toolbar-offset);transform:translateX(100%);transition:transform .3s ease-out;transition:transform var(--transition-slow);width:280px;z-index:998}.elements-overview-panel.open{transform:translateX(0)}.elements-overview-header{align-items:center;background:#1a1a1d;background:var(--color-surface-secondary);border-bottom:1px solid #2a2a2f;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:1rem 1.5rem;padding:var(--space-lg) var(--space-xl)}.elements-overview-title{color:#f8fafc;color:var(--color-text-primary);font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif);font-size:.875rem;font-weight:600;margin:0}.panel-minimize-btn{align-items:center;background:none;border:none;border-radius:.5rem;border-radius:var(--radius-sm);color:#cbd5e1;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:1.25rem;height:24px;justify-content:center;padding:.25rem;padding:var(--space-xs);transition:all .2s ease-out;transition:all var(--transition-normal);width:24px}.panel-minimize-btn:hover{background:#252529;background:var(--color-surface-tertiary);color:#f8fafc;color:var(--color-text-primary)}.elements-overview-content{padding:1rem;padding:var(--space-lg)}.elements-stats-grid{grid-gap:.5rem;grid-gap:var(--space-sm);display:grid;gap:.5rem;gap:var(--space-sm);grid-template-columns:repeat(3,1fr)}.stat-item-mini{background:#252529;background:var(--color-surface-tertiary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:.75rem;border-radius:var(--radius-md);padding:.5rem;padding:var(--space-sm);text-align:center;transition:all .2s ease-out;transition:all var(--transition-normal)}.stat-item-mini:hover{border-color:#404048;border-color:var(--color-border-hover);box-shadow:0 1px 3px #0003,0 1px 2px #0000001a;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.stat-value-mini{color:#3b82f6;color:var(--color-primary);display:block;font-size:1.25rem;font-weight:700}.stat-label-mini,.stat-value-mini{font-family:Satoshi,system-ui,sans-serif;font-family:var(--font-display,"Satoshi",system-ui,sans-serif)}.stat-label-mini{color:#94a3b8;color:var(--color-text-tertiary);font-size:.6875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}@media (max-width:1024px){.elements-overview-panel{border-left:none;border-radius:0;border-top:1px solid #ffffff1a;border-top:1px solid var(--glass-border);right:0;top:120px;width:100%}.elements-stats-grid{grid-template-columns:repeat(6,1fr)}}@media (max-width:768px){.elements-stats-grid{grid-template-columns:repeat(3,1fr)}}.element-list{max-height:200px;overflow-y:auto;padding-right:.5rem;padding-right:var(--space-sm)}.element-list::-webkit-scrollbar{width:4px}.element-list::-webkit-scrollbar-track{background:#111113;background:var(--color-surface);border-radius:2px}.element-list::-webkit-scrollbar-thumb{background:#404048;background:var(--color-border-hover);border-radius:2px}.element-list::-webkit-scrollbar-thumb:hover{background:#3b82f6;background:var(--color-primary)}.element-item{align-items:center;background:#252529;background:var(--color-surface-tertiary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:.5rem;border-radius:var(--radius-sm);display:flex;justify-content:space-between;margin-bottom:.25rem;margin-bottom:var(--space-xs);padding:.5rem .75rem;padding:var(--space-sm) var(--space-md);transition:all .2s ease-out;transition:all var(--transition-normal)}.element-item:hover{background:#2a2a2f;background:var(--color-surface-elevated);border-color:#404048;border-color:var(--color-border-hover);transform:translateX(2px)}.element-name{color:#f8fafc;color:var(--color-text-primary);flex:1 1;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-body,"Plus Jakarta Sans",system-ui,sans-serif);font-size:.8125rem;font-weight:500}.element-name.clickable{color:#3b82f6;color:var(--color-primary)}.element-name.clickable:hover{color:#2563eb;color:var(--color-primary-hover);text-decoration:underline}.element-delete-btn{align-items:center;background:none;border:none;border-radius:.5rem;border-radius:var(--radius-sm);color:#ef4444;color:var(--color-error);cursor:pointer;display:flex;font-size:1.25rem;font-weight:700;height:24px;justify-content:center;padding:.25rem;padding:var(--space-xs);transition:all .2s ease-out;transition:all var(--transition-normal);width:24px}.element-convert-btn{background:#3b82f626;border:1px solid #60a5fa73;border-radius:6px;color:#dbeafe;cursor:pointer;font-size:.65rem;font-weight:700;line-height:1;padding:2px 6px;transition:all .2s ease}.element-convert-btn:hover{background:#3b82f647;border-color:#93c5fdb3}[data-theme=light] .element-convert-btn{background:#3b82f61a;border-color:#3b82f666;color:#1d4ed8}[data-theme=light] .element-convert-btn:hover{background:#3b82f633;border-color:#3b82f699}.element-delete-btn:hover{background:#ef444426;background:var(--color-error-light);color:#ef4444;color:var(--color-error);transform:scale(1.1)}.element-empty{background:#111113;background:var(--color-surface);border:1px dashed #2a2a2f;border:1px dashed var(--color-border);border-radius:.5rem;border-radius:var(--radius-sm);color:#64748b;color:var(--color-text-muted);font-size:.8125rem;font-style:italic;padding:1rem;padding:var(--space-lg);text-align:center}.sidebar-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.visibility-toggle{background:none;border:none;border-radius:4px;cursor:pointer;font-size:1.2rem;padding:.25rem;transition:all .2s ease}.visibility-toggle:hover{background-color:#ffffff1a}.visibility-toggle.hidden{opacity:.4}.element-item.highlighted{background-color:#6366f133;border-left:3px solid #6366f1}.element-name.clickable{cursor:pointer;transition:color .2s ease}.element-name.clickable:hover{color:#6366f1}.element-actions{align-items:center;display:flex;gap:4px}.element-visibility-toggle{background:none;border:none;border-radius:3px;cursor:pointer;font-size:1rem;padding:.2rem;transition:all .2s ease}.element-visibility-toggle:hover{background-color:#ffffff1a}.element-visibility-toggle.hidden{opacity:.4}.set-management-expanded{background-color:var(--color-bg-secondary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:4px;margin-top:8px;padding:8px}.set-management-header{font-size:.875rem;margin-bottom:8px}.add-to-set h4,.set-distributions-list h4{color:#cbd5e1;color:var(--color-text-secondary);font-size:.75rem;margin:8px 0 4px}.set-distribution-item{align-items:center;display:flex;font-size:.75rem;justify-content:space-between;padding:4px 0}.remove-btn{background:var(--color-danger);border:none;border-radius:2px;color:#fff;cursor:pointer;font-size:.7rem;padding:2px 6px}.remove-btn:hover{background:var(--color-danger-hover)}.sidebar-btn-small{background:#3b82f6;background:var(--color-primary);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;padding:4px 8px}.sidebar-btn-small:hover{background:#2563eb;background:var(--color-primary-hover)}.analytics-panel-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.analytics-panel{background:var(--color-bg-primary);border:1px solid #2a2a2f;border:1px solid var(--color-border);border-radius:12px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;max-height:90vh;max-width:1400px;width:70%}.analytics-panel-header{align-items:center;border-bottom:1px solid #2a2a2f;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:20px 24px}.analytics-panel-title{color:#f8fafc;color:var(--color-text-primary);font-size:1.5rem;font-weight:600;margin:0}.analytics-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#cbd5e1;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.analytics-close-btn:hover{background:var(--color-bg-secondary);color:#f8fafc;color:var(--color-text-primary)}.analytics-panel-content{flex:1 1;overflow-y:auto;padding:24px}.analytics-loading .spinner{border:4px solid #2a2a2f;border:4px solid var(--color-border);height:48px;width:48px}.analytics-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(450px,1fr))}.analytics-plot-container{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172a80;border:1px solid #33415599;border-radius:12px;padding:16px}@media (max-width:1024px){.analytics-grid{grid-template-columns:1fr}}.analytics-error,.analytics-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:40px 20px}.analytics-loading .spinner{animation:spin 1s linear infinite;border:3px solid #2a2a2f;border-top-color:#3b82f6;border:3px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:40px;width:40px}.analytics-error p{color:var(--color-danger);font-size:.875rem;text-align:center}.analytics-summary{border-bottom:1px solid #33415599;display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;gap:var(--space-sm) var(--space-xl);margin-bottom:.75rem;margin-bottom:var(--space-md);padding:0 0 .5rem;padding:0 0 var(--space-sm)}.analytics-summary-ensemble{flex-direction:column;gap:.25rem;gap:var(--space-xs)}.analytics-summary-ensemble .analytics-summary-item+.analytics-summary-item{margin-left:0}.analytics-summary-item{align-items:center;display:flex;flex-direction:row;gap:.5rem;gap:var(--space-sm)}.analytics-summary-label{color:#94a3b8;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase}.analytics-summary-value{color:#f1f5f9;font-size:.85rem;font-weight:600}[data-theme=light] .analytics-summary-label{color:#7c7968}[data-theme=light] .analytics-summary-value{color:#141413}[data-theme=light] .analytics-plot-container{background:#ffffffb3;border-color:#00000014}[data-theme=light] .analytics-plot-wrapper{background:#ffffff80;border-color:#00000014}.analytics-plots-container{display:flex;flex-direction:column;gap:.75rem;gap:var(--space-md);padding:0}.analytics-curves-toggle{align-items:center;color:#cbd5e1;display:flex;font-size:.8rem;gap:8px;margin:0}.analytics-plot-wrapper{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172a80;border:1px solid #33415599;border-radius:8px;min-height:220px;padding:14px}.analytics-plot-title{color:#f8fafc;color:var(--color-text-primary);font-size:1rem;font-weight:600;margin:0 0 8px}.analytics-plot-wrapper canvas{border-radius:4px;display:block;height:180px!important;width:100%}[data-theme=light]{--color-background:#fdf6e3;--color-surface:#fdf6e3;--color-surface-secondary:#f0eee6;--color-surface-tertiary:#e8e5d9;--color-surface-elevated:#fff;--color-surface-hover:#ebe8de;--color-border:#d1cfc5;--color-border-light:#e2dfd3;--color-border-hover:#b8b5ab;--color-text-primary:#141413;--color-text-secondary:#2c2b25;--color-text-tertiary:#7c7968;--color-text-muted:#a09d92;--color-text-inverse:#fdf6e3;--glass-bg:#faf9f5e6;--glass-border:#0000000f;--glass-shadow:0 8px 32px #00000014;--shadow-sm:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow-md:0 4px 6px #00000014,0 2px 4px #0000000d;--shadow-lg:0 10px 15px #00000014,0 4px 6px #0000000a;--shadow-xl:0 20px 25px #0000001a,0 10px 10px #0000000a}[data-theme=light] .quick-start-panel{background:#f0eee6f7;border-color:#a19e9659;box-shadow:0 16px 48px #00000014}[data-theme=light] .quick-start-title{color:#141413}[data-theme=light] .quick-start-subtitle{color:#3a3831}[data-theme=light] .quick-start-action{background:#ffffffe6;border-color:#2563eb66;color:#1e40af}[data-theme=light] .quick-start-action:hover{background:#dbeafecc;border-color:#3b82f699;color:#1e3a8a}[data-theme=light] .quick-start-limits{background:#fef3c780;border-color:#d9770666}[data-theme=light] .quick-start-limits-title{color:#92400e}[data-theme=light] .quick-start-limits-text{color:#78350f}[data-theme=light] .parameters-panel-title{color:#141413}[data-theme=light] .parameters-panel,[data-theme=light] .parameters-panel-routing{background:#faf9f5f7;border-color:#00000014}[data-theme=light] .parameters-panel-header{background:linear-gradient(180deg,#f0eee6fa,#f8fafcf0);border-bottom-color:#d1cfc5}[data-theme=light] .sidebar-section-title{border-bottom-color:#d1cfc5;color:#2c2b25}[data-theme=light] .sidebar-section-header .visibility-toggle{color:#4a4840}[data-theme=light] .toolbar-btn{background:#fff;border-color:#d1cfc5;color:#2c2b25}[data-theme=light] .toolbar-btn:hover:not(:disabled){background:#eff6ff;border-color:#bfdbfe;color:#141413}[data-theme=light] .toolbar-btn.active{background:linear-gradient(135deg,#3d9bff,#2563eb);border-color:#3d9bff;color:#fff}[data-theme=light] .top-toolbar{background:#f8fafcdb;border-bottom-color:#0f172a14}[data-theme=light] .toolbar-section-nav .toolbar-btn{background:#ffffffb8;border-color:#94a3b82e;color:#334155}[data-theme=light] .toolbar-section-nav .toolbar-btn:hover:not(:disabled){background:#fffffff5}[data-theme=light] .secondary-toolbar{background:#ffffffe0;border-color:#94a3b838;box-shadow:0 24px 60px #0f172a24,inset 0 1px 0 #ffffffbf}[data-theme=light] .toolbar-shape-switcher{background:#fff;border-color:#d1cfc5}[data-theme=light] .toolbar-shape-btn{color:#4a4840}[data-theme=light] .toolbar-shape-btn.active{background:linear-gradient(135deg,#3d9bff,#2563eb);color:#fff}[data-theme=light] .mode-indicator.draw{background:#0000000a;border-color:#0000002e;color:#3a3831}[data-theme=light] .mode-indicator.visualize{background:#0891b212;border-color:#0891b24d;color:#0891b2}[data-theme=light] .sidebar-btn{background:#fff;border-color:#d1cfc5;color:#2c2b25}[data-theme=light] .sidebar-btn:hover:not(:disabled){background:#f0eee6;border-color:#b8b5ab;color:#141413}[data-theme=light] .sidebar-btn.active{background:#6366f1;border-color:#6366f1;color:#fff}[data-theme=light] .simulation-info{background:#faf9f5f2;border-color:#00000014;box-shadow:0 8px 32px #0000001a;color:#141413}[data-theme=light] .simulation-info-title{color:#141413}[data-theme=light] .simulation-info-label{color:#7c7968}[data-theme=light] .simulation-info-value{color:#141413}[data-theme=light] .data-panel{background:#faf9f5f2;border-color:#00000014}[data-theme=light] .data-panel-header{background:#f0eee6;border-bottom-color:#d1cfc5}[data-theme=light] .data-panel-title{color:#141413}[data-theme=light] .data-panel-close{color:#7c7968}[data-theme=light] .data-panel-close:hover{background:#e8e5d9;color:#141413}[data-theme=light] .data-section{border-right-color:#d1cfc5}[data-theme=light] .data-section-title{color:#2c2b25}[data-theme=light] .data-textarea,[data-theme=light] .form-select{background:#fff;border-color:#d1cfc5;color:#141413}[data-theme=light] .progress-bar-container{background:#e8e5d9}[data-theme=light] .stage-label{color:#141413}[data-theme=light] .progress-message,[data-theme=light] .progress-percentage{color:#7c7968}[data-theme=light] .element-item{background:#fff;border-color:#d1cfc5}[data-theme=light] .element-item:hover{background:#f0eee6;border-color:#b8b5ab}[data-theme=light] .element-name{color:#141413}[data-theme=light] .element-name.clickable{color:#6366f1}[data-theme=light] .element-delete-btn{color:#dc2626}[data-theme=light] .element-empty{background:#f0eee6;border-color:#d1cfc5;color:#7c7968}[data-theme=light] .stat-item{background:#fff;border-color:#d1cfc5}[data-theme=light] .stat-label{color:#7c7968}[data-theme=light] .stat-value{color:#6366f1}[data-theme=light] .distribution-item{background:#fff;border-color:#d1cfc5}[data-theme=light] .distribution-item:hover{background:#f0eee6;border-color:#b8b5ab}[data-theme=light] .distribution-list::-webkit-scrollbar-track{background:#f0eee6}[data-theme=light] .distribution-list::-webkit-scrollbar-thumb{background:#b8b5ab}[data-theme=light] .element-list::-webkit-scrollbar-track{background:#f0eee6}[data-theme=light] .element-list::-webkit-scrollbar-thumb{background:#b8b5ab}[data-theme=light] .frame-slider{background:#e8e5d9;border-color:#d1cfc5}[data-theme=light] .frame-info{color:#7c7968}[data-theme=light] .speed-select{background:#fff;border-color:#d1cfc5;color:#141413}[data-theme=light] .toolbar-separator{background:linear-gradient(180deg,#0000,#94a3b873,#0000)}[data-theme=light] .toolbar-separator-small{background:#d1cfc5}[data-theme=light] .toolbar-btn-account{background:#fff;border-color:#d1cfc5;color:#141413}[data-theme=light] .toolbar-version{color:#0006}[data-theme=light] .toolbar-fork-status{color:#cbd5e1;color:var(--color-text-secondary)}[data-theme=light] .floating-toolbar-label{color:#64748b}[data-theme=light] .toolbar-quota-badge{background:#fef3c780;border-color:#d9770680;color:#92400e}[data-theme=light] .toolbar-quota-badge.disabled{background:#e2e8f080;border-color:#94a3b866;color:#64748b}[data-theme=light] .status-card{background:#f0eee6;border-color:#d1cfc5}[data-theme=light] .status-card-error,[data-theme=light] .status-card-error .status-card-title,[data-theme=light] .status-card-error li,[data-theme=light] .status-card-error p{color:#7f1d1d}[data-theme=light] .elements-overview-panel{background:#faf9f5f2;border-color:#00000014}[data-theme=light] .elements-overview-header{background:#f0eee6;border-bottom-color:#d1cfc5}[data-theme=light] .elements-overview-title{color:#141413}[data-theme=light] .stat-item-mini{background:#fff;border-color:#d1cfc5}[data-theme=light] .panel-minimize-btn,[data-theme=light] .stat-label-mini{color:#7c7968}[data-theme=light] .panel-minimize-btn:hover{background:#e8e5d9;color:#141413}[data-theme=light] .quick-start-dismiss{color:#7c7968}[data-theme=light] .quick-start-dismiss:hover{color:#141413}[data-theme=light] .modal-overlay{background:#14141399}[data-theme=light] .canvas-container-fullscreen{background:linear-gradient(135deg,#fdf6e3,#f0eee6)}.toolbar-btn.theme-toggle-btn,[data-theme=light] .theme-toggle-btn{background:#fff!important;border:2px solid #d1cfc5!important;box-shadow:0 2px 4px #0000001a;font-size:1.1rem!important}.toolbar-btn.theme-toggle-btn:hover,[data-theme=light] .theme-toggle-btn:hover{background:#f0eee6!important;border-color:#b8b5ab!important;transform:scale(1.05)}[data-theme=dark] .theme-toggle-btn{background:#1a1a1d!important;border:2px solid #353540!important}[data-theme=dark] .theme-toggle-btn:hover{background:#252529!important;border-color:#404048!important}[data-theme=light] .parameter-group{background:#fff;border-color:#d1cfc5}[data-theme=light] .parameter-group-title{border-bottom-color:#6366f1;color:#141413}
/*# sourceMappingURL=main.d609ba13.css.map*/