.footnotes{margin-top:3rem;border-top-width:1px;--un-border-opacity:1;border-color:rgb(229 231 235 / var(--un-border-opacity));padding-top:2rem}.dark .footnotes{--un-border-opacity:1;border-color:rgb(55 65 81 / var(--un-border-opacity))}.footnotes ol{margin-bottom:0}.footnotes li:last-child p{margin-bottom:0}.prose .rlc-container{margin-top:1.5rem;margin-bottom:1.5rem;width:100%;display:flex;align-items:stretch;gap:0;overflow:hidden;border-width:1px;--un-border-opacity:1;border-color:rgb(229 231 235 / var(--un-border-opacity));border-radius:.5rem;--un-bg-opacity:1;background-color:rgb(255 255 255 / var(--un-bg-opacity));text-decoration:none;--un-shadow:var(--un-shadow-inset) 0 1px 2px 0 var(--un-shadow-color, rgb(0 0 0 / .05));box-shadow:var(--un-ring-offset-shadow),var(--un-ring-shadow),var(--un-shadow);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-duration:.2s}.dark .prose .rlc-container{--un-border-opacity:1;border-color:rgb(55 65 81 / var(--un-border-opacity));--un-bg-opacity:1;background-color:rgb(31 41 55 / var(--un-bg-opacity))}@media(min-width:1024px){.prose .rlc-container:hover{--un-shadow:var(--un-shadow-inset) 0 4px 6px -1px var(--un-shadow-color, rgb(0 0 0 / .1)),var(--un-shadow-inset) 0 2px 4px -2px var(--un-shadow-color, rgb(0 0 0 / .1));box-shadow:var(--un-ring-offset-shadow),var(--un-ring-shadow),var(--un-shadow)}}.prose a{overflow-wrap:anywhere;word-break:break-word}.blog-article-meta-item{align-items:center;display:inline-flex;gap:.4rem;white-space:nowrap}.blog-article-meta-icon{color:currentColor;display:inline-flex;flex-shrink:0;height:1rem;opacity:.85;width:1rem}.blog-article-meta-prefix{font-size:.78rem;letter-spacing:.04em;opacity:.78}.prose table{border-collapse:collapse;border:1px solid #d1d5db;border-spacing:0;table-layout:fixed;width:100%}html.dark .prose table{border-color:#4b5563}.prose th,.prose td{border:1px solid #d1d5db;overflow-wrap:break-word;padding:.625rem .875rem;word-break:break-word}html.dark .prose th,html.dark .prose td{border-color:#4b5563}.blog-article-content :where(ul ul,ul ol,ol ul,ol ol){margin-top:.75rem;margin-bottom:.75rem}.blog-article-content .code-block-wrapper{margin-top:1.5rem;margin-bottom:1.5rem;position:relative}.blog-article-content .code-file-label{align-items:center;background:#e5e7eb;border-bottom-right-radius:.88rem;border-top-left-radius:.75rem;box-shadow:0 1px #0f172a14;color:#1f2937;display:inline-flex;font-size:.94rem;font-weight:700;left:0;letter-spacing:.01em;line-height:1;max-width:calc(100% - 4.8rem);overflow:hidden;padding:.48rem .95rem;pointer-events:none;position:absolute;text-overflow:ellipsis;top:0;white-space:nowrap;z-index:1}.blog-article-content .code-copy-live{border:0;clip-path:inset(50%);clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.blog-article-content .code-copy-button{align-items:center;background:#12223deb;border:1px solid rgb(103 137 197 / .55);border-radius:.72rem;box-shadow:0 0 0 1px #94a3b833,0 8px 20px #0f172a40;color:#e2e8f0;cursor:pointer;display:inline-flex;height:2.2rem;justify-content:center;line-height:1;opacity:0;padding:0;pointer-events:none;position:absolute;right:.7rem;top:.7rem;transform:translateY(-2px) scale(.96);transition:border-color .18s ease,box-shadow .18s ease,color .18s ease,opacity .18s ease,transform .18s ease,visibility 0s linear .18s;visibility:hidden;width:2.2rem;z-index:2}.blog-article-content .code-copy-button[data-copy-visible=true]{opacity:1;pointer-events:auto;transform:translateY(0) scale(1);transition-delay:0s;visibility:visible}.blog-article-content .code-copy-button:after{background:#0f172a;border-radius:.45rem;color:#f8fafc;content:attr(data-copy-feedback);font-size:.7rem;font-weight:600;left:50%;opacity:0;padding:.22rem .45rem;pointer-events:none;position:absolute;top:calc(100% + .35rem);transform:translate(-50%,-4px);transition:opacity .16s ease,transform .16s ease;white-space:nowrap}.blog-article-content .code-copy-button:hover{border-color:#93c5fd;box-shadow:0 0 0 1px #94a3b847,0 10px 24px #0f172a52;transform:translateY(-1px)}.blog-article-content .code-copy-button:focus-visible{outline:2px solid #38bdf8;outline-offset:2px}.blog-article-content .code-copy-button[data-copy-state=success],.blog-article-content .code-copy-button[data-copy-state=error]{transform:translateY(-1px)}.blog-article-content .code-copy-button[data-copy-state=success]{border-color:#22d3ee;color:#67e8f9}.blog-article-content .code-copy-button[data-copy-state=error]{border-color:#f87171;color:#fecaca}.blog-article-content .code-copy-button[data-copy-state=success]:after,.blog-article-content .code-copy-button[data-copy-state=error]:after{opacity:1;transform:translate(-50%)}.blog-article-content .code-copy-icon{font-size:1.12rem;line-height:1;position:absolute;transition:opacity .15s ease,transform .15s ease}.blog-article-content .code-copy-icon--success{opacity:0;transform:scale(.75)}.blog-article-content .code-copy-button[data-copy-state=success] .code-copy-icon--copy{opacity:0;transform:scale(.72)}.blog-article-content .code-copy-button[data-copy-state=success] .code-copy-icon--success{opacity:1;transform:scale(1)}.blog-article-content pre.astro-code{--code-line-number-gap: 1.4rem;--code-line-height: 0;--code-line-number-width: 2.35rem;--code-column-divider-color: rgb(148 163 184 / .35);--code-column-divider-x: calc( var(--code-line-number-width) + (var(--code-line-number-gap) * .5) );--code-column-divider-extra-height: 20px;--code-column-divider-height: calc(100% + var(--code-column-divider-extra-height));--code-column-divider-top: calc(var(--code-column-divider-extra-height) / -2);background:var(--shiki-dark-bg, #111827)!important;border:1px solid #4b5563;border-radius:.75rem;color:var(--shiki-dark, #e5e7eb)!important;margin-top:0!important;margin-bottom:0!important;overflow-x:auto;padding:2.4rem .85rem!important}.blog-article-content pre.astro-code[data-code-filename]{padding-top:3rem!important}.blog-article-content pre.astro-code code{counter-reset:code-line;display:block;min-width:max-content;position:relative}.blog-article-content pre.astro-code code:before{background:var(--code-column-divider-color);content:"";height:var(--code-column-divider-height, 100%)!important;left:var(--code-column-divider-x);pointer-events:none;position:absolute;top:var(--code-column-divider-top, 0);width:1px}.blog-article-content pre.astro-code code>span.line{display:block;line-height:var(--code-line-height);min-height:calc(1em * var(--code-line-height));padding-left:calc(var(--code-line-number-width) + var(--code-line-number-gap));position:relative}.blog-article-content pre.astro-code code>span.line:before{color:#94a3b8;content:counter(code-line);counter-increment:code-line;font-size:.78rem;font-variant-numeric:tabular-nums;left:0;line-height:var(--code-line-height);opacity:.8;pointer-events:none;position:absolute;text-align:right;user-select:none;width:var(--code-line-number-width)}.blog-article-content pre.astro-code span,.blog-article-content pre.astro-code span[style*=--shiki-dark]{color:var(--shiki-dark)!important}html.dark .blog-article-content .code-copy-button{background:#0f172ae6;border-color:#475569e6;box-shadow:0 0 0 1px #64748b4d,0 10px 24px #0206178c;color:#e2e8f0}html.dark .blog-article-content .code-copy-button:hover{border-color:#7dd3fc}html.dark .blog-article-content .code-copy-button[data-copy-state=success]{border-color:#22d3ee;color:#a5f3fc}html.dark .blog-article-content .code-copy-button[data-copy-state=error]{border-color:#fb7185;color:#fecdd3}html.dark .blog-article-content .code-file-label{background:#dbe3ee;color:#0f172a;box-shadow:0 1px #0f172a26}.blog-article-content .admonition{border:1px solid #d1d5db;border-radius:.75rem;margin:1.5rem 0;padding:.875rem 1rem 1rem}.blog-article-content .admonition__title{font-size:1.2rem;font-weight:700;margin:0}.blog-article-content .admonition__content{margin-top:.5rem}.blog-article-content .admonition__content>:first-child{margin-top:0}.blog-article-content .admonition__content>:last-child{margin-bottom:0}.blog-article-content .admonition--note{background:#f0fdf4;border-color:#86efac}.blog-article-content .admonition--caution{background:#fffbeb;border-color:#fcd34d}.blog-article-content .admonition--danger{background:#fef2f2;border-color:#fca5a5}html.dark .blog-article-content .admonition{border-color:#4b5563}html.dark .blog-article-content .admonition--note{background:#052e16;border-color:#15803d}html.dark .blog-article-content .admonition--caution{background:#422006;border-color:#b45309}html.dark .blog-article-content .admonition--danger{background:#450a0a;border-color:#b91c1c}.prose .rlc-container:hover{--un-text-opacity:1;color:rgb(17 24 39 / var(--un-text-opacity))}.dark .prose .rlc-container:hover{--un-text-opacity:1;color:rgb(243 244 246 / var(--un-text-opacity))}.prose .rlc-info{min-width:0;display:flex;flex-direction:column;gap:.375rem;padding:1.5rem}.prose .rlc-title{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;--un-text-opacity:1;color:rgb(17 24 39 / var(--un-text-opacity));font-weight:600}.dark .prose .rlc-title{--un-text-opacity:1;color:rgb(243 244 246 / var(--un-text-opacity))}.prose .rlc-description{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;font-size:.875rem;line-height:1.25rem;--un-text-opacity:1;color:rgb(75 85 99 / var(--un-text-opacity))}.dark .prose .rlc-description{--un-text-opacity:1;color:rgb(209 213 219 / var(--un-text-opacity))}.prose .rlc-url-container{margin-top:1rem;display:flex;align-items:center;gap:.5rem;font-size:.75rem;line-height:1rem;--un-text-opacity:1;color:rgb(107 114 128 / var(--un-text-opacity))}.dark .prose .rlc-url-container{--un-text-opacity:1;color:rgb(156 163 175 / var(--un-text-opacity))}.prose .rlc-favicon{width:1rem;height:1rem;margin-block:0}.prose .rlc-url{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prose .rlc-image-container{display:none}.prose .rlc-image{width:100%;height:100%;border-radius:0;object-fit:cover}.blog-article-content img{cursor:zoom-in;-webkit-touch-callout:none}.blog-image-modal{opacity:0;pointer-events:none;transition:opacity .2s ease,visibility 0ms linear .2s;visibility:hidden}.blog-image-modal.is-open{opacity:1;pointer-events:auto;visibility:visible;transition:opacity .2s ease,visibility 0ms}.blog-image-modal img{transform:scale(.98);opacity:0;transition:transform .2s ease,opacity .2s ease}.blog-image-modal.is-open img{transform:scale(1);opacity:1}.toc-sidebar{--toc-sidebar-top: clamp(6.5rem, 35vh, 12.5rem);width:14rem;flex-shrink:0;align-self:start;position:sticky;top:var(--toc-sidebar-top);max-height:calc(100vh - var(--toc-sidebar-top) - 1.5rem)}.toc-sidebar-nav{position:static;max-height:100%;overflow-y:auto;overscroll-behavior:contain;padding:.25rem 0}.toc-sidebar-title{font-size:.875rem;font-weight:700;color:#111827;margin-bottom:.75rem;padding-left:.75rem}html.dark .toc-sidebar-title{color:#f3f4f6}.toc-sidebar-list{list-style:none;padding:0;margin:0}.toc-sidebar-list .toc-sidebar-list{padding-left:.75rem}.toc-sidebar-link{display:block;padding:.25rem .75rem;font-size:.8125rem;line-height:1.5;color:#6b7280;text-decoration:none;border-left:2px solid transparent;transition:color .15s,border-color .15s}.toc-sidebar-link:hover{color:#374151}html.dark .toc-sidebar-link{color:#9ca3af}html.dark .toc-sidebar-link:hover{color:#d1d5db}.toc-sidebar-link.is-active{color:#111827;font-weight:600;border-left-color:#111827}html.dark .toc-sidebar-link.is-active{color:#f3f4f6;border-left-color:#f3f4f6}.toc-mobile-bar{position:fixed;top:4rem;left:0;right:0;z-index:40;background:#fff;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:flex-end;padding:0 1rem;height:2.75rem;cursor:pointer;transition:transform .3s}html.dark .toc-mobile-bar{background:#111827;border-top-color:#374151;border-bottom-color:#374151}.toc-mobile-bar--hidden{transform:translateY(calc(-100% - 4rem))}.toc-mobile-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:600;color:#374151;background:none;border:none;border-radius:.375rem;flex-shrink:0;min-height:2rem;min-width:2.75rem}html.dark .toc-mobile-btn{color:#d1d5db}@media(min-width:1280px){.toc-mobile-bar{display:none!important}}.toc-panel-backdrop{position:fixed;inset:0;background:#0006;z-index:70;opacity:0;pointer-events:none;transition:opacity .25s ease}.toc-panel-backdrop--visible{opacity:1;pointer-events:auto}.toc-panel{position:fixed;top:0;left:0;bottom:0;z-index:71;width:min(20rem,85vw);background:#fff;transform:translate(-100%);transition:transform .3s ease;display:flex;flex-direction:column}html.dark .toc-panel{background:#1f2937}.toc-panel--open{transform:translate(0)}.toc-panel-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}html.dark .toc-panel-header{border-bottom-color:#374151}.toc-panel-title{font-size:1rem;font-weight:700;color:#111827}html.dark .toc-panel-title{color:#f3f4f6}.toc-panel-close{display:inline-flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;background:none;border:none;color:#6b7280;cursor:pointer;border-radius:.375rem;transition:background-color .15s}.toc-panel-close:hover{background:#f3f4f6}html.dark .toc-panel-close{color:#9ca3af}html.dark .toc-panel-close:hover{background:#374151}.toc-panel-body{overflow-y:auto;overscroll-behavior:contain;padding:.75rem 1.25rem 1.5rem;flex:1}.toc-panel-list{list-style:none;padding:0;margin:0}.toc-panel-list .toc-panel-list{padding-left:.75rem}.toc-panel-link{display:block;padding:.5rem .75rem;font-size:.875rem;line-height:1.5;color:#6b7280;text-decoration:none;border-left:2px solid transparent;border-radius:0 .25rem .25rem 0;transition:color .15s,border-color .15s,background-color .15s}.toc-panel-link:hover{color:#374151;background:#f3f4f6}html.dark .toc-panel-link{color:#9ca3af}html.dark .toc-panel-link:hover{color:#d1d5db;background:#374151}.toc-panel-link.is-active{color:#111827;font-weight:600;border-left-color:#111827}html.dark .toc-panel-link.is-active{color:#f3f4f6;border-left-color:#f3f4f6}@media(min-width:1280px){.toc-panel,.toc-panel-backdrop{display:none!important}}@media(prefers-reduced-motion:reduce){.toc-mobile-bar,.toc-panel,.toc-panel-backdrop,.toc-sidebar-link{transition:none}}
