.reading-progress{position:fixed;top:0;left:0;height:2px;width:0%;background:var(--accent);z-index:200;transition:width .1s linear}.article-page{padding-bottom:var(--space-20);display:flow-root}.article-layout{display:grid;grid-template-columns:200px var(--content-width) 240px;column-gap:var(--space-12);width:fit-content;max-width:100%;margin:0 auto;padding:0 var(--pad);align-items:start}.article-wrap{min-width:0}.article-hero-image{margin:var(--space-8) 0;overflow:hidden}.article-hero-image img{width:100%;aspect-ratio:40 / 21;object-fit:cover;display:block;border-radius:8px}.article-page img{-webkit-user-drag:none;user-select:none;-webkit-user-select:none;pointer-events:none}.article-header{margin-top:var(--space-8);padding:0 0 var(--space-12);border-bottom:1px solid var(--border);margin-bottom:var(--space-12)}.article-header-meta{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.article-category{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);text-decoration:none}.article-category:hover{text-decoration:underline;color:var(--accent)}.article-title{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:700;letter-spacing:-.02em;line-height:1.15;color:var(--text);margin-bottom:var(--space-6)}.article-description{font-size:var(--text-base);color:var(--text-muted);line-height:1.55;margin-bottom:var(--space-6);font-weight:400}.article-meta{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3);font-size:var(--text-sm);color:var(--text-muted);letter-spacing:.01em}.article-meta-sep{color:var(--border-hover)}.prose{font-size:var(--text-lg);line-height:1.8;color:var(--text)}.prose h2{font-size:var(--text-3xl);font-weight:700;letter-spacing:-.03em;line-height:1.25;margin:var(--space-12) 0 var(--space-4);color:var(--text)}.prose h3{font-size:var(--text-2xl);font-weight:600;letter-spacing:-.02em;line-height:1.3;margin:var(--space-8) 0 var(--space-3);color:var(--text)}.prose h4{font-size:var(--text-xl);font-weight:600;margin:var(--space-6) 0 var(--space-2)}.prose p{margin-bottom:var(--space-6)}.prose ul,.prose ol{margin:0 0 var(--space-6) var(--space-6);display:flex;flex-direction:column;gap:var(--space-2)}.prose li{line-height:1.7}.prose li>p{margin-bottom:0}.prose strong{font-weight:600;color:var(--text)}.prose em{font-style:italic}.prose a{color:var(--link);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}.prose a:hover{color:var(--link-hover)}.prose blockquote{border-left:3px solid var(--border-hover);padding-left:var(--space-6);margin:var(--space-8) 0;color:var(--text-muted);font-style:italic}.prose blockquote p{margin-bottom:0}.prose code{font-family:var(--font-mono);font-size:.875em;background:var(--tag-bg);border:1px solid var(--border);padding:2px 6px;border-radius:4px;color:var(--text)}.prose pre{background:#1e1e1e;color:#d4d4d4;padding:var(--space-6);border-radius:8px;overflow-x:auto;margin:var(--space-8) 0;font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.7}.prose pre code{background:none;border:none;padding:0;color:inherit;font-size:inherit}.prose hr{border:none;border-top:1px solid var(--border);margin:var(--space-12) 0}.prose table{width:100%;border-collapse:collapse;margin:var(--space-8) 0;font-size:var(--text-sm)}.prose th,.prose td{text-align:left;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}.prose th{font-weight:600;background:var(--tag-bg)}.prose tr:last-child td{border-bottom:none}.prose img{border-radius:8px;margin:var(--space-8) auto}.faq-section{margin:var(--space-12) 0;border-top:1px solid var(--border);padding-top:var(--space-8)}.faq-item{border-bottom:1px solid var(--border);padding:var(--space-6) 0}.faq-item:last-child{border-bottom:none}.faq-question{font-size:var(--text-lg);font-weight:600;color:var(--text);margin-bottom:var(--space-3);cursor:default}.faq-answer{font-size:var(--text-base);color:var(--text-muted);line-height:1.7}.author-bio{display:flex;align-items:flex-start;gap:var(--space-4);margin-top:var(--space-12);padding:var(--space-6);background:var(--bg-section);border-radius:8px;border:1px solid var(--border)}.author-bio-avatar{flex-shrink:0;width:44px;height:44px;border-radius:50%;background:var(--text);color:var(--bg);font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;display:flex;align-items:center;justify-content:center}.author-bio-name{font-weight:600;font-size:var(--text-base);margin-bottom:var(--space-1)}.author-bio-desc{font-size:var(--text-sm);color:var(--text-muted);line-height:1.6;margin:0}.author-bio-desc a{color:var(--accent);text-decoration:none;font-weight:500}.author-bio-desc a:hover{text-decoration:underline}.article-toc{position:sticky;top:80px}.toc-label{font-size:var(--text-xs);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--space-4)}.toc-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}.toc-item{line-height:1.4}.toc-h3{padding-left:var(--space-3)}.toc-link{font-size:var(--text-xs);color:var(--text-muted);text-decoration:none;display:block;padding:3px 0;border-left:2px solid transparent;padding-left:var(--space-3);margin-left:calc(var(--space-3) * -1);transition:color .15s,border-color .15s;line-height:1.5;cursor:pointer}.toc-link:hover{color:var(--text);text-decoration:none}.toc-link.active{color:var(--accent);border-left-color:var(--accent)}@media(max-width:1080px){.article-layout{grid-template-columns:1fr;width:auto}.article-toc{display:none}}.article-sidebar{position:sticky;top:80px}.sidebar-header{margin-bottom:var(--space-5)}.sidebar-header-label{font-size:var(--text-xs);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.sidebar-list{list-style:none;display:flex;flex-direction:column}.sidebar-item{border-bottom:1px solid var(--border)}.sidebar-item:first-child{border-top:1px solid var(--border)}.sidebar-link{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4) 0;text-decoration:none;color:inherit;transition:opacity .15s}.sidebar-link:hover{opacity:.65;text-decoration:none}.sidebar-title{font-size:var(--text-base);font-weight:600;line-height:1.45;color:var(--text)}.sidebar-meta{font-size:var(--text-xs);color:var(--text-light)}@media(max-width:1080px){.article-sidebar{display:none}}@media(max-width:640px){.prose{font-size:var(--text-base)}.prose h2{font-size:var(--text-2xl)}.prose h3{font-size:var(--text-xl)}.article-header{padding:var(--space-6) 0 var(--space-8);margin-bottom:var(--space-8)}.author-bio{flex-direction:column;gap:var(--space-3)}}
