@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap);:root{--primary:#6366f1;--primary-dark:#4f46e5;--primary-light:#eef2ff;--slate-50:#f8fafc;--slate-100:#f1f5f9;--slate-200:#e2e8f0;--slate-300:#cbd5e1;--slate-400:#94a3b8;--slate-500:#64748b;--slate-700:#334155;--slate-900:#0f172a;--shadow-sm:0 1px 2px 0 rgba(0,0,0,.05);--shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}body{-webkit-font-smoothing:antialiased;background-color:#fff;color:#0f172a;color:var(--slate-900);font-family:Inter,-apple-system,sans-serif;height:100vh;margin:0;overflow:hidden}.app-container{display:flex;flex-direction:column;height:100vh}.main-header{background:#fff;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--slate-200);height:60px;justify-content:space-between;padding:0 20px;z-index:20}.header-logo,.main-header{align-items:center;display:flex}.header-logo{gap:10px}.logo-icon{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);background:linear-gradient(135deg,var(--primary) 0,#8b5cf6 100%);border-radius:6px;box-shadow:0 2px 4px rgba(99,102,241,.3);color:#fff;display:flex;font-size:12px;font-weight:800;height:28px;justify-content:center;width:28px}.header-logo h1{color:#0f172a;color:var(--slate-900);font-size:16px;font-weight:600;letter-spacing:-.02em;margin:0}.pipeline-toolbar{background:#fff;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--slate-200);display:flex;gap:8px;overflow-x:auto;padding:8px 20px;scrollbar-width:none;z-index:10}.pipeline-toolbar::-webkit-scrollbar{display:none}.canvas-container{background-color:#fafafa;flex:1 1;position:relative}.submit-button{background:#6366f1;background:var(--primary);border:none;border-radius:8px;box-shadow:0 1px 2px 0 rgba(0,0,0,.05);box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .15s ease-in-out}.submit-button:hover{background:#4f46e5;background:var(--primary-dark);box-shadow:0 0 0 3px #eef2ff;box-shadow:0 0 0 3px var(--primary-light)}.clear-button{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--slate-200);border-radius:8px;color:#64748b;color:var(--slate-500);cursor:pointer;font-size:13px;font-weight:500;padding:8px 14px;transition:all .2s}.clear-button:hover{background-color:#fff1f2;border-color:#fecdd3;color:#e11d48}.modal-overlay{align-items:center;-webkit-animation:fadeIn .2s ease-out;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:rgba(15,23,42,.4);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.alert-box{-webkit-animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);background:#fff;border:1px solid #e2e8f0;border:1px solid var(--slate-200);border-radius:16px;box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);box-shadow:var(--shadow-lg);max-width:400px;padding:24px;width:100%}.alert-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.alert-header h2{color:#0f172a;color:var(--slate-900);font-size:18px;font-weight:600;margin:0}.alert-content{color:var(--slate-600);font-size:14px;line-height:1.6;margin-bottom:24px}.alert-stats{background:#f8fafc;background:var(--slate-50);border-radius:8px;margin-top:12px;padding:12px}.alert-stat-item{display:flex;font-family:monospace;justify-content:space-between;margin-bottom:4px}.alert-close-btn{background:#0f172a;background:var(--slate-900);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px;transition:opacity .2s;width:100%}.alert-close-btn:hover{opacity:.9}@-webkit-keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@-webkit-keyframes slideUp{0%{opacity:0;-webkit-transform:translateY(20px);transform:translateY(20px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;-webkit-transform:translateY(20px);transform:translateY(20px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}.draggable-node-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border:1px solid var(--slate-200);border-radius:8px;color:#334155;color:var(--slate-700);cursor:grab;display:flex;font-size:12px;font-weight:500;gap:8px;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.draggable-node-item:hover{background:#eef2ff;background:var(--primary-light);border-color:#6366f1;border-color:var(--primary);color:#6366f1;color:var(--primary);-webkit-transform:translateY(-1px);transform:translateY(-1px)}.react-flow{z-index:1}.react-flow__controls{border:1px solid #e2e8f0!important;border:1px solid var(--slate-200)!important;border-radius:8px!important;box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)!important;box-shadow:var(--shadow-lg)!important;flex-direction:column!important;gap:0!important;overflow:hidden}.react-flow__controls,.react-flow__controls-button{background-color:#fff!important;display:flex!important}.react-flow__controls-button{fill:#64748b!important;fill:var(--slate-500)!important;align-items:center!important;border-bottom:1px solid #f1f5f9!important;border-bottom:1px solid var(--slate-100)!important;border-right:none!important;height:32px!important;justify-content:center!important;width:32px!important}.react-flow__controls-button:hover{fill:#6366f1!important;fill:var(--primary)!important;background-color:#f8fafc!important;background-color:var(--slate-50)!important}.react-flow__controls-button:last-child{border-bottom:none!important}.react-flow__minimap{background-color:#fff!important;border:1px solid #e2e8f0!important;border:1px solid var(--slate-200)!important;border-radius:12px!important;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)!important;box-shadow:var(--shadow-md)!important;margin:20px!important}.secondary-button{border:1px solid #e2e8f0;color:#334155}.secondary-button:hover{background-color:#f8fafc;background-color:var(--slate-50);border-color:#cbd5e1;border-color:var(--slate-300);color:#0f172a;color:var(--slate-900)}.secondary-button:active{background-color:#f1f5f9;background-color:var(--slate-100);-webkit-transform:translateY(1px);transform:translateY(1px)}.vertical-divider{background-color:#e2e8f0;background-color:var(--slate-200);height:24px;margin:0 8px;width:1px}.base-node{background:#fff;border:1px solid var(--slate-200);border-radius:12px;box-shadow:0 4px 6px -1px rgba(0,0,0,.05);min-width:200px;overflow:visible!important;position:relative}.react-flow__node.selected .base-node{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light),var(--shadow-md)}.node-header{align-items:center;background:#fff;border-bottom:1px solid var(--slate-100);display:flex;padding:10px 12px}.node-header span{color:var(--slate-500);font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.node-content{background:transparent;display:flex;flex-direction:column;gap:12px;padding:12px}.node-label{color:var(--slate-400);font-size:10px;font-weight:600;margin-bottom:4px;text-transform:uppercase}.node-input,.node-select,.node-textarea{background:var(--slate-50);border:1px solid var(--slate-200);border-radius:6px;color:var(--slate-900);font-family:inherit;font-size:12px;padding:6px 8px;transition:all .15s ease;width:100%}.node-input-container{display:flex;flex-direction:column;gap:4px;max-width:9.2vw;position:relative}.node-input:focus,.node-select:focus,.node-textarea:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light);outline:none}.react-flow__handle{background:#fff!important;border:2px solid var(--slate-300)!important;height:12px!important;transition:all .2s cubic-bezier(.4,0,.2,1);width:12px!important;z-index:10}.react-flow__handle:hover{border-color:var(--primary)!important;box-shadow:0 0 0 4px var(--primary-light);-webkit-transform:scale(1.3);transform:scale(1.3)}.react-flow__connection-path{stroke:var(--primary);stroke-width:2;stroke-dasharray:5;-webkit-animation:dash .5s linear infinite;animation:dash .5s linear infinite}.react-flow__handle-connecting{background:var(--primary-light)!important;border-color:var(--primary)!important}.react-flow__handle-valid{background:#fff!important;border-color:#10b981!important;-webkit-transform:scale(1.4);transform:scale(1.4)}@-webkit-keyframes dash{0%{stroke-dashoffset:10}to{stroke-dashoffset:0}}@keyframes dash{0%{stroke-dashoffset:10}to{stroke-dashoffset:0}}.react-flow__handle-right{right:-7px!important}.react-flow__handle-left{left:-7px!important}.react-flow__edge-path{stroke-linecap:round}.react-flow__edge.selected .react-flow__edge-path{stroke:var(--primary)}.react-flow__node{transition:-webkit-transform .6s cubic-bezier(.34,1.56,.64,1);transition:transform .6s cubic-bezier(.34,1.56,.64,1);transition:transform .6s cubic-bezier(.34,1.56,.64,1),-webkit-transform .6s cubic-bezier(.34,1.56,.64,1);will-change:transform}.react-flow__node.dragging{transition:none!important}.secondary-button{align-items:center;background:#fff;border:1px solid var(--slate-200);border-radius:8px;color:var(--slate-700);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .2s}.secondary-button:hover{background-color:var(--primary-light);border-color:var(--primary);color:var(--primary)}.secondary-button svg{transition:-webkit-transform .3s ease;transition:transform .3s ease;transition:transform .3s ease,-webkit-transform .3s ease}.secondary-button:hover svg{-webkit-transform:rotate(90deg);transform:rotate(90deg)}.react-flow__container{height:100%;left:0;position:absolute;top:0;width:100%}.react-flow__pane{cursor:grab;z-index:1}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:grabbing}.react-flow__viewport{pointer-events:none;-webkit-transform-origin:0 0;transform-origin:0 0;z-index:2}.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{overflow:visible;pointer-events:none}.react-flow__connection-path,.react-flow__edge-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{cursor:pointer;pointer-events:visibleStroke}.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;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}.react-flow__node,.react-flow__nodes{-webkit-transform-origin:0 0;transform-origin:0 0}.react-flow__node{box-sizing:border-box;cursor:grab;pointer-events:all;position:absolute;-webkit-user-select:none;user-select:none}.react-flow__node.dragging{cursor:grabbing}.react-flow__nodesselection{pointer-events:none;-webkit-transform-origin:left top;transform-origin:left top;z-index:3}.react-flow__nodesselection-rect{cursor:grab;pointer-events:all;position:absolute}.react-flow__handle{background:#1a192b;border:1px solid #fff;border-radius:100%;height:6px;min-height:5px;min-width:5px;pointer-events:none;position:absolute;width:6px}.react-flow__handle.connectionindicator{cursor:crosshair;pointer-events:all}.react-flow__handle-bottom{bottom:-4px;top:auto}.react-flow__handle-bottom,.react-flow__handle-top{left:50%;-webkit-transform:translate(-50%);transform:translate(-50%)}.react-flow__handle-top{top:-4px}.react-flow__handle-left{left:-4px}.react-flow__handle-left,.react-flow__handle-right{top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%)}.react-flow__handle-right{right:-4px}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{margin:15px;position:absolute;z-index:5}.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%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.react-flow__attribution{background:hsla(0,0%,100%,.5);font-size:10px;margin:0;padding:2px 3px}.react-flow__attribution a{color:#999;text-decoration:none}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{height:100%;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;width:100%}.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-group,.react-flow__node-input,.react-flow__node-output{background-color:#fff;border:1px solid #1a192b;border-radius:3px;color:#222;font-size:12px;padding:10px;text-align:center;width:150px}.react-flow__node-default.selectable:hover,.react-flow__node-group.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover{box-shadow:0 1px 4px 1px rgba(0,0,0,.08)}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.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{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:hsla(0,0%,94%,.25)}.react-flow__nodesselection-rect,.react-flow__selection{background:rgba(0,89,220,.08);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 rgba(0,0,0,.08)}.react-flow__controls-button{align-items:center;background:#fefefe;border:none;border-bottom:1px solid #eee;box-sizing:initial;cursor:pointer;display:flex;height:16px;justify-content:center;padding:5px;-webkit-user-select:none;user-select:none;width:16px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{max-height:12px;max-width:12px;width:100%}.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__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.bottom,.react-flow__resize-control.top{cursor:ns-resize}.react-flow__resize-control.bottom.right,.react-flow__resize-control.top.left{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:#3367d9;border:1px solid #fff;border-radius:1px;height:4px;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);width:4px}.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.bottom.left,.react-flow__resize-control.handle.top.left{left:0}.react-flow__resize-control.handle.bottom.right,.react-flow__resize-control.handle.top.right{left:100%}.react-flow__resize-control.line{border:0 solid #3367d9}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{height:100%;top:0;-webkit-transform:translate(-50%);transform:translate(-50%);width:1px}.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.bottom,.react-flow__resize-control.line.top{height:1px;left:0;-webkit-transform:translateY(-50%);transform:translateY(-50%);width:100%}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}
/*# sourceMappingURL=main.c86d91b3.css.map*/