.header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100;height:3rem}.header-left{display:flex;align-items:center;gap:.75rem}.header-title{font-weight:700;font-size:1.1rem;color:var(--color-text);text-decoration:none}.header-title:hover{color:var(--color-primary)}.header-right{display:flex;align-items:center;gap:.25rem}.menu-toggle{display:inline-flex}.footer{padding:1rem;text-align:center;border-top:1px solid var(--color-border);color:var(--color-text-muted);font-size:.85rem;margin-top:auto}.footer-link{color:var(--color-text-muted);text-decoration:none;transition:color .15s}.footer-link:hover{color:var(--color-primary);text-decoration:underline}.sidebar{width:280px;min-width:280px;position:sticky;top:3rem;height:calc(100vh - 3rem);background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden;transition:margin-left .25s ease,opacity .25s ease;margin-left:0;z-index:90}.sidebar.collapsed{margin-left:-280px;opacity:0;pointer-events:none}.sidebar-backdrop{display:none}.sidebar-header{border-bottom:1px solid var(--color-border)}.sidebar-tabs{display:flex}.tab{flex:1;padding:.6rem;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:.85rem;color:var(--color-text-muted);transition:all .15s}.tab:hover{background:var(--color-hover)}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.sidebar-content{flex:1;overflow-y:auto;padding:.25rem 0}.file-tree{font-size:.875rem}.tree-node{display:flex;align-items:center;gap:.4rem;width:100%;padding:.35rem .5rem;background:none;border:none;cursor:pointer;font-size:.85rem;color:var(--color-text);text-align:left;border-radius:4px;transition:background .1s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-node:hover{background:var(--color-hover)}.tree-node.selected{background:var(--color-primary-bg);color:var(--color-primary);font-weight:600}.tree-icon{font-size:1rem;flex-shrink:0}.tree-name{overflow:hidden;text-overflow:ellipsis}.tags-list{padding:.5rem;display:flex;flex-wrap:wrap;gap:.4rem}.tag-pill{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .6rem;background:var(--color-tag-bg);color:var(--color-primary);border:1px solid var(--color-border);border-radius:999px;font-size:.8rem;cursor:pointer;transition:all .15s}.tag-pill:hover{background:var(--color-primary);color:#fff}.tag-count{font-size:.7rem;opacity:.7}.empty-state{padding:1rem;text-align:center;color:var(--color-text-muted);font-size:.85rem}@media(max-width:768px){.sidebar{position:fixed;top:3rem;left:0;height:calc(100vh - 3rem);margin-left:0;opacity:1;transform:translate(-100%);transition:transform .25s ease;box-shadow:2px 0 12px #00000026;pointer-events:auto}.sidebar.collapsed{margin-left:0;opacity:1;transform:translate(-100%)}.sidebar.open{transform:translate(0);pointer-events:auto}.sidebar-backdrop{display:block;position:fixed;inset:0;top:3rem;background:#0000004d;z-index:89}}.doc-stats{display:flex;gap:1rem;font-size:.8rem;color:var(--color-text-muted);margin-bottom:1rem;padding:.4rem 0;border-bottom:1px solid var(--color-border)}.doc-stats span{display:inline-flex;align-items:center;gap:.25rem}.doc-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem}.doc-tag{display:inline-flex;align-items:center;gap:.2rem;padding:.2rem .5rem;background:var(--color-tag-bg);color:var(--color-primary);border-radius:999px;font-size:.78rem;font-weight:500}.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:.15rem;font-size:.85rem;margin-bottom:1rem;color:var(--color-text-muted)}.breadcrumb-item{background:none;border:none;color:var(--color-primary);cursor:pointer;padding:.15rem .3rem;border-radius:4px;font-size:inherit}.breadcrumb-item:hover{background:var(--color-hover);text-decoration:underline}.breadcrumb-sep{color:var(--color-text-muted);margin:0 .1rem}.breadcrumb-current{color:var(--color-text);font-weight:500}.copy-code-btn{position:absolute;top:.5rem;right:.5rem;padding:.25rem .5rem;font-size:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;cursor:pointer;opacity:0;transition:opacity .15s;z-index:1;color:var(--color-text)}.code-block-wrapper:hover .copy-code-btn{opacity:1}.copy-code-btn:hover{background:var(--color-hover)}.toc{padding:.75rem;border:1px solid var(--color-border);border-radius:8px;margin-bottom:1rem}.toc-title{font-size:.85rem;font-weight:600;color:var(--color-text-muted);margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.05em}.toc-list{list-style:none;padding:0;margin:0}.toc-item{margin:0}.toc-link{display:block;width:100%;text-align:left;padding:.25rem .4rem;font-size:.8rem;color:var(--color-text-muted);background:none;border:none;border-left:2px solid transparent;cursor:pointer;border-radius:0 4px 4px 0;transition:all .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toc-link:hover{color:var(--color-text);background:var(--color-hover)}.toc-link.active{color:var(--color-primary);border-left-color:var(--color-primary);font-weight:500}.related-content{border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.related-toggle{display:flex;align-items:center;gap:.4rem;width:100%;padding:.6rem .75rem;background:none;border:none;cursor:pointer;font-size:.85rem;font-weight:600;color:var(--color-text-muted);text-align:left}.related-toggle:hover{background:var(--color-hover)}.related-sections{padding:0 .75rem .75rem}.related-section{margin-top:.5rem}.related-section-title{font-size:.78rem;font-weight:600;color:var(--color-text-muted);margin:0 0 .3rem}.related-section ul{list-style:none;padding:0;margin:0}.related-link{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:.8rem;padding:.15rem 0;text-align:left}.related-link:hover{text-decoration:underline}.ref-count{font-size:.7rem;color:var(--color-text-muted);margin-left:.3rem}.shared-tags{font-size:.75rem;color:var(--color-primary);font-style:italic}.template-meta,.effort-meta{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;margin:.5rem 0 1rem;font-size:.85rem;color:var(--color-text-muted)}.template-desc,.effort-desc{font-size:1.05rem;color:var(--color-text-muted);margin:.25rem 0 .5rem;font-style:italic}.status-badge{padding:.2rem .6rem;border-radius:999px;font-size:.78rem;font-weight:600;text-transform:capitalize}.status-active,.status-in-progress{background:#e8f5e9;color:#2e7d32}.status-planned{background:#e3f2fd;color:#1565c0}.status-completed,.status-done{background:#f3e5f5;color:#7b1fa2}.status-blocked{background:#fbe9e7;color:#c62828}.priority-badge{font-size:.78rem;font-weight:500;color:var(--color-text-muted)}.effort-dates{display:flex;gap:1rem;font-size:.85rem;color:var(--color-text-muted);margin-bottom:.75rem}.effort-links{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.effort-link{font-size:.85rem;color:var(--color-primary);text-decoration:none}.effort-link:hover{text-decoration:underline}.doc-layout{display:flex;gap:2rem;max-width:1200px;padding:1.5rem}.markdown-content{flex:1;min-width:0;max-width:800px}.doc-sidebar{width:240px;min-width:240px;position:sticky;top:4rem;max-height:calc(100vh - 5rem);overflow-y:auto}.markdown-content h1{font-size:2rem;margin:.5em 0 .3em;border-bottom:1px solid var(--color-border);padding-bottom:.3em}.markdown-content h2{font-size:1.5rem;margin:1.5em 0 .3em;border-bottom:1px solid var(--color-border);padding-bottom:.2em}.markdown-content h3{font-size:1.25rem;margin:1.2em 0 .3em}.markdown-content h4{font-size:1.1rem;margin:1em 0 .3em}.markdown-content p{line-height:1.7;margin:.8em 0}.markdown-content a{color:var(--color-primary);text-decoration:none}.markdown-content a:hover{text-decoration:underline}.markdown-content img{max-width:100%;border-radius:8px;margin:1em 0}.markdown-content blockquote{border-left:4px solid var(--color-primary);margin:1em 0;padding:.5em 1em;background:var(--color-hover);border-radius:0 8px 8px 0}.markdown-content ul,.markdown-content ol{padding-left:1.5em;margin:.5em 0}.markdown-content li{margin:.3em 0;line-height:1.6}.markdown-content code{background:var(--color-code-bg);padding:.15em .4em;border-radius:4px;font-size:.9em}.markdown-content pre{margin:0;padding:1rem;overflow-x:auto;border-radius:8px;background:var(--color-code-bg);font-size:.875rem;line-height:1.5}.markdown-content pre code{background:none;padding:0;font-size:inherit}.code-block-wrapper{position:relative;margin:1em 0}.table-wrapper{overflow-x:auto;margin:1em 0}.markdown-content table{width:100%;border-collapse:collapse}.markdown-content th,.markdown-content td{padding:.6rem .8rem;border:1px solid var(--color-border);text-align:left}.markdown-content th{background:var(--color-hover);font-weight:600}.markdown-content tr:nth-child(2n){background:var(--color-hover)}.markdown-content hr{border:none;border-top:1px solid var(--color-border);margin:2em 0}.markdown-loading,.markdown-error{padding:2rem;text-align:center;color:var(--color-text-muted)}.markdown-error h2{color:var(--color-error)}.mermaid-loading{padding:1rem;text-align:center;color:var(--color-text-muted);font-style:italic}@media(max-width:1024px){.doc-sidebar{display:none}.doc-layout{padding:1rem}}.welcome{max-width:800px;margin:0 auto;padding:2rem 1.5rem}.welcome-hero{text-align:center;margin-bottom:2rem}.welcome-hero h1{font-size:2.5rem;margin:0 0 .5rem;background:linear-gradient(135deg,var(--color-primary),#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-desc{font-size:1.1rem;color:var(--color-text-muted);max-width:500px;margin:0 auto}.welcome-search{display:flex;align-items:center;gap:.75rem;max-width:500px;margin:0 auto 2rem;padding:.85rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;cursor:pointer;transition:border-color .2s,box-shadow .2s}.welcome-search:hover{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.welcome-search-icon{font-size:1.1rem;opacity:.5}.welcome-search-text{flex:1;font-size:.95rem;color:var(--color-text-muted)}.welcome-search-kbd{padding:.2rem .5rem;font-size:.7rem;background:var(--color-hover);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-muted);font-family:inherit}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:2rem}.feature-card{padding:1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;text-align:center;transition:transform .15s,box-shadow .15s}.feature-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.feature-icon{font-size:2rem;display:block;margin-bottom:.5rem}.feature-card h3{margin:0 0 .3rem;font-size:1rem}.feature-card p{margin:0;font-size:.85rem;color:var(--color-text-muted);line-height:1.4}.folder-view{max-width:800px;padding:1.5rem}.folder-view-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.folder-view-icon{font-size:2rem}.folder-view-header h1{margin:0;font-size:1.75rem}.folder-view-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.folder-view-item{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s,transform .15s;color:var(--color-text);font-size:.9rem}.folder-view-item:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.folder-view-item-icon{font-size:1.5rem;flex-shrink:0}.folder-view-item-name{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-view-item-count{font-size:.75rem;color:var(--color-text-muted);white-space:nowrap}.folder-view-empty{text-align:center;padding:3rem 1rem;color:var(--color-text-muted)}.folder-view-back{margin-top:1rem;padding:.5rem 1rem;background:var(--color-primary);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem}.folder-view-back:hover{opacity:.9}.folder-view-loading{padding:2rem;text-align:center;color:var(--color-text-muted)}.search-overlay{position:fixed;inset:0;background:#00000080;z-index:200;display:flex;justify-content:center;padding-top:15vh}.search-modal{width:min(600px,90vw);max-height:60vh;background:var(--color-surface);border-radius:12px;box-shadow:0 16px 70px #0000004d;overflow:hidden;display:flex;flex-direction:column}.search-input-wrapper{display:flex;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);gap:.5rem}.search-icon{font-size:1.1rem;opacity:.5}.search-input{flex:1;border:none;outline:none;background:none;font-size:1rem;color:var(--color-text)}.search-kbd{padding:.15rem .4rem;font-size:.7rem;background:var(--color-hover);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-muted)}.search-results{overflow-y:auto;flex:1}.search-result{display:block;width:100%;padding:.75rem 1rem;background:none;border:none;border-bottom:1px solid var(--color-border);cursor:pointer;text-align:left;color:var(--color-text);transition:background .1s}.search-result:hover,.search-result.selected{background:var(--color-hover)}.result-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.25rem}.result-title{font-weight:600;font-size:.9rem;flex:1}.result-score{font-size:.8rem;color:#f59e0b}.result-excerpt{font-size:.8rem;color:var(--color-text-muted);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.result-path{font-size:.7rem;color:var(--color-text-muted);opacity:.6}.search-loading,.search-empty{padding:2rem 1rem;text-align:center;color:var(--color-text-muted)}.graph-overlay{position:fixed;inset:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center}.graph-modal{width:min(900px,95vw);height:min(700px,85vh);background:var(--color-surface);border-radius:12px;box-shadow:0 16px 70px #0000004d;display:flex;flex-direction:column;overflow:hidden}.graph-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--color-border)}.graph-header h3{margin:0;font-size:1rem}.graph-controls{display:flex;align-items:center;gap:.5rem}.graph-toggle{display:inline-flex;align-items:center;gap:.25rem;font-size:.8rem;cursor:pointer;color:var(--color-text-muted)}.graph-legend{display:flex;gap:1rem;padding:.4rem 1rem;font-size:.75rem;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:.25rem;vertical-align:middle}.graph-container{flex:1;min-height:0}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:3rem;height:3rem;border-radius:50%;background:var(--color-primary);color:#fff;border:none;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #0003;z-index:50;transition:transform .15s}.back-to-top:hover{transform:scale(1.1)}.reading-progress{position:fixed;top:3rem;left:0;right:0;height:3px;background:transparent;z-index:99}.reading-progress-bar{height:100%;background:var(--color-primary);transition:width .1s ease-out}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-body{display:flex;flex:1;min-height:0}.app-main{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto}.image-viewer{max-width:800px;padding:1.5rem}.image-viewer-title{text-align:center;font-size:1.5rem;margin:.5rem 0 1.5rem}.image-viewer-figure{display:flex;flex-direction:column;align-items:center;margin:0}.image-viewer-figure img{max-width:100%;max-height:70vh;height:auto;border-radius:8px;border:1px solid var(--border, #e2e8f0);object-fit:contain}.image-viewer-caption{display:flex;justify-content:center;gap:1rem;margin-top:.75rem;font-size:.85rem;color:var(--text-muted, #94a3b8)}.image-viewer-ext{background:var(--bg-muted, #334155);color:var(--text-muted, #94a3b8);padding:.1rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;letter-spacing:.05em}:root{--color-bg: #ffffff;--color-surface: #f8f9fa;--color-text: #1a1a2e;--color-text-muted: #6b7280;--color-primary: #3b82f6;--color-primary-bg: #eff6ff;--color-border: #e5e7eb;--color-hover: #f3f4f6;--color-code-bg: #f1f5f9;--color-tag-bg: #eff6ff;--color-error: #dc2626}@media(prefers-color-scheme:dark){:root{--color-bg: #0f172a;--color-surface: #1e293b;--color-text: #e2e8f0;--color-text-muted: #94a3b8;--color-primary: #60a5fa;--color-primary-bg: #1e3a5f;--color-border: #334155;--color-hover: #293548;--color-code-bg: #1e293b;--color-tag-bg: #1e3a5f;--color-error: #f87171}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}button{font-family:inherit}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;background:none;border:1px solid transparent;border-radius:6px;cursor:pointer;font-size:1rem;color:var(--color-text-muted);transition:all .15s;text-decoration:none}.btn-icon:hover{background:var(--color-hover);border-color:var(--color-border);color:var(--color-text)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@media(prefers-color-scheme:dark){.hljs{background:var(--color-code-bg)!important;color:#e2e8f0!important}}.mermaid-container{display:flex;justify-content:center;margin:1em 0;overflow-x:auto}.mermaid-error{padding:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:var(--color-error)}.mermaid-error pre{margin-top:.5rem;font-size:.8rem;overflow-x:auto}
