@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}.react-flow{--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:#ffffff80;--xy-minimap-background-color-default:#fff;--xy-minimap-mask-background-color-default:#f0f0f099;--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:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #00000014;--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:#0059dc14;--xy-selection-border-default:1px dotted #0059dccc;--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 #00000014;--xy-edge-label-background-color-default:#fff;--xy-edge-label-color-default:inherit;--xy-resize-background-color-default:#3367d9;direction:ltr}.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:#96969640;--xy-minimap-background-color-default:#141414;--xy-minimap-mask-background-color-default:#3c3c3c99;--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:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #ffffff14;--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:#c8c8dc14;--xy-selection-border-default:1px dotted #c8c8dccc;--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 #00000014;--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{width:100%;height:100%;position:absolute;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{pointer-events:none;position:absolute;overflow:visible}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{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.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;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:.5s linear infinite dashdraw}svg.react-flow__connectionline{z-index:1001;position:absolute;overflow:visible}.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:default;position:absolute}.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:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;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%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:0;left:50%;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{z-index:5;margin:15px;position:absolute}.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{background:var(--xy-attribution-background-color,var(--xy-attribution-background-color-default));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;top:0;left:0}.react-flow__viewport-portal{-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left: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{box-shadow:var(--xy-controls-box-shadow,var(--xy-controls-box-shadow-default));flex-direction:column;display:flex}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{background:var(--xy-controls-button-background-color,var(--xy-controls-button-background-color-default));border:none;border-bottom:1px solid var(--xy-controls-button-border-color-props,var(--xy-controls-button-border-color,var(--xy-controls-button-border-color-default)));width:26px;height:26px;color:var(--xy-controls-button-color-props,var(--xy-controls-button-color,var(--xy-controls-button-color-default)));cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:4px;display:flex}.react-flow__controls-button svg{fill:currentColor;width:100%;max-width:12px;max-height:12px}.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{border-radius:var(--xy-node-border-radius,var(--xy-node-border-radius-default));width:150px;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));padding:10px;font-size:12px}.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{background-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border:1px solid #fff;border-radius:1px;width:5px;height:5px;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-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border-style:solid;border-width:0}.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%}.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))}:root{--navy:#17365d;--blue:#1f4e79;--sky:#eaf4ff;--sky-line:#8db9e2;--green:#eaf8f0;--green-line:#8ccca5;--green-dark:#23734d;--amber:#fff3d6;--amber-line:#d6a23a;--amber-dark:#7a5200;--purple:#efeaff;--purple-line:#b1a4e8;--purple-dark:#5b4ab5;--red:#c93321;--text:#1f2937;--muted:#526071;--surface:#f7fafc}html,body{height:100%;margin:0;font-family:Apple SD Gothic Neo,Malgun Gothic,Noto Sans KR,Arial,sans-serif}button,input,select,textarea{font-family:inherit}#root{min-height:100%}.app-shell{min-height:100vh;color:var(--text);background:linear-gradient(#f7fafcfa,#e5edf7),radial-gradient(circle at 30% 0,#fffc 0,#0000 38%)}.diagram-frame{background:var(--surface);width:100vw;height:100vh;position:relative;overflow:hidden}.diagram-topbar{z-index:10;pointer-events:none;justify-content:space-between;align-items:flex-start;gap:18px;display:flex;position:absolute;top:18px;left:24px;right:24px}.diagram-topbar>div{pointer-events:auto}.diagram-topbar h1{letter-spacing:0;margin:0;font-size:30px;font-weight:900}.diagram-topbar p{color:var(--muted);margin:8px 0 0;font-size:14px;font-weight:800}.focus-toolbar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffe0;border:1px solid #94a3b873;border-radius:999px;align-items:center;gap:6px;padding:6px;display:flex;box-shadow:0 14px 34px #0f172a24}.focus-button{min-width:82px;height:34px;color:var(--navy);white-space:nowrap;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:999px;padding:0 13px;font-size:12px;font-weight:900;line-height:1;transition:color .16s,background .16s,border-color .16s,box-shadow .16s}.focus-button:hover,.focus-button.selected{color:#fff;background:var(--navy);border-color:var(--navy);box-shadow:0 8px 18px #17365d3d}.flow-shell{background:linear-gradient(#edf4fbf0,#e8f0fafa),linear-gradient(90deg,#ffb80033,#0000 18% 82%,#ffb8001f);border:1.5px solid #ffb800;border-radius:12px;position:absolute;inset:96px 24px 58px;overflow:hidden;box-shadow:inset 0 1px #ffffffb3}.react-flow{font-family:Apple SD Gothic Neo,Malgun Gothic,Noto Sans KR,Arial,sans-serif}.react-flow__node{background:0 0;border:0}.react-flow__node:focus,.react-flow__node:focus-visible{outline:none}.react-flow__edge-path{filter:drop-shadow(0 2px 4px #17365d38)}.react-flow__edge-text{paint-order:stroke;stroke:#fff;stroke-width:3px;font-size:15px;font-weight:950}.react-flow__edge-textbg{filter:drop-shadow(0 4px 8px #0f172a2e);rx:6px;ry:6px}.edge-label{z-index:5;text-align:center;white-space:normal;pointer-events:none;background:#fff;border:1.5px solid;border-radius:6px;place-items:center;max-width:210px;min-height:27px;padding:6px 10px;font-size:13px;font-weight:950;line-height:1.2;transition:opacity .18s;display:inline-grid;position:absolute;box-shadow:0 8px 18px #0f172a29}.edge-label-vpn{color:#a66d00}.edge-label-data{color:var(--red)}.edge-label-db{color:#0f7f8c}.edge-label-gateway{color:var(--purple-dark)}.edge-label.is-muted{opacity:.24}.edge-label.is-active{opacity:1}.flow-edge.is-muted{opacity:.22}.flow-edge.is-active{opacity:1}.flow-edge-vpn .react-flow__edge-path{stroke-dasharray:0}.flow-edge-data .react-flow__edge-path{stroke-dasharray:10 6}.flow-edge-db .react-flow__edge-path{stroke-dasharray:12 4 3 4}.flow-edge-gateway .react-flow__edge-path{stroke-dasharray:8 7}.diagram-node{text-align:left;cursor:pointer;background:#fff;border:1.4px solid #c5d0dc;border-radius:8px;width:100%;height:100%;min-height:116px;padding:0;transition:opacity .18s,box-shadow .18s,transform .18s,border-color .18s;display:block;position:relative;overflow:visible;box-shadow:0 12px 28px #17365d1f}.react-flow__node-field .diagram-node{min-height:122px}.vpn-group-node{pointer-events:none;background:linear-gradient(#fff3d661,#fff3d62e),linear-gradient(90deg,#ffb80029,#0000 28% 72%,#ffb80024);border:4px solid #ffb800c7;border-radius:28px;width:100%;height:100%;transition:opacity .18s,border-color .18s,background .18s;position:relative;box-shadow:inset 0 0 0 2px #ffffffb8,0 16px 44px #a66d001c}.vpn-group-node:after{content:"";border:2px dashed #a66d007a;border-radius:22px;position:absolute;inset:16px}.vpn-group-node span{z-index:1;color:#7a5200;white-space:nowrap;background:#fff9ea;border:2px solid #ffb800;border-radius:8px;place-items:center;min-height:34px;padding:0 16px;font-size:14px;font-weight:950;display:inline-grid;position:absolute;top:-17px;left:26px;box-shadow:0 8px 18px #a66d0024}.vpn-group-node.is-muted{opacity:.28}.vpn-group-node.is-active{opacity:1}.diagram-node:hover,.diagram-node:focus-visible{transform:translateY(-1px);box-shadow:0 16px 34px #17365d2e}.diagram-node.is-muted{opacity:.34}.diagram-node.is-active{opacity:1}.diagram-node.is-selected{border-color:var(--blue);box-shadow:0 0 0 3px #1f4e7924,0 16px 34px #17365d2e}.node-header{min-height:30px;color:var(--navy);border-radius:7px 7px 0 0;justify-content:center;align-items:center;padding:7px 12px;font-size:14px;font-weight:900;line-height:1.1;display:flex}.field-header,.site-header{background:#ddf4e7}.site-header{background:#dff1ff;justify-content:space-between}.gateway-header,.utm-header,.user-header{color:var(--purple-dark);background:#ece8ff}.utm-header{color:var(--blue);background:#eaf4ff}.ip-badge{color:#fff;background:var(--blue);border-radius:6px;place-items:center;min-width:122px;height:24px;padding:0 8px;font-size:10px;font-style:normal;font-weight:950;display:inline-grid}.ip-badge-inline{min-width:112px;height:22px;padding:0 7px;font-size:10px;line-height:1}.field-grid,.site-flow{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:26px 24px 22px;display:grid}.sensor-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding-inline:18px}.user-grid{grid-template-columns:1fr}.site-flow{grid-template-columns:72px 68px 1fr;align-items:center;gap:10px;padding:22px 24px 12px;position:relative}.site-flow.has-ns{grid-template-columns:72px 150px 1fr}.site-flow.has-ns:before{z-index:1;content:"";border-top:3px solid var(--red);width:36px;height:0;position:absolute;top:58px;left:241px}.site-flow.has-ns:after{z-index:1;content:"";border-top:6px solid #0000;border-bottom:6px solid #0000;border-left:9px solid var(--red);width:0;height:0;position:absolute;top:53px;left:275px}.internal-edge-label{z-index:2;min-height:20px;color:var(--red);white-space:nowrap;border:1px solid var(--red);background:#fff;border-radius:5px;place-items:center;padding:0 7px;font-size:10px;font-weight:950;display:inline-grid;position:absolute;top:35px;left:220px}.chip{text-align:center;border:1.25px solid;border-radius:6px;place-items:center;min-height:38px;padding:7px 9px;font-size:12px;font-weight:900;line-height:1.35;display:grid}.chip-green{color:var(--green-dark);background:var(--green);border-color:var(--green-line)}.chip-amber{color:var(--amber-dark);background:var(--amber);border-color:var(--amber-line)}.chip-sky{color:var(--blue);background:var(--sky);border-color:var(--sky-line)}.chip-red{color:var(--red);border-color:var(--red);background:#fff7f7}.chip-purple{color:var(--purple-dark);background:var(--purple);border-color:var(--purple-line)}.dmz-zone{border:1.35px solid var(--purple-line);background:#f7f3ff;border-radius:7px;place-items:center;gap:7px;min-height:72px;padding:7px;display:grid}.dmz-label{width:100%;min-height:28px;color:var(--purple-dark);background:var(--purple);border:1.15px solid var(--purple-line);border-radius:5px;place-items:center;font-size:12px;font-weight:950;display:grid}.server-stack{gap:8px;display:grid}.server-stack span{height:32px;color:var(--blue);background:#fff;border:1.2px solid #c5d0dc;border-radius:5px;justify-content:space-between;align-items:center;gap:6px;padding:0 7px;font-size:12px;font-weight:900;display:flex}.server-stack em{white-space:nowrap;min-width:24px;font-style:normal;line-height:1}.dashboard-band{height:26px;color:var(--green-dark);background:var(--green);border:1.2px solid var(--green-line);border-radius:5px;place-items:center;margin:0 24px 10px;font-size:12px;font-weight:900;display:grid}.dashboard-list{flex-wrap:wrap;justify-content:center;gap:8px;padding:0 24px 18px;display:flex}.dashboard-list span{min-width:72px;height:24px;color:var(--green-dark);border:1.1px solid var(--green-line);background:#fff;border-radius:5px;place-items:center;padding:0 10px;font-size:11px;font-weight:900;display:grid}.gateway-panel strong{font-size:14px;font-weight:900}.lora-ns-card{width:100%;min-height:72px;color:var(--red);text-align:center;border:1.3px solid var(--red);background:#fff7f7;border-radius:6px;place-items:center;gap:4px;padding:8px 9px;font-size:10px;font-weight:850;display:grid}.dmz-zone .lora-ns-card{background:#fff;min-height:68px}.lora-ns-card strong{font-size:12px;font-weight:950}.lora-ns-card em{font-style:normal;line-height:1.25}.gateway-panel{color:var(--purple-dark);text-align:center;background:var(--purple);border:1.3px solid var(--purple-line);border-radius:6px;gap:12px;margin:38px 34px;padding:22px;font-size:14px;font-weight:900;display:grid}.utm-node{border-color:var(--sky-line)}.utm-body{color:var(--blue);text-align:center;gap:6px;padding:14px 16px 16px;font-size:12px;font-weight:850;display:grid}.utm-body strong{font-size:13px;font-weight:950}.utm-body em{color:var(--red);font-size:10px;font-style:normal;font-weight:950;line-height:1.2}.utm-body .ip-badge{justify-self:center}.node-handle{border:2px solid #fff;width:13px;height:13px;box-shadow:0 0 0 2px}.node-handle.vpn-handle{color:#a66d00;background:#a66d00}.node-handle.data-handle{color:var(--red);background:var(--red)}.node-handle.db-handle{color:#0f7f8c;background:#0f7f8c}.react-flow__handle.handle-data-store-center{left:58%}.react-flow__handle.handle-db-out-center{left:42%}.react-flow__handle.handle-server-in{top:70%}.react-flow__handle.handle-field-vpn-out{left:50%}.react-flow__handle.handle-utm-gateway-in{left:66%}.react-flow__handle.handle-utm-vpn-in{left:34%}.react-flow__handle.handle-gateway-out{left:50%}.react-flow__handle.handle-utm-data-out{left:72%}.react-flow__handle.handle-utm-ns-db-in{top:62%}.react-flow__handle.handle-sihwa-utm-ns-db-in{left:50%}.react-flow__handle.handle-sihwa-utm-db-out-left,.react-flow__handle.handle-sihwa-utm-db-out-right{top:62%}.react-flow__handle{z-index:3}.node-handle.gateway-handle{color:var(--purple-dark);background:var(--purple-dark)}.node-handle.utm-handle{color:var(--blue);background:var(--blue)}.react-flow__node-field{width:340px}.react-flow__node-site{width:430px}.react-flow__node-utm{width:238px;height:132px}.react-flow__node-users{width:270px}.react-flow__node-gateway{width:600px}.react-flow__controls{border:1px solid #94a3b873;border-radius:8px;overflow:hidden;box-shadow:0 12px 30px #0f172a1f}.diagram-note{z-index:8;min-height:34px;color:var(--purple-dark);text-align:center;border:1px solid var(--purple-line);background:#ffffffe0;border-radius:8px;place-items:center;padding:7px 16px;font-size:13px;font-weight:900;display:grid;position:absolute;bottom:16px;left:24px;right:24px;box-shadow:0 10px 24px #17365d1a}.diagram-export-toolbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe0;border:1px solid #94a3b873;border-radius:8px;gap:6px;padding:6px;display:flex;box-shadow:0 12px 30px #0f172a1f}.diagram-export-button{color:#fff;cursor:pointer;background:var(--navy);border:1px solid var(--navy);border-radius:6px;place-items:center;min-width:82px;height:32px;padding:0 12px;font-size:12px;font-weight:950;line-height:1;transition:background .16s,transform .16s;display:inline-grid}.diagram-export-button:hover,.diagram-export-button:focus-visible{background:var(--blue);transform:translateY(-1px)}@media(max-width:900px){.diagram-topbar{flex-direction:column;gap:10px;top:12px;left:12px;right:12px}.diagram-topbar h1{font-size:20px}.diagram-topbar p{margin-left:0;font-size:12px}.flow-shell{inset:132px 12px 64px}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
