:root{--bg: #faf9f7;--surface: #ffffff;--surface-2: #f5f4f1;--fg: #1c1917;--fg-soft: #44403c;--muted: #78716c;--border: #e7e5e4;--border-strong: #d6d3d1;--accent: #d97706;--accent-hover: #b45309;--accent-fg: #ffffff;--accent-soft: #fef3e2;--danger: #dc2626;--danger-soft: #fef2f2;--success: #16a34a;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(28, 25, 23, .05), 0 1px 1px rgba(28, 25, 23, .04);--shadow-md: 0 4px 16px rgba(28, 25, 23, .08), 0 1px 3px rgba(28, 25, 23, .05);--shadow-lg: 0 12px 40px rgba(28, 25, 23, .14), 0 4px 12px rgba(28, 25, 23, .08);--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-8: 48px;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);color-scheme:light}[data-theme=dark]{--bg: #0c0a09;--surface: #1c1917;--surface-2: #292524;--fg: #fafaf9;--fg-soft: #e7e5e4;--muted: #a8a29e;--border: #292524;--border-strong: #44403c;--accent: #f59e0b;--accent-hover: #fbbf24;--accent-fg: #1c1917;--accent-soft: #292014;--danger: #f87171;--danger-soft: #2a1414;--success: #4ade80;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .6);color-scheme:dark}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-sans);background:var(--bg);color:var(--fg);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background .3s var(--ease-out),color .3s var(--ease-out)}h1,h2,h3,h4{font-weight:600;letter-spacing:-.02em;line-height:1.25}a{color:inherit;text-decoration:none}button,input,textarea{font-family:inherit;font-size:inherit;color:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}::selection{background:var(--accent-soft);color:var(--fg)}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px;border:3px solid transparent;background-clip:content-box}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:40px;padding:0 var(--space-4);border-radius:var(--radius-sm);border:1px solid transparent;background:var(--surface-2);color:var(--fg);font-weight:500;cursor:pointer;white-space:nowrap;transition:background .18s var(--ease-out),border-color .18s var(--ease-out),transform .12s var(--ease-out),box-shadow .18s var(--ease-out)}.btn:hover{background:var(--border)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-fg);box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--accent-hover)}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--surface-2)}.btn-outline{background:transparent;border-color:var(--border-strong)}.btn-outline:hover{background:var(--surface-2)}.btn-danger{background:transparent;color:var(--danger);border-color:var(--border)}.btn-danger:hover{background:var(--danger-soft);border-color:var(--danger)}.btn-sm{height:32px;padding:0 var(--space-3);font-size:14px}.btn-block{width:100%}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--muted);cursor:pointer;transition:background .18s var(--ease-out),color .18s var(--ease-out),transform .12s var(--ease-out)}.icon-btn:hover{background:var(--surface-2);color:var(--fg)}.icon-btn:active{transform:scale(.92)}.field{display:flex;flex-direction:column;gap:var(--space-2)}.label{font-size:13px;font-weight:500;color:var(--fg-soft)}.input{height:44px;padding:0 var(--space-3);border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface);transition:border-color .18s var(--ease-out),box-shadow .18s var(--ease-out)}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input::placeholder{color:var(--muted)}.field-error{font-size:13px;color:var(--danger)}.input-affix{position:relative;display:flex;align-items:center}.input-affix .input{width:100%;padding-right:44px}.input-affix .icon-btn{position:absolute;right:4px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.muted{color:var(--muted)}.mono{font-family:var(--font-mono)}.auth-wrap{min-height:100dvh;display:grid;place-items:center;padding:var(--space-5);background:radial-gradient(120% 120% at 50% 0%,var(--accent-soft) 0%,var(--bg) 45%)}.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-8) var(--space-6) var(--space-6)}.auth-brand{display:flex;align-items:center;gap:var(--space-2);justify-content:center;margin-bottom:var(--space-5)}.auth-brand .logo-mark{color:var(--accent)}.auth-brand b{font-size:20px;letter-spacing:-.03em}.auth-title{font-size:24px;text-align:center;margin-bottom:var(--space-2)}.auth-sub{text-align:center;color:var(--muted);margin-bottom:var(--space-6);font-size:14px}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-foot{text-align:center;margin-top:var(--space-5);font-size:14px;color:var(--muted)}.auth-foot a{color:var(--accent);font-weight:500}.remember-row{display:flex;align-items:center;gap:var(--space-2);font-size:14px;color:var(--fg-soft);cursor:pointer;-webkit-user-select:none;user-select:none}.remember-row input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.form-banner{font-size:14px;padding:var(--space-3);border-radius:var(--radius-sm);background:var(--danger-soft);color:var(--danger);border:1px solid color-mix(in srgb,var(--danger) 25%,transparent)}.shell{display:flex;height:100dvh;overflow:hidden}.sidebar{width:280px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column}.sidebar-head{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4)}.sidebar-head .logo-mark{color:var(--accent)}.sidebar-head b{font-size:17px;letter-spacing:-.03em}.sidebar-section{padding:var(--space-2) var(--space-3)}.sidebar-section-head{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-2);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.sidebar-scroll{flex:1;overflow-y:auto}.sidebar-foot{border-top:1px solid var(--border);padding:var(--space-2);display:flex;gap:var(--space-1);align-items:center}.tree-row{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-2);border-radius:var(--radius-sm);cursor:pointer;color:var(--fg-soft);transition:background .15s var(--ease-out),color .15s var(--ease-out);-webkit-user-select:none;user-select:none}.tree-row:hover{background:var(--surface-2);color:var(--fg)}.tree-row.active{background:var(--accent-soft);color:var(--fg);font-weight:500}.tree-row .twirl{transition:transform .18s var(--ease-out);flex-shrink:0;color:var(--muted)}.tree-row .twirl.open{transform:rotate(90deg)}.tree-row .name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-row .row-actions{display:none;gap:2px}.tree-row:hover .row-actions{display:flex}.tree-children{margin-left:var(--space-4);border-left:1px solid var(--border);padding-left:var(--space-1)}.doclist{width:320px;flex-shrink:0;border-right:1px solid var(--border);background:var(--bg);display:flex;flex-direction:column}.doclist-head{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--border)}.doclist-head h2{font-size:16px}.doclist-scroll{flex:1;overflow-y:auto;padding:var(--space-2)}.doc-item{padding:var(--space-3);border-radius:var(--radius-sm);cursor:pointer;border:1px solid transparent;transition:background .15s var(--ease-out),border-color .15s var(--ease-out)}.doc-item:hover{background:var(--surface-2)}.doc-item.active{background:var(--surface);border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.doc-item .doc-title{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-item .doc-meta{font-size:12px;color:var(--muted);margin-top:2px}.editor-pane{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg)}.editor-bar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);background:var(--surface)}.title-wrap{flex:1;min-width:0;display:flex;align-items:center;gap:4px}.editor-title{flex:1;min-width:0;border:1px solid transparent;background:transparent;font-size:18px;font-weight:600;letter-spacing:-.02em;border-radius:7px;padding:3px 8px;transition:background .15s var(--ease-out),border-color .15s var(--ease-out),box-shadow .15s var(--ease-out)}.editor-title:hover:not([readonly]){background:var(--surface-2)}.editor-title:focus{outline:none;background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.editor-title[readonly]{cursor:default}.crumb-sep{color:var(--muted);flex-shrink:0}.folder-picker{position:relative;flex-shrink:0}.crumb-btn{display:inline-flex;align-items:center;gap:5px;height:30px;max-width:170px;padding:0 8px;border:1px solid transparent;border-radius:7px;background:transparent;color:var(--muted);cursor:pointer;font-size:14px;transition:background .15s var(--ease-out),color .15s var(--ease-out)}.crumb-btn:hover{background:var(--surface-2);color:var(--fg)}.crumb-btn span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:50;min-width:210px;max-height:320px;overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:5px}.folder-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;background:transparent;color:var(--fg);cursor:pointer;border-radius:7px;font-size:14px;text-align:left}.folder-menu-item:hover{background:var(--surface-2)}.folder-menu-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-menu-item .ml-auto{margin-left:auto;color:var(--accent);flex-shrink:0}.icon-btn.xs{width:24px;height:24px}.nav-doc{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-sm);cursor:pointer;color:var(--fg-soft);font-size:14px;transition:background .15s var(--ease-out),color .15s var(--ease-out)}.nav-doc:hover{background:var(--surface-2);color:var(--fg)}.nav-doc.active{background:var(--accent-soft);color:var(--fg);font-weight:500}.nav-doc .doc-ic{color:var(--muted);flex-shrink:0}.nav-doc .name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-empty{padding:4px 10px 6px;font-size:12px;color:var(--muted)}.save-status{font-size:13px;color:var(--muted);display:inline-flex;align-items:center;gap:6px;min-width:64px}.save-status.saved{color:var(--success)}.save-status.error{color:var(--danger)}.segmented{display:inline-flex;background:var(--surface-2);border-radius:var(--radius-sm);padding:3px;gap:2px}.segmented button{border:none;background:transparent;cursor:pointer;color:var(--muted);height:30px;padding:0 var(--space-3);border-radius:6px;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:color .15s var(--ease-out);position:relative}.segmented button.active{color:var(--fg)}.seg-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--surface);border-radius:6px;box-shadow:var(--shadow-sm);z-index:0}.segmented button span{position:relative;z-index:1}.editor-body{flex:1;display:flex;overflow:hidden}.editor-half{flex:1;min-width:0;overflow:auto}.editor-half+.editor-half{border-left:1px solid var(--border)}.cm-host{height:100%}.cm-host .cm-editor{height:100%;font-family:var(--font-mono);font-size:14px}.cm-host .cm-scroller{font-family:var(--font-mono);line-height:1.7}.preview-scroll{padding:var(--space-6)}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);color:var(--muted);text-align:center;padding:var(--space-6)}.empty-state .empty-icon{color:var(--border-strong)}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0c0a0973;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:var(--space-4)}.modal{width:100%;max-width:460px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-5)}.modal h3{font-size:18px;margin-bottom:var(--space-2)}.modal-row{display:flex;gap:var(--space-2);align-items:center}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-5)}.toast-stack{position:fixed;bottom:var(--space-5);left:50%;transform:translate(-50%);z-index:200;display:flex;flex-direction:column;gap:var(--space-2)}.toast{padding:var(--space-3) var(--space-4);border-radius:var(--radius);background:var(--fg);color:var(--bg);box-shadow:var(--shadow-lg);font-size:14px;font-weight:500;display:flex;align-items:center;gap:var(--space-2)}.toast.error{background:var(--danger);color:#fff}.toast.success{background:var(--success);color:#fff}.share-link-box{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-2) var(--space-2) var(--space-3);background:var(--surface-2);border-radius:var(--radius-sm);border:1px solid var(--border)}.share-link-box input{flex:1;border:none;background:transparent;font-family:var(--font-mono);font-size:13px}.share-link-box input:focus{outline:none}.perm-toggle{display:flex;gap:var(--space-2);margin:var(--space-4) 0}.perm-option{flex:1;padding:var(--space-3);border-radius:var(--radius-sm);border:1px solid var(--border-strong);cursor:pointer;transition:all .15s var(--ease-out);background:var(--surface)}.perm-option.active{border-color:var(--accent);background:var(--accent-soft)}.perm-option .po-title{font-weight:600;display:flex;align-items:center;gap:6px}.perm-option .po-desc{font-size:12px;color:var(--muted);margin-top:2px}.shared-wrap{min-height:100dvh;display:flex;flex-direction:column}.shared-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--border);background:var(--surface)}.shared-bar .title{font-weight:600}.badge{font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px;background:var(--surface-2);color:var(--muted);display:inline-flex;align-items:center;gap:5px}.badge.edit{background:var(--accent-soft);color:var(--accent-hover)}.reading{max-width:760px;width:100%;margin:0 auto;padding:var(--space-8) var(--space-5)}.center-screen{min-height:100dvh;display:grid;place-items:center;padding:var(--space-5);text-align:center}.center-screen .big{font-size:56px;font-weight:700;letter-spacing:-.04em;color:var(--accent)}.page-wrap{max-width:720px;margin:0 auto;padding:var(--space-8) var(--space-5)}.page-head{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6)}.key-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--border)}.key-row:last-child{border-bottom:none}.key-row .kr-name{font-weight:500}.key-row .kr-meta{font-size:13px;color:var(--muted);margin-top:2px}.markdown{color:var(--fg);font-size:16px;line-height:1.7;word-wrap:break-word}.markdown>*:first-child{margin-top:0}.markdown h1{font-size:2em;margin:.8em 0 .4em;padding-bottom:.3em;border-bottom:1px solid var(--border)}.markdown h2{font-size:1.5em;margin:1.2em 0 .4em;padding-bottom:.3em;border-bottom:1px solid var(--border)}.markdown h3{font-size:1.25em;margin:1.2em 0 .4em}.markdown h4{font-size:1.05em;margin:1.2em 0 .4em}.markdown p{margin:.8em 0}.markdown a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.markdown ul,.markdown ol{margin:.8em 0;padding-left:1.6em}.markdown li{margin:.3em 0}.markdown blockquote{margin:1em 0;padding:.4em 1em;border-left:3px solid var(--accent);background:var(--surface-2);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--fg-soft)}.markdown code{font-family:var(--font-mono);font-size:.88em;background:var(--surface-2);padding:.15em .4em;border-radius:5px}.markdown pre{margin:1em 0;padding:var(--space-4);overflow:auto;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius)}.markdown pre code{background:transparent;padding:0;font-size:13.5px;line-height:1.6}.markdown table{border-collapse:collapse;margin:1em 0;width:100%;font-size:.95em}.markdown th,.markdown td{border:1px solid var(--border);padding:.5em .8em;text-align:left}.markdown th{background:var(--surface-2);font-weight:600}.markdown hr{border:none;border-top:1px solid var(--border);margin:1.6em 0}.markdown img{max-width:100%;border-radius:var(--radius-sm)}.markdown input[type=checkbox]{margin-right:.4em}.hljs-comment,.hljs-quote{color:var(--muted);font-style:italic}.hljs-keyword,.hljs-selector-tag,.hljs-built_in{color:#c026d3}.hljs-string,.hljs-attr{color:#16a34a}.hljs-number,.hljs-literal{color:#d97706}.hljs-title,.hljs-section,.hljs-function .hljs-title{color:#2563eb}.hljs-type,.hljs-class .hljs-title{color:#0891b2}.hljs-tag,.hljs-name{color:#dc2626}[data-theme=dark] .hljs-keyword,[data-theme=dark] .hljs-selector-tag,[data-theme=dark] .hljs-built_in{color:#e879f9}[data-theme=dark] .hljs-string,[data-theme=dark] .hljs-attr{color:#4ade80}[data-theme=dark] .hljs-number,[data-theme=dark] .hljs-literal{color:#fbbf24}[data-theme=dark] .hljs-title,[data-theme=dark] .hljs-section{color:#60a5fa}[data-theme=dark] .hljs-type{color:#22d3ee}[data-theme=dark] .hljs-tag,[data-theme=dark] .hljs-name{color:#f87171}.row{display:flex;align-items:center;gap:var(--space-2)}.spacer{flex:1}.stack{display:flex;flex-direction:column;gap:var(--space-4)}.spin{animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.icon-btn.panel-on{background:var(--surface-2);color:var(--fg)}
