.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,0.5);--xy-minimap-background-color-default:#fff;--xy-minimap-mask-background-color-default:rgb(240,240,240,0.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,0.25);--xy-node-boxshadow-hover-default:0 1px 4px 1px rgba(0,0,0,0.08);--xy-node-boxshadow-selected-default:0 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,0.08);--xy-selection-border-default:1px dotted rgba(0,89,220,0.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,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,0.25);--xy-minimap-background-color-default:#141414;--xy-minimap-mask-background-color-default:rgb(60,60,60,0.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,0.25);--xy-node-boxshadow-hover-default:0 1px 4px 1px rgba(255,255,255,0.08);--xy-node-boxshadow-selected-default:0 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,0.08);--xy-selection-border-default:1px dotted rgba(200,200,220,0.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,0.08);--xy-edge-label-background-color-default:#141414;--xy-edge-label-color-default:#f8f8f8}.react-flow__background{background-color:var(--xy-background-color,var(--xy-background-color-props,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}.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.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path,.react-flow__edge.selected .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__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__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:translateX(-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{pointer-events:none}.react-flow__edgelabel-renderer,.react-flow__viewport-portal{position:absolute;width:100%;height:100%;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top: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{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-default,.react-flow__node-group,.react-flow__node-input,.react-flow__node-output{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-default.selectable:hover,.react-flow__node-group.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover,var(--xy-node-boxshadow-hover-default))}.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: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__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{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));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.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-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.bottom,.react-flow__resize-control.line.top{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))}.react-flow{--xy-node-border-default:1px solid #ccc;--xy-theme-selected:#f57dbd;--xy-theme-hover:#9f0101;--xy-theme-edge-hover:black;--xy-theme-color-focus:#e8e8e8;--xy-theme-box-shadow:0 1px 3px 0px rgba(0,0,0,0.7);--port-color-audio:#059669;--port-color-midi:#d97706;--port-color-usb:#2563eb;--port-color-audio-hover:#10b981;--port-color-midi-hover:#f59e0b;--port-color-usb-hover:#3b82f6;--edge-glow-selected:4px;--edge-glow-hover:2px}@media (prefers-color-scheme:dark){.react-flow{--port-color-audio:#34d399;--port-color-midi:#fbbf24;--port-color-usb:#60a5fa;--port-color-audio-hover:#6ee7b7;--port-color-midi-hover:#fcd34d;--port-color-usb-hover:#93c5fd}}.react-flow__edges{z-index:900!important}.react-flow__nodes{z-index:auto!important}.react-flow__viewport .react-flow__edges{z-index:900!important}.react-flow__viewport .react-flow__nodes{z-index:auto!important}.react-flow__edge{position:relative!important}.react-flow__nodes .react-flow__node:has(.zone-node){z-index:800!important}.react-flow__nodes .react-flow__node:has(.device-node){z-index:1000!important}.react-flow__edge.selected .react-flow__edge-path{filter:drop-shadow(0 0 var(--edge-glow-selected) var(--port-color-audio));stroke-width:3px!important}.react-flow__edge:hover .react-flow__edge-path{filter:drop-shadow(0 0 var(--edge-glow-hover) var(--port-color-audio-hover));stroke-width:2.5px!important}.react-flow__edge.edge-audio .react-flow__edge-path{stroke:var(--port-color-audio)}.react-flow__edge.edge-midi .react-flow__edge-path{stroke:var(--port-color-midi)}.react-flow__edge.edge-usb .react-flow__edge-path{stroke:var(--port-color-usb)}.react-flow__edge.edge-audio.selected .react-flow__edge-path{filter:drop-shadow(0 0 var(--edge-glow-selected) var(--port-color-audio))}.react-flow__edge.edge-midi.selected .react-flow__edge-path{filter:drop-shadow(0 0 var(--edge-glow-selected) var(--port-color-midi))}.react-flow__edge.edge-usb.selected .react-flow__edge-path{filter:drop-shadow(0 0 var(--edge-glow-selected) var(--port-color-usb))}.react-flow__edge.edge-audio:hover .react-flow__edge-path{filter:drop-shadow(0 0 var(--edge-glow-hover) var(--port-color-audio-hover))}.react-flow__edge.edge-midi:hover .react-flow__edge-path{filter:drop-shadow(0 0 var(--edge-glow-hover) var(--port-color-midi-hover))}.react-flow__edge.edge-usb:hover .react-flow__edge-path{filter:drop-shadow(0 0 var(--edge-glow-hover) var(--port-color-usb-hover))}.react-flow__node{border:2px solid rgba(0,0,0,0);background-color:var(--xy-node-background-color-default);box-shadow:var(--xy-theme-box-shadow);border-radius:8px;color:var(--xy-node-color-default);&.selected.draggable:active{box-shadow:0 5px 10px 0 rgba(0,0,0,.3)}&:hover{border-color:hsl(var(--heroui-primary-200))}&.selected{border-color:hsl(var(--heroui-primary-400))}.device-node{padding:3em 5em;.device-name{font-size:1rem;text-align:center}.port-handle{width:1rem;height:1rem}.react-flow__handle{background:transparent;border:none;width:1rem;height:1rem;transform-origin:center;&.source .port-handle-icon{transform:rotate(180deg)}&.react-flow__handle-bottom{transform:rotate(-90deg);left:0;margin:0 .2rem}&.react-flow__handle-top{transform:rotate(90deg);left:0;margin:0 .2rem}&.react-flow__handle-left{transform:rotate(0deg);top:0;margin:.2rem 0}&.react-flow__handle-right{transform:rotate(0deg);top:0;margin:.2rem 0;.port-handle-icon{transform:rotate(180deg)}&.source .port-handle-icon{transform:rotate(0deg)}}&.react-flow__handle-bottom .port-handle-label>*,&.react-flow__handle-top .port-handle-label>*{display:block;transform-origin:left}&.react-flow__handle-bottom .port-handle-label>*{transform:rotate(45deg)}&.react-flow__handle-top .port-handle-label>*{transform:rotate(-45deg)}.port-handle-icon{position:relative;width:100%;height:100%;border:none;align-items:center;justify-content:center;pointer-events:none;&:before{content:"";position:absolute;width:100%;height:100%;mask:url(/handle_open.svg) center/contain no-repeat;-webkit-mask:url(/handle_open.svg) center/contain no-repeat;background-color:currentColor}}&.port-type-AUDIO .port-handle-icon,&.port-type-AUDIO .port-handle-label{color:var(--port-color-audio);filter:drop-shadow(var(--port-glow-audio,0 0 0 transparent))}&.port-type-MIDI .port-handle-icon,&.port-type-MIDI .port-handle-label{color:var(--port-color-midi);filter:drop-shadow(var(--port-glow-midi,0 0 0 transparent))}&.port-type-USB .port-handle-icon,&.port-type-USB .port-handle-label{color:var(--port-color-usb);filter:drop-shadow(var(--port-glow-usb,0 0 0 transparent))}.port-handle-label{position:absolute;left:100%;top:50%;transform:translateX(.25em) translateY(-50%);font-size:.6em;line-height:1;white-space:nowrap}&.react-flow__handle-right .port-handle-label{right:100%;left:auto;transform:translateX(-.25rem) translateY(-50%)}}.port-handle.connected .port-handle-icon:before{mask:url(/handle_filled.svg) center/contain no-repeat;-webkit-mask:url(/handle_filled.svg) center/contain no-repeat}}}.zone-node{transition:all .2s ease;user-select:none;position:relative;z-index:800}.react-flow__edge,.react-flow__edge path,.react-flow__edge-path{z-index:900!important}.react-flow__node{z-index:auto!important}.react-flow__node[data-id] .zone-node{z-index:800!important}.react-flow__node[data-id] .device-node{z-index:1000!important}.react-flow__node[data-nodetype=zone]{z-index:800!important}.react-flow__node[data-nodetype=device]{z-index:1000!important}.react-flow__node.react-flow__node-zone{z-index:800!important}.react-flow__node.react-flow__node-device{z-index:1000!important}.device-node{z-index:1000;position:relative}.react-flow__node .device-node:hover{box-shadow:0 6px 20px rgba(0,0,0,.25);transition:box-shadow .2s ease}.react-flow__node[data-parent-zone] .device-node{z-index:1001}.zone-node:hover{box-shadow:0 6px 20px rgba(0,0,0,.25);transition:box-shadow .2s ease}.zone-node:after{content:"";position:absolute;inset:-2px;border:2px dashed transparent;border-radius:8px;pointer-events:none;transition:border-color .2s ease}.zone-node:hover:after{border-color:rgba(255,0,113,.4)}.react-flow__node.selected .zone-node{border-color:hsl(var(--heroui-primary));box-shadow:0 0 0 2px hsl(var(--heroui-primary)/.3)}.dark .zone-node{background:hsl(var(--heroui-content2));border-color:hsl(var(--heroui-content3))}.dark .react-flow__node.selected .zone-node{border-color:hsl(var(--heroui-primary))}.react-flow__resize-control{width:12px!important;height:12px!important;border:2px solid #ff0071!important;background:white!important;border-radius:2px!important}.react-flow__resize-control:hover{background:#ff0071!important;transform:scale(1.2);transition:all .2s ease}.react-flow__resize-control.bottom.left,.react-flow__resize-control.bottom.right,.react-flow__resize-control.top.left,.react-flow__resize-control.top.right{width:16px!important;height:16px!important;border-radius:50%!important}.react-flow__resize-control.bottom,.react-flow__resize-control.top{cursor:ns-resize!important}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize!important}.react-flow__resize-control.bottom.right,.react-flow__resize-control.top.left{cursor:nw-resize!important}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:ne-resize!important}.zone-resize-handle{width:14px!important;height:14px!important;background:#ff0071!important;border:2px solid white!important;border-radius:50%!important;opacity:.9}.zone-resize-handle:hover{transform:scale(1.3);opacity:1;box-shadow:0 2px 8px rgba(255,0,113,.4)}.zone-resize-line{stroke-width:2px!important;stroke:#ff0071!important;opacity:.6}