*,:before,:after{box-sizing:border-box}:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-danger:#dc2626;--color-danger-hover:#b91c1c;--color-bg:#f1f5f9;--color-surface:#fff;--color-border:#e2e8f0;--color-border-strong:#cbd5e1;--color-text:#1e293b;--color-text-muted:#64748b;--color-sidebar:#1e293b;--color-sidebar-text:#e2e8f0;--canvas-bg:#fff;--conn-color:#475569;--radius:6px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}html,body{background:var(--color-bg);height:100%;color:var(--color-text);margin:0;padding:0;overflow:hidden}#root{flex-direction:column;height:100%;display:flex}button{cursor:pointer;font-family:inherit}kbd{color:#475569;background:#e2e8f0;border:1px solid #cbd5e1;border-radius:3px;padding:1px 5px;font-family:monospace;font-size:11px;display:inline-block}code{background:#f1f5f9;border-radius:3px;padding:1px 4px;font-family:ui-monospace,Consolas,monospace;font-size:.85em}.app{flex-direction:column;height:100%;display:flex;overflow:hidden}.app-body{flex:1;min-height:0;display:flex;overflow:hidden}.toolbar{background:var(--color-sidebar);height:52px;color:var(--color-sidebar-text);-webkit-user-select:none;user-select:none;z-index:10;flex-shrink:0;align-items:center;gap:8px;padding:0 16px;display:flex;box-shadow:0 2px 4px #0003}.toolbar-brand{align-items:center;gap:8px;margin-right:12px;display:flex}.toolbar-logo{font-size:22px}.toolbar-title{letter-spacing:-.3px;color:#fff;white-space:nowrap;font-size:15px;font-weight:700}.toolbar-diagram-types{border-right:1px solid #ffffff26;gap:2px;margin-right:4px;padding-right:12px;display:flex}.diagram-type-btn{color:#ffffffb3;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:5px;padding:5px 12px;font-size:13px;font-weight:500;transition:all .15s}.diagram-type-btn:hover{color:#fff;background:#ffffff1a}.diagram-type-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.toolbar-actions{align-items:center;gap:4px;margin-left:auto;display:flex}.toolbar-divider{background:#fff3;width:1px;height:22px;margin:0 4px}.toolbar-btn{border-radius:var(--radius);color:#ffffffd9;white-space:nowrap;background:#ffffff14;border:1px solid #ffffff26;padding:5px 11px;font-size:13px;font-weight:500;transition:all .15s}.toolbar-btn:hover:not(:disabled){color:#fff;background:#ffffff29}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.toolbar-btn-primary{background:var(--color-primary);color:#fff;border-color:#0000}.toolbar-btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.object-palette{background:var(--color-sidebar);width:160px;color:var(--color-sidebar-text);border-right:1px solid #ffffff12;flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.palette-header{border-bottom:1px solid #ffffff1a;padding:14px 12px 8px}.palette-header h3{text-transform:uppercase;letter-spacing:.8px;color:#ffffff80;margin:0;font-size:12px;font-weight:700}.palette-hint{color:#ffffff4d;margin-top:2px;font-size:11px}.palette-list{margin:0;padding:8px 0;list-style:none}.palette-list li{margin:0;padding:0}.palette-item{cursor:grab;border-radius:0;align-items:center;gap:8px;padding:9px 12px;transition:background .1s;display:flex}.palette-item:hover{background:#ffffff1a}.palette-item:active{cursor:grabbing;background:#ffffff26}.palette-item-icon{text-align:center;width:20px;font-size:16px}.palette-item-label{color:#fffc;font-size:13px;font-weight:500}.palette-footer{border-top:1px solid #ffffff1a;margin-top:auto;padding:12px}.palette-footer h4{text-transform:uppercase;letter-spacing:.7px;color:#fff6;margin:0 0 8px;font-size:11px;font-weight:700}.shortcuts-list{flex-direction:column;gap:5px;margin:0;padding:0;list-style:none;display:flex}.shortcuts-list li{color:#ffffff73;align-items:center;gap:5px;font-size:11px;display:flex}.canvas-container{background:var(--color-bg);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.canvas-controls{background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:6px;padding:6px 12px;display:flex}.canvas-btn{border-radius:var(--radius);border:1px solid var(--color-border-strong);background:var(--color-surface);color:var(--color-text);white-space:nowrap;padding:4px 10px;font-size:12px;font-weight:500;transition:all .15s}.canvas-btn:hover{background:#f1f5f9;border-color:#94a3b8}.canvas-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.canvas-btn-danger{color:var(--color-danger);border-color:#fca5a5}.canvas-btn-danger:hover{border-color:var(--color-danger);background:#fef2f2}.canvas-hint{color:var(--color-text-muted);font-size:12px;font-style:italic}.canvas-zoom-controls{align-items:center;gap:4px;margin-left:auto;display:flex}.zoom-label{color:var(--color-text-muted);text-align:center;min-width:38px;font-size:12px}.canvas-viewport{background:repeating-linear-gradient(0deg,#0000,#0000 24px,#94a3b826 24px 25px),repeating-linear-gradient(90deg,#0000,#0000 24px,#94a3b826 24px 25px);background-color:var(--color-bg);cursor:default;-webkit-user-select:none;user-select:none;flex:1;position:relative;overflow:hidden}.canvas-viewport.connect-mode{cursor:crosshair}.canvas-world{background:var(--canvas-bg);box-shadow:0 0 0 1px var(--color-border);position:relative}.canvas-svg{overflow:visible}.canvas-empty{text-align:center;color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.canvas-empty-icon{margin-bottom:12px;font-size:48px}.canvas-empty p{font-size:14px}.diagram-element{cursor:move;-webkit-user-select:none;user-select:none;position:absolute}.diagram-element.selected>*{outline:2px solid var(--color-primary);outline-offset:2px}.diagram-element.connect-source>*{outline-offset:2px;outline:2px solid #f59e0b}.diagram-element.connectable{cursor:pointer}.diagram-element.connectable:hover>*{outline-offset:2px;outline:2px dashed #10b981}.class-box{min-width:100%;box-shadow:var(--shadow);background:#fff;border:2px solid #334155;border-radius:4px;overflow:hidden}.class-header{color:#fff;text-align:center;background:#1e293b;padding:6px 10px}.element-kind-interface .class-header{background:#1d4ed8}.element-kind-abstract_class .class-header{background:#4f46e5}.element-kind-enum .class-header{background:#047857}.class-stereotype{color:#ffffffb3;margin-bottom:2px;font-size:10px;font-style:italic}.class-name{color:#fff;letter-spacing:.2px;font-size:13px;font-weight:700}.element-kind-abstract_class .class-name{font-style:italic}.class-members{border-top:1px solid #e2e8f0;min-height:24px;padding:4px 8px}.class-member{color:#374151;white-space:nowrap;text-overflow:ellipsis;padding:2px 0;font-family:ui-monospace,Consolas,monospace;font-size:11px;overflow:hidden}.participant-box{text-align:center;color:#1e40af;box-shadow:var(--shadow);white-space:nowrap;background:#dbeafe;border:2px solid #3b82f6;border-radius:4px;padding:10px 14px;font-size:13px;font-weight:600}.actor-box{color:#1e293b;flex-direction:column;align-items:center;gap:4px;padding:4px;display:flex}.actor-name{text-align:center;word-break:break-word;max-width:80px;font-size:12px;font-weight:600}.usecase-box{text-align:center;color:#713f12;min-height:50px;box-shadow:var(--shadow);background:#fef9c3;border:2px solid #ca8a04;border-radius:50px;justify-content:center;align-items:center;padding:12px 16px;font-size:13px;font-weight:600;display:flex}.activity-box{text-align:center;color:#065f46;box-shadow:var(--shadow);background:#d1fae5;border:2px solid #10b981;border-radius:24px;justify-content:center;align-items:center;padding:10px 16px;font-size:13px;font-weight:600;display:flex}.start-node{width:30px;height:30px;box-shadow:var(--shadow);background:#1e293b;border-radius:50%}.stop-node{width:32px;height:32px;box-shadow:var(--shadow);background:#fff;border:3px solid #1e293b;border-radius:50%;justify-content:center;align-items:center;display:flex}.stop-node-inner{background:#1e293b;border-radius:50%;width:16px;height:16px}.decision-node{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.decision-diamond{clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);width:90px;height:50px;box-shadow:var(--shadow);background:#fce7f3;border:2px solid #db2777;justify-content:center;align-items:center;display:flex;transform:rotate(0)}.decision-diamond span{color:#831843;text-align:center;word-break:break-word;max-width:60px;font-size:11px;font-weight:600;transform:none}.component-box{color:#1e40af;box-shadow:var(--shadow);background:#eff6ff;border:2px solid #2563eb;border-radius:4px;align-items:center;min-height:50px;padding:10px 10px 10px 28px;font-size:13px;font-weight:600;display:flex;position:relative}.component-icon{flex-direction:column;gap:3px;display:flex;position:absolute;top:50%;left:6px;transform:translateY(-50%)}.component-icon-bar{background:#2563eb;border-radius:2px;width:14px;height:5px;position:relative}.component-icon-bar:before{content:"";background:#2563eb;width:4px;height:3px;position:absolute;top:50%;left:-4px;transform:translateY(-50%)}.database-box{box-shadow:var(--shadow);background:#f0fdf4;border:2px solid #16a34a;border-radius:4px;width:100%;overflow:hidden}.database-top{background:#16a34a;border-radius:50% 50% 0 0/8px 8px 0 0;height:14px}.database-body{text-align:center;color:#14532d;justify-content:center;align-items:center;min-height:30px;padding:8px;font-size:12px;font-weight:600;display:flex}.database-bottom{background:#16a34a33;border-radius:0 0 50% 50%/0 0 6px 6px;height:10px}.object-instance-box{min-width:100%;box-shadow:var(--shadow);background:#fff;border:2px solid #0e7490;border-radius:4px;overflow:hidden}.object-instance-header{text-align:center;background:#0e7490;padding:6px 10px}.object-instance-name{color:#fff;letter-spacing:.2px;font-size:13px;font-weight:700;text-decoration:underline}.object-instance-fields{border-top:1px solid #e2e8f0;min-height:24px;padding:4px 8px}.object-instance-field{color:#374151;white-space:nowrap;text-overflow:ellipsis;padding:2px 0;font-family:ui-monospace,Consolas,monospace;font-size:11px;overflow:hidden}.deploy-node-box{box-shadow:var(--shadow);background:#f8fafc;border:2px solid #475569;border-radius:4px;width:100%;overflow:hidden}.deploy-node-header{background:#475569;align-items:center;gap:6px;padding:8px 10px;display:flex}.deploy-node-icon{color:#cbd5e1;font-size:14px}.deploy-node-name{color:#fff;font-size:13px;font-weight:700}.deploy-artifact-box{color:#713f12;box-shadow:var(--shadow);background:#fefce8;border:2px solid #ca8a04;border-radius:2px;align-items:center;gap:6px;min-height:44px;padding:8px 10px;font-size:12px;font-weight:600;display:flex;position:relative}.deploy-artifact-corner{clip-path:polygon(100% 0,0 0,100% 100%);background:#ca8a04;width:10px;height:10px;position:absolute;top:0;right:0}.deploy-cloud-box{text-align:center;color:#0c4a6e;box-shadow:var(--shadow);background:#e0f2fe;border:2px solid #0284c7;border-radius:40px 40px 24px 24px;justify-content:center;align-items:center;gap:4px;padding:10px 14px;font-size:13px;font-weight:600;display:flex}.state-node-box{box-shadow:var(--shadow);background:#f5f3ff;border:2px solid #7c3aed;border-radius:8px;width:100%;overflow:hidden}.state-node-name{color:#4c1d95;text-align:center;padding:8px 12px;font-size:13px;font-weight:700}.state-node-desc{border-top:1px solid #ddd6fe;padding:4px 8px}.state-node-desc-line{color:#5b21b6;padding:1px 0;font-family:ui-monospace,Consolas,monospace;font-size:11px}.seq-participant-box{flex-direction:column;align-items:center;gap:4px;padding:4px 6px;display:flex}.seq-participant-name{text-align:center;color:var(--color-text);font-size:12px;font-weight:600}.seq-boundary-box svg{color:#1d4ed8}.seq-control-box svg{color:#7c3aed}.seq-entity-box svg{color:#065f46}.seq-database-box svg{color:#b45309}.seq-collections-box svg{color:#0e7490}.seq-queue-box svg{color:#9d174d}.fork-node{background:#1e293b;border-radius:3px;width:100%;height:100%;min-height:20px}.comp-interface-box{flex-direction:column;align-items:center;gap:4px;padding:6px;display:flex}.comp-interface-box svg{color:#0369a1}.comp-interface-name{text-align:center;color:var(--color-text);font-size:12px;font-weight:600}.comp-node-box{box-shadow:var(--shadow);background:#f0f9ff;border:2px solid #0369a1;border-radius:4px;width:100%;overflow:hidden}.comp-node-header{background:#0369a1;align-items:center;gap:6px;padding:8px 10px;display:flex}.comp-node-icon{color:#bae6fd;font-size:14px}.comp-node-name{color:#fff;font-size:13px;font-weight:700}.deploy-file-box{color:#92400e;box-shadow:var(--shadow);background:#fffbeb;border:2px solid #d97706;border-radius:2px;align-items:center;gap:4px;width:100%;min-height:44px;padding:8px 10px;font-size:12px;font-weight:600;display:flex}.deploy-folder-box{box-shadow:var(--shadow);background:#fef9c3;border:2px solid #ca8a04;border-radius:4px;width:100%;overflow:hidden}.deploy-folder-tab{background:#ca8a04;width:40%;height:8px}.deploy-folder-body{color:#713f12;align-items:center;gap:4px;min-height:36px;padding:8px 10px;font-size:12px;font-weight:600;display:flex}.deploy-frame-box{box-shadow:var(--shadow);background:0 0;border:2px solid #64748b;border-radius:2px;width:100%;overflow:hidden}.deploy-frame-title{color:#fff;background:#64748b;padding:4px 8px;font-size:12px;font-weight:600}.deploy-package-box{box-shadow:var(--shadow);background:#f8fafc;border:2px solid #334155;border-radius:4px;width:100%;overflow:hidden}.deploy-package-tab{background:#334155;width:45%;height:8px}.deploy-package-body{color:#1e293b;text-align:center;padding:10px;font-size:13px;font-weight:600}.deploy-queue-box{color:#581c87;box-shadow:var(--shadow);background:#fdf4ff;border:2px solid #9333ea;border-radius:4px;align-items:center;gap:4px;width:100%;min-height:44px;padding:8px 10px;font-size:12px;font-weight:600;display:flex}.state-choice-node{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.state-choice-diamond{clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);width:60px;height:50px;box-shadow:var(--shadow);background:#f5f3ff;border:2px solid #7c3aed;justify-content:center;align-items:center;display:flex}.state-choice-diamond span{color:#4c1d95;text-align:center;word-break:break-word;max-width:40px;font-size:10px;font-weight:600}.end-node{clip-path:polygon(20% 0%,80% 0%,100% 20%,100% 80%,80% 100%,20% 100%,0% 80%,0% 20%);width:32px;height:32px;box-shadow:var(--shadow);background:#1e293b}.activity-input-box,.activity-output-box,.activity-procedure-box,.activity-task-box,.activity-save-box,.activity-load-box,.activity-continuous-box{box-shadow:var(--shadow);text-align:center;justify-content:center;align-items:center;width:100%;min-height:44px;padding:8px 18px;font-size:13px;font-weight:600;display:flex}.activity-input-box{color:#1e40af;clip-path:polygon(12% 0%,100% 0%,100% 100%,12% 100%,0% 50%);background:#dbeafe;padding-left:28px}.activity-output-box{color:#92400e;clip-path:polygon(0% 0%,88% 0%,100% 50%,88% 100%,0% 100%);background:#fef3c7;padding-right:28px}.activity-procedure-box{color:#065f46;background:#d1fae5;border:2px solid #10b981;border-width:2px 6px}.activity-task-box{color:#334155;background:#f1f5f9;border:2px solid #64748b;border-radius:0}.activity-save-box{color:#4c1d95;clip-path:polygon(8% 0%,100% 0%,92% 100%,0% 100%);background:#f5f3ff}.activity-load-box{color:#581c87;clip-path:polygon(0% 0%,92% 0%,100% 100%,8% 100%);background:#fdf4ff}.activity-continuous-box{color:#713f12;background:#fef9c3;border:2px solid #ca8a04;border-radius:4px 24px 24px 4px}.activity-uml-box{text-align:center;box-shadow:var(--shadow);background:#fff7ed;border:2px solid #c2410c;border-radius:4px;width:100%;padding:4px 8px}.activity-uml-stereotype{color:#9a3412;margin-bottom:2px;font-size:10px;font-style:italic}.activity-uml-name{color:#7c2d12;font-size:12px;font-weight:600}.activity-time-event-box{color:#0369a1;flex-direction:column;align-items:center;gap:2px;padding:4px;display:flex}.state-history-box{color:#4c1d95;width:36px;height:36px;box-shadow:var(--shadow);background:#f5f3ff;border:2px solid #7c3aed;border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.state-entry-point{width:24px;height:24px;box-shadow:var(--shadow);background:#7c3aed;border-radius:50%}.state-exit-point{color:#7c3aed;width:24px;height:24px;box-shadow:var(--shadow);background:#fff;border:2px solid #7c3aed;border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:flex}.deploy-simple-box{box-shadow:var(--shadow);text-align:center;background:#f8fafc;border:2px solid;border-radius:4px;justify-content:center;align-items:center;width:100%;min-height:44px;padding:10px 12px;font-size:12px;font-weight:600;display:flex}.deploy-card-box{color:#581c87;box-shadow:var(--shadow);background:#fdf4ff;border:2px solid #9333ea;border-radius:8px;justify-content:center;align-items:center;width:100%;min-height:44px;padding:10px 12px;font-size:12px;font-weight:600;display:flex}.deploy-circle-box{text-align:center;color:#164e63;width:70px;height:70px;box-shadow:var(--shadow);word-break:break-word;background:#ecfeff;border:2px solid #0e7490;border-radius:50%;justify-content:center;align-items:center;padding:4px;font-size:11px;font-weight:600;display:flex}.deploy-hexagon-box{text-align:center;color:#4c1d95;width:80px;height:70px;box-shadow:var(--shadow);clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%);word-break:break-word;background:#f5f3ff;border:2px solid #7c3aed;justify-content:center;align-items:center;padding:4px 16px;font-size:11px;font-weight:600;display:flex}.deploy-stack-box{flex-direction:column;justify-content:flex-end;width:100%;height:100%;display:flex;position:relative}.deploy-stack-layer{background:#f8fafc;border:2px solid #334155;border-radius:4px;height:44px;position:absolute;bottom:0;left:8px;right:0}.deploy-stack-layer-mid{background:#f1f5f9;bottom:6px;left:4px}.deploy-stack-layer-top{color:#1e293b;background:#e2e8f0;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex;bottom:12px;left:0}.uc-container-box{box-shadow:var(--shadow);background:0 0;border:2px dashed #0ea5e9;border-radius:4px;flex-direction:column;gap:2px;width:100%;min-height:44px;padding:6px 10px;font-size:12px;display:flex}.uc-container-label{color:#0284c7;font-size:10px;font-style:italic}.uc-container-name{color:#0c4a6e;font-size:13px;font-weight:600}.object-map-box{box-shadow:var(--shadow);border:2px solid #0369a1;border-radius:4px;width:100%;overflow:hidden}.object-map-header{color:#fff;text-align:center;background:#0369a1;padding:4px 8px;font-size:12px;font-weight:700}.object-map-entries{color:#0c4a6e;background:#f0f9ff;padding:4px 8px;font-size:11px}.object-map-entry{border-bottom:1px solid #bae6fd;padding:2px 0;font-family:monospace}.object-map-entry:last-child{border-bottom:none}.object-map-empty{color:#94a3b8;font-style:italic}.comp-port-box{color:#475569;width:30px;height:30px;box-shadow:var(--shadow);background:#f1f5f9;border:2px solid #64748b;border-radius:2px;justify-content:center;align-items:center;font-size:9px;font-weight:600;display:flex}.deploy-label-box{color:#334155;text-align:center;background:0 0;justify-content:center;align-items:center;width:100%;min-height:32px;padding:6px 10px;font-size:13px;font-weight:600;display:flex}.state-pin-box{color:#92400e;width:30px;height:30px;box-shadow:var(--shadow);background:#fef3c7;border:2px solid #d97706;border-radius:2px;justify-content:center;align-items:center;font-size:12px;display:flex}.state-expansion-box{color:#4c1d95;width:30px;height:30px;box-shadow:var(--shadow);background:#ede9fe;border:2px solid #7c3aed;border-radius:2px;justify-content:center;align-items:center;font-size:12px;display:flex}.state-sdl-receive-box{color:#14532d;box-shadow:var(--shadow);background:#f0fdf4;border:2px solid #16a34a;border-radius:4px;justify-content:center;align-items:center;gap:4px;width:100%;min-height:44px;padding:8px 10px;font-size:12px;font-weight:600;display:flex}.note-box{color:#713f12;clip-path:polygon(0% 0%,calc(100% - 16px) 0%,100% 16px,100% 100%,0% 100%);background:#fefce8;border:1.5px solid #ca8a04;border-radius:4px;width:100%;min-height:54px;padding:8px 10px;font-size:12px;position:relative;box-shadow:2px 2px 4px #00000026}.note-corner{filter:brightness(.75);border-top:0 solid #0000;border-bottom:16px solid #0000;border-left:0 solid #0000;border-right:16px solid #ca8a04;width:0;height:0;position:absolute;top:0;right:0}.note-text{word-break:break-word;font-style:italic;line-height:1.4}.connection-line-path{stroke:var(--conn-color);stroke-width:1.5px;fill:none}.connection-selected .connection-line-path{stroke:var(--color-primary);stroke-width:2px}.connection-label{fill:var(--color-text-muted);pointer-events:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:11px}.connection-selected .connection-label{fill:var(--color-primary)}.code-panel{border-left:1px solid var(--color-border);background:#0f172a;flex-direction:column;flex-shrink:0;width:320px;display:flex;overflow:hidden}.code-panel-tabs{border-bottom:1px solid #ffffff14;flex-shrink:0;display:flex}.code-tab{color:#ffffff80;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px;font-size:13px;font-weight:500;transition:all .15s}.code-tab:hover{color:#fffc;background:#ffffff0d}.code-tab.active{color:#fff;border-bottom-color:var(--color-primary);background:#ffffff0a}.code-editor-wrapper{flex-direction:column;flex:1;display:flex;overflow:hidden}.code-editor{resize:none;color:#e2e8f0;tab-size:2;caret-color:#93c5fd;background:#0f172a;border:none;outline:none;flex:1;padding:14px;font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:12px;line-height:1.7}.code-editor-footer{border-top:1px solid #ffffff14;flex-shrink:0;justify-content:space-between;align-items:center;padding:6px 12px;display:flex}.code-line-count{color:#ffffff59;font-size:11px}.preview-wrapper{background:#fff;flex-direction:column;flex:1;justify-content:flex-start;align-items:center;padding:12px;display:flex;position:relative;overflow:auto}.preview-loading{color:var(--color-text-muted);align-items:center;gap:10px;margin:auto;font-size:13px;display:flex}.spinner{border:2px solid #e2e8f0;border-top-color:var(--color-primary);border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.preview-error{color:var(--color-danger);text-align:center;margin:auto;font-size:13px}.preview-error p{margin:4px 0}.preview-image{max-width:100%;height:auto;display:block}.modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:10px;flex-direction:column;width:440px;max-width:95vw;max-height:85vh;display:flex;overflow:hidden;box-shadow:0 25px 50px #0003}.modal-sm{width:360px}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{color:var(--color-text);text-transform:capitalize;margin:0;font-size:16px;font-weight:700}.modal-close{color:var(--color-text-muted);background:0 0;border:none;border-radius:4px;padding:4px;font-size:18px;line-height:1}.modal-close:hover{color:var(--color-text);background:#f1f5f9}.modal-body{flex-direction:column;flex:1;gap:14px;padding:20px;display:flex;overflow-y:auto}.modal-footer{justify-content:flex-end;gap:8px;padding-top:6px;display:flex}.form-label{color:var(--color-text);flex-direction:column;gap:5px;font-size:13px;font-weight:600;display:flex}.form-hint{color:var(--color-text-muted);font-size:11px;font-weight:400}.form-input,.form-textarea{border:1px solid var(--color-border-strong);border-radius:var(--radius);color:var(--color-text);background:var(--color-surface);outline:none;padding:8px 10px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.form-textarea{resize:vertical;font-family:ui-monospace,Consolas,monospace;font-size:12px;line-height:1.6}.connection-summary{color:var(--color-text-muted);text-align:center;border-radius:var(--radius);border:1px solid var(--color-border);background:#f8fafc;margin:0;padding:8px;font-size:14px}.btn{border-radius:var(--radius);cursor:pointer;border:1px solid #0000;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border-strong)}.btn-secondary:hover{background:#f1f5f9}.btn-sm{padding:4px 10px;font-size:12px}.preview-overlay{z-index:1;background:#ffffffb3;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.preview-image.preview-loading{opacity:.4}.diagram-element.is-container{cursor:move}.diagram-element.is-container:not(.selected):not(.connect-source)>.container-box{outline-offset:-1px;outline:1px dashed #6366f159}.container-box{border:2px solid var(--container-border,#6366f1);background:var(--container-bg,#eef2ff99);width:100%;height:100%;box-shadow:var(--shadow);border-radius:6px;flex-direction:column;display:flex;overflow:visible}.container-header{background:var(--container-header-bg,#6366f1);-webkit-user-select:none;user-select:none;border-radius:4px 4px 0 0;align-items:center;gap:6px;height:30px;min-height:30px;padding:0 10px;display:flex}.container-keyword{text-transform:uppercase;letter-spacing:.5px;color:#ffffffb3;font-size:10px;font-weight:600}.container-name{color:#fff;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:700;overflow:hidden}.container-body{flex:1;min-height:80px;padding:16px;position:relative}.container-kind-deploy_node{--container-border:#475569;--container-header-bg:#475569;--container-bg:#f8fafcb3}.container-kind-deploy_cloud{--container-border:#0284c7;--container-header-bg:#0284c7;--container-bg:#e0f2fe99}.container-kind-deploy_frame{--container-border:#0369a1;--container-header-bg:#0369a1;--container-bg:#f0f9ffb3}.container-kind-deploy_package{--container-border:#1d4ed8;--container-header-bg:#1d4ed8;--container-bg:#eff6ffb3}.container-kind-deploy_folder{--container-border:#b45309;--container-header-bg:#b45309;--container-bg:#fffbebb3}.container-kind-class_package{--container-border:#1e293b;--container-header-bg:#1e293b;--container-bg:#f1f5f9b3}.container-kind-comp_package{--container-border:#7c3aed;--container-header-bg:#7c3aed;--container-bg:#f5f3ffb3}.container-kind-comp_frame{--container-border:#92400e;--container-header-bg:#92400e;--container-bg:#fffbebb3}.container-kind-uc_rectangle{--container-border:#065f46;--container-header-bg:#065f46;--container-bg:#ecfdf5b3}.container-kind-uc_package{--container-border:#047857;--container-header-bg:#047857;--container-bg:#ecfdf5b3}.container-kind-state_composite{--container-border:#6d28d9;--container-header-bg:#6d28d9;--container-bg:#f5f3ffb3}.container-kind-activity_partition{--container-border:#166534;--container-header-bg:#166534;--container-bg:#f0fdf4b3}.diagram-element.selected>.container-box{outline:2px solid var(--color-primary);outline-offset:2px}.diagram-element.connect-source>.container-box{outline-offset:2px;outline:2px solid #f59e0b}.diagram-element.connectable:hover>.container-box{outline-offset:2px;outline:2px dashed #10b981}
