:root{--bg: #0d1117;--bg-soft: #11161e;--panel: #161b22;--panel-2: #1b212b;--line: #232a36;--line-strong: #2f3845;--card: #1f2937;--ink: #e8ecf2;--ink-soft: #b6bdc9;--ink-dim: #7d8696;--accent: #6ea8ff;--accent-soft: #2a3b5c;--good: #6cd09a;--warn: #f0b955;--danger: #f06a6a;--font-ui: "Inter", -apple-system, "Segoe UI", system-ui, sans-serif;--font-doc: "Source Serif Pro", "Iowan Old Style", Georgia, "Times New Roman", serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--r-sm: 4px;--r: 6px;--r-md: 10px;--r-lg: 14px;--ease: cubic-bezier(.2,.8,.2,1)}[data-reading=paper]{--paper-bg: #f6f1e6;--paper-ink: #1d1a16;--paper-ink-dim: #6a6258;--paper-rule: #d9d0bf}[data-reading=dark]{--paper-bg: #15191f;--paper-ink: #e8ecf2;--paper-ink-dim: #8a93a3;--paper-rule: #2a3140}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}html,body{margin:0;height:100vh;background:var(--bg);color:var(--ink);font-family:Inter,sans-serif;font-size:var(--font-size, 14px)}#root{display:flex;flex-direction:column;height:100vh}.btn{display:inline-flex;align-items:center;gap:.25rem;padding:6px 12px;font-size:13px;font-weight:400;border-radius:var(--r);cursor:pointer;text-decoration:none;border:none;background:var(--panel-2);color:var(--ink)}.btn:hover{background:var(--line)}.btn svg{width:16px;height:16px}.btn.primary{background:var(--accent);color:#fff}.btn.primary:hover{filter:brightness(1.1)}.btn.ghost{background:var(--panel-2);color:var(--ink)}.btn.ghost:hover{background:var(--line)}.btn.danger{background:#dc2626;color:#fff}.btn.danger:hover{filter:brightness(1.1)}#root>main{flex:1;display:flex;overflow:hidden}.workspace #graph-container{position:relative;display:flex;width:70%;transition:width .3s}.workspace #linear-panel{width:30%;transition:width .3s;border-left:1px solid var(--panel);overflow:hidden;display:flex;flex-direction:column}.workspace.expanded #graph-container{width:20%}.workspace.expanded #linear-panel{width:80%}#graph{flex:1;height:100%}#projectName,#projectList{background:var(--bg);color:var(--ink);border:none;border-bottom:1px solid var(--panel);padding:8px;font-size:1rem}#autoSaveLabel{display:flex;align-items:center;gap:.25rem}#modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--panel);color:#f0f0f0;display:none;flex-direction:column;z-index:1000}#modal.show{display:flex}#closeModal{align-self:flex-end;margin:8px}#modalList{flex:1;overflow-y:auto;padding:1rem;max-width:800px;margin:auto;background:var(--panel);border-radius:var(--r);border:1px solid var(--panel);line-height:1.6;font-family:system-ui,sans-serif;-webkit-user-select:text;user-select:text}#modalList a{color:inherit;text-decoration:underline}#modalList a:hover{text-decoration:underline}#modalList .linear-node{background:none;border:none;padding:0;margin-top:2rem;max-width:700px}#modalList .linear-node:first-child{margin-top:0}#modalList .linear-meta{margin:0 0 .5rem}#modalList .linear-id{font:.75rem/1 monospace;color:#666}#modalList .linear-title{font-weight:600}#modalList .linear-body p{margin:.5rem 0}#modalList input:not([type=checkbox]),#modalList textarea{width:100%;color:#000}#modalList textarea{min-height:8rem}.suggestion{background:var(--card);border:1px solid var(--panel);border-radius:var(--r);padding:.5rem;margin:.5rem 0;cursor:pointer;white-space:pre-wrap}.suggestion:hover{background:var(--line)}.node-card{width:100%;height:100%;background:var(--card);color:var(--ink);border:1px solid var(--panel);border-radius:var(--r);padding:.75rem;font-size:.8rem;min-width:180px;min-height:100px;max-width:400px;max-height:300px;position:relative;display:flex;flex-direction:column;box-sizing:border-box}.node-card:hover{border-color:var(--accent)}.node-card.selected{box-shadow:0 0 0 2px var(--accent)}.node-card.resizing{border-style:dashed}.node-card .node-id{font-family:monospace;font-size:.75rem;color:var(--ink-dim);margin-right:.25rem}.node-card .node-header{position:relative;margin-bottom:.25rem;text-overflow:ellipsis;white-space:nowrap}.node-card .node-title{font-weight:700;font-size:15px;display:inline-block;max-width:calc(100% - 3rem);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.node-card .node-title-input{font-weight:700;font-size:14px;background:transparent;border:none;border-bottom:1px solid var(--ink-dim);color:inherit;outline:none;width:calc(100% - 5rem);padding:0 2px}.node-card .node-content{flex:1;position:relative}.node-card .node-preview,.node-card .node-editor{position:absolute;top:0;right:0;bottom:0;left:0}.node-card .node-preview[aria-hidden=true],.node-card .node-editor[aria-hidden=true]{display:none!important}.node-card .node-preview{color:inherit;overflow-y:auto;scrollbar-width:none;white-space:pre-wrap;overflow-wrap:anywhere}.node-card .node-preview::-webkit-scrollbar{display:none}.node-card .preview-more{position:absolute;bottom:0;left:0;width:100%;text-align:center;pointer-events:none;background:linear-gradient(to bottom,transparent 0%,var(--card-bg, var(--card)) 70%);color:var(--ink-dim)}.node-card .node-editor .node-textarea{width:100%;height:100%;border:none;background:transparent;color:inherit;font-family:Inter,sans-serif;font-size:inherit;white-space:pre-wrap;overflow-wrap:anywhere;overflow-y:auto;resize:none;scrollbar-width:none}.node-card .node-editor .node-textarea::-webkit-scrollbar{display:none}.node-card .node-editor .node-textarea:focus{outline:none;box-shadow:none}.node-card .node-overview-title{flex:1;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;text-align:center;overflow:hidden;text-overflow:ellipsis;padding:.25rem;line-height:1.2}.node-toolbar{float:right;display:inline-flex;gap:2px;align-items:center}.node-color-btn{width:16px;height:16px;border:1px solid rgba(255,255,255,.3);border-radius:3px;cursor:pointer;padding:0}.node-color-picker{position:absolute;top:100%;right:0;display:grid;grid-template-columns:repeat(4,20px);gap:3px;padding:6px;background:var(--panel);border:1px solid var(--ink-dim);border-radius:var(--r);box-shadow:0 4px 12px #0000004d;z-index:20}.node-color-swatch{width:20px;height:20px;border-radius:3px;cursor:pointer;border:1px solid rgba(0,0,0,.2)}.node-color-swatch:hover{transform:scale(1.15)}.node-card .invalid-dot{position:absolute;top:4px;right:4px;width:8px;height:8px;background:#dc2626;border-radius:50%}#settingsButton{margin-left:auto;align-self:center}.react-flow__controls{opacity:1}.react-flow__controls button{background:var(--panel-2);color:var(--ink);border:none;width:32px;height:32px;cursor:pointer;border-radius:var(--r)}.react-flow__controls button:hover{background:var(--line)}.react-flow__minimap{background:var(--panel);border:1px solid var(--panel);border-radius:var(--r)}#playthrough{position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--panel);color:var(--ink);display:none;flex-direction:column;z-index:1000}#playthrough.show{display:flex}.play-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;border-bottom:1px solid var(--panel)}.play-nav{display:flex;gap:.5rem}.play-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;align-items:center;padding:2rem}.play-chapter{max-width:640px;width:100%}.play-title{font-size:2rem;font-weight:700;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--accent)}#playthrough .play-text{font-size:1.1rem;line-height:1.8}#playthrough .play-text p{margin:0 0 1rem}#playthrough .choice{display:inline-block;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:10px 20px;margin:.5rem .25rem;cursor:pointer;font-size:1rem;font-weight:500;transition:filter .2s}#playthrough .choice:hover{filter:brightness(1.15)}.play-breadcrumb{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--panel);font-size:.8rem;color:var(--ink-dim);max-width:640px;width:100%}.breadcrumb-sep{opacity:.4}.breadcrumb-current{font-weight:600;color:var(--ink)}#linearEditor{font-family:var(--font-doc);line-height:1.7;max-width:720px;margin:auto;flex:1;padding:1rem;outline:none;white-space:pre-wrap;overflow-wrap:anywhere;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}#linearEditor::-webkit-scrollbar{display:none}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.no-scrollbar::-webkit-scrollbar{display:none}.main-editor-container{position:relative}.linear-id{font:11px/1 monospace;color:var(--ink-dim)}#linearEditor h2{font-family:Inter,sans-serif;font-size:1.5rem;font-weight:600;margin-top:2.5rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--panel)}#linearEditor p{line-height:1.7;margin-bottom:1rem;white-space:pre-wrap;overflow-wrap:anywhere}.node-link{background:var(--accent);color:#fff;padding:2px 8px;border-radius:9999px;font-family:Inter,sans-serif;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.node-link:hover{filter:brightness(1.1);color:#fff}.ProseMirror h2{font-family:Inter,sans-serif;font-size:1.5rem;font-weight:600;border-bottom:1px solid var(--panel);margin-top:2rem;margin-bottom:1rem}.ProseMirror p{font-family:var(--font-doc);line-height:1.7;margin-bottom:1rem}.bubble-menu{display:flex;background:var(--card);color:var(--ink);padding:4px;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.bubble-menu button{background:none;border:none;padding:8px;margin:0 2px;border-radius:6px;transition:background-color .2s;color:inherit;cursor:pointer}.bubble-menu button:hover{background:var(--line)}.bubble-menu button.is-active{background:var(--panel-2)}.linear-container{background:var(--panel);color:var(--ink);display:flex;flex-direction:column;height:100%}.linear-header{background:var(--panel);color:var(--ink);border-color:var(--panel);padding:.75rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--panel)}.linear-header-left,.linear-header-right{display:flex;align-items:center;gap:.5rem}.linear-header-right{gap:.75rem}.linear-header-title{font-size:1.125rem;font-weight:700;margin:0}.linear-header-stats{font-size:.75rem;opacity:.5}.linear-body{display:flex;flex:1;min-height:0}.linear-sidebar{background:var(--panel);border-color:var(--panel);color:var(--ink);display:none;flex-direction:column;width:25%;height:100%;min-height:0}@media(min-width:768px){.linear-sidebar{display:flex}}.linear-sidebar-inner{flex:1;overflow-y:auto;padding:1rem}.linear-sidebar-heading{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.outline-list{display:flex;flex-direction:column;gap:.25rem;list-style:none;margin:0;padding:0}.linear-main{background:var(--bg);color:var(--ink);flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.linear-main-scroll{flex:1;overflow-y:auto;padding:1rem}@media(min-width:640px){.linear-main-scroll{padding:2rem}}@media(min-width:768px){.linear-main-scroll{padding:3rem}}.linear-editor-wrapper{max-width:48rem;margin-left:auto;margin-right:auto;position:relative}.outline-btn{background:transparent;color:var(--ink);display:block;width:100%;text-align:left;font-size:.875rem;padding:.5rem;border-radius:.375rem;border:none;cursor:pointer}.outline-btn:hover{background:var(--line)}.outline-btn.active{background:var(--panel-2);color:var(--ink)}.is-active-node{background-color:#3b82f633;transition:background-color .3s ease;border-radius:4px}.linear-footer{border-color:var(--panel)}.shortcut-key{background:var(--panel-2);color:var(--ink);padding:2px 6px;border-radius:var(--r)}.text-dim{color:var(--ink-dim)}.editor-toolbar{display:flex;align-items:center;gap:2px;padding:4px 8px;border-bottom:1px solid var(--panel);background:var(--bg);flex-wrap:wrap;min-height:36px}.toolbar-group{display:flex;gap:1px}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:4px;background:transparent;color:var(--ink);cursor:pointer;font-size:12px;transition:background .15s}.toolbar-btn:hover{background:var(--line)}.toolbar-btn.active{background:var(--accent);color:#fff}.toolbar-divider{width:1px;height:20px;background:var(--panel);margin:0 4px}input:focus,textarea:focus{outline:none;box-shadow:none}.node-notes-btn{background:none;border:none;cursor:pointer;font-size:12px;padding:0 2px;opacity:.6}.node-notes-btn:hover{opacity:1}.node-notes{position:absolute;bottom:-80px;left:0;right:0;z-index:15;background:var(--panel);border:1px solid var(--ink-dim);border-radius:var(--r);padding:4px}.node-notes-textarea{width:100%;height:60px;border:none;background:transparent;color:var(--ink);font-size:12px;resize:none;outline:none;font-family:inherit}.node-link-pill{display:inline-block;background:var(--accent);color:#fff;padding:1px 6px;border-radius:9999px;font-size:.7rem;font-weight:500;margin:0 2px;white-space:nowrap}.node-card.redesigned.idea-node,.node-card.idea-node{border-style:dashed;border-width:1.5px;border-color:var(--accent)}.node-card.idea-node .node-preview{font-style:italic}.section-node-label{padding:8px 12px;font-size:13px;font-weight:600;color:var(--ink-soft);pointer-events:none;font-family:var(--font-ui)}.node-word-count{position:absolute;bottom:2px;right:4px;font-size:9px;opacity:.4;font-family:monospace}#linearEditor .ProseMirror{font-family:var(--font-doc);font-size:1.1rem;line-height:1.8;color:var(--ink);min-height:80vh;outline:none}#linearEditor .ProseMirror h1{font-family:Inter,sans-serif;font-size:2rem;font-weight:700;margin:2.5rem 0 1rem;line-height:1.3}#linearEditor .ProseMirror h2{font-family:Inter,sans-serif;font-size:1.5rem;font-weight:600;margin:2.5rem 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--panel);line-height:1.3}#linearEditor .ProseMirror h3{font-family:Inter,sans-serif;font-size:1.2rem;font-weight:600;margin:1.5rem 0 .5rem}#linearEditor .ProseMirror p{margin:0 0 1rem}#linearEditor .ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--ink-dim);pointer-events:none;height:0}#linearEditor .ProseMirror blockquote{border-left:3px solid var(--accent);padding-left:1rem;margin:1rem 0;color:var(--ink-dim);font-style:italic}#linearEditor .ProseMirror ul,#linearEditor .ProseMirror ol{padding-left:1.5rem;margin:.5rem 0}#linearEditor .ProseMirror hr{border:none;border-top:2px solid var(--panel);margin:2rem 0}#linearEditor .ProseMirror mark{background:#facc1566;border-radius:2px;padding:1px 2px}@media(max-width:768px){.react-flow__minimap{display:none}}.app-shell{display:flex;height:100vh;background:var(--bg);color:var(--ink);overflow:hidden;font-size:14px;font-family:var(--font-ui)}.app-shell .right-col{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;gap:12px;height:44px;padding:0 14px;border-bottom:1px solid var(--line);background:var(--bg);flex:0 0 auto}.topbar .project-name{background:transparent;border:none;outline:none;font-family:var(--font-doc);font-style:italic;font-size:15px;color:var(--ink);padding:4px 8px;border-radius:4px;min-width:200px}.topbar .project-name:hover,.topbar .project-name:focus{background:var(--panel)}.topbar .pill{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;font-size:11.5px;font-weight:500;border-radius:999px;background:var(--panel-2);color:var(--ink-soft);border:1px solid var(--line)}.topbar .pill .dot{width:6px;height:6px;border-radius:50%;background:var(--good)}.topbar .pill.saving .dot{background:var(--warn)}.topbar .divider{width:1px;height:22px;background:var(--line)}.topbar .avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#b88dff);border:none;cursor:pointer}.topbar .kbd{display:inline-block;padding:1px 5px;font-family:var(--font-mono);font-size:10.5px;color:var(--ink-dim);background:var(--panel);border:1px solid var(--line);border-radius:3px;margin-left:6px}.topbar .spacer{flex:1}.workspace{flex:1;display:flex;position:relative;overflow:hidden;min-height:0}.sidebar-nav{width:56px;flex:0 0 auto;background:var(--bg-soft);border-right:1px solid var(--line);display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:4px}.sidebar-nav .logo{width:40px;height:40px;border-radius:8px;background:linear-gradient(135deg,var(--accent),#b88dff);border:none;cursor:pointer;position:relative}.sidebar-nav .logo:after{content:"";position:absolute;top:12px;right:12px;bottom:12px;left:12px;border:1.5px solid rgba(13,17,23,.5);border-radius:2px;border-right-color:transparent;border-bottom-color:transparent}.sidebar-nav .sep{width:28px;height:1px;background:var(--line);margin:8px 0}.sidebar-nav .sb-btn{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;color:var(--ink-dim);cursor:pointer;position:relative;transition:background .15s var(--ease),color .15s var(--ease)}.sidebar-nav .sb-btn:hover{background:var(--panel);color:var(--ink)}.sidebar-nav .sb-btn.active{background:var(--panel-2);color:var(--accent)}.sidebar-nav .sb-btn.active:before{content:"";position:absolute;left:-1px;top:8px;bottom:8px;width:2px;background:var(--accent);border-radius:0 2px 2px 0}.sidebar-nav .sb-btn svg{width:18px;height:18px}.sidebar-nav .spacer{flex:1}.app-shell ::-webkit-scrollbar{width:8px;height:8px}.app-shell ::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:4px}.app-shell ::-webkit-scrollbar-thumb:hover{background:var(--ink-dim)}.app-shell ::-webkit-scrollbar-track{background:transparent}.split-divider{width:1px;background:var(--line);flex:0 0 auto;cursor:col-resize;position:relative;transition:background .15s var(--ease)}.split-divider:hover{background:var(--accent)}.split-divider:before{content:"";position:absolute;top:0;right:-3px;bottom:0;left:-3px}.graph-pane{flex:1;position:relative;background:radial-gradient(circle at 20px 20px,var(--line) 1px,transparent 1.5px),var(--bg-soft);background-size:22px 22px;overflow:hidden;min-width:0}.graph-toolbar{position:absolute;top:12px;left:12px;display:flex;gap:4px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);padding:4px;z-index:5;box-shadow:0 8px 24px #00000040}.graph-toolbar .btn.icon{width:28px;height:28px;padding:0}.graph-zoom{position:absolute;bottom:12px;right:12px;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);z-index:5;box-shadow:0 8px 24px #00000040}.graph-zoom button{background:transparent;border:none;color:var(--ink-soft);width:32px;height:32px;font-size:14px;cursor:pointer;border-bottom:1px solid var(--line)}.graph-zoom button:last-child{border-bottom:none}.graph-zoom button:hover{color:var(--ink);background:var(--panel-2)}.graph-pane .react-flow__minimap{position:absolute;bottom:12px;left:12px;width:180px;height:110px;background:var(--panel)!important;border:1px solid var(--line);border-radius:var(--r);z-index:5;overflow:hidden;box-shadow:0 8px 24px #00000040}.graph-pane .react-flow__edge path{stroke:#3a4250}.graph-pane .react-flow__edge.selected path,.graph-pane .react-flow__edge:hover path{stroke:var(--accent)}.node-card.redesigned{background:var(--card);border:1px solid var(--line-strong);border-radius:8px;padding:10px 12px;font-size:12.5px;color:var(--ink);box-shadow:0 4px 14px #00000040;transition:border-color .15s var(--ease),box-shadow .15s var(--ease),transform .15s var(--ease);position:relative}.node-card.redesigned:hover{border-color:var(--accent);transform:translateY(-1px)}.node-card.redesigned.is-active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft),0 8px 22px #0006}.node-card.redesigned .accent-bar{position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:8px 0 0 8px}.node-card.redesigned .node-id{font-family:var(--font-mono);font-size:10px;color:var(--ink-dim);margin-bottom:4px}.node-card.redesigned .node-title{font-weight:600;font-size:13px;margin-bottom:4px;line-height:1.25;color:var(--ink)}.node-card.redesigned .node-preview{font-size:11.5px;color:var(--ink-soft);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.node-card.redesigned .node-preview .node-link-pill{color:var(--accent);font-family:var(--font-mono);font-size:10.5px}.doc-pane{flex:1;display:flex;flex-direction:column;background:var(--bg);border-left:1px solid var(--line);min-width:0}.doc-toolbar{display:flex;align-items:center;gap:4px;height:40px;padding:0 12px;border-bottom:1px solid var(--line);background:var(--bg);overflow-x:auto;flex:0 0 auto}.doc-toolbar .group{display:flex;align-items:center;gap:1px;padding-right:8px;margin-right:4px;border-right:1px solid var(--line)}.doc-toolbar .group:last-child{border-right:none}.doc-toolbar .tb-btn{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;color:var(--ink-soft);cursor:pointer;font-size:13px;font-weight:500}.doc-toolbar .tb-btn:hover{background:var(--panel-2);color:var(--ink)}.doc-toolbar .tb-btn.active{background:var(--accent-soft);color:var(--accent)}.doc-toolbar .tb-btn svg{width:15px;height:15px}.doc-toolbar select{background:transparent;border:1px solid var(--line);color:var(--ink-soft);border-radius:4px;padding:3px 6px;font-size:12px;outline:none}.doc-body{flex:1;display:flex;min-height:0;overflow:hidden}.doc-outline{width:200px;flex:0 0 auto;background:var(--bg-soft);border-right:1px solid var(--line);overflow-y:auto;padding:12px 8px 12px 12px;transition:width .25s var(--ease),opacity .2s,padding .25s var(--ease)}.doc-outline.hidden{width:0;padding-left:0;padding-right:0;opacity:0;pointer-events:none}.doc-outline-title{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-dim);font-weight:600;padding:4px 8px;margin-bottom:6px}.doc-outline-list{list-style:none;padding:0;margin:0}.doc-outline-item{display:block;width:100%;text-align:left;background:transparent;border:none;padding:5px 8px;border-radius:4px;color:var(--ink-soft);cursor:pointer;font-size:12.5px;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-left:2px solid transparent}.doc-outline-item:hover{background:var(--panel);color:var(--ink)}.doc-outline-item.active{background:var(--panel-2);color:var(--ink);border-left-color:var(--accent)}.doc-outline-item .id-tag{font-family:var(--font-mono);font-size:10px;color:var(--ink-dim);margin-right:6px}.doc-outline-item.active .id-tag{color:var(--accent)}.doc-scroll{flex:1;overflow-y:auto;padding:48px 0 200px;scroll-behavior:smooth}.doc-page{max-width:min(720px,92%);margin:0 auto;padding:56px clamp(28px,6%,80px);background:var(--panel);border:1px solid var(--line);border-radius:4px;font-family:var(--font-doc);font-size:16.5px;line-height:1.7;color:var(--ink);box-shadow:0 6px 30px #0000004d;min-height:1100px}.doc-page h1{font-size:30px;font-weight:600;letter-spacing:-.01em;margin:0 0 4px;line-height:1.2}.doc-page h2{font-size:21px;font-weight:600;margin:38px 0 12px;letter-spacing:-.005em;scroll-margin-top:24px;display:flex;align-items:baseline;gap:12px}.doc-page h2 .node-id{font-family:var(--font-mono);font-size:12px;color:var(--ink-dim);font-weight:500;background:var(--bg-soft);padding:2px 7px;border-radius:4px;border:1px solid var(--line)}.doc-page h2.is-active .node-id{color:var(--accent);border-color:var(--accent-soft);background:var(--accent-soft)}.doc-page p{margin:0 0 1em;text-wrap:pretty}.doc-page p:last-child{margin-bottom:0}.doc-page .node-link{display:inline-flex;align-items:center;gap:3px;font-family:var(--font-mono);font-size:13px;color:var(--accent);background:var(--accent-soft);padding:1px 7px;border-radius:3px;text-decoration:none;margin:0 2px;cursor:pointer;border:1px solid transparent;transition:border-color .15s var(--ease)}.doc-page .node-link:hover{border-color:var(--accent)}.doc-status{display:flex;align-items:center;gap:12px;height:28px;padding:0 14px;border-top:1px solid var(--line);background:var(--bg);color:var(--ink-dim);font-size:11.5px;font-family:var(--font-mono);flex:0 0 auto}.doc-status .sep{color:var(--line-strong)}.doc-status .saved{color:var(--good)}.app-shell.focus-mode .topbar,.app-shell.focus-mode .doc-toolbar,.app-shell.focus-mode .doc-status,.app-shell.focus-mode .sidebar-nav,.app-shell.focus-mode .doc-outline{display:none}.app-shell.focus-mode .doc-pane{border-left:none}.app-shell.focus-mode .doc-page{box-shadow:none;border:none;background:transparent}.read-shell{flex:1;display:flex;flex-direction:column;min-height:0}.read-bar{display:flex;align-items:center;gap:12px;height:44px;padding:0 16px;border-bottom:1px solid var(--line);background:var(--bg);flex:0 0 auto}.read-bar .toggle{display:inline-flex;background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:2px}.read-bar .toggle button{background:transparent;border:none;color:var(--ink-dim);font-size:11.5px;padding:4px 10px;border-radius:4px;cursor:pointer;font-weight:500}.read-bar .toggle button.active{background:var(--panel-2);color:var(--ink)}.read-stage{flex:1;overflow-y:auto;background:var(--paper-bg);color:var(--paper-ink);padding:60px 24px 120px;scroll-behavior:smooth}.read-page{max-width:620px;margin:0 auto;font-family:var(--font-doc)}.read-page .chapter-num{font-family:var(--font-mono);font-size:11px;color:var(--paper-ink-dim);letter-spacing:.16em;text-transform:uppercase;margin-bottom:6px;display:block}.read-page h1{font-size:34px;margin:0 0 32px;font-weight:600;letter-spacing:-.01em;line-height:1.15;border-bottom:1px solid var(--paper-rule);padding-bottom:18px}.read-page p{font-size:19px;line-height:1.75;margin:0 0 1.1em;text-wrap:pretty;-webkit-hyphens:auto;hyphens:auto}.read-page .first-letter:first-letter{font-size:3.4em;float:left;line-height:.85;padding:6px 8px 0 0;font-weight:600}.read-choices{margin-top:44px;padding-top:24px;border-top:1px solid var(--paper-rule)}.read-choices .label{font-family:var(--font-mono);font-size:11px;color:var(--paper-ink-dim);text-transform:uppercase;letter-spacing:.14em;margin-bottom:14px;display:block}.read-choice{display:block;width:100%;text-align:left;background:transparent;border:1px solid var(--paper-rule);border-radius:4px;padding:14px 18px;margin-bottom:10px;font-family:var(--font-doc);font-size:17px;color:var(--paper-ink);cursor:pointer;transition:all .18s var(--ease);position:relative}.read-choice:hover{background:#0000000a;border-color:var(--paper-ink);transform:translate(2px)}[data-reading=dark] .read-choice:hover{background:#ffffff0a}.read-choice .num{font-family:var(--font-mono);font-size:11px;color:var(--paper-ink-dim);margin-right:12px}.read-stage.editor-mode .read-choice:after{content:attr(data-target);position:absolute;right:16px;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:10.5px;color:var(--paper-ink-dim);background:#0000000d;padding:1px 6px;border-radius:3px}[data-reading=dark] .read-stage.editor-mode .read-choice:after{background:#ffffff0d}.read-breadcrumb{position:sticky;bottom:0;display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;color:var(--paper-ink-dim);background:linear-gradient(to top,var(--paper-bg) 70%,transparent);padding:16px 24px 14px;flex-wrap:wrap;max-width:620px;margin:32px auto 0}.read-breadcrumb .crumb{padding:2px 6px;border-radius:3px;cursor:pointer;background:transparent;border:none;color:inherit;font:inherit}.read-breadcrumb .crumb:hover{background:#0000000f}[data-reading=dark] .read-breadcrumb .crumb:hover{background:#ffffff0f}.read-breadcrumb .crumb.current{color:var(--paper-ink);font-weight:600}.read-breadcrumb .sep{opacity:.5}.cmd-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d111799;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;display:flex;justify-content:center;align-items:flex-start;padding-top:12vh}.cmd-palette{width:540px;max-width:90vw;background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 24px 60px #00000080}.cmd-input{width:100%;padding:16px 20px;background:transparent;border:none;border-bottom:1px solid var(--line);color:var(--ink);font-size:16px;outline:none;font-family:var(--font-ui)}.cmd-list{max-height:360px;overflow-y:auto;padding:6px}.cmd-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:6px;font-size:13px;color:var(--ink-soft);cursor:pointer;border:none;background:transparent;width:100%;text-align:left}.cmd-item:hover,.cmd-item.active{background:var(--panel-2);color:var(--ink)}.cmd-item .cmd-icon{color:var(--ink-dim);display:inline-flex}.cmd-item.active .cmd-icon{color:var(--accent)}.cmd-item .cmd-shortcut{margin-left:auto}.cmd-section{font-size:10px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.1em;padding:8px 14px 4px;font-weight:600}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d111799;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:40;display:flex;justify-content:center;align-items:center}.modal-card{width:460px;max-width:90vw;background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--r-lg);box-shadow:0 24px 60px #00000080;overflow:hidden}.modal-card header{padding:14px 20px;border-bottom:1px solid var(--line);font-weight:600;display:flex;align-items:center;gap:8px}.modal-card .body{padding:16px 20px;display:flex;flex-direction:column;gap:18px}.modal-card .row{display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-card .row label{color:var(--ink-soft)}.modal-card .section-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-dim);font-weight:600;margin-bottom:8px}.modal-card footer{padding:12px 20px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px}.modal{width:520px;max-width:92vw;background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 24px 70px #00000080}.modal.lg{width:640px;max-height:84vh;display:flex;flex-direction:column}.modal.lg .modal-body{overflow-y:auto}.modal.sm{width:420px}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line)}.modal-head h3{margin:0;font-size:15px;font-weight:600}.modal-body{padding:8px 18px 18px}.modal-foot{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.field-label{display:block;font-size:12px;color:var(--ink-dim);margin:6px 0}.field-input{width:100%;background:var(--bg-soft);border:1px solid var(--line);border-radius:7px;padding:10px 12px;color:var(--ink);font-size:14px;font-family:var(--font-ui);outline:none}.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.stat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:16px}.stat{display:flex;flex-direction:column;align-items:center;gap:2px;background:var(--bg-soft);border:1px solid var(--line);border-radius:9px;padding:12px 6px}.stat-num{font-size:22px;font-weight:700;color:var(--ink);font-family:var(--font-ui)}.stat-lbl{font-size:10.5px;color:var(--ink-dim);text-align:center}.insight-note{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--warn);background:#f0b9551a;border:1px solid rgba(240,185,85,.25);border-radius:8px;padding:9px 12px;margin-bottom:14px}.insight-row{padding:12px 0;border-bottom:1px solid var(--line)}.insight-row:last-child{border-bottom:none}.insight-head{display:flex;align-items:center;gap:9px;margin-bottom:8px}.insight-icon{display:inline-flex;color:var(--ink-dim)}.insight-row.warn .insight-icon{color:var(--warn)}.insight-label{font-size:13px;font-weight:600;color:var(--ink)}.insight-count{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--ink-dim);background:var(--bg-soft);padding:1px 8px;border-radius:999px}.insight-chips{display:flex;flex-wrap:wrap;gap:6px}.insight-chip{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;background:var(--bg-soft);border:1px solid var(--line);border-radius:7px;padding:5px 10px;font-size:12px;color:var(--ink-soft);cursor:pointer;font-family:var(--font-ui)}.insight-chip:hover{border-color:var(--accent);color:var(--ink)}.chip-dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto}.insight-ok{font-size:12.5px;color:var(--good)}.longest-path{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.path-arrow{color:var(--ink-dim);font-family:var(--font-mono)}.hist-empty{font-size:13px;color:var(--ink-dim);text-align:center;padding:24px 12px;line-height:1.5}.hist-list{display:flex;flex-direction:column}.hist-item{display:flex;align-items:center;gap:11px;padding:11px 4px;border-bottom:1px solid var(--line)}.hist-item:last-child{border-bottom:none}.hist-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex:0 0 auto;box-shadow:0 0 0 3px var(--accent-soft)}.hist-main{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.hist-label{font-size:13px;color:var(--ink);font-weight:500}.hist-meta{font-size:11px;color:var(--ink-dim);font-family:var(--font-mono)}.export-opt{display:flex;align-items:flex-start;gap:12px;width:100%;text-align:left;background:var(--bg-soft);border:1px solid var(--line);border-radius:9px;padding:14px;margin-bottom:10px;cursor:pointer;transition:border-color .15s var(--ease),background .15s var(--ease)}.export-opt:hover{border-color:var(--accent);background:var(--panel-2)}.export-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:8px;flex:0 0 auto;background:var(--accent-soft);color:var(--accent)}.export-title{display:block;font-size:14px;font-weight:600;color:var(--ink)}.export-desc{display:block;font-size:12px;color:var(--ink-dim);margin-top:2px;line-height:1.4}.proj-menu{position:relative;flex:0 0 auto}.proj-trigger{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid transparent;cursor:pointer;color:var(--ink);font-family:var(--font-doc);font-style:italic;font-size:15px;padding:5px 8px;border-radius:6px;max-width:230px}.proj-trigger:hover{background:var(--panel);border-color:var(--line)}.proj-trigger-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-trigger svg{color:var(--ink-dim);flex:0 0 auto}.proj-pop{position:absolute;top:calc(100% + 6px);left:0;z-index:40;width:320px;background:var(--panel);border:1px solid var(--line-strong);border-radius:10px;box-shadow:0 18px 50px #00000073;padding:6px;overflow:hidden}.proj-pop-section{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-dim);font-weight:600;padding:8px 10px 4px}.proj-list{max-height:280px;overflow-y:auto}.proj-item{display:flex;align-items:center;gap:8px;width:100%;background:transparent;border:none;cursor:pointer;padding:8px 10px;border-radius:7px;text-align:left;color:var(--ink-soft)}.proj-item:hover{background:var(--panel-2)}.proj-item.active{background:var(--accent-soft)}.proj-item-main{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.proj-item-name{font-size:13px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-item.active .proj-item-name{color:var(--accent)}.proj-item-meta{font-size:11px;color:var(--ink-dim);font-family:var(--font-mono)}.proj-item-tools{display:inline-flex;gap:2px;opacity:0;transition:opacity .12s}.proj-item:hover .proj-item-tools{opacity:1}.proj-mini{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:5px;color:var(--ink-dim);cursor:pointer}.proj-mini:hover{background:var(--line);color:var(--ink)}.proj-mini.danger:hover{color:var(--danger);background:#f06a6a1f}.proj-pop-divider{height:1px;background:var(--line);margin:6px 4px}.proj-action{display:flex;align-items:center;gap:9px;width:100%;background:transparent;border:none;cursor:pointer;padding:8px 10px;border-radius:7px;color:var(--ink-soft);font-size:13px}.proj-action:hover{background:var(--panel-2);color:var(--ink)}.proj-action svg{color:var(--ink-dim)}.graph-search{position:absolute;top:12px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:7px;z-index:6;background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:6px 12px;color:var(--ink-dim);box-shadow:0 6px 18px #00000040}.graph-search input{background:transparent;border:none;outline:none;color:var(--ink);font-family:var(--font-ui);font-size:13px;width:150px}.graph-search input::placeholder{color:var(--ink-dim)}.graph-search-count{font-family:var(--font-mono);font-size:11px;color:var(--accent);background:var(--accent-soft);padding:1px 7px;border-radius:999px}.graph-search-clear{display:inline-flex;background:transparent;border:none;cursor:pointer;color:var(--ink-dim);padding:2px;border-radius:4px}.graph-search-clear:hover{color:var(--ink);background:var(--panel-2)}.node-card.dimmed{opacity:.28;filter:saturate(.5);transition:opacity .15s var(--ease)}.node-card.matched{box-shadow:0 0 0 2px var(--accent),0 8px 22px #0006}[data-app=workshop]{--bg: #f7f6f3;--bg-soft: #efece6;--panel: #ffffff;--panel-2: #f2efe9;--line: #e7e2d8;--line-strong: #d8d2c4;--card: #ffffff;--ink: #20242c;--ink-soft: #4b515c;--ink-dim: #8a8f99;--accent: #15727a;--accent-2: #0e5b62;--accent-soft: #dcebec;--accent-ink: #0b474c;--good: #1f9d6b;--warn: #c98a16;--danger: #d6483b;--danger-soft: #f6e2df;--edge: #9a937f;--soft-shadow: 0 10px 30px rgba(40, 44, 56, .1), 0 2px 6px rgba(40, 44, 56, .06);--lift-shadow: 0 18px 44px rgba(40, 44, 56, .2), 0 4px 12px rgba(40, 44, 56, .12);color:var(--ink);background:var(--bg)}
