.hidden{display:none!important}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0d0d1a;--bg-secondary:#141428;--bg-surface:#1a1a33;--bg-elevated:#22223d;--bg-hover:#2a2a4a;--border:#2d2d52;--border-subtle:#232345;--border-focus:#6366f1;--text-primary:#e8e8f0;--text-secondary:#9090b0;--text-tertiary:#606080;--accent:#6366f1;--accent-hover:#818cf8;--accent-muted:#6366f126;--success:#22c55e;--success-bg:#22c55e1f;--error:#ef4444;--error-bg:#ef44441a;--warning:#f59e0b;--radius-sm:4px;--radius-md:6px;--radius-lg:10px;--transition:.15s ease;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", "SF Mono", "Consolas", monospace;--font-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", Roboto, sans-serif}html,body{height:100%;font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:13px;overflow:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}#app{flex-direction:column;height:100vh;display:flex;position:relative}header{background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:10;-webkit-user-select:none;user-select:none;flex-shrink:0;align-items:center;gap:8px;height:44px;padding:0 12px;display:flex}.header-left{flex-shrink:0}.logo{color:var(--accent);letter-spacing:-.3px;align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.logo svg{opacity:.9}.tabs-bar{scrollbar-width:none;flex:1;align-items:center;gap:2px;padding:0 8px;display:flex;overflow-x:auto}.tabs-bar::-webkit-scrollbar{display:none}.tab{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--transition);background:0 0;border:1px solid #0000;align-items:center;gap:6px;padding:5px 12px;font-size:12px;display:flex;position:relative}.tab:hover{background:var(--bg-hover);color:var(--text-primary)}.tab.active{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border)}.tab .tab-close{opacity:0;width:16px;height:16px;transition:all var(--transition);border-radius:3px;justify-content:center;align-items:center;font-size:14px;line-height:1;display:flex}.tab:hover .tab-close,.tab.active .tab-close{opacity:.5}.tab .tab-close:hover{opacity:1;background:var(--error-bg);color:var(--error)}.tab .tab-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;display:none}.tab.modified .tab-dot{display:block}.tab-name{text-overflow:ellipsis;max-width:120px;overflow:hidden}.tab-cloud{opacity:.5;font-size:10px}.tab-coll-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.tab-name-input{border:1px solid var(--accent);color:var(--text-primary);width:100px;font-size:12px;font-family:var(--font-sans);background:0 0;border-radius:2px;outline:none;padding:0 4px}.tab-add{border-radius:var(--radius-sm);border:1px dashed var(--border);width:26px;height:26px;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition);background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;display:flex}.tab-add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-muted)}.header-right{flex-shrink:0;align-items:center;gap:4px;display:flex}.btn-header{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-size:12px;font-family:var(--font-sans);white-space:nowrap;align-items:center;gap:5px;padding:5px 10px;display:flex}.btn-header:hover{border-color:var(--accent);color:var(--text-primary);background:var(--bg-hover)}.btn-header.btn-icon{padding:5px 7px}.btn-header.btn-icon span{display:none}.btn-header.btn-theme{gap:3px}.btn-header.btn-theme .chevron-icon{opacity:.45;transition:opacity var(--transition), transform var(--transition)}.btn-header.btn-theme:hover .chevron-icon{opacity:.8}.dropdown-menu-theme{min-width:120px}.dropdown-menu button.active{color:var(--accent-hover);background:var(--accent-muted);font-weight:500}.btn-aist-auth{gap:6px}.btn-aist-auth:hover{border-color:var(--success)}.aist-dot{background:var(--text-tertiary);border-radius:50%;flex-shrink:0;width:7px;height:7px;display:inline-block}.aist-dot.connected{background:var(--success);box-shadow:0 0 4px var(--success)}.aist-dialog{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);width:380px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-lg);z-index:1;position:relative;overflow:hidden}.aist-close{z-index:2;position:absolute;top:12px;right:12px}.aist-dialog-hero{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:28px 20px 20px;display:flex}.aist-logo{border-radius:14px;box-shadow:0 2px 12px #00000026}.aist-dialog-hero h2{color:var(--text-primary);margin:0;font-size:16px;font-weight:600}.aist-dialog-body{flex-direction:column;gap:16px;padding:0 24px 24px;display:flex}.aist-info-text{color:var(--text-secondary);text-align:center;margin:0;font-size:13px;line-height:1.6}.btn-aist-connect{border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;transition:background var(--transition);border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 20px;font-size:14px;font-weight:600;text-decoration:none;display:flex}.btn-aist-connect:hover{background:var(--accent-hover)}.aist-connected-info{background:var(--success-bg);border-radius:var(--radius-md);border:1px solid #22c55e40;align-items:center;gap:12px;padding:12px;display:flex}.aist-model-name{color:var(--text-primary);font-size:13px;font-weight:600}.aist-model-sub{color:var(--text-secondary);margin-top:2px;font-size:12px}.btn-aist-danger{border-radius:var(--radius-md);border:1px solid var(--border);width:100%;color:var(--error);cursor:pointer;transition:all var(--transition);font-size:12px;font-family:var(--font-sans);background:0 0;padding:8px}.btn-aist-danger:hover{background:var(--error-bg);border-color:var(--error)}.aist-credits{margin:10px 0 12px}.aist-credits-header{color:var(--text-secondary);justify-content:space-between;align-items:center;margin-bottom:5px;font-size:11px;display:flex}.aist-credits-plan{color:var(--text-tertiary);font-size:11px}.aist-credits-track{background:var(--border);border-radius:3px;height:5px;overflow:hidden}.aist-credits-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .4s}.aist-credits-fill.warn{background:#f59e0b}.aist-credits-fill.danger{background:var(--error)}.dropdown{position:relative}.dropdown-menu{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);min-width:200px;box-shadow:var(--shadow-lg);z-index:50;padding:4px;animation:.12s dropdown-in;display:none;position:absolute;top:calc(100% + 4px);right:0}.dropdown-menu.open{display:block}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-menu button{width:100%;color:var(--text-primary);text-align:left;cursor:pointer;border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-sans);transition:background var(--transition);background:0 0;border:none;padding:7px 12px;display:block}.dropdown-menu button:hover{background:var(--accent-muted);color:var(--accent-hover)}.dropdown-divider{background:var(--border);height:1px;margin:4px 8px}main{flex:1;display:flex;position:relative;overflow:hidden}.editor-pane{background:var(--bg-primary);flex-direction:column;width:42%;min-width:250px;display:flex}.pane-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:space-between;align-items:center;padding:6px 12px;display:flex}.pane-title{text-transform:uppercase;letter-spacing:.8px;color:var(--text-tertiary);font-size:11px;font-weight:600}.pane-actions{gap:6px;display:flex}.select-small{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;font-size:11px;font-family:var(--font-sans);outline:none;padding:3px 6px}.select-small:hover,.select-small:focus{border-color:var(--accent)}#editor-container{flex:1;overflow:hidden}#editor-container .cm-editor{height:100%;font-size:13px}#editor-container .cm-editor.cm-focused{outline:none}#editor-container .cm-scroller{line-height:1.6;font-family:var(--font-mono)!important}#editor-container .cm-gutters{background:var(--bg-primary);border-right:1px solid var(--border-subtle);color:var(--text-tertiary)}#editor-container .cm-activeLineGutter{background:var(--bg-surface)}#editor-container .cm-activeLine{background:#6366f10d}#editor-container .cm-selectionBackground{background:#6366f133!important}#editor-container .cm-cursor{border-left-color:var(--accent)}#editor-container .cm-matchingBracket{outline:1px solid var(--accent);background:#6366f140}.error-bar{background:var(--error-bg);color:var(--error);font-size:12px;font-family:var(--font-mono);border-top:1px solid #ef44444d;flex-shrink:0;align-items:flex-start;gap:8px;max-height:80px;padding:8px 12px;animation:.15s slide-up;display:flex;overflow-y:auto}.error-bar svg{flex-shrink:0;margin-top:1px}.error-bar.hidden{display:none}@keyframes slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.resize-handle{cursor:col-resize;background:var(--bg-secondary);border-left:1px solid var(--border);border-right:1px solid var(--border);width:5px;transition:background var(--transition);z-index:5;flex-shrink:0;justify-content:center;align-items:center;display:flex}.resize-handle:hover,.resize-handle.dragging{background:var(--accent-muted);border-color:var(--accent)}.resize-handle-line{background:var(--text-tertiary);width:1px;height:32px;transition:background var(--transition);border-radius:1px}.resize-handle:hover .resize-handle-line,.resize-handle.dragging .resize-handle-line{background:var(--accent)}.preview-pane{background:var(--bg-primary);flex-direction:column;flex:1;min-width:300px;display:flex}.preview-pane.fullscreen{z-index:60;background:#fff;position:fixed;inset:0}.preview-pane.fullscreen .pane-header{background:#fffffff2;border-bottom-color:#e0e0e0}.preview-pane.fullscreen .pane-title{color:#666}.preview-pane.fullscreen .btn-zoom{color:#333;background:#f5f5f5;border-color:#ddd}.preview-pane.fullscreen .btn-zoom:hover{border-color:var(--accent);background:#e8e8e8}.preview-pane.fullscreen .zoom-label{color:#666}.zoom-controls{align-items:center;gap:3px;display:flex}.btn-zoom{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-size:11px;font-family:var(--font-sans);justify-content:center;align-items:center;min-width:28px;height:24px;padding:3px 8px;display:flex}.btn-zoom:hover{border-color:var(--accent);color:var(--text-primary);background:var(--bg-hover)}.zoom-label{color:var(--text-tertiary);text-align:center;font-variant-numeric:tabular-nums;min-width:38px;font-size:11px}.zoom-separator{background:var(--border);width:1px;height:16px;margin:0 4px}.preview-viewport{cursor:grab;background:#fff;flex:1;position:relative;overflow:auto}.preview-viewport:active{cursor:grabbing}.preview-viewport.no-diagram{justify-content:center;align-items:center;display:flex}.preview-content{transform-origin:0 0;justify-content:center;align-items:center;min-width:100%;min-height:100%;padding:32px;display:flex}.preview-content svg{max-width:none}.preview-empty{color:#bbb;text-align:center;padding:48px;font-size:14px}.preview-empty svg{opacity:.3;margin-bottom:12px}#status-bar{background:var(--bg-secondary);border-top:1px solid var(--border);height:24px;color:var(--text-tertiary);-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 12px;font-size:11px;display:flex;position:relative}.status-left,.status-right{align-items:center;gap:8px;display:flex}.status-center{color:var(--text-tertiary);opacity:.85;letter-spacing:.02em;align-items:center;gap:3px;font-size:10px;transition:opacity .2s;display:flex;position:absolute;left:50%;transform:translate(-50%)}.status-center:hover{opacity:1}.status-heart{color:#c0787a;font-size:10px}.status-brand-link{color:inherit;text-decoration:none;transition:color .2s}.status-brand-link:hover{color:var(--text-secondary);text-underline-offset:2px;text-decoration:underline}.status-dot{width:7px;height:7px;transition:background var(--transition);border-radius:50%}.status-dot.ready{background:var(--success)}.status-dot.rendering{background:var(--warning);animation:1s infinite pulse}.status-dot.error{background:var(--error)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.status-sep{color:var(--border)}.status-hint{opacity:.6}.overlay{z-index:100;justify-content:center;align-items:flex-start;padding-top:15vh;display:flex;position:fixed;inset:0}.overlay.hidden{display:none}.overlay-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;position:absolute;inset:0}.palette-dialog{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);width:500px;max-width:90vw;box-shadow:var(--shadow-lg);animation:.12s palette-in;position:relative;overflow:hidden}@keyframes palette-in{0%{opacity:0;transform:translateY(-12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.palette-dialog input{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text-primary);font-size:15px;font-family:var(--font-sans);background:0 0;outline:none;padding:14px 16px}.palette-dialog input::placeholder{color:var(--text-tertiary)}.palette-results{max-height:320px;padding:4px;overflow-y:auto}.palette-item{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.palette-item:hover,.palette-item.selected{background:var(--accent-muted)}.palette-item-left{align-items:center;gap:10px;display:flex}.palette-item-icon{width:20px;height:20px;color:var(--text-tertiary);justify-content:center;align-items:center;font-size:14px;display:flex}.palette-item-name{color:var(--text-primary);font-size:13px}.palette-item-hint{color:var(--text-tertiary);font-size:11px}.palette-item kbd{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);font-size:11px;font-family:var(--font-sans);border-radius:3px;padding:2px 6px}.palette-empty{text-align:center;color:var(--text-tertiary);padding:20px;font-size:13px}.shortcuts-dialog{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);width:600px;max-width:90vw;box-shadow:var(--shadow-lg);padding:24px;animation:.12s palette-in;position:relative}.shortcuts-dialog h2{color:var(--text-primary);margin-bottom:20px;font-size:16px}.shortcuts-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.shortcut-section h3{text-transform:uppercase;letter-spacing:.8px;color:var(--text-tertiary);margin-bottom:8px;font-size:11px;font-weight:600}.shortcut-row{color:var(--text-secondary);justify-content:space-between;align-items:center;padding:4px 0;font-size:12px;display:flex}.shortcut-row kbd{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);font-size:11px;font-family:var(--font-mono);border-radius:3px;padding:2px 6px}.btn-close{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-family:var(--font-sans);transition:all var(--transition);margin-top:20px;padding:8px 16px}.btn-close:hover{border-color:var(--accent);background:var(--bg-hover)}#toast-container{z-index:200;pointer-events:none;flex-direction:column-reverse;gap:8px;display:flex;position:fixed;bottom:36px;right:16px}.toast{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);color:var(--text-primary);pointer-events:auto;align-items:center;gap:8px;max-width:340px;padding:10px 16px;font-size:13px;animation:.2s toast-in;display:flex}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--error)}.toast.info{border-left:3px solid var(--accent)}.toast-icon{flex-shrink:0;font-size:15px}.toast.leaving{animation:.2s forwards toast-out}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes toast-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(20px)}}.btn-ai{font-weight:600;color:#fff!important;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%)!important;border-color:#7c3aed!important}.btn-ai:hover{background:linear-gradient(135deg,#818cf8 0%,#a78bfa 100%)!important;border-color:#8b5cf6!important}.ai-dialog{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);width:720px;max-width:95vw;max-height:85vh;box-shadow:var(--shadow-lg);flex-direction:column;animation:.15s palette-in;display:flex;position:relative;overflow:hidden}.ai-dialog-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.ai-dialog-header h2{color:var(--text-primary);align-items:center;gap:8px;font-size:16px;display:flex}.ai-dialog-header h2 svg{color:var(--accent)}.btn-close-small{width:28px;height:28px;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;font-size:20px;display:flex}.btn-close-small:hover{background:var(--error-bg);color:var(--error)}.ai-dialog-body{flex:1;padding:20px;overflow-y:auto}.ai-input-group{margin-bottom:14px}.ai-input-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.label-optional{text-transform:none;color:var(--text-tertiary);letter-spacing:0;font-weight:400}.ai-input-group textarea,.ai-input-group input[type=text]{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);resize:vertical;transition:border-color var(--transition);outline:none;padding:10px 12px}.ai-input-group textarea:focus,.ai-input-group input[type=text]:focus{border-color:var(--accent)}.char-counter{text-align:right;color:var(--text-tertiary);font-variant-numeric:tabular-nums;margin-top:4px;font-size:11px;transition:color .2s;display:block}.char-counter.warning{color:var(--warning,#f59e0b)}.char-counter.danger{color:var(--error)}.ai-input-group textarea::placeholder,.ai-input-group input::placeholder{color:var(--text-tertiary)}.ai-options{align-items:center;gap:8px;margin-bottom:16px;display:flex}.btn-ai-submit{color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);font-size:13px;font-weight:600;font-family:var(--font-sans);background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border:none;align-items:center;gap:6px;margin-left:auto;padding:8px 18px;display:flex}.btn-ai-submit:hover{background:linear-gradient(135deg,#818cf8 0%,#a78bfa 100%);transform:translateY(-1px)}.btn-ai-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.ai-loading{color:var(--text-secondary);align-items:center;gap:12px;padding:16px;font-size:13px;display:flex}.ai-loading.hidden{display:none}.ai-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.ai-results{flex-direction:column;gap:12px;display:flex}.ai-result-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color var(--transition);overflow:hidden}.ai-result-card:hover{border-color:var(--accent)}.ai-result-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.ai-result-title{color:var(--text-primary);font-size:13px;font-weight:600}.ai-result-type{background:var(--accent-muted);color:var(--accent);border-radius:10px;padding:2px 8px;font-size:11px}.ai-result-preview{background:#fff;justify-content:center;align-items:center;min-height:80px;padding:12px;display:flex;overflow:hidden}.ai-result-preview svg{max-width:100%;max-height:200px}.ai-result-actions{border-top:1px solid var(--border-subtle);gap:6px;padding:8px 14px;display:flex}.ai-result-actions button{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;font-size:11px;font-family:var(--font-sans);transition:all var(--transition);padding:5px 12px}.ai-result-actions button:hover{border-color:var(--accent);color:var(--text-primary)}.ai-result-actions button.btn-use{background:var(--accent);color:#fff;border-color:var(--accent)}.ai-result-actions button.btn-use:hover{background:var(--accent-hover)}.ai-result-error{color:var(--error);padding:10px 14px;font-size:12px;font-style:italic}#editor-container.drag-over{outline-offset:-2px;background:var(--accent-muted);outline:2px solid var(--accent)!important}::selection{background:#6366f159}button:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:1px}@media print{header,#status-bar,.editor-pane,.resize-handle,.pane-header,.overlay{display:none!important}.preview-pane{width:100%!important;position:static!important}.preview-viewport{background:#fff!important;overflow:visible!important}.preview-content{transform:none!important}}@media (width<=768px){header{flex-wrap:wrap;height:auto;padding:8px}.tabs-bar{order:3;width:100%;padding:4px 0}main{flex-direction:column}.editor-pane{height:40%;min-width:unset;width:100%!important}.resize-handle{cursor:row-resize;border-left:none;border-right:none;border-top:1px solid var(--border);border-bottom:1px solid var(--border);width:100%;height:5px}.resize-handle-line{width:32px;height:1px}.preview-pane{min-width:unset}.shortcuts-grid{grid-template-columns:1fr}.btn-header span{display:none}}.lang-selector{display:inline-flex;position:relative}.btn-lang{letter-spacing:.03em;align-items:center;gap:4px;padding:4px 7px;font-size:12px;font-weight:500;display:inline-flex}.lang-flag{font-size:14px;line-height:1}.lang-code{letter-spacing:.05em;font-size:11px}.lang-dropdown{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:500;min-width:160px;max-height:280px;padding:4px;display:none;position:absolute;top:calc(100% + 4px);right:0;overflow-y:auto}.lang-dropdown.open{display:block}.lang-item{border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;transition:background var(--transition), color var(--transition);background:0 0;border:none;align-items:center;gap:8px;padding:6px 8px;font-size:12px;display:flex}.lang-item:hover{background:var(--bg-hover);color:var(--text-primary)}.lang-item.active{color:var(--accent);background:var(--accent-muted)}.lang-dropdown::-webkit-scrollbar{width:4px}.lang-dropdown::-webkit-scrollbar-track{background:0 0}.lang-dropdown::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);width:340px;max-width:90vw;height:100vh;box-shadow:var(--shadow-lg);z-index:100;flex-direction:column;transition:transform .2s ease-out;display:flex;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar.hidden{transform:translate(-100%);display:flex!important}.sidebar-backdrop{z-index:99;opacity:0;pointer-events:none;background:#0006;transition:opacity .2s;position:fixed;inset:0}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.sidebar-backdrop.hidden{opacity:0;pointer-events:none;display:block!important}.sidebar-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 16px 12px;display:flex}.sidebar-header h2{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.sidebar-search{flex-shrink:0;padding:8px 12px}.sidebar-search input{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-surface);width:100%;color:var(--text-primary);font-size:12px;font-family:var(--font-sans);transition:border-color var(--transition);outline:none;padding:8px 12px}.sidebar-search input:focus{border-color:var(--accent)}.sidebar-nav{flex-shrink:0;gap:2px;padding:4px 12px;display:flex}.sidebar-nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-size:11px;font-family:var(--font-sans);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:4px;padding:6px 8px;display:flex}.sidebar-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--accent-muted);color:var(--accent);font-weight:500}.sidebar-count{background:var(--bg-surface);color:var(--text-tertiary);border-radius:8px;padding:1px 5px;font-size:10px}.sidebar-collections{flex-shrink:0;padding:8px 12px 4px}.sidebar-section-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.sidebar-section-header span{text-transform:uppercase;letter-spacing:.8px;color:var(--text-tertiary);font-size:10px;font-weight:600}.btn-tiny{border-radius:var(--radius-sm);border:1px dashed var(--border);width:20px;height:20px;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition);background:0 0;justify-content:center;align-items:center;font-size:14px;display:flex}.btn-tiny:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-muted)}.collection-item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);color:var(--text-secondary);align-items:center;gap:8px;padding:5px 8px;font-size:12px;display:flex}.collection-item:hover{background:var(--bg-hover);color:var(--text-primary)}.collection-item.active{background:var(--accent-muted);color:var(--accent)}.collection-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.collection-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.collection-count{color:var(--text-tertiary);font-size:10px}.sidebar-tags{flex-wrap:wrap;flex-shrink:0;gap:4px;padding:4px 12px;display:flex}.sidebar-tag{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);border-radius:10px;padding:2px 8px;font-size:10px}.sidebar-tag:hover,.sidebar-tag.active{border-color:var(--accent);color:var(--accent);background:var(--accent-muted)}.sidebar-grid{flex:1;grid-template-columns:1fr 1fr;align-content:start;gap:8px;padding:8px 12px;display:grid;overflow-y:auto}.diagram-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);position:relative;overflow:hidden}.diagram-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);transform:scale(1.02)}.diagram-card-thumb{background:var(--bg-primary);border-bottom:1px solid var(--border-subtle);justify-content:center;align-items:center;height:80px;display:flex;overflow:hidden}.diagram-card-thumb svg{pointer-events:none;max-width:100%;max-height:100%;display:block}.diagram-card-thumb>svg,.diagram-card-thumb>#sidebar-thumb svg{transform-origin:50%;width:100%;height:auto;transform:scale(.9)}.diagram-card-thumb .thumb-placeholder{color:var(--text-tertiary);font-size:24px}.diagram-card-info{padding:8px}.diagram-card-title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px;font-size:11px;font-weight:500;overflow:hidden}.diagram-card-meta{color:var(--text-tertiary);justify-content:space-between;align-items:center;font-size:10px;display:flex}.diagram-card-type{background:var(--bg-elevated);border-radius:3px;padding:1px 5px}.diagram-card-actions{display:none;position:absolute;top:4px;right:4px}.diagram-card:hover .diagram-card-actions{gap:2px;display:flex}.diagram-card-btn{border-radius:var(--radius-sm);background:var(--bg-elevated);width:22px;height:22px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);border:none;justify-content:center;align-items:center;font-size:12px;display:flex}.diagram-card-btn:hover{background:var(--accent);color:#fff}.diagram-card-btn.danger:hover{background:var(--error)}.diagram-card .star-badge{filter:drop-shadow(0 1px 2px #0000004d);font-size:12px;position:absolute;top:4px;left:4px}.diagram-card .collection-badge{border:1px solid var(--bg-surface);border-radius:50%;width:8px;height:8px;position:absolute;bottom:32px;right:4px}.btn-load-more{border-radius:var(--radius-md);border:1px dashed var(--border);width:calc(100% - 24px);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-size:12px;font-family:var(--font-sans);background:0 0;flex-shrink:0;margin:4px 12px 12px;padding:8px}.btn-load-more:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-muted)}.context-menu{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:200;min-width:160px;padding:4px;animation:.1s dropdown-in;position:fixed}.context-menu button{width:100%;color:var(--text-primary);text-align:left;cursor:pointer;border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-sans);transition:background var(--transition);background:0 0;border:none;padding:7px 12px;display:block}.context-menu button:hover{background:var(--accent-muted);color:var(--accent-hover)}.context-menu button.danger{color:var(--error)}.context-menu button.danger:hover{background:var(--error-bg);color:var(--error)}.save-dialog-content,.collection-dialog-content{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);width:420px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-lg);z-index:1;padding:24px;position:relative}.save-dialog-content h2,.collection-dialog-content h2{color:var(--text-primary);margin:0 0 20px;font-size:16px;font-weight:600}.save-form{flex-direction:column;gap:14px;display:flex}.save-field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:500;display:block}.save-field input,.save-field select{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-surface);width:100%;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);transition:border-color var(--transition);outline:none;padding:8px 12px}.save-field input:focus,.save-field select:focus{border-color:var(--accent)}.save-title-row{gap:6px;display:flex}.save-title-row input{flex:1}.save-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.btn-secondary{border-radius:var(--radius-md);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-size:13px;font-family:var(--font-sans);background:0 0;padding:8px 16px}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-primary{border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;transition:background var(--transition);font-size:13px;font-weight:500;font-family:var(--font-sans);border:none;padding:8px 16px}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.color-picker{flex-wrap:wrap;gap:6px;display:flex}.color-swatch{cursor:pointer;width:28px;height:28px;transition:all var(--transition);border:2px solid #0000;border-radius:50%}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-elevated), 0 0 0 4px currentColor}.icon-picker{flex-wrap:wrap;gap:4px;display:flex}.icon-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-surface);cursor:pointer;width:32px;height:32px;transition:all var(--transition);justify-content:center;align-items:center;font-size:16px;display:flex}.icon-btn:hover{border-color:var(--accent);background:var(--accent-muted)}.icon-btn.active{border-color:var(--accent);background:var(--accent-muted);box-shadow:0 0 0 1px var(--accent)}.history-panel{background:var(--bg-secondary);border-left:1px solid var(--border);width:280px;max-width:85vw;height:100vh;box-shadow:var(--shadow-lg);z-index:100;flex-direction:column;transition:transform .2s ease-out;display:flex;position:fixed;top:0;right:0;transform:translate(100%)}.history-panel.open{transform:translate(0)}.history-panel.hidden{transform:translate(100%);display:flex!important}.history-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px;display:flex}.history-header h3{color:var(--text-primary);margin:0;font-size:14px;font-weight:600}.history-list{flex:1;padding:12px;overflow-y:auto}.history-item{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);align-items:flex-start;gap:10px;padding:8px;display:flex;position:relative}.history-item:hover{background:var(--bg-hover)}.history-item+.history-item{margin-top:2px}.history-item:before{content:"";background:var(--border);width:1px;position:absolute;top:28px;bottom:-10px;left:16px}.history-item:last-child:before{display:none}.history-dot{border:2px solid var(--border);background:var(--bg-secondary);z-index:1;border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:3px}.history-item.current .history-dot{background:var(--accent);border-color:var(--accent)}.history-item.checkpoint .history-dot{background:var(--warning);border-color:var(--warning)}.history-info{flex:1;min-width:0}.history-time{color:var(--text-secondary);font-size:11px;font-weight:500}.history-label{color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:10px;overflow:hidden}.btn-checkpoint{border-radius:var(--radius-md);border:1px dashed var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-size:12px;font-family:var(--font-sans);background:0 0;flex-shrink:0;margin:8px 12px 12px;padding:8px}.btn-checkpoint:hover{border-color:var(--warning);color:var(--warning);background:#f59e0b1a}.history-empty{text-align:center;color:var(--text-tertiary);padding:32px 16px;font-size:12px}.diff-dialog{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);width:700px;max-width:calc(100vw - 32px);max-height:80vh;box-shadow:var(--shadow-lg);z-index:1;flex-direction:column;display:flex;position:relative}.diff-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.diff-header h2{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.diff-content{font-family:var(--font-mono);flex:1;padding:16px;font-size:12px;line-height:1.6;overflow-y:auto}.diff-line{border-radius:2px;padding:1px 8px}.diff-line.added{color:var(--success);background:#22c55e1f}.diff-line.removed{color:var(--error);background:#ef44441a}.diff-line.unchanged{color:var(--text-tertiary)}.diff-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:12px 20px;display:flex}.save-status{color:var(--text-tertiary);align-items:center;gap:4px;font-size:11px;display:inline-flex}.save-status.cloud{color:var(--success)}.save-status.saving{color:var(--accent)}.save-status.unsaved{color:var(--warning)}.btn-my-diagrams{gap:6px}.btn-history{padding:5px 7px}@media (width<=768px){.sidebar{width:100vw;max-width:100vw}.sidebar-grid{grid-template-columns:1fr 1fr}.btn-my-diagrams span,.btn-history span{display:none}}@media (width<=480px){.sidebar-grid{grid-template-columns:1fr}.diagram-card-thumb{height:60px}}
