.custom-select{width:100%;position:relative}.custom-select__trigger{width:100%;padding:var(--space-xs) var(--space-sm);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer;transition:border-color var(--duration-fast) var(--easing-default);text-align:left;justify-content:space-between;align-items:center;display:flex}.custom-select__trigger:hover{border-color:var(--color-border-default)}.custom-select__trigger:focus{border-color:var(--color-primary);outline:none}.custom-select__value{color:var(--color-text-primary)}.custom-select__placeholder{color:var(--color-text-muted)}.custom-select__chevron{color:var(--color-text-muted);transition:transform var(--duration-fast) var(--easing-default);flex-shrink:0}.custom-select__chevron--open{transform:rotate(180deg)}.custom-select__dropdown{top:calc(100% + var(--space-xxs));background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);padding:var(--space-xxs);z-index:50;max-height:200px;position:absolute;left:0;right:0;overflow-y:auto}.custom-select__option{width:100%;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer;text-align:left;transition:background-color var(--duration-fast) var(--easing-default);background:0 0;border:none;display:block}.custom-select__option:hover{background-color:var(--color-bg-elevated)}.custom-select__option--selected{color:var(--color-primary);font-weight:var(--font-weight-medium)}.help-content{padding:var(--space-md)}.help-content__header{align-items:center;gap:var(--space-sm);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border-subtle);margin-bottom:var(--space-lg);display:flex}.help-content__back{border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--duration-fast) var(--easing-default), color var(--duration-fast) var(--easing-default);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.help-content__back:hover{background-color:var(--color-bg-elevated);color:var(--color-text-primary)}.help-content__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.help-content__body{gap:var(--space-xl);flex-direction:column;display:flex}.help-content__section{gap:var(--space-sm);flex-direction:column;display:flex}.help-content__section h3{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);padding-bottom:var(--space-xs);border-bottom:1px solid var(--color-border-subtle)}.help-content__section p{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.help-content__section p strong{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.help-content__shortcuts{gap:var(--space-sm);flex-direction:column;display:flex}.help-content__shortcut{padding:var(--space-xs) 0;justify-content:space-between;align-items:center;display:flex}.help-content__shortcut-key{font-family:var(--font-family-mono);font-size:var(--font-size-xs);padding:var(--space-xxs) var(--space-sm);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);color:var(--color-text-primary)}.help-content__shortcut-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.help-content__node-types{gap:var(--space-sm);flex-direction:column;display:flex}.help-content__node-type{align-items:flex-start;gap:var(--space-sm);display:flex}.help-content__node-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:5px}.help-content__node-dot--decision{background-color:var(--color-node-decision)}.help-content__node-dot--condition{background-color:var(--color-node-condition)}.help-content__node-dot--action{background-color:var(--color-node-action)}.help-content__node-dot--consequence{background-color:var(--color-node-consequence)}.help-content__node-info{flex-direction:column;gap:2px;display:flex}.help-content__node-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.help-content__node-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.settings-overlay{z-index:9999;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.settings-overlay__panel{background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:400px;max-height:80vh;overflow-y:auto}.settings-overlay__header{padding:var(--space-lg) var(--space-lg) var(--space-md);justify-content:space-between;align-items:center;display:flex}.settings-overlay__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.settings-overlay__close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--duration-fast) var(--easing-default), color var(--duration-fast) var(--easing-default);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.settings-overlay__close:hover{background-color:var(--color-bg-elevated);color:var(--color-text-primary)}.settings-overlay__body{gap:var(--space-lg);padding:var(--space-md) var(--space-lg) var(--space-lg);flex-direction:column;display:flex}.settings-overlay__field{gap:var(--space-xs);flex-direction:column;display:flex}.settings-overlay__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.settings-overlay__workspace{align-items:center;gap:var(--space-sm);display:flex}.settings-overlay__workspace-path{font-size:var(--font-size-sm);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;padding:var(--space-xs) var(--space-sm);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);flex:1;overflow:hidden}.settings-overlay__workspace-button{padding:var(--space-xs) var(--space-sm);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-default);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-family-base);font-size:var(--font-size-xs);cursor:pointer;white-space:nowrap;transition:background-color var(--duration-fast) var(--easing-default)}.settings-overlay__workspace-button:hover{background-color:var(--color-primary);color:var(--color-text-on-primary);border-color:var(--color-primary)}.settings-overlay__help-button{width:100%;padding:var(--space-sm) 0;border:none;border-top:1px solid var(--color-border-subtle);color:var(--color-primary);font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer;text-align:left;background:0 0}.settings-overlay__help-button:hover{text-decoration:underline}.header{height:var(--header-height);padding:0 var(--space-md);background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border-default);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;display:flex}.header__left{align-items:center;gap:var(--space-xs);display:flex}.header__logo{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);letter-spacing:.3px}.header__right{align-items:center;gap:var(--space-xs);display:flex}.header__icon-button{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--duration-fast) var(--easing-default), color var(--duration-fast) var(--easing-default);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.header__icon-button:hover{background-color:var(--color-bg-elevated);color:var(--color-text-primary)}.app-shell{background-color:var(--color-bg-base);flex-direction:column;height:100vh;display:flex}.app-shell__body{flex:1;min-height:0}.app-shell__sidebar{background-color:var(--color-bg-sidebar);border-right:1px solid var(--color-border-default);overflow-y:auto}.app-shell__canvas{background-color:var(--color-bg-base);position:relative;overflow:hidden}.app-shell__panel{background-color:var(--color-bg-sidebar);border-left:1px solid var(--color-border-default);overflow-y:auto}.app-shell__resize-handle{background-color:var(--color-border-default);cursor:col-resize;width:1px;transition:background-color var(--duration-fast) var(--easing-default);position:relative}.app-shell__resize-handle:before{content:"";position:absolute;inset:0 -3px}.app-shell__resize-handle:hover,.app-shell__resize-handle[data-resize-handle-active]{background-color:var(--color-primary)}.map-list{flex-direction:column;height:100%;display:flex}.map-list__header{padding:var(--space-sm) var(--space-md);justify-content:space-between;align-items:center;height:36px;display:flex}.map-list__title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);letter-spacing:var(--letter-spacing-label)}.map-list__actions{align-items:center;gap:var(--space-xxs);display:flex}.map-list__action-button{border-radius:var(--radius-sm);width:24px;height:24px;color:var(--color-text-muted);cursor:pointer;transition:background-color var(--duration-fast) var(--easing-default), color var(--duration-fast) var(--easing-default);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.map-list__action-button:hover{background-color:var(--color-bg-elevated);color:var(--color-text-primary)}.map-list__items{padding:var(--space-md);gap:var(--space-xxs);flex-direction:column;flex:1;display:flex;overflow-y:auto}.map-list__item{align-items:center;gap:var(--space-xs);width:100%;padding:var(--space-xxs) var(--space-xs);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer;text-align:left;transition:background-color var(--duration-fast) var(--easing-default), color var(--duration-fast) var(--easing-default);background:0 0;border:none;display:flex}.map-list__item:hover,.map-list__item--active{background-color:var(--color-bg-elevated);color:var(--color-text-primary)}.map-list__name{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.map-list__delete{border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:color var(--duration-fast) var(--easing-default);flex-shrink:0;justify-content:center;align-items:center;padding:2px;display:none}.map-list__item:hover .map-list__delete{display:flex}.map-list__delete:hover{color:var(--color-error)}.map-list__icon{color:var(--color-text-muted);flex-shrink:0}.map-list__item--active .map-list__icon{color:var(--color-text-primary)}.map-list__edit-input{min-width:0;padding:0 var(--space-xxs);border:1px solid var(--color-primary);border-radius:var(--radius-sm);background-color:var(--color-bg-elevated);color:var(--color-text-primary);font-family:var(--font-family-base);font-size:var(--font-size-sm);outline:none;flex:1}.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;touch-action:none}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke,var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width,var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke,var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width,var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{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-text{fill:var(--xy-edge-label-color,var(--xy-edge-label-color-default))}.node-type-menu{background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--space-xxs);z-index:9999;min-width:240px}.node-type-menu__item{align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;text-align:left;transition:background-color var(--duration-fast) var(--easing-default);background:0 0;border:none;display:flex}.node-type-menu__item:hover{background-color:var(--color-bg-elevated)}.node-type-menu__dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.node-type-menu__dot--decision{background-color:var(--color-node-decision)}.node-type-menu__dot--consequence{background-color:var(--color-node-consequence)}.node-type-menu__dot--condition{background-color:var(--color-node-condition)}.node-type-menu__dot--action{background-color:var(--color-node-action)}.node-type-menu__text{flex-direction:column;gap:2px;display:flex}.node-type-menu__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.node-type-menu__description{font-size:var(--font-size-xs);color:var(--color-text-muted)}.node-type-menu__divider{background-color:var(--color-border-subtle);height:1px;margin:var(--space-xs) 0}.rule-node{border-radius:var(--radius-md);background-color:var(--color-bg-surface);border:1.5px solid var(--color-border-default);width:240px;box-shadow:var(--shadow-sm);font-family:var(--font-family-base);transition:box-shadow var(--duration-fast) var(--easing-default), border-color var(--duration-fast) var(--easing-default);overflow:hidden}.rule-node:hover{box-shadow:var(--shadow-md)}.rule-node--selected{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.rule-node__header{align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border-bottom:1px solid var(--color-border-subtle);display:flex}.rule-node--decision .rule-node__header{background-color:var(--color-node-decision);color:var(--color-text-on-primary)}.rule-node--consequence .rule-node__header{background-color:var(--color-node-consequence);color:var(--color-text-on-primary)}.rule-node--condition .rule-node__header{background-color:var(--color-node-condition);color:var(--color-text-on-primary)}.rule-node--action .rule-node__header{background-color:var(--color-node-action);color:var(--color-text-on-primary)}.rule-node__icon{align-items:center;display:flex}.rule-node__type-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-label)}.rule-node__display-id{font-size:var(--font-size-xs);font-weight:var(--font-weight-normal);opacity:.7;font-family:var(--font-family-mono);margin-left:auto}.rule-node__body{padding:var(--space-sm) var(--space-md);cursor:text;min-height:40px}.rule-node__label{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:var(--line-height-normal);word-wrap:break-word}.rule-node__edit-input{width:100%;color:var(--color-text-primary);font-family:var(--font-family-base);font-size:var(--font-size-sm);line-height:var(--line-height-normal);resize:none;box-sizing:border-box;background:0 0;border:none;outline:none;margin:0;padding:0}.rule-node__handle{background-color:var(--color-border-default);border:2px solid var(--color-bg-surface);width:8px;height:8px;transition:background-color var(--duration-fast) var(--easing-default);border-radius:50%}.rule-node__handle:hover{background-color:var(--color-primary)}.rule-node__source-area{align-items:center;display:flex;position:absolute;top:50%;right:-12px;transform:translateY(-50%)}.rule-node__add-button{border:1.5px solid var(--color-border-default);background-color:var(--color-bg-surface);width:20px;height:20px;color:var(--color-text-muted);cursor:pointer;opacity:0;transition:opacity var(--duration-fast) var(--easing-default), border-color var(--duration-fast) var(--easing-default), color var(--duration-fast) var(--easing-default);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;left:14px}.rule-node:hover .rule-node__add-button{opacity:1}.rule-node__add-button:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-bg-elevated)}.rule-node--consequence-ref{border:1.5px dashed var(--color-node-consequence);border-radius:var(--radius-md);background-color:var(--color-bg-surface);opacity:.85;width:200px}.rule-node__ref-body{align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);display:flex}.rule-node__ref-icon{color:var(--color-node-consequence);flex-shrink:0}.rule-node__ref-label{font-size:var(--font-size-sm);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.rule-node__ref-id{font-size:var(--font-size-xs);color:var(--color-text-muted);font-family:var(--font-family-mono);flex-shrink:0}.labeled-edge__label{background-color:var(--color-bg-surface);padding:var(--space-xxs) var(--space-xs);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-xs);color:var(--color-text-secondary);transition:border-color var(--duration-fast) var(--easing-default), background-color var(--duration-fast) var(--easing-default);text-align:center;border:1px solid #0000;min-width:24px}.labeled-edge__label:hover{border-color:var(--color-border-default)}.labeled-edge__label--selected{border-color:var(--color-primary);background-color:var(--color-bg-elevated)}.labeled-edge__label--empty{border-style:dashed;border-color:var(--color-border-subtle)}.labeled-edge__label--empty:hover{border-color:var(--color-primary)}.labeled-edge__text{white-space:nowrap;color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.labeled-edge__input{width:80px;color:var(--color-text-primary);font-family:var(--font-family-base);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-align:center;background:0 0;border:none;outline:none;padding:0}.labeled-edge__text--placeholder{color:var(--color-text-muted);font-style:italic}.canvas-header{padding:var(--space-xs) var(--space-md);background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border-default);align-items:center;min-height:36px;display:flex}.canvas-header__name{font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);color:var(--color-text-primary)}.empty-state{justify-content:center;align-items:center;height:100%;display:flex}.empty-state__content{align-items:center;gap:var(--space-sm);flex-direction:column;display:flex;position:relative}.empty-state__button{border:2px dashed var(--color-border-default);width:64px;height:64px;color:var(--color-text-muted);cursor:pointer;transition:border-color var(--duration-normal) var(--easing-default), color var(--duration-normal) var(--easing-default), background-color var(--duration-normal) var(--easing-default);background:0 0;border-radius:50%;justify-content:center;align-items:center;display:flex}.empty-state__button:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-bg-elevated)}.empty-state__hint{font-size:var(--font-size-sm);color:var(--color-text-muted)}.no-map-state{justify-content:center;align-items:center;gap:var(--space-xs);flex-direction:column;height:100%;display:flex}.no-map-state__text{font-size:var(--font-size-lg);color:var(--color-text-muted)}.no-map-state__hint{font-size:var(--font-size-sm);color:var(--color-text-muted)}.rule-canvas{flex-direction:column;width:100%;height:100%;display:flex}.rule-canvas__flow{flex:1;min-height:0}.rule-canvas__background{--xy-background-pattern-dots-color-default:var(--color-border-subtle)}.rule-canvas__controls{border:1px solid var(--color-border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden}.rule-canvas__controls button{background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border-subtle);color:var(--color-text-secondary);width:28px;height:28px}.rule-canvas__controls button:hover{background-color:var(--color-bg-elevated);color:var(--color-text-primary)}.rule-canvas__controls button svg{fill:currentColor}.react-flow__edge-text{font-size:var(--font-size-xs);fill:var(--color-text-secondary)}.react-flow__edge-textbg{fill:var(--color-bg-base)}.react-flow__edge path{stroke:var(--color-border-default)}.react-flow__edge.selected path,.react-flow__edge:hover path{stroke:var(--color-primary)}.react-flow__connection-line path{stroke:var(--color-primary);stroke-dasharray:5}.rule-canvas__auto-layout{bottom:var(--space-md);z-index:5;position:absolute;left:50px}.rule-canvas__auto-layout-button{border:1px solid var(--color-border-default);border-radius:var(--radius-md);background-color:var(--color-bg-surface);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;box-shadow:var(--shadow-md);transition:background-color var(--duration-fast) var(--easing-default), color var(--duration-fast) var(--easing-default);justify-content:center;align-items:center;display:flex}.rule-canvas__auto-layout-button:hover{background-color:var(--color-bg-elevated);color:var(--color-text-primary)}.map-info-panel{gap:var(--space-md);flex-direction:column;display:flex}.map-info-panel__field{gap:var(--space-xxs);flex-direction:column;display:flex}.map-info-panel__label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.map-info-panel__meta{padding-top:var(--space-sm);border-top:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;display:flex}.map-info-panel__meta-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.map-info-panel__meta-value{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.map-info-panel__section{gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle);flex-direction:column;display:flex}.map-info-panel__section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-label);margin:0}.map-info-panel__export-buttons{gap:var(--space-xs);grid-template-columns:1fr 1fr;display:grid}.map-info-panel__export-button{padding:var(--space-xs) var(--space-sm);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family-base);font-size:var(--font-size-xs);cursor:pointer;text-align:center;transition:background-color var(--duration-fast) var(--easing-default), border-color var(--duration-fast) var(--easing-default), color var(--duration-fast) var(--easing-default)}.map-info-panel__export-button:hover{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-on-primary)}.map-info-panel__export-button--full{width:100%;margin-top:var(--space-xs)}.edge-label-suggestions{gap:var(--space-xs);margin-bottom:var(--space-sm);flex-wrap:wrap;display:flex}.edge-label-suggestions__group{gap:var(--space-xxs);display:flex}.edge-label-suggestions__chip{padding:var(--space-xxs) var(--space-sm);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);color:var(--color-text-secondary);font-family:var(--font-family-base);font-size:var(--font-size-xs);cursor:pointer;transition:background-color var(--duration-fast) var(--easing-default), border-color var(--duration-fast) var(--easing-default), color var(--duration-fast) var(--easing-default)}.edge-label-suggestions__chip:hover,.edge-label-suggestions__chip--recommended{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-on-primary)}.edge-label-suggestions__chip--recommended:hover{opacity:.9}.attribute-panel{flex-direction:column;height:100%;display:flex}.attribute-panel__header{padding:var(--space-sm) var(--space-md);flex-shrink:0;align-items:center;height:36px;display:flex}.attribute-panel__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);color:var(--color-text-primary)}.attribute-panel__body{padding:var(--space-md);gap:var(--space-md);flex-direction:column;flex:1;display:flex;overflow-y:auto}.attribute-panel__empty{justify-content:center;align-items:center;height:100%;display:flex}.attribute-panel__empty-hint{font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center}.attribute-panel__section{gap:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--color-border-subtle);flex-direction:column;display:flex}.attribute-panel__section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-label)}.attribute-panel__field{gap:var(--space-xxs);flex-direction:column;display:flex}.attribute-panel__label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.attribute-panel__textarea--tall{min-height:100px}:root{--space-xxs:4px;--space-xs:8px;--space-sm:12px;--space-md:16px;--space-ml:20px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--font-family-base:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-family-mono:"SF Mono", "Fira Code", monospace;--font-size-xs:12px;--font-size-sm:14px;--font-size-md:16px;--font-size-lg:18px;--font-size-xl:20px;--font-size-2xl:24px;--font-size-3xl:32px;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--line-height-tight:1.2;--line-height-normal:1.5;--letter-spacing-label:.5px;--header-height:44px;--shadow-sm:0 1px 3px #0000001f;--shadow-md:0 4px 12px #00000026;--shadow-lg:0 8px 24px #0003;--duration-fast:.1s;--duration-normal:.2s;--duration-slow:.3s;--easing-default:cubic-bezier(.4, 0, .2, 1)}[data-theme=light]{--color-primary:#335cff;--color-primary-hover:#254edb;--color-primary-rgb:51, 92, 255;--color-bg-base:#f8f9fa;--color-bg-surface:#fff;--color-bg-sidebar:#f1f3f5;--color-bg-elevated:#f5f6f8;--color-border-subtle:#dee2e6;--color-border-default:#cfd4da;--color-border-focus:#335cff;--color-text-primary:#111827;--color-text-secondary:#6b7280;--color-text-muted:#9ca3af;--color-text-on-primary:#fff;--color-error:#ef4444;--color-success:#10b981;--color-warning:#f59e0b;--color-node-decision:#335cff;--color-node-consequence:#10b981;--color-node-condition:#f59e0b;--color-node-action:#8b5cf6;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f}[data-theme=dark]{--color-primary:#547aff;--color-primary-hover:#7593ff;--color-primary-rgb:84, 122, 255;--color-bg-base:#121214;--color-bg-surface:#18181b;--color-bg-sidebar:#18181b;--color-bg-elevated:#27272a;--color-border-subtle:#27272a;--color-border-default:#3f3f46;--color-border-focus:#547aff;--color-text-primary:#d4d4d8;--color-text-secondary:#a1a1aa;--color-text-muted:#71717a;--color-text-on-primary:#fff;--color-error:#f87171;--color-success:#34d399;--color-warning:#fbbf24;--color-node-decision:#547aff;--color-node-consequence:#34d399;--color-node-condition:#fbbf24;--color-node-action:#a78bfa;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080}[data-theme=retro]{--color-primary:#2aa198;--color-primary-hover:#35bbb2;--color-primary-rgb:42, 161, 152;--color-bg-base:#fdf6e3;--color-bg-surface:#eee8d5;--color-bg-sidebar:#eee8d5;--color-bg-elevated:#f6efdc;--color-border-subtle:#d6cbae;--color-border-default:#93a1a1;--color-border-focus:#2aa198;--color-text-primary:#586e75;--color-text-secondary:#657b83;--color-text-muted:#93a1a1;--color-text-on-primary:#fdf6e3;--color-error:#dc322f;--color-success:#859900;--color-warning:#b58900;--color-node-decision:#268bd2;--color-node-consequence:#2aa198;--color-node-condition:#b58900;--color-node-action:#d33682;--shadow-sm:0 1px 3px #586e751a;--shadow-md:0 4px 12px #586e7526;--shadow-lg:0 8px 24px #586e7533}[data-theme=miami]{--color-primary:#f0c;--color-primary-hover:#ff33d6;--color-primary-rgb:255, 0, 204;--color-bg-base:#1a1a2e;--color-bg-surface:#16213e;--color-bg-sidebar:#16213e;--color-bg-elevated:#0f3460;--color-border-subtle:#1e2a4a;--color-border-default:#05d9e8;--color-border-focus:#f0c;--color-text-primary:#fff;--color-text-secondary:#ffffffb3;--color-text-muted:#fff6;--color-text-on-primary:#fff;--color-error:#f05;--color-success:#05d9e8;--color-warning:gold;--color-node-decision:#05d9e8;--color-node-consequence:#39ff14;--color-node-condition:gold;--color-node-action:#f0c;--shadow-sm:0 1px 3px #05d9e826;--shadow-md:0 4px 12px #05d9e833;--shadow-lg:0 8px 24px #ff00cc40}input[type=text],textarea,.custom-select__trigger{padding:var(--space-xs) var(--space-sm);background-color:var(--color-bg-base);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family-base);font-size:var(--font-size-sm);line-height:var(--line-height-normal);transition:border-color var(--duration-fast) var(--easing-default), box-shadow var(--duration-fast) var(--easing-default)}input[type=text]:focus,textarea:focus,.custom-select__trigger:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb,0, 122, 204), .15);outline:none}input[type=text]::placeholder,textarea::placeholder{color:var(--color-text-muted)}textarea{resize:vertical;min-height:60px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-family-base);font-size:var(--font-size-md);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-base);-webkit-font-smoothing:antialiased}::selection{background-color:var(--color-primary);color:var(--color-text-on-primary)}:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}
