[data-v-c51d27c9] .df-code-node{background:#fff;border:1.5px solid #cbd5e1;border-radius:8px;box-shadow:0 1px 4px #00000014;min-width:260px;overflow:hidden;position:relative}[data-v-c51d27c9] .df-code-node:hover{border-color:#94a3b8}[data-v-c51d27c9] .df-code-node:before{background:var(--df-accent,#3b82f6);bottom:0;content:"";left:0;position:absolute;top:0;width:3px}[data-v-c51d27c9] .df-cn-header{align-items:center;display:flex;gap:6px;justify-content:space-between;min-height:28px;padding:6px 8px 4px 10px}[data-v-c51d27c9] .df-cn-header-left{align-items:center;display:flex;flex:1;gap:6px;min-width:0}[data-v-c51d27c9] .df-cn-header-right{align-items:center;display:flex;flex-shrink:0;gap:4px}[data-v-c51d27c9] .df-cn-icon{flex-shrink:0;font-size:13px}[data-v-c51d27c9] .df-cn-title{color:#0f172a;font-size:13px;font-weight:700;-webkit-hyphens:auto;hyphens:auto;overflow-wrap:break-word;word-break:break-word}[data-v-c51d27c9] .df-cn-edit{background:transparent;border:none;color:#6b7280;cursor:pointer;font-size:12px;opacity:0;transition:opacity .15s ease}[data-v-c51d27c9] .df-code-node:hover .df-cn-edit{opacity:1}[data-v-c51d27c9] .df-cn-edit:hover{color:#111827}[data-v-c51d27c9] .df-cn-toggle{background:transparent;border:1px solid #e5e7eb;border-radius:4px;color:#6b7280;cursor:pointer;font-size:12px;margin-left:4px;padding:0 6px}[data-v-c51d27c9] .df-code-node:hover .df-cn-toggle,[data-v-c51d27c9] .df-uml-node:hover .df-cn-toggle{opacity:1}[data-v-c51d27c9] .df-cn-toggle:hover{border-color:#cbd5e1;color:#111827}[data-v-c51d27c9] .df-code{background:#fafafa;border-top:1px solid #f1f5f9;color:#111827;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:12px;line-height:1.25;overflow-x:auto;padding:6px 8px}[data-v-c51d27c9] .df-line{margin:0;max-width:100%;overflow-wrap:anywhere;padding:0;white-space:pre-wrap;word-break:break-word}[data-v-c51d27c9] .df-line.df-footer,[data-v-c51d27c9] .df-line.df-header,[data-v-c51d27c9] .df-line.df-header.df-wrap{white-space:pre-wrap}[data-v-c51d27c9] .df-line.df-header{color:#0f172a}[data-v-c51d27c9] .df-line.df-comment{color:#64748b}[data-v-c51d27c9] .df-line.df-method{color:#1d4ed8}[data-v-c51d27c9] .df-line.df-abstract{color:#7c3aed}[data-v-c51d27c9] .df-line.df-attr{color:#0f766e}[data-v-c51d27c9] .df-line.df-endpoint{color:#b91c1c}[data-v-c51d27c9] .df-line.df-dep{color:#7c2d12}[data-v-c51d27c9] .df-line.df-footer{color:#0f172a}[data-v-c51d27c9] .df-line.df-inline{display:inline-block}[data-v-c51d27c9] .df-uml-node{background:#fff;border:1.5px solid #cbd5e1;border-radius:8px;box-shadow:0 1px 4px #00000014;min-width:260px}[data-v-c51d27c9] .df-uml-header{align-items:center;display:flex;gap:6px;justify-content:space-between;min-height:28px;padding:6px 8px 4px 10px}[data-v-c51d27c9] .df-uml-header-left{align-items:center;display:flex;flex:1;gap:6px;min-width:0}[data-v-c51d27c9] .df-uml-header-right{align-items:center;display:flex;flex-shrink:0;gap:4px}[data-v-c51d27c9] .df-uml-title{color:#0f172a;font-size:13px;font-weight:700;-webkit-hyphens:auto;hyphens:auto;overflow-wrap:break-word;word-break:break-word}[data-v-c51d27c9] .df-uml-st{color:#64748b;flex-shrink:0;font-size:11px;white-space:nowrap}[data-v-c51d27c9] .df-uml-section{border-top:1px solid #f1f5f9;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:12px;padding:6px 8px}[data-v-c51d27c9] .df-uml-row{overflow-wrap:anywhere;white-space:pre-wrap}[data-v-c51d27c9] .df-uml-empty{color:#94a3b8;font-style:italic}.node-item[data-v-c51d27c9]{position:relative;transition:all .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.node-item[data-v-c51d27c9]:hover{transform:translateY(-1px)}.node-item[data-v-c51d27c9]:active{transform:scale(.95)}.node-item[draggable=true][data-v-c51d27c9]{cursor:grab}.node-item[draggable=true][data-v-c51d27c9]:active{cursor:grabbing}.node-item[draggable=true][data-v-c51d27c9]:focus{outline:none}.node-item[draggable=true][dragging][data-v-c51d27c9]{opacity:.5;transform:scale(.95)}.node-palette .overflow-x-auto[data-v-c51d27c9]{scrollbar-width:none;-ms-overflow-style:none}.node-palette .overflow-x-auto[data-v-c51d27c9]::-webkit-scrollbar{display:none}.node-item[data-v-c51d27c9]{min-width:140px}.node-scroll-container[data-v-c51d27c9]{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.node-palette button[data-v-c51d27c9]:hover{background-color:#e5e7eb}.canvas-container[data-v-c51d27c9]{background:#f8fafc;background-image:linear-gradient(rgba(0,0,0,.1) 1px,transparent 0),linear-gradient(90deg,rgba(0,0,0,.1) 1px,transparent 0);background-position:0 0;background-size:20px 20px;display:flex;flex-direction:column;height:auto;min-height:var(--canvas-min-height,600px);overflow:var(--canvas-overflow,hidden);position:relative}.canvas-container[dragover][data-v-c51d27c9]{background-color:#eff6ff}[data-v-c51d27c9] .drawflow{background:transparent!important;height:100%!important;min-height:var(--canvas-min-height,600px)!important;min-width:600px!important;overflow:auto;overflow:var(--canvas-overflow,hidden);width:auto!important}[data-v-c51d27c9] .parent-drawflow .drawflow{height:8000px!important;overflow:visible!important;position:absolute!important;width:8000px!important}[data-v-c51d27c9] .drawflow .input{background:#10b981!important;border:2px solid #fff!important;border-radius:50%!important;box-shadow:0 1px 3px #0000002e!important;cursor:crosshair!important;display:block!important;height:14px!important;left:10px!important;pointer-events:all!important;position:absolute!important;top:50%!important;transform:translateY(-50%)!important;visibility:visible!important;width:14px!important;z-index:1000!important}[data-v-c51d27c9] .drawflow .output{background:#3b82f6!important;border:2px solid #fff!important;border-radius:50%!important;box-shadow:0 1px 3px #0000002e!important;cursor:crosshair!important;display:block!important;height:14px!important;pointer-events:all!important;position:absolute!important;right:-120px!important;top:50%!important;transform:translateY(-50%)!important;visibility:visible!important;width:14px!important;z-index:1000!important}[data-v-c51d27c9] .drawflow .connection{pointer-events:none!important;position:absolute!important;z-index:500!important}[data-v-c51d27c9] .drawflow .connection.relationship-association path{stroke:#3b82f6!important;stroke-width:1.8px!important;stroke-dasharray:none!important}[data-v-c51d27c9] .drawflow .connection.relationship-aggregation path{stroke:#10b981!important;stroke-width:1.8px!important;stroke-dasharray:5,5!important}[data-v-c51d27c9] .drawflow .connection.relationship-composition path{stroke:#8b5cf6!important;stroke-width:2.2px!important;stroke-dasharray:none!important}[data-v-c51d27c9] .drawflow .connection.relationship-inheritance path{stroke:#f59e0b!important;stroke-width:1.8px!important;stroke-dasharray:10,5!important}[data-v-c51d27c9] .drawflow .parent-node{position:relative!important;z-index:100!important}.sidebar-backdrop[data-v-c51d27c9]{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000004d;bottom:0;left:0;position:absolute;right:0;top:0;z-index:999}.node-editor-sidebar[data-v-c51d27c9]{display:flex;flex-direction:column;height:100%;position:absolute;right:0;top:0;transform:translate(100%);transition:transform .3s ease-in-out;z-index:1000}.node-editor-sidebar.sidebar-open[data-v-c51d27c9]{transform:translate(0)}.sidebar-header[data-v-c51d27c9]{flex-shrink:0}.sidebar-content[data-v-c51d27c9]{flex:1;min-height:0;overflow-y:auto}.section[data-v-c51d27c9]{margin-bottom:24px}.section-title[data-v-c51d27c9]{color:#374151;font-size:14px;font-weight:600;gap:6px}.section-header[data-v-c51d27c9],.section-title[data-v-c51d27c9]{align-items:center;display:flex;margin-bottom:12px}.section-header[data-v-c51d27c9]{justify-content:space-between}.input-label[data-v-c51d27c9]{color:#6b7280;display:block;font-size:12px;font-weight:500;margin-bottom:4px}.input-field[data-v-c51d27c9]{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.input-field[data-v-c51d27c9]:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.add-item-btn[data-v-c51d27c9]{align-items:center;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;font-size:12px;gap:4px;padding:6px 12px;transition:all .2s}.add-item-btn[data-v-c51d27c9]:hover{background:#e5e7eb;border-color:#9ca3af}.item-row[data-v-c51d27c9]{align-items:center;display:flex;gap:8px;margin-bottom:8px}.item-input[data-v-c51d27c9]{border:1px solid #d1d5db;border-radius:4px;flex:1;font-size:13px;padding:6px 10px;transition:border-color .2s}.item-input[data-v-c51d27c9]:focus{border-color:#3b82f6;outline:none}.remove-item-btn[data-v-c51d27c9]{align-items:center;background:#ef4444;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;height:24px;justify-content:center;transition:background-color .2s;width:24px}.remove-item-btn[data-v-c51d27c9]:hover{background:#dc2626}.endpoint-row[data-v-c51d27c9]{align-items:center;display:flex;gap:8px;margin-bottom:8px}.endpoint-method-select[data-v-c51d27c9]{background:#fff;border:1px solid #d1d5db;border-radius:4px;font-size:12px;padding:6px 8px;width:80px}.endpoint-path-input[data-v-c51d27c9]{border:1px solid #d1d5db;border-radius:4px;flex:1;font-family:monospace;font-size:13px;padding:6px 10px}.empty-state[data-v-c51d27c9]{color:#9ca3af;flex-direction:column;padding:24px 16px;text-align:center}.empty-state[data-v-c51d27c9],.save-btn[data-v-c51d27c9]{align-items:center;display:flex;justify-content:center}.save-btn[data-v-c51d27c9]{background:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;gap:8px;padding:12px 16px;transition:background-color .2s;width:100%}.save-btn[data-v-c51d27c9]:hover{background:#059669}[data-v-c51d27c9] .drawflow .connection.custom-relationship path,[data-v-c51d27c9] .drawflow .connection.relationship-aggregation-* path,[data-v-c51d27c9] .drawflow .connection.relationship-association-* path,[data-v-c51d27c9] .drawflow .connection.relationship-composition-* path,[data-v-c51d27c9] .drawflow .connection.relationship-inheritance-* path,[data-v-c51d27c9] .drawflow .connection[data-relationship-type] path,[data-v-c51d27c9] .drawflow .connection[data-relationship-type] svg path{stroke-opacity:1!important;fill:none!important}[data-v-c51d27c9] .drawflow .connection.relationship-association-* path,[data-v-c51d27c9] .drawflow .connection[data-relationship-type=association] path{stroke:#3b82f6!important;stroke-width:2px!important;stroke-dasharray:none!important;stroke-opacity:1!important}[data-v-c51d27c9] .drawflow .connection.relationship-aggregation-* path,[data-v-c51d27c9] .drawflow .connection[data-relationship-type=aggregation] path{stroke:#10b981!important;stroke-width:2px!important;stroke-dasharray:5,5!important;stroke-opacity:1!important}[data-v-c51d27c9] .drawflow .connection.relationship-composition-* path,[data-v-c51d27c9] .drawflow .connection[data-relationship-type=composition] path{stroke:#8b5cf6!important;stroke-width:3px!important;stroke-dasharray:none!important;stroke-opacity:1!important}[data-v-c51d27c9] .drawflow .connection.relationship-inheritance-* path,[data-v-c51d27c9] .drawflow .connection[data-relationship-type=inheritance] path{stroke:#f59e0b!important;stroke-width:2px!important;stroke-dasharray:10,5!important;stroke-opacity:1!important}[data-v-c51d27c9] .drawflow .connection.relationship-dependency-* path,[data-v-c51d27c9] .drawflow .connection[data-relationship-type=dependency] path{stroke:#6b7280!important;stroke-width:2px!important;stroke-dasharray:3,3!important;stroke-opacity:1!important}[data-v-c51d27c9] .drawflow .connection path{stroke-opacity:1!important;fill:none!important}[data-v-c51d27c9] .drawflow .connection.custom-relationship{opacity:1!important;visibility:visible!important}[data-v-c51d27c9] .drawflow .connection path{shape-rendering:geometricPrecision}[data-v-c51d27c9] .drawflow .connection[data-relationship-type=inheritance] polygon{fill:#f59e0b!important;stroke:#f59e0b!important}[data-v-c51d27c9] .drawflow .connection[data-relationship-type=composition] polygon{fill:#8b5cf6!important;stroke:#8b5cf6!important}[data-v-c51d27c9] .drawflow .connection[data-relationship-type=aggregation] polygon{fill:#10b981!important;stroke:#10b981!important}[data-v-c51d27c9] .drawflow .connection[data-relationship-type=association] polygon{fill:#3b82f6!important;stroke:#3b82f6!important}[data-v-c51d27c9] .drawflow .connection[data-relationship-type=dependency] polygon{fill:#6b7280!important;stroke:#6b7280!important}.relationship-modal-backdrop[data-v-c51d27c9]{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.relationship-type-button[data-v-c51d27c9]{transition:all .2s ease}.relationship-type-button[data-v-c51d27c9]:hover{transform:translateY(-1px)}.cardinality-preset-button[data-v-c51d27c9]{transition:all .2s ease}.cardinality-preset-button[data-v-c51d27c9]:hover{background-color:#e5e7eb;transform:scale(1.05)}[data-v-c51d27c9] .cardinality-label-source{right:-120px!important}[data-v-c51d27c9] .cardinality-label-target{left:2px!important}
