.blog-layout:where(.astro-4sn4zg3r){display:flex;gap:3rem;max-width:1060px;margin:0 auto}.blog-post:where(.astro-4sn4zg3r){flex:1;max-width:720px;min-width:0}.blog-sidebar:where(.astro-4sn4zg3r){width:240px;flex-shrink:0;display:none}@media(min-width:1080px){.blog-sidebar:where(.astro-4sn4zg3r){display:flex;flex-direction:column;position:sticky;top:2rem;align-self:flex-start;max-height:calc(100vh - 4rem)}}.blog-sidebar:where(.astro-4sn4zg3r) .toc{flex:1;min-height:0;overflow-y:auto}.post-header:where(.astro-4sn4zg3r){margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--sl-color-hairline)}.post-category:where(.astro-4sn4zg3r){display:inline-block;padding:.25rem .75rem;border-radius:2rem;font-size:.78rem;font-weight:600;background:#6366f11f;color:var(--sl-color-accent);text-decoration:none;text-transform:capitalize;letter-spacing:.02em;margin-bottom:1rem;transition:background .15s}.post-category:where(.astro-4sn4zg3r):hover{background:#6366f133}.post-title:where(.astro-4sn4zg3r){margin:0 0 .75rem;font-size:2.25rem;font-weight:800;color:var(--sl-color-white);line-height:1.2}.post-desc:where(.astro-4sn4zg3r){margin:0 0 1rem;font-size:1.1rem;color:var(--sl-color-gray-2);line-height:1.5}.post-meta:where(.astro-4sn4zg3r){display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--sl-color-gray-3);margin-bottom:0}.meta-sep:where(.astro-4sn4zg3r){opacity:.5}.reading-time:where(.astro-4sn4zg3r){color:var(--sl-color-gray-3)}.post-content:where(.astro-4sn4zg3r){font-size:1.05rem;line-height:1.8;color:var(--sl-color-gray-2);letter-spacing:.01em}.post-content:where(.astro-4sn4zg3r) h2{font-size:1.5rem;font-weight:700;color:var(--sl-color-white);margin:3rem 0 1rem;padding-top:.5rem}.post-content:where(.astro-4sn4zg3r) h3{font-size:1.2rem;font-weight:600;color:var(--sl-color-white);margin:2rem 0 .75rem}.post-content:where(.astro-4sn4zg3r) h4{font-size:1.05rem;font-weight:600;color:var(--sl-color-white);margin:1.5rem 0 .5rem}.post-content:where(.astro-4sn4zg3r) p{margin:0 0 1.5rem}.post-content:where(.astro-4sn4zg3r) code{padding:.15em .4em;border-radius:.3rem;background:var(--sl-color-gray-6);font-size:.88em;font-weight:500}.post-content:where(.astro-4sn4zg3r) pre{padding:1.25rem 1.5rem;border-radius:.75rem;background:var(--sl-color-gray-7);overflow-x:auto;margin:0 0 1.75rem;border:1px solid var(--sl-color-hairline)}.post-content:where(.astro-4sn4zg3r) pre code{padding:0;background:none;font-weight:400}.post-content:where(.astro-4sn4zg3r) ul,.post-content:where(.astro-4sn4zg3r) ol{margin:0 0 1.5rem;padding-left:1.5rem}.post-content:where(.astro-4sn4zg3r) li{margin-bottom:.5rem;line-height:1.7}.post-content:where(.astro-4sn4zg3r) li>ul,.post-content:where(.astro-4sn4zg3r) li>ol{margin-top:.4rem;margin-bottom:.4rem}.post-content:where(.astro-4sn4zg3r) blockquote{border-left:3px solid var(--sl-color-accent);padding:1rem 1.25rem;margin:1.75rem 0;background:#6366f10a;border-radius:0 .5rem .5rem 0;color:var(--sl-color-gray-2);font-style:normal}.post-content:where(.astro-4sn4zg3r) blockquote p{margin-bottom:.5rem}.post-content:where(.astro-4sn4zg3r) blockquote p:last-child{margin-bottom:0}.post-content:where(.astro-4sn4zg3r) blockquote strong{color:var(--sl-color-white)}.post-content:where(.astro-4sn4zg3r) table{width:100%;border-collapse:separate;border-spacing:0;margin:1.75rem 0;font-size:.92rem;line-height:1.6;border-radius:.75rem;overflow:hidden;border:1px solid var(--sl-color-hairline)}.post-content:where(.astro-4sn4zg3r) thead{background:#6366f114}.post-content:where(.astro-4sn4zg3r) th{padding:.85rem 1rem;text-align:left;font-weight:600;color:var(--sl-color-white);font-size:.85rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--sl-color-accent)}.post-content:where(.astro-4sn4zg3r) td{padding:.75rem 1rem;border-bottom:1px solid var(--sl-color-hairline);vertical-align:top}.post-content:where(.astro-4sn4zg3r) tr:last-child td{border-bottom:none}.post-content:where(.astro-4sn4zg3r) tbody tr:nth-child(2n){background:#6366f108}.post-content:where(.astro-4sn4zg3r) tbody tr:hover{background:#6366f10f}.post-content:where(.astro-4sn4zg3r) .table-wrapper,.post-content:where(.astro-4sn4zg3r) div:has(>table){overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1.75rem 0}.post-content:where(.astro-4sn4zg3r) .table-wrapper table,.post-content:where(.astro-4sn4zg3r) div:has(>table) table{margin:0}.post-content:where(.astro-4sn4zg3r) hr{border:none;height:1px;background:linear-gradient(to right,transparent,var(--sl-color-hairline) 20%,var(--sl-color-hairline) 80%,transparent);margin:3rem 0}.post-content:where(.astro-4sn4zg3r) img{border-radius:.75rem;margin:1.5rem 0;border:1px solid var(--sl-color-hairline)}.post-content:where(.astro-4sn4zg3r) a{color:var(--sl-color-accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;transition:text-decoration-color .15s}.post-content:where(.astro-4sn4zg3r) a:hover{text-decoration-thickness:2px}.post-content:where(.astro-4sn4zg3r) strong{color:var(--sl-color-white);font-weight:600}@media(max-width:640px){.post-content:where(.astro-4sn4zg3r) table{font-size:.82rem}.post-content:where(.astro-4sn4zg3r) th,.post-content:where(.astro-4sn4zg3r) td{padding:.6rem .7rem}.post-content:where(.astro-4sn4zg3r) blockquote{padding:.75rem 1rem;margin:1.25rem 0}}.post-footer:where(.astro-4sn4zg3r){margin-top:3rem;padding-top:2rem;border-top:1px solid var(--sl-color-hairline)}.back-link:where(.astro-4sn4zg3r){display:inline-block;margin-top:1.5rem;font-size:.9rem;color:var(--sl-color-gray-3);text-decoration:none}.back-link:where(.astro-4sn4zg3r):hover{color:var(--sl-color-white)}.related-section:where(.astro-4sn4zg3r){max-width:1060px;margin:3rem auto 0;padding-top:2rem;border-top:1px solid var(--sl-color-hairline)}.related-heading:where(.astro-4sn4zg3r){font-size:1rem;font-weight:600;color:var(--sl-color-gray-3);margin:0 0 1rem}.related-grid:where(.astro-4sn4zg3r){display:grid;gap:.75rem}.related-card:where(.astro-4sn4zg3r){display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-radius:.5rem;border:1px solid var(--sl-color-hairline);text-decoration:none;transition:border-color .15s}.related-card:where(.astro-4sn4zg3r):hover{border-color:var(--sl-color-accent)}.related-title:where(.astro-4sn4zg3r){font-size:.9rem;font-weight:600;color:var(--sl-color-white)}.related-card:where(.astro-4sn4zg3r) time:where(.astro-4sn4zg3r){font-size:.8rem;color:var(--sl-color-gray-3);white-space:nowrap;margin-left:1rem}@media(max-width:480px){.post-title:where(.astro-4sn4zg3r){font-size:1.6rem}}.expressive-code .copy button{opacity:.6!important;width:1.6rem!important;height:1.6rem!important;background:transparent!important;border:none!important}.expressive-code .copy button div{display:none!important}.expressive-code .copy button:before{display:none!important}.expressive-code .copy button:after{background-color:#d6deeb!important;margin:.25rem!important}.expressive-code .copy button:hover{opacity:1!important}
