*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #ffffff;--surface: #f5f5f5;--border: #d0d0d0;--text: #1a1a1a;--text-muted: #595959;--accent: #4f3ebf;--accent-hover: #3f31a0;--error-bg: #fff0f0;--error-text: #b00;--toolbar-h: 44px;--panel-w: 300px;--radius: 4px}[data-dark]{--bg: #1a1a1a;--surface: #252525;--border: #3a3a3a;--text: #e8e8e8;--text-muted: #b3b3b3;--error-bg: #2a1010;--error-text: #ff8a8a}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;background:var(--bg);color:var(--text);overflow:hidden;height:100vh}#app{height:100vh;display:flex;flex-direction:column}#mermaid-app{display:flex;flex-direction:column;height:100vh;position:relative}.toolbar{display:flex;align-items:center;justify-content:space-between;min-height:var(--toolbar-h);padding:4px 8px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;gap:4px 8px;flex-wrap:wrap}.toolbar-left,.toolbar-center,.toolbar-right{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.toolbar-title{font-weight:600;font-size:14px;white-space:nowrap}.toolbar button,.toolbar select{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:12px;cursor:pointer;white-space:nowrap}.toolbar button:hover{border-color:var(--accent)}.toolbar button svg{display:inline-block;vertical-align:-2px}.toolbar-sep{width:1px;height:20px;background:var(--border);flex-shrink:0;margin:0 2px}.toolbar select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.btn-label{display:none}[data-btn-style=icon-text] .btn-label,[data-btn-style=text] .btn-label{display:inline}[data-btn-style=text] .toolbar button>svg{display:none}[data-btn-style=text] .toolbar .btn-chevron svg{display:inline-block;vertical-align:-2px}[data-btn-style=text] .docs-link>svg{display:none}[data-btn-style=icon-text] .docs-link,[data-btn-style=text] .docs-link{width:auto;padding:4px 8px;gap:4px}[data-btn-style=icon-text] .toolbar-sep,[data-btn-style=text] .toolbar-sep{display:none}.workspace{flex:1;overflow:hidden;min-height:0}.layout-split-h{display:grid;grid-template-columns:calc(var(--split-ratio, .5) * (100% - 6px)) 6px calc((1 - var(--split-ratio, .5)) * (100% - 6px))}.layout-split-v{display:grid;grid-template-rows:calc(var(--split-ratio, .5) * (100% - 6px)) 6px calc((1 - var(--split-ratio, .5)) * (100% - 6px))}.splitter{background:var(--border);position:relative;z-index:2;transition:background .15s}.splitter:hover,.splitter:active{background:var(--accent)}.splitter-horizontal{cursor:col-resize}.splitter-vertical{cursor:row-resize}.splitter-horizontal:before{content:"";position:absolute;top:0;bottom:0;left:-4px;right:-4px}.splitter-vertical:before{content:"";position:absolute;left:0;right:0;top:-4px;bottom:-4px}.layout-editor-only,.layout-preview-only{display:flex}.layout-editor-only .preview-host{display:none}.layout-editor-only .editor-host{flex:1;min-width:0;min-height:0}.layout-preview-only .editor-host{display:none}.layout-preview-only .preview-host{flex:1;min-width:0;min-height:0}.editor-host{overflow:auto}.layout-split-h .editor-host,.layout-split-v .editor-host{border:none}.editor-host .cm-editor{height:100%}.editor-host .cm-scroller{overflow:auto}.preview-host{overflow:hidden;background:var(--bg);position:relative}.preview-host:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.preview-svg-wrap svg{max-width:none}.zoom-controls{position:absolute;bottom:8px;left:8px;display:flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:4px;z-index:5;opacity:.9}.zoom-controls:hover{opacity:1}.zoom-controls button{padding:3px 6px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:12px;cursor:pointer;line-height:1;display:inline-flex;align-items:center;justify-content:center}.zoom-controls button:hover{border-color:var(--accent)}.zoom-level{font-size:11px;min-width:36px;text-align:center;color:var(--text-muted)}.minimap{position:absolute;bottom:8px;right:8px;width:150px;height:100px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;z-index:5;opacity:.85}.minimap:hover{opacity:1}.minimap-img{pointer-events:none}.minimap-viewport{position:absolute;border:2px solid var(--accent);background:#5c4acd1a;pointer-events:none;border-radius:1px}.preview-svg-wrap .node:hover,.preview-svg-wrap .cluster:hover{filter:brightness(1.1);transition:filter .15s}.preview-error{padding:16px;background:var(--error-bg);border-radius:var(--radius);color:var(--error-text)}.preview-error pre{margin-top:8px;font-size:12px;white-space:pre-wrap;word-break:break-word}.template-panel{position:absolute;top:var(--toolbar-h);right:0;bottom:0;width:var(--panel-w);background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:10;box-shadow:-2px 0 8px #0000001a}.template-panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border)}.template-panel-header h3{font-size:14px;font-weight:600}.template-panel-actions{padding:8px 12px;display:flex;flex-direction:column;gap:6px;border-bottom:1px solid var(--border)}.template-filter{width:100%;padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:12px}.template-btns{display:flex;gap:4px}.template-btns button,.template-btns .btn-file{flex:1;padding:4px 6px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:11px;cursor:pointer;text-align:center}.template-btns button:hover,.template-btns .btn-file:hover{border-color:var(--accent)}.template-save-form{padding:8px 12px;display:flex;flex-direction:column;gap:4px;border-bottom:1px solid var(--border)}.template-save-form input{width:100%;padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:12px}.template-save-btns{display:flex;gap:4px}.template-save-btns button{flex:1;padding:4px 6px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:11px;cursor:pointer}.template-list{flex:1;overflow-y:auto;padding:4px 0}.template-empty{padding:16px 12px;color:var(--text-muted);font-size:12px;text-align:center}.template-item{display:flex;align-items:center;padding:6px 12px;cursor:pointer;border-bottom:1px solid var(--border)}.template-item:hover{background:var(--bg)}.template-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.template-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-type{font-size:11px;color:var(--text-muted)}.template-tags{display:flex;flex-wrap:wrap;gap:2px}.tag{font-size:10px;padding:1px 4px;border-radius:2px;background:var(--border);color:var(--text-muted)}.template-actions{display:flex;gap:2px;flex-shrink:0}.template-actions button{padding:2px 6px;border:1px solid transparent;border-radius:var(--radius);background:none;color:var(--text-muted);font-size:11px;cursor:pointer}.template-actions button:hover{border-color:var(--border);color:var(--text)}.btn-danger:hover{color:var(--error-text)!important;border-color:var(--error-text)!important}.btn-icon{background:none!important;border:none!important;font-size:18px;cursor:pointer;color:var(--text);padding:0 4px!important}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:50;animation:modal-fade .15s ease-out}.modal{background:var(--bg);border:1px solid var(--border);border-radius:6px;max-width:560px;width:calc(100vw - 32px);max-height:calc(100vh - 32px);display:flex;flex-direction:column;box-shadow:0 10px 32px #0000004d}.modal-wide{max-width:900px}.modal-subheader{font-size:11px;color:var(--text-muted);margin-top:2px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--border)}.modal-footer button{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:13px;cursor:pointer}.modal-footer button:hover:not(:disabled){border-color:var(--accent)}.modal-footer button:disabled{opacity:.5;cursor:not-allowed}.modal-footer .btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.modal-footer .btn-primary:hover:not(:disabled){background:var(--accent-hover)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:15px;font-weight:600}.modal-body{padding:12px 16px 16px;overflow-y:auto}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.shortcuts{width:100%;border-collapse:collapse;font-size:13px}.shortcuts td{padding:4px 8px;vertical-align:top}.shortcuts td:first-child{white-space:nowrap;width:1%;color:var(--text-muted)}.shortcuts-section{padding-top:12px!important;font-weight:600;color:var(--text)!important;border-bottom:1px solid var(--border)}.shortcuts-tip{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);color:var(--text-muted);font-size:12px}.shortcuts-tip code{background:var(--surface);padding:1px 4px;border-radius:2px;font-size:11px}kbd{display:inline-block;padding:1px 6px;font-family:inherit;font-size:11px;line-height:1.4;color:var(--text);background:var(--surface);border:1px solid var(--border);border-bottom-width:2px;border-radius:3px;white-space:nowrap}.history-panel{position:absolute;top:var(--toolbar-h);right:0;bottom:0;width:var(--panel-w);background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:10;box-shadow:-2px 0 8px #0000001a}.diff-body{padding:0;max-height:70vh}.diff-pane{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;line-height:1.5;margin:0;padding:8px 0;white-space:pre;overflow-x:auto}.diff-line{display:flex;padding:0 12px}.diff-line.diff-added{background:#2ecc711f}.diff-line.diff-removed{background:#e74c3c1f}[data-dark] .diff-line.diff-added{background:#2ecc712e}[data-dark] .diff-line.diff-removed{background:#e74c3c33}.diff-marker{flex-shrink:0;width:16px;text-align:center;-webkit-user-select:none;user-select:none;color:var(--text-muted);font-weight:600}.diff-added .diff-marker{color:#27ae60}.diff-removed .diff-marker{color:#c0392b}.diff-content{flex:1;white-space:pre-wrap;word-break:break-word}.diff-stat{font-weight:600}.diff-stat.added{color:#27ae60}.diff-stat.removed{color:#c0392b}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:8px 16px;font-size:13px;color:var(--text);box-shadow:0 4px 12px #00000026;z-index:100;animation:toast-in .18s ease-out}.toast-error{border-color:var(--error-text);color:var(--error-text)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.document-tabs{display:flex;align-items:stretch;gap:2px;background:var(--surface);border-bottom:1px solid var(--border);padding:0 4px;flex-shrink:0;overflow-x:auto;height:32px}.doc-tab-group{display:inline-flex;align-items:stretch;position:relative;top:1px}.doc-tab{display:flex;align-items:center;gap:6px;padding:4px 4px 4px 10px;border:1px solid transparent;border-right:none;border-bottom:none;border-top-left-radius:4px;background:transparent;color:var(--text-muted);cursor:pointer;font-size:12px;white-space:nowrap;font-family:inherit}.doc-tab-group:has(.doc-tab.active) .doc-tab-close,.doc-tab.active+.doc-tab-close{background:var(--bg);border-color:var(--border);border-bottom-color:var(--bg)}.doc-tab-group .doc-tab-close{border:1px solid transparent;border-left:none;border-bottom:none;padding:0 6px;border-top-right-radius:4px;align-self:stretch;display:inline-flex;align-items:center;cursor:pointer;background:transparent;color:var(--text-muted);font-size:14px;line-height:1}.doc-tab-group .doc-tab-close:hover{color:var(--text)}.doc-tab:hover{background:var(--bg);color:var(--text)}.doc-tab.active{background:var(--bg);border-color:var(--border);color:var(--text);border-top-right-radius:0}.doc-tab[aria-current=page]{font-weight:600}.doc-tab-name{max-width:160px;overflow:hidden;text-overflow:ellipsis}.doc-tab-input{background:var(--bg);color:var(--text);border:1px solid var(--accent);border-radius:2px;padding:1px 4px;font-size:12px;width:140px}.doc-tab-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;line-height:1;padding:0 2px;border-radius:2px}.doc-tab-close:hover{background:var(--border);color:var(--text)}.doc-tab-new{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:0 8px;margin-left:4px}.doc-tab-new:hover{color:var(--accent)}.editor-pane{display:flex;flex-direction:column;overflow:hidden;min-width:0;min-height:0}.editor-tabs{display:flex;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;height:28px;align-items:stretch}.editor-tab{background:transparent;border:none;border-right:1px solid var(--border);padding:0 14px;font-size:12px;color:var(--text-muted);cursor:pointer}.editor-tab:hover{color:var(--text)}.editor-tab.active{color:var(--text);background:var(--bg);font-weight:600}.editor-tab-body{flex:1;min-height:0;overflow:hidden;display:flex}.editor-tab-body .editor-host{flex:1;min-width:0;min-height:0}.config-scroll{flex:1;overflow-y:auto;padding:12px 16px;background:var(--bg)}.layout-split-h .editor-pane,.layout-split-v .editor-pane{border:none}.layout-editor-only .editor-pane{flex:1;min-width:0;min-height:0;display:flex}.layout-preview-only .editor-pane{display:none}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;right:0;top:calc(100% + 2px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 12px #0000002e;z-index:30;min-width:140px;display:flex;flex-direction:column}.dropdown-menu button{background:transparent;border:none;text-align:left;padding:6px 12px;font-size:12px;color:var(--text);cursor:pointer}.dropdown-menu button:hover{background:var(--bg)}.form-row{display:flex;align-items:center;gap:12px;margin:8px 0}.form-row>label{width:130px;flex-shrink:0;font-size:12px;color:var(--text-muted)}.form-row input[type=text],.form-row input[type=color],.form-row select{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:12px}.form-row input[type=color]{padding:0;width:36px;height:24px}.form-error{color:var(--error-text);background:var(--error-bg);padding:6px 10px;border-radius:var(--radius);font-size:12px;margin-top:8px}.warning-banner{background:#f4c54226;border:1px solid #f4c542;border-radius:var(--radius);padding:8px 12px;font-size:12px;margin-bottom:12px;color:var(--text)}[data-dark] .warning-banner{background:#f4c54214}.warning-banner code{background:var(--surface);padding:1px 4px;border-radius:2px}.config-form fieldset{border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px 12px;margin-bottom:12px}.config-form fieldset[disabled]{opacity:.6}.config-form legend{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:0 6px}.config-warn{display:block;width:100%;margin-left:142px;font-size:11px;color:var(--text-muted)}.config-actions{display:flex;justify-content:flex-end;margin-top:4px}.btn-link{background:none;border:none;color:var(--text-muted);cursor:pointer;text-decoration:underline;font-size:11px}.tab-bar{display:flex;gap:2px;margin-bottom:12px;border-bottom:1px solid var(--border)}.tab-btn{background:transparent;border:none;border-bottom:2px solid transparent;padding:6px 12px;font-size:12px;color:var(--text-muted);cursor:pointer}.tab-btn:hover{color:var(--text)}.tab-btn.tab-active{color:var(--accent);border-bottom-color:var(--accent)}.embed-textarea{width:100%;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;padding:8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);resize:vertical;min-height:80px}.docs-link{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);text-decoration:none}.docs-link:hover{border-color:var(--accent);color:var(--accent)}.docs-link svg{display:block}.workspace.drag-hover{outline:2px dashed var(--accent);outline-offset:-8px}.cm-lint-marker-error{filter:hue-rotate(0deg)}@media(max-width:640px){.splitter{display:none}.layout-split-h,.layout-split-v{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.template-panel,.history-panel{width:100%}.toolbar-title{display:none}}
