.blog-progress-bar{position:fixed;top:0;left:0;width:100%;height:4px;z-index:var(--z-toast);background:var(--color-bg-subtle);pointer-events:none}.blog-progress-bar:after{content:"";display:block;height:100%;background:var(--color-brand);width:calc(var(--blog-progress, 0) * 1%);animation:reading-progress linear;animation-timeline:scroll();transition:width 60ms linear}.blog-progress-bar[data-js-active=true]:after{animation:none}@keyframes reading-progress{to{width:100%}}@media(prefers-reduced-motion:reduce){.blog-progress-bar:after{animation:none;transition:none}}.blog-post{padding:var(--space-10) 0 var(--space-16)}@media(min-width:768px){.blog-post{padding:var(--space-12) 0 var(--space-20)}}.blog-post__breadcrumbs{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-tertiary);margin-bottom:var(--space-6)}.blog-post__breadcrumbs a{color:var(--color-text-secondary);text-decoration:none}.blog-post__breadcrumbs a:hover{color:var(--color-brand)}.blog-post__breadcrumbs-current{color:var(--color-text-primary);max-width:32ch;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.blog-post__meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4)}.blog-post__meta-sep{color:var(--color-text-tertiary)}.blog-post__title{font-size:var(--text-3xl);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight);margin:0 0 var(--space-4);text-wrap:balance}@media(min-width:768px){.blog-post__title{font-size:var(--text-4xl)}}.blog-post__excerpt{font-size:var(--text-md);line-height:var(--leading-relaxed);color:var(--color-text-secondary);margin:0 0 var(--space-5);max-width:60ch;text-wrap:pretty}.blog-post__action-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-8)}.blog-post__tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin:0}.blog-post__tag{display:inline-flex;align-items:center;height:24px;padding:0 var(--space-2);background:var(--color-bg-subtle);border:1px solid var(--color-border-subtle);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-secondary)}.blog-post__featured-image{width:100%;aspect-ratio:16 / 9;object-fit:cover;border-radius:var(--radius-xl);margin:0 0 var(--space-10);background:var(--color-bg-subtle)}.blog-post__foot{margin-top:var(--space-12);padding-top:var(--space-6);border-top:1px solid var(--color-border-subtle)}.blog-toc{margin:0 0 var(--space-10);padding:var(--space-5) var(--space-6);background:var(--color-bg-warm);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl)}.blog-toc__title{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-tertiary);margin-bottom:var(--space-3)}.blog-toc__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-1)}.blog-toc__list a{font-size:var(--text-sm);color:var(--color-text-secondary);text-decoration:none;line-height:var(--leading-snug);display:inline-block;padding:var(--space-1) 0;transition:color var(--motion-fast) var(--ease-default)}.blog-toc__list a:hover{color:var(--color-brand);text-decoration:none}.blog-toc__list li[data-depth="3"] a{padding-left:var(--space-4)}.blog-content{line-height:var(--leading-relaxed);font-size:var(--text-md);color:var(--color-text-primary)}.blog-content>*:first-child{margin-top:0}.blog-content>*:last-child{margin-bottom:0}.blog-content p{margin:0 0 var(--space-5);color:var(--color-text-primary)}.blog-content p strong{font-weight:var(--font-semibold);color:var(--color-text-primary)}.blog-content em{font-style:italic}.blog-content h2{font-size:var(--text-2xl);font-weight:var(--font-bold);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight);margin:var(--space-12) 0 var(--space-4);padding-bottom:var(--space-2);border-bottom:2px solid var(--color-brand-muted);scroll-margin-top:80px}@media(min-width:768px){.blog-content h2{font-size:var(--text-3xl)}}.blog-content h3{font-size:var(--text-xl);font-weight:var(--font-semibold);letter-spacing:var(--tracking-tight);line-height:var(--leading-snug);margin:var(--space-10) 0 var(--space-3);padding-left:var(--space-3);border-left:3px solid var(--color-brand);scroll-margin-top:80px}.blog-content h4{font-size:var(--text-lg);font-weight:var(--font-semibold);margin:var(--space-6) 0 var(--space-2);scroll-margin-top:80px}.blog-content .heading-anchor{margin-left:var(--space-2);color:var(--color-text-tertiary);text-decoration:none;opacity:0;transition:opacity var(--motion-fast) var(--ease-default)}.blog-content h2:hover .heading-anchor,.blog-content h3:hover .heading-anchor,.blog-content h4:hover .heading-anchor,.blog-content .heading-anchor:focus{opacity:1;color:var(--color-brand)}.blog-content a{color:var(--color-text-primary);text-decoration:underline;text-decoration-thickness:1.5px;text-decoration-color:var(--color-brand);text-underline-offset:3px;transition:color var(--motion-fast) var(--ease-default),text-decoration-color var(--motion-fast) var(--ease-default)}.blog-content a:hover{color:var(--color-brand);text-decoration-color:var(--color-brand-hover)}.blog-content a.heading-anchor{text-decoration:none}.blog-content ul,.blog-content ol{margin:var(--space-3) 0 var(--space-6);padding-left:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2)}.blog-content ul{list-style-type:disc}.blog-content ol{list-style-type:decimal}.blog-content li::marker{color:var(--color-text-tertiary)}.blog-content li>ul,.blog-content li>ol{margin:var(--space-2) 0}.blog-content blockquote{margin:var(--space-8) 0;padding:var(--space-4) var(--space-6);background:var(--color-bg-warm);border-left:3px solid var(--color-brand);border-radius:0 var(--radius-lg) var(--radius-lg) 0;color:var(--color-text-primary);font-style:italic}.blog-content blockquote p{margin:0 0 var(--space-3)}.blog-content blockquote p:last-child{margin-bottom:0}.blog-content blockquote strong{font-style:normal}.blog-content :not(pre)>code{background:var(--color-bg-subtle);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xs);padding:2px 6px;font-family:var(--font-mono);font-size:.9em;color:var(--color-text-primary);white-space:nowrap}.blog-content pre.astro-code,.blog-content pre{margin:var(--space-6) 0;padding:var(--space-4) var(--space-5);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);overflow-x:auto;font-size:var(--text-sm);line-height:var(--leading-relaxed);background:var(--color-bg-subtle)}.blog-content pre code{font-family:var(--font-mono);background:transparent;border:0;padding:0;white-space:pre;color:inherit}.blog-content table{width:100%;border-collapse:separate;border-spacing:0;margin:var(--space-8) 0;font-size:var(--text-sm);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);overflow:hidden}.blog-content th,.blog-content td{border-bottom:1px solid var(--color-border-subtle);border-right:1px solid var(--color-border-subtle);padding:var(--space-3) var(--space-4);text-align:left}.blog-content th:last-child,.blog-content td:last-child{border-right:0}.blog-content tr:last-child td{border-bottom:0}.blog-content th{background:var(--color-bg-subtle);font-weight:var(--font-semibold);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-secondary)}.blog-content tr:nth-child(2n) td{background:var(--color-bg-canvas)}@media(max-width:640px){.blog-content table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}}.blog-content hr{border:0;border-top:1px solid var(--color-border-subtle);margin:var(--space-12) 0}.blog-content img{max-width:100%;height:auto;border-radius:var(--radius-lg);margin:var(--space-6) 0;background:var(--color-bg-subtle)}.blog-content figure{margin:var(--space-6) 0}.blog-content figcaption{text-align:center;font-size:var(--text-sm);color:var(--color-text-tertiary);margin-top:var(--space-2)}.blog-related{margin-top:var(--space-16);padding-top:var(--space-10);border-top:1px solid var(--color-border-subtle)}.blog-related__head{margin-bottom:var(--space-6)}.blog-related__title{font-size:var(--text-xl);margin:0}.blog-related__grid{display:grid;grid-template-columns:1fr;gap:var(--space-5)}@media(min-width:640px){.blog-related__grid{grid-template-columns:repeat(3,1fr)}}.blog-index{padding:var(--space-10) 0 var(--space-16)}@media(min-width:768px){.blog-index{padding:var(--space-12) 0 var(--space-20)}}.blog-index__head{margin-bottom:var(--space-10);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border-subtle)}.blog-index__grid{display:grid;grid-template-columns:1fr;gap:var(--space-8)}@media(min-width:640px){.blog-index__grid{grid-template-columns:repeat(2,1fr);gap:var(--space-6)}}@media(min-width:1024px){.blog-index__grid{grid-template-columns:repeat(3,1fr)}}
