@import"https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap";.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--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: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--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: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--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{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.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;-moz-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:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.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.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{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-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{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));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:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.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%}.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))}.panel-badges{display:flex;gap:12px;margin-bottom:16px;align-items:center}.panel-id-badge{background:#e0f2fe;color:#0369a1;font-size:11px;font-weight:700;padding:4px 8px;border-radius:4px;letter-spacing:.02em}.panel-status-badge{display:flex;align-items:center;gap:6px;background:#dcfce7;color:#15803d;font-size:11px;font-weight:600;padding:4px 8px;border-radius:4px}.panel-status-badge .status-dot{width:6px;height:6px;background:#16a34a;border-radius:50%}.panel-title{font-size:24px;font-weight:700;color:#0f172a;margin-bottom:12px;line-height:1.3}.panel-subtitle{font-size:14px;color:#64748b;margin-bottom:8px;font-weight:400;line-height:1.5}.hero-status-row{display:flex;gap:16px;margin-bottom:32px}.hero-badge{flex:1;display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:8px;font-size:13px;font-weight:600}.hero-badge.success{background:#ecfdf5;color:#065f46;border:1px solid #D1FAE5}.hero-badge.warning{background:#fffbeb;color:#92400e;border:1px solid #FEF3C7}.hero-badge.neutral{background:#f8fafc;color:#475569;border:1px solid #E2E8F0}.hero-icon{display:flex}.panel-section{margin-bottom:40px}.section-header-row{display:flex;align-items:center;gap:12px;margin-bottom:24px}.section-icon{display:flex;color:#06b6d4}.section-icon.teal{color:#14b8a6}.section-icon.cyan{color:#06b6d4}.section-icon.green{color:#10b981}.section-title{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#334155;margin:0}.divider{height:1px;background:#f1f5f9;margin:32px 0}.panel-field{margin-bottom:20px}.field-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;color:#64748b;margin-bottom:12px;letter-spacing:.02em}.field-box{padding:14px 18px;border-radius:6px;font-size:14px;color:#1e293b;font-weight:500;line-height:1.6}.field-box.highlight{background:#f8fafc;border:1px solid #F1F5F9}.field-text-content{font-size:14px;color:#334155;line-height:1.8}.field-text{font-size:14px;color:#334155;line-height:1.6}.system-ref{display:flex;align-items:center;gap:10px;font-size:14px;color:#475569;font-weight:500}.grid-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:20px}.tag-group,.tag-cloud{display:flex;flex-wrap:wrap;gap:10px}.legal-tag,.category-tag{display:inline-block;padding:6px 12px;background:#f1f5f9;border-radius:4px;font-size:13px;color:#475569;font-weight:500}.field-text-muted{color:#94a3b8;font-style:italic}.mt-3{margin-top:28px}.mb-2{margin-bottom:16px}.panel-footer-modern{padding:24px 32px;border-top:1px solid #F1F5F9;display:flex;gap:12px;background:#fff}.edit-btn-modern{flex:1;background:#21eac3;color:#fff;border:none;border-radius:6px;height:44px;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s}.edit-btn-modern:hover{background:#17c9aa;transform:translateY(-1px);box-shadow:0 4px 12px #1deac34d}.icon-btn-text{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#fef2f2;border:1px solid #FECACA;border-radius:6px;cursor:pointer;color:#ef4444;transition:all .2s}.icon-btn-text:hover{background:#fee2e2;color:#dc2626;border-color:#fca5a5;transform:translateY(-1px)}.panel-title-input{font-size:24px;font-weight:700;color:#0f172a;margin-bottom:8px;line-height:1.3;border:none;background:transparent;width:100%;outline:none;padding:4px 0;border-bottom:2px solid transparent;transition:border-color .2s}.panel-title-input:focus{border-bottom-color:#21eac3}.panel-subtitle-input{font-size:14px;color:#64748b;font-weight:400;line-height:1.5;border:none;background:transparent;width:100%;outline:none;padding:4px 0;border-bottom:2px solid transparent;transition:border-color .2s}.panel-subtitle-input:focus{border-bottom-color:#21eac3}.field-input{width:100%;padding:12px 14px;border:1px solid #E2E8F0;border-radius:6px;font-size:14px;color:#1e293b;background:#fff;transition:all .2s}.field-input:focus{outline:none;border-color:#21eac3;box-shadow:0 0 0 3px #21eac326}.field-textarea{width:100%;padding:12px 14px;border:1px solid #E2E8F0;border-radius:6px;font-size:14px;color:#1e293b;background:#fff;resize:vertical;font-family:inherit;line-height:1.6;transition:all .2s}.field-textarea:focus{outline:none;border-color:#21eac3;box-shadow:0 0 0 3px #21eac326}.hero-badge.clickable{cursor:pointer;transition:all .2s;border:1px solid transparent}.hero-badge.clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.legal-tag.clickable,.category-tag.clickable{cursor:pointer;border:2px solid transparent;transition:all .15s}.legal-tag.clickable:hover,.category-tag.clickable:hover{background:#e2e8f0}.legal-tag.clickable.active,.category-tag.clickable.active{background:#21eac3;color:#fff;border-color:#17c9aa}.tag-group.editable,.tag-cloud.editable{gap:8px}.panel-status-badge.unsaved{background:#fef3c7;color:#92400e}.save-btn-modern{flex:1;background:#21eac3;color:#fff;border:none;border-radius:6px;height:44px;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s}.save-btn-modern:hover{background:#17c9aa;transform:translateY(-1px);box-shadow:0 4px 12px #1deac34d}.panel-comment-box{background:#f8fafc;border:1px solid #E2E8F0;border-radius:8px;padding:18px;margin-top:32px}.comment-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.comment-icon{font-size:16px}.comment-title{font-weight:600;font-size:13px;color:#475569}.comment-date-badge{margin-left:auto;font-size:10px;color:#94a3b8;background:#fff;padding:2px 6px;border-radius:4px;border:1px solid #F1F5F9}.comment-text{font-style:italic;color:#475569;font-size:13px;line-height:1.5}@media (max-width: 768px){.panel-header{padding:16px}.panel-title{font-size:20px}.panel-subtitle{font-size:13px}.hero-status-row{flex-direction:column;gap:12px}.hero-badge{width:100%}.grid-row{grid-template-columns:1fr;gap:16px}.panel-content{padding:16px}.panel-section{margin-bottom:28px}.divider{margin:24px 0}.field-label{font-size:10px;margin-bottom:8px}.field-box{padding:12px 14px;font-size:13px}.panel-actions{flex-direction:column}.panel-actions button{width:100%}.tag-cloud,.tag-group{gap:6px}.legal-tag,.category-tag{font-size:10px;padding:4px 8px}}@media (max-width: 1024px) and (min-width: 769px){.panel-title{font-size:22px}.hero-badge{font-size:12px;padding:10px 12px}.field-box{font-size:13px}}.context-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.context-menu{position:fixed;z-index:1000;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;padding:6px;min-width:180px;animation:contextMenuFadeIn .15s ease-out}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:14px;color:#334155;transition:all .15s ease}.context-menu-item:hover{background:#f1f5f9;color:#0f172a}.context-menu-icon{font-size:16px}.edge-delete-button{position:fixed;bottom:24px;right:24px;z-index:100;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#fef2f2;border:1px solid #FECACA;border-radius:6px;cursor:pointer;color:#ef4444;transition:all .2s;animation:edgeDeleteFadeIn .2s ease-out;position:relative}.edge-count-badge{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px;box-shadow:0 2px 4px #0003}@keyframes edgeDeleteFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.edge-delete-button:hover{background:#fee2e2;color:#dc2626;border-color:#fca5a5;transform:translateY(-1px)}.edge-delete-button:active{transform:scale(.95)}.edge-delete-button .material-icons{font-size:20px}:root{--color-bg-primary: #f8fafc;--color-bg-secondary: #ffffff;--color-bg-tertiary: #f1f5f9;--color-bg-card: #ffffff;--color-bg-hover: #e2e8f0;--color-accent-primary: #14b8a6;--color-accent-light: #5eead4;--color-accent-dark: #0d9488;--color-accent-blue: #3b82f6;--color-accent-cyan: #06b6d4;--color-accent-purple: #8b5cf6;--color-accent-green: #10b981;--color-accent-orange: #f59e0b;--color-accent-red: #ef4444;--color-text-primary: #1e293b;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--color-status-compliant: #14b8a6;--color-status-review: #f59e0b;--color-status-warning: #ef4444;--color-node-finance: rgba(59, 130, 246, .15);--color-node-operations: rgba(107, 114, 128, .15);--color-node-hr: rgba(20, 184, 166, .15);--color-border: #e2e8f0;--color-border-light: #f1f5f9;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .1);--shadow-header: 0 4px 20px rgba(0, 0, 0, .08);--font-family: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;font-family:var(--font-family)}html,body,#root{height:100%;width:100%}body{font-family:var(--font-family);font-size:var(--font-size-md);line-height:1.5;color:var(--color-text-primary);background:var(--color-bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.main-content{display:flex;flex:1;overflow:hidden}.map-container{flex:1;width:100%;height:100%;position:relative}.filter-bar-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#fff;border-radius:40px;padding:10px 16px 10px 20px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 24px #0000001f;border:1.5px solid #e2e8f0;z-index:50;max-width:90vw}.filter-label{font-size:12px;font-weight:700;color:#475569;text-transform:none;padding-left:0;border-right:1.5px solid #e2e8f0;padding-right:14px;margin-right:8px}.filter-divider{display:none}.filter-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;padding:5px 10px;border-radius:16px;transition:all .2s;background:transparent;border:1.5px solid #e2e8f0}.filter-toggle:hover{background:#f8fafc}.filter-toggle.active{background:#e6fffa;border-color:#14b8a6}.toggle-label{font-size:11px;font-weight:600;line-height:1;color:#334155;white-space:nowrap}.toggle-switch{width:28px;height:16px;background:#cbd5e1;border-radius:20px;position:relative;transition:background .2s}.filter-toggle.active .toggle-switch{background:#14b8a6}.toggle-knob{width:10px;height:10px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0000001a}.filter-toggle.active .toggle-knob{transform:translate(10px)}.filter-more-btn{padding:6px 10px;background:transparent;border:1.5px solid #e2e8f0;border-radius:20px;cursor:pointer;color:#64748b;display:flex;align-items:center;justify-content:center;transition:all .2s}.filter-more-btn:hover{background:#f8fafc;color:#21eac3;border-color:#21eac3}.filter-separator{color:#e2e8f0;font-size:20px;margin:0 12px;font-weight:300;line-height:1}@media (max-width: 768px){.filter-bar-container{bottom:12px;padding:8px 12px;gap:8px;flex-wrap:wrap;max-width:95vw}.filter-label,.filter-separator{display:none}.toggle-label{font-size:10px}.add-system-btn-filter{padding:6px 10px;font-size:10px;gap:4px}.filter-toggle{padding:4px 8px;gap:6px}}@media (max-width: 1024px) and (min-width: 769px){.filter-bar-container{bottom:16px;padding:8px 14px;gap:10px}.filter-label{font-size:11px;padding-right:12px;margin-right:6px}.toggle-label{font-size:10px}.add-system-btn-filter{padding:7px 12px;font-size:10px}}.add-system-btn-filter{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#21eac3;border:none;border-radius:20px;color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.add-system-btn-filter:hover{background:#17d1ae;transform:translateY(-1px);box-shadow:0 4px 12px #1deac34d}.advanced-filters-panel{position:absolute;bottom:120px;left:50%;transform:translate(-50%);background:#fff;border-radius:16px;padding:24px;box-shadow:0 8px 32px #00000026;border:2px solid #e2e8f0;min-width:400px;max-width:90vw;max-height:60vh;overflow-y:auto;z-index:99;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.advanced-filters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #f1f5f9}.filter-tabs{display:flex;gap:8px}.filter-tab{padding:8px 16px;background:transparent;border:none;border-radius:8px;font-size:14px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.filter-tab:hover{background:#f1f5f9;color:#0f172a}.filter-tab.active{background:#21eac3;color:#fff}.advanced-filters-header h3{font-size:16px;font-weight:700;color:#0f172a;margin:0}.close-advanced-btn{background:none;border:none;font-size:28px;color:#94a3b8;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-advanced-btn:hover{background:#f1f5f9;color:#64748b}.category-filters{display:grid;grid-template-columns:1fr 1fr;gap:12px}.category-filter-item{display:flex;align-items:center;gap:10px;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s;background:#fff}.category-filter-item:hover{background:#f8fafc;border-color:#cbd5e1}.category-filter-item.active{background:#e6fffa;border-color:#21eac3}.category-color-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0}.category-filter-item span{font-size:13px;font-weight:500;color:#334155;flex:1}.category-filter-item .check-mark{color:#21eac3;font-weight:700;font-size:16px}.tag-filters{display:grid;grid-template-columns:1fr 1fr;gap:12px}.tag-filter-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s;background:#fff}.tag-filter-item:hover{background:#f8fafc;border-color:#cbd5e1}.tag-filter-item.active{background:#e6fffa;border-color:#21eac3}.tag-filter-item span{font-size:13px;font-weight:500;color:#334155}.tag-filter-item .check-mark{color:#21eac3;font-weight:700;font-size:16px}.filter-settings-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--color-border);background:#fff;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);cursor:pointer;margin-left:8px}.filter-settings-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.gdpr-toggle{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:var(--transition-base)}.gdpr-toggle:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.gdpr-toggle.active{background:#14b8a61a;border-color:var(--color-accent-primary);color:var(--color-accent-primary);box-shadow:0 0 0 4px #14b8a60d}.shield-icon{font-size:16px}.edge-label{background:var(--color-bg-secondary);padding:4px 12px;border-radius:12px;font-size:10px;font-weight:600;color:var(--color-accent-primary);border:1px solid var(--color-accent-primary);box-shadow:0 2px 4px #0000000d;cursor:pointer;transition:all .2s}.edge-label:hover{background:var(--color-accent-primary);color:#fff;transform:translate(-50%,-50%) scale(1.05)}.react-flow__background{background:transparent!important}.react-flow__controls{display:none}.react-flow__edge-path{stroke-dasharray:none!important;animation:none!important;transition:stroke .2s ease,stroke-width .2s ease}.react-flow__edge.selected .react-flow__edge-path{stroke:#1e293b!important;stroke-width:3px!important}.react-flow__edge.animated .react-flow__edge-path{stroke-dasharray:none!important;animation:none!important}.react-flow__edge *{animation:none!important}.system-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;width:100%;height:100%;min-width:240px;padding:16px;display:flex;flex-direction:column;gap:12px;transition:box-shadow .2s ease,transform .2s ease;border:1px solid var(--color-border);position:relative}.system-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.system-card.selected{border-color:var(--color-accent-primary);box-shadow:0 0 0 2px #14b8a61a,0 4px 12px #0000001f}.system-card.dimmed{opacity:.4;filter:grayscale(1)}.system-card.highlighted{animation:pulse-glow 1.5s ease-in-out infinite;z-index:10}@keyframes pulse-glow{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.card-header{display:flex;align-items:flex-start;gap:12px}.card-icon-wrapper{width:clamp(32px,3.5vw,44px);height:clamp(32px,3.5vw,44px);border-radius:8px;background:#21eac3;display:flex;align-items:center;justify-content:center;flex-shrink:0}.card-icon{font-size:clamp(1rem,1.2vw,1.4rem)}.card-icon-letter{font-size:clamp(12px,1.2vw,16px);font-weight:700;color:#fff;letter-spacing:-.02em}.card-info{flex:1}.card-title{font-weight:700;font-size:clamp(12px,1.2vw,16px);color:#1e293b;margin-bottom:2px}.card-subtitle{font-size:clamp(10px,1vw,13px);color:#64748b;font-weight:500}.card-menu{color:var(--color-text-muted);cursor:pointer}.card-menu:hover{color:var(--color-text-primary)}.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.card-tag{background:#f1f5f9;color:#475569;border-radius:4px;padding:4px 8px;font-size:clamp(8px,.8vw,11px);font-weight:600;text-transform:uppercase;letter-spacing:.02em}.card-tag.default,.card-tag.active,.card-tag.warning{background:#f1f5f9;color:#475569}.card-handle{width:24px!important;height:24px!important;border-radius:50%!important;background:var(--color-accent-primary)!important;border:2px solid white!important;opacity:0;transition:opacity .2s,transform .2s;z-index:10}.card-handle.handle-source{z-index:20}.card-handle.handle-target{z-index:10;transform:scale(.8)}.app-container.is-connecting .card-handle.handle-source{pointer-events:none!important;opacity:0!important}.app-container.is-connecting .card-handle.handle-target{opacity:0!important;pointer-events:auto!important;transform:scale(2);background:#22c55e!important}.group-label{position:absolute;font-size:var(--font-size-sm);font-weight:600;color:var(--color-accent-blue);letter-spacing:.1em;text-transform:uppercase;opacity:.8}.react-flow__resize-control.handle{width:16px!important;height:16px!important;border-radius:50%}.react-flow__resize-control.handle.bottom.right,.react-flow__resize-control.handle.bottom.left,.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.top.left{width:20px!important;height:20px!important}.map-controls{position:absolute;left:var(--spacing-lg);bottom:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md);z-index:10}.zoom-controls{display:flex;flex-direction:column;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.zoom-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--color-text-primary);cursor:pointer;transition:var(--transition-fast);font-size:var(--font-size-xl)}.zoom-btn:hover{background:var(--color-bg-hover)}.zoom-btn:first-child{border-bottom:1px solid var(--color-border)}.control-buttons{display:flex;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.control-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-right:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-fast)}.control-btn:last-child{border-right:none}.control-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.control-btn-single{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-fast)}.control-btn-single:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.control-btn-single.active{background:#21eac3;color:#fff;border-color:#21eac3}.control-btn-single.active:hover{background:#1dd4b0}.header-logo{position:absolute;top:20px;left:24px;z-index:100;pointer-events:none}.header-logo img{height:56px;width:auto}.control-btn.active{color:var(--color-accent-blue)}.map-legend{position:absolute;left:var(--spacing-lg);bottom:calc(var(--spacing-lg) + 150px);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);min-width:160px;z-index:10}.legend-title{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-sm)}.legend-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) 0}.legend-dot{width:10px;height:10px;border-radius:var(--radius-full)}.legend-dot.compliant{background:var(--color-status-compliant)}.legend-dot.review{background:var(--color-status-review)}.legend-line{width:20px;height:2px;background:var(--color-text-muted);border-radius:1px;position:relative}.legend-line:before,.legend-line:after{content:"";position:absolute;width:3px;height:3px;background:var(--color-text-muted);border-radius:var(--radius-full)}.legend-line:before{left:-1px;top:-.5px}.legend-line:after{right:-1px;top:-.5px}.legend-text{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.detail-panel{width:580px;background:var(--color-bg-secondary);border-left:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden;animation:slideIn .3s ease;z-index:100;position:relative}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.detail-panel{width:100%;position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;border-left:none}}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.panel-system-info{display:flex;align-items:center;gap:var(--spacing-md)}.panel-icon{width:48px;height:48px;background:var(--color-accent-blue);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem}.panel-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.panel-subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:2px}.panel-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-md);transition:var(--transition-fast)}.panel-close:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.panel-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.compliance-card{background:var(--color-bg-tertiary);border-radius:var(--radius-lg);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.compliance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.compliance-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.compliance-score{font-size:var(--font-size-xl);font-weight:700;color:var(--color-status-compliant)}.compliance-bar{height:6px;background:var(--color-bg-primary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-sm)}.compliance-fill{height:100%;background:linear-gradient(90deg,var(--color-status-compliant),var(--color-accent-cyan));border-radius:var(--radius-full);transition:width .5s ease}.compliance-warning{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-status-review)}.compliance-warning svg{width:14px;height:14px}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.info-card{background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:var(--spacing-md)}.info-label{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.info-value{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-primary)}.info-value svg{width:14px;height:14px;color:var(--color-text-muted)}.section{border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-md)}.section:last-child{border-bottom:none}.section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) 0;cursor:pointer;transition:var(--transition-fast)}.section-header:hover{opacity:.8}.section-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.03em}.section-toggle{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:var(--transition-fast)}.section-toggle.open{transform:rotate(180deg)}.section-content{padding-bottom:var(--spacing-md);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.section-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6}.tags{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.tag{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.tag svg{width:12px;height:12px}.category-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.category-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.category-dot{width:6px;height:6px;background:var(--color-accent-blue);border-radius:var(--radius-full)}.panel-footer{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:var(--transition-fast);border:none}.btn-primary{background:var(--color-accent-blue);color:#fff}.btn-primary:hover{background:#2563eb;box-shadow:var(--shadow-glow-blue)}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:8px;transition:all .2s}.btn-secondary:hover{background:var(--color-bg-hover);border-color:#21eac3;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{width:100%;max-width:480px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;animation:scaleIn .2s ease}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.modal-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.modal-body{padding:var(--spacing-lg)}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.form-input{width:100%;padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);outline:none;transition:var(--transition-fast)}.form-input:focus{border-color:var(--color-accent-blue)}.form-input::placeholder{color:var(--color-text-muted)}.form-select{width:100%;padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239ca3af' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.form-select:focus{border-color:var(--color-accent-blue)}.modal-footer{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.modal.modal-large{max-width:640px;max-height:90vh;display:flex;flex-direction:column}.modal-body-scroll{max-height:60vh;overflow-y:auto;padding:var(--spacing-lg)}.form-section{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.form-section:last-child{border-bottom:none;margin-bottom:0}.form-section-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-accent-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.form-section-title:before{content:"";width:3px;height:14px;background:var(--color-accent-primary);border-radius:2px}.form-row{display:flex;gap:var(--spacing-md)}.form-group-half{flex:1}.form-textarea{width:100%;padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);font-family:inherit;outline:none;resize:vertical;min-height:60px;transition:var(--transition-fast)}.form-textarea:focus{border-color:var(--color-accent-blue)}.form-textarea::placeholder{color:var(--color-text-muted)}.tag-selector{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.tag-option{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-fast)}.tag-option:hover{background:var(--color-bg-hover)}.tag-option.active{background:#14b8a61a;border-color:var(--color-accent-primary);color:var(--color-accent-primary)}.tag-check{font-size:10px;font-weight:700}.checkbox-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.checkbox-grid-3{grid-template-columns:repeat(3,1fr)}.checkbox-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:8px 12px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast)}.checkbox-item:hover{background:var(--color-bg-hover)}.checkbox-item:has(input:checked){background:#14b8a614;border-color:var(--color-accent-primary)}.checkbox-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-accent-primary);cursor:pointer}.checkbox-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:500}.checkbox-item:has(input:checked) .checkbox-label{color:var(--color-text-primary)}.toggle-group{display:flex;gap:0;margin-top:var(--spacing-xs)}.toggle-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 16px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:var(--transition-fast)}.toggle-btn:first-child{border-radius:var(--radius-md) 0 0 var(--radius-md);border-right:none}.toggle-btn:last-child{border-radius:0 var(--radius-md) var(--radius-md) 0}.toggle-btn:hover{background:var(--color-bg-hover)}.toggle-btn.active{background:#14b8a61a;border-color:var(--color-accent-primary);color:var(--color-accent-primary)}.toggle-btn.active.negative{background:#ef44441a;border-color:var(--color-accent-red);color:var(--color-accent-red)}.toggle-btn.active.warning{background:#f59e0b1a;border-color:var(--color-accent-orange);color:var(--color-accent-orange)}.toggle-indicator{font-size:12px;font-weight:700}.form-label-date{font-weight:400;color:var(--color-text-muted);margin-left:var(--spacing-sm)}.add-system-btn{position:absolute;bottom:var(--spacing-lg);right:var(--spacing-lg);width:56px;height:56px;background:#21eac3;border:none;border-radius:var(--radius-full);color:#fff;font-size:1.5rem;cursor:pointer;box-shadow:var(--shadow-lg);transition:var(--transition-fast);z-index:10}.add-system-btn:hover{transform:scale(1.1);background:#17c9aa;box-shadow:0 8px 24px #1deac366}.react-flow__edge-path{stroke:var(--color-text-muted);stroke-width:2;opacity:.5}.react-flow__edge.animated .react-flow__edge-path{stroke-dasharray:5;animation:dash 1s linear infinite}@keyframes dash{to{stroke-dashoffset:-10}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-bg-primary)}::-webkit-scrollbar-thumb{background:var(--color-bg-hover);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.confirm-dialog{background:var(--color-bg-secondary);border-radius:var(--radius-xl);padding:var(--spacing-xl);max-width:400px;width:90%;text-align:center;animation:scaleIn .2s ease}.confirm-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-md);font-size:28px}.confirm-icon.warning{background:#f59e0b1a}.confirm-icon.danger{background:#ef44441a}.confirm-icon.info{background:#3b82f61a}.confirm-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.confirm-message{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);line-height:1.5}.confirm-actions{display:flex;gap:var(--spacing-md);justify-content:center}.confirm-actions .btn{min-width:120px}.btn-danger{background:var(--color-accent-red);color:#fff}.btn-danger:hover{background:#dc2626;box-shadow:0 0 0 4px #ef444433}.toast-container{position:fixed;bottom:100px;right:var(--spacing-lg);z-index:1100;display:flex;flex-direction:column;gap:var(--spacing-sm)}.toast{background:var(--color-bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);box-shadow:var(--shadow-lg);border-left:4px solid var(--color-accent-primary);display:flex;align-items:center;gap:var(--spacing-md);animation:slideInRight .3s ease;max-width:360px}.toast.success{border-left-color:var(--color-accent-green)}.toast.error{border-left-color:var(--color-accent-red)}.toast.warning{border-left-color:var(--color-accent-orange)}.toast-icon{font-size:20px}.toast-content{flex:1}.toast-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.toast-message{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.toast-close{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px}.toast-close:hover{color:var(--color-text-primary)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.form-input.error,.form-textarea.error,.form-select.error{border-color:var(--color-accent-red);background:#ef44440d}.form-error{color:var(--color-accent-red);font-size:var(--font-size-xs);margin-top:var(--spacing-xs);display:flex;align-items:center;gap:4px}.form-error:before{content:"⚠"}.delete-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:transparent;border:1px solid var(--color-accent-red);border-radius:var(--radius-md);color:var(--color-accent-red);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:var(--transition-fast)}.delete-btn:hover{background:#ef44441a}.edit-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-accent-blue);border:none;border-radius:var(--radius-md);color:#fff;font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:var(--transition-fast)}.edit-btn:hover{background:#2563eb}.category-manager-modal{background:#fff;border-radius:16px;width:90%;max-width:700px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.category-manager-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:2px solid var(--color-border);background:linear-gradient(135deg,#f8fafc,#fff)}.category-manager-header h2{font-size:22px;font-weight:600;color:var(--color-text-primary);margin:0}.close-btn{width:36px;height:36px;border-radius:8px;border:none;background:transparent;color:var(--color-text-secondary);font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1}.close-btn:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.category-manager-body{padding:28px;overflow-y:auto;flex:1;min-height:0}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:32px}.category-card{background:#fff;border:2px solid var(--color-border);border-radius:12px;overflow:hidden;transition:all .2s ease;cursor:default}.category-card:hover{border-color:var(--color-accent-primary);box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.category-card-color{height:60px;position:relative;transition:all .2s ease}.category-card:hover .category-card-color{height:70px}.color-picker-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.category-card-content{padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px}.category-card-label{font-size:14px;font-weight:500;color:var(--color-text-primary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.default-badge{font-size:11px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;padding:4px 8px;background:var(--color-bg-tertiary);border-radius:6px}.delete-category-btn{background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.delete-category-btn:hover{background:#fee2e2;color:var(--color-accent-red)}.add-category-section{padding:24px;background:var(--color-bg-tertiary);border-radius:12px;border:2px dashed var(--color-border)}.add-category-section h3{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:0 0 20px}.add-category-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.category-input{padding:12px 16px;border:2px solid var(--color-border);border-radius:8px;font-size:14px;color:var(--color-text-primary);background:#fff;transition:all .2s ease}.category-input:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #14b8a61a}.category-input::placeholder{color:var(--color-text-muted)}.color-picker-wrapper{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border:2px solid var(--color-border);border-radius:8px;transition:all .2s ease}.color-picker-wrapper:hover{border-color:var(--color-accent-primary)}.color-picker-large{width:48px;height:48px;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.color-picker-large:hover{transform:scale(1.05)}.color-value{font-size:13px;font-family:Poppins,sans-serif;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase}.add-category-btn{padding:14px 20px;background:#21eac3;border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;margin-top:8px}.add-category-btn:hover:not(:disabled){background:#17d1ae;transform:translateY(-1px);box-shadow:0 4px 12px #1deac34d}.add-category-btn:disabled{opacity:.5;cursor:not-allowed}.tag-manager-modal{background:#fff;border-radius:16px;width:90%;max-width:700px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.tag-manager-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:2px solid var(--color-border);background:linear-gradient(135deg,#f8fafc,#fff)}.tag-manager-header h2{font-size:22px;font-weight:600;color:var(--color-text-primary);margin:0}.tag-manager-body{padding:28px;overflow-y:auto;flex:1;min-height:0}.tags-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:32px}.tag-card{background:#fff;border:2px solid var(--color-border);border-radius:10px;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:all .2s ease}.tag-card:hover{border-color:var(--color-accent-primary);box-shadow:0 4px 12px #00000014}.tag-card-label{font-size:13px;font-weight:500;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.delete-tag-btn{background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.delete-tag-btn:hover{background:#fee2e2;color:var(--color-accent-red)}.add-tag-section{padding:24px;background:var(--color-bg-tertiary);border-radius:12px;border:2px dashed var(--color-border)}.add-tag-section h3{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:0 0 20px}.add-tag-form{display:flex;flex-direction:column;gap:12px}.tag-input{padding:12px 16px;border:2px solid var(--color-border);border-radius:8px;font-size:14px;color:var(--color-text-primary);background:#fff;transition:all .2s ease}.tag-input:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #14b8a61a}.tag-input::placeholder{color:var(--color-text-muted)}.add-tag-btn{padding:12px 20px;background:#21eac3;border:none;border-radius:8px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease}.add-tag-btn:hover:not(:disabled){background:#17d1ae;transform:translateY(-1px);box-shadow:0 4px 12px #1deac34d}.add-tag-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.map-controls{left:var(--spacing-sm);bottom:80px;gap:var(--spacing-sm)}.zoom-btn{width:40px;height:40px;font-size:20px}.control-btn{width:36px;height:36px}.control-btn-single{width:40px;height:40px}.map-legend{display:none}.system-card{min-width:220px!important;padding:16px!important;box-shadow:0 4px 12px #00000026!important}.card-title{font-size:14px!important}.card-subtitle{font-size:12px!important}.card-icon-wrapper{width:40px!important;height:40px!important}.card-icon-letter{font-size:16px!important}.card-tag{font-size:10px!important;padding:5px 10px!important}.react-flow__node{cursor:pointer}.react-flow__handle{width:20px!important;height:20px!important}.header-title-overlay{font-size:16px;top:12px;left:12px}.modal-overlay{padding:0}.modal-content,.category-manager-modal,.tag-manager-modal{width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0}}@media (max-width: 1024px) and (min-width: 769px){.detail-panel{width:400px}.system-card{min-width:200px}}
