:root{--bg: #272e50;--panel: #2f3760;--ink: #ffffff;--muted: #a5adc9;--line: #6a78ba;--accent: #5a9dff;--accent-soft: #3a4478;--danger: #c94040;--danger-soft: #4a2a2a;--code-bg: #1c2140;--rail-w: 320px}*{box-sizing:border-box}html{color-scheme:dark}html,body,#root{height:100%;margin:0;background:var(--bg);color:var(--ink);font:14px/1.5 system-ui,-apple-system,Segoe UI,Roboto,sans-serif}input,textarea{background:var(--panel);color:var(--ink)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;cursor:pointer}.app{display:flex;flex-direction:column;height:100%}.brand{font-size:15px;font-weight:600;margin:0}#topbar-actions{display:flex;align-items:center;gap:8px}#topbar-actions:empty{display:none}.btn-topbar-save{padding:4px 12px;border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:4px;font-weight:500;transition:background-color .15s,border-color .15s,color .15s}.btn-topbar-save:disabled{opacity:.6;cursor:not-allowed}.btn-topbar-save.dirty{background:var(--danger);border-color:var(--danger);color:#fff}.btn-topbar-save.dirty:not(:disabled):hover{filter:brightness(1.08)}.layout{display:flex;flex:1;overflow:hidden}.rail{width:var(--rail-w);flex-shrink:0;background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden}.rail-body{flex:1;overflow-y:auto;padding:12px;min-height:0}.rail-footer{border-top:1px solid var(--line);padding:10px 12px;display:flex;flex-direction:column;gap:6px}.rail-footer .brand{padding:2px 0}.main{flex:1;overflow:auto;padding:24px 32px}.err{color:var(--danger);font-size:12px}.admin-gear-wrap{position:fixed;top:12px;right:16px;z-index:100}.admin-gear{padding:6px;background:var(--panel);border:1px solid var(--line);border-radius:6px;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;transition:background-color .15s,color .15s,border-color .15s}.admin-gear:hover{background:var(--accent-soft)}.admin-gear.is-admin{color:var(--accent);border-color:var(--accent)}.admin-popover{position:absolute;top:100%;right:0;margin-top:6px;padding:10px;background:var(--panel);border:1px solid var(--line);border-radius:6px;min-width:200px;box-shadow:0 4px 12px #00000059;display:flex;flex-direction:column;gap:8px}.admin-popover form{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.admin-popover input{flex:1;min-width:120px;padding:4px 8px;border:1px solid var(--line);border-radius:4px}.admin-popover button{padding:4px 10px;border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:4px}.admin-popover .badge{padding:2px 8px;background:var(--accent-soft);color:var(--accent);border-radius:4px;font-weight:600;font-size:12px;align-self:flex-start}.tree{font-size:13px}.tree .node{margin:1px 0}.tree .row{display:flex;align-items:center;gap:4px;padding:3px 4px;border-radius:4px}.tree .row:hover{background:var(--accent-soft)}.tree .node.topic.active>.row{background:var(--accent-soft)}.tree .toggle,.tree .bullet{display:inline-block;width:18px;text-align:center;background:none;border:0;color:var(--muted);padding:0}.tree .title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree .slug{color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;opacity:.7}.tree .actions{display:flex;gap:4px;margin-left:4px;opacity:.55;transition:opacity .1s}.tree .row:hover .actions{opacity:1}.tree .actions button{font-size:11px;padding:1px 8px;background:var(--panel);color:var(--ink);border:1px solid var(--line);border-radius:3px;line-height:1.5}.tree .actions button.act-edit:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.tree .actions button.act-del:hover{background:var(--danger-soft);border-color:var(--danger);color:var(--danger)}.tree .children{margin-left:18px;border-left:1px dashed var(--line);padding-left:8px}.tree .bookmarks-children{margin-left:30px;padding-left:8px}.tree .bookmark-tree{display:flex;align-items:baseline;gap:8px;padding:2px 6px;margin:1px 0;border-radius:3px;color:var(--ink);text-decoration:none;font-size:12px}.tree .bookmark-tree:hover{background:var(--accent-soft);text-decoration:none}.tree .bookmark-tree.active{background:var(--accent-soft)}.tree .bookmark-tree-time{font:600 11px/1 ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--accent);min-width:40px}.tree .bookmark-tree-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree .add-row{display:block;margin:4px 0 8px 18px;padding:2px 8px;background:transparent;border:1px dashed var(--line);color:var(--muted);font-size:12px;border-radius:4px;cursor:pointer}.tree .add-row:hover{color:var(--accent);border-color:var(--accent)}.inline-form{margin:6px 0 10px 18px;padding:8px 10px;background:var(--accent-soft);border:1px solid var(--accent);border-radius:4px;display:flex;flex-direction:column;gap:6px}.inline-form-title{font-size:11px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.04em}.inline-field{display:flex;flex-direction:column;gap:2px;font-size:11px;color:var(--muted)}.inline-form input{padding:4px 8px;border:1px solid var(--line);border-radius:3px;font:13px/1.4 system-ui;color:var(--ink)}.inline-form input:focus{outline:none;border-color:var(--accent)}.inline-form-err{color:var(--danger);font-size:12px}.inline-form-actions{display:flex;gap:6px}.inline-form-actions button{font-size:12px;padding:3px 10px;border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:3px}.inline-form-actions button[type=submit]{background:var(--accent);color:#fff;border-color:var(--accent)}.inline-form-actions button[type=submit]:disabled{opacity:.6}.tree .node.project>.row>.title{font-weight:600}.tree .node.section>.row>.title{font-weight:500}.muted{color:var(--muted)}.topic{max-width:820px}.topic-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.topic-head h1{margin:0;font-size:26px}.topic-head .title-input{flex:1;font:600 22px/1.3 system-ui;padding:6px 10px;border:1px solid var(--line);border-radius:4px}.edit-actions{display:flex;gap:8px}.edit-actions button,.btn-edit{padding:6px 14px;border:1px solid var(--line);border-radius:4px;background:var(--panel);color:var(--ink);text-decoration:none}.edit-actions button:first-child{background:var(--accent);color:#fff;border-color:var(--accent)}.rich-content{line-height:1.6}.rich-content h1,.rich-content h2,.rich-content h3{margin:1.4em 0 .4em;line-height:1.25}.rich-content p{margin:.6em 0}.rich-content ul,.rich-content ol{padding-left:1.4em}.rich-content img{max-width:100%;height:auto;border-radius:4px;margin:8px 0}.rich-content blockquote{border-left:3px solid var(--line);padding-left:12px;color:var(--muted);margin:1em 0}.rich-content pre{background:var(--code-bg);padding:10px 12px;border-radius:4px;overflow-x:auto}.rich-content code{font:.9em ui-monospace,SFMono-Regular,Menlo,monospace;background:var(--code-bg);padding:1px 4px;border-radius:3px}.rich-content pre code{background:transparent;padding:0}.tiptap{min-height:1em;padding:16px 18px;border:1px solid var(--line);border-radius:6px;background:var(--panel);color:var(--ink);outline:none;line-height:1.6}.tiptap:focus{border-color:var(--accent)}.tiptap p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--muted);pointer-events:none;height:0}.tiptap h1,.tiptap h2,.tiptap h3{margin:1.4em 0 .4em;line-height:1.25}.tiptap p{margin:.6em 0}.tiptap ul,.tiptap ol{padding-left:1.4em}.tiptap img{max-width:100%;height:auto;border-radius:4px;margin:8px 0}.tiptap img.ProseMirror-selectednode{outline:2px solid var(--accent)}.tiptap blockquote{border-left:3px solid var(--line);padding-left:12px;color:var(--muted)}.tiptap pre{background:var(--code-bg);padding:10px 12px;border-radius:4px;overflow-x:auto}.tiptap code{background:var(--code-bg);padding:1px 4px;border-radius:3px}.tiptap pre code{background:transparent;padding:0}.topic-video-wrap{position:sticky;top:-24px;z-index:10;margin:0 0 16px;padding:8px 0;background:var(--bg)}.topic-video{display:block;width:100%;max-height:45vh;background:#000;border-radius:6px}.topic-video-resize{height:8px;margin-top:4px;border-radius:3px;background:var(--panel);border:1px solid var(--line);cursor:ns-resize;touch-action:none;transition:background-color .15s}.topic-video-resize:hover{background:var(--accent-soft)}.topic-video-resize.dragging{background:var(--accent);border-color:var(--accent)}.video-sync-toggle{display:inline-flex;align-items:center;gap:6px;margin-top:8px;font-size:12px;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none}.video-sync-toggle input{margin:0}.topic-with-video{height:100%;display:flex;flex-direction:column;margin:0}.topic-with-video .topic-video-wrap{position:static;top:auto;z-index:auto;margin:0;padding:0 0 16px;flex-shrink:0}.topic-with-video .topic-scroll{flex:1;min-height:0;overflow-y:auto}.bookmarks{list-style:none;margin:0 0 20px;display:flex;flex-direction:column;gap:4px;background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:8px}.bookmark-btn{display:flex;align-items:baseline;gap:12px;width:100%;padding:6px 10px;border:0;background:transparent;text-align:left;border-radius:4px;color:var(--ink)}.bookmark-btn:not(:disabled):hover{background:var(--accent-soft)}.bookmark-btn:disabled{color:var(--muted);cursor:not-allowed}.bookmark-time{font:600 12px/1 ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--accent);min-width:56px}.bookmark-label{flex:1}.video-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}.video-controls button{padding:4px 12px;border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:4px}.video-controls button:disabled{opacity:.6;cursor:not-allowed}.video-controls button.danger{color:var(--danger);border-color:var(--danger)}.video-controls button.danger:hover{background:var(--danger-soft)}.video-controls .video-hint{color:var(--muted);font-size:12px}.checkbox-inline{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid var(--line);border-radius:4px;color:var(--ink);font-size:13px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-inline input{margin:0}.bookmark-editor{margin:0 0 20px;padding:12px 14px;background:var(--panel);border:1px solid var(--line);border-radius:6px}.bookmark-editor-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.bookmark-editor-head h2{margin:0;font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.bookmark-editor-head button{padding:4px 10px;border:1px solid var(--accent);background:var(--accent);color:#fff;border-radius:4px}.bookmark-editor .small{font-size:12px}.edit-section-head{margin:20px 0 6px;font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.bookmark-rows{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}.bookmark-row-wrap{border:1px solid var(--line);border-radius:6px;padding:10px;background:var(--panel)}.bookmark-row-body{margin-top:8px}.bookmark-row-body .tiptap{min-height:1em}.bookmark-row-hint{margin-top:4px}.bookmark-section{margin:28px 0;scroll-margin-top:16px}.bookmark-section-head{display:flex;align-items:center;gap:10px;font-size:20px;margin:0 0 8px;padding-top:12px;border-top:2px solid var(--line)}.bookmark-section-time{font:600 12px/1 ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent);border-radius:4px;padding:4px 8px;cursor:pointer}.bookmark-section-time:hover:not(:disabled){background:var(--accent);color:#fff}.bookmark-section-time:disabled{opacity:.6;cursor:not-allowed}.bookmark-row{display:grid;grid-template-columns:auto 80px auto auto 1fr auto;align-items:center;gap:6px}.bookmark-row.no-video{grid-template-columns:auto 1fr auto}.bookmark-row-grip{display:flex;flex-direction:column;gap:1px}.bookmark-row-grip button{font-size:10px;padding:0 4px;line-height:1.4;border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:2px}.bookmark-row-grip button:disabled{opacity:.3}.bookmark-row input{padding:4px 8px;border:1px solid var(--line);border-radius:3px;font:13px/1.4 system-ui;color:var(--ink)}.bookmark-row input:focus{outline:none;border-color:var(--accent)}.bookmark-row input.err{border-color:var(--danger);background:var(--danger-soft)}.bookmark-time-input{font:600 12px/1.4 ui-monospace,SFMono-Regular,Menlo,monospace!important;text-align:center}.bookmark-time-input.no-time::placeholder{text-decoration:line-through;color:var(--muted);opacity:1}.bookmark-row button{padding:3px 10px;border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:3px;font-size:12px}.bookmark-row button:disabled{opacity:.5;cursor:not-allowed}.bookmark-row button.danger{color:var(--danger);border-color:var(--line);padding:3px 8px}.bookmark-row button.danger:hover{background:var(--danger-soft);border-color:var(--danger)}.title-input,.tiptap,.bookmark-row input{outline:1px dashed var(--accent);outline-offset:2px}.tiptap:focus,.title-input:focus,.bookmark-row input:focus{outline-style:solid}
