*{box-sizing:border-box;margin:0;padding:0}html,body,#root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f7f8fa;width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Helvetica Neue,PingFang SC,Microsoft YaHei,Source Han Sans SC,Noto Sans CJK SC,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:#d9d9d9;border-radius:3px}::-webkit-scrollbar-track{background:0 0}.sidebar{background:#fff;border-right:1px solid #dee0e3;flex-direction:column;width:260px;min-width:260px;height:100vh;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid #f0f0f0;align-items:center;gap:10px;padding:16px 16px 12px;display:flex}.space-icon{color:#fff;background:linear-gradient(135deg,#5b6ae0,#7b61ff);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;font-weight:600;display:flex}.space-info{flex-direction:column;gap:2px;min-width:0;display:flex}.space-name{color:#1f2329;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.space-badge{color:#3370ff;background:#e8f0fe;border-radius:3px;width:fit-content;padding:1px 6px;font-size:11px}.sidebar-search{color:#8f959e;cursor:pointer;border-radius:6px;align-items:center;gap:6px;margin:8px 12px;padding:6px 10px;font-size:13px;display:flex}.sidebar-search:hover{background:#f5f6f7}.sidebar-nav{flex:1;padding:4px 0;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:#d9d9d9;border-radius:2px}.nav-section-title{color:#1f2329;cursor:pointer;align-items:center;gap:4px;padding:6px 12px;font-size:13px;font-weight:500;display:flex}.nav-section-title:hover{background:#f5f6f7}.chapter-item{-webkit-user-select:none;user-select:none}.chapter-title{color:#1f2329;cursor:pointer;white-space:nowrap;text-overflow:ellipsis;border-radius:4px;align-items:center;gap:4px;margin:0 4px;padding:5px 12px;font-size:13px;line-height:1.4;display:flex;overflow:hidden}.chapter-title:hover{background:#f5f6f7}.chapter-title.active{color:#3370ff;background:#e8f0fe}.chapter-title.active .doc-icon svg path{stroke:#3370ff}.chapter-arrow{flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:flex}.arrow-icon{color:#8f959e;transition:transform .15s}.arrow-icon.expanded{transform:rotate(90deg)}.chapter-icon{flex-shrink:0;font-size:14px}.doc-icon{flex-shrink:0;align-items:center;display:flex}.has-icon .doc-icon{display:none}.chapter-text{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.toc{align-self:flex-start;width:200px;min-width:200px;max-height:calc(100vh - 100px);padding:0 8px 32px 0;position:sticky;top:32px;overflow-y:auto}.toc::-webkit-scrollbar{width:3px}.toc::-webkit-scrollbar-thumb{background:0 0}.toc:hover::-webkit-scrollbar-thumb{background:#d9d9d9}.toc-inner{border-left:1px solid #e5e6eb}.toc-item{color:#8f959e;cursor:pointer;text-overflow:ellipsis;white-space:nowrap;border-left:2px solid #0000;margin-left:-1px;padding:4px 0 4px 12px;font-size:12px;line-height:1.6;transition:color .15s,border-color .15s;overflow:hidden}.toc-item:hover{color:#1f2329}.toc-item.active{color:#3370ff;border-left-color:#3370ff}.toc-level-1{padding-left:12px;font-size:13px;font-weight:500}.toc-level-2{padding-left:12px}.toc-level-3{padding-left:24px}.content-view{background:#f7f8fa;flex-direction:column;flex:1;min-width:0;display:flex;position:relative}.breadcrumb{color:#8f959e;white-space:nowrap;background:#fff;border-bottom:1px solid #f0f0f0;align-items:center;gap:6px;padding:10px 24px;font-size:12px;display:flex;overflow:hidden}.breadcrumb-sep{color:#c4c6cc}.breadcrumb-item{cursor:pointer}.breadcrumb-item:hover{color:#3370ff}.breadcrumb-item.current{color:#1f2329}.content-body{flex:1;justify-content:center;align-items:flex-start;gap:16px;padding:32px 24px;display:flex;overflow-y:auto}.article{color:#1f2329;background:#fff;border-radius:8px;width:100%;max-width:800px;min-height:400px;padding:40px 48px;font-size:15px;line-height:1.8;box-shadow:0 1px 3px #0000000a}.article h1{color:#1f2329;margin:0 0 24px;font-size:28px;font-weight:700;line-height:1.4}.article h2{color:#1f2329;border-bottom:1px solid #f0f0f0;margin:32px 0 16px;padding-bottom:8px;font-size:22px;font-weight:600}.article h3{color:#1f2329;margin:24px 0 12px;font-size:18px;font-weight:600}.article p{margin:8px 0 16px}.article ul,.article ol{margin:8px 0 16px;padding-left:24px}.article li{margin:4px 0}.article strong{color:#1f2329;font-weight:600}.article blockquote{color:#646a73;background:#f7f8fa;border-left:3px solid #3370ff;border-radius:0 4px 4px 0;margin:16px 0;padding:12px 16px;overflow:hidden}.article code{color:#d63384;background:#f5f6f7;border-radius:3px;padding:2px 6px;font-family:SF Mono,Menlo,monospace;font-size:13px}.article pre{color:#d4d4d4;background:#1e1e1e;border-radius:6px;margin:12px 0 16px;padding:16px 20px;font-size:13px;line-height:1.6;overflow-x:auto}.article pre code{color:inherit;background:0 0;padding:0}.shiki-wrapper{margin:12px 0 16px;position:relative}.shiki-wrapper pre.shiki{border-radius:6px;margin:0;padding:16px 20px;font-family:SF Mono,Menlo,monospace;font-size:13px;line-height:1.6;overflow-x:auto}.shiki-wrapper pre.shiki code{color:inherit;font-size:inherit;background:0 0;padding:0}.code-lang-label{color:#6272a4;-webkit-user-select:none;user-select:none;opacity:0;font-family:SF Mono,Menlo,monospace;font-size:11px;transition:opacity .15s;position:absolute;top:8px;left:12px}.shiki-wrapper:hover .code-lang-label{opacity:1}.code-copy-btn{color:#8f959e;cursor:pointer;opacity:0;background:#ffffff1a;border:1px solid #ffffff26;border-radius:4px;padding:4px 10px;font-size:12px;transition:opacity .15s;position:absolute;top:8px;right:8px}.shiki-wrapper:hover .code-copy-btn{opacity:1}.code-copy-btn:hover{color:#fff;background:#fff3}.article img{border-radius:8px;max-width:100%;margin:16px 0}.article table{border-collapse:collapse;width:100%;margin:16px 0}.article th,.article td{text-align:left;border:1px solid #dee0e3;padding:8px 12px;font-size:14px}.article th{background:#f5f6f7;font-weight:600}.content-placeholder{text-align:center;color:#8f959e;padding:80px 0}.content-placeholder h1{color:#646a73;margin-bottom:8px;font-size:20px}.empty-hint{text-align:center;color:#8f959e;padding:80px 0}.article .meta-info{color:#8f959e;align-items:center;gap:12px;margin-bottom:24px;font-size:13px;display:flex}.article .meta-info .author{align-items:center;gap:6px;display:flex}.article .meta-info .avatar{background:#e8e8e8;border-radius:50%;width:24px;height:24px}.article .image-placeholder{justify-content:center;margin:16px 0;display:flex}.article .image-placeholder-inner{color:#8f959e;text-align:center;background:#f5f6f7;border:1px dashed #dee0e3;border-radius:8px;padding:40px 60px;font-size:14px}.article .chapter-links a{color:#3370ff;text-decoration:none}.article .chapter-links a:hover{text-decoration:underline}.article .chapter-links li{margin:8px 0}.article .content-image{text-align:center;margin:20px 0}.article .content-image img{border-radius:6px;max-width:100%;box-shadow:0 2px 8px #00000014}.article .image-caption{color:#8f959e;margin-top:8px;font-size:13px}.article .image-caption:empty{display:none}.article .callout-block{color:#1f2329;background:#f7f8fa;border-radius:8px;flex-wrap:wrap;align-items:center;gap:4px;margin:16px 0;padding:12px 16px;font-size:14px;display:flex}.article .file-link{color:#3370ff;background:#fff;border:1px solid #dee0e3;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:14px;text-decoration:none;display:inline-flex}.article .file-link:hover{background:#f0f4ff;border-color:#3370ff}.article .content-label{color:#8f959e;text-align:center;margin:4px 0 12px;font-size:13px}.article .file-attachment{margin:12px 0}.article .file-attachment .file-card{color:#1f2329;border:1px solid #dee0e3;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;text-decoration:none;transition:border-color .15s,background .15s;display:flex}.article .file-attachment .file-card:hover{background:#f0f4ff;border-color:#3370ff}.article .file-attachment .file-icon{font-size:24px}.article .file-attachment .file-info{flex-direction:column;gap:2px;display:flex}.article .file-attachment .file-name{color:#1f2329;font-size:14px;font-weight:500}.article .file-attachment .file-size{color:#8f959e;font-size:12px}.back-to-top{color:#3370ff;cursor:pointer;opacity:0;pointer-events:none;z-index:20;background:#fff;border:0;border-radius:999px;justify-content:center;align-items:center;width:44px;height:44px;transition:opacity .2s,transform .2s,box-shadow .2s,background .2s;display:inline-flex;position:absolute;bottom:28px;right:28px;transform:translateY(12px);box-shadow:0 8px 24px #1f232924}.back-to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.back-to-top:hover{color:#fff;background:#3370ff;box-shadow:0 10px 28px #3370ff42}.back-to-top svg{stroke:currentColor;stroke-width:2px;fill:none;stroke-linecap:round;stroke-linejoin:round;width:20px;height:20px}.app-layout{width:100vw;height:100vh;display:flex;overflow:hidden}
