*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--radius: 6px;--header-h: 48px;--footer-h: 32px;--tab-h: 34px;--transition: .15s ease}html,body{height:100%;width:100%;overflow:hidden}astro-island{display:contents}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-root{height:100%;width:100%;background:var(--bg);color:var(--fg);transition:background var(--transition),color var(--transition)}.app-layout{isolation:isolate;display:flex;flex-direction:column;height:100%}.app-header{height:var(--header-h);min-height:var(--header-h);display:flex;align-items:center;justify-content:space-between;padding:0 16px;border-bottom:1px solid var(--border);gap:12px;background:var(--surface)}.header-left{display:flex;align-items:center;gap:10px;flex-shrink:0}.logo-mark{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius);background:color-mix(in srgb,var(--accent) 12%,transparent)}.header-left h1{font-size:13.5px;font-weight:600;letter-spacing:-.02em;color:var(--fg);white-space:nowrap}.header-controls{display:flex;align-items:center;gap:6px;flex-shrink:0}.header-sep{width:1px;height:20px;background:var(--border);margin:0 4px}.toggle-group{display:flex;align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:2px;gap:2px;height:30px}.toggle-btn{display:flex;align-items:center;gap:5px;padding:4px 10px;height:24px;border:none;background:transparent;color:var(--muted);font-family:inherit;font-size:12px;font-weight:500;cursor:pointer;border-radius:calc(var(--radius) - 2px);transition:color var(--transition);white-space:nowrap;line-height:1;position:relative;isolation:isolate}.toggle-btn:hover,.toggle-btn[data-pressed]{color:var(--fg)}.toggle-pill{position:absolute;inset:0;border-radius:calc(var(--radius) - 2px);z-index:-1;background:var(--surface);box-shadow:0 1px 2px #0000000f}.dark .toggle-pill{background:var(--border);box-shadow:0 1px 3px #0003}.icon-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--border);background:var(--bg);color:var(--muted);border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.icon-btn:hover:not(:disabled){color:var(--fg);border-color:var(--muted);background:var(--surface-2)}.icon-btn:disabled{opacity:.35;cursor:default;pointer-events:none}.app-main{flex:1;display:flex;overflow:hidden;min-height:0}.panel{display:flex;flex-direction:column;min-height:0;overflow:hidden}.editor-panel,.preview-panel{min-width:0}.panel-tab{height:var(--tab-h);min-height:var(--tab-h);display:flex;align-items:center;gap:6px;padding:0 16px;font-size:11.5px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);background:var(--surface);user-select:none}.panel-tab-actions{display:flex;align-items:center;gap:6px;margin-left:auto}.panel-tab-actions .toggle-group{padding:1px;height:24px}.panel-tab-actions .toggle-btn{padding:2px 8px;font-size:11px;text-transform:none;letter-spacing:0;height:20px}.panel-tab-actions .icon-btn{width:24px;height:24px}.dropdown-menu{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 2px 8px #00000014,0 1px 2px #0000000f;overflow:hidden;min-width:140px;transform-origin:top right;transition:opacity .15s ease,transform .15s ease}.dropdown-menu:not([data-open]){opacity:0;transform:scale(.96) translateY(-4px);pointer-events:none}@starting-style{.dropdown-menu[data-open]{opacity:0;transform:scale(.96) translateY(-4px)}}.dark .dropdown-menu{box-shadow:0 2px 10px #0000004d,0 1px 3px #0003}.dropdown-menu-item{display:block;width:100%;padding:7px 12px;border:none;background:transparent;color:var(--fg);font-family:inherit;font-size:12px;font-weight:500;text-align:left;cursor:pointer;transition:background var(--transition)}.dropdown-menu-item[data-highlighted]{background:var(--bg)}.dropdown-menu-item+.dropdown-menu-item{border-top:1px solid var(--border)}.panel-content{flex:1;overflow:auto;min-height:0}.editor-content{background:var(--bg)}.preview-content{background:var(--bg);position:relative;overflow:hidden}.resize-handle{flex-shrink:0;width:5px;background:var(--border);cursor:col-resize;transition:background var(--transition);touch-action:none;position:relative}.resize-handle:before{content:"";position:absolute;inset:0 -3px}.resize-handle:hover,.resize-handle[data-separator=active]{background:var(--accent)}.cm-wrapper{height:100%;overflow:auto}.cm-wrapper .cm-editor{height:100%;outline:none}.cm-wrapper .cm-focused{outline:none}.cm-wrapper .cm-scroller{overflow:auto;font-family:JetBrains Mono,Fira Code,SF Mono,Cascadia Code,Consolas,monospace}.svg-viewer{position:relative;width:100%;height:100%;overflow:hidden;display:flex;align-items:center;justify-content:center;touch-action:none;user-select:none}.svg-viewer-content{transform-origin:center center;will-change:transform;display:flex;align-items:center;justify-content:center;pointer-events:none}.svg-viewer-content svg{display:block;max-width:none;max-height:none}.zoom-controls{position:absolute;bottom:12px;right:12px;display:flex;align-items:center;gap:2px;padding:4px;background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);box-shadow:0 2px 8px #00000014,0 1px 2px #0000000f;z-index:5;pointer-events:auto}.dark .zoom-controls{box-shadow:0 2px 10px #0000004d,0 1px 3px #0003}.zoom-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--muted);border-radius:var(--radius);cursor:pointer;transition:color var(--transition),background var(--transition)}.zoom-btn:hover{color:var(--fg);background:var(--bg)}.zoom-level{font-family:JetBrains Mono,monospace;font-size:10.5px;font-weight:600;color:var(--muted);min-width:38px;text-align:center;user-select:none;letter-spacing:-.02em}.zoom-sep{width:1px;height:16px;background:var(--border);margin:0 2px}.svg-viewer:after{content:"";position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .2s ease}.ascii-container{font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;line-height:1.3;color:var(--fg);white-space:pre;text-align:left;padding:24px;margin:0;overflow:auto;width:100%;height:100%}.error-box{display:flex;align-items:flex-start;gap:10px;padding:16px 20px;margin:32px;background:color-mix(in srgb,#f85149 8%,var(--bg));border:1px solid color-mix(in srgb,#f85149 25%,var(--border));border-radius:var(--radius);max-width:600px;width:calc(100% - 64px)}.error-icon{flex-shrink:0;color:#f85149;padding-top:2px}.error-text{font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.6;color:color-mix(in srgb,#f85149 80%,var(--fg));white-space:pre-wrap;word-break:break-word;margin:0}.ascii-fallback{display:flex;flex-direction:column;align-items:center;width:100%;height:100%;gap:16px;padding:16px;overflow:hidden}.fallback-notice{display:flex;align-items:center;gap:8px;padding:8px 14px;background:color-mix(in srgb,var(--accent) 8%,var(--bg));border:1px solid color-mix(in srgb,var(--accent) 20%,var(--border));border-radius:var(--radius);font-size:12px;color:var(--muted);line-height:1.4;flex-shrink:0}.fallback-notice svg{flex-shrink:0}.fallback-switch-btn{flex-shrink:0;margin-left:4px;padding:3px 10px;border:1px solid var(--border);background:var(--surface);color:var(--accent);font-family:inherit;font-size:11px;font-weight:600;border-radius:calc(var(--radius) - 1px);cursor:pointer;white-space:nowrap;transition:all var(--transition)}.fallback-switch-btn:hover{background:color-mix(in srgb,var(--accent) 12%,var(--surface));border-color:var(--accent)}.app-footer{height:var(--footer-h);min-height:var(--footer-h);display:flex;align-items:center;justify-content:space-between;padding:0 16px;border-top:1px solid var(--border);font-size:11px;color:var(--muted);background:var(--surface)}.footer-left,.footer-right{display:flex;align-items:center;gap:4px}.footer-emoji{cursor:default;line-height:1}.app-footer a{color:var(--accent);text-decoration:none;font-weight:500}.app-footer a:hover{text-decoration:underline}.pwa-toast{position:fixed;right:16px;bottom:16px;z-index:200;display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface, #161b22);border:1px solid var(--border, #30363d);border-radius:var(--radius);box-shadow:0 4px 16px #0000004d;font-size:12px;color:var(--fg, #e6edf3)}.pwa-toast-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.pwa-toast-reload{padding:4px 10px;background:var(--accent, #4493f8);color:#fff;border:none;border-radius:4px;font-family:inherit;font-size:11px;font-weight:500;cursor:pointer;transition:filter var(--transition)}.pwa-toast-reload:hover{filter:brightness(1.1)}.pwa-toast-close{display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;background:transparent;border:none;color:var(--muted, #9198a1);cursor:pointer;border-radius:4px;transition:color var(--transition)}.pwa-toast-close:hover{color:var(--fg, #e6edf3)}.dialog-backdrop{position:fixed;inset:0;background:#00000073;z-index:100;opacity:1;transition:opacity .15s ease}.dialog-backdrop:not([data-open]){opacity:0;pointer-events:none}@starting-style{.dialog-backdrop[data-open]{opacity:0}}.dialog-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);box-shadow:0 8px 32px #0000001f;padding:20px;min-width:360px;max-width:480px;max-height:min(70vh,calc(100dvh - 32px));z-index:101;outline:none;display:flex;flex-direction:column;overflow:hidden;opacity:1;transition:opacity .15s ease,transform .15s ease}.dialog-popup:not([data-open]){opacity:0;transform:translate(-50%,-50%) scale(.96);pointer-events:none}@starting-style{.dialog-popup[data-open]{opacity:0;transform:translate(-50%,-50%) scale(.96)}}.dark .dialog-popup{box-shadow:0 8px 32px #0006,0 2px 8px #0000004d}.dialog-title{font-size:14px;font-weight:600;color:var(--fg);margin:0 0 16px;flex-shrink:0}.save-label{display:block;font-size:12px;font-weight:500;color:var(--muted);margin-bottom:6px}.save-input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--fg);font-family:inherit;font-size:13px;outline:none;transition:border-color var(--transition),box-shadow var(--transition);box-sizing:border-box}.save-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 20%,transparent)}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.dialog-btn{padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500;border-radius:var(--radius);cursor:pointer;transition:all var(--transition);border:1px solid transparent}.dialog-btn:disabled{opacity:.5;cursor:default}.dialog-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.dialog-btn-primary:hover:not(:disabled){filter:brightness(1.1)}.dialog-btn-secondary{background:transparent;color:var(--fg);border-color:var(--border)}.dialog-btn-secondary:hover:not(:disabled){background:var(--surface-2)}.diagram-list{display:flex;flex-direction:column;gap:2px;overflow-y:auto;min-height:0;margin:0 -4px}.diagram-list-item{display:flex;align-items:center;gap:2px;padding:0 4px}.diagram-list-item-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;padding:10px 12px;border:none;background:transparent;border-radius:var(--radius);cursor:pointer;text-align:left;font-family:inherit;color:var(--fg);transition:background var(--transition)}.diagram-list-item-main:hover{background:var(--surface-2)}.diagram-list-item-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.diagram-list-item-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}.diagram-list-item-badge{flex-shrink:0;font-size:10px;font-weight:500;padding:1px 6px;border-radius:9999px;background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);letter-spacing:.01em}.diagram-list-item-action{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--muted);border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.diagram-list-item-action:hover{background:var(--surface-2);color:var(--fg)}.diagram-list-item-action-danger:hover{background:color-mix(in srgb,#f85149 10%,var(--surface));color:#f85149}.diagram-list-empty{text-align:center;padding:32px 16px;font-size:13px;color:var(--muted);margin:0}@media(max-width:768px){.app-main{flex-direction:column}.editor-panel{border-bottom:1px solid var(--border)}.resize-handle{width:100%;height:3px;cursor:default;pointer-events:none}.resize-handle:hover{background:var(--border)}.header-left h1{display:none}.app-footer{font-size:10px;padding:0 10px;white-space:nowrap;overflow:hidden}.dialog-popup{min-width:unset;width:calc(100% - 32px);max-height:calc(100dvh - 32px)}.toggle-btn span:not(:only-child){display:none}.header-sep{margin:0 2px}}@media(max-width:480px){.header-controls{gap:4px}.toggle-btn{padding:4px 6px;font-size:11px}.footer-left{display:none}.footer-right{margin-left:auto}}.tooltip-popup{padding:4px 8px;font-size:11px;font-weight:500;color:var(--fg);background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) - 1px);box-shadow:0 2px 6px #00000014;white-space:nowrap;pointer-events:none}.dark .tooltip-popup{box-shadow:0 2px 8px #0000004d}.app-root.dark ::-webkit-scrollbar{width:8px;height:8px}.app-root.dark ::-webkit-scrollbar-track{background:transparent}.app-root.dark ::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.app-root.dark ::-webkit-scrollbar-thumb:hover{background:var(--muted)}.app-root.light ::-webkit-scrollbar{width:8px;height:8px}.app-root.light ::-webkit-scrollbar-track{background:transparent}.app-root.light ::-webkit-scrollbar-thumb{background:#d1d9e0;border-radius:4px}.app-root.light ::-webkit-scrollbar-thumb:hover{background:#8b949e}
