.theme-switch-wrap[data-astro-cid-g6q3pnbr]{margin-left:auto;display:inline-flex;gap:0;align-items:center;color:var(--color-faint);font-size:inherit;line-height:inherit;letter-spacing:.01em}.theme-switch-btn[data-astro-cid-g6q3pnbr]{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;padding:2px 4px;color:inherit;font:inherit;cursor:pointer;transition:color .15s ease}.theme-switch-btn[data-astro-cid-g6q3pnbr][aria-pressed=true]{color:var(--color-text);font-weight:600}.theme-switch-btn[data-astro-cid-g6q3pnbr]:hover{color:var(--color-text)}.theme-switch-btn[data-astro-cid-g6q3pnbr]:focus-visible{outline:none;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;color:var(--color-text)}.theme-switch-sep[data-astro-cid-g6q3pnbr]{color:var(--color-line-strong);font-size:11px;line-height:1;opacity:.75;transform:translateY(-1px)}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI Variable,Segoe UI,Helvetica Neue,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-feature-settings:normal;font-variation-settings:normal;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;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-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,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--color-bg: light-dark(#f7f7f7, #131315);--color-surface: light-dark(#ffffff, #131315);--color-card-bg: light-dark(#ffffff, rgba(255, 255, 255, .045));--color-pre-bg: light-dark(#ffffff, #161618);--color-code-bg: light-dark(rgba(0, 0, 0, .045), rgba(255, 255, 255, .045));--color-text: light-dark(#0a0a0a, #e0e0e0);--color-muted: light-dark(#65676b, #7c7c7c);--color-faint: light-dark(#999999, #5c5c5c);--color-line: light-dark(rgba(0, 0, 0, .09), rgba(255, 255, 255, .055));--color-line-strong: light-dark(rgba(0, 0, 0, .18), rgba(255, 255, 255, .12));--color-image-outline: light-dark(rgba(0, 0, 0, .1), rgba(255, 255, 255, .1));--color-shiki: light-dark(var(--shiki-light), var(--shiki-dark));--shadow-edge-inset: light-dark(rgba(255, 255, 255, .96), transparent);--shadow-edge-rim: light-dark(rgba(0, 0, 0, .04), rgba(255, 255, 255, .06));--shadow-edge: inset 0 0 0 1px var(--shadow-edge-inset), 0 0 0 1px var(--shadow-edge-rim);--wide-bleed: 16px}@media(min-width:640px){:root{--wide-bleed: 40px}}@media(min-width:1024px){:root{--wide-bleed: 88px}}html{-webkit-text-size-adjust:100%;color-scheme:light dark}body{font-feature-settings:"ss01","ss02","cv11";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}::-moz-selection{background:var(--color-text);color:var(--color-bg)}::selection{background:var(--color-text);color:var(--color-bg)}.post-title{margin:0;font-size:24px;font-weight:400;line-height:1.22;letter-spacing:-.015em}@media(min-width:640px){.post-title{font-size:28px}}.design-grid{display:grid;gap:22px 28px;grid-template-columns:repeat(2,minmax(0,1fr));margin:24px calc(var(--wide-bleed) * -1)}@media(max-width:720px){.design-grid{grid-template-columns:1fr}}.design-card{background:var(--color-card-bg);border-radius:.25rem;box-shadow:var(--shadow-edge);padding:18px 20px}.design-card h3{font:500 17px/1.3 ui-sans-serif,system-ui,sans-serif;letter-spacing:-.015em;margin:0 0 8px}.design-card p{color:var(--color-muted);font-size:14px;line-height:1.5;margin:0}.post-content{font-size:16px;line-height:1.5}.post-content>:first-child{margin-top:0}.post-content p{margin:0 0 16px;text-wrap:pretty}.post-content p:last-child{margin-bottom:0}.post-content strong{font-weight:550}.post-content em{font-style:italic}.post-content h1,.post-content h2,.post-content h3,.post-content h4,.post-content h5{font-weight:500}.post-content h1{font-size:24px;font-weight:400;line-height:1.22;letter-spacing:-.015em;margin:36px 0 12px}.post-content h2{font-size:21px;line-height:1.28;letter-spacing:-.01em;margin:34px 0 10px}.post-content h3{font-size:18px;line-height:1.35;letter-spacing:-.005em;margin:28px 0 8px}.post-content h4{font-size:16px;line-height:1.4;margin:24px 0 6px}.post-content h5{color:var(--color-muted);font-size:14px;line-height:1.4;letter-spacing:.01em;margin:22px 0 6px}.post-content ul,.post-content ol{margin:0 0 16px;padding-left:24px}.post-content ul{list-style:disc}.post-content ol{list-style:decimal}.post-content li{margin-bottom:6px;padding-left:2px;text-wrap:pretty}.post-content li:last-child{margin-bottom:0}.post-content li::marker{color:var(--color-faint)}.post-content ol li::marker{font-variant-numeric:tabular-nums;font-weight:500}.post-content li>ul,.post-content li>ol{margin:6px 0 0}.post-content code{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.93em;background:var(--color-code-bg);padding:1.5px 6px;border-radius:5px;word-break:break-word}.post-content :where(figure,table,.code-big pre,.table-title,.wide-bleed){margin-inline:calc(var(--wide-bleed) * -1)}.post-content pre{background:var(--color-pre-bg);border-radius:.25rem;box-shadow:var(--shadow-edge);padding:20px 22px;overflow-x:auto;margin:24px 0;font-size:11px;line-height:1.55}.post-content .code-big pre{margin-top:24px;margin-bottom:24px}@media(min-width:640px){.post-content pre,.post-content .code-big pre{margin-top:32px;margin-bottom:32px}}.post-content pre code{background:transparent!important;padding:0;border-radius:0;font-size:inherit}.post-content .astro-code span[style*=--shiki-light]{color:light-dark(var(--shiki-light),var(--shiki-dark))}.post-content a{color:inherit;text-decoration:underline;text-decoration-color:var(--color-line-strong);text-decoration-thickness:1px;text-underline-offset:3px;transition-property:text-decoration-color;transition-duration:.15s;transition-timing-function:ease}.post-content a:hover{text-decoration-color:var(--color-text)}.post-content blockquote{border-left:3px solid var(--color-line-strong);color:var(--color-muted);font-style:italic;margin:0 0 18px;padding:2px 0 2px 16px}.post-content blockquote p{margin-bottom:0}.post-content img{display:block;max-width:100%;height:auto;margin:20px auto 24px;border-radius:4px;outline:1px solid var(--color-image-outline);outline-offset:-1px}.post-content .light-image-frame{margin:20px auto 24px}.post-content .light-image-frame img,.post-content .light-image-frame .figure-image{margin:0 auto}.post-content .light-image-frame figcaption{color:var(--color-muted);font-size:14px;line-height:1.4;margin-top:8px;text-align:center;text-wrap:pretty}.post-content hr{border:0;border-top:1px solid var(--color-line);width:30%;margin:80px auto}.post-content .table-title{margin-top:32px;margin-bottom:0;padding:0 12px 10px;font-size:18px;font-weight:500;letter-spacing:-.01em;line-height:1.3}@media(min-width:640px){.post-content .table-title{margin-top:36px}}@media(min-width:1024px){.post-content .table-title{margin-top:40px}}.post-content .table-title+table{margin-top:0}.post-content table{border-collapse:collapse;width:calc(100% + var(--wide-bleed) * 2);margin-top:24px;margin-bottom:24px;font-size:13px;line-height:1.5}@media(min-width:640px){.post-content table{margin-top:32px;margin-bottom:32px}}.post-content th,.post-content td{text-align:left;padding:8px 12px;vertical-align:top;border-bottom:1px solid var(--color-line)}.post-content th{font-weight:600;color:var(--color-text);border-bottom:1px solid var(--color-line-strong)}.post-content :is(.right-toc,.block-toc-static) ol{list-style:none;margin:0;padding:0;counter-reset:toc}.post-content :is(.right-toc,.block-toc-static) li{counter-increment:toc;margin:0}.post-content :is(.right-toc,.block-toc-static) li::marker{content:""}.post-content :is(.right-toc,.block-toc-static) li:before{content:counter(toc) ". ";color:var(--color-faint);font-variant-numeric:tabular-nums}.post-content :is(.right-toc,.block-toc-static) a{color:inherit;text-decoration:none}.post-content .right-toc-title{color:var(--color-faint);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin:0 0 12px}.post-content .right-toc{position:fixed;top:96px;left:calc(50% + 480px);width:170px;font-size:13px;line-height:1.45;color:var(--color-muted);max-height:calc(100vh - 140px);overflow-y:auto}.post-content .right-toc li{padding:5px 0}.post-content .right-toc a:hover{text-decoration:underline;text-decoration-color:var(--color-line-strong);text-underline-offset:3px}@media(max-width:1280px){.post-content .right-toc{display:none}}.post-content .block-toc-static{border-left:1px solid var(--color-line);margin:32px auto;padding:4px 0 4px 20px;width:220px}.post-content .block-toc-static ol{color:var(--color-muted);font-size:13px;line-height:1.45}.post-content .block-toc-static li{padding:4px 0}.post-content .block-toc-static li:before{transition:transform .18s ease}.post-content .block-toc-static a{--hover-shift: 0;display:inline-flex;position:relative;transition:color .18s ease,transform .18s ease;transform:translate(var(--hover-shift))}.post-content .block-toc-static a:after{background:linear-gradient(90deg,var(--color-line-strong),transparent);border-radius:999px;bottom:-1px;content:"";height:1px;left:0;position:absolute;transform-origin:left;transition:width .18s ease,opacity .18s ease;width:0;opacity:0}.post-content .block-toc-static a:hover,.post-content .block-toc-static a:focus-visible{--hover-shift: 4px;color:var(--color-text)}.post-content .block-toc-static a:hover:after,.post-content .block-toc-static a:focus-visible:after{width:100%;opacity:1}.post-content .block-toc-static li:hover{color:var(--color-text)}.post-content .block-toc-static li:hover:before{color:var(--color-line-strong);transform:translate(2px)}.post-content figure{margin-top:24px;margin-bottom:24px}@media(min-width:640px){.post-content figure{margin-top:32px;margin-bottom:32px}}.post-content figure img{display:block;width:100%;margin:0;border-radius:4px}.post-content figure .figure-image{height:280px;border-radius:.25rem;display:flex;align-items:center;justify-content:center;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--color-faint);background:var(--color-surface);box-shadow:var(--shadow-edge),0 1px 3px #0000000f,0 1px 2px -1px #0000000f}.post-content figure figcaption{font-size:14px;line-height:1.5;color:var(--color-muted);margin:12px auto 0;max-width:44rem;text-align:center;text-wrap:pretty}@media(max-width:720px){.post-content figure{margin-inline:0}.post-content figure .figure-image{height:200px}}.relative{position:relative}.sticky{position:sticky}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.my-3{margin-top:.75rem;margin-bottom:.75rem}.mb-2{margin-bottom:.5rem}.mb-8{margin-bottom:2rem}.mr-1\.5{margin-right:.375rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.table{display:table}.w-full{width:100%}.max-w-post{max-width:720px}.max-w-shell{max-width:896px}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.list-none{list-style-type:none}.flex-col{flex-direction:column}.items-center{align-items:center}.gap-3{gap:.75rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.text-pretty{text-wrap:pretty}.border{border-width:1px}.border-t{border-top-width:1px}.border-line{border-color:var(--color-line)}.bg-bg{background-color:var(--color-bg)}.p-0{padding:0}.px-0{padding-left:0;padding-right:0}.px-4{padding-left:1rem;padding-right:1rem}.py-0{padding-top:0;padding-bottom:0}.py-20{padding-top:5rem;padding-bottom:5rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-\[18px\]{padding-top:18px;padding-bottom:18px}.font-mono{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace}.font-sans{font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI Variable,Segoe UI,Helvetica Neue,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji"}.text-\[0\.95em\]{font-size:.95em}.text-\[11px\]{font-size:11px}.text-\[15px\]{font-size:15px}.text-\[16px\]{font-size:16px}.font-light{font-weight:300}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-\[1\.55\]{line-height:1.55}.leading-\[1\.5\]{line-height:1.5}.tracking-\[-0\.01em\]{letter-spacing:-.01em}.tracking-\[0\.04em\]{letter-spacing:.04em}.text-faint{color:var(--color-faint)}.text-muted{color:var(--color-muted)}.text-text{color:var(--color-text)}.underline{text-decoration-line:underline}.no-underline{text-decoration-line:none}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.outline{outline-style:solid}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}@media print{body{font-size:11pt}article{padding:0!important;max-width:none!important}.post-content h2,.post-content h3{page-break-after:avoid}}.before\:absolute:before{content:var(--tw-content);position:absolute}.before\:left-1\/2:before{content:var(--tw-content);left:50%}.before\:top-0:before{content:var(--tw-content);top:0}.before\:h-px:before{content:var(--tw-content);height:1px}.before\:w-\[30\%\]:before{content:var(--tw-content);width:30%}.before\:-translate-x-1\/2:before{content:var(--tw-content);--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.before\:bg-line:before{content:var(--tw-content);background-color:var(--color-line)}.first\:pt-0:first-child{padding-top:0}.first\:before\:hidden:first-child:before{content:var(--tw-content);display:none}.last\:pb-0:last-child{padding-bottom:0}.hover\:text-text:hover{color:var(--color-text)}.hover\:underline:hover{text-decoration-line:underline}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.group:focus-visible .group-focus-visible\:underline{text-decoration-line:underline}@media(min-width:640px){.sm\:px-10{padding-left:2.5rem;padding-right:2.5rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:py-10{padding-top:2.5rem;padding-bottom:2.5rem}.sm\:text-\[17px\]{font-size:17px}}.\[\&\>\*\:last-child\]\:border-b>*:last-child{border-bottom-width:1px}.\[\&\>\*\:last-child\]\:border-line>*:last-child{border-color:var(--color-line)}.\[\&_p\:last-child\]\:mb-0 p:last-child{margin-bottom:0}.\[\&_p\]\:m-0 p{margin:0}
