@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&family=Sora:wght@300;400;500;600&display=swap";pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}.hljs{background:#1e1e1e;color:#dcdcdc}.hljs-keyword,.hljs-literal,.hljs-symbol,.hljs-name{color:#569cd6}.hljs-link{color:#569cd6;text-decoration:underline}.hljs-built_in,.hljs-type{color:#4ec9b0}.hljs-number,.hljs-class{color:#b8d7a3}.hljs-string,.hljs-meta .hljs-string{color:#d69d85}.hljs-regexp,.hljs-template-tag{color:#9a5334}.hljs-subst,.hljs-function,.hljs-title,.hljs-params,.hljs-formula{color:#dcdcdc}.hljs-comment,.hljs-quote{color:#57a64a;font-style:italic}.hljs-doctag{color:#608b4e}.hljs-meta,.hljs-meta .hljs-keyword,.hljs-tag{color:#9b9b9b}.hljs-variable,.hljs-template-variable{color:#bd63c5}.hljs-attr,.hljs-attribute{color:#9cdcfe}.hljs-section{color:gold}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-bullet,.hljs-selector-tag,.hljs-selector-id,.hljs-selector-class,.hljs-selector-attr,.hljs-selector-pseudo{color:#d7ba7d}.hljs-addition{background-color:#144212;display:inline-block;width:100%}.hljs-deletion{background-color:#600;display:inline-block;width:100%}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #141414;--bg2: #1c1c1c;--bg3: #232323;--bg4: #2b2b2b;--bg5: #333333;--border: #2a2a2a;--border2: #383838;--text: #e8e8e8;--text2: #a8a8a8;--text3: #636363;--accent: #c46b4a;--accent2: #a85a3c;--accent3: #e0a38a;--green: #5f9e6f;--red: #c16767;--amber: #bfa14a;--font: "JetBrains Mono", "Fira Code", monospace;--sans: "Sora", -apple-system, BlinkMacSystemFont, sans-serif;--sidebar-w: 256px;--topbar-h: 46px;--statusbar-h: 26px;--radius: 6px}html,body,#root{height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--sans)}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--text3)}.auth-page{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);background-image:radial-gradient(ellipse 50% 50% at 80% 20%,rgba(196,107,74,.06) 0%,transparent 60%),radial-gradient(ellipse 40% 60% at 10% 90%,rgba(90,130,180,.04) 0%,transparent 60%);padding:16px}.auth-card{background:var(--bg2);border:1px solid var(--border2);border-radius:14px;padding:36px 40px;width:100%;max-width:400px;box-shadow:0 32px 80px #0009}@media (max-width: 480px){.auth-card{padding:28px 24px;border-radius:12px}}.auth-logo{font-family:var(--font);font-size:18px;font-weight:600;color:var(--accent3);letter-spacing:-.5px;margin-bottom:28px;text-align:center}.auth-logo span{color:var(--bg5)}.auth-card h2{font-size:14px;font-weight:500;color:var(--text);margin-bottom:20px}.auth-field{margin-bottom:14px}.auth-field label{display:block;font-size:11px;color:var(--text3);margin-bottom:6px;letter-spacing:.06em;text-transform:uppercase}.auth-field input{width:100%;background:var(--bg3);border:1px solid var(--border2);color:var(--text);padding:10px 14px;border-radius:var(--radius);font-size:14px;font-family:var(--sans);outline:none;transition:border-color .15s,box-shadow .15s}.auth-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #c46b4a1a}.auth-error{font-size:12px;color:var(--red);margin-bottom:14px;padding:9px 12px;background:#c1676714;border-radius:var(--radius);border:1px solid rgba(193,103,103,.2)}.auth-btn{width:100%;background:var(--accent);border:none;color:#fff;padding:11px;border-radius:var(--radius);font-size:14px;font-weight:500;font-family:var(--sans);cursor:pointer;transition:background .15s,transform .1s;margin-top:6px}.auth-btn:hover{background:var(--accent2)}.auth-btn:active{transform:scale(.99)}.auth-btn:disabled{opacity:.4;cursor:not-allowed}.auth-switch{text-align:center;font-size:13px;color:var(--text3);margin-top:18px}.auth-switch button{background:none;border:none;color:var(--accent3);cursor:pointer;font-size:13px;font-family:var(--sans)}.auth-switch button:hover{color:var(--accent)}.app{height:100vh;display:flex;flex-direction:column;overflow:hidden}.mobile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:49;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.topbar{height:var(--topbar-h);display:flex;align-items:center;gap:10px;padding:0 14px;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0;z-index:10}.topbar-hamburger{display:none;background:none;border:none;color:var(--text3);cursor:pointer;padding:6px;border-radius:var(--radius);transition:all .15s}.topbar-hamburger:hover{background:var(--bg4);color:var(--text)}.topbar-sidebar-toggle{background:none;border:none;color:var(--text3);cursor:pointer;padding:5px;border-radius:var(--radius);transition:all .15s;display:flex;align-items:center}.topbar-sidebar-toggle:hover{background:var(--bg4);color:var(--text)}.logo{font-family:var(--font);font-size:13px;font-weight:600;color:var(--text2);letter-spacing:-.2px;white-space:nowrap;flex-shrink:0}.logo span{color:var(--accent);font-size:10px;position:relative;top:-1px}.topbar-center{flex:1;min-width:0;display:flex;align-items:center}.crumbs{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text3);min-width:0;overflow:hidden}.crumb{color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.crumb-sep{color:var(--border2)}.file-title-input{background:none;border:none;color:var(--text);font-size:13px;font-family:var(--sans);font-weight:500;outline:none;min-width:0;max-width:240px;padding:3px 6px;border-radius:4px;transition:background .15s}.file-title-input:hover,.file-title-input:focus{background:var(--bg3)}.topbar-right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}.sync-pill{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text3);min-width:64px}.sync-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.topbtn{display:flex;align-items:center;gap:5px;background:none;border:1px solid var(--border2);color:var(--text2);padding:5px 11px;border-radius:var(--radius);font-size:12px;cursor:pointer;font-family:var(--sans);transition:all .15s;white-space:nowrap}.topbtn:hover{background:var(--bg4);color:var(--text);border-color:var(--border2)}.topbtn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.topbtn.primary:hover{background:var(--accent2)}.topbtn.ghost{border-color:transparent}.topbtn.ghost:hover{border-color:var(--border2)}.user-menu{display:flex;align-items:center;gap:8px}.user-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;flex-shrink:0}.user-name{font-size:12px;color:var(--text3)}.main{display:flex;flex:1;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;transition:width .2s ease,transform .2s ease}.sidebar.collapsed{width:0;border-right:none}.sidebar-top{padding:10px 12px;display:flex;align-items:center;gap:4px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-title{font-size:10px;font-weight:600;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;flex:1}.sidebar-actions{display:flex;gap:1px}.sibtn{background:none;border:none;cursor:pointer;color:var(--text3);width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.sibtn:hover{background:var(--bg4);color:var(--text)}.sidebar-search{display:flex;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-search svg{color:var(--text3);flex-shrink:0}.search-input{flex:1;background:none;border:none;color:var(--text);font-size:12px;font-family:var(--sans);outline:none;min-width:0}.search-input::placeholder{color:var(--text3)}.search-clear{background:none;border:none;color:var(--text3);cursor:pointer;font-size:11px;padding:2px 4px;border-radius:3px;transition:all .15s}.search-clear:hover{background:var(--bg4);color:var(--text)}.tree{flex:1;overflow-y:auto;padding:4px 0}.tree-no-results,.tree-empty-folder{font-size:11px;color:var(--text3);padding:10px 14px;font-style:italic}.tree-item{position:relative;-webkit-user-select:none;user-select:none}.tree-row{display:flex;align-items:center;gap:4px;padding:4px 8px 4px 0;cursor:pointer;transition:background .1s;border-radius:4px;margin:0 4px 1px;min-height:26px}.tree-row:hover{background:var(--bg3)}.tree-row.active{background:#c46b4a1f}.tree-row.active .tree-label{color:var(--accent3)}.tree-row.drag-over{background:#c46b4a1f;outline:1px solid var(--accent);border-radius:4px}.tree-row.dragging{opacity:.3}.folder-arrow{width:14px;height:14px;display:flex;align-items:center;justify-content:center;color:var(--text3);transition:transform .15s;flex-shrink:0}.folder-arrow.open{transform:rotate(90deg)}.folder-icon-wrap{display:flex;align-items:center;flex-shrink:0}.file-icon{font-family:var(--font);font-size:10px;font-weight:600;width:18px;text-align:center;flex-shrink:0;letter-spacing:-.5px}.tree-label{font-size:12.5px;color:var(--text2);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .12s}.tree-label.search-match{color:var(--accent3);font-weight:500}.tree-row:hover .tree-label{color:var(--text)}.tree-badge{font-size:10px;color:var(--text3);background:var(--bg4);padding:1px 5px;border-radius:10px;flex-shrink:0;font-family:var(--font)}.tree-actions{display:none;gap:1px;flex-shrink:0}.tree-row:hover .tree-actions{display:flex}.ta-btn{background:none;border:none;cursor:pointer;color:var(--text3);width:20px;height:20px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .12s;font-family:var(--sans)}.ta-btn:hover{background:var(--bg5);color:var(--text)}.ta-btn.danger:hover{background:#c1676726;color:var(--red)}.tree-inline-rename{flex:1;background:var(--bg3);border:1px solid var(--accent);color:var(--text);padding:1px 5px;border-radius:3px;font-size:12.5px;font-family:var(--sans);outline:none;min-width:0}.tree-children{display:none}.tree-children.open{display:block}.sidebar-footer{padding:8px 12px;border-top:1px solid var(--border);display:flex;gap:12px;font-size:10px;color:var(--text3);flex-shrink:0}.editor-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.toolbar{display:flex;align-items:center;gap:2px;padding:6px 12px;border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap;background:var(--bg2)}.tbtn{background:none;border:1px solid transparent;color:var(--text3);padding:4px 8px;border-radius:4px;font-size:11.5px;cursor:pointer;font-family:var(--font);transition:all .12s;min-width:28px;text-align:center;white-space:nowrap}.tbtn:hover{background:var(--bg3);border-color:var(--border);color:var(--text)}.tbtn-sep{width:1px;height:16px;background:var(--border);margin:0 3px;flex-shrink:0}.editor-wrap{flex:1;display:flex;overflow:hidden}.editor{flex:1;background:var(--bg);color:var(--text);border:none;outline:none;padding:28px 40px;font-family:var(--font);font-size:14px;line-height:1.8;resize:none;-moz-tab-size:2;tab-size:2;overflow-y:auto}.editor::placeholder{color:var(--text3)}@media (max-width: 768px){.editor{padding:20px;font-size:15px}}.preview{flex:1;background:var(--bg);padding:28px 40px;overflow-y:auto;display:none}.preview.visible{display:block}@media (max-width: 768px){.preview{padding:20px}}.preview h1,.preview h2,.preview h3,.preview h4{color:var(--text);font-weight:600;margin:1.5em 0 .5em;line-height:1.3;font-family:var(--sans)}.preview h1{font-size:1.75em;border-bottom:1px solid var(--border);padding-bottom:.4em}.preview h2{font-size:1.35em;border-bottom:1px solid var(--border);padding-bottom:.3em}.preview h3{font-size:1.1em}.preview p{color:var(--text2);margin:.7em 0;line-height:1.8}.preview code{background:var(--bg3);color:var(--accent3);padding:2px 6px;border-radius:4px;font-family:var(--font);font-size:.88em}.preview pre{position:relative;padding:0;background:#1e1e1e;border:1px solid var(--border);border-radius:8px;overflow:hidden;margin:1.2em 0}.preview pre code.hljs{padding:16px 18px;font-size:13px;line-height:1.65;display:block;overflow-x:auto;background:#1e1e1e!important}.preview blockquote{border-left:2px solid var(--accent);padding-left:16px;margin:1em 0;color:var(--text3)}.preview ul,.preview ol{color:var(--text2);padding-left:1.5em;margin:.6em 0}.preview li{margin:.3em 0}.preview a{color:var(--accent3)}.preview hr{border:none;border-top:1px solid var(--border);margin:2em 0}.preview table{border-collapse:collapse;width:100%;margin:1em 0;font-size:14px}.preview th,.preview td{border:1px solid var(--border);padding:8px 12px;color:var(--text2)}.preview th{background:var(--bg3);color:var(--text);font-weight:600}.preview strong{color:var(--text)}.preview em{color:var(--accent3)}.code-header{display:flex;align-items:center;justify-content:space-between;padding:6px 14px;background:var(--bg4);border-bottom:1px solid var(--border)}.code-lang{font-size:10px;font-family:var(--font);color:var(--accent3);text-transform:uppercase;letter-spacing:.1em}.code-copy{background:none;border:1px solid var(--border2);color:var(--text3);font-size:11px;padding:2px 8px;border-radius:4px;cursor:pointer;font-family:var(--sans);transition:all .15s}.code-copy:hover{background:var(--bg3);color:var(--text);border-color:var(--accent)}.code-copy.copied{color:var(--green);border-color:var(--green)}.preview .hljs{background:#1e1e1e!important;color:#d4d4d4}.preview .hljs-keyword{color:#569cd6}.preview .hljs-keyword.hljs-control{color:#c586c0}.preview .hljs-built_in{color:#4ec9b0}.preview .hljs-string{color:#ce9178}.preview .hljs-subst{color:#d4d4d4}.preview .hljs-number{color:#b5cea8}.preview .hljs-literal{color:#569cd6}.preview .hljs-comment{color:#6a9955;font-style:italic}.preview .hljs-title{color:#dcdcaa}.preview .hljs-title.class_{color:#4ec9b0}.preview .hljs-title.function_{color:#dcdcaa}.preview .hljs-params,.preview .hljs-variable{color:#9cdcfe}.preview .hljs-variable.language_{color:#569cd6}.preview .hljs-property,.preview .hljs-attr{color:#9cdcfe}.preview .hljs-type{color:#4ec9b0}.preview .hljs-operator,.preview .hljs-punctuation{color:#d4d4d4}.preview .hljs-regexp{color:#d16969}.preview .hljs-meta{color:#dcdcaa}.preview .hljs-meta .hljs-string{color:#ce9178}.preview .hljs-tag{color:gray}.preview .hljs-name{color:#569cd6}.preview .hljs-selector-tag,.preview .hljs-selector-class,.preview .hljs-selector-id{color:#d7ba7d}.preview .hljs-attribute{color:#9cdcfe}.preview .hljs-section{color:#569cd6;font-weight:600}.preview .hljs-deletion{color:#f44747}.preview .hljs-addition{color:#b5cea8}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:10px;color:var(--text3);padding:32px}.empty-icon{opacity:.25;margin-bottom:4px}.empty-title{font-size:15px;color:var(--text2);font-weight:500}.empty-sub{font-size:13px;color:var(--text3);text-align:center;max-width:280px;line-height:1.6}.empty-actions{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap;justify-content:center}.empty-actions button{display:flex;align-items:center;gap:6px;background:none;border:1px solid var(--border2);color:var(--text2);padding:8px 16px;border-radius:var(--radius);font-size:13px;cursor:pointer;font-family:var(--sans);transition:all .15s}.empty-actions button:hover{background:var(--bg3);color:var(--text)}.statusbar{height:var(--statusbar-h);background:var(--bg2);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 14px;gap:8px;flex-shrink:0}.stat{font-size:11px;color:var(--text3);font-family:var(--font)}.stat-sep{font-size:11px;color:var(--border2)}.stat-filename{font-size:11px;color:var(--text3);margin-left:auto}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:100;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:16px}.modal-overlay.show{display:flex}.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:12px;padding:24px;min-width:300px;max-width:400px;width:100%;box-shadow:0 24px 60px #00000080;animation:modal-in .15s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(4px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal h3{font-size:14px;color:var(--text);margin-bottom:16px;font-weight:600}.modal input{width:100%;background:var(--bg3);border:1px solid var(--border2);color:var(--text);padding:9px 12px;border-radius:var(--radius);font-size:14px;font-family:var(--sans);outline:none;margin-bottom:16px;transition:border-color .15s,box-shadow .15s}.modal input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #c46b4a1a}.modal-btns{display:flex;gap:8px;justify-content:flex-end}.mbtn{background:none;border:1px solid var(--border2);color:var(--text2);padding:7px 16px;border-radius:var(--radius);font-size:13px;cursor:pointer;font-family:var(--sans);transition:all .15s}.mbtn:hover{background:var(--bg4);color:var(--text)}.mbtn.ok{background:var(--accent);border-color:var(--accent);color:#fff}.mbtn.ok:hover{background:var(--accent2)}.mbtn.danger{background:#c167671a;border-color:#c167674d;color:var(--red)}.mbtn.danger:hover{background:#c1676733}.confirm-modal{text-align:center}.confirm-icon{width:48px;height:48px;border-radius:50%;background:#c167671a;border:1px solid rgba(193,103,103,.2);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--red)}.confirm-msg{font-size:13px;color:var(--text3);margin-bottom:20px;line-height:1.6}.confirm-msg strong{color:var(--text2)}.ctx-menu{display:none;position:fixed;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;padding:4px;z-index:200;min-width:164px;box-shadow:0 8px 32px #00000080;animation:ctx-in .1s ease}@keyframes ctx-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.ctx-menu.show{display:block}.ctx-item{padding:7px 13px;font-size:12.5px;color:var(--text2);cursor:pointer;border-radius:5px;transition:background .1s;display:flex;align-items:center;gap:8px}.ctx-item:hover{background:var(--bg4);color:var(--text)}.ctx-sep{height:1px;background:var(--border);margin:4px 0}.ctx-item.danger:hover{background:#c167671a;color:var(--red)}.spinner-page{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);gap:6px}.spinner-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:dot-bounce .9s ease-in-out infinite}.spinner-dot:nth-child(2){animation-delay:.15s}.spinner-dot:nth-child(3){animation-delay:.3s}@keyframes dot-bounce{0%,80%,to{transform:scale(.5);opacity:.3}40%{transform:scale(1);opacity:1}}.desktop-only{display:flex}@media (max-width: 900px){:root{--sidebar-w: 220px}.topbtn span{display:none}}@media (max-width: 768px){.desktop-only{display:none!important}.topbar-hamburger{display:flex}.topbar-sidebar-toggle{display:none}.mobile-overlay{display:block}.sidebar{position:fixed;top:var(--topbar-h);left:0;height:calc(100vh - var(--topbar-h) - var(--statusbar-h));z-index:50;transform:translate(-100%);width:var(--sidebar-w)!important;transition:transform .25s ease;box-shadow:4px 0 24px #0006}.sidebar.mobile-open{transform:translate(0)}.sidebar.collapsed{transform:translate(-100%);width:var(--sidebar-w)!important}.sync-pill,.user-name{display:none}.toolbar{gap:1px;padding:5px 8px}.tbtn{padding:4px 6px;font-size:11px;min-width:24px}.topbtn{padding:5px 9px}.logo{font-size:12px}}@media (max-width: 480px){:root{--topbar-h: 48px}.topbar{padding:0 10px;gap:6px}.toolbar{overflow-x:auto;flex-wrap:nowrap}.toolbar::-webkit-scrollbar{height:0}}.sync-dot.error{background:var(--red);animation:pulse 1.5s infinite}.sync-dot.saving{background:var(--amber);animation:pulse 1s infinite}.sync-dot.saved{background:var(--green);animation:none}.stat-error{margin-left:auto;font-size:11px;color:var(--red);font-family:var(--font)}@supports (padding: env(safe-area-inset-bottom)){.statusbar{padding-bottom:calc(4px + env(safe-area-inset-bottom));height:calc(var(--statusbar-h) + env(safe-area-inset-bottom))}.topbar{padding-left:max(14px,env(safe-area-inset-left));padding-right:max(14px,env(safe-area-inset-right));padding-top:env(safe-area-inset-top)}.sidebar{padding-bottom:env(safe-area-inset-bottom)}}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:3px}button:focus:not(:focus-visible),input:focus:not(:focus-visible),textarea:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}@media print{.topbar,.sidebar,.toolbar,.statusbar{display:none!important}.editor-area{overflow:visible}.preview{display:block!important;padding:0}.editor{display:block!important;overflow:visible}}
