.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%}.device-node{background:#fff9;border:2px solid transparent;border-radius:8px;padding:16px 0;width:320px;min-width:320px;max-width:320px;min-height:150px;box-sizing:border-box;box-shadow:0 16px 40px #e9ecf1;transition:box-shadow 0s,min-height .2s,background-color .3s ease,border 0s;display:flex;gap:8px;align-items:flex-start;position:relative;transform-origin:top left;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.react-flow__node.selected .device-node{border:2px solid #8B5CF6;box-shadow:0 16px 40px #8b5cf64d}.react-flow__node.selected .device-node:hover{box-shadow:0 16px 40px #8b5cf64d}[data-theme=dark] .device-node{background:#1a1a1a99;box-shadow:0 16px 40px #0006}.device-node:hover{box-shadow:0 16px 40px #e9ecf199}[data-theme=dark] .device-node:hover{box-shadow:0 16px 40px #0009}[data-theme=dark] .react-flow__node.selected .device-node:hover{box-shadow:0 16px 40px #8b5cf64d}.device-node:focus-within{box-shadow:0 16px 40px #e9ecf199}[data-theme=dark] .device-node:focus-within{box-shadow:0 16px 40px #0009}.device-node-connection-point{width:36px;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;position:relative;padding-top:0;padding-left:12px;gap:8px}.device-node-handle-wrapper{position:absolute;left:12px;width:16px;height:16px;cursor:pointer;z-index:10;pointer-events:none}.device-node-handle-wrapper .device-node-handle-left{left:0!important;top:0!important}.device-node-handle-wrapper .device-node-handle-left:not(.no-connection):not(.selected-for-deletion):after{background:var(--handle-color, #8B5CF6)!important}.device-node-handle-left:not(.no-connection):not(.selected-for-deletion):after{background:var(--handle-color, #8B5CF6)!important}.device-node-handle-left{width:16px!important;height:16px!important;border:1px solid #c4c4c4!important;border-radius:10px!important;background:#fff!important;left:12px!important;top:0!important;transform:none!important;position:absolute!important;padding:5px!important;box-sizing:border-box!important;cursor:pointer!important;z-index:1000!important;transition:background-color .3s ease,border-color .3s ease}[data-theme=dark] .device-node-handle-left{border:1px solid #404040!important;background:#2a2a2a!important}.device-node-handle-left-1{top:22px!important}.device-node-handle-left-2{top:44px!important}.device-node-handle-left-3{top:66px!important}.device-node-handle-left:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;background:var(--handle-color, #8B5CF6);border-radius:50%}.device-node-handle-left.no-connection:after{background:#ddd!important}[data-theme=dark] .device-node-handle-left.no-connection:after{background:#555!important}.device-node-handle-left.selected-for-deletion:after{background:#ff6b6b!important}.device-node-handle-right{width:16px!important;height:16px!important;border:1px solid #c4c4c4!important;border-radius:10px!important;background:#fff!important;right:-8px!important;padding:5px!important;box-sizing:border-box!important;transition:background-color .3s ease,border-color .3s ease}[data-theme=dark] .device-node-handle-right{border:1px solid #404040!important;background:#2a2a2a!important}.device-node-handle-right:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;background:#8b5cf6;border-radius:50%}.device-node-content{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0;overflow:hidden;padding-right:12px;box-sizing:border-box}.device-node-header{display:flex;flex-direction:column;gap:0;line-height:0}.device-node-brand,.device-node-brand-input{font-family:LETS Sans Variable,sans-serif;font-size:12px;line-height:12px;color:#969696;letter-spacing:-.264px;margin-bottom:0;text-transform:uppercase;transition:color .3s ease}[data-theme=dark] .device-node-brand,[data-theme=dark] .device-node-brand-input{color:gray!important}.device-node-brand-input{background:transparent;border:none;outline:none;padding:0;width:100%;font-size:12px;line-height:12px}.device-node-brand-input:focus{background:#8b5cf614;border-radius:2px}[data-theme=dark] .device-node-brand-input:focus{background:#8b5cf62e}.device-node-title,.device-node-title-input{font-family:LETS Sans Variable,sans-serif;font-weight:400;font-size:20px;line-height:24px;color:#202020;letter-spacing:-.44px;margin-top:0;margin-bottom:0;word-wrap:break-word;transition:color .3s ease}[data-theme=dark] .device-node-title,[data-theme=dark] .device-node-title-input{color:#fff}.device-node-title-input{background:transparent;border:none;outline:none;padding:0;width:100%;font-size:20px;line-height:24px}.device-node-title-input:focus{background:#8b5cf614;border-radius:2px}[data-theme=dark] .device-node-title-input:focus{background:#8b5cf62e}.device-node-details-section{display:flex;flex-direction:column;gap:4px;line-height:0}.details-label{font-family:LETS Sans Variable,sans-serif;font-weight:500;font-size:10px;line-height:12px;color:#969696;letter-spacing:-.1px;text-transform:uppercase;transition:color .3s ease}[data-theme=dark] .details-label{color:gray!important}.device-node-description,.device-node-description-input{font-family:LETS Sans Variable,sans-serif;font-weight:400;font-size:12px;line-height:16px;color:#616161;word-wrap:break-word;margin:0;transition:color .3s ease}[data-theme=dark] .device-node-description,[data-theme=dark] .device-node-description-input{color:#ccc}.device-node-description-input{background:transparent;border:none;outline:none;padding:0;width:100%;resize:none;font-size:12px;line-height:16px;font-family:inherit;min-height:16px;overflow:hidden}.device-node-description-input:focus{background:#8b5cf614;border-radius:2px}[data-theme=dark] .device-node-description-input:focus{background:#8b5cf62e}.device-node-divider{background:#c4c4c4;height:1px;width:100%;flex-shrink:0;transition:background-color .3s ease}[data-theme=dark] .device-node-divider{background:#404040}.device-node-fields{display:flex;flex-direction:column;gap:6px;margin-top:2px}.device-node-field{display:flex;gap:16px;align-items:flex-start;width:100%;position:relative;min-height:16px;box-sizing:border-box;max-width:100%;overflow:hidden}.field-name-container{flex:3 1 0;min-width:0;max-width:60%;display:flex;align-items:flex-start;position:relative;gap:4px;padding-top:0;box-sizing:border-box}.field-name,.field-name-input{flex:1;min-width:0;display:block;align-items:flex-start;position:relative;font-family:LETS Sans Variable,sans-serif;font-weight:400;font-size:10px;line-height:16px;color:#333;letter-spacing:-.15px;white-space:normal;word-wrap:break-word;text-transform:uppercase;transition:color .3s ease}[data-theme=dark] .field-name,[data-theme=dark] .field-name-input{color:#ccc}.field-name-input{width:100%;background:transparent;border:none;outline:none;padding:0;font-size:10px;line-height:16px;min-height:16px;resize:none;overflow:hidden}.field-name-input:focus{background:#8b5cf614;border-radius:2px}[data-theme=dark] .field-name-input:focus{background:#8b5cf62e}.field-value-container{display:flex;align-items:flex-start;gap:4px;flex:2 1 0;min-width:0;max-width:40%;position:relative;justify-content:flex-end;padding-top:0;box-sizing:border-box}.field-value,.field-value-input{font-family:LETS Sans Variable,sans-serif;font-weight:400;font-size:10px;line-height:16px;color:#333;letter-spacing:-.15px;white-space:normal;word-wrap:break-word;flex:1;min-width:0;transition:color .3s ease}[data-theme=dark] .field-value,[data-theme=dark] .field-value-input{color:#ccc}.field-value-input{text-transform:uppercase;background:transparent!important;border:none!important;outline:none!important;padding:0;min-height:16px;text-align:right;resize:none!important;overflow:hidden!important;-ms-overflow-style:none;scrollbar-width:none;box-shadow:none!important}.field-value-input::-webkit-scrollbar{display:none;width:0;height:0}.field-value-input::-webkit-resizer{display:none}.field-value-input:focus{background:#8b5cf614;border-radius:2px;border:none!important;outline:none!important;box-shadow:none!important}[data-theme=dark] .field-value-input{background:transparent}[data-theme=dark] .field-value-input:focus{background:#8b5cf62e;border:none!important;outline:none!important;box-shadow:none!important}[data-theme=dark] .device-node input,[data-theme=dark] .device-node textarea{background:transparent!important}[data-theme=dark] .device-node{color:#e0e0e0}[data-theme=dark] .device-node input::placeholder,[data-theme=dark] .device-node textarea::placeholder{color:#999}[data-theme=dark] .device-node p,[data-theme=dark] .device-node span,[data-theme=dark] .device-node div:not(.device-node):not(.device-node-content):not(.device-node-header):not(.device-node-details-section):not(.device-node-fields):not(.device-node-field):not(.field-name-container):not(.field-value-container):not(.field-connection-point):not(.details-label):not(.device-node-brand){color:#e0e0e0}[data-theme=dark] .device-node *{color:inherit}[data-theme=dark] .device-node .device-node-brand-input{color:gray!important}[data-theme=dark] .device-node .device-node-title-input,[data-theme=dark] .device-node .device-node-description-input,[data-theme=dark] .device-node .field-name-input,[data-theme=dark] .device-node .field-value-input{color:inherit!important}.field-connection-point{width:16px;min-height:16px;display:flex;align-items:flex-start;justify-content:center;margin-left:0;flex-shrink:0;position:relative;padding-top:0;box-sizing:border-box}.field-connection-handle{width:16px!important;height:16px!important;background:#fff!important;border:1px solid #c4c4c4!important;border-radius:10px!important;padding:5px!important;box-sizing:border-box!important;position:relative!important;right:auto!important;top:0!important;transform:none!important;flex-shrink:0!important;align-self:flex-start!important;cursor:pointer!important;transition:background-color .3s ease,border-color .3s ease}[data-theme=dark] .field-connection-handle{background:#2a2a2a!important;border:1px solid #404040!important}.field-connection-handle:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;background:var(--handle-color, #8B5CF6)!important;border-radius:50%}.field-connection-handle.no-connection:after{background:#ddd!important}[data-theme=dark] .field-connection-handle.no-connection:after{background:#555!important}.connection-dot-small{width:16px;height:16px;border:1px solid #c4c4c4;border-radius:10px;display:flex;align-items:center;justify-content:center;position:relative;background:#fff;transition:background-color .3s ease,border-color .3s ease}[data-theme=dark] .connection-dot-small{border:1px solid #404040;background:#2a2a2a}.connection-dot-small:after{content:"";width:6px;height:6px;background:#8b5cf6;border-radius:50%;position:absolute}.field-duplicate-button{background:none;border:none;color:#616161;font-size:16px;cursor:pointer;padding:0;line-height:16px;opacity:0;transition:opacity .2s,color .2s;flex-shrink:0;width:18px;height:16px;display:flex;align-items:center;justify-content:center;margin-right:-4px}.field-duplicate-button:hover{color:#8b5cf6}.field-remove-button{background:none;border:none;color:#ff6b6b;font-size:16px;cursor:pointer;padding:0;line-height:16px;opacity:0;transition:opacity .2s;flex-shrink:0;width:18px;height:16px;display:flex;align-items:center;justify-content:center}.device-node-field:hover .field-duplicate-button,.device-node-field:hover .field-remove-button{opacity:1}[data-theme=dark] .field-duplicate-button{color:#999}[data-theme=dark] .field-duplicate-button:hover{color:#a78bfa}.add-field-button{background:transparent;border:1px dashed #c4c4c4;color:#616161;font-family:LETS Sans Variable,sans-serif;font-size:10px;padding:4px 8px;border-radius:4px;cursor:pointer;transition:border-color .3s ease,color .3s ease}[data-theme=dark] .add-field-button{border:1px dashed #404040;color:#999}margin-top: 4px; width: 100%; text-align: left; height: 24px; box-sizing: border-box; } .add-field-button.invisible{display:none}.add-field-button.visible{display:block}.add-field-button:hover{background:#8b5cf60d;border-color:#8b5cf6;color:#8b5cf6}[data-theme=dark] .add-field-button:hover{background:#8b5cf626;border-color:#a78bfa;color:#a78bfa}.delete-node-button{background:#757575;border:none;color:#fff;padding:4px;border-radius:4px;cursor:pointer;width:20px;height:20px;display:flex;align-items:center;justify-content:center;transition:background-color .2s;position:absolute;left:10px;z-index:10}[data-theme=dark] .delete-node-button{background:#404040}.delete-node-button svg{width:14px;height:14px;stroke:#fff}.delete-node-button.invisible{opacity:0;pointer-events:none}.delete-node-button.visible{opacity:1;pointer-events:auto}.delete-node-button:hover{background:#ff6b6b}[data-theme=dark] .delete-node-button:hover{background:#ef4444}.add-input-node-button{background:#757575;border:none;color:#fff;padding:0;border-radius:50%;cursor:pointer;width:16px;height:16px;display:flex;align-items:center;justify-content:center;transition:background-color .2s;position:absolute;left:12px;z-index:10}[data-theme=dark] .add-input-node-button{background:#404040}.add-input-node-button svg{width:10px;height:10px;stroke:#fff;stroke-width:2}.add-input-node-button.invisible{opacity:0;pointer-events:none}.add-input-node-button.visible{opacity:1;pointer-events:auto}.add-input-node-button:hover{background:#8b5cf6}[data-theme=dark] .add-input-node-button:hover{background:#7c3aed}.toolbar{height:60px;background:transparent;border-bottom:none;display:flex;align-items:center;justify-content:space-between;padding:0 20px;box-shadow:none;position:fixed;top:0;left:0;right:0;width:100%;z-index:10;transition:background-color .3s ease,border-color .3s ease}[data-theme=dark] .toolbar{background:transparent;border-bottom:none;box-shadow:none}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:12px}.toolbar-section{position:relative}.toolbar-button{height:32px;padding:0 14px;border:none;background:#f5f5f5;border-radius:4px;cursor:pointer;font-family:LETS Sans Variable,sans-serif;font-size:13px;font-weight:500;line-height:1;color:#374151;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px;box-sizing:border-box}[data-theme=dark] .toolbar-button{border:none;background:#2a2a2a;color:#e0e0e0}.toolbar-button:hover,[data-theme=dark] .toolbar-button:hover{color:#fff;background:#8b5cf6}.toolbar-button.primary{background:#8b5cf6;color:#fff}.toolbar-button.primary:hover{background:#7c3aed}[data-theme=dark] .toolbar-button.primary:hover{background:#9d7af5;color:#fff}.toolbar-button.danger{color:#6b7280}[data-theme=dark] .toolbar-button.danger{color:#9ca3af}.toolbar-button.danger:hover,[data-theme=dark] .toolbar-button.danger:hover{background:#ef4444;color:#fff}.device-menu{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border:2px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:180px;z-index:100;overflow:hidden;transition:background-color .3s ease,border-color .3s ease}[data-theme=dark] .device-menu{background:#1a1a1a;border:2px solid #2a2a2a;box-shadow:0 4px 12px #0006}.device-menu-item{width:100%;padding:12px 16px;border:none;background:#fff;text-align:left;cursor:pointer;font-size:14px;color:#333;transition:background .2s,color .2s;border-bottom:1px solid #f0f0f0}[data-theme=dark] .device-menu-item{background:#1a1a1a;color:#e0e0e0;border-bottom:1px solid #2a2a2a}.device-menu-item:last-child{border-bottom:none}.device-menu-item:hover{background:#f5f5f5;color:#8b5cf6}[data-theme=dark] .device-menu-item:hover{background:#2a2a2a;color:#a78bfa}.hash-section{display:flex;align-items:center;gap:10px}.hash-load{display:flex;align-items:center;gap:0;border:1px solid #d1d5db;border-radius:4px;overflow:hidden;transition:all .15s}[data-theme=dark] .hash-load{border:1px solid #404040}.hash-load:focus-within{border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf61a}.hash-input{height:32px;padding:0 12px;border:none;border-radius:0;font-size:13px;font-family:LETS Sans Variable,sans-serif;font-weight:400;width:250px;background:#fff;color:#374151;transition:all .15s;box-sizing:border-box}[data-theme=dark] .hash-input{background:#2a2a2a;color:#e0e0e0}[data-theme=dark] .hash-input::placeholder{color:#999}.hash-input:focus{outline:none}.hash-load .toolbar-button{height:32px;border:none;border-radius:0;padding:0 14px;margin:0}[data-theme=dark] .hash-load .toolbar-button{background:#2a2a2a}.hash-load .toolbar-button:hover{background:#8b5cf6;color:#fff}.hash-input::placeholder{color:#9ca3af;font-weight:400}.toolbar-button.copied{background:#10b981;color:#fff}.toolbar-button.copied:hover{background:#059669}.hash-section>.toolbar-button{min-width:120px;justify-content:center}.snap-lines-container{pointer-events:none}.modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}[data-theme=dark] .modal-backdrop{background:#000000b3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:#fff;border-radius:8px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;width:90%;padding:24px;animation:slideUp .2s ease-out;font-family:LETS Sans Variable,sans-serif;transition:background-color .3s ease,color .3s ease}[data-theme=dark] .modal-container{background:#1a1a1a;box-shadow:0 20px 25px -5px #0006,0 10px 10px -5px #0003}@keyframes slideUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-title{font-size:18px;font-weight:500;color:#202020;margin-bottom:12px;letter-spacing:-.36px;transition:color .3s ease}[data-theme=dark] .modal-title{color:#e0e0e0}.modal-message{font-size:14px;font-weight:400;color:#616161;line-height:20px;margin-bottom:24px;letter-spacing:-.14px;transition:color .3s ease}[data-theme=dark] .modal-message{color:#ccc}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.modal-button{height:32px;padding:0 16px;border:1px solid #d1d5db;background:#fff;border-radius:4px;cursor:pointer;font-family:LETS Sans Variable,sans-serif;font-size:13px;font-weight:500;color:#374151;transition:all .15s;display:flex;align-items:center;justify-content:center;box-sizing:border-box;min-width:80px}[data-theme=dark] .modal-button{border:1px solid #404040;background:#2a2a2a;color:#e0e0e0}.modal-button:hover{border-color:#8b5cf6;color:#8b5cf6;background:#faf5ff}[data-theme=dark] .modal-button:hover{border-color:#8b5cf6;color:#8b5cf6;background:#2a1a3a}.modal-button-primary{background:#8b5cf6;color:#fff;border-color:#8b5cf6}.modal-button-primary:hover{background:#7c3aed;border-color:#7c3aed;color:#fff}.modal-button-secondary{background:#fff;color:#374151;border-color:#d1d5db}[data-theme=dark] .modal-button-secondary{background:#2a2a2a;color:#e0e0e0;border-color:#404040}.modal-button-secondary:hover{background:#f9fafb;border-color:#9ca3af;color:#374151}[data-theme=dark] .modal-button-secondary:hover{background:#404040;border-color:#555;color:#e0e0e0}.edge-tooltip{position:fixed;pointer-events:none;z-index:10000;transform:translate(-50%,-100%);margin-top:-8px}.edge-tooltip-content{border-radius:6px;padding:8px 12px;box-shadow:0 4px 12px #00000040;font-family:LETS Sans Variable,sans-serif;font-size:12px;min-width:100px;max-width:300px;white-space:nowrap}.edge-tooltip-text{word-break:break-word;white-space:normal;text-align:center}.edge-style-menu-overlay{position:fixed;inset:0;z-index:1000;background:transparent}.edge-style-menu{position:fixed;background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:1001;min-width:160px;padding:4px;transform:translate(-50%,10px);font-family:LETS Sans Variable,sans-serif}[data-theme=dark] .edge-style-menu{background:#1a1a1a;border-color:#404040;box-shadow:0 4px 6px -1px #0000004d,0 2px 4px -1px #0003}.edge-style-menu-title{padding:6px 12px;font-family:LETS Sans Variable,sans-serif;font-size:10px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e5e7eb;margin-bottom:4px}[data-theme=dark] .edge-style-menu-title{color:#9ca3af;border-bottom-color:#404040}.edge-style-menu-item{display:flex;align-items:center;width:100%;padding:6px 12px;background:transparent;border:none;border-radius:4px;cursor:pointer;font-family:LETS Sans Variable,sans-serif;font-size:12px;font-weight:400;color:#374151;transition:background-color .15s ease;gap:8px}[data-theme=dark] .edge-style-menu-item{color:#e5e7eb}.edge-style-menu-item:hover{background:#f3f4f6}[data-theme=dark] .edge-style-menu-item:hover{background:#2a2a2a}.edge-style-menu-item.active{background:#ede9fe;color:#7c3aed}[data-theme=dark] .edge-style-menu-item.active{background:#3a2a4a;color:#a78bfa}.edge-style-icon{font-size:14px;width:20px;text-align:center;font-family:monospace}.checkmark{margin-left:auto;color:#7c3aed;font-weight:600}[data-theme=dark] .checkmark{color:#a78bfa}.edge-style-menu-divider{height:1px;background:#e5e7eb;margin:4px -4px;width:calc(100% + 8px)}[data-theme=dark] .edge-style-menu-divider{background:#404040}.edge-color-picker-section{padding:4px 0}.edge-color-presets{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;padding:0 12px 8px}.edge-color-swatch{width:20px;height:20px;border:2px solid #e5e7eb;border-radius:4px;cursor:pointer;padding:0;background:none;transition:all .15s ease;position:relative;box-shadow:0 1px 2px #0000000d}[data-theme=dark] .edge-color-swatch{border-color:#404040;box-shadow:0 1px 2px #0000004d}.edge-color-swatch:hover{transform:scale(1.08);border-color:#8b5cf6;box-shadow:0 2px 4px #8b5cf633;z-index:1}[data-theme=dark] .edge-color-swatch:hover{border-color:#a78bfa;box-shadow:0 2px 4px #a78bfa4d}.edge-color-swatch.active{border-color:#7c3aed;box-shadow:0 0 0 2px #7c3aed33,0 2px 4px #7c3aed26;transform:scale(1.05)}[data-theme=dark] .edge-color-swatch.active{border-color:#a78bfa;box-shadow:0 0 0 2px #a78bfa4d,0 2px 4px #a78bfa33}.edge-color-custom{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:4px;transition:background-color .15s ease}.edge-color-custom:hover{background:#f3f4f6}[data-theme=dark] .edge-color-custom:hover{background:#2a2a2a}.edge-color-input{width:20px;height:20px;border:2px solid #d1d5db;border-radius:4px;cursor:pointer;padding:2px;background:#fff;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:all .15s ease;box-shadow:0 1px 2px #0000000d;overflow:hidden;flex-shrink:0}.edge-color-input:hover{border-color:#8b5cf6;box-shadow:0 2px 4px #8b5cf633;transform:scale(1.05)}.edge-color-input:active{transform:scale(.98)}.edge-color-input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf633,0 2px 4px #8b5cf626}.edge-color-input::-webkit-color-swatch-wrapper{padding:0;border:none;border-radius:2px;width:100%;height:100%}.edge-color-input::-webkit-color-swatch{border:none;border-radius:2px;width:100%;height:100%}.edge-color-input::-moz-color-swatch{border:none;border-radius:2px;width:100%;height:100%}[data-theme=dark] .edge-color-input{border-color:#404040;background:#2a2a2a;box-shadow:0 1px 2px #0000004d}[data-theme=dark] .edge-color-input:hover{border-color:#a78bfa;box-shadow:0 2px 4px #a78bfa4d}[data-theme=dark] .edge-color-input:focus{border-color:#a78bfa;box-shadow:0 0 0 2px #a78bfa4d,0 2px 4px #a78bfa33}.edge-color-label{font-family:LETS Sans Variable,sans-serif;font-size:12px;font-weight:400;color:#374151}[data-theme=dark] .edge-color-label{color:#e5e7eb}.app-container{width:100%;height:100vh;display:flex;flex-direction:column;background:#fff;transition:background-color .3s ease}[data-theme=dark] .app-container{background:#0a0a0a}.diagram-container{flex:1;position:relative;width:100%;height:100vh;background:#fff;transition:background-color .3s ease}[data-theme=dark] .diagram-container{background:#0a0a0a}.react-flow-container{width:100%;height:100%}.react-flow__edge-path{stroke-width:2;cursor:pointer;transition:stroke-width .2s ease;pointer-events:stroke}.react-flow__edge-text{fill:#8b5cf6!important;font-weight:600!important}[data-theme=dark] .react-flow__edge-text{fill:#a78bfa!important}.react-flow__edge-textbg{fill:#fff!important}[data-theme=dark] .react-flow__edge-textbg{fill:#1a1a1a!important}.react-flow__background,.react-flow__background-pattern,[data-theme=dark] .react-flow__background,[data-theme=dark] .react-flow__background-pattern,.react-flow__attribution{display:none!important}.react-flow__minimap{background:#f5f5f5!important;border:1px solid #d1d5db!important;border-radius:4px!important;box-shadow:none!important}[data-theme=dark] .react-flow__minimap{background:#0a0a0a!important;border:1px solid #2a2a2a!important;opacity:.5!important}[data-theme=dark] .react-flow__minimap svg{opacity:.7}[data-theme=dark] .react-flow__minimap .react-flow__minimap-mask{fill:#0a0a0a!important}.react-flow__pane,.react-flow__handle,.react-flow__handle-top,.react-flow__handle-bottom,.react-flow__handle-left,.react-flow__handle-right{cursor:pointer!important}[data-theme=dark] .react-flow__controls{background:#1a1a1a!important;border:1px solid #2a2a2a!important}[data-theme=dark] .react-flow__controls-button{background:#2a2a2a!important;border-bottom:1px solid #404040!important;color:#e0e0e0!important}[data-theme=dark] .react-flow__controls-button:hover{background:#404040!important}[data-theme=dark] .react-flow__controls-button svg{fill:#e0e0e0!important}@font-face{font-family:LETS Sans Variable;src:url(/assets/LETSSansVF-pkgeAUSn.woff2) format("woff2");font-weight:100 900;font-stretch:75% 100%;font-style:normal;font-display:swap}*{margin:0;padding:0;box-sizing:border-box}body{font-family:LETS Sans Variable,-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;background:#fff;transition:background-color .3s ease}[data-theme=dark] body{background:#0a0a0a}#root{width:100%;height:100vh}
