*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#1f2937;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh;background:#f8fafc}html,body,#root{height:100%;overflow:hidden}h1,h2,h3,h4,h5,h6{color:#1e293b;font-weight:600;line-height:1.2}p{color:#64748b;line-height:1.6}a{color:#3b82f6;text-decoration:none;transition:color .2s ease}a:hover{color:#2563eb}button{font-family:inherit;font-size:inherit;line-height:inherit;cursor:pointer;border:none;background:none;transition:all .2s ease}button:disabled{cursor:not-allowed;opacity:.6}input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){:root{--border-color: #000000;--text-color: #000000;--background-color: #ffffff}}.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%}.default-node-details-compact{text-align:center}.node-type-compact{font-size:10px;color:#9ca3af;background:#f9fafb;padding:2px 6px;border-radius:8px;display:inline-block}.tool-node-content-compact{text-align:center}.tool-category-compact{font-size:10px;color:#6b7280;background:#f3f4f6;padding:2px 6px;border-radius:8px;display:inline-block}.base-node-renderer{border:1px solid #374151;border-radius:12px;background:#1f2937;box-shadow:0 4px 12px #0006;transition:all .2s ease;overflow:hidden;cursor:pointer;position:relative;color:#f9fafb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.base-node-renderer:hover{box-shadow:0 8px 20px #00000080;transform:translateY(-2px);border-color:#4b5563}.base-node-renderer.selected{border-width:2px;border-color:#60a5fa;box-shadow:0 8px 25px #60a5fa4d}.base-node-header{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 12px;color:#fff;font-size:12px;font-weight:600;position:relative;border-radius:12px 12px 0 0}.base-node-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.base-node-header-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.base-node-status{display:flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#fff3;flex-shrink:0}.status-spinner{width:8px;height:8px;border:1px solid rgba(255,255,255,.3);border-top:1px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-pending{background:#9ca3af}.status-running{background:#3b82f6}.status-completed{background:#10b981}.status-error{background:#ef4444}.base-node-content{padding:16px 12px;text-align:center}.base-node-content-title{font-weight:600;font-size:14px;color:#f9fafb;margin-bottom:4px;line-height:1.2;word-break:break-word}.base-node-content-subtitle{font-size:11px;color:#9ca3af;margin-bottom:0;line-height:1.3;word-break:break-word;text-transform:uppercase;letter-spacing:.5px}.base-node-content-details{display:flex;flex-direction:column;gap:4px}.base-node-handle{width:10px;height:10px;border:2px solid #1F2937;background:#9ca3af;border-radius:50%;transition:all .2s ease}.base-node-handle-input{left:-7px}.base-node-handle-output{right:-7px}.base-node-handle:hover{background:#f9fafb;border-color:#60a5fa;transform:scale(1.3);box-shadow:0 2px 8px #60a5fa66}.base-node-handle.connected{background:#60a5fa;border-color:#1f2937}@media (max-width: 768px){.base-node-renderer{min-width:180px!important;max-width:220px!important}.base-node-content-title{font-size:13px}.base-node-content-subtitle{font-size:11px}.base-node-header{font-size:11px;padding:6px 10px}.base-node-content{padding:10px}}.node-detail{font-size:11px;color:#6b7280;line-height:1.3;word-break:break-word;margin-bottom:2px}.node-detail:last-child{margin-bottom:0}.node-detail-label{font-weight:500;color:#374151}.node-detail-value{color:#6b7280}.node-tag{display:inline-flex;align-items:center;padding:2px 6px;background:#f3f4f6;color:#6b7280;border-radius:4px;font-size:10px;font-weight:500;margin-right:4px;margin-bottom:2px}.node-tag.tag-success{background:#d1fae5;color:#065f46}.node-tag.tag-warning{background:#fef3c7;color:#92400e}.node-tag.tag-error{background:#fee2e2;color:#991b1b}.node-tag.tag-info{background:#dbeafe;color:#1e40af}.node-progress{width:100%;height:4px;background:#e5e7eb;border-radius:2px;overflow:hidden;margin-top:8px}.node-progress-bar{height:100%;background:#3b82f6;border-radius:2px;transition:width .3s ease}.node-progress-bar.success{background:#10b981}.node-progress-bar.error{background:#ef4444}.node-actions{display:flex;gap:4px;margin-top:8px}.node-action-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#f3f4f6;border:1px solid #D1D5DB;border-radius:4px;cursor:pointer;transition:all .2s ease;color:#6b7280}.node-action-btn:hover{background:#e5e7eb;border-color:#9ca3af;color:#374151}.node-action-btn:active{background:#d1d5db}.node-action-btn.primary{background:#3b82f6;border-color:#3b82f6;color:#fff}.node-action-btn.primary:hover{background:#2563eb;border-color:#2563eb}.node-action-btn.danger{background:#ef4444;border-color:#ef4444;color:#fff}.node-action-btn.danger:hover{background:#dc2626;border-color:#dc2626}.agent-tools-header{display:flex;align-items:center;gap:4px;padding:4px 6px;border-radius:4px;cursor:pointer;transition:background-color .2s ease;font-size:11px;color:#6b7280}.agent-tools-header:hover{background-color:#f9fafb}.tools-count{background:#f3f4f6;padding:2px 6px;border-radius:10px;font-size:10px;font-weight:500;flex:1}.tools-toggle{color:#9ca3af;transition:transform .2s ease}.agent-tools-list{margin-top:4px;padding-left:16px;border-left:2px solid #F3F4F6}.agent-tool-item{display:flex;align-items:center;justify-content:space-between;padding:2px 4px;margin-bottom:2px;border-radius:3px;font-size:10px}.agent-tool-item:hover{background-color:#f9fafb}.agent-tool-name{color:#374151;font-weight:500}.agent-tool-category{color:#9ca3af;font-size:9px;background:#f3f4f6;padding:1px 4px;border-radius:6px}.agent-model-compact{font-size:10px;color:#9ca3af;text-align:center;margin-top:2px}.agent-node{position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.agent-node-content{padding:6px 8px;font-size:11px;color:#374151}.agent-model-info{display:flex;align-items:center;gap:6px;margin-bottom:8px;padding:4px 8px;background:#f3f4f6;border-radius:4px}.agent-model-label{font-weight:500;color:#6b7280}.agent-model-name{font-weight:600;color:#8b5cf6;font-size:11px}.agent-tools-status{display:flex;align-items:center;gap:4px;margin-bottom:8px;color:#059669;font-weight:500;position:relative}.agent-subflow-toggle{background:none;border:1px solid #8B5CF6;border-radius:4px;padding:2px;cursor:pointer;color:#8b5cf6;display:flex;align-items:center;justify-content:center;margin-left:auto;transition:all .2s ease}.agent-subflow-toggle:hover{background:#8b5cf6;color:#fff;transform:scale(1.05)}.agent-max-calls{font-size:10px;color:#6b7280;font-weight:400}.agent-tools-section{margin-bottom:8px}.agent-tools-header{display:flex;align-items:center;gap:4px;margin-bottom:6px;font-weight:600;color:#4b5563;font-size:11px}.agent-tools-list{display:flex;flex-direction:column;gap:3px}.agent-tool-item{display:flex;align-items:center;gap:6px;padding:3px 6px;background:#f9fafb;border-radius:3px;border-left:2px solid #8B5CF6;transition:all .2s ease}.agent-tool-item.clickable{cursor:pointer}.agent-tool-item.active{background:#ede9fe;border-left-color:#7c3aed}.agent-tool-item.clickable:hover{background:#f3f4f6}.agent-tool-icon{display:flex;align-items:center;justify-content:center;width:16px;height:16px;background:#8b5cf6;border-radius:2px;color:#fff}.agent-tool-info{flex:1;min-width:0}.agent-tool-name{font-weight:500;color:#1f2937;font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.agent-tool-category{font-size:9px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.agent-tools-more{font-size:10px;color:#6b7280;font-style:italic;text-align:center;padding:2px}.agent-subflow-section{margin:8px 0;padding:8px;background:#f9fafb;border-radius:6px;border:1px solid #E5E7EB}.agent-tool-calls-section{border-top:1px solid #E5E7EB;padding-top:6px}.agent-tool-calls-header{display:flex;align-items:center;gap:4px;margin-bottom:4px;font-weight:600;color:#4b5563;font-size:11px}.agent-tool-calls-list{display:flex;flex-direction:column;gap:2px}.agent-tool-call-item{display:flex;align-items:center;gap:4px;padding:2px 4px;background:#fefefe;border-radius:2px}.agent-tool-call-status .success{color:#10b981}.agent-tool-call-status .error{color:#ef4444}.agent-tool-call-name{font-size:10px;color:#374151;font-weight:500}.agent-handle{position:absolute;width:12px;height:12px;border:2px solid #8B5CF6;border-radius:50%;background:#fff;z-index:10}.agent-handle-input{left:-6px;top:50%;transform:translateY(-50%)}.agent-handle-output{right:-6px;top:50%;transform:translateY(-50%)}.handle-dot{width:4px;height:4px;background:#8b5cf6;border-radius:50%;margin:2px auto}.agent-tool-handle{position:absolute;display:flex;align-items:center;justify-content:center;z-index:5;pointer-events:none}.agent-tool-handle-0{right:-8px;top:30%}.agent-tool-handle-1{right:-8px;top:50%}.agent-tool-handle-2{right:-8px;top:70%}.tool-handle-dot{width:16px;height:16px;background:#8b5cf61a;border:1px dashed #8B5CF6;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#8b5cf6;position:relative;animation:pulse-tool 2s ease-in-out infinite}.tool-handle-line{position:absolute;width:20px;height:1px;background:#8b5cf6;border-top:1px dashed #8B5CF6;left:50%;top:50%;transform:translate(-50%,-50%);opacity:.6}@keyframes pulse-tool{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.1);opacity:1}}.agent-node.selected .tool-handle-dot{border-color:#8b5cf6;background:#8b5cf633;animation:pulse-tool-selected 1.5s ease-in-out infinite}@keyframes pulse-tool-selected{0%,to{transform:scale(1);box-shadow:0 0 #8b5cf666}50%{transform:scale(1.1);box-shadow:0 0 0 4px #8b5cf61a}}@media (max-width: 768px){.agent-node-content{font-size:11px}.agent-tool-name{font-size:9px}.agent-tool-category{font-size:8px}}.agent-tool-handle[title]:hover:after{content:attr(title);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#1f2937;color:#fff;padding:4px 8px;border-radius:4px;font-size:10px;white-space:nowrap;z-index:1000;margin-bottom:4px}.agent-tool-handle[title]:hover:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#1f2937;z-index:1000}.tool-node{position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;opacity:.8;transition:opacity .2s ease}.tool-node:hover{opacity:1}.tool-node-content{padding:8px 12px;font-size:12px;color:#374151}.tool-description{margin-bottom:8px;line-height:1.4;color:#6b7280;font-size:11px}.tool-category{margin-bottom:8px}.tool-category-badge{display:inline-block;padding:2px 6px;border-radius:12px;font-size:10px;font-weight:500;border:1px solid currentColor}.tool-category-badge[data-category=数学]{background-color:#f59e0b33;color:#f59e0b}.tool-category-badge[data-category=搜索]{background-color:#3b82f633;color:#3b82f6}.tool-category-badge[data-category=开发]{background-color:#10b98133;color:#10b981}.tool-category-badge[data-category=文本]{background-color:#8b5cf633;color:#8b5cf6}.tool-category-badge[data-category=工具]{background-color:#6b728033;color:#6b7280}.tool-parent-info{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#f9fafb;border-radius:4px;border-left:2px solid #8B5CF6;margin-top:8px}.tool-parent-label{font-size:10px;color:#6b7280;font-weight:500}.tool-parent-name{font-size:10px;color:#8b5cf6;font-weight:600}.tool-node-error{border-color:#ef4444!important;background:#fef2f2!important}.tool-node-error .tool-node-content{color:#dc2626}.tool-node-renderer{border-style:dashed!important;border-width:2px!important;box-shadow:0 2px 4px #0000000d}.tool-node-renderer.selected{box-shadow:0 4px 12px #00000026;border-style:solid!important}.tool-node-renderer{animation:tool-node-appear .3s ease-out}@keyframes tool-node-appear{0%{opacity:0;transform:scale(.8)}to{opacity:.8;transform:scale(1)}}.tool-node .base-node-header{opacity:.9}.tool-node .base-node-header-title{font-weight:600;font-size:12px}@media (max-width: 768px){.tool-node-content{font-size:11px;padding:6px 10px}.tool-description{font-size:10px}.tool-category-badge{font-size:9px;padding:1px 4px}}.workflow-canvas{display:flex;flex-direction:column;height:100vh;width:100vw;background:linear-gradient(135deg,#0f172a,#1e293b,#334155);position:relative;overflow:hidden}.workflow-canvas:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 25% 25%,rgba(59,130,246,.1) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(139,92,246,.1) 0%,transparent 50%);pointer-events:none;z-index:0}.workflow-canvas-header{padding:20px 24px;background:#0f172acc;border-bottom:1px solid rgba(75,85,99,.3);box-shadow:0 1px 3px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;z-index:10}.workflow-title{font-size:24px;font-weight:700;color:#f9fafb;margin:0 0 8px}.workflow-description{font-size:14px;color:#d1d5db;margin:0;line-height:1.5}.workflow-canvas-content{flex:1;position:relative;background:transparent;z-index:5}.react-flow__viewport{background:transparent!important}.react-flow__controls{background:#374151!important;border:1px solid #4B5563!important;border-radius:8px;box-shadow:0 4px 6px #0000004d}.react-flow__controls-button{background:#374151!important;border-bottom:1px solid #4B5563!important;color:#d1d5db!important;transition:all .2s ease}.react-flow__controls-button:hover{background:#4b5563!important;color:#f9fafb!important}.react-flow__controls-button:last-child{border-bottom:none!important}.react-flow__minimap{background:#374151!important;border:1px solid #4B5563!important;border-radius:8px;box-shadow:0 4px 6px #0000004d}.react-flow__background{background:transparent!important}.react-flow__background-pattern{stroke:#94a3b833!important;opacity:.4}.react-flow__edge-path{stroke:#64748b!important;stroke-width:2;opacity:.8}.react-flow__edge.selected .react-flow__edge-path{stroke:#60a5fa!important;stroke-width:3}.react-flow__edge:hover .react-flow__edge-path{stroke:#d1d5db!important;stroke-width:3}.react-flow__arrowhead{fill:#9ca3af!important}.react-flow__edge.selected .react-flow__arrowhead{fill:#60a5fa!important}.react-flow__selection{background:#60a5fa1a!important;border:1px dashed #60A5FA!important}.react-flow__node.dragging{opacity:.7}.react-flow__node.selected{box-shadow:0 0 0 2px #60a5fa!important}.react-flow__handle{background:#6b7280!important;border:2px solid #374151!important;width:8px!important;height:8px!important}.react-flow__handle:hover{background:#9ca3af!important}.react-flow__handle.react-flow__handle-connecting{background:#60a5fa!important}@media (max-width: 768px){.workflow-canvas-header{padding:16px 20px}.workflow-title{font-size:20px}.workflow-description{font-size:13px}.react-flow__controls{transform:scale(.9)}.react-flow__minimap{transform:scale(.9);transform-origin:bottom right}}@media (max-width: 480px){.workflow-canvas-header{padding:12px 16px}.workflow-title{font-size:18px}}.react-flow__renderer::-webkit-scrollbar{width:8px;height:8px}.react-flow__renderer::-webkit-scrollbar-track{background:#374151}.react-flow__renderer::-webkit-scrollbar-thumb{background:#6b7280;border-radius:4px}.react-flow__renderer::-webkit-scrollbar-thumb:hover{background:#9ca3af}.workflow-executor{display:flex;flex-direction:column;height:100vh;background:#f9fafb}.workflow-controls{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#fff;border-bottom:1px solid #E5E7EB;box-shadow:0 1px 3px #0000001a}.control-buttons{display:flex;gap:12px}.control-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#fff;border:1px solid #D1D5DB;border-radius:6px;color:#374151;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.control-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.control-btn:active:not(:disabled){background:#e5e7eb}.control-btn:disabled{opacity:.5;cursor:not-allowed}.control-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.control-btn.active:hover{background:#2563eb;border-color:#2563eb}.execution-status{display:flex;align-items:center;gap:16px;font-size:14px}.status-indicator{display:inline-flex;align-items:center;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;text-transform:uppercase}.status-indicator.status-idle{background:#f3f4f6;color:#6b7280}.status-indicator.status-running{background:#dbeafe;color:#1d4ed8;animation:pulse 2s infinite}.status-indicator.status-paused{background:#fef3c7;color:#92400e}.status-indicator.status-completed{background:#d1fae5;color:#065f46}.status-indicator.status-error{background:#fee2e2;color:#991b1b}.status-indicator.status-pending{background:#f3f4f6;color:#6b7280}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.current-node{color:#6b7280;font-style:italic}.execution-results{position:fixed;right:0;top:0;bottom:0;width:400px;background:#fff;border-left:1px solid #E5E7EB;box-shadow:-4px 0 6px #0000001a;z-index:1000;overflow:hidden;display:flex;flex-direction:column}.execution-results h3{margin:0;padding:16px 20px;background:#f9fafb;border-bottom:1px solid #E5E7EB;font-size:16px;font-weight:600;color:#1f2937}.results-list{flex:1;overflow-y:auto;padding:8px 0}.result-item{margin:8px 16px;padding:12px;background:#f9fafb;border-radius:6px;border-left:4px solid #E5E7EB}.result-item.status-running{border-left-color:#3b82f6;background:#eff6ff}.result-item.status-completed{border-left-color:#10b981;background:#ecfdf5}.result-item.status-error{border-left-color:#ef4444;background:#fef2f2}.result-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.node-name{font-weight:600;color:#1f2937;flex:1}.result-status{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase}.execution-time{font-size:11px;color:#9ca3af;margin-left:8px}.result-error{background:#fee2e2;color:#991b1b;padding:8px;border-radius:4px;font-size:12px;margin-top:8px;border:1px solid #FECACA}.result-data{margin-top:8px;background:#fff;border:1px solid #E5E7EB;border-radius:4px;overflow:hidden}.result-data pre{margin:0;padding:8px;font-size:11px;line-height:1.4;color:#374151;overflow-x:auto;white-space:pre-wrap;word-break:break-word}@media (max-width: 1200px){.execution-results{width:350px}}@media (max-width: 768px){.workflow-controls{padding:12px 16px}.control-buttons{gap:8px}.control-btn{padding:6px 12px;font-size:13px}.execution-status{gap:12px;font-size:13px}.execution-results{width:100%;position:relative;box-shadow:none;border-left:none;border-top:1px solid #E5E7EB;height:300px}}@media (max-width: 480px){.workflow-controls{flex-direction:column;gap:12px;align-items:stretch}.control-buttons{justify-content:center}.execution-status{justify-content:center;text-align:center}.current-node{display:block;margin-top:4px;font-size:12px}}.app{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b,#334155);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;color:#f9fafb}*{box-sizing:border-box}body{margin:0;padding:0}#root{height:100vh;margin:0;padding:0}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#1f2937}::-webkit-scrollbar-thumb{background:#4b5563;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6b7280}button:focus-visible,textarea:focus-visible,input:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}::selection{background:#3b82f633}.app-welcome{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2)}.welcome-content{max-width:600px;text-align:center;background:#fff;padding:48px 40px;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.welcome-title{font-size:32px;font-weight:700;color:#1f2937;margin:0 0 16px}.welcome-description{font-size:16px;color:#6b7280;margin:0 0 40px;line-height:1.6}.upload-area{position:relative;margin-bottom:32px}.upload-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.upload-label{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 24px;border:2px dashed #D1D5DB;border-radius:12px;background:#f9fafb;cursor:pointer;transition:all .3s ease}.upload-label:hover{border-color:#3b82f6;background:#eff6ff}.upload-label:hover .upload-icon{color:#3b82f6;transform:scale(1.1)}.upload-icon{color:#9ca3af;transition:all .3s ease}.upload-text{font-size:16px;font-weight:600;color:#374151}.upload-hint{font-size:14px;color:#6b7280}.example-section{margin-bottom:32px}.example-section h3{font-size:18px;font-weight:600;color:#374151;margin:0 0 20px}.example-workflows{display:grid;grid-template-columns:1fr;gap:16px}.workflow-card{display:flex;align-items:center;gap:16px;padding:16px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;transition:all .2s ease}.workflow-card:hover{background:#f3f4f6;border-color:#d1d5db}.workflow-card-content{flex:1}.workflow-card-title{font-size:16px;font-weight:600;color:#1f2937;margin:0 0 4px}.workflow-card-description{font-size:14px;color:#6b7280;margin:0;line-height:1.4}.workflow-card-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;flex-shrink:0}.workflow-card-btn:hover:not(:disabled){background:#2563eb}.workflow-card-btn:active:not(:disabled){background:#1d4ed8}.workflow-card-btn:disabled{opacity:.5;cursor:not-allowed}.app-main{display:flex;flex-direction:column;height:100vh}.workflow-container{flex:1;overflow:auto}.app-toolbar{display:flex;align-items:center;gap:12px;padding:12px 20px;background:#0f172acc;border-bottom:1px solid rgba(75,85,99,.3);box-shadow:0 1px 3px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toolbar-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.toolbar-btn:hover{background:#2563eb}.toolbar-btn.success{background:#10b981}.toolbar-btn.success:hover{background:#059669}.toolbar-btn.secondary{background:#6b7280}.toolbar-btn.secondary:hover{background:#4b5563}.upload-like input{display:none}.error-message{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:#fee2e2;color:#991b1b;border:1px solid #FECACA;border-radius:8px;font-size:14px}.chat-container{padding:16px 20px;background:#0f172acc;border-top:1px solid rgba(75,85,99,.3);box-shadow:0 -1px 3px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.chat-form{max-width:800px;margin:0 auto}.chat-input-wrapper{display:flex;align-items:center;gap:12px;padding:12px;background:#1f2937cc;border:1px solid rgba(75,85,99,.5);border-radius:12px;transition:all .2s ease}.chat-input-wrapper:focus-within{border-color:#60a5fa;background:#1f2937e6;box-shadow:0 0 0 3px #60a5fa1a}.chat-input{flex:1;padding:8px 0;border:none;background:transparent;font-size:16px;color:#f9fafb;outline:none}.chat-input::placeholder{color:#9ca3af}.chat-send-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.chat-send-btn:hover:not(:disabled){background:#2563eb}.chat-send-btn:active:not(:disabled){background:#1d4ed8;transform:scale(.95)}.chat-send-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none}@media (max-width: 768px){.app{font-size:14px}.welcome-content{padding:32px 24px;margin:16px}.welcome-title{font-size:24px}.welcome-description{font-size:14px}.upload-label{padding:32px 16px}.upload-text{font-size:14px}.upload-hint{font-size:12px}.app-toolbar{padding:8px 16px}.toolbar-btn{padding:6px 12px;font-size:13px}.chat-container{padding:12px 16px}.chat-input{font-size:16px}}@media (max-width: 480px){.app-welcome{padding:16px}.welcome-content{padding:24px 16px;margin:0}.welcome-title{font-size:20px}.upload-label{padding:24px 12px}.example-btn{width:100%;justify-content:center}.app-toolbar{padding:8px 12px;flex-wrap:wrap;gap:8px}.toolbar-btn{padding:6px 10px;font-size:12px}.chat-container{padding:12px}.chat-input-wrapper{padding:10px}.chat-send-btn{width:36px;height:36px}}
