@font-face{font-family:Work Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/blog/_astro/work-sans-vietnamese-400-normal.BxGuknnG.woff2)format("woff2"),url(/blog/_astro/work-sans-vietnamese-400-normal.DFZk_KN_.woff)format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Work Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/blog/_astro/work-sans-latin-ext-400-normal.zfQnhXzv.woff2)format("woff2"),url(/blog/_astro/work-sans-latin-ext-400-normal.j7TZlk-s.woff)format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Work Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/blog/_astro/work-sans-latin-400-normal.jUejSri3.woff2)format("woff2"),url(/blog/_astro/work-sans-latin-400-normal.DE1_0GuN.woff)format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Work Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/blog/_astro/work-sans-vietnamese-600-normal.DizFELYt.woff2)format("woff2"),url(/blog/_astro/work-sans-vietnamese-600-normal.ue5fzGW6.woff)format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Work Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/blog/_astro/work-sans-latin-ext-600-normal.DNiHHggD.woff2)format("woff2"),url(/blog/_astro/work-sans-latin-ext-600-normal.B1NFRnx8.woff)format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Work Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/blog/_astro/work-sans-latin-600-normal.DB-2V89X.woff2)format("woff2"),url(/blog/_astro/work-sans-latin-600-normal.Cg-NlmS7.woff)format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Work Sans;font-style:normal;font-display:swap;font-weight:700;src:url(/blog/_astro/work-sans-vietnamese-700-normal.CqjC4WOy.woff2)format("woff2"),url(/blog/_astro/work-sans-vietnamese-700-normal.BYAoORCv.woff)format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Work Sans;font-style:normal;font-display:swap;font-weight:700;src:url(/blog/_astro/work-sans-latin-ext-700-normal.Bc0iTajH.woff2)format("woff2"),url(/blog/_astro/work-sans-latin-ext-700-normal.BP8nCPzd.woff)format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Work Sans;font-style:normal;font-display:swap;font-weight:700;src:url(/blog/_astro/work-sans-latin-700-normal.CEeo_t6l.woff2)format("woff2"),url(/blog/_astro/work-sans-latin-700-normal.mDs79oer.woff)format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Work Sans;font-style:normal;font-display:swap;font-weight:800;src:url(/blog/_astro/work-sans-vietnamese-800-normal.DtzNau0w.woff2)format("woff2"),url(/blog/_astro/work-sans-vietnamese-800-normal.8tnFD7M8.woff)format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Work Sans;font-style:normal;font-display:swap;font-weight:800;src:url(/blog/_astro/work-sans-latin-ext-800-normal.WPcZEmTk.woff2)format("woff2"),url(/blog/_astro/work-sans-latin-ext-800-normal.Dy0F6lr3.woff)format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Work Sans;font-style:normal;font-display:swap;font-weight:800;src:url(/blog/_astro/work-sans-latin-800-normal.CHo7j6hf.woff2)format("woff2"),url(/blog/_astro/work-sans-latin-800-normal.C89f8isX.woff)format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--color-bg:#f8fafc;--color-surface:#ffffff;--color-text:#0f172a;--color-text-muted:#475569;--color-border:#e2e8f0;--color-accent:#0d9488;--color-accent-hover:#0f766e;--color-accent-light:#14b8a6;--color-accent-muted:#5eead4;--color-tag-bg:#ccfbf1;--color-tag-text:#0f766e;--font-sans:"Work Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-heading:"Work Sans", system-ui, sans-serif;--font-serif:ui-serif, Georgia, serif;--measure:65ch;--max-width:720px;--header-height:56px;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius:8px;--radius-lg:12px;--radius-xl:16px;--shadow:0 1px 3px rgba(0, 0, 0, .06);--shadow-md:0 4px 12px rgba(13, 148, 136, .08);--shadow-lg:0 12px 40px -12px rgba(0, 0, 0, .15);--ease:cubic-bezier(.25, .46, .45, .94);--ease-out:cubic-bezier(.16, 1, .3, 1);--duration:.3s}html.dark{--color-bg:#0f172a;--color-surface:#1e293b;--color-text:#f1f5f9;--color-text-muted:#94a3b8;--color-border:#334155;--color-accent:#2dd4bf;--color-accent-hover:#5eead4;--color-accent-light:#14b8a6;--color-accent-muted:#99f6e4;--color-tag-bg:#134e4a;--color-tag-text:#99f6e4}@media (prefers-color-scheme:dark){html:not(.light):not(.dark){--color-bg:#0f172a;--color-surface:#1e293b;--color-text:#f1f5f9;--color-text-muted:#94a3b8;--color-border:#334155;--color-accent:#2dd4bf;--color-accent-hover:#5eead4;--color-accent-light:#14b8a6;--color-accent-muted:#99f6e4;--color-tag-bg:#134e4a;--color-tag-text:#99f6e4}}*,:before,:after{box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;scroll-behavior:smooth;overflow-x:hidden}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}body{margin:0;font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.65;letter-spacing:-.01em;overflow-x:hidden}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-100px;left:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-accent);color:#fff;border-radius:var(--radius);z-index:100;transition:top .2s}.skip-link:focus,.skip-link:focus-visible{top:var(--space-md);outline:2px solid #fff;outline-offset:2px}.site-header{position:sticky;top:0;z-index:50;background:#ffffffe6;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid transparent;box-shadow:0 1px #0000000a}html.dark .site-header{background:#0f172ae6;box-shadow:0 1px #ffffff0f}.nav-toggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;padding:0;margin:0;background:0 0;border:0;cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius)}.nav-toggle:hover,.nav-toggle:focus-visible{color:var(--color-accent);outline:2px solid var(--color-accent);outline-offset:2px}.nav-toggle-icon{position:relative;display:block;width:22px;height:2px;background:currentColor;box-shadow:0-6px 0 currentColor,0 6px 0 currentColor;transition:transform .2s,box-shadow .2s}.nav-toggle-icon:after{content:"";position:absolute;left:0;top:50%;width:100%;height:2px;margin-top:-1px;background:currentColor;transform:rotate(-90deg);opacity:0;transition:opacity .2s}.site-header.is-nav-open .nav-toggle-icon{box-shadow:none;transform:rotate(45deg)}.site-header.is-nav-open .nav-toggle-icon:after{opacity:1}.header-inner{max-width:1120px;margin:0 auto;padding:var(--space-md) var(--space-lg);display:flex;flex-wrap:nowrap;align-items:center;justify-content:space-between;gap:var(--space-lg);min-width:0}@media (max-width:767px){.site-header .nav-toggle{display:flex;order:2}.site-header .header-inner{padding:var(--space-sm) var(--space-md);flex-wrap:wrap}.site-header .nav{display:none!important;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;padding:var(--space-md);margin:0;border-top:1px solid var(--color-border);background:var(--color-surface);box-shadow:0 8px 24px #00000014;max-height:min(80vh,400px);overflow-y:auto;z-index:100}html.dark .site-header .nav{background:var(--color-surface);box-shadow:0 8px 24px #0000004d}.site-header.is-nav-open .nav{display:flex!important}.site-header .nav a,.site-header .nav .nav-icon-link,.site-header .nav .nav-link-muted,.site-header .nav .nav-cta,.site-header .nav .theme-toggle,.site-header .nav button{min-height:48px;padding:var(--space-md) var(--space-lg);justify-content:flex-start;border-radius:var(--radius);width:100%;text-align:left;white-space:normal}.site-header .nav a:hover,.site-header .nav .nav-link-muted:hover{background:#0d948814}.site-header .nav .theme-toggle,.site-header .nav button{background:0 0;border:0;font-size:inherit;color:var(--color-text-muted);cursor:pointer}.site-header{position:relative}}@media (min-width:768px){.header-inner{padding:var(--space-md) var(--space-xl)}}.logo{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-heading);font-weight:800;font-size:1.25rem;letter-spacing:-.02em;color:var(--color-text);text-decoration:none}.logo__img{width:32px;height:32px;flex-shrink:0;display:block}.logo__text{transition:color var(--duration) var(--ease)}.header-inner .logo{flex-shrink:0}.logo:hover{color:var(--color-accent)}.logo:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius)}.nav{display:flex;flex-wrap:nowrap;align-items:center;gap:var(--space-xl);flex-shrink:0;min-width:0}.nav a{color:var(--color-text-muted);text-decoration:none;font-size:.9375rem;font-weight:500;padding:var(--space-sm) var(--space-xs);min-height:44px;min-width:44px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;transition:color var(--duration) var(--ease)}.nav a:hover{color:var(--color-accent)}.nav a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius)}.nav-icon-link{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-sm);color:var(--color-text-muted);transition:color var(--duration) var(--ease)}.nav-icon-link:hover{color:var(--color-accent)}.nav-icon{display:block}.nav-link-muted{color:var(--color-text-muted)!important;font-size:.875rem!important}.nav-link-muted:hover{color:var(--color-accent)!important}.nav-cta{padding:.5rem 1rem!important;min-height:auto!important;min-width:auto!important;font-weight:700!important;color:#0f172a!important;background:var(--color-accent)!important;border-radius:9999px!important;box-shadow:0 2px 6px #0d94884d!important}.nav-cta:hover{color:#0f172a!important;background:var(--color-accent-hover)!important;box-shadow:0 4px 10px #0d948859!important}.theme-toggle{background:0 0;border:0;cursor:pointer;padding:var(--space-sm) var(--space-xs);min-height:44px;min-width:44px;display:inline-flex;align-items:center;justify-content:center;font-size:1.25rem;line-height:1;color:var(--color-text-muted)}.theme-toggle:hover{color:var(--color-accent)}.theme-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius)}.theme-toggle-icon--dark{display:none}html.dark .theme-toggle-icon:first-of-type{display:none}html.dark .theme-toggle-icon--dark{display:inline}.main{max-width:1120px;margin:0 auto;padding:var(--space-2xl) var(--space-lg) var(--space-3xl);min-height:calc(100vh - var(--header-height) - 120px);overflow-x:hidden}@media (max-width:640px){.main{padding:var(--space-xl) var(--space-md) var(--space-2xl)}}@media (min-width:768px){.main{padding:3rem var(--space-xl) 4rem}}.site-footer{border-top:1px solid var(--color-border);background:var(--color-surface)}.footer-inner{max-width:1120px;margin:0 auto;padding:var(--space-xl) var(--space-lg);text-align:center;font-size:.8125rem;color:var(--color-text-muted);line-height:1.6}@media (max-width:640px){.footer-inner{padding:var(--space-lg) var(--space-md);font-size:.75rem}}.footer-inner p+p{margin-top:var(--space-sm)}.footer-inner a{color:var(--color-accent);text-decoration:underline;text-underline-offset:.15em}.footer-inner a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:2px}.footer-inner .footer-links{margin-bottom:var(--space-xs)}.footer-inner .footer-product{margin-top:var(--space-sm);font-size:.9375rem}.footer-inner .footer-product a{color:var(--color-accent);font-weight:600}@media (prefers-color-scheme:dark){html:not(.light) .footer-inner .footer-product a{color:var(--color-accent-muted)}}html.dark .footer-inner .footer-product a{color:var(--color-accent-muted)}.reading-progress{position:fixed;top:0;left:0;width:100vw;height:4px;z-index:200;background:var(--color-border);overflow:hidden;pointer-events:none}.reading-progress__bar{height:100%;width:0;background:var(--color-accent);transition:width .15s ease-out}@media (prefers-reduced-motion:reduce){.reading-progress__bar{transition:none}}.article-with-toc{display:grid;gap:var(--space-2xl);align-items:start;max-width:100%}.article-with-toc>*{min-width:0}@media (max-width:767px){.article-with-toc{display:block}}@media (min-width:1024px){.article-with-toc{grid-template-columns:1fr 200px}.article-with-toc .prose{max-width:100%}}.toc{font-size:.875rem}.toc[hidden]{display:none!important}.toc__title{font-family:var(--font-heading);font-weight:600;margin:0 0 var(--space-sm);font-size:.8125rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.toc__list{list-style:none;padding:0;margin:0}.toc__item{margin-bottom:var(--space-xs)}.toc__item--h3{padding-left:var(--space-md)}.toc__link{color:var(--color-text-muted);text-decoration:none;display:block;padding:var(--space-xs)0;border-radius:var(--radius);transition:color var(--duration) var(--ease)}.toc__link:hover{color:var(--color-accent)}@media (max-width:1023px){.toc{order:-1;margin-bottom:0;padding:var(--space-md)0;border-bottom:1px solid var(--color-border)}.toc__list{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.toc__item{margin-bottom:0}.toc__item--h3{padding-left:0}}@media (min-width:1024px){.toc{position:sticky;top:calc(var(--header-height) + var(--space-md))}}.prose{max-width:min(var(--max-width),var(--measure));width:100%;min-width:0;margin-left:auto;margin-right:auto;font-size:clamp(1rem,.95rem + .25vw,1.0625rem)}@media (max-width:767px){.prose{max-width:100%;box-sizing:border-box}}.prose p{line-height:1.72}.prose h1{font-family:var(--font-heading);font-size:clamp(1.75rem,4vw,2.25rem);font-weight:800;margin-top:0;margin-bottom:var(--space-md);line-height:1.2;letter-spacing:-.02em}.prose h2{font-family:var(--font-heading);font-size:clamp(1.35rem,2.5vw,1.5rem);font-weight:700;margin-top:var(--space-2xl);margin-bottom:var(--space-sm);padding-bottom:var(--space-xs);border-bottom:1px solid var(--color-border);letter-spacing:-.01em}.prose h3{font-family:var(--font-heading);font-size:clamp(1.15rem,1.5vw,1.25rem);font-weight:600;margin-top:var(--space-xl);margin-bottom:var(--space-sm)}.prose .heading-anchor{margin-left:.25em;color:var(--color-accent);text-decoration:none;opacity:.5;transition:opacity var(--duration) var(--ease)}.prose .heading-anchor:hover{opacity:1}.prose h2:hover .heading-anchor,.prose h3:hover .heading-anchor{opacity:.8}.prose p{margin:0 0 var(--space-md)}.prose>p:first-of-type{font-size:1.125rem;color:var(--color-text-muted);line-height:1.65}.prose ul,.prose ol{margin:0 0 var(--space-md);padding-left:1.5rem}.prose li{margin-bottom:var(--space-xs)}.prose a{color:var(--color-accent);text-decoration:underline;text-underline-offset:.15em}.prose a:hover{text-decoration-thickness:2px}.prose a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:2px}.prose strong{font-weight:600}.prose code{font-size:.9em;padding:.15em .4em;background:var(--color-tag-bg);color:var(--color-tag-text);border-radius:4px;word-break:break-word;overflow-wrap:break-word}.prose pre{overflow-x:auto;padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);margin:0 0 var(--space-md);max-width:100%}.prose pre code{padding:0;background:0 0;color:inherit}.prose blockquote{margin:0 0 var(--space-md);padding-left:var(--space-lg);border-left:4px solid var(--color-border);color:var(--color-text-muted)}.prose hr{border:0;border-top:1px solid var(--color-border);margin:var(--space-xl)0}.prose img{max-width:100%;height:auto;border-radius:var(--radius)}.prose{word-wrap:break-word;overflow-wrap:break-word}.prose .table-wrapper{width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:var(--space-xl)0;border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-md)}.prose table{width:100%;min-width:480px;border-collapse:collapse;font-size:.9375rem}@media (max-width:767px){.prose table{min-width:320px;font-size:.8125rem}.prose th,.prose td{padding:var(--space-sm) var(--space-md)}}.prose thead{background:var(--color-bg)}.prose th{font-family:var(--font-heading);font-weight:600;text-align:left;padding:var(--space-md) var(--space-lg);border-bottom:2px solid var(--color-border);color:var(--color-text)}.prose td{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:top}.prose tbody tr:hover{background:#0d94880a}.prose tbody tr:last-child td{border-bottom:none}.prose td .check{color:var(--color-accent);font-weight:600}.prose td .cross{color:var(--color-text-muted)}.prose figure,.prose .prose-figure{margin:var(--space-xl)0}.prose figure img,.prose .prose-figure img{border-radius:var(--radius-lg);border:1px solid var(--color-border)}.prose figcaption,.prose .prose-figure figcaption{font-size:.875rem;color:var(--color-text-muted);margin-top:var(--space-sm);text-align:center}.prose .callout{margin:var(--space-xl)0;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);border-left:4px solid var(--color-border);background:var(--color-bg);font-size:.9375rem;line-height:1.6}.prose .callout strong:first-child{display:block;margin-bottom:var(--space-xs)}.prose .callout-tip{border-left-color:var(--color-accent);background:#0d94880f}.prose .callout-note{border-left-color:#64748b;background:#64748b0f}.prose .callout-warning{border-left-color:#d97706;background:#d977060f}.prose p{max-width:60ch}.prose ul,.prose ol{margin:0 0 var(--space-lg);padding-left:1.5rem}.prose li{margin-bottom:var(--space-sm)}.prose li::marker{color:var(--color-accent)}.prose h2{margin-top:var(--space-3xl);scroll-margin-top:2rem}.prose h3{margin-top:var(--space-xl);scroll-margin-top:2rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-lg);box-shadow:var(--shadow)}.tag{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:var(--space-xs) var(--space-sm);margin:2px 4px 2px 0;font-size:.75rem;font-weight:600;background:var(--color-tag-bg);color:var(--color-tag-text);border-radius:6px;text-decoration:none}a.tag{color:var(--color-tag-text)}@media (prefers-color-scheme:dark){html:not(.light) .tag,html:not(.light) a.tag{background:var(--color-tag-bg);color:var(--color-tag-text)}}html.dark .tag,html.dark a.tag{background:var(--color-tag-bg);color:var(--color-tag-text)}.tag:hover{opacity:.9}.tag:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--space-lg);margin-top:var(--space-3xl);padding-top:var(--space-2xl);font-size:.9375rem}.pagination a{color:var(--color-text-muted);text-decoration:none;transition:color var(--duration) var(--ease)}.pagination a:hover{color:var(--color-accent)}.pagination a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:4px}.pagination .current{color:var(--color-text-muted);font-variant-numeric:tabular-nums}.breadcrumb{margin-bottom:var(--space-lg);font-size:.875rem}.breadcrumb__list{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-xs);list-style:none;margin:0;padding:0}.breadcrumb__item{display:inline-flex;align-items:center;gap:var(--space-xs)}.breadcrumb__item:not(:last-child):after{content:"›";color:var(--color-text-muted);margin-left:var(--space-xs)}.breadcrumb a{color:var(--color-text-muted);text-decoration:none}.breadcrumb a:hover{color:var(--color-accent)}.breadcrumb [aria-current=page]{color:var(--color-text);font-weight:500}.post-list{list-style:none;padding:0;margin:0;display:grid;gap:var(--space-2xl);grid-template-columns:1fr;max-width:100%}@media (min-width:768px){.post-list{grid-template-columns:repeat(2,1fr);gap:var(--space-2xl) var(--space-xl)}}@media (min-width:1024px){.post-list{gap:2.5rem var(--space-xl)}}.post-card{position:relative;background:var(--color-surface);border:0;border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 1px 2px #0000000a;transition:transform var(--duration) var(--ease-out),box-shadow var(--duration) var(--ease)}@media (prefers-reduced-motion:no-preference){.post-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px -8px #0000001f,0 0 0 1px #00000008}.post-card--animate{animation:card-enter .5s var(--ease-out) both}}html.dark .post-card{box-shadow:0 1px #ffffff0d}html.dark .post-card:hover{box-shadow:0 8px 30px -8px #0006,0 0 0 1px #ffffff0f}@keyframes card-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.post-card--pinned{box-shadow:0 0 0 1px #0d948833,0 2px 8px #0d948814}.post-card__badge{position:absolute;top:var(--space-md);right:var(--space-md);z-index:1;padding:.25rem .6rem;font-size:.6875rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;background:var(--color-accent);color:#fff;border-radius:6px}.post-card:focus-within{outline:2px solid var(--color-accent);outline-offset:2px}.post-card__media{display:block;aspect-ratio:16/9;background:var(--color-bg);overflow:hidden}.post-card__media--placeholder{background:linear-gradient(160deg,var(--color-border) 0%,var(--color-bg) 100%)}.post-card__media img{width:100%;height:100%;object-fit:cover;vertical-align:middle;transition:transform .6s var(--ease-out)}@media (prefers-reduced-motion:no-preference){.post-card:hover .post-card__media img{transform:scale(1.03)}}.post-card__body{padding:var(--space-xl) var(--space-xl) var(--space-lg);display:flex;flex-direction:column;gap:0}.post-card__category{font-size:.8125rem;color:var(--color-text-muted);margin:0 0 var(--space-sm);font-weight:500}.post-card__category-sep{margin:0 .35em;opacity:.6}.post-card__category time{font-variant-numeric:tabular-nums}.post-card__title{font-family:var(--font-heading);font-size:clamp(1.2rem,2vw,1.375rem);font-weight:600;margin:0 0 var(--space-sm);line-height:1.35;letter-spacing:-.02em}.post-card__title a{color:var(--color-text);text-decoration:none;transition:color var(--duration) var(--ease)}.post-card__title a:hover{color:var(--color-accent)}.post-card__excerpt{margin:0 0 var(--space-md);color:var(--color-text-muted);font-size:.9375rem;line-height:1.55;flex-grow:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-card__footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-sm);margin-top:auto;padding-top:0;border-top:none}.post-card__author{font-size:.8125rem;color:var(--color-text-muted);text-decoration:none;transition:color var(--duration) var(--ease)}.post-card__author:hover{color:var(--color-accent)}.post-card__link{font-size:.875rem;font-weight:500;color:var(--color-accent);text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;transition:gap var(--duration) var(--ease),color var(--duration) var(--ease)}.post-card__link:hover{gap:.4rem;color:var(--color-accent-hover)}.post-card__meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.8125rem;color:var(--color-text-muted)}.post-card__meta a{color:var(--color-text-muted);text-decoration:none;transition:color var(--duration) var(--ease)}.post-card__meta a:hover{color:var(--color-accent)}.section-heading{font-family:var(--font-heading);font-size:clamp(1.5rem,3vw,1.875rem);font-weight:600;margin:0 0 var(--space-3xl);letter-spacing:-.03em;color:var(--color-text)}.hero{max-width:var(--max-width);margin-left:auto;margin-right:auto;margin-bottom:var(--space-3xl)}.hero--minimal{margin-bottom:var(--space-3xl);padding-top:var(--space-xl)}@media (max-width:640px){.hero--minimal{padding-top:var(--space-lg);margin-bottom:var(--space-2xl)}.hero__title--large{font-size:clamp(1.75rem,6vw,2.25rem)}.hero__lead{font-size:1rem}.hero__ctas{gap:var(--space-sm)}}@media (min-width:768px){.hero--minimal{margin-bottom:4.5rem;padding-top:var(--space-2xl)}}@media (prefers-reduced-motion:no-preference){.hero__title{animation:hero-enter .6s var(--ease-out) both}.hero__lead{animation:hero-enter .6s var(--ease-out) .08s both}.hero__ctas{animation:hero-enter .6s var(--ease-out) .16s both}}@keyframes hero-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.hero__title{font-family:var(--font-heading);font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;margin:0 0 var(--space-sm);line-height:1.15;letter-spacing:-.03em}.hero__title--large{font-size:clamp(2.5rem,8vw,4rem);font-weight:800;letter-spacing:-.04em;margin-bottom:var(--space-md)}.hero__lead{color:var(--color-text-muted);font-size:1.125rem;margin:0 0 var(--space-xl);line-height:1.6;max-width:48ch}.hero__ctas{display:flex;flex-wrap:wrap;gap:var(--space-md);align-items:center}.hero__cta-primary{display:inline-flex;align-items:center;gap:.375rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#0f172a;background:var(--color-accent);border:0;border-radius:8px;text-decoration:none;transition:background var(--duration) var(--ease),box-shadow var(--duration) var(--ease)}.hero__cta-primary:hover{background:var(--color-accent-hover)}@media (prefers-reduced-motion:no-preference){.hero__cta-primary:hover{transform:translateY(-1px)}}.hero__cta-secondary{display:inline-flex;align-items:center;padding:.75rem 1.25rem;font-size:.9375rem;font-weight:500;color:var(--color-text-muted);background:0 0;border:0;border-radius:8px;text-decoration:none;transition:color var(--duration) var(--ease),background var(--duration) var(--ease)}.hero__cta-secondary:hover{color:var(--color-accent);background:#0d948814}html.dark .hero__cta-secondary:hover{background:#2dd4bf1a}.cta-block{margin-top:var(--space-2xl);padding:var(--space-xl);background:linear-gradient(135deg,#0d948814,#14b8a60d);border:1px solid rgba(13,148,136,.2);border-radius:var(--radius-lg);text-align:center}@media (max-width:640px){.cta-block{padding:var(--space-lg);margin-top:var(--space-xl)}.cta-block__title{font-size:1.125rem}}html.dark .cta-block{background:linear-gradient(135deg,#2dd4bf1f,#0d948814);border-color:#2dd4bf40}.cta-block__title{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;margin:0 0 var(--space-sm)}.cta-block__text{color:var(--color-text-muted);font-size:.9375rem;margin:0 0 var(--space-md);max-width:42ch;margin-left:auto;margin-right:auto}.cta-block__btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:700;color:#0f172a;background:var(--color-accent);border-radius:9999px;text-decoration:none;box-shadow:0 2px 8px #0d94884d;transition:background .2s,box-shadow .2s}.prose .cta-block__btn,.prose .cta-block__btn:hover{color:#0f172a;text-decoration:none}html.dark .prose .cta-block__btn,html.dark .cta-block__btn{color:#0f172a}.cta-block__btn:hover{background:var(--color-accent-hover);box-shadow:0 4px 12px #0d948866}.article-header{margin-bottom:var(--space-2xl);padding-bottom:var(--space-xl);border-bottom:1px solid var(--color-border)}.article-header h1{margin-bottom:var(--space-md);word-wrap:break-word;overflow-wrap:break-word}@media (max-width:640px){.article-header{margin-bottom:var(--space-xl);padding-bottom:var(--space-lg)}.article-header h1{font-size:clamp(1.5rem,5vw,2rem)}}.article-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:var(--space-md);font-size:.9375rem;color:var(--color-text-muted)}.article-byline{display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--color-text-muted)}.article-byline:hover{color:var(--color-accent)}.article-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.article-date,.article-reading-time{color:var(--color-text-muted)}.article-tags{margin:.75rem 0 0;display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.post-card__tags{display:inline-flex;flex-wrap:wrap;gap:.375rem;align-items:center}.article-hero{margin:0 0 2rem}.article-hero img,.article-hero__img{width:100%;height:auto;border-radius:var(--radius);display:block}.author-bio{margin:var(--space-2xl)0;padding:var(--space-xl);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg-subtle, rgba(0, 0, 0, .02))}.author-bio__inner{display:flex;gap:1.25rem;align-items:flex-start;flex-wrap:wrap}.author-bio__avatar-link{flex-shrink:0}.author-bio__avatar{width:80px;height:80px;border-radius:50%;object-fit:cover}.author-bio__avatar-link:hover .author-bio__avatar{opacity:.9}.author-bio__content{flex:1;min-width:0}.author-bio__label{font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin:0 0 .25rem}.author-bio__name{font-family:var(--font-heading);font-weight:700;font-size:1.125rem;text-decoration:none;color:inherit;display:inline-block;margin-bottom:.25rem}.author-bio__name:hover{color:var(--color-accent)}.author-bio__role{font-size:.9375rem;color:var(--color-text-muted);margin:0 0 .5rem}.author-bio__bio{font-size:.9375rem;line-height:1.6;margin:0 0 .75rem;color:var(--color-text)}.author-bio__signals{margin:.75rem 0;font-size:.875rem;color:var(--color-text-muted)}.author-bio__list{list-style:none;padding:0;margin:0 0 .5rem}.author-bio__list li{position:relative;padding-left:1rem;margin-bottom:.25rem}.author-bio__list li:before{content:"✓";position:absolute;left:0;color:var(--color-accent);font-weight:600}.author-bio__expertise{margin:0}.author-bio__expertise-label{font-weight:600;color:var(--color-text)}.author-bio__links{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.75rem}.author-bio__profile-link,.author-bio__social{font-size:.9375rem;font-weight:500}.author-bio__profile-link:hover,.author-bio__social:hover{text-decoration-thickness:2px}.author-page-header{display:flex;align-items:flex-start;gap:1.5rem;flex-wrap:wrap;margin-bottom:2rem}.author-page-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;flex-shrink:0}.author-page-header__content{flex:1;min-width:0}.author-page-name{margin:0 0 .5rem;font-family:var(--font-heading);font-size:1.75rem}.author-page-role{margin:0 0 .5rem;font-size:.9375rem;color:var(--color-text-muted);font-weight:600}.author-page-bio{margin:0;color:var(--color-text-muted);line-height:1.6}.author-page-social{margin:.75rem 0 0;font-size:.9375rem;display:flex;flex-wrap:wrap;gap:1rem}.author-page-social a:hover{color:var(--color-accent)}.author-eat{margin-bottom:2rem;padding:var(--space-xl);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg-subtle, rgba(0, 0, 0, .02))}.author-eat__title{font-family:var(--font-heading);font-size:1.125rem;font-weight:700;margin:0 0 var(--space-md);letter-spacing:-.01em}.author-eat__summary{margin:0 0 var(--space-md);line-height:1.6;color:var(--color-text);font-size:.9375rem}.author-eat__block{margin-top:var(--space-md)}.author-eat__subtitle{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin:0 0 .5rem}.author-eat__list{list-style:none;padding:0;margin:0}.author-eat__list li{position:relative;padding-left:1rem;margin-bottom:.35rem;font-size:.9375rem}.author-eat__list li:before{content:"✓";position:absolute;left:0;color:var(--color-accent);font-weight:600}.author-eat__tags{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem}.author-eat__tag{display:inline-block;font-size:.8125rem;padding:.25rem .6rem;background:var(--color-tag-bg);color:var(--color-tag-text);border-radius:999px;font-weight:500}.author-posts-title{font-size:1.125rem;margin-bottom:1rem;font-family:var(--font-heading);font-weight:700}.related-posts{margin-top:var(--space-2xl);padding-top:var(--space-xl);border-top:1px solid var(--color-border)}.related-posts__title{font-family:var(--font-heading);font-size:1.125rem;font-weight:700;margin:0 0 var(--space-sm);letter-spacing:-.01em}.related-posts__intro{font-size:.9375rem;color:var(--color-text-muted);margin:0 0 var(--space-md);line-height:1.5}.related-posts__list{list-style:none;padding:0;margin:0;display:grid;gap:var(--space-md)}.related-posts__list a{color:var(--color-text);text-decoration:none;font-weight:500;padding:var(--space-sm)0;border-bottom:1px solid var(--color-border);display:block;transition:color .2s,border-color .2s}.related-posts__list a:hover{color:var(--color-accent);border-color:var(--color-accent)}@media (max-width:767px){.post-card__body{padding:var(--space-md)}.post-card__title{font-size:1.1rem}.post-card__excerpt{font-size:.875rem}.article-header{margin-bottom:var(--space-lg);padding-bottom:var(--space-md)}.article-header h1{font-size:clamp(1.35rem,5vw,1.75rem);word-break:break-word}.article-meta{font-size:.8125rem;gap:.5rem}.article-hero{margin:0 0 var(--space-lg)}.article-hero img{border-radius:var(--radius)}.toc{order:-1;margin-bottom:0;padding:var(--space-sm)0;border-bottom:1px solid var(--color-border);overflow-x:auto;-webkit-overflow-scrolling:touch}.toc__list{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.toc__item{margin-bottom:0}.toc__item--h3{padding-left:0}.toc__link{font-size:.8125rem;padding:var(--space-xs) var(--space-sm)}.cta-block{padding:var(--space-md);margin-top:var(--space-xl)}.cta-block__title{font-size:1.05rem}.cta-block__text{font-size:.875rem}.cta-block__btn{font-size:.9375rem;padding:.625rem 1.25rem}.author-bio{padding:var(--space-md);margin:var(--space-xl)0}.author-bio__inner{gap:.75rem}.author-bio__avatar{width:56px;height:56px}.author-bio__name{font-size:1rem}.author-bio__bio,.author-bio__role{font-size:.875rem}.related-posts{margin-top:var(--space-xl);padding-top:var(--space-md)}.related-posts__title{font-size:1rem}.related-posts__list a{font-size:.9375rem;padding:var(--space-sm)0}.prose img{max-width:100%;height:auto}.prose figure,.prose .prose-figure{margin:var(--space-md)0}.prose h2{margin-top:var(--space-xl);font-size:clamp(1.15rem,4vw,1.35rem)}.prose h3{margin-top:var(--space-lg);font-size:clamp(1.05rem,3.5vw,1.15rem)}.prose p{max-width:100%}.prose blockquote{padding-left:var(--space-md);margin-left:0;margin-right:0}.prose .callout{padding:var(--space-sm) var(--space-md);margin:var(--space-md)0}.section-heading{font-size:clamp(1.25rem,5vw,1.5rem);margin-bottom:var(--space-xl)}}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media (prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}