.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.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 .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation: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:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.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-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.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:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.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{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.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{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.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:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}:root{--bg-primary: #1a1f2e;--bg-secondary: #252b3b;--bg-tertiary: #2d3548;--connection-cyan: #00ffff;--connection-orange: #ff9500;--connection-red: #ff3366;--connection-green: #00ff88;--connection-blue: #4a9eff;--connection-purple: #aa55ff;--text-primary: #e0e6f0;--text-secondary: #9aa5b8;--text-muted: #6b7280;--node-shadow: rgba(0, 0, 0, .5);--node-glow: rgba(0, 255, 255, .08);--node-border: rgba(255, 255, 255, .1);--port-input: #00ffff;--port-output: #00ffff;--port-size: 10px;--border-radius: 8px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);overflow:hidden}#root{width:100vw;height:100vh}.react-flow{background-color:var(--bg-primary)}.react-flow__background{background-color:var(--bg-primary);background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:20px 20px}.react-flow__edge-path{stroke-width:2px;transition:all .3s ease}.react-flow__edge.selected .react-flow__edge-path{stroke-width:3px}.react-flow__edge:hover .react-flow__edge-path{stroke-width:2.5px}.react-flow__edge.edge-evaluating .react-flow__edge-path{stroke-width:3px}.flow-particle{pointer-events:none}.react-flow__edge-path{stroke-linecap:round;stroke-linejoin:round}.custom-node{background:var(--bg-secondary);border:1px solid var(--node-border);border-radius:var(--border-radius);box-shadow:0 4px 12px var(--node-shadow);padding:0;min-width:180px;font-size:13px;transition:all .3s cubic-bezier(.4,0,.2,1)}.custom-node:hover{box-shadow:0 6px 16px var(--node-shadow);transform:translateY(-2px);border-color:#00ffff4d}.custom-node.selected{border-color:var(--connection-cyan);box-shadow:0 4px 16px var(--node-shadow);transform:translateY(-1px)}.node-header{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#ffffff08;border-bottom:1px solid var(--node-border);border-radius:var(--border-radius) var(--border-radius) 0 0;font-weight:500}.node-icon{width:18px;height:18px;flex-shrink:0}.node-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.node-content{padding:10px 12px;color:var(--text-secondary);font-size:12px}.node-data-item{margin:4px 0;display:flex;justify-content:space-between;gap:8px}.node-data-label{color:var(--text-muted);font-weight:500}.node-data-value{color:var(--text-primary);font-family:Monaco,Courier New,monospace}.react-flow__handle{width:var(--port-size);height:var(--port-size);border:2px solid var(--bg-secondary);background:var(--port-input);transition:all .3s cubic-bezier(.4,0,.2,1)}.react-flow__handle:hover{width:14px;height:14px;transform:scale(1.1)}.react-flow__handle-connecting{animation:pulse .6s cubic-bezier(.4,0,.2,1) infinite}.react-flow__handle-valid{background:#0f8}.port-cyan{background:var(--connection-cyan)!important}.port-orange{background:var(--connection-orange)!important}.port-red{background:var(--connection-red)!important}.port-green{background:var(--connection-green)!important}.port-blue{background:var(--connection-blue)!important}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.react-flow__controls{background:var(--bg-secondary);border:1px solid var(--node-border);border-radius:var(--border-radius);box-shadow:0 4px 12px var(--node-shadow)}.react-flow__controls-button{background:var(--bg-tertiary);border-bottom:1px solid var(--node-border);color:var(--text-primary);transition:all .2s ease}.react-flow__controls-button:hover{background:#00ffff1a;color:var(--connection-cyan)}.react-flow__minimap{background:var(--bg-secondary);border:1px solid var(--node-border);border-radius:var(--border-radius)}.react-flow__minimap-mask{fill:#00ffff1a;stroke:var(--connection-cyan)}.react-flow__minimap-node{fill:var(--bg-tertiary);stroke:var(--node-border)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#00ffff4d}.react-flow__nodesselection-rect,.react-flow__selection{background:#00ffff14;border:1px solid var(--connection-cyan)}.node-editor-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.node-editor-modal{background:var(--bg-secondary);border:1px solid var(--node-border);border-radius:12px;width:90%;max-width:700px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #00000080;animation:slideUp .3s ease}.node-editor-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--node-border)}.node-editor-header h2{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;border-radius:4px;transition:all .2s}.close-btn:hover{background:#ffffff0d;color:var(--text-primary)}.node-editor-tabs{display:flex;gap:4px;padding:0 20px;border-bottom:1px solid var(--node-border);background:#0003}.tab{background:none;border:none;color:var(--text-secondary);padding:12px 20px;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;font-size:14px;font-weight:500}.tab:hover{color:var(--text-primary);background:#ffffff08}.tab.active{color:var(--connection-cyan);border-bottom-color:var(--connection-cyan)}.code-editor-content{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px}.code-section{display:flex;flex-direction:column}.code-section h3{margin:0 0 8px;font-size:12px;font-weight:700;letter-spacing:1px;color:var(--connection-cyan);text-transform:uppercase}.code-hint{font-size:11px;color:var(--text-muted);margin-bottom:8px;font-style:italic}.code-textarea{width:100%;background:var(--bg-primary);border:1px solid var(--node-border);border-radius:6px;padding:12px;color:var(--text-primary);font-family:Monaco,Courier New,Consolas,monospace;font-size:13px;line-height:1.5;resize:vertical;transition:all .2s}.code-textarea:focus{outline:none;border-color:var(--connection-cyan);box-shadow:0 0 0 3px #00ffff26;background:#0000004d}.code-textarea.code-main{background:#0006;border-color:var(--connection-cyan);border-width:2px}.editor-section h3{margin:0 0 8px;font-size:16px;color:var(--text-primary)}.hint{color:var(--text-secondary);font-size:13px;margin:0 0 16px}.expression-field,.data-field{margin-bottom:20px}.expression-field label,.data-field label{display:block;margin-bottom:8px;color:var(--text-primary);font-weight:500;font-size:14px}.expression-field textarea,.data-field input{width:100%;background:var(--bg-tertiary);border:1px solid var(--node-border);border-radius:6px;padding:10px;color:var(--text-primary);font-family:Monaco,Courier New,monospace;font-size:13px;resize:vertical;transition:all .2s}.expression-field textarea:focus,.data-field input:focus{outline:none;border-color:var(--connection-cyan);box-shadow:0 0 0 3px #00ffff1a}.hint-text{margin-top:6px;font-size:11px;color:var(--text-muted);font-style:italic}.empty-state{text-align:center;padding:40px;color:var(--text-muted);font-style:italic}.info-grid{display:flex;flex-direction:column;gap:12px}.info-item{padding:12px;background:var(--bg-tertiary);border-radius:6px;color:var(--text-primary)}.info-grid h4{margin:16px 0 8px;color:var(--text-primary);font-size:14px}.port-info{padding:8px 12px;background:var(--bg-tertiary);border-radius:4px;font-size:13px;color:var(--text-secondary)}.port-info code{color:var(--connection-cyan);font-weight:600}.node-editor-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px;border-top:1px solid var(--node-border)}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s;border:1px solid}.btn-primary{background:var(--connection-cyan);color:var(--bg-primary);border-color:var(--connection-cyan)}.btn-primary:hover{background:#00e6e6;border-color:#00e6e6;transform:translateY(-1px);box-shadow:0 4px 12px #00ffff4d}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--node-border)}.btn-secondary:hover{background:#ffffff0d;border-color:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.palette-toggle{position:absolute;left:0;top:70px;background:var(--bg-secondary);border:1px solid var(--node-border);border-left:none;border-radius:0 6px 6px 0;padding:8px 6px;cursor:pointer;display:flex;align-items:center;color:var(--text-primary);transition:all .2s;z-index:100}.palette-toggle:hover{background:var(--bg-tertiary);color:var(--connection-cyan)}.node-palette{position:absolute;left:0;top:50px;bottom:0;width:250px;background:var(--bg-secondary);border-right:1px solid var(--node-border);display:flex;flex-direction:column;z-index:100;animation:slideIn .3s ease}.palette-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--node-border)}.palette-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary)}.palette-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;border-radius:4px;transition:all .2s}.palette-close:hover{background:#ffffff0d;color:var(--text-primary)}.palette-content{flex:1;overflow-y:auto;padding:8px}.palette-category{margin-bottom:8px}.category-header{width:100%;background:none;border:none;color:var(--text-primary);padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;text-align:left;border-radius:4px;transition:all .2s}.category-header:hover{background:#ffffff0d}.category-items{display:flex;flex-direction:column;gap:4px;padding:4px 0 4px 24px}.node-template{background:var(--bg-tertiary);border:1px solid var(--node-border);border-left:3px solid;border-radius:4px;padding:10px 12px;cursor:pointer;display:flex;align-items:center;gap:8px;color:var(--text-primary);font-size:13px;transition:all .2s;text-align:left}.node-template:hover{background:#ffffff14;border-color:var(--connection-cyan);transform:translate(2px)}.node-template svg{flex-shrink:0}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}
