@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-dark:#0f1115;--bg-gradient:linear-gradient(135deg, #0f1115 0%, #1a1c23 100%);--panel-bg:#191c23a6;--panel-border:#ffffff14;--panel-blur:blur(16px);--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-blue:#3b82f6;--accent-blue-glow:#3b82f666;--status-normal:#10b981;--status-normal-glow:#10b9814d;--status-warning:#f59e0b;--status-warning-glow:#f59e0b4d;--status-danger:#ef4444;--status-danger-glow:#ef444466;--node-bg:#1e2128cc;--node-border:#ffffff1a;--node-radius:12px}*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,sans-serif}body{background:var(--bg-dark);color:var(--text-primary);background-image:radial-gradient(circle at 15%,#3b82f614,#0000 25%),radial-gradient(circle at 85% 30%,#10b9810d,#0000 25%);width:100vw;height:100vh;overflow:hidden}.glass-panel{background:var(--panel-bg);-webkit-backdrop-filter:var(--panel-blur);border:1px solid var(--panel-border);border-radius:16px;box-shadow:0 8px 32px #0003}.custom-node{border-radius:var(--node-radius);background:var(--node-bg);border:1.5px solid var(--node-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:240px;padding:16px;transition:all .3s;position:relative;overflow:visible}.custom-node:hover{border-color:#fff3;box-shadow:0 10px 25px #0000004d}.custom-node.selected{border-color:var(--accent-blue);box-shadow:0 0 15px var(--accent-blue-glow)}.custom-node.status-normal{border-top:3px solid var(--status-normal)}.custom-node.status-warning{border-top:3px solid var(--status-warning);animation:2s infinite pulse-warning}.custom-node.status-danger{border-top:3px solid var(--status-danger);animation:1s infinite pulse-danger}@keyframes pulse-warning{0%{box-shadow:0 0 0 0 var(--status-warning-glow)}70%{box-shadow:0 0 0 10px #f59e0b00}to{box-shadow:0 0 #f59e0b00}}@keyframes pulse-danger{0%{box-shadow:0 0 0 0 var(--status-danger-glow)}70%{box-shadow:0 0 0 15px #ef444400}to{box-shadow:0 0 #ef444400}}.react-flow__handle{background:var(--accent-blue);border:2px solid var(--bg-dark);z-index:3;border-radius:999px;width:18px;height:18px;transition:background .2s,box-shadow .2s;box-shadow:0 0 0 4px #3b82f62e}.react-flow__handle:hover,.react-flow__handle-connecting,.react-flow__handle-valid{background:#60a5fa;box-shadow:0 0 0 6px #60a5fa38}.react-flow__handle-top{top:-10px}.react-flow__handle-bottom{bottom:-10px}.btn{cursor:pointer;color:#fff;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.btn-primary{background:var(--accent-blue);box-shadow:0 4px 14px var(--accent-blue-glow)}.btn-primary:hover{background:#2563eb;transform:translateY(-1px)}.btn-danger{background:var(--status-danger);box-shadow:0 4px 14px var(--status-danger-glow)}.btn-danger:hover{background:#dc2626}.btn-success{background:var(--status-normal);box-shadow:0 4px 14px var(--status-normal-glow)}.btn-success:hover{background:#059669}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}input[type=number],input[type=text]{border:1px solid var(--panel-border);color:#fff;background:#0f1115cc;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:14px;transition:border .2s}input:focus{border-color:var(--accent-blue)}.text-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.flex-row{align-items:center;gap:8px;display:flex}.flex-col{flex-direction:column;gap:4px;display:flex}.justify-between{justify-content:space-between}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.text-secondary{color:var(--text-secondary)}.progress-bg{background:#ffffff1a;border-radius:3px;width:100%;height:6px;margin-top:8px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .3s,background-color .3s}.app-container{width:100vw;height:100vh;position:relative}.sidebar-item{border:1px solid var(--panel-border);cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff0a;border-radius:8px;padding:10px 12px;transition:background .2s,border-color .2s}.sidebar-item:hover{background:#ffffff14;border-color:#ffffff26}.glass-panel::-webkit-scrollbar{width:4px}.glass-panel::-webkit-scrollbar-track{background:0 0}.glass-panel::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.react-flow__background{background-color:#0000!important}.react-flow__background path{stroke:#ffffff0d!important}.react-flow__node.selected .custom-node{border-color:var(--accent-blue)!important;box-shadow:0 0 10px #3b82f64d!important}.react-flow__node.selected,.react-flow__node:focus{box-shadow:none!important;outline:none!important}.live-dot{background:var(--status-danger);border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:1.5s infinite live-pulse}@keyframes live-pulse{0%{box-shadow:0 0 #ef444499}70%{box-shadow:0 0 0 8px #ef444400}to{box-shadow:0 0 #ef444400}}.react-flow__edge-path{stroke-width:2px}.react-flow__controls button{background:var(--panel-bg)!important;border:1px solid var(--panel-border)!important;color:#fff!important;fill:#fff!important}.react-flow__controls button:hover{background:#3b82f633!important}.react-flow__controls button svg{fill:#fff!important}.react-flow__minimap{background:var(--panel-bg)!important;border:1px solid var(--panel-border)!important;border-radius:8px!important}.react-flow{direction:ltr}.react-flow__container{width:100%;height:100%;position:absolute;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:1px;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{-webkit-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab;position:absolute}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:-webkit-grab;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;background:#1a192b;border:1px solid #fff;border-radius:100%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:-4px;left:50%;transform:translate(-50%)}.react-flow__handle-top{top:-4px;left:50%;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{top:50%;right:-4px;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{z-index:5;margin:15px;position:absolute}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{background:#ffffff80;margin:0;padding:2px 3px;font-size:10px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10px}}.react-flow__edgelabel-renderer{pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute}.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{color:#222;text-align:center;background-color:#fff;border:1px solid #1a192b;border-radius:3px;width:150px;padding:10px;font-size:12px}.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 #0059dccc}.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{box-sizing:content-box;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fefefe;border:none;border-bottom:1px solid #eee;justify-content:center;align-items:center;width:16px;height:16px;padding:5px;display:flex}.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{background-color:#3367d9;border:1px solid #fff;border-radius:1px;width:4px;height:4px;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{top:50%;left:0}.react-flow__resize-control.handle.right{top:50%;left:100%}.react-flow__resize-control.handle.top{top:0;left:50%}.react-flow__resize-control.handle.bottom{top:100%;left:50%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border:0 solid #3367d9}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;height:100%;top:0;transform:translate(-50%)}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{width:100%;height:1px;left:0;transform:translateY(-50%)}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}
