.blog-post-screen{min-height:100vh;background:#09090b;color:#a1a1aa;display:flex;flex-direction:column}.blog-post-screen.loading{min-height:100vh}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.7}}.skeleton{background:#1f1f23;border-radius:6px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-back{width:100px;height:16px;margin-bottom:24px}.skeleton-meta{width:180px;height:14px;margin-bottom:16px}.skeleton-title{width:100%;height:36px;margin-bottom:12px}.skeleton-title-short{width:60%;height:36px;margin-bottom:16px}.skeleton-excerpt{width:90%;height:18px}.skeleton-cover{width:100%;height:320px;border-radius:12px;margin-bottom:40px}.blog-post-content-skeleton{display:flex;flex-direction:column;gap:16px}.skeleton-line{width:100%;height:16px}.skeleton-line-short{width:75%;height:16px}.skeleton-heading{width:45%;height:24px;margin-top:24px}.skeleton-toc-title{width:70px;height:12px;margin-bottom:16px}.skeleton-toc-item{width:100%;height:14px;margin-bottom:8px}.skeleton-toc-item-short{width:70%;height:14px;margin-bottom:8px;margin-left:12px}.blog-post-layout{display:flex;gap:160px;max-width:1200px;width:100%;margin:100px auto 80px;padding:0 32px;flex:1}.blog-post-article{flex:1;max-width:760px;width:100%}.blog-post-article.no-toc{max-width:760px;margin:0 auto}.blog-toc{width:220px;flex-shrink:0;align-self:flex-start;position:sticky;top:100px;max-height:calc(100vh - 140px);overflow-y:auto}.blog-toc-title{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#52525b;margin-bottom:16px}.blog-toc-nav{display:flex;flex-direction:column;gap:4px}.blog-toc-item{display:block;width:100%;text-align:left;padding:8px 12px;font-size:13px;line-height:1.4;color:#71717a;background:transparent;border:none;border-left:2px solid #27272a;cursor:pointer;transition:all .15s ease}.blog-toc-item:hover{color:#a1a1aa;border-left-color:#52525b;background:#ffffff05}.blog-toc-item.active{color:#fff;border-left-color:#3b82f6;background:#3b82f614}.blog-toc-item-sub{padding-left:24px;font-size:12px}.blog-post-header{margin-bottom:32px}.blog-post-back-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#52525b;text-decoration:none;margin-bottom:24px;transition:color .15s ease}.blog-post-back-link:hover{color:#71717a}.blog-post-meta{display:flex;align-items:center;gap:8px;font-size:13px;color:#52525b;margin-bottom:16px}.blog-post-category{color:#3b82f6;font-weight:500}.blog-post-dot{color:#3f3f46}.blog-post-title{font-size:32px;font-weight:700;line-height:1.3;color:#fff;margin:0 0 16px;letter-spacing:-.02em}.blog-post-excerpt{font-size:16px;line-height:1.7;color:#71717a;margin:0}.blog-post-cover{margin:0 0 40px;border-radius:12px;overflow:hidden;background:#18181b}.blog-post-cover img{width:100%;display:block;object-fit:cover}.blog-post-content{font-size:15px;line-height:1.8;color:#a1a1aa}.blog-post-content>*+*{margin-top:20px}.blog-post-content h2{font-size:24px;font-weight:600;color:#fff;margin-top:48px;margin-bottom:16px;letter-spacing:-.01em;scroll-margin-top:100px}.blog-post-content h3{font-size:19px;font-weight:600;color:#fff;margin-top:36px;margin-bottom:12px;scroll-margin-top:100px}.blog-post-content h4{font-size:16px;font-weight:600;color:#fff;margin-top:28px;margin-bottom:8px}.blog-post-content p{margin:0}.blog-post-content a{color:#60a5fa;text-decoration:none;transition:color .15s ease}.blog-post-content a:hover{color:#93c5fd;text-decoration:underline}.blog-post-content strong{font-weight:600;color:#d4d4d8}.blog-post-content em{font-style:italic;color:#a1a1aa}.blog-post-content ul,.blog-post-content ol{padding-left:24px;margin:16px 0}.blog-post-content li{margin:8px 0}.blog-post-content li::marker{color:#3f3f46}.blog-post-content blockquote{margin:24px 0;padding:16px 20px;border-left:3px solid #3b82f6;background:#3b82f60d;border-radius:0 8px 8px 0;color:#71717a;font-style:italic}.blog-post-content blockquote p{margin:0}.blog-post-content code{font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;background:#18181b;padding:3px 6px;border-radius:4px;color:#e879f9}.blog-post-content pre{margin:24px 0;border-radius:8px;overflow:hidden}.blog-code-block{border-radius:8px!important;font-size:13px!important;border:1px solid #27272a!important}.blog-code-block code{background:transparent!important;padding:0!important;color:inherit!important}.mermaid-container{margin:28px 0;padding:24px;background:#111113;border:1px solid #27272a;border-radius:12px;overflow-x:auto;display:flex;justify-content:center}.mermaid-container svg{max-width:100%;height:auto}.mermaid-error{color:#f87171;padding:16px;background:#f871711a;border-radius:8px;font-size:14px}.blog-post-content table{width:100%;border-collapse:separate;border-spacing:0;margin:28px 0;font-size:14px;border-radius:12px;overflow:hidden;border:1px solid #27272a;background:#111113}.blog-post-content thead{background:#18181b}.blog-post-content th{padding:14px 18px;text-align:left;font-weight:600;color:#fff;font-size:13px;border-bottom:1px solid #27272a}.blog-post-content td{padding:14px 18px;text-align:left;color:#a1a1aa;border-bottom:1px solid #1f1f23}.blog-post-content tbody tr:last-child td{border-bottom:none}.blog-post-content tbody tr{transition:background .15s ease}.blog-post-content tbody tr:hover{background:#3b82f60d}.blog-post-content tbody tr:hover td{color:#d4d4d8}.blog-post-content img{max-width:60%;height:auto;border-radius:10px;margin:24px auto;display:block}.blog-post-content hr{border:none;height:1px;background:#27272a;margin:40px 0}.blog-post-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:48px;padding-top:24px;border-top:1px solid #1f1f23}.blog-post-tag{font-size:13px;color:#52525b;background:#18181b;padding:6px 12px;border-radius:6px;transition:color .15s ease}.blog-post-tag:hover{color:#71717a}.blog-post-share{display:flex;align-items:center;justify-content:space-between;margin-top:40px;padding:20px 24px;background:#131316;border-radius:12px;border:1px solid #1f1f23}.blog-share-label{font-size:14px;font-weight:500;color:#71717a}.blog-share-buttons{display:flex;gap:8px}.blog-share-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:8px;background:#1f1f23;border:none;color:#71717a;cursor:pointer;transition:all .15s ease;text-decoration:none}.blog-share-btn:hover{background:#27272a;color:#a1a1aa}.blog-post-screen.not-found{text-align:center}.blog-post-not-found{margin:140px auto;padding:48px;max-width:400px}.blog-post-not-found h1{font-size:24px;font-weight:600;color:#fff;margin-bottom:12px}.blog-post-not-found p{font-size:15px;color:#52525b;margin-bottom:24px}.blog-post-retry{padding:10px 20px;border-radius:8px;border:1px solid #27272a;background:transparent;color:#a1a1aa;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.blog-post-retry:hover{background:#18181b;border-color:#3f3f46}@media (max-width: 1100px){.blog-post-layout{gap:32px}.blog-toc{width:180px}.blog-toc-item{font-size:12px;padding:6px 10px}}@media (max-width: 900px){.blog-post-layout{flex-direction:column;gap:0;margin-top:80px;max-width:720px}.blog-toc{display:none}.blog-post-article,.blog-post-article.no-toc{max-width:100%}.blog-post-content img{max-width:80%}}@media (max-width: 640px){.blog-post-layout{padding:0 20px;margin-top:72px;margin-bottom:60px}.blog-post-title{font-size:26px}.blog-post-content{font-size:14px;line-height:1.75}.blog-post-content h2{font-size:20px;margin-top:36px}.blog-post-content h3{font-size:17px;margin-top:28px}.blog-post-share{flex-direction:column;gap:16px;text-align:center}.blog-code-block{font-size:12px!important}}.blog-toc-sticky::-webkit-scrollbar{width:3px}.blog-toc-sticky::-webkit-scrollbar-track{background:transparent}.blog-toc-sticky::-webkit-scrollbar-thumb{background:#27272a;border-radius:2px}.blog-post-content pre::-webkit-scrollbar{height:6px}.blog-post-content pre::-webkit-scrollbar-track{background:#18181b}.blog-post-content pre::-webkit-scrollbar-thumb{background:#3f3f46;border-radius:3px}
