*,:after,:before{box-sizing:border-box;border-width:0;border-style:solid;border-color:var(--un-default-border-color,#e5e7eb)}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*,:after,:before{--un-rotate:0;--un-rotate-x:0;--un-rotate-y:0;--un-rotate-z:0;--un-scale-x:1;--un-scale-y:1;--un-scale-z:1;--un-skew-x:0;--un-skew-y:0;--un-translate-x:0;--un-translate-y:0;--un-translate-z:0;--un-pan-x: ;--un-pan-y: ;--un-pinch-zoom: ;--un-scroll-snap-strictness:proximity;--un-ordinal: ;--un-slashed-zero: ;--un-numeric-figure: ;--un-numeric-spacing: ;--un-numeric-fraction: ;--un-border-spacing-x:0;--un-border-spacing-y:0;--un-ring-offset-shadow:0 0 transparent;--un-ring-shadow:0 0 transparent;--un-shadow-inset: ;--un-shadow:0 0 transparent;--un-ring-inset: ;--un-ring-offset-width:0px;--un-ring-offset-color:#fff;--un-ring-width:0px;--un-ring-color:rgba(147,197,253,.5);--un-blur: ;--un-brightness: ;--un-contrast: ;--un-drop-shadow: ;--un-grayscale: ;--un-hue-rotate: ;--un-invert: ;--un-saturate: ;--un-sepia: ;--un-backdrop-blur: ;--un-backdrop-brightness: ;--un-backdrop-contrast: ;--un-backdrop-grayscale: ;--un-backdrop-hue-rotate: ;--un-backdrop-invert: ;--un-backdrop-opacity: ;--un-backdrop-saturate: ;--un-backdrop-sepia: }::backdrop{--un-rotate:0;--un-rotate-x:0;--un-rotate-y:0;--un-rotate-z:0;--un-scale-x:1;--un-scale-y:1;--un-scale-z:1;--un-skew-x:0;--un-skew-y:0;--un-translate-x:0;--un-translate-y:0;--un-translate-z:0;--un-pan-x: ;--un-pan-y: ;--un-pinch-zoom: ;--un-scroll-snap-strictness:proximity;--un-ordinal: ;--un-slashed-zero: ;--un-numeric-figure: ;--un-numeric-spacing: ;--un-numeric-fraction: ;--un-border-spacing-x:0;--un-border-spacing-y:0;--un-ring-offset-shadow:0 0 transparent;--un-ring-shadow:0 0 transparent;--un-shadow-inset: ;--un-shadow:0 0 transparent;--un-ring-inset: ;--un-ring-offset-width:0px;--un-ring-offset-color:#fff;--un-ring-width:0px;--un-ring-color:rgba(147,197,253,.5);--un-blur: ;--un-brightness: ;--un-contrast: ;--un-drop-shadow: ;--un-grayscale: ;--un-hue-rotate: ;--un-invert: ;--un-saturate: ;--un-sepia: ;--un-backdrop-blur: ;--un-backdrop-brightness: ;--un-backdrop-contrast: ;--un-backdrop-grayscale: ;--un-backdrop-hue-rotate: ;--un-backdrop-invert: ;--un-backdrop-opacity: ;--un-backdrop-saturate: ;--un-backdrop-sepia: }.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.after\:absolute:after{position:absolute}.static{position:static}.left-0{left:0}.right-0{right:0}.top-16{top:4rem}.after\:left-0:after{left:0}.after\:top-0:after{top:0}.z-\[9\]{z-index:9}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.my{margin-top:1rem;margin-bottom:1rem}.my-6{margin-top:1.5rem;margin-bottom:1.5rem}.mb-16{margin-bottom:4rem}.mb-24{margin-bottom:6rem}.mb-3{margin-bottom:.75rem}.mb-32{margin-bottom:8rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb0{margin-bottom:0}.me{margin-inline-end:1rem}.mr-2{margin-right:.5rem}.mr-4{margin-right:1rem}.ms{margin-inline-start:1rem}.mt-0{margin-top:0}.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}.mt-28{margin-top:7rem}.mt-5{margin-top:1.25rem}.mt-8{margin-top:2rem}.inline{display:inline}.block{display:block}.inline-block{display:inline-block}.hidden{display:none}.h-\[230px\]{height:230px}.h-12{height:3rem}.h-14{height:3.5rem}.h-5{height:1.25rem}.h-9{height:2.25rem}.h-full{height:100%}.h1,[h1=""]{height:.25rem}.h2{height:.5rem}.h3{height:.75rem}.max-w-4xl{max-width:56rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-full{max-width:100%}.max-w-screen{max-width:100vw}.max-w-xs{max-width:20rem}.min-h-screen{min-height:100vh}.w-12{width:3rem}.w-5{width:1.25rem}.w-full{width:100%}.after\:h-full:after{height:100%}.after\:w-full:after{width:100%}.flex{display:flex}.inline-flex{display:inline-flex}.flex-shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.flex-col{flex-direction:column}.inline-table{display:inline-table}.table{display:table}.table-caption{display:table-caption}.table-cell{display:table-cell}.transform{transform:translateX(var(--un-translate-x)) translateY(var(--un-translate-y)) translateZ(var(--un-translate-z)) rotate(var(--un-rotate)) rotateX(var(--un-rotate-x)) rotateY(var(--un-rotate-y)) rotate(var(--un-rotate-z)) skewX(var(--un-skew-x)) skewY(var(--un-skew-y)) scaleX(var(--un-scale-x)) scaleY(var(--un-scale-y)) scaleZ(var(--un-scale-z))}.cursor-pointer{cursor:pointer}.resize{resize:both}.columns-1{column-count:1}.break-inside-avoid-column{break-inside:avoid-column}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.gap-3{gap:.75rem}.gap-x-6{column-gap:1.5rem}.gap-y-20{row-gap:5rem}.break-all{word-break:break-all}.b,.border,.border-1,[b=""]{border-width:1px}.border-b{border-bottom-width:1px}.border-t-1{border-top-width:1px}.border-\[\#e9e1e1\]{--un-border-opacity:1;border-color:rgba(233,225,225,var(--un-border-opacity))}.border-neutral-200{--un-border-opacity:1;border-color:rgba(229,229,229,var(--un-border-opacity))}.border-neutral-800{--un-border-opacity:1;border-color:rgba(38,38,38,var(--un-border-opacity))}.rounded{border-radius:.25rem}.rounded-\[3px\]{border-radius:3px}.rounded-full{border-radius:9999px}.rounded-l-md{border-top-left-radius:.375rem;border-bottom-left-radius:.375rem}.border-solid{border-style:solid}.bg-neutral-50{--un-bg-opacity:1;background-color:rgba(250,250,250,var(--un-bg-opacity))}.bg-neutral-800{--un-bg-opacity:1;background-color:rgba(38,38,38,var(--un-bg-opacity))}.after\:bg-\[rgba\(0\,0\,0\,0\.1\)\]:after{--un-bg-opacity:0.1;background-color:rgba(0,0,0,var(--un-bg-opacity))}.object-cover{object-fit:cover}.p-0{padding:0}.p1{padding:.25rem}.p2{padding:.5rem}.p3{padding:.75rem}.p4{padding:1rem}.px,.px-4,[px=""]{padding-left:1rem;padding-right:1rem}.px-16{padding-left:4rem;padding-right:4rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px2rem{padding-left:2rem;padding-right:2rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.pb-30{padding-bottom:7.5rem}.pl-4{padding-left:1rem}.pr-2{padding-right:.5rem}.pt{padding-top:1rem}.pt-12{padding-top:3rem}.pt-2{padding-top:.5rem}.pt-6{padding-top:1.5rem}.pie{padding-inline-end:1rem}.text-center{text-align:center}.text-\[13px\]{font-size:13px}.text-\[24px\]{font-size:24px}.text-5xl{font-size:3rem;line-height:1}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-500{font-weight:500}.font-600{font-weight:600}.font-bold{font-weight:700}.fw6{font-weight:6}.leading-\[1\.25em\]{line-height:1.25em}.leading-6{line-height:1.5rem}.leading-normal{line-height:1.5}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.leading-tight{line-height:1.25}.tracking-tighter{letter-spacing:-.05em}.tracking-wide{letter-spacing:.025em}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}[color~="\#000000"]{--un-text-opacity:1;color:rgba(0,0,0,var(--un-text-opacity))}.text-\[\#f36\]{--un-text-opacity:1;color:rgba(255,51,102,var(--un-text-opacity))}.text-white{--un-text-opacity:1;color:rgba(255,255,255,var(--un-text-opacity))}.hover\:text-blue-600:hover{--un-text-opacity:1;color:rgba(37,99,235,var(--un-text-opacity))}.hover\:text-teal-300:hover{--un-text-opacity:1;color:rgba(94,234,212,var(--un-text-opacity))}.hover\:underline:hover,.underline{text-decoration-line:underline}.shadow-sm{--un-shadow:var(--un-shadow-inset) 0 1px 2px 0 var(--un-shadow-color,rgba(0,0,0,.05))}.hover\:shadow-lg:hover,.shadow-sm{box-shadow:var(--un-ring-offset-shadow),var(--un-ring-shadow),var(--un-shadow)}.hover\:shadow-lg:hover{--un-shadow:var(--un-shadow-inset) 0 10px 15px -3px var(--un-shadow-color,rgba(0,0,0,.1)),var(--un-shadow-inset) 0 4px 6px -4px var(--un-shadow-color,rgba(0,0,0,.1))}.ring{--un-ring-width:1px;--un-ring-offset-shadow:var(--un-ring-inset) 0 0 0 var(--un-ring-offset-width) var(--un-ring-offset-color);--un-ring-shadow:var(--un-ring-inset) 0 0 0 calc(var(--un-ring-width) + var(--un-ring-offset-width)) var(--un-ring-color);box-shadow:var(--un-ring-offset-shadow),var(--un-ring-shadow),var(--un-shadow)}.blur{--un-blur:blur(8px)}.blur,.filter{filter:var(--un-blur) var(--un-brightness) var(--un-contrast) var(--un-drop-shadow) var(--un-grayscale) var(--un-hue-rotate) var(--un-invert) var(--un-saturate) var(--un-sepia)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease\!{transition-timing-function:cubic-bezier(.4,0,.2,1)!important}.after\:content-\[\'\'\]:after{content:""}.text-12{font-size:12px}.text-14{font-size:14px}.text-18{font-size:18px}@media (prefers-color-scheme:dark){.dark\:border-\[\#414141\]{--un-border-opacity:1;border-color:rgba(65,65,65,var(--un-border-opacity))}.dark\:bg-\[rgba\(22\,24\,29\)\]{background-color:#16181d}}@media (min-width:640px){.sm\:absolute{position:absolute}.sm\:mx-0{margin-left:0;margin-right:0}.sm\:text-13{font-size:13px}}@media (min-width:768px){.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:mb-12{margin-bottom:3rem}.md\:block{display:block}.md\:h-\[500px\]{height:500px}.md\:max-w-4xl{max-width:56rem}.md\:w-\[66\%\]{width:66%}.md\:flex-row{flex-direction:row}.md\:columns-3{column-count:3}.md\:justify-between{justify-content:space-between}.md\:gap-6{gap:1.5rem}.md\:gap-x-16{column-gap:4rem}.md\:gap-y-8{row-gap:2rem}.md\:px-0{padding-left:0;padding-right:0}.md\:px-6{padding-left:1.5rem;padding-right:1.5rem}.md\:pl-0{padding-left:0}.md\:pl-8{padding-left:2rem}.md\:pr-8{padding-right:2rem}.md\:pt-20{padding-top:5rem}.md\:text-left{text-align:left}.md\:text-\[46px\]{font-size:46px}.md\:text-8xl{font-size:6rem;line-height:1}.md\:leading-none{line-height:1}}@media (min-width:1024px){.lg\:mb-3{margin-bottom:.75rem}.lg\:gap-x-32{column-gap:8rem}}:root{--max-width:1100px;--border-radius:12px;--font-mono:ui-monospace,Menlo,Monaco,"Cascadia Mono","Segoe UI Mono","Roboto Mono","Oxygen Mono","Ubuntu Monospace","Source Code Pro","Fira Mono","Droid Sans Mono","Courier New",monospace;--wash:#fff;--foreground-rgb:#23272f;--background-start-rgb:214,219,220;--background-end-rgb:255,255,255;--sub-text:#666;--primary-glow:conic-gradient(from 180deg at 50% 50%,#16abff33 0deg,#0885ff33 55deg,#54d6ff33 120deg,#0071ff33 160deg,transparent 360deg);--secondary-glow:radial-gradient(#fff,hsla(0,0%,100%,0));--tile-start-rgb:239,245,249;--tile-end-rgb:228,232,233;--tile-border:conic-gradient(#00000080,#00000040,#00000030,#00000020,#00000010,#00000010,#00000080);--callout-rgb:238,240,241;--callout-border-rgb:172,175,176;--card-rgb:180,185,188;--card-border-rgb:131,134,135;--shiki-color-text:#24292e;--shiki-color-background:#fff;--shiki-token-constant:#6f42c1;--shiki-token-string:#032f62;--shiki-token-comment:#6a737d;--shiki-token-keyword:#d73a49;--shiki-token-parameter:#005cc5;--shiki-token-function:#6f42c1;--shiki-token-string-expression:#032f62;--shiki-token-punctuation:#24292e;--shiki-token-link:#e00;--sp-syntax-color-plain:#24292e;--sp-syntax-color-comment:#6a737d;--sp-syntax-color-keyword:#d73a49;--sp-syntax-color-tag:#22863a;--sp-syntax-color-punctuation:#24292e;--sp-syntax-color-definition:#6f42c1;--sp-syntax-color-property:#005cc5;--sp-syntax-color-static:#032f62;--sp-syntax-color-string:#032f62;--sp-colors-surface1:#fff;--sp-colors-code-inline:#f7f7f7}@media (prefers-color-scheme:dark){:root{--wash:#000;--foreground-rgb:#f6f7f9;--background-start-rgb:0,0,0;--background-end-rgb:0,0,0;--sub-text:#a1a1a1;--primary-glow:radial-gradient(rgba(1,65,255,.4),rgba(1,65,255,0));--secondary-glow:linear-gradient(to bottom right,rgba(1,65,255,0),rgba(1,65,255,0),rgba(1,65,255,.3));--tile-start-rgb:2,13,46;--tile-end-rgb:2,5,19;--tile-border:conic-gradient(#ffffff80,#ffffff40,#ffffff30,#ffffff20,#ffffff10,#ffffff10,#ffffff80);--callout-rgb:20,20,20;--callout-border-rgb:108,108,108;--card-rgb:100,100,100;--card-border-rgb:200,200,200;--sp-syntax-color-plain:#fff;--sp-syntax-color-comment:#757575;--sp-syntax-color-keyword:#77b7d7;--sp-syntax-color-tag:#dfab5c;--sp-syntax-color-punctuation:#fff;--sp-syntax-color-definition:#86d9ca;--sp-syntax-color-property:#77b7d7;--sp-syntax-color-static:#c64640;--sp-syntax-color-string:#977cdc;--sp-colors-surface1:#16181d;--sp-colors-code-inline:#323232}}.sub-text{color:var(--sub-text)}.line,.line-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical}.line-3{-webkit-line-clamp:3}blockquote{font-style:italic}blockquote>p{font-size:12px}pre>code .token.keyword{color:var(--sp-syntax-color-keyword)}pre>code .token.function{color:var(--sp-syntax-color-definition)}pre>code .token.property-access{color:var(--sp-syntax-color-property)}pre>code .token.string{color:var(--sp-syntax-color-string)}pre>code .token.punctuation{color:var(--sp-syntax-color-punctuation)}pre>code .token.operator{color:var(--sp-syntax-color-plain);background-color:transparent!important}pre>code .token.comment{color:var(--sp-syntax-color-comment)}*{box-sizing:border-box;padding:0;margin:0}body,html{max-width:100vw}body{color:var(--foreground-rgb);background:var(--wash)}a{color:inherit;text-decoration:none}@media (prefers-color-scheme:dark){html{color-scheme:dark}}@font-face{font-family:Source Code Pro;font-style:normal;font-weight:400;font-display:swap;src:url(https://react.dev/fonts/Source-Code-Pro-Regular.woff2) format("woff2")}.code-shadow{box-shadow:0 .8px 2px rgba(0,0,0,.032),0 2.7px 6.7px rgba(0,0,0,.048),0 12px 30px rgba(0,0,0,.08)}h1{font-size:40px}h1,h2{font-weight:700}h2{font-size:28px}h3{font-size:24px}h3,h4{font-weight:700}h4{font-size:20px}h1,h2,h3,h4{margin-top:1.5rem;margin-bottom:1.5rem}pre{box-shadow:0 .8px 2px rgba(0,0,0,.032),0 2.7px 6.7px rgba(0,0,0,.048),0 12px 30px rgba(0,0,0,.08);background:var(--sp-colors-surface1)!important;margin-top:2rem;margin-bottom:2rem;height:100%;width:100%;display:flex;align-items:center;overflow-x:auto;border-radius:.5rem;padding:1.125rem}pre>code{color:var(--sp-syntax-color-plain)!important;text-shadow:none!important}.post-body li,p{color:var(--foreground-rgb);margin-top:1rem;margin-bottom:1rem;font-size:14px;line-height:1.8}p>code{background:var(--sp-colors-code-inline);margin-left:3px;margin-right:3px;border-radius:.125rem;padding-left:3px;padding-right:3px}code,pre{font-size:13.6px;font-weight:400;font-family:Source Code Pro,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}pre>.language-id{display:none}code>.line{line-height:24px}.header-anchor-link{position:relative}.header-anchor-link:hover:after{position:absolute;content:"#";left:calc(100% + 4px);opacity:.2}.post-body>a:not(.header-anchor-link,.anchor){will-change:color;transition:all .3s;border-bottom:1px dotted rgba(64,153,255,.6);color:#2f7bbd}a:not(.header-anchor-link,.anchor):hover{color:#f36;border-color:#f36}