:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.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))}*{box-sizing:border-box;margin:0;padding:0}:root{--bg-dark:#000;--bg-panel:#0a0a0a;--bg-card:#111;--border:#222;--text:#fff;--text-muted:#888;--primary:#0f0;--primary-hover:#0c0;--success:#0f8;--danger:#f44;--warning:#fc0;--lime:#0f0;--cyan:#0ff}body.light-mode{--bg-dark:#f5f5f5;--bg-panel:#fff;--bg-card:#fff;--border:#e0e0e0;--text:#1a1a1a;--text-muted:#666;--primary:#0a0;--primary-hover:#080;--success:#0a6;--danger:#d33;--warning:#c90;--lime:#0a0;--cyan:#09c}body.light-mode .react-flow__background{background:#fafafa!important}body.light-mode .react-flow__node{box-shadow:0 2px 8px #0000001a!important}body.light-mode .react-flow__edge-path{stroke:#888!important}body.light-mode .react-flow__controls button{color:#333!important;background:#fff!important;border-color:#ddd!important}body.light-mode .react-flow__controls button:hover{background:#f0f0f0!important}body.light-mode .react-flow__minimap{background:#fff!important;border:1px solid #e0e0e0!important}body.light-mode .node-base{background:#fff!important;border-color:#e0e0e0!important;box-shadow:0 2px 8px #0000001a!important}body.light-mode .node-base:hover{box-shadow:0 4px 16px #00000026!important}body.light-mode .node-palette,body.light-mode .config-panel,body.light-mode .top-bar{background:#fff!important;border-color:#e0e0e0!important}body.light-mode .palette-section{background:#f8f8f8!important;border-color:#e8e8e8!important}body.light-mode .palette-node{background:#fff!important;border-color:#e0e0e0!important}body.light-mode .palette-node:hover{background:#f0fff0!important;border-color:#0a0!important}body.light-mode .section-header{border-color:#e0e0e0!important}body.light-mode input,body.light-mode select,body.light-mode textarea{color:#1a1a1a!important;background:#f8f8f8!important;border-color:#d0d0d0!important}body.light-mode input:focus,body.light-mode select:focus,body.light-mode textarea:focus{border-color:#0a0!important}body.light-mode .btn-secondary{color:#333!important;background:#f0f0f0!important;border-color:#d0d0d0!important}body.light-mode .btn-secondary:hover{background:#e0e0e0!important}body{background:var(--bg-dark);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.top-bar{background:var(--bg-panel);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:20px;padding:12px 20px;display:flex}.top-bar-left,.top-bar-center,.top-bar-right{align-items:center;gap:12px;display:flex}.logo{align-items:center;gap:8px;font-size:18px;font-weight:700;display:flex}.logo-icon{font-size:24px}.flow-name-input{background:var(--bg-card);border:1px solid var(--border);color:var(--text);border-radius:6px;width:200px;padding:8px 12px;font-size:14px}.flow-name-input:focus{border-color:var(--primary);outline:none}@keyframes btnShine{0%{left:-100%}to{left:100%}}@keyframes btnGradient{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.btn-primary{background:linear-gradient(135deg, var(--primary) 0%, #0c0 50%, var(--primary) 100%);color:var(--bg-dark);cursor:pointer;text-transform:uppercase;letter-spacing:.5px;background-size:200% 200%;border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:12px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.btn-primary:before{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.btn-primary:hover{animation:2s infinite btnGradient;transform:translateY(-2px);box-shadow:0 8px 25px #0f06}.btn-primary:hover:before{animation:.6s btnShine}.btn-primary:active{transform:translateY(0);box-shadow:0 4px 15px #00ff004d}.btn-secondary{background:linear-gradient(135deg, var(--bg-card) 0%, #ffffff0d 100%);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.btn-secondary:before{content:"";background:linear-gradient(90deg,#0000,#ffffff1a,#0000);width:100%;height:100%;position:absolute;top:0;left:-100%}.btn-secondary:hover{background:linear-gradient(135deg,#8b5cf61a 0%,#8b5cf60d 100%);border-color:#8b5cf6;transform:translateY(-2px);box-shadow:0 8px 20px #8b5cf633}.btn-secondary:hover:before{animation:.6s btnShine}.btn-tool{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 14px;font-size:13px;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative}.btn-tool:after{content:"";background:var(--primary);width:0;height:2px;transition:all .3s;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}.btn-tool:hover:not(:disabled){color:var(--text);background:#8b5cf61a;transform:translateY(-1px)}.btn-tool:hover:not(:disabled):after{width:60%}.btn-tool:disabled{opacity:.4;cursor:not-allowed}.btn-icon{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 12px;font-size:16px;transition:all .25s cubic-bezier(.4,0,.2,1)}.btn-icon:hover{color:var(--text);background:#8b5cf626;transform:scale(1.1)}.btn-danger{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px 20px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 8px 25px #ef444466}.btn-danger:active{transform:translateY(0)}.main-content{flex:1;display:flex;overflow:hidden}.node-palette{background:var(--bg-panel);border-right:1px solid var(--border);flex-direction:column;width:260px;display:flex;overflow-y:auto}.palette-header{color:var(--text-primary);border-bottom:1px solid var(--border);padding:16px;font-size:14px;font-weight:600}.node-group{border-bottom:1px solid var(--border)}.group-header{cursor:pointer;background:#ffffff05;align-items:center;gap:8px;padding:10px 12px;transition:background .2s;display:flex}.group-header:hover{background:#ffffff0d}.group-icon{font-size:14px}.group-name{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;flex:1;font-size:11px;font-weight:600}.group-toggle{color:var(--text-muted);font-size:10px}.group-nodes{background:#0000001a;flex-direction:column;gap:6px;padding:8px;display:flex}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 5px var(--node-color,#8b5cf6)}50%{box-shadow:0 0 20px var(--node-color,#8b5cf6), 0 0 30px var(--node-color,#8b5cf6)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes iconPop{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.group-nodes{flex-direction:column;gap:8px;display:flex}.group-nodes .palette-node{opacity:0;animation:.3s ease-out forwards slideIn}.group-nodes .palette-node:first-child{animation-delay:50ms}.group-nodes .palette-node:nth-child(2){animation-delay:.1s}.group-nodes .palette-node:nth-child(3){animation-delay:.15s}.group-nodes .palette-node:nth-child(4){animation-delay:.2s}.group-nodes .palette-node:nth-child(5){animation-delay:.25s}.group-nodes .palette-node:nth-child(6){animation-delay:.3s}.group-nodes .palette-node:nth-child(7){animation-delay:.35s}.group-nodes .palette-node:nth-child(8){animation-delay:.4s}.palette-node{background:linear-gradient(135deg, var(--bg-card) 0%, #ffffff05 100%);border:1px solid var(--border);cursor:grab;border-left:4px solid var(--node-color);border-radius:12px;align-items:center;gap:12px;padding:12px 14px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.palette-node:before{content:"";background:linear-gradient(90deg,#0000,#ffffff1a,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.palette-node:hover:before{left:100%}.palette-node:hover{border-color:var(--node-color);background:linear-gradient(135deg, rgba(var(--node-color-rgb,139,92,246), .1) 0%, rgba(var(--node-color-rgb,139,92,246), .05) 100%);box-shadow:0 4px 20px #0000004d, 0 0 15px rgba(var(--node-color-rgb,139,92,246), .2);transform:translate(8px)scale(1.02)}.palette-node:hover .palette-node-icon{animation:.4s iconPop}.palette-node:active{cursor:grabbing;transform:translate(8px)scale(.98)}.template-node{background:linear-gradient(135deg, var(--bg-card) 0%, #8b5cf626 100%);border:1px dashed #8b5cf680;cursor:pointer!important}.template-node:hover{background:linear-gradient(135deg,#8b5cf633 0%,#8b5cf64d 100%);border-style:solid;animation:2s infinite pulseGlow}.template-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#8b5cf6 0%,#a855f7 100%);border-radius:6px;padding:3px 8px;font-size:9px;font-weight:700;animation:2s infinite bounce}.addon-node{background:linear-gradient(135deg, var(--bg-card) 0%, #8b5cf614 100%);border-left:4px solid #8b5cf6}.addon-node:hover{background:linear-gradient(135deg,#8b5cf626 0%,#8b5cf640 100%);box-shadow:0 4px 20px #0000004d,0 0 20px #8b5cf64d}.addon-badge{font-size:14px;animation:1.5s infinite bounce}.hub-node{background:linear-gradient(135deg,#8b5cf633 0%,#6366f133 100%);position:relative;border:2px solid #8b5cf6!important;border-left-width:4px!important}.hub-node:after{content:"";z-index:-1;opacity:0;background:linear-gradient(135deg,#8b5cf6,#06b6d4,#8b5cf6) 0 0/200% 200%;border-radius:14px;transition:opacity .3s;animation:3s linear infinite shimmer;position:absolute;inset:-2px}.hub-node:hover:after{opacity:.5}.hub-node:hover{transform:translate(8px)scale(1.05);box-shadow:0 8px 30px #8b5cf666,0 0 40px #8b5cf633}.hub-badge{color:#fff;letter-spacing:1px;text-shadow:0 1px 2px #0000004d;background:linear-gradient(135deg,#8b5cf6 0%,#06b6d4 50%,#8b5cf6 100%) 0 0/200% 100%;border-radius:6px;padding:4px 10px;font-size:9px;font-weight:800;animation:2s linear infinite shimmer}.group-hint{color:#a78bfa;background:linear-gradient(135deg,#8b5cf61a 0%,#8b5cf60d 100%);border:1px solid #8b5cf633;border-radius:8px;align-items:center;gap:6px;margin-bottom:10px;padding:8px 14px;font-size:11px;animation:.3s ease-out slideIn;display:flex}.palette-node-icon{font-size:18px}.palette-node-info{flex-direction:column;flex:1;min-width:0;display:flex}.palette-node-label{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.palette-node-desc{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.palette-footer{border-top:1px solid var(--border);margin-top:auto;padding:16px}.palette-tip{color:var(--text-muted);background:var(--bg-card);border-radius:6px;padding:10px;font-size:11px;line-height:1.5}.flow-editor{background:var(--bg-dark);flex:1}.react-flow__node{cursor:pointer}.node-base{background:var(--bg-card);border:2px solid var(--border);border-radius:10px;align-items:center;gap:10px;min-width:160px;padding:12px 16px;transition:all .2s;display:flex;box-shadow:0 4px 12px #0000004d}.node-base:hover{box-shadow:0 6px 20px #0006}.node-icon{font-size:24px}.node-content{flex-direction:column;display:flex}.node-title{font-size:13px;font-weight:600}.node-subtitle{color:var(--text-muted);font-size:11px}.node-options{color:var(--text-muted);margin-top:4px;font-size:10px}.menu-option{padding:2px 0}.node-incoming{border-color:#22c55e}.node-ring{border-color:#3b82f6}.node-ai{border-color:#0f0}.node-ai-compact{cursor:pointer;background:linear-gradient(145deg,#1a1a2e 0%,#0f0f1a 100%);border:2px solid #8b5cf6;border-radius:12px;min-width:140px;padding:0;transition:all .3s;overflow:hidden}.node-ai-compact:hover{border-color:#a78bfa;transform:translateY(-2px);box-shadow:0 4px 20px #8b5cf64d}.node-ai-compact.selected{border-color:#0f0;box-shadow:0 0 20px #00ff004d}.ai-compact-header{background:linear-gradient(135deg,#8b5cf6 0%,#6366f1 100%);align-items:center;gap:8px;padding:10px 12px;display:flex}.ai-icon{font-size:20px}.ai-label{color:#fff;flex:1;font-size:13px;font-weight:700}.ai-edit{opacity:.7;font-size:14px;transition:opacity .2s}.node-ai-compact:hover .ai-edit{opacity:1}.ai-powers-row{background:#0000004d;justify-content:center;gap:6px;padding:8px 10px;display:flex}.ai-power{opacity:.3;cursor:pointer;border-radius:6px;padding:4px;font-size:16px;transition:all .2s}.ai-power.active{opacity:1;box-shadow:0 0 8px var(--power-color);background:#ffffff1a}.ai-power:hover{transform:scale(1.2)}.node-ai-compact .handle-in,.node-ai-compact .handle-out{background:#8b5cf6!important;border:2px solid #1a1a2e!important;width:12px!important;height:12px!important}.node-ai-compact .handle-in:hover,.node-ai-compact .handle-out:hover{transform:scale(1.3);background:#0f0!important}.node-config-overlay{z-index:1000;background:#000c;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.node-config-modal{background:linear-gradient(145deg,#1a1a2e 0%,#0f0f1a 100%);border:2px solid #8b5cf6;border-radius:16px;width:90%;max-width:400px;max-height:80vh;animation:.3s slideUp;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.config-header{background:linear-gradient(135deg,#8b5cf6 0%,#6366f1 100%);justify-content:space-between;align-items:center;padding:16px 20px;font-size:16px;font-weight:700;display:flex}.config-close{color:#fff;cursor:pointer;background:#0000004d;border:none;border-radius:8px;width:28px;height:28px;font-size:18px;transition:all .2s}.config-close:hover{background:#fff3;transform:scale(1.1)}.config-body{flex-direction:column;gap:16px;max-height:60vh;padding:20px;display:flex;overflow-y:auto}.config-field{flex-direction:column;gap:8px;display:flex}.config-field label{color:#a78bfa;text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.config-field input,.config-field textarea{color:#fff;background:#0000004d;border:1px solid #333;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .2s}.config-field input:focus,.config-field textarea:focus{border-color:#8b5cf6;outline:none}.powers-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.power-toggle{color:#888;cursor:pointer;background:#0000004d;border:1px solid #333;border-radius:8px;align-items:center;gap:8px;padding:10px 12px;font-size:13px;transition:all .2s;display:flex}.power-toggle:hover{border-color:var(--power-color);color:#fff}.power-toggle.active{border-color:var(--power-color);color:#fff;box-shadow:0 0 10px var(--power-color);background:#8b5cf633}.power-toggle span:first-child{font-size:18px}.config-link{border-top:1px solid #333;padding-top:8px}.config-link a{color:#8b5cf6;align-items:center;gap:4px;font-size:13px;text-decoration:none;transition:color .2s;display:flex}.config-link a:hover{color:#a78bfa}.node-compact{border:2px solid var(--node-accent,#8b5cf6);cursor:pointer;background:linear-gradient(145deg,#1a1a2e 0%,#0f0f1a 100%);border-radius:10px;min-width:120px;padding:0;transition:all .3s;overflow:hidden}.node-compact:hover{box-shadow:0 4px 15px #0006, 0 0 15px color-mix(in srgb, var(--node-accent) 30%, transparent);transform:translateY(-2px)}.node-compact.selected{border-color:#0f0;box-shadow:0 0 15px #00ff004d}.compact-content{background:linear-gradient(135deg, var(--node-accent) 0%, color-mix(in srgb, var(--node-accent) 70%, #000) 100%);align-items:center;gap:8px;padding:10px 12px;display:flex}.compact-icon{font-size:18px}.compact-label{color:#fff;white-space:nowrap;flex:1;font-size:12px;font-weight:600}.compact-config{opacity:0;font-size:12px;transition:opacity .2s}.node-compact:hover .compact-config{opacity:.8}.handle-compact{transition:all .2s;background:var(--node-accent,#8b5cf6)!important;border:2px solid #0f0f1a!important;width:10px!important;height:10px!important}.handle-compact:hover{transform:scale(1.4);background:#0f0!important}.handle-yes{background:#22c55e!important}.handle-no{background:#ef4444!important}.toggle-btn{color:#888;cursor:pointer;text-align:center;background:#0000004d;border:1px solid #333;border-radius:8px;padding:10px 16px;font-size:13px;transition:all .2s}.toggle-btn:hover{border-color:#8b5cf6}.toggle-btn.active{color:#22c55e;background:#22c55e33;border-color:#22c55e}.field-hint{color:#666;font-size:11px;font-style:italic}@keyframes hubPulse{0%,to{box-shadow:0 0 20px #8b5cf64d}50%{box-shadow:0 0 40px #8b5cf699,0 0 60px #8b5cf64d}}@keyframes hubGlow{0%{border-color:#8b5cf6}50%{border-color:#06b6d4}to{border-color:#8b5cf6}}@keyframes robotBounce{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-2px)rotate(-5deg)}75%{transform:translateY(-2px)rotate(5deg)}}@keyframes addonSlideIn{0%{opacity:0;transform:scale(.8)translateY(5px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes handlePulse{0%,to{transform:scale(1);box-shadow:0 0 5px}50%{transform:scale(1.2);box-shadow:0 0 15px,0 0 25px}}@keyframes emptyIconFloat{0%,to{opacity:.3;transform:translateY(0)}50%{opacity:.6;transform:translateY(-4px)}}.node-ai-hub{background:linear-gradient(145deg,#1a1a2e 0%,#0f0f1a 50%,#16213e 100%);border:3px solid #8b5cf6;border-radius:20px;min-width:240px;padding:0;transition:all .4s cubic-bezier(.4,0,.2,1);animation:4s ease-in-out infinite hubGlow;overflow:visible}.node-ai-hub:hover{animation:1.5s ease-in-out infinite hubPulse;transform:scale(1.02)}.node-ai-hub.selected{border-color:#0f0;animation:none;box-shadow:0 0 30px #0f06,0 0 60px #0f03}.node-ai-hub.has-addons{border-color:#0f0;box-shadow:0 0 25px #00ff004d}.node-hub-header{background:linear-gradient(135deg,#8b5cf6 0%,#6366f1 50%,#4f46e5 100%);align-items:center;gap:14px;padding:18px 20px;display:flex;position:relative;overflow:hidden}.node-hub-header:before{content:"";background:linear-gradient(45deg,#0000,#ffffff1a,#0000);width:200%;height:200%;animation:3s linear infinite shimmer;position:absolute;top:-50%;left:-50%;transform:rotate(45deg)}.node-icon-large{filter:drop-shadow(0 4px 8px #0006);z-index:1;font-size:36px;animation:3s ease-in-out infinite robotBounce;position:relative}.node-hub-title{z-index:1;flex:1;position:relative}.node-hub-title .node-title{color:#fff;text-shadow:0 2px 4px #0000004d;letter-spacing:.5px;margin-bottom:4px;font-size:18px;font-weight:800}.node-hub-title .node-subtitle{color:#ffffffe6;font-size:11px;font-weight:500}.node-addons-container{background:linear-gradient(#0006 0%,#0003 100%);border-top:1px solid #8b5cf64d;padding:14px 18px}.node-addons-label{text-transform:uppercase;letter-spacing:1px;color:#a78bfa;margin-bottom:10px;font-size:10px;font-weight:600}.node-addons-grid{flex-wrap:wrap;gap:8px;display:flex}.node-addon-badge{cursor:pointer;background:linear-gradient(135deg,#00000080 0%,#0000004d 100%);border:1px solid;border-radius:8px;align-items:center;gap:6px;padding:6px 10px;font-size:11px;transition:all .2s;animation:.3s ease-out forwards addonSlideIn;display:flex}.node-addon-badge:hover{background:linear-gradient(135deg,#ffffff1a 0%,#ffffff0d 100%);transform:scale(1.05);box-shadow:0 2px 10px #0000004d}.node-addon-badge .addon-icon{font-size:14px}.node-addon-badge .addon-label{color:#e0e0e0;font-weight:500}.node-addons-empty{text-align:center;background:linear-gradient(#0000004d 0%,#0000001a 100%);border-top:1px solid #8b5cf633;padding:16px 18px}.node-addons-empty .empty-hint{color:#888;margin-bottom:12px;font-size:11px;font-style:italic}.node-addons-empty .empty-icons{justify-content:center;gap:12px;font-size:20px;display:flex}.node-addons-empty .empty-icons span{cursor:pointer;transition:all .2s;animation:2s ease-in-out infinite emptyIconFloat}.node-addons-empty .empty-icons span:first-child{animation-delay:0s}.node-addons-empty .empty-icons span:nth-child(2){animation-delay:.2s}.node-addons-empty .empty-icons span:nth-child(3){animation-delay:.4s}.node-addons-empty .empty-icons span:nth-child(4){animation-delay:.6s}.node-addons-empty .empty-icons span:hover{transform:scale(1.3)translateY(-4px);opacity:1!important}.handle-addon{z-index:10;transition:all .3s cubic-bezier(.4,0,.2,1);background:#8b5cf6!important;border:2px solid #1a1a2e!important;width:12px!important;height:12px!important}.handle-addon:hover{animation:1s ease-in-out infinite handlePulse;transform:scale(1.5);box-shadow:0 0 20px #0f0;background:#0f0!important}.handle-main{background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%)!important;border:2px solid #0f172a!important;width:16px!important;height:16px!important}.handle-main:hover{transform:scale(1.4);box-shadow:0 0 15px #22c55e}.handle-transfer{background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%)!important}.handle-transfer:hover{box-shadow:0 0 15px #14b8a6}.addon-count-badge{color:#000;text-align:center;background:linear-gradient(135deg,#0f0 0%,#22c55e 100%);border-radius:20px;min-width:24px;padding:4px 10px;font-size:12px;font-weight:800;animation:2s infinite bounce;box-shadow:0 2px 10px #0f06}.addon-remove{opacity:0;color:#ef4444;cursor:pointer;margin-left:auto;padding:0 4px;font-size:16px;font-weight:700;transition:all .2s}.node-addon-badge:hover .addon-remove{opacity:1}.addon-remove:hover{color:#f87171;transform:scale(1.2)}.quick-add-panel{z-index:100;background:linear-gradient(145deg,#1a1a2e 0%,#0f0f1a 100%);border:2px solid #8b5cf6;border-radius:12px;min-width:200px;padding:12px;animation:.2s ease-out slideIn;position:absolute;bottom:-120px;left:50%;transform:translate(-50%);box-shadow:0 10px 40px #00000080}.quick-add-title{text-transform:uppercase;letter-spacing:1px;color:#a78bfa;margin-bottom:8px;font-size:10px;font-weight:600}.quick-add-grid{flex-wrap:wrap;gap:6px;display:flex}.quick-add-btn{border:1px solid var(--btn-color,#8b5cf6);color:#fff;cursor:pointer;background:#0000004d;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:11px;transition:all .2s;display:flex}.quick-add-btn:hover{box-shadow:0 0 15px var(--btn-color,#8b5cf666);background:#8b5cf633;transform:scale(1.05)}.node-menu{border-color:#f97316;min-height:100px}.node-voicemail{border-color:#6b7280}.node-transfer{border-color:#14b8a6}.node-email{border-color:#eab308}.node-calendar{border-color:#10b981}.node-hours{border-color:#f59e0b;min-width:180px}.node-vip{border-color:#fbbf24;min-width:180px}.node-language{border-color:#06b6d4;min-width:200px}.node-sms{border-color:#22c55e}.node-coming-soon{opacity:.7}.coming-soon-badge{color:#fff;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border-radius:4px;margin-top:4px;padding:2px 6px;font-size:9px;display:inline-block}.coming-soon-banner{text-align:center;background:#f59e0b33;border:1px solid #f59e0b;border-radius:6px;margin-bottom:16px;padding:10px;font-size:12px}.output-lang{color:#06b6d4;background:#06b6d433}.handle-lang{background:#06b6d4!important}.checkbox-grid{background:var(--bg-card);border-radius:6px;grid-template-columns:1fr 1fr;gap:6px;max-height:200px;padding:8px;display:grid;overflow-y:auto}.node-lead{border-color:#ec4899}.node-payment{border-color:#22c55e;min-width:180px}.node-features{gap:4px;margin-top:4px;display:flex}.feature-tag{font-size:12px}.output-paid{color:#22c55e;background:#22c55e33}.output-declined{color:#ef4444;background:#ef444433}.handle-paid{background:#22c55e!important}.handle-declined{background:#ef4444!important}.handle-fallback{background:#f97316!important}.node-transfer{min-width:170px}.node-voicemail{min-width:160px}.node-webhook{border-color:#0ff;min-width:180px}.node-endcall{background:linear-gradient(135deg, var(--bg-card) 0%, #ef44441a 100%);border-color:#ef4444}.method-badge{color:#fff;border-radius:3px;margin-right:4px;padding:1px 4px;font-size:9px;font-weight:600;display:inline-block}.output-success{color:#22c55e;background:#22c55e33}.output-error{color:#ef4444;background:#ef444433}.handle-success{background:#22c55e!important}.handle-error{background:#ef4444!important}.node-outputs{flex-direction:column;gap:4px;margin-top:6px;font-size:10px;display:flex}.output-label{border-radius:3px;padding:2px 6px;font-weight:500}.output-open{color:#22c55e;background:#22c55e33}.output-closed{color:#ef4444;background:#ef444433}.output-vip{color:#fbbf24;background:#fbbf2433}.output-normal{color:#94a3b8;background:#94a3b833}.handle-open{background:#22c55e!important}.handle-closed{background:#ef4444!important}.handle-vip{background:#fbbf24!important}.handle-normal{background:#94a3b8!important}.node-badge{color:#10b981;background:#10b98133;border-radius:4px;margin-top:4px;padding:2px 6px;font-size:10px}.config-section-header{color:var(--primary);border-bottom:1px solid var(--border);margin-bottom:12px;padding-bottom:8px;font-size:12px;font-weight:600}.checkbox-group{flex-direction:column;gap:8px;display:flex}.checkbox-label{cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.config-info{background:var(--bg-card);color:var(--text-muted);border-radius:6px;padding:10px;font-size:11px;line-height:1.6}.handle-source,.handle-target{background:var(--primary)!important;border:2px solid var(--bg-card)!important;width:12px!important;height:12px!important}.handle-bottom{top:auto!important;bottom:-6px!important}.config-panel{background:var(--bg-panel);border-left:1px solid var(--border);flex-direction:column;width:300px;display:flex}.config-empty{justify-content:center;align-items:center}.empty-state{text-align:center;color:var(--text-muted)}.empty-icon{margin-bottom:12px;font-size:48px;display:block}.config-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px;display:flex}.config-header h3{font-size:14px;font-weight:600}.config-body{flex:1;padding:16px;overflow-y:auto}.config-field{margin-bottom:16px}.config-field label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.config-field input,.config-field textarea,.config-field select{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text);border-radius:6px;padding:10px 12px;font-family:inherit;font-size:13px}.config-field textarea{resize:vertical;min-height:80px}.config-field input:focus,.config-field textarea:focus,.config-field select:focus{border-color:var(--primary);outline:none}.config-field small{color:var(--text-muted);margin-top:4px;font-size:11px;display:block}.menu-option-row{gap:8px;margin-bottom:8px;display:flex}.menu-option-row input:first-child{text-align:center}.config-footer{border-top:1px solid var(--border);padding:16px}.react-flow__controls{background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #0000004d}.react-flow__controls-button{background:var(--bg-panel)!important;border-bottom:1px solid var(--border)!important;fill:var(--text)!important}.react-flow__controls-button:hover{background:var(--bg-card)!important}.react-flow__minimap{border:1px solid var(--border);border-radius:8px;background:var(--bg-panel)!important}@keyframes connectPulse{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}to{opacity:1;transform:scale(1)}}@keyframes sparkle{0%,to{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1)}}.react-flow__edge-path{stroke-linecap:round}.react-flow__connection-line{stroke-width:3px;filter:drop-shadow(0 0 8px #0f0);stroke:#0f0!important}.handle-source:hover,.handle-target:hover{transition:all .2s;transform:scale(1.3);box-shadow:0 0 12px #0f0,0 0 24px #0f0}.react-flow__node.selected .node-base{box-shadow:0 0 20px #8b5cf699,0 0 40px #8b5cf64d}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-panel)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#446}.toolbar-divider{background:var(--border);width:1px;height:24px;margin:0 8px}.btn-tool.active{background:var(--primary);color:#fff}.btn-test{color:#fff;cursor:pointer;background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);border:none;border-radius:6px;padding:8px 16px;font-weight:600;transition:all .2s}.btn-test:hover{transform:translateY(-1px);box-shadow:0 4px 12px #22c55e66}.modal-overlay{z-index:1000;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-panel);border:1px solid var(--border);border-radius:12px;min-width:400px;max-width:500px}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px;display:flex}.modal-header h2{font-size:18px;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:24px}.modal-close:hover{color:var(--text)}.modal-body{padding:20px}.modal-body p{color:var(--text-muted);margin-bottom:16px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:12px;padding:16px 20px;display:flex}.test-phone-input input{background:var(--bg-card);border:2px solid var(--border);width:100%;color:var(--text);text-align:center;border-radius:8px;padding:14px;font-size:18px}.test-phone-input input:focus{border-color:var(--primary);outline:none}.test-info{flex-direction:column;gap:8px;margin-top:20px;display:flex}.test-info-item{color:var(--text-muted);font-size:14px}.btn-call{background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%)!important}.btn-call:hover{box-shadow:0 4px 12px #22c55e66}.live-preview{background:var(--bg-panel);border-left:1px solid var(--border);flex-direction:column;width:280px;display:flex}.preview-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px;font-weight:600;display:flex}.preview-hint{color:var(--text-muted);font-size:11px;font-weight:400}.preview-content{flex:1;padding:16px;overflow-y:auto}.preview-empty{color:var(--text-muted);text-align:center;padding:40px 20px}.preview-flow{flex-direction:column;gap:12px;display:flex}.preview-step{background:var(--bg-card);border-left:3px solid var(--primary);border-radius:8px;gap:12px;padding:12px;transition:all .2s;display:flex}.preview-step.selected{border-left-color:var(--success);background:#22c55e1a}.step-number{background:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:600;display:flex}.step-content{flex:1;min-width:0}.step-type{color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-size:11px}.step-script{font-size:13px;line-height:1.4}.preview-footer{border-top:1px solid var(--border);padding:16px}.ai-suggestion{color:var(--text-muted);font-size:12px;line-height:1.5}.ai-suggestion strong{color:var(--warning)}.test-simulator{background:var(--bg-panel);border:1px solid var(--border);border-radius:20px;width:380px;overflow:hidden;box-shadow:0 25px 50px #00000080}.sim-header{background:linear-gradient(135deg,#0f0 0%,#0ff 100%);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.sim-status{font-size:14px;font-weight:600}.sim-phone{padding:20px}.phone-screen{background:var(--bg-dark);border-radius:16px;flex-direction:column;min-height:350px;padding:20px;display:flex}.call-info{text-align:center;border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:20px}.caller-avatar{margin-bottom:8px;font-size:48px}.caller-name{font-size:18px;font-weight:600}.call-timer{color:var(--text-muted);margin-top:4px;font-size:14px}.transcript-area{flex-direction:column;flex:1;gap:12px;max-height:200px;display:flex;overflow-y:auto}.transcript-item{border-radius:12px;gap:8px;padding:10px 12px;font-size:13px;line-height:1.4;display:flex}.transcript-item.ai{background:#8b5cf633;border:1px solid #8b5cf64d}.transcript-item.user{background:#22c55e33;border:1px solid #22c55e4d}.transcript-item.system{color:var(--text-muted);background:#ffffff0d;font-size:12px}.transcript-item .speaker{flex-shrink:0}.speaking-indicator,.listening-indicator{color:var(--text-muted);justify-content:center;align-items:center;gap:4px;padding:12px;display:flex}.speaking-indicator .dot{background:var(--primary);border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite pulse}.speaking-indicator .dot:nth-child(2){animation-delay:.2s}.speaking-indicator .dot:nth-child(3){animation-delay:.4s}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.listening-indicator{color:var(--success);animation:1.5s ease-in-out infinite pulse}.phone-controls{justify-content:center;gap:16px;margin-top:20px;display:flex}.control-btn{cursor:pointer;background:var(--bg-card);color:var(--text);border:none;border-radius:30px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .2s}.control-btn:hover{transform:scale(1.05)}.control-btn.end-btn{background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%)}.control-btn.restart-btn{background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%)}.sim-footer{background:var(--bg-card);color:var(--text-muted);justify-content:space-between;padding:12px 20px;font-size:12px;display:flex}.current-node{color:var(--primary);font-weight:500}.tests-remaining{color:var(--success);margin-top:8px;font-size:11px}.tests-remaining.low{color:var(--warning)}.panel-toggle{background:var(--bg-panel);border:1px solid var(--border);color:var(--text);cursor:pointer;z-index:100;writing-mode:vertical-rl;text-orientation:mixed;border-radius:0 8px 8px 0;padding:12px 8px;font-size:12px;transition:all .2s;position:fixed;top:50%;transform:translateY(-50%)}.panel-toggle:hover{background:var(--primary);border-color:var(--primary)}.panel-toggle.left{border-left:none;border-radius:0 8px 8px 0;left:0}.panel-toggle.right{writing-mode:vertical-lr;border-right:none;border-radius:8px 0 0 8px;right:0}.no-flow-warning{color:var(--warning);margin-top:8px;font-size:12px}.loading-screen{background:var(--bg-dark);flex-direction:column;justify-content:center;align-items:center;height:100vh;display:flex}.loading-spinner{font-size:48px;animation:1s ease-in-out infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.connected-banner{color:#fff;text-align:center;background:linear-gradient(90deg,#22c55e 0%,#16a34a 100%);padding:4px;font-size:12px;font-weight:500}.unsaved-dot{color:#f59e0b;margin-left:8px;animation:2s infinite pulse}.btn-primary.saving{opacity:.7;cursor:wait}.save-status{color:var(--success);margin-left:8px}.save-error{color:var(--danger);cursor:help;margin-left:8px}.error-toast{background:var(--danger);color:#fff;z-index:1000;border-radius:8px;padding:12px 24px;animation:.3s ease-out slideUp;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}
