.react-flow{direction:ltr;--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: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--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: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--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: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--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 rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.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: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--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: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--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: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--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 rgba(0, 0, 0, .08);--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{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;touch-action:none}.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{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.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;-moz-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:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.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:default}.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:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;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%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;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{position:absolute;z-index:5;margin:15px}.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{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@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;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.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{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.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{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;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))}.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{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));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:var(--xy-resize-background-color, var(--xy-resize-background-color-default));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%}.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}html,body,#root{min-height:100%;margin:0}body{background:#080b11;color:#e5eefc;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.login-page{min-height:100vh;display:grid;grid-template-columns:minmax(360px,480px) 1fr;background:radial-gradient(circle at 80% 20%,rgba(56,189,248,.18),transparent 30%),linear-gradient(135deg,#080b11,#0c1320 55%,#111827)}.login-panel{padding:64px 54px;display:flex;flex-direction:column;justify-content:center;background:#080b11c7;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.login-visual{min-height:100%;display:flex;align-items:center;padding:64px}.system-map{width:min(780px,100%);display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.map-node{min-height:116px;padding:18px;border:1px solid rgba(148,163,184,.18);background:#0f172ab3;border-radius:8px;box-shadow:0 24px 70px #00000047}.map-node strong{display:block;color:#f8fafc;font-size:18px;margin-bottom:8px}.map-node span{color:#9fb1c7;line-height:1.6}.brand-title{margin:0 0 10px;color:#f8fafc;font-size:34px;line-height:1.15}.muted{color:#91a1b7}.app-logo{height:44px;display:flex;align-items:center;padding:0 20px;color:#f8fafc;font-weight:700;letter-spacing:0}.app-logo span{color:#38bdf8}.app-header{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 22px;border-bottom:1px solid rgba(148,163,184,.12)}.page{padding:22px}.page-title{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.page-title h1{margin:0 0 6px;font-size:22px;color:#f8fafc}.metric-row{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:14px;margin-bottom:18px}.metric{padding:18px;background:#101722;border-radius:8px}.metric-label{color:#91a1b7;margin-bottom:10px}.metric-value{font-size:30px;color:#f8fafc;font-weight:700}.work-panel{background:#101722;border-radius:8px;padding:18px}.toolbar{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-bottom:14px}.flat-button.ant-btn{border:0;box-shadow:none;background:#0f2336bd;color:#dbeafe}.flat-button.ant-btn:hover,.flat-button.ant-btn:focus{background:#1e416cf5!important;color:#f8fafc!important}.flat-button-primary.ant-btn{background:#0ea5e9;color:#06121f;font-weight:700}.flat-button-primary.ant-btn:hover,.flat-button-primary.ant-btn:focus{background:#38bdf8!important;color:#06121f!important}.ant-message{z-index:3000}.ant-message .ant-message-notice-content{min-width:180px;border-radius:8px;background:#122033;color:#f8fafc;border:1px solid rgba(56,189,248,.28);box-shadow:0 18px 48px #00000061}.ant-message .anticon-check-circle{color:#35d399}.ant-message .anticon-close-circle{color:#ff6b6b}.ant-notification{z-index:5200}.ant-notification .ant-notification-notice{border-radius:8px;background:#122033;border:1px solid rgba(56,189,248,.24);box-shadow:0 18px 48px #0000006b}.ant-notification .ant-notification-notice-message{color:#f8fafc;font-weight:700}.ant-notification .ant-notification-notice-description{color:#a9bad0}.ant-popover{max-width:min(280px,calc(100vw - 24px))}.ant-popconfirm .ant-popover-message-title{max-width:220px;white-space:normal}.table-actions{display:inline-flex;gap:6px;align-items:center}.icon-action.ant-btn{width:30px;height:30px;border:0;border-radius:6px;box-shadow:none;background:#0f2336c7;color:#bfdbfe}.icon-action.ant-btn:hover,.icon-action.ant-btn:focus{background:#38bdf833!important;color:#e0f2fe!important}.icon-action-danger.ant-btn{color:#fecaca;background:#7f1d1d52}.icon-action-danger.ant-btn:hover,.icon-action-danger.ant-btn:focus{background:#ef444438!important;color:#fee2e2!important}.button-editor{display:grid;grid-template-columns:1fr 120px 1.2fr 1.1fr 1.2fr 1fr 36px;gap:8px;align-items:center;margin-bottom:8px}.flow-meta{display:grid;grid-template-columns:minmax(260px,520px);gap:12px;align-items:center;margin-bottom:16px}.flow-editor-modal{top:0;width:100vw!important;max-width:100vw;padding-bottom:0}.flow-editor-modal .ant-modal-content{min-height:100vh;border-radius:0;padding:0;background:#08111d}.flow-editor-modal .ant-modal-header{margin:0;padding:12px 16px;border-bottom:1px solid rgba(148,163,184,.12);background:#0b111a}.flow-editor-modal .ant-modal-body{padding:14px;height:calc(100vh - 65px);overflow:hidden}.flow-editor-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.flow-title-input.ant-input{width:min(460px,45vw);height:38px;border:0;background:#0f2336a3;color:#f8fafc;font-size:18px;font-weight:700;padding-left:10px;box-shadow:none}.flow-title-input.ant-input:hover,.flow-title-input.ant-input:focus{background:#18324cf0}.flow-exit-button.ant-btn{border:0;box-shadow:none;background:#7f1d1dbd;color:#fee2e2;padding-inline:14px}.flow-exit-button.ant-btn:hover,.flow-exit-button.ant-btn:focus{background:#b91c1ce6!important;color:#fff7f7!important}.flow-close-confirm{z-index:4200}.flow-close-confirm .ant-modal-content{width:440px;margin-inline:auto;background:#101722;border:1px solid rgba(56,189,248,.18);box-shadow:0 28px 76px #00000085}.flow-close-confirm .ant-modal-header{margin-bottom:10px;background:transparent}.flow-close-confirm .ant-modal-title{color:#f8fafc;font-size:17px}.flow-close-text{margin:0;color:#a9bad0;line-height:1.65}.flow-close-actions{display:flex;justify-content:flex-end;gap:8px}.flow-discard-button.ant-btn{border:0;background:#7f1d1d94;color:#fecaca;box-shadow:none}.flow-discard-button.ant-btn:hover,.flow-discard-button.ant-btn:focus{background:#b91c1cd1!important;color:#fff1f2!important}.flow-editor-shell{height:100%;min-height:0}.flow-editor{display:grid;grid-template-columns:250px minmax(360px,1fr) 380px;gap:14px;min-height:calc(100vh - 170px)}.flow-library,.flow-canvas,.step-config{background:#0d1520;border-radius:8px;padding:16px;min-height:100%}.step-config{max-height:100%;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain}.action-menu,.action-submenu,.step-config{scrollbar-color:rgba(56,189,248,.42) rgba(15,23,36,.78);scrollbar-width:thin}.action-menu::-webkit-scrollbar,.action-submenu::-webkit-scrollbar,.step-config::-webkit-scrollbar{width:8px}.action-menu::-webkit-scrollbar-track,.action-submenu::-webkit-scrollbar-track,.step-config::-webkit-scrollbar-track{background:#0f1724c7;border-radius:999px}.action-menu::-webkit-scrollbar-thumb,.action-submenu::-webkit-scrollbar-thumb,.step-config::-webkit-scrollbar-thumb{background:#38bdf857;border:2px solid rgba(15,23,36,.78);border-radius:999px}.action-menu::-webkit-scrollbar-thumb:hover,.action-submenu::-webkit-scrollbar-thumb:hover,.step-config::-webkit-scrollbar-thumb:hover{background:#67e8f985}.action-group{margin-bottom:18px}.action-category{margin-bottom:8px}.flow-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.flow-track{display:flex;flex-direction:column;gap:12px;position:relative}.flow-node{display:grid;grid-template-columns:34px minmax(0,1fr) 36px;gap:12px;align-items:center;background:#111c2b;border:1px solid rgba(148,163,184,.14);border-radius:8px;padding:12px;cursor:pointer;position:relative}.flow-node:not(:last-child):after{content:"";position:absolute;left:28px;bottom:-13px;width:2px;height:13px;background:#243244}.flow-node.active{border-color:#38bdf8;box-shadow:0 0 0 1px #38bdf84d}.node-index{width:28px;height:28px;display:grid;place-items:center;background:#182538;border-radius:50%;color:#f8fafc;font-weight:700}.node-body{min-width:0;display:flex;flex-direction:column;gap:6px}.node-body strong,.node-body span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.keyboard-editor{margin-top:8px}.keyboard-row{background:#111c2b;border-radius:8px;padding:10px;margin-bottom:10px}.keyboard-row-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.keyboard-button-config{display:grid;grid-template-columns:1fr 120px 1fr 1fr 1fr 1fr 1fr 36px;gap:8px;align-items:center;margin-bottom:8px}.mind-flow-editor{grid-template-columns:240px minmax(520px,1fr) 360px}.tree-flow-editor{display:grid;grid-template-columns:minmax(620px,1fr) 380px;gap:14px;height:calc(100vh - 170px);min-height:620px}.flow-editor-shell .tree-flow-editor{height:100%;min-height:0}.mind-canvas{padding:0;overflow:hidden}.tree-canvas{padding:0;overflow:hidden;background:#0d1520;border-radius:8px}.tree-canvas .react-flow{width:100%;height:100%;min-height:620px}.flow-editor-shell .tree-canvas .react-flow{min-height:0}.mind-canvas .react-flow{min-height:calc(100vh - 170px);background:#0d1520;border-radius:8px}.mind-canvas .react-flow__minimap,.tree-canvas .react-flow__minimap{width:142px;height:104px;background:#0f1724;border:0;border-radius:6px;box-sizing:border-box;box-shadow:none;opacity:.86;padding:5px}.tree-canvas .react-flow__minimap svg,.mind-canvas .react-flow__minimap svg{background:#0f1724;box-sizing:border-box;width:100%;height:100%;display:block;margin:0}.tree-canvas .react-flow__controls,.mind-canvas .react-flow__controls{overflow:hidden;border:0;border-radius:6px;box-shadow:none}.tree-canvas .react-flow__controls-button,.mind-canvas .react-flow__controls-button{width:28px;height:28px;background:#101b2a;border-bottom:1px solid rgba(148,163,184,.16);color:#dbeafe;fill:#dbeafe}.tree-canvas .react-flow__controls-button:hover,.mind-canvas .react-flow__controls-button:hover{background:#16263a}.tree-canvas .react-flow__controls-button svg,.mind-canvas .react-flow__controls-button svg{fill:currentColor}.tree-canvas .react-flow__attribution,.mind-canvas .react-flow__attribution{display:none}.mind-node{width:220px;min-height:78px;padding:12px 14px;border:1px solid rgba(148,163,184,.22);background:#111c2b;border-radius:8px;color:#e5eefc;box-shadow:0 16px 38px #0000003d;position:relative}.rf-node-active .mind-node,.react-flow__node.selected .mind-node{border-color:#38bdf8;background:#132235;box-shadow:0 0 0 1px #38bdf847,0 20px 46px #0000004d}.mind-node-title{color:#f8fafc;font-size:15px;line-height:1.28;font-weight:700;margin-bottom:7px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mind-node-sub{color:#91a1b7;font-size:13px;line-height:1.42;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tone-button{width:160px;min-height:64px;background:#12253a}.tone-root{background:#183457;border-color:#38bdf875}.tone-trigger_command,.tone-trigger_text,.tone-trigger_deeplink,.tone-trigger_special{background:#132b2f;border-color:#2dd4bf52}.tone-flow{width:160px;min-height:60px;background:#10251f}.tone-call_api{background:#1c1833}.tone-condition{width:250px;background:#1f1b12;border-color:#facc1552}.tone-check_chat_member{background:#10251f}.tone-schedule_poll,.tone-schedule_once,.tone-delay{width:260px;min-height:92px;background:#0c1c2beb;border-style:dashed;border-color:#67e8f961;box-shadow:inset 0 0 0 1px #38bdf80f,0 18px 40px #00000038}.tone-schedule_poll:before,.tone-schedule_once:before,.tone-delay:before{content:"时间区域";display:inline-block;margin-bottom:8px;padding:2px 7px;border-radius:5px;background:#22d3ee1f;color:#67e8f9;font-size:11px;font-weight:600}.config-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.condition-config-note{padding:10px 12px;border-radius:6px;background:#facc1514;color:#facc15;font-size:12px;line-height:1.55}.node-source-add,.node-source-dot{position:absolute;left:50%;bottom:-12px;transform:translate(-50%);width:24px;height:24px;border:1px solid rgba(56,189,248,.65);background:#0f2336;color:#f8fafc;border-radius:50%;z-index:2}.node-source-add{display:grid;place-items:center;cursor:pointer;font-size:12px}.node-source-add:hover{border-color:#67e8f9;background:#12314c}.node-source-dot{cursor:crosshair}.mind-node .react-flow__handle,.send-button-container .react-flow__handle{width:10px;height:10px;border:1px solid rgba(203,213,225,.8);background:#0d1520}.condition-ports{display:grid;gap:7px;margin-top:13px}.condition-port-row{position:relative;display:flex;align-items:center;justify-content:space-between;height:36px;padding:0 28px 0 12px;border:0;border-radius:6px;background:#0f172ac7;color:#e5eefc;font-size:13px;font-weight:700}.condition-port-row.pass{background:#11302be0}.condition-port-row.fail{background:#311b27e0}.condition-port-row.has-child{box-shadow:inset 0 -2px #2dd4bf5c}.condition-port-row .condition-port{right:8px;top:50%;width:13px;height:13px;transform:translateY(-50%);border-color:#facc15e6;background:#111827;z-index:12}.node-button-matrix{display:grid;gap:7px;margin-top:12px}.node-button-row{display:flex;gap:8px;align-items:center}.node-inline-button{position:relative;flex:1 1 0;min-width:0;min-height:36px;padding:8px 28px 8px 12px;border-radius:6px;background:#183457;border:0;color:#dff7ff;font-size:13px;line-height:1.2;cursor:pointer}.node-inline-button span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.node-inline-button:hover,.node-inline-button.is-selected{background:#1e416c}.node-inline-button.has-child{box-shadow:inset 0 -2px #2dd4bf6b}.node-inline-button.style-primary,.send-button-pill.style-primary{background:#15395d}.node-inline-button.style-success,.send-button-pill.style-success{background:#153f34}.node-inline-button.style-danger,.send-button-pill.style-danger{background:#4a1c28}.node-inline-button .button-port{right:8px;top:50%;width:13px;height:13px;transform:translateY(-50%);border-color:#67e8f9d9;background:#102536}.send-button-container{width:max-content;min-width:292px;max-width:760px;padding:16px 18px 18px;border:1px solid rgba(56,189,248,.42);background:#112235;border-radius:8px;color:#e5eefc;position:relative;box-shadow:0 18px 46px #00000047}.send-button-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:13px}.rf-node-active .send-button-container,.react-flow__node.selected .send-button-container{border-color:#38bdf8;background:#132842;box-shadow:0 0 0 1px #38bdf847,0 20px 46px #0000004d}.send-button-container .mind-node-sub{color:#67e8f9}.send-button-board{display:grid;gap:8px}.send-button-row{display:flex;gap:8px;align-items:center}.send-button-pill,.send-button-add,.send-button-add-row{height:36px;border-radius:6px;border:0;color:#f8fafc;cursor:pointer;position:relative;box-shadow:none}.send-button-pill{min-width:104px;max-width:172px;padding:0 30px 0 14px;background:#2b3d55;font-size:13px;font-weight:600}.send-button-pill span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.send-button-pill:hover,.send-button-pill.is-selected{background:#1e416c}.send-button-pill.has-child{box-shadow:inset 0 -3px #2dd4bf70}.send-button-pill.style-primary:hover,.send-button-pill.style-primary.is-selected,.send-button-pill.style-success:hover,.send-button-pill.style-success.is-selected,.send-button-pill.style-danger:hover,.send-button-pill.style-danger.is-selected{background:#1e416c}.send-button-add,.send-button-add-row{width:36px;min-width:36px;padding:0;background:#2b3d55;color:#c7f3ff;display:grid;place-items:center;font-size:17px;font-weight:600}.send-button-add:hover,.send-button-add-row:hover{background:#1e416c}.send-button-add-row{justify-self:start}.send-button-pill .button-port{right:8px;top:50%;width:13px;height:13px;transform:translateY(-50%);border-color:#67e8f9e6;background:#112235;z-index:12}.tree-canvas .react-flow__node{z-index:1!important}.tree-canvas .react-flow__node:has(.send-button-container){z-index:2!important}.tree-canvas .react-flow__edges{z-index:8!important}.tree-canvas .react-flow__connection{z-index:30!important}.tree-canvas .react-flow__edge{z-index:8!important}.tree-canvas .react-flow__edge.button-flow-edge{z-index:18!important}.tree-canvas .react-flow__edge.condition-flow-edge{z-index:19!important}.tree-canvas .react-flow__edge.button-flow-edge .react-flow__edge-path{stroke:#67e8f9f2;stroke-width:1.8}.tree-canvas .react-flow__edge.condition-flow-edge .react-flow__edge-path{stroke:#facc15eb;stroke-width:1.8}.tree-canvas .react-flow__edge-path{stroke:#cbd5e19e;pointer-events:stroke}.tree-canvas .react-flow__edge.selected .react-flow__edge-path{stroke:#38bdf8db}.node-context-menu{position:absolute;z-index:40;min-width:140px;background:#101722;border:1px solid rgba(148,163,184,.22);border-radius:8px;padding:6px;box-shadow:0 18px 48px #00000057}.node-context-menu button{width:100%;border:0;background:transparent;color:#e5eefc;text-align:left;padding:8px 10px;border-radius:6px;cursor:pointer}.node-context-menu button:hover{background:#182538}.action-menu{position:absolute;z-index:80;width:236px;overflow:visible;background:#0b111a;border:1px solid rgba(56,189,248,.24);border-radius:8px;padding:8px;box-shadow:0 22px 52px #0000006b}.action-menu-category{position:relative}.action-menu-category-button{width:100%;display:grid;grid-template-columns:22px 1fr 16px;gap:2px 8px;text-align:left;background:transparent;border:0;border-radius:6px;color:#e5eefc;padding:9px 10px;cursor:pointer}.action-menu-category-button:after{content:"›";grid-column:3;grid-row:1 / span 2;align-self:center;color:#cbd5e1;font-size:20px}.action-menu-category-button>span{color:#38bdf8;grid-row:1 / span 2}.action-menu-category-button strong{font-size:13px;line-height:1.2}.action-menu-category-button small{color:#91a1b7;font-size:12px;line-height:1.3}.action-menu-category:not(.is-disabled):hover>.action-menu-category-button,.action-menu-category.is-active>.action-menu-category-button{background:#13253a}.action-menu-category.is-disabled .action-menu-category-button{cursor:default;color:#64748b;opacity:.72}.action-menu-category.is-disabled .action-menu-category-button:after{content:""}.action-submenu{display:none;position:absolute;left:calc(100% + 8px);top:0;width:260px;max-height:420px;overflow-y:auto;overflow-x:hidden;background:#0b111a;border:1px solid rgba(56,189,248,.24);border-radius:8px;padding:8px;box-shadow:0 22px 52px #0000006b}.action-submenu:before{content:"";position:absolute;left:-10px;top:0;width:10px;height:100%}.action-menu-category.is-active .action-submenu{display:block}.action-menu-item{width:100%;display:grid;grid-template-columns:24px 1fr;gap:3px 8px;text-align:left;background:transparent;border:0;border-radius:6px;color:#e5eefc;padding:8px;cursor:pointer}.action-menu-item:hover{background:#121f30}.action-menu-item span{color:#38bdf8;grid-row:span 2}.action-menu-item strong{font-size:13px;line-height:1.2}.action-menu-item small,.action-menu-empty{color:#91a1b7;font-size:12px;line-height:1.45}.danger-text{color:#ff7875;font-size:12px}.variable-field{position:relative}.variable-field .ant-input,.variable-field .ant-input-affix-wrapper,.variable-field textarea.ant-input{padding-right:38px}.variable-picker-button{position:absolute;right:4px;top:50%;z-index:2;width:28px;height:28px;transform:translateY(-50%);color:#7dd3fc;background:#0f172ab8}.variable-field-textarea .variable-picker-button{top:auto;bottom:4px;transform:none}.variable-picker-button:hover{color:#cffafe;background:#183457}.variable-picker-overlay .ant-popover-inner{background:#0b111a;border:1px solid rgba(56,189,248,.24);box-shadow:0 22px 52px #00000075}.variable-picker-overlay .ant-popover-inner-content{padding:10px}.variable-picker-overlay .ant-popover-inner{width:fit-content;max-width:calc(100vw - 32px)}.variable-picker-overlay .ant-popover-arrow:before,.variable-picker-overlay .ant-popover-arrow:after{background:#0b111a}.variable-picker-popover{display:grid;gap:12px;width:fit-content;min-width:0;max-width:min(560px,calc(100vw - 44px));max-height:min(430px,calc(100vh - 88px));overflow-y:auto;overflow-x:hidden;padding:2px 2px 2px 0;scrollbar-color:rgba(56,189,248,.42) rgba(15,23,36,.78);scrollbar-width:thin}.variable-picker-popover::-webkit-scrollbar{width:8px}.variable-picker-popover::-webkit-scrollbar-track{background:#0f1724c7;border-radius:999px}.variable-picker-popover::-webkit-scrollbar-thumb{background:#38bdf857;border:2px solid rgba(15,23,36,.78);border-radius:999px}.variable-picker-popover::-webkit-scrollbar-thumb:hover{background:#67e8f985}.variable-picker-group{display:grid;gap:7px;width:100%;min-width:0;max-width:100%}.variable-picker-title{color:#67e8f9;font-size:13px;font-weight:700}.variable-picker-pills{display:flex;flex-wrap:wrap;gap:6px;width:fit-content;align-items:start;max-width:100%;min-width:0}.variable-picker-pills button{width:auto;min-width:0;box-sizing:border-box;height:28px;border:0;border-radius:6px;background:#152235;color:#e5eefc;padding:0 10px;font-size:12px;font-weight:400;line-height:1.25;cursor:pointer;max-width:100%;white-space:nowrap;overflow-wrap:normal;word-break:normal;text-align:center}.variable-picker-pills button:hover{background:#183457;color:#cffafe}.variable-picker-empty{color:#91a1b7;font-size:12px;line-height:1.3}.variable-name-pair{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px}.variable-assignment-list{display:grid;gap:10px}.variable-assignment-row{display:grid;grid-template-columns:minmax(220px,.9fr) minmax(260px,1fr) 34px;gap:8px;align-items:start;padding:10px;border-radius:6px;background:#111c2bb8}.action-picker{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:10px}.action-pick{display:grid;grid-template-columns:28px 1fr;gap:6px 10px;text-align:left;background:#111c2b;border:1px solid rgba(148,163,184,.16);color:#e5eefc;border-radius:8px;padding:12px;cursor:pointer}.action-pick:hover{border-color:#38bdf899}.action-pick small{grid-column:2;color:#91a1b7;line-height:1.45}.keyboard-preview{background:#111c2b;border-radius:8px;padding:12px}.keyboard-line{display:grid;grid-template-columns:70px minmax(0,1fr);gap:10px;align-items:center;margin-top:10px}.keyboard-pills{display:flex;flex-wrap:wrap;gap:8px}@media(max-width:900px){.login-page{grid-template-columns:1fr}.login-visual{display:none}.metric-row{grid-template-columns:repeat(2,minmax(140px,1fr))}}@media(max-width:620px){.metric-row{grid-template-columns:1fr}.page-title{flex-direction:column}.button-editor,.flow-meta,.flow-editor,.tree-flow-editor,.keyboard-button-config,.variable-name-pair,.variable-assignment-row{grid-template-columns:1fr}}
