@font-face{font-family:Geist;src:url(/assets/GeistVF-CrgPqtmy.woff2) format("woff2");font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:Geist Mono;src:url(/assets/GeistMonoVF-BNLlm6Cd.woff2) format("woff2");font-weight:100 900;font-style:normal;font-display:swap}*{margin:0;padding:0;box-sizing:border-box}:root,[data-theme=dark]{--bg-0: #08080c;--bg-1: #0a0a0f;--bg-2: #0e0e14;--bg-3: #13131a;--bg-4: #191920;--bg-5: #1e1e26;--surface: #24242e;--border: rgba(255, 255, 255, .06);--border-hi: rgba(255, 255, 255, .1);--fg: #c9ccd6;--fg-2: #9a9db0;--fg-3: #6a6e80;--fg-4: #3e4155;--accent: #7c6af6;--accent-dim: rgba(124, 106, 246, .12);--accent-fg: #a89afc;--green: #4ec9b0;--green-dim: rgba(78, 201, 176, .12);--red: #f14c4c;--red-dim: rgba(241, 76, 76, .08);--yellow: #e5c07b;--radius: 6px;--radius-sm: 4px;--font-sans: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "Geist Mono", "Fira Code", "Cascadia Code", monospace;--transition: .15s cubic-bezier(.4, 0, .2, 1)}[data-theme=light]{--bg-0: #e8e6e1;--bg-1: #f0eeea;--bg-2: #e4e2dd;--bg-3: #dad8d3;--bg-4: #d0cec9;--bg-5: #c8c6c1;--surface: #dcdad5;--border: rgba(0, 0, 0, .08);--border-hi: rgba(0, 0, 0, .13);--fg: #2c2c2c;--fg-2: #555555;--fg-3: #888888;--fg-4: #aaaaaa;--accent: #6c5ce7;--accent-dim: rgba(108, 92, 231, .1);--accent-fg: #5a4bd1;--green: #2d8a56;--green-dim: rgba(45, 138, 86, .1);--red: #c0392b;--red-dim: rgba(192, 57, 43, .08);--yellow: #d4880f}html,body,#root{height:100%;background:var(--bg-0);color:var(--fg);font-family:var(--font-sans);font-size:13px;overflow:hidden;-webkit-font-smoothing:antialiased}.app{display:grid;grid-template-columns:48px auto 1fr;grid-template-rows:38px 1fr 24px;height:100vh}.navbar{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;padding:0 12px;background:var(--bg-2);border-bottom:1px solid var(--border);z-index:20}.navbar-left,.navbar-right,.navbar-center{display:flex;align-items:center;gap:8px}.navbar-brand{display:flex;align-items:center;gap:6px;font-weight:600;font-size:13px;color:var(--accent-fg);letter-spacing:-.2px}.navbar-file{font-size:12px;color:var(--fg-3)}.navbar-status{font-size:10px;padding:1px 6px;border-radius:3px;font-weight:500}.navbar-status.compiling{color:var(--accent-fg);background:var(--accent-dim)}.navbar-status.ok{color:var(--green);background:var(--green-dim)}.navbar-status.err{color:var(--red);background:var(--red-dim)}.navbar-peers{display:flex;align-items:center;gap:3px}.navbar-peers-count{font-size:11px;color:var(--fg-3);margin-left:2px}.navbar-btn{display:flex;align-items:center;justify-content:center;width:30px;height:28px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--fg-3);cursor:pointer;transition:all var(--transition)}.navbar-btn:hover:not(:disabled){background:#8080801f;color:var(--fg)}.navbar-btn:disabled{opacity:.25;cursor:default}.activity-bar{grid-row:2 / 3;display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:8px 0;background:var(--bg-0);border-right:1px solid var(--border);z-index:10}.activity-top,.activity-bottom{display:flex;flex-direction:column;align-items:center;gap:4px}.activity-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:var(--radius);background:transparent;color:var(--fg-3);cursor:pointer;transition:all var(--transition);position:relative}.activity-btn:hover{color:var(--fg-2);background:var(--surface)}.activity-btn.active{color:var(--fg)}.activity-btn.active:before{content:"";position:absolute;left:-6px;top:8px;bottom:8px;width:2px;border-radius:1px;background:var(--accent)}.activity-btn:disabled{opacity:.25;cursor:default}.sidebar{grid-row:2;width:200px;background:var(--bg-2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px 8px 16px;font-size:11px;font-weight:600;letter-spacing:.8px;color:var(--fg-3)}.sidebar-header-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--fg-3);cursor:pointer;transition:all var(--transition)}.sidebar-header-btn:hover{background:#ffffff0f;color:var(--fg)}.sidebar-search{display:flex;align-items:center;gap:6px;margin:0 8px 4px;padding:5px 8px;background:var(--bg-4);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--fg-3);transition:border-color var(--transition)}.sidebar-search:focus-within{border-color:var(--accent)}.sidebar-search-input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:var(--fg);font-family:var(--font-sans);font-size:12px}.sidebar-search-input::placeholder{color:var(--fg-4)}.sidebar-list{flex:1;padding:0 4px;overflow-y:auto}.tree-item{display:flex;align-items:center;gap:4px;width:100%;padding:4px 8px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--fg-2);font-family:var(--font-sans);font-size:12px;cursor:pointer;transition:background var(--transition);text-align:left}.tree-item:hover{background:#ffffff0a;color:var(--fg)}.tree-active{background:var(--accent-dim)!important;color:var(--fg)!important}.tree-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-folder{color:var(--fg-3)}.sidebar-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--fg-2);font-family:var(--font-sans);font-size:12px;cursor:pointer;transition:all var(--transition);text-align:left}.sidebar-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-rename{padding:2px 8px}.sidebar-rename-input{width:100%;padding:5px 8px;background:var(--bg-4);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--fg);font-family:var(--font-sans);font-size:12px;outline:none}.sidebar-item:hover{background:#ffffff0a;color:var(--fg)}.sidebar-item-active{background:var(--accent-dim);color:var(--fg)}.sidebar-create{display:flex;align-items:center;padding:4px 8px;gap:0}.sidebar-create-input{flex:1;min-width:0;padding:4px 6px;background:var(--bg-4);border:1px solid var(--accent);border-radius:var(--radius-sm) 0 0 var(--radius-sm);color:var(--fg);font-family:var(--font-mono);font-size:12px;outline:none}.sidebar-create-input::placeholder{color:var(--fg-4)}.sidebar-create-ext{padding:4px 6px;background:var(--bg-5);border:1px solid var(--accent);border-left:none;border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--fg-3);font-family:var(--font-mono);font-size:12px}.sidebar-empty{padding:16px;text-align:center;color:var(--fg-4);font-size:12px}.editor-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--fg-4)}.editor-empty p{color:var(--fg-3);font-size:14px}.editor-empty-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border-hi);border-radius:var(--radius);background:var(--surface);color:var(--fg);font-size:13px;cursor:pointer;transition:all var(--transition)}.editor-empty-btn:hover{background:var(--bg-5);border-color:var(--accent)}.main-area{grid-row:2;display:flex;min-width:0;min-height:0;overflow:hidden}.editor-section{display:flex;flex-direction:column;min-width:0;overflow:hidden}.editor-tabs{display:flex;height:35px;background:var(--bg-2);border-bottom:1px solid var(--border);flex-shrink:0}.editor-tab{display:flex;align-items:center;gap:6px;padding:0 14px;height:100%;background:var(--bg-2);color:var(--fg-3);font-size:12px;border-right:1px solid var(--border);position:relative}.editor-tab.active{background:var(--bg-1);color:var(--fg)}.editor-mode-toggle{display:flex;align-items:center;gap:4px;margin-left:auto;padding:0 10px;height:100%;border:none;background:transparent;color:var(--fg-4);font-family:var(--font-sans);font-size:11px;cursor:pointer;transition:all var(--transition)}.editor-mode-toggle:hover{color:var(--fg-2);background:#8080800f}.editor-mode-toggle.form{color:var(--accent-fg)}.editor-mode-toggle.typ{color:var(--fg-3)}.form-editor{flex:1;overflow-y:auto;padding:16px 20px;background:var(--bg-1)}.form-empty{padding:32px 16px;text-align:center;color:var(--fg-4);font-size:13px;display:flex;flex-direction:column;align-items:center;gap:8px}.form-empty p{color:var(--fg-3);margin:0}.form-empty span{font-size:11px}.form-hint-code{text-align:left;padding:12px;margin-top:8px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:11px;line-height:1.5;color:var(--fg-2);white-space:pre;overflow-x:auto;max-width:100%}.form-fields{display:flex;flex-direction:column;gap:12px}.form-field{display:flex;flex-direction:column;gap:4px}.form-label{font-size:11px;font-weight:500;color:var(--fg-3);text-transform:capitalize}.form-label.required:after{content:" *";color:var(--red)}.form-input{width:100%;padding:8px 10px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--fg);font-family:var(--font-sans);font-size:13px;outline:none;transition:border-color var(--transition)}.form-input:hover{border-color:var(--border-hi)}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--fg-4)}.form-textarea{resize:vertical;min-height:60px;line-height:1.5}.svg-preview{flex:1;overflow:auto;display:flex;align-items:flex-start;justify-content:center;padding:24px 20px}.svg-preview>svg{max-width:100%;height:auto;border-radius:4px;box-shadow:0 0 0 1px #ffffff0a,0 4px 20px #00000073}.editor-tab.active:after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--accent)}.breadcrumb{display:flex;align-items:center;gap:4px;padding:4px 16px;background:var(--bg-1);border-bottom:1px solid var(--border);flex-shrink:0}.breadcrumb-item{font-size:11px;color:var(--fg-3)}.breadcrumb-item.current{color:var(--fg-2)}.editor-wrap{flex:1;min-height:0;position:relative;display:flex;flex-direction:column}.editor-wrap>div{flex:1;min-height:0;display:flex;flex-direction:column}.editor-wrap .cm-editor{flex:1;min-height:0;background:var(--bg-1)}.editor-wrap .cm-editor .cm-scroller{font-family:var(--font-mono);font-size:13px;line-height:1.65;padding-top:4px;overflow:auto!important}.editor-wrap .cm-editor .cm-content{padding:0 0 0 4px}.editor-wrap .cm-editor .cm-gutters{background:var(--bg-1);border-right:none;padding-right:4px}.editor-wrap .cm-editor .cm-lineNumbers .cm-gutterElement{color:var(--fg-4);font-size:12px;padding:0 8px 0 16px;min-width:3ch}.editor-wrap .cm-editor .cm-activeLine,.editor-wrap .cm-editor .cm-activeLineGutter{background:#ffffff05}.editor-wrap .cm-editor .cm-activeLineGutter .cm-gutterElement{color:var(--fg-3)}.editor-wrap .cm-editor .cm-cursor{border-left:2px solid var(--accent-fg)}.editor-wrap .cm-editor .cm-selectionBackground{background:#7c6af626!important}.editor-wrap .cm-editor.cm-focused .cm-selectionBackground{background:#7c6af633!important}.editor-wrap .cm-editor .cm-matchingBracket{background:#7c6af633;outline:1px solid rgba(124,106,246,.3)}.editor-wrap .cm-editor .cm-foldGutter .cm-gutterElement{color:var(--fg-4)}.problems-panel{flex-shrink:0;max-height:180px;background:var(--bg-2);border-top:1px solid var(--border)}.problems-header{display:flex;align-items:center;gap:8px;padding:6px 14px;font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--fg-3);border-bottom:1px solid var(--border)}.problems-count{font-size:10px;font-weight:500;color:var(--red);background:var(--red-dim);padding:0 5px;border-radius:8px;min-width:16px;text-align:center}.problems-body{padding:8px 14px;color:var(--red);font-family:var(--font-mono);font-size:12px;line-height:1.5;white-space:pre-wrap;word-break:break-word;overflow-y:auto;max-height:140px}.splitter{width:5px;cursor:col-resize;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--bg-2);transition:background var(--transition);position:relative}.splitter-line{width:1px;height:100%;background:var(--border);transition:background var(--transition),width var(--transition)}.splitter:hover .splitter-line{width:2px;background:var(--accent);border-radius:1px}.splitter:after{content:"";position:absolute;top:0;left:-4px;right:-4px;bottom:0}.preview-section{display:flex;flex-direction:column;min-width:0;overflow:hidden;background:var(--bg-3)}.preview-header{display:flex;align-items:center;justify-content:space-between;height:35px;padding:0 12px;background:var(--bg-2);border-bottom:1px solid var(--border);flex-shrink:0}.preview-title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--fg-2)}.preview-badge{font-size:9px;font-weight:600;letter-spacing:.5px;padding:1px 5px;border-radius:3px}.preview-badge.live{background:var(--green-dim);color:var(--green)}.preview-badge.compiling{background:var(--accent-dim);color:var(--accent-fg);animation:pulse 1s ease-in-out infinite}.preview-badge.err{background:var(--red-dim);color:var(--red)}.preview-badge.saved{background:#ffffff0a;color:var(--fg-3)}.preview-actions{display:flex;align-items:center;gap:2px}.preview-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--fg-3);cursor:pointer;transition:all var(--transition)}.preview-btn:hover:not(:disabled){background:#ffffff0f;color:var(--fg)}.preview-btn:disabled{opacity:.2;cursor:default}.compile-indicator{display:flex;align-items:center;padding:0 6px}.compile-spinner{width:10px;height:10px;border:1.5px solid var(--fg-4);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.compile-indicator.compiled{color:var(--green)}.preview-body{flex:1;min-height:0;overflow:hidden;display:flex;background:var(--bg-1)}.pdf-pages{flex:1;overflow-y:overlay;overflow-x:hidden;display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 20px}.pdf-page{width:100%;max-width:680px;border-radius:4px;overflow:hidden;box-shadow:0 0 0 1px #ffffff0a,0 4px 20px #00000073,0 12px 40px #00000040;background:#fff;flex-shrink:0}.pdf-page canvas{display:block;width:100%;height:auto}.pdf-pages::-webkit-scrollbar{width:6px}.pdf-pages::-webkit-scrollbar-track{background:transparent;margin:4px 0}.pdf-pages::-webkit-scrollbar-thumb{background:#7c6af600;border-radius:3px;transition:background .3s}.pdf-pages:hover::-webkit-scrollbar-thumb{background:#7c6af640}.pdf-pages:hover::-webkit-scrollbar-thumb:hover{background:#7c6af673}.pdf-pages::-webkit-scrollbar-corner{background:transparent}.preview-error{flex:1;display:flex;flex-direction:column;align-items:center;padding:32px 20px;gap:10px;overflow-y:auto}.preview-error-icon{color:var(--red);opacity:.6}.preview-error-title{font-size:13px;font-weight:500;color:var(--red)}.preview-error-body{width:100%;max-width:500px;padding:12px 16px;background:var(--red-dim);border:1px solid rgba(241,76,76,.15);border-radius:var(--radius);color:var(--fg-2);font-family:var(--font-mono);font-size:12px;line-height:1.6;white-space:pre-wrap;word-break:break-word;overflow-y:auto;max-height:60vh}.preview-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--fg-4)}.preview-empty p{font-size:13px;color:var(--fg-3)}.preview-empty span{font-size:11px}.statusbar{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;padding:0 12px;background:var(--bg-0);border-top:1px solid var(--border)}.statusbar-left,.statusbar-right{display:flex;align-items:center;gap:4px}.statusbar-item{font-size:11px;color:var(--fg-4);padding:0 4px}.statusbar-sep{width:1px;height:10px;background:var(--fg-4);opacity:.3}.compiling-text{color:var(--accent-fg)}.error-text{color:var(--red)}.ok-text{color:var(--green)}.ctx-menu{position:fixed;z-index:200;min-width:160px;background:var(--bg-3);border:1px solid var(--border-hi);border-radius:var(--radius);padding:4px 0;box-shadow:0 8px 24px #0006;animation:scaleIn .1s ease-out}.ctx-item{display:flex;align-items:center;width:100%;padding:6px 14px;border:none;background:transparent;color:var(--fg-2);font-family:var(--font-sans);font-size:12px;cursor:pointer;text-align:left;transition:background var(--transition)}.ctx-item:hover{background:var(--accent-dim);color:var(--fg)}.ctx-item.danger{color:var(--red)}.ctx-item.danger:hover{background:var(--red-dim)}.ctx-sep{height:1px;margin:4px 8px;background:var(--border)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff24}::-webkit-scrollbar-corner{background:transparent}.sidebar{animation:slideIn .15s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.problems-panel{animation:slideUp .15s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.yRemoteSelection{opacity:.25}.yRemoteSelectionHead{position:absolute;border-left:2px solid;border-color:inherit}.yRemoteSelectionHead:after{content:attr(data-user);position:absolute;top:-1.4em;left:-1px;padding:1px 6px;font-size:10px;font-family:var(--font-sans);font-weight:500;border-radius:3px 3px 3px 0;white-space:nowrap;color:#fff;background-color:inherit;line-height:1.4}.peers-avatars{display:flex;align-items:center;gap:2px;margin-left:6px}.peer-dot{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--bg-1);flex-shrink:0}.cm-editor .cm-tooltip-autocomplete{background:var(--bg-3)!important;border:1px solid var(--border-hi)!important;border-radius:var(--radius)!important;box-shadow:0 8px 24px #0000004d!important}.cm-editor .cm-tooltip-autocomplete>ul{font-family:var(--font-sans)!important;font-size:12px!important}.cm-editor .cm-tooltip-autocomplete>ul>li{padding:3px 8px!important;color:var(--fg-2)!important}.cm-editor .cm-tooltip-autocomplete>ul>li[aria-selected]{background:var(--accent-dim)!important;color:var(--fg)!important}.cm-editor .cm-completionLabel{color:var(--fg)!important}.cm-editor .cm-completionDetail{color:var(--fg-3)!important;font-style:italic;margin-left:8px}.share-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .1s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.share-dialog{width:400px;max-width:90vw;background:var(--bg-3);border:1px solid var(--border-hi);border-radius:10px;overflow:hidden;box-shadow:0 16px 48px #00000080;animation:scaleIn .15s ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.share-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;font-size:13px;font-weight:500;color:var(--fg);border-bottom:1px solid var(--border)}.share-close{background:none;border:none;color:var(--fg-3);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.share-close:hover{color:var(--fg)}.share-create{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border)}.share-mode-toggle{display:flex;border:1px solid var(--border-hi);border-radius:var(--radius);overflow:hidden;flex:1}.share-mode-btn{flex:1;padding:6px 0;border:none;background:var(--bg-4);color:var(--fg-3);font-size:12px;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition)}.share-mode-btn+.share-mode-btn{border-left:1px solid var(--border)}.share-mode-btn.active{background:var(--accent-dim);color:var(--accent-fg)}.share-create-btn{padding:6px 14px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:12px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition);white-space:nowrap}.share-create-btn:hover{opacity:.9}.share-list{max-height:200px;overflow-y:auto}.share-entry{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border)}.share-entry:last-child{border-bottom:none}.share-entry-info{display:flex;align-items:center;gap:8px}.share-entry-mode{font-size:10px;font-weight:500;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.share-entry-mode.view{background:#4ec9b01f;color:var(--green)}.share-entry-mode.edit{background:var(--accent-dim);color:var(--accent-fg)}.share-entry-date{font-size:11px;color:var(--fg-4)}.share-entry-actions{display:flex;gap:4px}.share-entry-btn{padding:3px 8px;border:1px solid var(--border-hi);border-radius:var(--radius-sm);background:transparent;color:var(--fg-3);font-size:11px;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition)}.share-entry-btn:hover{background:#ffffff0f;color:var(--fg)}.share-entry-btn.delete:hover{color:var(--red);border-color:#f14c4c4d}.share-empty{padding:20px 16px;text-align:center;color:var(--fg-4);font-size:12px}.share-page{display:grid;grid-template-rows:36px 1fr 24px;height:100vh}.share-banner{display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:var(--bg-2);border-bottom:1px solid var(--border)}.share-banner-left{display:flex;align-items:center;gap:10px}.share-banner-right{display:flex;align-items:center;gap:6px}.share-banner-file{font-size:13px;font-weight:500;color:var(--fg)}.share-banner-mode{font-size:10px;font-weight:500;padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.share-banner-mode.view{background:#4ec9b01f;color:var(--green)}.share-banner-mode.edit{background:var(--accent-dim);color:var(--accent-fg)}.share-banner-peers{font-size:11px;color:var(--green)}.share-panels{display:flex;min-height:0}.share-editor{flex:1;min-width:0;overflow:hidden}.share-editor .cm-editor{height:100%;background:var(--bg-1)}.share-editor .cm-editor .cm-scroller{font-family:var(--font-mono);font-size:13px;line-height:1.65}.share-editor .cm-editor .cm-gutters{background:var(--bg-1);border-right:none}.share-editor .cm-editor .cm-lineNumbers .cm-gutterElement{color:var(--fg-4);font-size:12px}.share-preview{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--bg-1);border-left:1px solid var(--border)}.share-not-found{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--fg-3);font-size:14px}.share-not-found h2{color:var(--fg);font-size:18px;font-weight:500}.navbar-btn-active{color:var(--accent-fg)!important;background:var(--accent-dim)!important}.ai-panel{width:320px;flex-shrink:0;display:flex;flex-direction:column;background:var(--bg-2);border-left:1px solid var(--border);animation:slideInRight .15s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.ai-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.ai-title{font-size:12px;font-weight:500;color:var(--fg-2)}.ai-header-actions{display:flex;align-items:center;gap:2px}.ai-header-btn{display:flex;align-items:center;justify-content:center;gap:4px;width:auto;padding:4px 6px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--fg-3);cursor:pointer;transition:all var(--transition);position:relative}.ai-header-btn:hover{background:#8080801f;color:var(--fg)}.ai-key-dot{width:6px;height:6px;border-radius:50%}.ai-key-dot.ok{background:var(--green)}.ai-key-dot.missing{background:var(--red)}.ai-key-form{display:flex;gap:6px;padding:8px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.ai-key-input{flex:1;min-width:0;padding:5px 8px;background:var(--bg-4);border:1px solid var(--border-hi);border-radius:var(--radius-sm);color:var(--fg);font-family:var(--font-mono);font-size:11px;outline:none}.ai-key-input:focus{border-color:var(--accent)}.ai-key-input::placeholder{color:var(--fg-4)}.ai-key-save{padding:5px 10px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:11px;font-weight:500;font-family:var(--font-sans);cursor:pointer}.ai-key-save:hover{opacity:.9}.ai-model-select{width:100%;padding:5px 8px;background:var(--bg-4);border:1px solid var(--border-hi);border-radius:var(--radius-sm);color:var(--fg);font-family:var(--font-sans);font-size:11px;outline:none}.ai-model-select:focus{border-color:var(--accent)}.ai-status-bar{padding:4px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.ai-backend-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:500;padding:2px 8px;border-radius:3px;letter-spacing:.3px}.ai-backend-badge.cli{background:var(--green-dim);color:var(--green)}.ai-backend-badge.api{background:var(--accent-dim);color:var(--accent-fg)}.ai-backend-badge.none{background:var(--red-dim);color:var(--red)}.ai-settings-panel{padding:10px 12px;border-bottom:1px solid var(--border);flex-shrink:0;animation:slideUp .1s ease-out}.ai-settings-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.ai-settings-label{font-size:11px;color:var(--fg-3)}.ai-settings-value{font-size:11px;color:var(--fg-4)}.ai-settings-value.ok{color:var(--green)}.ai-settings-divider{height:1px;background:var(--border);margin:6px 0}.ai-history{flex:1;overflow-y:auto;padding:8px}.ai-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px 16px;gap:6px}.ai-empty p{color:var(--fg-3);font-size:12px}.ai-empty span{color:var(--fg-4);font-size:11px;line-height:1.4}.ai-examples{display:flex;flex-direction:column;gap:4px;margin-top:8px;width:100%}.ai-example{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--fg-3);font-family:var(--font-sans);font-size:11px;text-align:left;cursor:pointer;transition:all var(--transition)}.ai-example:hover{background:var(--accent-dim);color:var(--accent-fg);border-color:var(--accent)}.ai-scope-badge{font-size:10px;color:var(--fg-4);margin-left:6px}.ai-settings-info{font-size:11px;color:var(--fg-4);padding:4px 0;line-height:1.4}.ai-msg{margin-bottom:6px}.ai-msg-user{padding:6px 10px;border-radius:var(--radius) var(--radius) var(--radius-sm) var(--radius);background:var(--accent-dim);color:var(--fg);font-size:12px;line-height:1.4;margin-left:24px}.ai-msg-agent{display:flex;align-items:flex-start;gap:6px;padding:6px 10px;border-radius:var(--radius-sm) var(--radius) var(--radius) var(--radius);background:var(--bg-3);border:1px solid var(--border);font-size:12px;line-height:1.4;color:var(--fg-2);margin-right:24px}.ai-msg-text{flex:1;min-width:0;word-break:break-word;white-space:pre-wrap}.ai-msg.error .ai-msg-agent{border-color:#f14c4c33}.ai-msg.error .ai-msg-text{color:var(--red)}.ai-msg-badge{font-size:9px;font-weight:500;padding:1px 5px;border-radius:3px;flex-shrink:0;margin-top:1px}.ai-msg-badge.done{background:var(--green-dim);color:var(--green)}.ai-msg-badge.err{background:var(--red-dim);color:var(--red)}.ai-input-area{display:flex;align-items:flex-end;gap:6px;padding:8px;border-top:1px solid var(--border);flex-shrink:0}.ai-input{flex:1;min-width:0;padding:8px 10px;background:var(--bg-4);border:1px solid var(--border);border-radius:var(--radius);color:var(--fg);font-family:var(--font-sans);font-size:12px;line-height:1.4;resize:none;outline:none}.ai-input:focus{border-color:var(--accent)}.ai-input::placeholder{color:var(--fg-4)}.ai-input:disabled{opacity:.5}.ai-send{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;cursor:pointer;flex-shrink:0;transition:all var(--transition)}.ai-send:hover:not(:disabled){opacity:.9}.ai-send:disabled{opacity:.3;cursor:default}.ai-stop{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px;border:1px solid var(--red);border-radius:var(--radius);background:var(--red-dim);color:var(--red);font-family:var(--font-sans);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition)}.ai-stop:hover{background:#f14c4c26}.ai-streaming-dot{width:6px;height:6px;border-radius:50%;background:var(--accent-fg);animation:pulse 1s ease-in-out infinite;margin-left:4px}.ai-logout-btn{border:none;background:transparent;color:var(--fg-4);font-family:var(--font-sans);font-size:10px;cursor:pointer;padding:1px 4px;margin-left:4px}.ai-logout-btn:hover{color:var(--red);text-decoration:underline}.ai-connect-icon{color:var(--accent);opacity:.5;margin-bottom:4px}.ai-connect-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;margin-top:8px;border:1px solid var(--accent);border-radius:var(--radius);background:var(--accent-dim);color:var(--accent-fg);font-family:var(--font-sans);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition)}.ai-connect-btn:hover:not(:disabled){background:#7c6af633}.ai-connect-btn:disabled{opacity:.7;cursor:default}.ai-code-form{display:flex;gap:6px;width:100%;margin-top:10px}.ai-code-input{flex:1;min-width:0;padding:8px 10px;background:var(--bg-4);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--fg);font-family:var(--font-mono);font-size:12px;outline:none}.ai-code-input::placeholder{color:var(--fg-4)}.ai-code-input:focus{border-color:var(--accent-fg);box-shadow:0 0 0 2px var(--accent-dim)}.ai-code-submit{padding:8px 14px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:12px;font-weight:500;font-family:var(--font-sans);cursor:pointer;white-space:nowrap}.ai-code-submit:hover:not(:disabled){opacity:.9}.ai-code-submit:disabled{opacity:.4}.ai-cmd{display:block;width:100%;padding:6px 10px;margin-top:6px;background:var(--bg-4);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:11px;color:var(--accent-fg);text-align:center;-webkit-user-select:all;user-select:all}.ai-cred-input{width:100%;padding:8px;margin-top:8px;background:var(--bg-4);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--fg);font-family:var(--font-mono);font-size:10px;line-height:1.4;resize:vertical;outline:none}.ai-cred-input:focus{border-color:var(--accent)}.ai-cred-input::placeholder{color:var(--fg-4)}.ai-connect-error{font-size:11px;color:var(--red);margin-top:4px}.ai-connect-link-primary{display:flex;align-items:center;justify-content:center;width:100%;padding:8px 14px;margin-top:6px;border:1px solid var(--accent);border-radius:var(--radius);background:var(--accent-dim);color:var(--accent-fg);font-size:12px;font-weight:500;font-family:var(--font-sans);text-decoration:none;transition:all var(--transition)}.ai-connect-link-primary:hover{background:#7c6af633}.ai-file-context{font-size:10px;color:var(--fg-4);margin-left:auto;font-family:var(--font-mono)}.ai-msg-tool{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-sm);background:#4ec9b00f;border-left:2px solid var(--green);font-size:11px;color:var(--fg-3)}.ai-tool-icon{color:var(--green);display:flex;flex-shrink:0}.ai-tool-name{font-weight:500;color:var(--green);white-space:nowrap}.ai-tool-detail{color:var(--fg-4);font-family:var(--font-mono);font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-msg-error-text{color:var(--red)!important}.ai-msg-applied{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--radius-sm);background:var(--green-dim);color:var(--green);font-size:12px;font-weight:500}.ai-skeleton{display:flex;flex-direction:column;gap:6px;width:100%;padding:2px 0}.ai-skeleton-line{height:10px;border-radius:4px;background:linear-gradient(90deg,var(--bg-4) 25%,var(--bg-5) 50%,var(--bg-4) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ai-writing .cm-editor .cm-cursor{border-left:3px solid var(--accent-fg)!important;animation:cursorPulse .8s ease-in-out infinite}@keyframes cursorPulse{0%,to{opacity:1;border-left-color:var(--accent-fg)}50%{opacity:.5;border-left-color:var(--accent)}}.ai-writing .cm-editor:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,transparent 0%,rgba(124,106,246,.03) 30%,rgba(124,106,246,.05) 60%,transparent 100%);animation:scanDown 2s ease-in-out infinite;z-index:5}@keyframes scanDown{0%{transform:translateY(-100%)}to{transform:translateY(100%)}}.ai-writing .cm-editor{position:relative;overflow:hidden}.ai-writing~.editor-tabs .editor-tab.active:after,.editor-wrap.ai-writing+.splitter{background:var(--accent-fg);animation:accentPulse 1s ease-in-out infinite}@keyframes accentPulse{0%,to{opacity:1}50%{opacity:.4}}.export-menu{position:absolute;top:100%;right:0;margin-top:4px;min-width:130px;background:var(--bg-3);border:1px solid var(--border-hi);border-radius:var(--radius);padding:4px 0;box-shadow:0 8px 24px #0006;z-index:50;animation:scaleIn .1s ease-out}.export-menu button{display:block;width:100%;padding:6px 14px;border:none;background:transparent;color:var(--fg-2);font-family:var(--font-sans);font-size:12px;text-align:left;cursor:pointer;transition:background var(--transition)}.export-menu button:hover{background:var(--accent-dim);color:var(--fg)}.version-panel{width:320px;flex-shrink:0;display:flex;flex-direction:column;background:var(--bg-2);border-left:1px solid var(--border);animation:slideInRight .15s ease-out}.version-save{display:flex;gap:6px;padding:8px;border-bottom:1px solid var(--border);flex-shrink:0}.version-save-input{flex:1;min-width:0;padding:5px 8px;background:var(--bg-4);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--fg);font-family:var(--font-sans);font-size:11px;outline:none}.version-save-input:focus{border-color:var(--accent)}.version-save-input::placeholder{color:var(--fg-4)}.version-save-btn{padding:5px 10px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:11px;font-weight:500;font-family:var(--font-sans);cursor:pointer}.version-save-btn:disabled{opacity:.5}.version-list{flex:1;overflow-y:auto;padding:4px}.version-item{padding:8px 10px;margin-bottom:4px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-3)}.version-item-active{border-color:var(--accent)}.version-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px}.version-time{font-size:11px;font-weight:500;color:var(--fg-2)}.version-msg{flex:1;font-size:11px;color:var(--fg-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.version-size{font-size:10px;color:var(--fg-4)}.version-actions{display:flex;gap:4px}.version-action-btn{padding:2px 8px;border:1px solid var(--border-hi);border-radius:var(--radius-sm);background:transparent;color:var(--fg-3);font-size:10px;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition)}.version-action-btn:hover{background:#ffffff0f;color:var(--fg)}.version-action-btn.restore:hover{background:var(--accent-dim);color:var(--accent-fg)}.version-diff{margin-top:6px;padding:8px;background:var(--bg-1);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:11px;line-height:1.5;color:var(--fg-2);max-height:200px;overflow:auto;white-space:pre-wrap;word-break:break-word}.login-page{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-0)}.login-card{width:340px;padding:32px;background:var(--bg-3);border:1px solid var(--border-hi);border-radius:12px;box-shadow:0 16px 48px #0006;display:flex;flex-direction:column;gap:12px}.login-header{text-align:center;margin-bottom:8px;color:var(--accent)}.login-header h1{font-size:18px;font-weight:600;color:var(--fg);margin:8px 0 4px}.login-header p{font-size:12px;color:var(--fg-3)}.login-input{padding:10px 12px;background:var(--bg-4);border:1px solid var(--border);border-radius:var(--radius);color:var(--fg);font-family:var(--font-sans);font-size:13px;outline:none}.login-input:focus{border-color:var(--accent)}.login-input::placeholder{color:var(--fg-4)}.login-error{font-size:12px;color:var(--red);text-align:center}.login-btn{padding:10px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:13px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition)}.login-btn:hover:not(:disabled){opacity:.9}.login-btn:disabled{opacity:.5}.login-toggle{border:none;background:transparent;color:var(--accent-fg);font-size:11px;font-family:var(--font-sans);cursor:pointer;text-align:center}.login-toggle:hover{text-decoration:underline}.navbar-user{font-size:11px;color:var(--fg-3);padding:0 4px}.version-trigger{font-size:9px;padding:1px 4px;border-radius:3px;background:#ffffff0a;color:var(--fg-4)}
