*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a12;--surface:#13131e;--panel:#161622;--border:#1f1f30;--border-hover:#2e2e45;--text:#c8c8e0;--text-muted:#5a5a7a;--text-dim:#3a3a55;--accent:#6366f1;--accent-hover:#818cf8;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace}html,body,#root{background:var(--bg);width:100%;height:100%;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:13px;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#2a2a44;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#3a3a5a}.setup-overlay{background:radial-gradient(at 40% 30%,#1a1035 0%,#0a0a12 70%);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.setup-screen{background:radial-gradient(at 40% 30%,#1a1035 0%,#0a0a12 70%);justify-content:center;align-items:center;width:100%;height:100%;padding:40px 20px;display:flex;overflow-y:auto}.setup-card{background:var(--surface);border:1px solid var(--border-hover);border-radius:16px;width:500px;padding:44px 44px 32px;box-shadow:0 24px 80px #0006,0 0 0 1px #ffffff08}.setup-logo{align-items:baseline;gap:6px;margin-bottom:8px;display:flex}.logo-k9{background:linear-gradient(135deg,#6366f1,#a78bfa);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:800}.logo-studio{color:#88a;letter-spacing:.05em;font-size:20px;font-weight:300}.setup-tagline{color:var(--text-muted);margin-bottom:32px;font-size:12px}.setup-form{flex-direction:column;gap:18px;display:flex}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;flex-direction:column;gap:6px;font-size:12px;font-weight:500;display:flex}.required{color:#ef4444}.form-input{background:var(--panel);border:1px solid var(--border-hover);color:var(--text);border-radius:8px;outline:none;padding:10px 13px;font-family:inherit;font-size:13px;transition:border-color .15s}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #6366f122}.form-textarea{resize:vertical;min-height:72px}.setup-prompt{color:#7070a0;margin-bottom:24px;font-size:13px;line-height:1.6}.setup-prompt strong{color:#a0a0c8}.setup-option{background:#0a0a1a;border:1px solid #1e1e38;border-radius:10px;margin-bottom:4px;padding:18px 18px 16px}.setup-option-label{letter-spacing:.06em;text-transform:uppercase;color:#9090c8;margin-bottom:4px;font-size:12px;font-weight:700}.setup-option-sub{color:#4a4a80;margin-bottom:12px;font-size:11px;line-height:1.5}.setup-input-row{gap:6px;margin-bottom:8px;display:flex}.setup-input{color:#e0e0f8;background:#111120;border:1px solid #2a2a44;border-radius:6px;outline:none;flex:1;padding:8px 11px;font-family:inherit;font-size:12px;transition:border-color .15s}.setup-input:focus{border-color:#6366f1}.setup-input:disabled{opacity:.5}.setup-browse-btn{color:#6060a0;cursor:pointer;background:#111120;border:1px solid #2a2a44;border-radius:6px;padding:0 12px;font-size:14px;transition:all .15s}.setup-browse-btn:hover{color:#a5b4fc;border-color:#6366f1}.setup-repo-hint{color:#3a3a60;font-size:10px;font-family:var(--font-mono);margin-bottom:10px}.setup-btn-primary{color:#a78bfa;cursor:pointer;text-align:center;background:#1a1a40;border:1px solid #6366f140;border-radius:7px;width:100%;padding:9px;font-size:12px;font-weight:600;transition:all .15s}.setup-btn-primary:hover:not(:disabled){color:#c4b5fd;background:#6366f122;border-color:#6366f1}.setup-btn-primary:disabled{opacity:.4;cursor:not-allowed}.setup-field-error{color:#f87171;margin-bottom:8px;font-size:11px}.setup-clone-success{flex-direction:column;gap:6px;display:flex}.setup-clone-ok{color:#4ade80;margin-bottom:4px;font-size:11px}.setup-clone-hint{color:#3a3a70;margin-bottom:8px;font-size:10px;line-height:1.5}.setup-clone-hint code{color:#6060a0;font-family:var(--font-mono)}.setup-checking{color:#7070c0;margin-bottom:8px;font-size:11px}.setup-not-found{background:#1a1020;border:1px solid #f59e0b44;border-radius:6px;margin-bottom:8px;padding:10px 12px}.setup-not-found-msg{color:#f59e0b;margin-bottom:4px;font-size:11px}.setup-not-found-msg code{font-family:var(--font-mono);color:#a08840}.setup-not-found-sub{color:#6060a0;margin-bottom:10px;font-size:11px}.setup-not-found-actions{flex-direction:column;gap:6px;display:flex}.setup-btn-ghost{color:#5050a0;cursor:pointer;background:0 0;border:1px solid #2a2a50;border-radius:5px;padding:6px 12px;font-size:11px;transition:border-color .15s,color .15s}.setup-btn-ghost:hover{color:#8080d0;border-color:#4040a0}.setup-or{color:#2a2a50;align-items:center;gap:10px;margin:12px 0;font-size:11px;display:flex}.setup-or:before,.setup-or:after{content:"";background:#1a1a30;flex:1;height:1px}.setup-footer-skip{text-align:center;margin-top:20px}.setup-skip-btn{color:#3a3a60;cursor:pointer;text-underline-offset:3px;background:0 0;border:none;font-size:10px;text-decoration:underline;transition:color .15s}.setup-skip-btn:hover{color:#6060a0}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:4px;padding:11px 20px;font-size:13px;font-weight:600;transition:background .15s,transform .1s}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.setup-footer{text-align:center;color:var(--text-dim);margin-top:28px;font-size:11px}.studio{background:var(--bg);flex-direction:column;width:100%;height:100%;display:flex}.studio-header{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:46px;padding:0 16px;display:flex}.header-left{align-items:center;gap:10px;display:flex}.header-right{align-items:center;gap:8px;display:flex}.header-back{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:16px}.header-back:hover{background:var(--border);color:var(--text)}.logo-k9{background:linear-gradient(135deg,#6366f1,#a78bfa);-webkit-text-fill-color:transparent;cursor:pointer;-webkit-background-clip:text;background-clip:text;font-size:16px;font-weight:800;text-decoration:none}.logo-k9:hover{opacity:.8}.logo-studio{color:#66a;font-size:13px;font-weight:300}.header-divider{color:var(--border-hover)}.header-project{color:var(--text);font-weight:600}.header-domain{color:#818cf8;background:#6366f122;border:1px solid #6366f133;border-radius:20px;padding:2px 8px;font-size:11px}.btn-secondary{background:var(--panel);border:1px solid var(--border-hover);color:var(--text-muted);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:12px;transition:all .15s}.btn-secondary:hover{border-color:var(--accent);color:var(--text)}.studio-body{flex:1;display:flex;overflow:hidden}.palette{background:var(--panel);flex-direction:column;flex-shrink:0;width:100%;display:flex;overflow-y:auto}.palette-tabs{border-bottom:1px solid var(--border);background:var(--panel);flex-shrink:0;display:flex}.palette-tab{color:#8888b8;cursor:pointer;letter-spacing:.02em;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px 8px;font-size:11px;font-weight:600;transition:all .15s}.palette-tab:hover{color:#c0c0e0}.palette-tab.active{color:#f59e0b;border-bottom-color:#f59e0b}.palette-header{letter-spacing:.1em;text-transform:uppercase;color:#9090b8;padding:12px 14px 4px;font-size:10px;font-weight:700}.palette-hint{color:#5a5a80;padding:0 14px 10px;font-size:10px}.palette-list{flex-direction:column;flex:1;gap:3px;padding:0 8px;display:flex}.palette-item{cursor:grab;background:var(--surface);border-left-style:solid;border-left-width:3px;border-top:1px solid var(--border);border-right:1px solid var(--border);border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:10px;padding:8px 10px;transition:all .15s;display:flex}.palette-item:hover{background:#1e1e30;border-color:var(--border-hover)!important}.palette-item:active{cursor:grabbing}.palette-icon{flex-shrink:0;font-size:14px}.palette-item-text{flex:1;min-width:0}.palette-label{color:var(--text);font-size:12px;font-weight:500}.palette-class{color:#7878a8;font-size:10px;font-family:var(--font-mono);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.palette-regen{border-top:1px solid var(--border);flex-direction:column;gap:6px;margin-top:auto;padding:10px 10px 14px;display:flex}.palette-regen-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-size:10px;font-weight:700}.palette-regen-textarea{background:var(--surface);border:1px solid var(--border-hover);color:var(--text);resize:vertical;border-radius:6px;outline:none;padding:7px 9px;font-family:inherit;font-size:11px;line-height:1.5;transition:border-color .15s}.palette-regen-textarea:focus{border-color:var(--accent)}.palette-regen-btn{color:#818cf8;cursor:pointer;text-align:center;background:#6366f111;border:1px solid #6366f133;border-radius:6px;padding:7px;font-size:12px;font-weight:600;transition:all .15s}.palette-regen-btn:hover:not(:disabled){border-color:var(--accent);background:#6366f122}.palette-regen-btn:disabled{opacity:.4;cursor:not-allowed}.palette-section-title{letter-spacing:.1em;text-transform:uppercase;color:#c04040;align-items:center;gap:6px;padding:14px 14px 4px;font-size:10px;font-weight:700;display:flex}.palette-hint-icon{color:#5050a0;cursor:default;letter-spacing:0;text-transform:none;-webkit-user-select:none;user-select:none;font-size:11px;font-weight:400;position:relative}.palette-hint-icon:hover{color:#9090c8}.palette-hint-tooltip{color:#a0a0c8;letter-spacing:0;text-transform:none;z-index:999;pointer-events:none;background:#12122a;border:1px solid #2a2a50;border-radius:6px;width:210px;padding:8px 10px;font-size:11px;font-weight:400;line-height:1.6;display:none;position:absolute;bottom:0;left:18px;box-shadow:0 4px 16px #00000080}.palette-hint-icon:hover .palette-hint-tooltip{display:block}.palette-hierarchy{font-size:11px;font-family:var(--font-mono);color:var(--text-muted);padding:0 14px 14px;line-height:1.8}.hier-line{color:#6868a0}.hier-indent{padding-left:12px}.hier-indent-2{padding-left:24px}.hier-indent-3{padding-left:36px}.studio-center{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.canvas-wrapper{flex:1;position:relative;overflow:hidden}.canvas-watermark{pointer-events:none;z-index:5;-webkit-user-select:none;user-select:none;align-items:baseline;gap:10px;display:flex;position:absolute;bottom:28px;right:80px}.watermark-k9{letter-spacing:-.5px;background:linear-gradient(135deg,#6366f122,#a78bfa22);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:800}.watermark-tag{letter-spacing:.12em;text-transform:uppercase;color:#2a2a45;font-size:11px;font-weight:300}.watermark-url{font-size:11px;font-family:var(--font-mono);color:#2a2a45}.canvas-empty{text-align:center;pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.canvas-empty-icon{color:var(--border-hover);margin-bottom:12px;font-size:40px}.canvas-empty-title{color:#3a3a55;margin-bottom:6px;font-size:15px;font-weight:600}.canvas-empty-sub{color:var(--text-dim);margin-bottom:10px;font-size:12px}.canvas-empty-hint{color:#2a2a40;font-size:11px}.react-flow__edge-path{stroke-width:2px}.react-flow__controls button{background:var(--panel)!important;border:1px solid var(--border)!important;color:var(--text)!important}.react-flow__controls button:hover{background:var(--surface)!important}.react-flow__minimap{overflow:hidden;border-radius:8px!important}.yaml-panel{background:var(--surface);border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;height:180px;display:flex}.yaml-header{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);flex-shrink:0;padding:6px 14px;font-size:10px;font-weight:700}.yaml-content{font-family:var(--font-mono);color:#7878a8;white-space:pre;flex:1;padding:10px 14px;font-size:11px;line-height:1.6;overflow:auto}.inspector{background:var(--panel);flex-direction:column;flex-shrink:0;width:100%;display:flex;overflow-y:auto}.inspector-header{letter-spacing:.1em;text-transform:uppercase;color:#9090b8;border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:6px;padding:12px 14px 8px;font-size:10px;font-weight:700;display:flex}.inspector-cop-lights{align-items:center;gap:5px;margin-left:auto;display:flex}.cop-light{opacity:.15;border-radius:50%;width:6px;height:6px}.cop-red{background:#e05050;animation:3.6s ease-in-out infinite cop-pulse}.cop-amber{background:#e09030;animation:3.6s ease-in-out 1.2s infinite cop-pulse}.cop-green{background:#50b870;animation:3.6s ease-in-out 2.4s infinite cop-pulse}@keyframes cop-pulse{0%,to{opacity:.12}50%{opacity:.65}}.inspector.empty .inspector-empty-msg{color:#7070a0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;font-size:13px;display:flex}.inspector-empty-icon{font-size:28px}.inspector-body{flex-direction:column;gap:12px;padding:12px;display:flex}.inspector-type-badge{letter-spacing:.06em;text-transform:uppercase;font-size:10px;font-weight:600;font-family:var(--font-mono);border-style:solid;border-width:1px;border-radius:4px;padding:4px 8px}.inspector-field{flex-direction:column;gap:5px;display:flex}.inspector-label{color:#9898c8;text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:600}.inspector-input{background:var(--surface);border:1px solid var(--border-hover);color:#8a8ab0;border-radius:6px;outline:none;width:100%;padding:7px 10px;font-family:inherit;font-size:12px;transition:border-color .15s}.inspector-input:focus{border-color:var(--accent)}.inspector-textarea{resize:vertical;min-height:60px}.inspector-abb{flex-direction:column;gap:4px;display:flex}.inspector-abb-code{font-family:var(--font-mono);color:#6366f1;background:#6366f111;border-radius:4px;padding:4px 8px;font-size:11px}.inspector-footer{background:#0a0a18;border-top:1px solid #1a1a30;margin-top:auto;padding:14px 14px 16px}.inspector-footer-title{letter-spacing:.1em;text-transform:uppercase;color:#8080b0;margin-bottom:7px;font-size:9px;font-weight:700}.inspector-footer-body{color:#7070a0;margin-bottom:10px;font-size:11px;line-height:1.6}.inspector-footer-tool{color:#818cf8;font-weight:600}.inspector-footer-links{align-items:center;gap:6px;font-size:10px;display:flex}.inspector-footer-links a{color:#7878b8;text-decoration:none;transition:color .15s}.inspector-footer-links a:hover{color:#a5b4fc}.inspector-footer-dot{color:#4a4a70}.inspector-feedback{border-top:1px solid #2a1a1a;padding:14px 14px 18px}.inspector-llm{border-top:1px solid #1a1a2a;padding:14px 14px 18px}.inspector-llm-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;padding:2px 0;display:flex}.inspector-llm-header:hover .inspector-llm-title{color:#e05050}.inspector-llm-title{letter-spacing:.1em;text-transform:uppercase;color:#c04040;flex:1;font-size:10px;font-weight:700;transition:color .15s}.llm-expand-arrow{color:#5a5a7a;font-size:9px}.llm-connected-tag{color:#50b870;white-space:nowrap;text-overflow:ellipsis;max-width:130px;font-size:10px;overflow:hidden}.llm-error-tag{color:#e05050;white-space:nowrap;text-overflow:ellipsis;max-width:130px;font-size:10px;overflow:hidden}.llm-config-fields{flex-direction:column;gap:6px;margin-top:8px;display:flex}.inspector-feedback-label{letter-spacing:.1em;text-transform:uppercase;color:#c04040;margin-bottom:8px;font-size:10px;font-weight:700}.inspector-feedback-textarea{box-sizing:border-box;color:#c8b86a;resize:none;background:#0e0e08;border:1px solid #3a3420;border-radius:6px;outline:none;width:100%;padding:10px 12px;font-family:inherit;font-size:12px;line-height:1.6;transition:border-color .15s}.inspector-feedback-textarea::placeholder{color:#5a5030}.inspector-feedback-textarea:focus{border-color:#6a5c2a}.inspector-feedback-btn{color:#c04040;cursor:pointer;background:0 0;border:1px solid #c04040;border-radius:6px;width:100%;margin-top:8px;padding:7px 0;font-size:11px;transition:all .15s}.inspector-feedback-btn:hover:not(:disabled){color:#e05050;border-color:#e05050}.inspector-feedback-btn:disabled{opacity:.3;cursor:not-allowed}.inspector-feedback-ok{color:#8ab870;text-align:center;margin-top:6px;font-size:11px}.inspector-feedback-err{color:#b87070;text-align:center;margin-top:6px;font-size:11px}.inspector-icon{color:#f59e0b}.inspector-section-label{letter-spacing:.1em;text-transform:uppercase;color:#c04040;border-top:1px solid var(--border);padding-top:4px;font-size:10px;font-weight:700}.inspector-row{gap:8px;display:flex}.inspector-row .inspector-field{flex:1}[data-theme=light]{--bg:#1e1e2a;--surface:#252535;--panel:#2a2a3e;--border:#32324a;--border-hover:#44445e;--text:#d8d8f0;--text-muted:#88a;--text-dim:#4a4a65;--accent:#818cf8;--accent-hover:#a5b4fc}[data-theme=light] .canvas-header-watermark{color:#c0c0d8}[data-theme=light] .watermark-tag,[data-theme=light] .watermark-url{color:#c8c8dc}[data-theme=light] .bottom-content{color:#8888b8;background:#fafafe}[data-theme=light] .gen-overlay{background:#f0f0f8d9}[data-theme=light] .connection-toast{color:#c53030;background:#fff4f4;border-color:#ef444466}.studio-left{background:var(--panel);border-right:1px solid var(--border);flex-shrink:0;overflow-y:auto}.studio-right{background:var(--panel);border-left:1px solid var(--border);flex-shrink:0;overflow-y:auto}.canvas-area{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.pane-resizer{background:var(--border);cursor:col-resize;z-index:10;flex-shrink:0;width:5px;transition:background .15s;position:relative}.pane-resizer:hover{background:var(--accent)}.header-center{pointer-events:none;flex-direction:column;align-items:center;gap:2px;display:flex;position:absolute;left:50%;transform:translate(-50%)}.header-workdir{color:#7a6830;letter-spacing:.02em;white-space:nowrap;text-overflow:ellipsis;max-width:420px;font-size:9px;overflow:hidden}.header-workdir code{color:#a08840;font-family:var(--font-mono);font-size:9px}.header-framework{letter-spacing:.35em;text-transform:uppercase;color:#7070a8;font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:11px;font-weight:300}.header-sep{background:var(--border-hover);width:1px;height:18px;margin:0 4px}.header-visit-counter{background:#0e0a16;border:1px solid #2a1a40;border-radius:5px;flex-direction:column;align-items:center;padding:2px 8px;line-height:1.1;display:flex}.visit-count{font-family:var(--font-mono);color:#9060c0;letter-spacing:.05em;font-size:13px;font-weight:700}.visit-label{color:#4a3a5a;text-transform:uppercase;letter-spacing:.08em;font-size:9px}.btn-icon{border:1px solid var(--border-hover);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:5px 9px;font-size:13px;line-height:1;transition:all .15s}.btn-icon:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.btn-icon:disabled{opacity:.28;cursor:not-allowed}.canvas-header-watermark{letter-spacing:.38em;text-transform:uppercase;color:#2a2a45;pointer-events:none;z-index:5;-webkit-user-select:none;user-select:none;white-space:nowrap;font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:11px;font-weight:300;position:absolute;top:14px;left:50%;transform:translate(-50%)}.connection-toast{color:#fca5a5;z-index:100;pointer-events:none;white-space:nowrap;background:#130e1e;border:1px solid #ef444444;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-size:12px;animation:.2s toast-in;display:flex;position:absolute;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0006}.toast-icon{color:#f59e0b;font-size:13px}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.bottom-panel{background:var(--surface);border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex;position:relative}.bottom-resizer{background:var(--border);cursor:row-resize;z-index:10;flex-shrink:0;height:5px;transition:background .15s;position:absolute;top:0;left:0;right:0}.bottom-resizer:hover{background:var(--accent)}.bottom-tabs{background:var(--panel);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:0;margin-top:5px;padding:0 4px;display:flex}.bottom-tab{color:#9898c8;cursor:pointer;font-size:11px;font-weight:500;font-family:var(--font-mono);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:7px 14px;transition:all .15s}.bottom-tab:hover{color:#d0d0f0}.bottom-tab.active{color:#f59e0b;border-bottom-color:#f59e0b}.bottom-tabs-spacer{flex:1}.bottom-height-hint{color:#7070a0;font-size:10px;font-family:var(--font-mono);-webkit-user-select:none;user-select:none;padding-right:8px}.bottom-content{font-family:var(--font-mono);color:#a0a0c8;white-space:pre;background:var(--surface);flex:1;padding:12px 18px;font-size:12.5px;line-height:1.8;overflow:auto}.gen-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:#0a0a12e0;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.gen-card{background:var(--surface);border:1px solid #6366f133;border-radius:16px;flex-direction:column;align-items:center;gap:16px;width:430px;padding:28px 32px;display:flex;box-shadow:0 24px 80px #0009,0 0 0 1px #ffffff08}.gen-logo{align-items:baseline;gap:6px;display:flex}.gen-spinner{justify-content:center;align-items:center;display:flex}.gen-spinner-ring{border:3px solid #6366f133;border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.gen-steps{flex-direction:column;gap:5px;width:100%;display:flex}.gen-phase-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);border-top:1px solid var(--border);margin-top:6px;padding-top:6px;font-size:9px;font-weight:700}.gen-phase-inspector{color:#f59e0b44}.gen-inspector-icon{color:#f59e0b}.gen-step{opacity:0;align-items:center;gap:10px;transition:opacity .3s,transform .3s;display:flex;transform:translate(-6px)}.gen-step-visible{opacity:1;transform:translate(0)}.gen-step-dot{width:14px;color:var(--accent);text-align:center;flex-shrink:0;font-size:11px}.gen-step-text{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.gen-step-visible .gen-step-text{color:var(--text)}.gen-step-inspect.gen-step-visible .gen-step-text{color:#f5c97a}.gen-footer{color:var(--text-dim);text-align:center;font-size:10px}.palette-project{border-bottom:1px solid var(--border);flex-direction:column;gap:6px;padding:12px 10px 10px;display:flex}.palette-project-label{letter-spacing:.1em;text-transform:uppercase;color:#c04040;margin-bottom:1px;font-size:10px;font-weight:700}.palette-project-sublabel{letter-spacing:.08em;text-transform:uppercase;color:#5a5a90;margin-top:8px;margin-bottom:3px;font-size:9px;font-weight:600}.palette-project-input{color:#c0c0e0;background:#111120;border:1px solid #2a2a44;border-radius:5px;outline:none;width:100%;padding:6px 9px;font-family:inherit;font-size:11px;transition:border-color .15s,color .15s}.palette-project-input:focus{border-color:var(--accent);color:#c8c8ee;background:#14142a}.palette-project-input:not(:placeholder-shown){color:#c0c0e0}.palette-project-input::placeholder{color:#5a5a80;font-size:10.5px}.palette-project-row{gap:5px;display:flex}.palette-project-row .palette-project-input{flex:1;min-width:0}.palette-project-folder-row{align-items:center;gap:4px;margin-top:1px;display:flex}.palette-project-folder{font-family:var(--font-mono);flex:1;font-size:10px}.palette-browse-btn{color:#7070a0;cursor:pointer;background:#111120;border:1px solid #2a2a44;border-radius:5px;flex-shrink:0;padding:4px 8px;font-size:13px;line-height:1;transition:all .15s}.palette-browse-btn:hover{border-color:var(--accent);color:#a0a0cc}.palette-folder-hint{color:#818cf8;font-size:10px;font-family:var(--font-mono);word-break:break-all;padding:2px 2px 0}.palette-folder-hint code{color:#a5b4fc}.palette-container-path-info{background:#1a1a28;border:1px solid #2d2d45;border-radius:6px;flex-direction:column;gap:3px;margin:4px 0 6px;padding:8px 10px;display:flex}.palette-container-path-label{text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-size:9px;font-family:var(--font-mono)}.palette-container-path{color:#a5b4fc;font-size:10px;font-family:var(--font-mono);word-break:break-all;white-space:pre-wrap}.palette-container-path-hint{color:#64748b;font-size:10px;font-family:var(--font-mono);word-break:break-all}.palette-container-path-hint code{color:#818cf8}.palette-bpmn-import{border-bottom:1px solid var(--border);flex-direction:column;gap:6px;padding:10px 10px 8px;display:flex}.palette-bpmn-label{cursor:pointer;display:block}.palette-bpmn-btn{color:#7070a8;text-align:center;letter-spacing:.04em;background:#111120;border:1px dashed #3a3a5a;border-radius:6px;padding:8px 12px;font-size:11px;transition:all .15s;display:block}.palette-bpmn-label:hover .palette-bpmn-btn{color:#9898c8;background:#14142a;border-color:#6366f155}.palette-bpmn-hint{color:#3a3a58;text-align:center;letter-spacing:.03em;font-size:10px}.palette-bpmn-loading{opacity:.6;cursor:wait}.palette-bpmn-error{color:#f87171;background:#1a0a0a;border:1px solid #ef444430;border-radius:5px;padding:5px 8px;font-size:10.5px}.palette-bpmn-ok{color:#34d399;background:#0a1a12;border:1px solid #10b98130;border-radius:5px;padding:5px 8px;font-size:10.5px}.palette-templates{border-bottom:1px solid var(--border);padding:6px 10px 8px}.palette-template-select{color:#8a8ab0;cursor:pointer;background:#111120;border:1px solid #2a2a44;border-radius:5px;outline:none;width:100%;margin-top:5px;padding:6px 8px;font-size:11px;transition:border-color .15s}.palette-template-select:hover{border-color:#6366f155}.palette-template-select:focus{border-color:var(--accent)}.palette-template-select option{color:#8a8ab0;background:#111120}.palette-platforms{border-bottom:1px solid var(--border);padding:10px}.platform-group-label{letter-spacing:.1em;text-transform:uppercase;color:#c04040;margin-bottom:5px;font-size:9px;font-weight:700}.platform-pills{flex-wrap:wrap;gap:5px;display:flex}.platform-pill{color:#c8b86a;cursor:pointer;letter-spacing:.02em;background:0 0;border:1px solid #3a3a5a;border-radius:12px;padding:3px 9px;font-size:10px;font-weight:500;transition:all .15s}.platform-pill:hover{color:#e0d080;border-color:#c8b86a}.platform-pill-active{font-weight:600}.palette-describe{border-bottom:1px solid var(--border);flex-direction:column;gap:8px;padding:12px 10px 10px;display:flex}.palette-describe-label{letter-spacing:.1em;text-transform:uppercase;color:#c04040;font-size:10px;font-weight:700}.palette-describe-textarea{color:#8a8ab0;resize:vertical;background:#111120;border:1px solid #2a2a44;border-radius:6px;outline:none;min-height:120px;padding:8px 10px;font-family:inherit;font-size:11px;line-height:1.6;transition:border-color .15s}.palette-describe-textarea:focus{border-color:var(--accent);color:#8a8ab0}.palette-describe-textarea::placeholder{color:#3a3a58}.palette-no-llm-note{color:#3a3a68;letter-spacing:.01em;margin-top:8px;font-size:10px;line-height:1.5}.palette-generate-btn{color:#a78bfa;cursor:pointer;text-align:center;letter-spacing:.03em;background:linear-gradient(135deg,#6366f118,#8b5cf618);border:1px solid #6366f140;border-radius:8px;padding:9px;font-size:12px;font-weight:600;transition:all .2s}.palette-generate-btn:hover:not(:disabled){border-color:var(--accent);color:#fff;background:linear-gradient(135deg,#6366f130,#8b5cf630)}.palette-generate-btn:disabled{opacity:.38;cursor:not-allowed}.palette-generate-footer{border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:6px;margin-top:auto;padding:10px;display:flex}.palette-generate-btn-green{background:var(--surface);color:#4a9e78;cursor:pointer;text-align:center;letter-spacing:.08em;text-transform:uppercase;border:1px solid #2a2a44;border-radius:8px;width:100%;padding:12px 16px;font-size:12px;font-weight:300;transition:all .2s}.palette-generate-btn-green:hover:not(:disabled){color:#6ee7b7;background:#0a1a12;border-color:#10b98166}.palette-generate-btn-green:active:not(:disabled){transform:scale(.98)}.palette-generate-btn-green:disabled{opacity:.35;cursor:not-allowed}.palette-scaffold-btn{background:var(--surface);color:#4a9e78;cursor:pointer;text-align:center;letter-spacing:.08em;text-transform:uppercase;border:1px solid #2a2a44;border-radius:8px;width:100%;padding:10px 16px;font-size:12px;font-weight:300;transition:all .2s}.palette-scaffold-btn:hover:not(:disabled){color:#6ee7b7;background:#0a1a12;border-color:#10b98166}.palette-scaffold-btn:active:not(:disabled){transform:scale(.98)}.palette-scaffold-btn:disabled{opacity:.35;cursor:not-allowed}.palette-context-hint{color:#818cf8;background:#6366f110;border-bottom:1px solid #6366f120;padding:6px 14px;font-size:11px}.hint-arrow{color:var(--accent);font-weight:700}.palette-item-dimmed{opacity:.25;cursor:not-allowed!important}.palette-item-highlighted{background:#1e1e35!important}.palette-valid-badge{flex-shrink:0;font-size:12px;font-weight:700}.palette-invalid-badge{color:#3a3a4a;flex-shrink:0;font-size:12px}.export-toast{z-index:200;pointer-events:none;white-space:nowrap;border-radius:8px;padding:9px 18px;font-size:12px;animation:.2s toast-in;position:absolute;top:54px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0006}.export-toast-ok{color:#6ee7b7;background:#0a1a12;border:1px solid #10b98144}.export-toast-err{color:#fca5a5;background:#1a0a0a;border:1px solid #ef444444}.scaffold-done-overlay{z-index:900;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0008;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.scaffold-done-card{text-align:center;background:#0e0e1e;border:1px solid #2a2a50;border-radius:16px;width:90%;max-width:480px;padding:40px 44px;animation:.25s toast-in;box-shadow:0 24px 64px #0009}.scaffold-done-icon{color:#4a9e78;margin-bottom:14px;font-size:32px}.scaffold-done-title{color:#e2e2f0;letter-spacing:.02em;margin-bottom:8px;font-size:20px;font-weight:700}.scaffold-done-path{font-size:12px;font-family:var(--font-mono);color:#a5b4fc;word-break:break-all;background:#12122a;border:1px solid #2a2a44;border-radius:6px;margin-bottom:4px;padding:6px 12px}.scaffold-done-container-path{font-size:9px;font-family:var(--font-mono);color:#475569;word-break:break-all;margin-bottom:16px}.scaffold-done-body{color:#8080b0;margin-bottom:22px;font-size:13px;line-height:1.7}.scaffold-done-rec{color:#5050a0;text-transform:uppercase;letter-spacing:.08em;justify-content:center;align-items:center;gap:10px;margin-bottom:10px;font-size:11px;display:flex}.scaffold-done-tool{color:#a78bfa;text-transform:none;letter-spacing:0;background:#1e1040;border:1px solid #6366f144;border-radius:6px;padding:3px 10px;font-size:12px;font-weight:700}.scaffold-done-hint{color:#4a4a80;margin-bottom:28px;font-size:11px;line-height:1.6}.scaffold-done-hint code{color:#7070b0;font-family:var(--font-mono)}.scaffold-done-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;display:flex}.scaffold-download-btn{color:#f97316;cursor:pointer;letter-spacing:.02em;background:0 0;border:1px solid #f9731644;border-radius:8px;padding:10px 22px;font-size:13px;font-weight:600;transition:all .15s}.scaffold-download-btn:hover:not(:disabled){background:#f9731610;border-color:#f97316}.scaffold-download-btn:active:not(:disabled){transform:scale(.98)}.scaffold-download-btn:disabled{opacity:.45;cursor:not-allowed}.scaffold-done-btn{color:#6060a0;cursor:pointer;background:0 0;border:1px solid #2a2a50;border-radius:8px;padding:9px 28px;font-size:12px;transition:all .15s}.scaffold-done-btn:hover{color:#a5b4fc;background:#1a1a30;border-color:#6366f1}.palette-download-btn{color:#f97316;cursor:pointer;letter-spacing:.02em;background:0 0;border:1px solid #f9731444;border-radius:8px;width:100%;margin-top:2px;padding:10px 0;font-size:13px;font-weight:600;transition:all .15s}.palette-download-btn:hover:not(:disabled){background:#f9731610;border-color:#f97316}.palette-download-btn:active:not(:disabled){transform:scale(.98)}.palette-download-btn:disabled{opacity:.45;cursor:not-allowed}.palette-llm-divider{background:#1f1f30;height:1px;margin:8px 0 6px}.palette-llm-bar{align-items:center;gap:6px;padding:2px 0;display:flex}.llm-status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;transition:background .3s}.llm-dot-on{background:#50b870;box-shadow:0 0 5px #50b87060}.llm-dot-off{background:#3a3a55}.llm-status-text{color:#9090b8;flex:1;font-size:11px}.llm-config-btn{color:#9060c0;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #4c2e6644;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:600;transition:border-color .15s,color .15s}.llm-config-btn:hover{color:#b080e0;border-color:#7040a0}.llm-config-panel{background:#0e0e1a;border:1px solid #2a1a40;border-radius:6px;flex-direction:column;gap:6px;margin-bottom:6px;padding:10px;display:flex}.llm-config-panel-title{color:#9060c0;align-items:center;gap:6px;margin-bottom:2px;font-size:11px;font-weight:600;display:flex}.llm-optional-tag{color:#5a5a7a;text-transform:uppercase;letter-spacing:.05em;border:1px solid #2a2a3a;border-radius:3px;padding:1px 5px;font-size:9px;font-weight:500}.llm-config-row{align-items:center;gap:6px;display:flex}.llm-config-label{color:#6a5a8a;text-align:right;min-width:54px;font-size:10px}.llm-config-input{color:#8a8ab0;font-size:11px;font-family:var(--font-mono);background:#13131e;border:1px solid #2a1a40;border-radius:4px;outline:none;flex:1;padding:4px 7px}.llm-config-input:focus{border-color:#7040a0}.llm-config-actions{gap:6px;margin-top:2px;display:flex}.llm-save-btn{color:#c080f0;cursor:pointer;background:#3a1a5a;border:1px solid #6030a0;border-radius:4px;padding:4px 14px;font-size:11px;font-weight:600;transition:background .15s}.llm-save-btn:hover:not(:disabled){background:#4a2a6a}.llm-save-btn:disabled{opacity:.5;cursor:not-allowed}.llm-clear-btn{color:#5a5a7a;cursor:pointer;background:0 0;border:1px solid #2a2a3a;border-radius:4px;padding:4px 10px;font-size:11px;transition:border-color .15s,color .15s}.llm-clear-btn:hover{color:#8a8aaa;border-color:#4a4a6a}.llm-session-note{color:#c04040;text-align:center;padding-top:4px;font-size:10px;font-weight:600}.llm-verify-ok{color:#50b870;padding:3px 0 1px;font-size:11px}.llm-verify-err{color:#e05050;padding:3px 0 1px;font-size:11px}.activity-log{border-top:1px solid #1e1e38;flex-shrink:0;padding:10px 12px 12px}.activity-log-label{letter-spacing:.1em;text-transform:uppercase;color:#c04040;margin-bottom:5px;font-size:9px;font-weight:700}.activity-log-body{max-height:140px;font-family:var(--font-mono);background:#0a0a18;border:1px solid #1e1e38;border-radius:5px;padding:5px 7px;font-size:10px;overflow-y:auto}.activity-log-empty{color:#3a3a4a;padding:2px 0;font-style:italic}.activity-log-entry{gap:6px;padding:1px 0;line-height:1.4;display:flex}.log-ts{color:#3a3a4a;flex-shrink:0}.log-info .log-msg{color:#4a4a5a}.log-warn .log-msg{color:#5a5040}.log-error .log-msg{color:#5a3838}.activity-log-header{justify-content:space-between;align-items:center;margin-bottom:5px;display:flex}.llm-access-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.llm-access-off{background:#2a2a44}.llm-access-on{background:#d070c0;animation:1s ease-in-out infinite llm-pulse}@keyframes llm-pulse{0%,to{opacity:1;box-shadow:0 0 4px #d070c0}50%{opacity:.4;box-shadow:none}}.context-menu{background:var(--surface);border:1px solid var(--border-hover);z-index:1000;border-radius:8px;min-width:170px;padding:4px;position:fixed;box-shadow:0 8px 24px #0006}.context-menu-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;text-overflow:ellipsis;padding:6px 12px 4px;font-size:10px;font-weight:600;overflow:hidden}.context-menu-divider{background:var(--border);height:1px;margin:3px 0}.context-menu-item{width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:4px;align-items:center;gap:8px;padding:7px 12px;font-size:12px;transition:background .1s;display:flex}.context-menu-item:hover{background:var(--border)}.context-menu-danger{color:#ef4444}.context-menu-danger:hover{background:#ef444420!important}.react-flow{--xy-edge-stroke-default:#b1b1b7;--xy-edge-stroke-width-default:1;--xy-edge-stroke-selected-default:#555;--xy-connectionline-stroke-default:#b1b1b7;--xy-connectionline-stroke-width-default:1;--xy-attribution-background-color-default:#ffffff80;--xy-minimap-background-color-default:#fff;--xy-minimap-mask-background-color-default:#f0f0f099;--xy-minimap-mask-stroke-color-default:transparent;--xy-minimap-mask-stroke-width-default:1;--xy-minimap-node-background-color-default:#e2e2e2;--xy-minimap-node-stroke-color-default:transparent;--xy-minimap-node-stroke-width-default:2;--xy-background-color-default:transparent;--xy-background-pattern-dots-color-default:#91919a;--xy-background-pattern-lines-color-default:#eee;--xy-background-pattern-cross-color-default:#e2e2e2;background-color:var(--xy-background-color,var(--xy-background-color-default));--xy-node-color-default:inherit;--xy-node-border-default:1px solid #1a192b;--xy-node-background-color-default:#fff;--xy-node-group-background-color-default:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #00000014;--xy-node-boxshadow-selected-default:0 0 0 .5px #1a192b;--xy-node-border-radius-default:3px;--xy-handle-background-color-default:#1a192b;--xy-handle-border-color-default:#fff;--xy-selection-background-color-default:#0059dc14;--xy-selection-border-default:1px dotted #0059dccc;--xy-controls-button-background-color-default:#fefefe;--xy-controls-button-background-color-hover-default:#f4f4f4;--xy-controls-button-color-default:inherit;--xy-controls-button-color-hover-default:inherit;--xy-controls-button-border-color-default:#eee;--xy-controls-box-shadow-default:0 0 2px 1px #00000014;--xy-edge-label-background-color-default:#fff;--xy-edge-label-color-default:inherit;--xy-resize-background-color-default:#3367d9;direction:ltr}.react-flow.dark{--xy-edge-stroke-default:#3e3e3e;--xy-edge-stroke-width-default:1;--xy-edge-stroke-selected-default:#727272;--xy-connectionline-stroke-default:#b1b1b7;--xy-connectionline-stroke-width-default:1;--xy-attribution-background-color-default:#96969640;--xy-minimap-background-color-default:#141414;--xy-minimap-mask-background-color-default:#3c3c3c99;--xy-minimap-mask-stroke-color-default:transparent;--xy-minimap-mask-stroke-width-default:1;--xy-minimap-node-background-color-default:#2b2b2b;--xy-minimap-node-stroke-color-default:transparent;--xy-minimap-node-stroke-width-default:2;--xy-background-color-default:#141414;--xy-background-pattern-dots-color-default:#777;--xy-background-pattern-lines-color-default:#777;--xy-background-pattern-cross-color-default:#777;--xy-node-color-default:#f8f8f8;--xy-node-border-default:1px solid #3c3c3c;--xy-node-background-color-default:#1e1e1e;--xy-node-group-background-color-default:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #ffffff14;--xy-node-boxshadow-selected-default:0 0 0 .5px #999;--xy-handle-background-color-default:#bebebe;--xy-handle-border-color-default:#1e1e1e;--xy-selection-background-color-default:#c8c8dc14;--xy-selection-border-default:1px dotted #c8c8dccc;--xy-controls-button-background-color-default:#2b2b2b;--xy-controls-button-background-color-hover-default:#3e3e3e;--xy-controls-button-color-default:#f8f8f8;--xy-controls-button-color-hover-default:#fff;--xy-controls-button-border-color-default:#5b5b5b;--xy-controls-box-shadow-default:0 0 2px 1px #00000014;--xy-edge-label-background-color-default:#141414;--xy-edge-label-color-default:#f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props,var(--xy-background-color,var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke,var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width,var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke,var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width,var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{pointer-events:none;position:absolute;overflow:visible}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected,var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke,var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke,var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:.5s linear infinite dashdraw}svg.react-flow__connectionline{z-index:1001;position:absolute;overflow:visible}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{-webkit-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default;position:absolute}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;background-color:var(--xy-handle-background-color,var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color,var(--xy-handle-border-color-default));border-radius:100%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:0;left:50%;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{z-index:5;margin:15px;position:absolute}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px)translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px)translateY(-50%)}.react-flow__attribution{background:var(--xy-attribution-background-color,var(--xy-attribution-background-color-default));margin:0;padding:2px 3px;font-size:10px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10px}}.react-flow__edgelabel-renderer{pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__viewport-portal{-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__minimap{background:var(--xy-minimap-background-color-props,var(--xy-minimap-background-color,var(--xy-minimap-background-color-default)))}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var(--xy-minimap-mask-background-color-props,var(--xy-minimap-mask-background-color,var(--xy-minimap-mask-background-color-default)));stroke:var(--xy-minimap-mask-stroke-color-props,var(--xy-minimap-mask-stroke-color,var(--xy-minimap-mask-stroke-color-default)));stroke-width:var(--xy-minimap-mask-stroke-width-props,var(--xy-minimap-mask-stroke-width,var(--xy-minimap-mask-stroke-width-default)))}.react-flow__minimap-node{fill:var(--xy-minimap-node-background-color-props,var(--xy-minimap-node-background-color,var(--xy-minimap-node-background-color-default)));stroke:var(--xy-minimap-node-stroke-color-props,var(--xy-minimap-node-stroke-color,var(--xy-minimap-node-stroke-color-default)));stroke-width:var(--xy-minimap-node-stroke-width-props,var(--xy-minimap-node-stroke-width,var(--xy-minimap-node-stroke-width-default)))}.react-flow__background-pattern.dots{fill:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-dots-color-default)))}.react-flow__background-pattern.lines{stroke:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-lines-color-default)))}.react-flow__background-pattern.cross{stroke:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-cross-color-default)))}.react-flow__controls{box-shadow:var(--xy-controls-box-shadow,var(--xy-controls-box-shadow-default));flex-direction:column;display:flex}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{background:var(--xy-controls-button-background-color,var(--xy-controls-button-background-color-default));border:none;border-bottom:1px solid var(--xy-controls-button-border-color-props,var(--xy-controls-button-border-color,var(--xy-controls-button-border-color-default)));width:26px;height:26px;color:var(--xy-controls-button-color-props,var(--xy-controls-button-color,var(--xy-controls-button-color-default)));cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:4px;display:flex}.react-flow__controls-button svg{fill:currentColor;width:100%;max-width:12px;max-height:12px}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{border-radius:var(--xy-node-border-radius,var(--xy-node-border-radius-default));width:150px;color:var(--xy-node-color,var(--xy-node-color-default));text-align:center;border:var(--xy-node-border,var(--xy-node-border-default));background-color:var(--xy-node-background-color,var(--xy-node-background-color-default));padding:10px;font-size:12px}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover,var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected,var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color,var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color,var(--xy-selection-background-color-default));border:var(--xy-selection-border,var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var(--xy-controls-button-background-color-hover-props,var(--xy-controls-button-background-color-hover,var(--xy-controls-button-background-color-hover-default)));color:var(--xy-controls-button-color-hover-props,var(--xy-controls-button-color-hover,var(--xy-controls-button-color-hover-default)))}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var(--xy-controls-button-border-color-props,var(--xy-controls-button-border-color,var(--xy-controls-button-border-color-default)))}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border:1px solid #fff;border-radius:1px;width:5px;height:5px;translate:-50% -50%}.react-flow__resize-control.handle.left{top:50%;left:0}.react-flow__resize-control.handle.right{top:50%;left:100%}.react-flow__resize-control.handle.top{top:0;left:50%}.react-flow__resize-control.handle.bottom{top:100%;left:50%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border-style:solid;border-width:0}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;height:100%;top:0;transform:translate(-50%)}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{width:100%;height:1px;left:0;transform:translateY(-50%)}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color,var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color,var(--xy-edge-label-color-default))}
