:root{--bg:#f6f7f4;--panel:#fff;--panel-soft:#f9faf8;--text:#20242a;--muted:#667085;--line:#e1e5df;--line-strong:#cbd5c8;--accent:#1f7a5b;--accent-ink:#fff;--accent-soft:#e9f5ef;--danger:#b42318;--code-bg:#171b22;--code-text:#e7edf3;--list-width:280px;--toc-width:240px;--toc-collapsed-width:42px}[data-theme=dark]{--bg:#151714;--panel:#1d211e;--panel-soft:#242a25;--text:#ecefea;--muted:#a1aa9f;--line:#333a35;--line-strong:#475149;--accent:#71d7a7;--accent-ink:#102018;--accent-soft:#23382d;--danger:#ffb4a8;--code-bg:#111418;--code-text:#e7edf3}*{box-sizing:border-box}html,body{height:100%}body{background:var(--bg);color:var(--text);margin:0;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;line-height:1.65;overflow:hidden}button,input,textarea{font:inherit}button,a{color:inherit}button{cursor:pointer}a{text-decoration:none}.app-shell{grid-template-columns:var(--list-width) 6px var(--toc-width) minmax(0, 1fr);grid-template-rows:52px minmax(0,1fr) 48px;height:100vh;display:grid}.app-shell.toc-collapsed{grid-template-columns:var(--list-width) 6px var(--toc-collapsed-width) minmax(0, 1fr)}.article-list-panel{border-right:1px solid var(--line);background:var(--panel);flex-direction:column;grid-area:1/1/4;min-width:0;display:flex}.brand-row{justify-content:space-between;align-items:center;gap:12px;padding:12px 12px 10px;display:flex}.brand{align-items:center;gap:10px;min-width:0;display:flex}.brand-mark{background:var(--accent);width:30px;height:30px;color:var(--accent-ink);border-radius:8px;flex:none;place-items:center;font-weight:800;display:grid}.brand strong,.brand small{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.brand strong{letter-spacing:0;font-size:15px}.brand small{color:var(--muted);font-size:12px;line-height:1.2}.search-row{border:1px solid var(--line-strong);background:var(--panel-soft);border-radius:8px;align-items:center;gap:8px;height:38px;margin:0 12px 12px;padding:0 10px;display:flex}.search-row svg{width:16px;height:16px;color:var(--muted);flex:none}.search-row input{width:100%;min-width:0;color:var(--text);background:0 0;border:0;outline:0}.list-meta{border-top:1px solid var(--line);border-bottom:1px solid var(--line);color:var(--muted);padding:8px 12px;font-size:12px}.post-list{min-height:0;padding:6px;overflow-y:auto}.post-item{width:100%;color:var(--text);text-align:left;background:0 0;border:0;border-radius:8px;margin:0 0 4px;padding:10px;display:block}.post-item:hover{background:var(--panel-soft)}.post-item.active{background:var(--accent-soft);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent), transparent 45%)}.post-title{text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:700;display:block;overflow:hidden}.post-stats{color:var(--muted);white-space:nowrap;gap:8px;margin-top:4px;font-size:12px;display:flex;overflow:hidden}mark{color:#171717;background:#fff0a6;border-radius:4px;padding:0 2px}.list-resizer{cursor:col-resize;grid-area:1/2/4;position:relative}.list-resizer:after{content:"";background:var(--line);width:1px;position:absolute;inset:0 auto 0 2px}.list-resizer:hover:after{background:var(--accent)}.toc-panel{border-right:1px solid var(--line);background:var(--panel-soft);flex-direction:column;grid-area:1/3/4;min-width:0;display:flex}.toc-head{border-bottom:1px solid var(--line);height:52px;color:var(--muted);justify-content:space-between;align-items:center;gap:8px;padding:0 10px 0 12px;font-size:13px;font-weight:700;display:flex}.toc-body{min-height:0;padding:10px 8px 18px;overflow-y:auto}.toc-link,.toc-empty{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;border-radius:8px;padding:6px 8px;font-size:13px;line-height:1.35;display:block;overflow:hidden}.toc-link:hover,.toc-link.active{background:color-mix(in srgb, var(--accent-soft), var(--panel) 30%);color:var(--text)}.toc-link.level-2{padding-left:18px}.toc-link.level-3{padding-left:28px}.toc-link.level-4,.toc-link.level-5,.toc-link.level-6{padding-left:38px}.app-shell.toc-collapsed .toc-head{justify-content:center;padding:0 5px}.app-shell.toc-collapsed .toc-head span,.app-shell.toc-collapsed .toc-body{display:none}.topbar{border-bottom:1px solid var(--line);background:var(--panel);grid-area:1/4;justify-content:space-between;align-items:center;gap:16px;min-width:0;padding:0 16px;display:flex}.topbar-main{align-items:baseline;gap:12px;min-width:0;display:flex}.topbar-main strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:15px;overflow:hidden}.topbar-main span,.topbar-actions{color:var(--muted);white-space:nowrap;font-size:12px}.topbar-actions{flex:none;justify-content:flex-end;align-items:center;gap:8px;display:flex}.reader-scroll{grid-area:2/4;min-width:0;overflow-y:auto}.reader{max-width:860px;margin:0 auto;padding:42px 36px 72px}.article-title-block{margin-bottom:28px}.article-title-block h1{letter-spacing:0;margin:0 0 12px;font-size:34px;line-height:1.24}.article-meta{color:var(--muted);flex-wrap:wrap;gap:14px;font-size:13px;display:flex}.article-body{font-size:16px}.article-body h1,.article-body h2,.article-body h3,.article-body h4,.article-body h5,.article-body h6{letter-spacing:0;margin:2em 0 .7em;line-height:1.35}.article-body h1{font-size:30px}.article-body h2{font-size:25px}.article-body h3{font-size:21px}.article-body h4{font-size:18px}.article-body p{margin:1em 0}.article-body a{color:var(--accent);text-underline-offset:3px;text-decoration:underline}.article-body ul,.article-body ol{padding-left:1.4em}.article-body blockquote{border-left:4px solid var(--accent);background:var(--panel-soft);color:var(--muted);border-radius:0 8px 8px 0;margin:1.3em 0;padding:10px 14px}.article-body table{border-collapse:collapse;width:100%;margin:1.4em 0;font-size:14px}.article-body th,.article-body td{border:1px solid var(--line);vertical-align:top;padding:9px 10px}.article-body th{background:var(--panel-soft);text-align:left}.article-body img{border:1px solid var(--line);border-radius:8px;max-width:100%}.attachment-card{border:1px solid var(--line);background:var(--panel-soft);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;margin:1em 0;padding:12px 14px;font-size:14px;display:flex}.attachment-card a{flex:none}.article-body code:not(.code-block code){background:var(--panel-soft);color:var(--danger);border-radius:5px;padding:2px 5px;font-size:.92em}.code-block{border:1px solid var(--line-strong);background:var(--code-bg);color:var(--code-text);border-radius:8px;margin:1.4em 0;overflow:hidden}.code-head{color:#cbd5df;border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;gap:10px;min-height:36px;padding:0 10px 0 12px;font-size:12px;display:flex}.code-actions{gap:6px;display:flex}.code-actions button{min-width:42px;height:25px;color:var(--code-text);background:#ffffff14;border:1px solid #ffffff2e;border-radius:6px;padding:0 8px;font-size:12px}.code-block pre{margin:0;padding:12px 0;font-size:13px;line-height:1.6;overflow:auto}.code-block pre.hidden{display:none}.code-line{grid-template-columns:44px minmax(0,1fr);gap:10px;min-width:max-content;padding-right:14px;display:grid}.line-no{color:#778391;text-align:right;user-select:none}.comments{border-top:1px solid var(--line);margin-top:54px;padding-top:26px}.section-heading{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:14px;display:flex}.section-heading h2{margin:0;font-size:22px}.muted{color:var(--muted);font-size:12px}.comment-form{border:1px solid var(--line);background:var(--panel-soft);border-radius:8px;margin-bottom:18px;padding:12px}.comment-form textarea{resize:vertical;border:1px solid var(--line-strong);background:var(--panel);width:100%;min-height:92px;color:var(--text);border-radius:8px;outline:none;padding:10px 12px}.comment-tools{justify-content:space-between;align-items:center;gap:12px;margin-top:10px;display:flex}.comment-list{flex-direction:column;gap:10px;display:flex}.comment{border:1px solid var(--line);background:var(--panel);border-radius:8px;padding:12px}.comment.reply{margin-top:10px;margin-left:min(28px,5vw)}.comment-head{color:var(--muted);justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px;font-size:12px;display:flex}.comment-user{color:var(--text);font-weight:700}.comment-body{white-space:pre-wrap;word-break:break-word;font-size:14px}.comment-attachments{flex-wrap:wrap;gap:8px;margin-top:8px;font-size:13px;display:flex}.comment-attachments img{object-fit:cover;border:1px solid var(--line);border-radius:8px;max-width:130px;max-height:100px}.reply-btn{color:var(--muted);background:0 0;border:0;font-size:12px}.reply-btn:hover{color:var(--accent)}.reader-footer{border-top:1px solid var(--line);background:var(--panel);min-width:0;color:var(--muted);grid-area:3/4;justify-content:space-between;align-items:center;gap:16px;padding:0 16px;font-size:13px;display:flex}.social-links{flex-wrap:wrap;align-items:center;gap:12px;min-width:0;display:flex;overflow:hidden}.social-links a:hover{color:var(--accent)}.footer-slot{border:1px dashed var(--line-strong);border-radius:8px;flex:none;width:160px;height:24px}.icon-button,.tool-button,.primary-button,.file-button{border:1px solid var(--line-strong);background:var(--panel);min-height:32px;color:var(--text);white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:0 10px;display:inline-flex}.icon-button{width:32px;padding:0}.icon-button svg,.tool-button svg,.primary-button svg,.file-button svg{width:16px;height:16px}.tool-button:hover,.icon-button:hover,.file-button:hover{background:var(--accent-soft);border-color:color-mix(in srgb, var(--accent), transparent 45%)}.primary-button{border-color:var(--accent);background:var(--accent);color:var(--accent-ink)}.file-button{cursor:pointer}.file-button input{display:none}.toast{z-index:20;background:var(--text);max-width:min(360px,100vw - 36px);color:var(--panel);opacity:0;pointer-events:none;border-radius:8px;padding:10px 14px;font-size:14px;transition:opacity .15s,transform .15s;position:fixed;bottom:18px;right:18px;transform:translateY(8px)}.toast.show{opacity:1;transform:translateY(0)}@media (width<=900px){body:before{content:"第一版面向桌面宽屏。";z-index:99;background:var(--panel);color:var(--text);text-align:center;place-items:center;padding:24px;display:grid;position:fixed;inset:0}}
