*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,sans-serif;font-size:13px;background:var(--ctp-base);color:var(--ctp-text);height:100dvh;overflow:hidden;display:flex;flex-direction:column}#titlebar{height:36px;flex-shrink:0;background:var(--ctp-crust);border-bottom:1px solid var(--ctp-surface0);display:flex;align-items:center;gap:4px;padding:0 8px 0 0;z-index:50}.titlebar-menu{position:relative;margin-left:0}.titlebar-menu--edit{margin-left:4px}.titlebar-menu-btn{height:28px;padding:0 10px;border:none;background:transparent;color:var(--ctp-subtext0);border-radius:5px;cursor:pointer;font-size:13px;transition:background .1s,color .1s}.titlebar-menu-btn:hover,.titlebar-menu-btn.open{background:var(--ctp-surface0);color:var(--ctp-text)}.titlebar-menu-btn:focus-visible{outline:2px solid var(--ctp-lavender);outline-offset:1px}.titlebar-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:var(--ctp-mantle);border:1px solid var(--ctp-surface1);border-radius:8px;box-shadow:0 6px 20px color-mix(in srgb,var(--ctp-crust) 80%,transparent);padding:4px;min-width:200px;z-index:200;display:none;flex-direction:column;gap:1px}.titlebar-dropdown.open{display:flex}.titlebar-menu-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:5px;border:none;background:transparent;color:var(--ctp-text);font-size:13px;cursor:pointer;text-align:left;white-space:nowrap}.titlebar-menu-item:hover{background:var(--ctp-surface0)}.titlebar-menu-item:focus-visible{outline:2px solid var(--ctp-lavender);outline-offset:-2px}.titlebar-menu-item:disabled{color:var(--ctp-overlay0);cursor:default;pointer-events:none}.titlebar-menu-item .menu-shortcut{margin-left:auto;font-size:11px;color:var(--ctp-overlay0)}.titlebar-menu-separator{height:1px;background:var(--ctp-surface1);margin:3px 0}.titlebar-title{flex:1;text-align:center}.titlebar-title-input{background:transparent;border:none;color:var(--ctp-subtext1);font-size:13px;font-weight:500;text-align:center;width:100%;max-width:260px;outline:none;padding:2px 6px;border-radius:4px;transition:background .1s,color .1s}.titlebar-title-input:hover{background:var(--ctp-surface0);color:var(--ctp-text)}.titlebar-title-input:focus{background:var(--ctp-surface1);color:var(--ctp-text)}.titlebar-file-indicator{font-size:11px;color:var(--ctp-green);white-space:nowrap;margin-left:8px;display:inline-flex;align-items:center;gap:4px;background:color-mix(in srgb,var(--ctp-green) 12%,transparent);padding:2px 8px;border-radius:10px}.titlebar-file-indicator.file-indicator--saving{color:var(--ctp-subtext0);background:color-mix(in srgb,var(--ctp-subtext0) 10%,transparent)}.titlebar-file-indicator.file-indicator--saved{color:var(--ctp-green);background:color-mix(in srgb,var(--ctp-green) 20%,transparent)}.titlebar-file-indicator.file-indicator--error{color:var(--ctp-red);background:color-mix(in srgb,var(--ctp-red) 15%,transparent);cursor:help}.titlebar-save-indicator{display:none}@keyframes save-spin{to{transform:rotate(360deg)}}.save-spin{animation:save-spin .7s linear infinite;transform-origin:center}.titlebar-right{margin-left:auto;display:flex;align-items:center}.ai-prompt-btn{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px;border:1px solid color-mix(in srgb,var(--ctp-lavender) 40%,transparent);background:color-mix(in srgb,var(--ctp-lavender) 10%,transparent);color:var(--ctp-lavender);border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:background .15s,color .15s,border-color .15s;white-space:nowrap}.ai-prompt-btn:hover{background:color-mix(in srgb,var(--ctp-lavender) 20%,transparent);border-color:color-mix(in srgb,var(--ctp-lavender) 70%,transparent);color:var(--ctp-text)}.ai-prompt-btn--copied{background:color-mix(in srgb,var(--ctp-green) 15%,transparent);border-color:color-mix(in srgb,var(--ctp-green) 50%,transparent);color:var(--ctp-green)}.ai-sparkle{flex-shrink:0}.titlebar-home-btn{width:56px;height:36px;flex-shrink:0;border:none;background:transparent;color:var(--ctp-subtext0);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s;margin:0;padding:0}.titlebar-home-btn:hover{background:var(--ctp-surface0);color:var(--ctp-text)}.titlebar-home-btn.active{color:var(--ctp-lavender)}#titlebar.dashboard-open>:not(.titlebar-home-btn){visibility:hidden;pointer-events:none}.dashboard{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--ctp-base);z-index:100;display:flex;flex-direction:column;align-items:center;padding:80px 24px 40px;overflow-y:auto;gap:40px}.dashboard-header{display:flex;flex-direction:column;align-items:center;gap:14px}.dashboard-title{font-size:28px;font-weight:600;color:var(--ctp-text);letter-spacing:-.5px}.dashboard-github-link{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--ctp-subtext0);text-decoration:none;opacity:.7;transition:opacity .15s,color .15s}.dashboard-github-link:hover{opacity:1;color:var(--ctp-text)}.dashboard-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.dashboard-action-card{display:flex;flex-direction:column;align-items:center;gap:10px;width:148px;padding:20px 12px 16px;border:1px solid var(--ctp-surface0);border-radius:10px;background:var(--ctp-mantle);color:var(--ctp-text);cursor:pointer;transition:border-color .15s,background .15s,transform .1s;text-align:center}.dashboard-action-card:hover{border-color:var(--ctp-lavender);background:var(--ctp-surface0);transform:translateY(-1px)}.dashboard-action-icon{color:var(--ctp-lavender);display:flex;align-items:center;justify-content:center}.dashboard-action-text{display:flex;flex-direction:column;gap:3px}.dashboard-action-label{font-size:13px;font-weight:500;color:var(--ctp-text)}.dashboard-action-sub{font-size:11px;color:var(--ctp-subtext0)}.dashboard-section{width:100%;max-width:520px;display:flex;flex-direction:column;gap:8px}.dashboard-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ctp-subtext0);padding:0 2px}.dashboard-recent-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.dashboard-empty{font-size:13px;color:var(--ctp-subtext0);padding:8px 2px}.dashboard-recent-item{display:flex;flex-direction:column;border:1px solid var(--ctp-surface1);border-radius:8px;background:var(--ctp-surface0);color:var(--ctp-text);cursor:pointer;text-align:left;overflow:hidden;transition:border-color .15s,box-shadow .15s;position:relative;padding:0}.dashboard-recent-item:hover{border-color:var(--ctp-overlay0);box-shadow:0 2px 8px #00000026}.dashboard-recent-thumb{width:100%;aspect-ratio:16 / 9;background:var(--ctp-base);display:flex;align-items:center;justify-content:center;overflow:hidden;border-bottom:1px solid var(--ctp-surface1)}.dashboard-recent-thumb-img{width:100%;height:100%;object-fit:contain;display:block}.dashboard-recent-footer{display:flex;align-items:center;gap:6px;padding:8px 10px}.dashboard-recent-name{font-size:12px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-recent-time{font-size:11px;color:var(--ctp-subtext0);white-space:nowrap;flex-shrink:0}.dashboard-recent-remove{border:none;background:transparent;color:var(--ctp-subtext0);cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center;opacity:0;transition:opacity .1s,color .1s;flex-shrink:0}.dashboard-recent-item:hover .dashboard-recent-remove{opacity:1}.dashboard-recent-remove:hover{color:var(--ctp-red)}#app{display:flex;flex:1;min-height:0;position:relative}#toolbar{width:56px;background:var(--ctp-mantle);border-right:1px solid var(--ctp-surface0);display:flex;flex-direction:column;align-items:stretch;padding:8px 0;gap:0;z-index:10;flex-shrink:0;overflow-y:auto;overflow-x:hidden}#canvas-container{flex:1;position:relative;overflow:hidden;background:var(--ctp-base);background-image:radial-gradient(circle,var(--ctp-surface0) 1px,transparent 1px);background-size:50px 50px}#canvas-container.pan-mode,#canvas-container.pan-mode *{cursor:grab!important}#canvas-container.pan-grabbing,#canvas-container.pan-grabbing *{cursor:grabbing!important}#canvas{position:absolute;top:0;left:0;width:100%;height:100%;overflow:visible;cursor:default;-webkit-user-select:none;user-select:none}#popover-layer{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:100}#popover-layer>*{pointer-events:all}.tool-btn{width:36px;height:36px;border:none;background:transparent;color:var(--ctp-subtext0);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s;flex-shrink:0}.tool-btn:hover{background:var(--ctp-surface0);color:var(--ctp-text)}.tool-btn.active{background:var(--ctp-surface1);color:var(--ctp-lavender)}.tool-btn:focus-visible{outline:2px solid var(--ctp-lavender);outline-offset:1px}.tool-btn svg{width:18px;height:18px}.tool-group{display:flex;flex-direction:column}.tool-group-header{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;width:100%;height:28px;border:none;background:transparent;color:var(--ctp-overlay0);cursor:pointer;padding:0 4px;transition:background .1s,color .1s}.tool-group-header:hover{background:var(--ctp-surface0);color:var(--ctp-text)}.tool-group-label{font-size:9px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;line-height:1}.tool-group-chevron{transition:transform .15s;transform:rotate(-90deg)}.tool-group.open .tool-group-chevron{transform:rotate(0)}.tool-group-body{display:none;flex-direction:column;align-items:center;padding:2px 0 4px;gap:2px}.tool-group.open .tool-group-body{display:flex}.toolbar-divider{width:28px;height:1px;background:var(--ctp-surface0);margin:4px auto}.uml-class{cursor:move}.uml-class .class-header{fill:var(--ctp-surface1)}.uml-class .class-body{fill:var(--ctp-surface0)}.uml-class .class-border{fill:none;stroke:var(--ctp-overlay0);stroke-width:1.5}.uml-class .class-title{fill:var(--ctp-text);font-weight:600;font-size:13px;dominant-baseline:middle;text-anchor:middle}.uml-class .class-stereotype{fill:var(--ctp-mauve);font-size:10px;dominant-baseline:middle;text-anchor:middle}.uml-class .member-text{fill:var(--ctp-subtext1);font-size:12px;font-family:JetBrains Mono,Fira Code,monospace;cursor:text}.uml-class .section-label{fill:var(--ctp-overlay0);font-size:10px;font-style:italic;text-transform:uppercase;letter-spacing:.04em}.uml-class .add-member-btn{fill:var(--ctp-overlay0);font-size:11px;cursor:pointer;opacity:0;transition:opacity .15s}.uml-class:hover .add-member-btn{opacity:1}.uml-class .add-member-btn:hover{fill:var(--ctp-lavender)}.uml-class .divider{stroke:var(--ctp-surface2);stroke-width:1}.uml-class.selected .class-border{stroke:var(--ctp-lavender);stroke-width:2}.uml-package{cursor:move}.uml-package .pkg-bg{fill:var(--ctp-mantle);stroke:var(--ctp-overlay0);stroke-width:1.5;stroke-dasharray:6 3}.uml-package .pkg-tab{fill:var(--ctp-surface0);stroke:var(--ctp-overlay0);stroke-width:1.5}.uml-package .pkg-name{fill:var(--ctp-subtext0);font-size:11px;dominant-baseline:middle}.uml-package.selected .pkg-bg{stroke:var(--ctp-lavender);stroke-width:2}.port{fill:var(--ctp-base);stroke:var(--ctp-lavender);stroke-width:1.5;cursor:crosshair;opacity:0;transition:opacity .1s}.port.visible,.uml-class:hover .port,.uml-package:hover .port,.uml-storage:hover .port,.uml-actor:hover .port,.uml-queue:hover .port,.uml-usecase:hover .port{opacity:1}.connection{cursor:pointer}.connection .conn-line{fill:none;stroke:var(--ctp-overlay1);stroke-width:1.5}.connection.selected .conn-line{stroke:var(--ctp-lavender)}.connection .conn-label{fill:var(--ctp-subtext0);font-size:11px;text-anchor:middle;filter:url(#label-backdrop)}.connection .multiplicity{fill:var(--ctp-subtext0);font-size:11px;filter:url(#label-backdrop)}.resize-handle{fill:transparent;cursor:nwse-resize}.inline-input{background:var(--ctp-surface1);color:var(--ctp-text);border:1px solid var(--ctp-lavender);border-radius:3px;padding:1px 4px;font-size:13px;outline:none;width:100%}.popover{position:fixed;background:var(--ctp-mantle);border:1px solid var(--ctp-surface1);border-radius:8px;padding:8px 10px;box-shadow:0 4px 16px color-mix(in srgb,var(--ctp-crust) 80%,transparent);display:flex;flex-direction:column;gap:6px;min-width:180px;transform:translate(-50%,-110%);transition:opacity .12s}.popover select,.popover input{background:var(--ctp-surface0);color:var(--ctp-text);border:1px solid var(--ctp-surface2);border-radius:4px;padding:3px 6px;font-size:12px;width:100%;outline:none}.popover select:focus,.popover input:focus{border-color:var(--ctp-lavender)}.popover-row{display:flex;gap:8px;align-items:center}.popover-row label{font-size:11px;color:var(--ctp-subtext0);flex-shrink:0;min-width:46px}.theme-picker{margin-top:auto;display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 4px;border-top:1px solid var(--ctp-surface2)}.theme-dot{width:20px;height:20px;border-radius:50%;border:2px solid var(--ctp-overlay0);cursor:pointer}.theme-dot[data-active=true],.theme-dot[data-theme=print][data-active=true]{border-color:var(--ctp-lavender)}.uml-storage{cursor:move}.uml-storage .storage-bg{fill:var(--ctp-surface0);stroke:var(--ctp-teal);stroke-width:1.5}.uml-storage .storage-name{fill:var(--ctp-text);font-size:13px;font-weight:500;dominant-baseline:middle;text-anchor:middle}.uml-storage.selected .storage-bg{stroke:var(--ctp-lavender);stroke-width:2}.uml-class:hover,.uml-package:hover,.uml-storage:hover,.uml-actor:hover,.uml-queue:hover,.uml-usecase:hover,.sd-state:hover,.sd-start-state:hover,.sd-end-state:hover,.seq-lifeline:hover,.seq-diagram:hover{opacity:.9}.ghost-line{fill:none;stroke:var(--ctp-lavender);stroke-width:1.5;stroke-dasharray:5 3;pointer-events:none}.storage-shadow-shape{fill:var(--ctp-surface0);stroke:var(--ctp-teal);stroke-width:1.5;opacity:.5}.class-shadow-shape{fill:var(--ctp-surface1);stroke:var(--ctp-overlay0);stroke-width:1.5;opacity:.5}.uml-actor{cursor:move}.uml-actor .actor-bg{fill:var(--ctp-surface0);stroke:var(--ctp-mauve);stroke-width:1.5}.uml-actor .actor-name{fill:var(--ctp-text);font-size:12px;font-weight:500;dominant-baseline:middle;text-anchor:middle}.uml-actor .actor-figure{fill:none;stroke:var(--ctp-mauve);stroke-width:1.5;stroke-linecap:round}.uml-actor .actor-figure[r]{fill:var(--ctp-surface0)}.uml-actor.selected .actor-bg{stroke:var(--ctp-lavender);stroke-width:2}.actor-shadow-shape{fill:var(--ctp-surface0);stroke:var(--ctp-mauve);stroke-width:1.5;opacity:.4}.uml-queue{cursor:move}.uml-queue .queue-bg{fill:var(--ctp-surface0);stroke:var(--ctp-sapphire);stroke-width:1.5}.uml-queue .queue-name{fill:var(--ctp-text);font-size:12px;font-weight:500;dominant-baseline:middle;text-anchor:middle}.uml-queue .queue-flow-arrow{fill:none;stroke:var(--ctp-sapphire);stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;opacity:.7}.uml-queue.selected .queue-bg{stroke:var(--ctp-lavender);stroke-width:2}.queue-shadow-shape{fill:var(--ctp-surface0);stroke:var(--ctp-sapphire);stroke-width:1.5;opacity:.4}.uml-usecase:hover .port{opacity:1}.uml-usecase{cursor:move}.uml-usecase .usecase-bg{fill:var(--ctp-base);stroke:var(--ctp-overlay2);stroke-width:1.5}.uml-usecase .usecase-name{fill:var(--ctp-text);font-size:13px;dominant-baseline:central;text-anchor:middle;pointer-events:none}.uml-usecase.selected .usecase-bg{stroke:var(--ctp-lavender);stroke-width:2}.seq-fragment-cond{fill:var(--ctp-subtext0);font-size:11px}.conn-channel-symbol .channel-circle{fill:var(--ctp-base);stroke:var(--ctp-mauve);stroke-width:1.5}.conn-channel-symbol .channel-r{fill:var(--ctp-mauve);font-size:10px;font-weight:700}.conn-channel-symbol .channel-arrow{fill:none;stroke:var(--ctp-mauve);stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}.snap-guide{stroke:var(--ctp-lavender);stroke-width:1;stroke-dasharray:4 3;opacity:.7;pointer-events:none}.rubber-band{fill:color-mix(in srgb,var(--ctp-lavender) 12%,transparent);stroke:var(--ctp-lavender);stroke-width:1;stroke-dasharray:4 3;pointer-events:none}#zoom-ctrl{position:absolute;bottom:16px;left:16px;display:flex;align-items:center;gap:2px;background:var(--ctp-mantle);border:1px solid var(--ctp-surface1);border-radius:8px;padding:3px 6px;box-shadow:0 2px 8px color-mix(in srgb,var(--ctp-crust) 70%,transparent);z-index:20;-webkit-user-select:none;user-select:none}.zoom-btn{width:24px;height:24px;border:none;background:transparent;color:var(--ctp-subtext0);border-radius:5px;cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s;padding:0}.zoom-btn:hover{background:var(--ctp-surface0);color:var(--ctp-text)}.zoom-reset{font-size:14px;margin-left:2px}.zoom-label{font-size:12px;color:var(--ctp-subtext1);min-width:38px;text-align:center;font-variant-numeric:tabular-nums}.conn-popover{min-width:unset;padding:6px 8px;gap:4px}.popover-section-label{font-size:9px;text-transform:uppercase;letter-spacing:.5px;color:var(--ctp-overlay0);margin-top:2px}.popover-section-separator{border:none;border-top:1px solid var(--ctp-surface1);margin:2px 0}.conn-type-row{display:flex;gap:3px;align-items:center}.conn-type-btn{width:32px;height:28px;border:1px solid var(--ctp-surface2);border-radius:6px;background:var(--ctp-surface0);color:var(--ctp-subtext1);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s,border-color .1s;padding:0}.conn-type-btn--text{width:auto;padding:0 8px;font-size:11px}.conn-type-btn svg{display:block}.conn-type-btn:hover{background:var(--ctp-surface1);color:var(--ctp-text)}.conn-type-btn.active{background:var(--ctp-surface2);color:var(--ctp-lavender);border-color:var(--ctp-lavender)}.conn-flip-btn{width:28px;height:28px;border:1px solid var(--ctp-surface2);border-radius:6px;background:transparent;color:var(--ctp-subtext0);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s;padding:0;margin-left:4px}.conn-flip-btn:hover{background:var(--ctp-surface0);color:var(--ctp-text)}.conn-mult-row{display:flex;align-items:center;gap:4px;margin-top:2px}.conn-mult-sel{background:var(--ctp-surface0);color:var(--ctp-text);border:1px solid var(--ctp-surface2);border-radius:4px;padding:2px 4px;font-size:12px;flex:1;outline:none}.conn-mult-sel:focus{border-color:var(--ctp-lavender)}.conn-mult-sep{color:var(--ctp-overlay0);font-size:11px}.conn-routing-grid{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:2px 6px}.conn-routing-side-label{font-size:11px;color:var(--ctp-subtext0);white-space:nowrap}.conn-elbow-row{display:flex;align-items:center;gap:2px;margin-top:2px}.conn-elbow-btn{width:32px;height:28px;border:1px solid var(--ctp-surface2);border-radius:6px;background:var(--ctp-surface0);color:var(--ctp-subtext0);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex:1;transition:background .1s,color .1s,border-color .1s}.conn-elbow-btn:hover{background:var(--ctp-surface1);color:var(--ctp-text)}.conn-elbow-btn.active{background:var(--ctp-surface2);color:var(--ctp-lavender);border-color:var(--ctp-lavender)}.elem-props-panel{transform:translateY(-50%);min-width:220px;transition:opacity .12s}.elem-props-panel .props-label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ctp-text);cursor:pointer;min-width:unset}.elem-props-panel .props-label input[type=checkbox]{width:auto;accent-color:var(--ctp-lavender);cursor:pointer}.accent-row{flex-direction:column;align-items:flex-start;gap:5px}.accent-label{font-size:11px;color:var(--ctp-subtext0)}.accent-swatches{display:flex;gap:4px;flex-wrap:nowrap}.accent-swatch{width:18px;height:18px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;outline:none;transition:border-color .1s,transform .1s}.accent-swatch:hover{transform:scale(1.15)}.accent-swatch--active{border-color:var(--ctp-text)}.accent-swatch--clear{background:transparent!important;border-color:var(--ctp-overlay0);color:var(--ctp-overlay0);font-size:12px;line-height:14px;text-align:center}.accent-swatch--clear.accent-swatch--active{border-color:var(--ctp-text);color:var(--ctp-text)}.sd-state:hover .port,.sd-start-state:hover .port,.sd-end-state:hover .port{opacity:1}.sd-state{cursor:move}.sd-state-bg{fill:var(--ctp-surface0);stroke:var(--ctp-overlay1);stroke-width:1.5}.sd-state-name{fill:var(--ctp-text);font-size:13px;pointer-events:none}.sd-state.selected .sd-state-bg{stroke:var(--ctp-lavender);stroke-width:2}.sd-start-state{cursor:move}.sd-start-circle{fill:var(--ctp-text)}.sd-start-state.selected .sd-start-circle{fill:var(--ctp-lavender)}.sd-end-state{cursor:move}.sd-end-outer{fill:none;stroke:var(--ctp-text);stroke-width:2}.sd-end-inner{fill:var(--ctp-text)}.sd-end-state.selected .sd-end-outer{stroke:var(--ctp-lavender)}.sd-end-state.selected .sd-end-inner{fill:var(--ctp-lavender)}.seq-lifeline{cursor:move;pointer-events:bounding-box}.seq-header-bg{fill:var(--ctp-surface0);stroke:var(--ctp-overlay1);stroke-width:1.5;cursor:grab}.seq-header-bg:active{cursor:grabbing}.seq-header-name{fill:var(--ctp-text);font-size:13px;text-anchor:middle;pointer-events:none}.seq-spine{stroke:var(--ctp-overlay1);stroke-dasharray:6 4;stroke-width:1.5;pointer-events:none}.seq-msg-arrow{stroke:var(--ctp-text);stroke-width:1.5;fill:none}.seq-msg-arrow-head{stroke:var(--ctp-text);stroke-width:1.5;fill:var(--ctp-text)}.seq-msg-row:has(.seq-msg-arrow[stroke-dasharray]) .seq-msg-arrow-head{fill:none}.seq-msg-label{fill:var(--ctp-subtext0);font-size:11px}.add-msg-btn{fill:var(--ctp-green);font-size:11px;cursor:pointer;opacity:0;transition:opacity .1s}.seq-lifeline:hover .add-msg-btn{opacity:1}.seq-lifeline.selected .seq-header-bg{stroke:var(--ctp-lavender);stroke-width:2}.seq-msg-row{cursor:pointer}.seq-msg-row:hover .seq-msg-label{fill:var(--ctp-text)}.seq-active-area{fill:var(--ctp-surface1);stroke:var(--ctp-overlay1);stroke-width:1}.pkg-bg-dashed{stroke-dasharray:6 3}.seq-conn-arrow{stroke:var(--ctp-text);stroke-width:1.5;fill:none}.seq-conn-arrow-head{stroke:var(--ctp-text);stroke-width:1.5;fill:var(--ctp-text)}.seq-conn-arrow-head.open{fill:none}.seq-conn-group{cursor:pointer}.seq-conn-group:hover .seq-conn-arrow{stroke:var(--ctp-lavender)}.seq-conn-group:hover .seq-conn-arrow-head{stroke:var(--ctp-lavender);fill:var(--ctp-lavender)}.seq-conn-group.seq-conn-selected .seq-conn-arrow{stroke:var(--ctp-blue)}.seq-conn-group.seq-conn-selected .seq-conn-arrow-head{stroke:var(--ctp-blue);fill:var(--ctp-blue)}.seq-conn-group:hover .seq-conn-arrow-head.open,.seq-conn-group.seq-conn-selected .seq-conn-arrow-head.open{fill:none}.seq-drop-slot{stroke:var(--ctp-lavender);stroke-width:2.5;stroke-linecap:round;pointer-events:none}.seq-slot-indicator{stroke:var(--ctp-lavender);stroke-width:2;stroke-linecap:round;opacity:.7}.seq-bar-port{fill:var(--ctp-surface0);stroke:var(--ctp-lavender);stroke-width:1.5;opacity:0;transition:opacity .1s}.seq-lifeline:hover .seq-bar-port,.seq-lifeline.selected .seq-bar-port{opacity:1}.seq-insert-slot{fill:var(--ctp-surface0);stroke:var(--ctp-lavender);stroke-width:1.5;opacity:0;pointer-events:all;transition:opacity .1s}.seq-insert-slot.seq-insert-slot-empty{opacity:.7}.seq-lifeline:hover .seq-insert-slot{opacity:.6}.seq-insert-slot:hover{opacity:1!important}.seq-conn-label{fill:var(--ctp-subtext0);font-size:11px;font-family:inherit;cursor:text;-webkit-user-select:none;user-select:none;filter:url(#label-backdrop)}.seq-conn-group:hover .seq-conn-label{fill:var(--ctp-lavender)}.seq-conn-group.seq-conn-selected .seq-conn-label{fill:var(--ctp-blue)}.seq-diagram-bg{fill:transparent;pointer-events:all}.seq-diagram.selected .seq-diagram-bg{stroke:var(--ctp-lavender);stroke-width:2;stroke-dasharray:4 3}.lifeline-add-btn{position:fixed;z-index:1000;width:22px;height:22px;border-radius:50%;background:var(--ctp-surface1);border:1px solid var(--ctp-lavender);color:var(--ctp-lavender);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;line-height:1;padding:0}.lifeline-add-btn:hover{background:var(--ctp-lavender);color:var(--ctp-base)}.comment{cursor:move}.comment-bg{fill:color-mix(in srgb,var(--ctp-yellow) 12%,var(--ctp-base));stroke:color-mix(in srgb,var(--ctp-yellow) 50%,transparent);stroke-width:1.5}.comment.selected .comment-bg{stroke:var(--ctp-lavender);stroke-width:2}.comment-dogear{fill:color-mix(in srgb,var(--ctp-yellow) 30%,var(--ctp-base))}.comment-dogear-fold{stroke:color-mix(in srgb,var(--ctp-yellow) 50%,transparent);stroke-width:1}.comment-pin-line{stroke:var(--ctp-overlay1);stroke-width:1;stroke-dasharray:4 3;pointer-events:none}.comment-fo{overflow:visible}.comment-text{font-size:12px;color:var(--ctp-text);white-space:pre-wrap;word-break:break-word;padding:6px 8px;box-sizing:border-box;width:100%;height:100%}.comment-textarea{font-size:12px;color:var(--ctp-text);background:var(--ctp-surface1);border:1px solid var(--ctp-lavender);border-radius:3px;padding:6px 8px;box-sizing:border-box;width:100%;height:100%;resize:none;outline:none;font-family:inherit}.menu-checkmark{display:inline-block;width:14px;font-size:11px;color:var(--ctp-green)}.minimap-container{position:fixed;bottom:16px;right:16px;z-index:90;border-radius:8px;overflow:hidden;box-shadow:0 4px 16px color-mix(in srgb,var(--ctp-crust) 70%,transparent);border:1px solid var(--ctp-surface1);cursor:crosshair;-webkit-user-select:none;user-select:none}.minimap-svg{display:block}.minimap-bg{fill:var(--ctp-mantle)}.minimap-el-rect{opacity:.75}.minimap-conn-line{stroke:var(--ctp-overlay2);stroke-width:.5;fill:none}.minimap-viewport{fill:color-mix(in srgb,var(--ctp-blue) 12%,transparent);stroke:var(--ctp-blue);stroke-width:1.5;rx:2;pointer-events:none}.search-panel{position:fixed;top:64px;left:50%;transform:translate(-50%);width:360px;max-width:calc(100vw - 32px);background:var(--ctp-mantle);border:1px solid var(--ctp-surface1);border-radius:10px;box-shadow:0 8px 32px color-mix(in srgb,var(--ctp-crust) 80%,transparent);display:flex;flex-direction:column;overflow:hidden;z-index:200}.search-panel-input-wrap{padding:10px 12px;border-bottom:1px solid transparent}.search-panel--has-results .search-panel-input-wrap{border-bottom-color:var(--ctp-surface1)}.search-panel-input{width:100%;background:var(--ctp-surface0);color:var(--ctp-text);border:1px solid var(--ctp-surface2);border-radius:6px;padding:7px 10px;font-size:13px;outline:none;box-sizing:border-box}.search-panel-input:focus{border-color:var(--ctp-lavender)}.search-panel-list{max-height:320px;overflow-y:auto;padding:4px 0}.search-result-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:7px 12px;background:transparent;border:none;border-radius:0;color:var(--ctp-text);font-size:13px;cursor:pointer;text-align:left;gap:8px}.search-result-row:hover,.search-result-row.highlighted{background:var(--ctp-surface0)}.search-result-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-kind{flex-shrink:0;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--ctp-overlay0);background:var(--ctp-surface1);border-radius:4px;padding:2px 5px}.alignment-toolbar{position:fixed;top:44px;left:50%;transform:translate(-50%);z-index:110;background:var(--ctp-mantle);border:1px solid var(--ctp-surface1);border-radius:8px;padding:4px 6px;box-shadow:0 4px 16px color-mix(in srgb,var(--ctp-crust) 80%,transparent);display:flex;align-items:center;gap:2px;pointer-events:all}.align-btn-group{display:flex;align-items:center;gap:2px}.align-sep{width:1px;height:20px;background:var(--ctp-surface1);margin:0 4px;flex-shrink:0}.align-btn{width:28px;height:28px;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--ctp-subtext1);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .1s,color .1s,border-color .1s}.align-btn:hover{background:var(--ctp-surface0);color:var(--ctp-text);border-color:var(--ctp-surface2)}.align-btn:focus-visible{outline:2px solid var(--ctp-lavender);outline-offset:1px}.align-btn--disabled,.align-btn:disabled{opacity:.35;cursor:default;pointer-events:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .15s}.modal-overlay.open{opacity:1;pointer-events:all}.modal-dialog{background:var(--ctp-base);border:1px solid var(--ctp-surface1);border-radius:10px;box-shadow:0 8px 32px color-mix(in srgb,var(--ctp-crust) 80%,transparent);max-width:560px;width:calc(100% - 32px);max-height:calc(100dvh - 64px);display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:1px solid var(--ctp-surface1);flex-shrink:0}.modal-title{font-size:14px;font-weight:600;color:var(--ctp-text)}.modal-close{width:28px;height:28px;border:none;background:transparent;color:var(--ctp-subtext0);border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s}.modal-close:hover{background:var(--ctp-surface0);color:var(--ctp-text)}.modal-close:focus-visible{outline:2px solid var(--ctp-lavender);outline-offset:1px}.modal-body{overflow-y:auto;padding:12px 16px 16px}.help-modal-body{display:grid;grid-template-columns:1fr 1fr;gap:20px 24px}.help-modal-section{display:flex;flex-direction:column;gap:4px}.help-modal-section-title{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ctp-subtext1);margin-bottom:6px}.help-modal-row{display:flex;align-items:baseline;gap:8px;min-height:22px}.help-modal-key{flex-shrink:0;font-family:SF Mono,ui-monospace,Cascadia Code,monospace;font-size:11px;color:var(--ctp-text);background:var(--ctp-surface1);border:1px solid var(--ctp-surface2);border-radius:4px;padding:1px 5px;white-space:nowrap;min-width:24px;text-align:center;line-height:1.6}.help-modal-action{font-size:12px;color:var(--ctp-subtext0);line-height:1.5}.bulk-elem-panel{transform:translate(-100%);min-width:180px;transition:opacity .12s}.bulk-elem-panel .props-label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ctp-text);cursor:pointer;min-width:unset}.bulk-elem-panel .props-label input[type=checkbox]{width:auto;accent-color:var(--ctp-lavender);cursor:pointer}.bulk-conn-panel{transform:translate(-100%);min-width:unset}.has-accent .class-title,.has-accent .class-stereotype,.has-accent .pkg-name,.has-accent .storage-name,.has-accent .actor-name,.has-accent .queue-name,.has-accent .usecase-name,.has-accent .sd-state-name,.has-accent .seq-header-name{fill:var(--ctp-base)!important}.has-accent .actor-figure{stroke:var(--ctp-base)!important}.has-accent .actor-figure[r]{fill:var(--ctp-base)!important}.has-accent .queue-flow-arrow{stroke:var(--ctp-base)!important}
