button[data-astro-cid-vnzlvqnm]{padding:var(--space-1) var(--space-3);border-radius:var(--radius-medium);border-color:var(--border);background-color:var(--button);font-size:var(--text-7);font-family:var(--font-text);font-weight:var(--font-semibold)}button[data-astro-cid-vnzlvqnm] a[data-astro-cid-vnzlvqnm]{color:inherit;text-decoration:none;text-decoration-line:none;transition:inherit}button[data-astro-cid-vnzlvqnm]:hover,button[data-astro-cid-vnzlvqnm].button-active{background-color:var(--primary);color:var(--primary-foreground);border:none;a:hover{color:inherit}}@layer reset,variables,base,utilities,components;@layer reset{*,*:before,*:after{box-sizing:border-box}*:not(dialog){margin:0}@media(prefers-reduced-motion:no-preference){html{interpolate-size:allow-keywords}}body{-webkit-font-smoothing:auto}img,picture,video,canvas,svg{display:block;max-width:100%;vertical-align:middle}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}p{text-wrap:pretty}h1,h2,h3,h4,h5,h6{text-wrap:balance}button{appearance:none;background:transparent;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;outline:none}#root{isolation:isolate}}@layer variables{:root.dark{color-scheme:dark}:root{--color-off-white: oklch(99% .002 247.839deg);--color-slight-gray: rgb(250 250 250);--color-base-50: oklch(98.5% .002 247.839deg);--color-base-100: oklch(96.7% .003 264.542deg);--color-base-150: oklch(95.5% .004 261.325deg);--color-base-200: oklch(92.8% .006 264.531deg);--color-base-300: oklch(87.2% .01 258.338deg);--color-base-400: oklch(70.7% .022 261.325deg);--color-base-500: oklch(55.1% .027 264.364deg);--color-base-600: oklch(44.6% .03 256.802deg);--color-base-700: oklch(37.3% .034 259.733deg);--color-base-750: oklch(32.5% .033 261.692deg);--color-base-800: oklch(27.8% .033 256.848deg);--color-base-900: oklch(21% .034 264.665deg);--color-base-950: oklch(13% .028 261.692deg);color-scheme:light;--background: light-dark(var(--color-off-white), var(--color-base-800));--foreground: light-dark(var(--color-base-950), var(--color-base-200));--primary: light-dark(var(--color-base-800), var(--color-base-200));--primary-foreground: light-dark(var(--color-base-100), var(--color-base-800));--border: light-dark(var(--color-base-200), var(--color-base-600));--list-disc: light-dark(var(--color-base-400), var(--color-base-600));--secondary: light-dark(var(--color-slight-gray), var(--color-base-750));--button: light-dark(var(--color-base-150), var(--color-base-700));--foreground-secondary: light-dark(var(--color-base-700), var(--color-base-300));--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-14: 3.5rem;--space-16: 4rem;--space-18: 4.5rem;--space-char: 65ch;--text-1: clamp(1.75rem, 1.5rem + 1.1vw, 2.25rem);--text-2: clamp(1.5rem, 1.3rem + .8vw, 1.875rem);--text-3: clamp(1.25rem, 1.1rem + .5vw, 1.5rem);--text-4: clamp(1.125rem, 1.05rem + .3vw, 1.25rem);--text-5: 1.125rem;--text-6: 1rem;--text-7: .875rem;--text-8: .75rem;--text-9: .625rem;--text-10: .5rem;--text-11: .375rem;--text-12: .25rem;--radius-small: .125rem;--radius-medium: .375rem;--radius-large: .75rem;--radius-full: 9999px;--width-sm: 640px;--width-md: 768px;--width-lg: 1120px;--width-sidebar: 25ch;--width-avatar: 200px;--sz: var(--width-avatar);--font-text: var(--font-nunito-sans), system-ui, sans-serif;--font-heading: var(--font-inter), system-ui, sans-serif;--font-mono: var(--font-fira-code), ui-monospace, consolas, monospace;--leading-small: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.75;--font-normal: 450;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--text-regular: var(--text-5);--transition-fast: .12s cubic-bezier(.4, 0, .2, 1);--transition: .2s cubic-bezier(.4, 0, .2, 1);--color-info: oklch(70.7% .165 254.624deg);--color-important: oklch(71.4% .203 305.504deg);--color-warning: oklch(75% .183 55.934deg);--color-caution: oklch(63.7% .237 25.331deg);--color-tip: oklch(.6456 .2245 148.76)}}@layer base{*{border-color:var(--border)}body{color:var(--foreground);background-color:var(--background);font-family:var(--font-text);font-weight:var(--font-normal);font-size:var(--text-regular);line-height:var(--leading-normal)}main{max-width:var(--width-lg);margin-inline:auto;padding-block-start:var(--space-8);padding-inline:var(--space-6);display:flex;flex-direction:column}.sr-only{display:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:var(--font-semibold);line-height:1.25;&:first-child{margin-block-start:0}}h1{font-size:var(--text-1);margin:var(--space-10) 0 var(--space-6)}h2{font-size:var(--text-2);margin:var(--space-8) 0 var(--space-5)}h3{font-size:var(--text-3);margin:var(--space-6) 0 var(--space-4)}h4{font-size:var(--text-4);margin:var(--space-5) 0 var(--space-3)}h5{font-size:var(--text-5);margin:var(--space-4) 0 var(--space-2)}h6{font-size:var(--text-regular);margin:var(--space-4) 0 var(--space-2)}p{margin-block-end:var(--space-4);&:last-child{margin-block-end:0}}a{color:var(--foreground);font-weight:var(--font-semibold);text-decoration:underline;text-underline-offset:var(--space-1);transition:color var(--transition-fast);&:hover{color:var(--foreground-secondary)}}strong,b{font-weight:var(--font-semibold)}em,i{font-style:italic}ul,ol{padding-inline-start:var(--space-6);margin-block-end:var(--space-4)}ul{list-style-type:disc}li{margin-block-end:var(--space-1)}ul li:not(:last-child){margin-bottom:var(--space-2)}ol{list-style-type:decimal}ul>li::marker{color:var(--list-disc)}svg,img,video{max-width:100%;height:auto}figure>img,figure>svg{margin-inline:auto}.katex-display{overflow:auto hidden;height:auto;padding-top:.1rem;padding-bottom:.1rem}.katex *{display:inherit;width:initial;height:initial}.katex svg{display:inline}.katex .sr-only,.katex .katex-mathml{display:none}kbd{box-shadow:0 0 0 1px var(--border),0 3px 0 var(--border);border-radius:var(--radius-medium);padding:var(--space-1);font-family:var(--font-mono);font-size:var(--text-6)}}@layer components{.prose{max-width:var(--space-char);p,h1,h2,h3,h4,h5,h6,figure,blockquote,div.expressive-code,ul,.markdown-table-wrapper,aside{margin-bottom:var(--space-4)}h2{line-height:var(--leading-snug);font-weight:var(--font-bold)}h2:not(:first-child){margin-top:var(--space-10)}h3:not(:first-child){margin-top:var(--space-8)}h4:not(:first-child){margin-top:var(--space-6)}h5:not(:first-child){margin-top:var(--space-4)}blockquote{padding-inline-start:var(--space-4);margin-top:var(--space-6);margin-bottom:var(--space-6);border-left:4px solid var(--border);:before{content:open-quote}:after{content:close-quote}p{font-style:italic;color:var(--foreground-secondary)}}li{padding-inline-start:var(--space-2)}strong,b{font-weight:var(--font-bold)}em,i{font-style:italic}code{font-family:var(--font-mono);font-weight:var(--font-semibold);font-size:var(--text-6)}code:not(pre code){display:inline-block}code:not(pre code):before,code:not(pre code):after{content:"`"}pre>code .ec-line{max-height:var(--space-5)!important}svg,img,video{border-radius:var(--radius-medium)}figure{@media(width>=110ch){margin-inline:auto;max-width:75%}}figure>img,figure>svg{margin-bottom:var(--space-4)}figure>figcaption{font-size:var(--text-6);color:var(--foreground-secondary);text-align:center}sup{white-space:nowrap;unicode-bidi:isolate;font-size:var(--text-8);a[data-footnote-ref]{display:inline-block;text-decoration:none}a[data-footnote-ref]:before{content:"["}a[data-footnote-ref]:after{content:"]"}}.markdown-table-wrapper{overflow-x:auto;border-radius:var(--radius-medium);border:1px solid var(--border);box-shadow:0 1px 2px rgb(from var(--border) r g b / 10%);font-size:var(--text-7);font-weight:var(--font-medium);background-color:var(--secondary);--background-border-color: var(--button);code,p{font-size:inherit}table{width:100%;border-collapse:collapse}thead{background-color:var(--background-border-color);border-bottom:1px solid var(--border)}th{padding-inline:var(--space-2);padding-block:var(--space-2);margin:auto;text-align:center;vertical-align:middle;img{margin-block:0}}td{padding-inline:var(--space-2);padding-block:var(--space-2);border-bottom:1px solid var(--border)}}}}@layer utilities{.align-left{text-align:start}.align-center{text-align:center}.align-right{text-align:end}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex};.wrap{flex-wrap:wrap}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.hstack{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;align-content:flex-start;height:auto;>*{margin:0}}.vstack{display:flex;flex-direction:column;gap:var(--space-3)}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.mx-auto{margin-left:auto;margin-right:auto}.mt-2{margin-block-start:var(--space-2)}.mt-4{margin-block-start:var(--space-4)}.mt-6{margin-block-start:var(--space-6)}.mb-2{margin-block-end:var(--space-2)}.mb-4{margin-block-end:var(--space-4)}.mb-6{margin-block-end:var(--space-6)}.p-4{padding:var(--space-4)}:is(ul,ol,a).unstyled{list-style:none;text-decoration:none;padding:0}.hide-md{@media(width<=110ch){display:none!important}}.sidebar{position:sticky;top:var(--space-8);align-self:flex-start;padding-bottom:var(--space-4)}ul.list-no-decoration,.list-no-decoration ul{list-style:none;padding:0}a.link-no-decoration,.link-no-decoration a{text-decoration:none}.hide-dark{display:block}.hide-light{display:none}.dark{.hide-dark{display:none}.hide-light{display:block}}.w-100{width:100%}.w-23{width:25%}.w-50{width:50%}.w-33{width:33%}.image-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);@media(width<=110ch){grid-template-columns:100%}}}@layer components{.blog-post-hero{h1{margin-bottom:var(--space-2);text-wrap:auto}h1 code{display:inline}p{margin-bottom:0}.blog-post-metadata{color:var(--foreground-secondary);font-size:var(--text-6)}.hero-tag{display:inline-block;a{font-size:var(--text-6)}a:before{content:"#";margin-right:0}}}.blog-content{width:100%}figure.beoe.d2{margin-inline:0;max-width:100%;svg{margin-inline:auto;max-height:50vh}svg.d2-svg>rect{fill:var(--background)!important}}.beoe-light{display:block}.beoe-dark{display:none}.dark{.beoe-light{display:none}.beoe-dark{display:block}}.footnotes{margin-top:var(--space-10)}}@layer components{.card{border:1px solid var(--border);border-radius:var(--radius-large);background-color:var(--secondary)}}.social-connection[data-astro-cid-tgn4b3wb] a[data-astro-cid-tgn4b3wb]{font-weight:var(--font-normal)}footer[data-astro-cid-35ed7um5]{font-size:var(--text-7);color:var(--foreground-secondary);margin-top:var(--space-8);border-top:1px solid var(--border);padding-top:var(--space-4);padding-bottom:var(--space-4);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;row-gap:var(--space-3)}.footer-attributions[data-astro-cid-35ed7um5]{@media(max-width:768px){text-align:center;width:100%}}.footer-socials[data-astro-cid-35ed7um5]{margin-left:auto;@media(max-width:768px){margin-inline:auto}}.navbar[data-astro-cid-qlfjksao]{margin-bottom:var(--space-6);font-family:var(--font-heading);flex-wrap:wrap;row-gap:var(--space-2);a{font-size:var(--text-5);line-height:var(--leading-small)}.navbar-home-link{font-size:var(--text-3);font-weight:var(--font-bold)}#toggleDarkMode{padding:0;border:none}.dark #toggleDarkMode svg{filter:invert(1)}.navbar-secondary-links{margin-left:auto}}
