*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e4e4e7}: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:DM Sans,ui-sans-serif,system-ui,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:DM Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,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:#a1a1aa}input::placeholder,textarea::placeholder{opacity:1;color:#a1a1aa}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]{display:none}*,: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: }.visible{visibility:visible!important}.static{position:static!important}.fixed{position:fixed!important}.absolute{position:absolute!important}.relative{position:relative!important}.sticky{position:sticky!important}.z-20{z-index:20!important}.my-6{margin-top:1.5rem!important;margin-bottom:1.5rem!important}.mt-20{margin-top:5rem!important}.block{display:block!important}.inline{display:inline!important}.flex{display:flex!important}.table{display:table!important}.grid{display:grid!important}.hidden{display:none!important}.size-5{width:1.25rem!important;height:1.25rem!important}.h-full{height:100%!important}.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))!important}.flex-col{flex-direction:column!important}.flex-wrap{flex-wrap:wrap!important}.items-center{align-items:center!important}.justify-start{justify-content:flex-start!important}.justify-between{justify-content:space-between!important}.gap-4{gap:1rem!important}.self-center{align-self:center!important}.text-wrap{text-wrap:wrap!important}.rounded-sm{border-radius:.125rem!important}.border{border-width:1px!important}.bg-green{--tw-bg-opacity: 1 !important;background-color:rgb(41 177 165 / var(--tw-bg-opacity))!important}.bg-contain{background-size:contain!important}.bg-cover{background-size:cover!important}.bg-center{background-position:center!important}.bg-top{background-position:top!important}.px-4{padding-left:1rem!important;padding-right:1rem!important}.py-6{padding-top:1.5rem!important;padding-bottom:1.5rem!important}.text-sm{font-size:.9375rem!important}.font-bold{font-weight:700!important}.uppercase{text-transform:uppercase!important}.italic{font-style:italic!important}.text-blue{--tw-text-opacity: 1 !important;color:rgb(57 172 201 / var(--tw-text-opacity))!important}.text-red{--tw-text-opacity: 1 !important;color:rgb(211 60 87 / var(--tw-text-opacity))!important}.underline{text-decoration-line:underline!important}.antialiased{-webkit-font-smoothing:antialiased!important;-moz-osx-font-smoothing:grayscale!important}.outline{outline-style:solid!important}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color) !important;--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color) !important;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)!important}.grayscale{--tw-grayscale: grayscale(100%) !important;filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)!important}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)!important}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important;transition-duration:.15s!important}body{--color-black: #16191C;--color-white: #fff;--color-blue: #39ACC9;--color-blue-rgb: 57, 172, 201;--color-orange: #DA6324;--color-orange-rgb: 218, 99, 36;--color-red: #d33c57;--color-red-rgb: 211, 60, 87;--color-yellow: #EFA916;--color-yellow-rgb: 239, 169, 22;--color-green: #29B1A5;--color-green-rgb: 41, 177, 165;--color-avid: #ff8a3d;--color-avid-rgb: 255, 138, 61;--color-gray: #a1a1aa;--theme-text-color: #fff;--theme-text-color-rgb: 255, 255, 255;--theme-text-fade-color: #718096;--theme-text-fade-color-rgb: 113, 128, 150;--theme-text-fade-color: #91A1B7;--theme-text-fade-color-rgb: 132, 145, 164;--theme-background-color: #1a202c;--theme-background-color-rgb: 26, 32, 44;--theme-nav-background: rgba(0,0,0,.2);--theme-nav-border: rgba(0,0,0,.05);--theme-extreme-color: #000;--theme-extreme-color-rgb: 0,0,0;--theme-extreme-contrast: #fff;--theme-extreme-contrast-rgb: 255,255,255;--theme-subtle-border: rgba(var(--theme-extreme-contrast-rgb),.15);--accent-color: var(--color-blue);--accent-color-rgb: var(--color-blue);--theme-footer-border-alpha: .05;--theme-article-link-color: #c8d0db;--icon-arrow-svg: url("data:image/svg+xml,%3Csvg width='23' height='19' viewBox='0 0 23 19' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M15.2151 10.95L7.70129 18.24H13.0613L22.4213 9.12L13.0613 0H7.70129L15.3182 7.39001H0V10.95H15.2151Z' fill='%23FFFFFF'/%3E%3C/svg%3E%0A");--padding-horiz: 32px;--color-about: var(--color-blue);--color-about-rgb: var(--color-blue-rgb);--color-blog: var(--color-yellow);--color-blog-rgb: var(--color-yellow-rgb);--color-projects: var(--color-red);--color-projects-rgb: var(--color-red-rgb);--color-uses: var(--color-green);--color-uses-rgb: var(--color-green-rgb);--color-contact: var(--color-orange);--color-contact-rgb: var(--color-orange-rgb);--color-avid: var(--color-orange);--color-avid-rgb: var(--color-orange-rgb);--paragraph-line-height: 1.777777778em}@media (min-width: 640px){body{--padding-horiz: 48px}}@media (min-height: 970px) and (min-width: 768px){body{max-height:none}}@media (prefers-color-scheme: light){body{--theme-text-fade-color: #4E6976;--theme-text-fade-color-rgb: 78, 105, 118;--theme-text-color: #0A2D3E;--theme-text-color-rgb: 10, 45, 62;--theme-background-color: #edf4f7;--theme-background-color-rgb: 237, 244, 247;--theme-extreme-color: #fff;--theme-extreme-color-rgb: 255,255,255;--theme-extreme-contrast: #000;--theme-extreme-contrast-rgb: 0,0,0;--theme-subtle-border: rgba(var(--theme-extreme-contrast-rgb),.05);--theme-article-link-color: #4a6470 !important;--theme-nav-background: rgba(255,255,255,.5);--theme-nav-border: rgba(0,0,0,.07);--theme-footer-border-alpha: .07}}body.theme-light{--theme-text-fade-color: #4E6976 !important;--theme-text-fade-color-rgb: 78, 105, 118 !important;--theme-text-color: #0A2D3E !important;--theme-text-color-rgb: 10, 45, 62 !important;--theme-background-color: #edf4f7 !important;--theme-background-color-rgb: 237, 244, 247 !important;--theme-extreme-color: #fff !important;--theme-extreme-color-rgb: 0,0,0 !important;--theme-extreme-contrast: #000 !important;--theme-extreme-contrast-rgb: 0,0,0 !important;--theme-subtle-border: rgba(var(--theme-extreme-contrast-rgb),.05) !important;--theme-article-link-color: #4a6470 !important;--theme-nav-background: rgba(255,255,255,.5) !important;--theme-nav-border: rgba(0,0,0,.07) !important;--theme-footer-border-alpha: .07 !important}html.theme-light body{--theme-text-fade-color: #4E6976 !important;--theme-text-fade-color-rgb: 78, 105, 118 !important;--theme-text-color: #0A2D3E !important;--theme-text-color-rgb: 10, 45, 62 !important;--theme-background-color: #edf4f7 !important;--theme-background-color-rgb: 237, 244, 247 !important;--theme-extreme-color: #fff !important;--theme-extreme-color-rgb: 255, 255, 255 !important;--theme-extreme-contrast: #000 !important;--theme-extreme-contrast-rgb: 0, 0, 0 !important;--theme-subtle-border: rgba(var(--theme-extreme-contrast-rgb), .05) !important;--theme-article-link-color: #4a6470 !important;--theme-nav-background: rgba(255, 255, 255, .5) !important;--theme-nav-border: rgba(0, 0, 0, .07) !important;--theme-footer-border-alpha: .07 !important}html.theme-dark body{--theme-text-color: #fff !important;--theme-text-color-rgb: 255, 255, 255 !important;--theme-text-fade-color: #91A1B7 !important;--theme-text-fade-color-rgb: 132, 145, 164 !important;--theme-background-color: #1a202c !important;--theme-background-color-rgb: 26, 32, 44 !important;--theme-nav-background: rgba(0, 0, 0, .2) !important;--theme-nav-border: rgba(0, 0, 0, .05) !important;--theme-extreme-color: #000 !important;--theme-extreme-color-rgb: 0, 0, 0 !important;--theme-extreme-contrast: #fff !important;--theme-extreme-contrast-rgb: 255, 255, 255 !important;--theme-subtle-border: rgba(var(--theme-extreme-contrast-rgb), .15) !important;--theme-article-link-color: #c8d0db !important;--theme-footer-border-alpha: .05 !important}body{background:var(--theme-background-color);color:var(--theme-text-color);font-family:DM Sans,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:300;display:flex;min-height:100vh;flex-direction:column;align-items:stretch;justify-content:flex-start}.page-content{width:100%;flex:1 1 auto;padding-bottom:8rem}p{font-size:1.125rem;color:var(--theme-text-fade-color);line-height:var(--paragraph-line-height, 1.777777778em)}p strong{font-weight:700;color:var(--theme-text-color)}a.has-arrow:not(.no-hover):after,button.has-arrow:not(.no-hover):after{content:"";display:inline-block;width:1em;height:1em;margin-left:.5em;transition:transform var(--hover-duration, .2s) var(--hover-function, ease-in-out),color var(--hover-duration, .2s) var(--hover-function, ease-in-out);background:var(--accent-color);mask:var(--icon-arrow-svg) center center no-repeat;-webkit-mask:var(--icon-arrow-svg) center center no-repeat;mask-size:contain;-webkit-mask-size:contain}a.has-arrow:not(.no-hover):hover:after,button.has-arrow:not(.no-hover):hover:after{transform:translate(.25em)}.accent-about{--accent-color: var(--color-about);--accent-color-rgb: var(--color-about-rgb)}.accent-blog{--accent-color: var(--color-blog);--accent-color-rgb: var(--color-blog-rgb)}.accent-uses{--accent-color: var(--color-uses);--accent-color-rgb: var(--color-uses-rgb)}.accent-projects{--accent-color: var(--color-projects);--accent-color-rgb: var(--color-projects-rgb)}.accent-contact{--accent-color: var(--color-contact);--accent-color-rgb: var(--color-contact-rgb)}.accent-avid{--accent-color: var(--color-avid);--accent-color-rgb: var(--color-avid-rgb)}.accent-blue{--accent-color: var(--color-blue);--accent-color-rgb: var(--color-blue-rgb)}.accent-yellow{--accent-color: var(--color-yellow);--accent-color-rgb: var(--color-yellow-rgb)}.accent-red{--accent-color: var(--color-red);--accent-color-rgb: var(--color-red-rgb)}.accent-green{--accent-color: var(--color-green);--accent-color-rgb: var(--color-green-rgb)}.accent-orange{--accent-color: var(--color-orange);--accent-color-rgb: var(--color-orange-rgb)}.content-longform{margin-left:auto;margin-right:auto;width:100%;padding-left:var(--padding-horiz);padding-right:var(--padding-horiz);max-width:calc(var(--padding-horiz) * 2 + 800px);--longform-section-gap: 3.5rem;--longform-content-gap: 2rem;--longform-gap-diff: 1.5rem;--longform-active-gap: var(--longform-section-gap);--longform-elements-margin: var(--longform-content-gap) 0;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:var(--longform-active-gap)}.content-longform h1,.content-longform h2{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:2.25rem}.content-longform h1 strong,.content-longform h2 strong{color:var(--accent-color)}.content-longform h3{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:1.75rem}.content-longform h3 strong{color:var(--accent-color)}.content-longform h4{font-size:1.25rem;font-weight:700}.content-longform h5{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:0em;line-height:1.1964285714em;font-size:1.25rem}.content-longform h5 strong{color:var(--accent-color)}.content-longform h6{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:0em;line-height:1.1964285714em;font-size:.9375rem;text-transform:uppercase}.content-longform h6 strong{color:var(--accent-color)}.content-longform p{font-size:1.125rem;color:var(--theme-text-fade-color);line-height:var(--paragraph-line-height, 1.777777778em)}.content-longform p strong{font-weight:700;color:var(--theme-text-color)}.content-longform p a,.content-longform li a,.content-longform li p a{font-weight:600;transition:color .2s ease;color:var(--theme-article-link-color)}.content-longform p a:hover,.content-longform li a:hover,.content-longform li p a:hover{color:var(--accent-color)}.content-longform p a strong,.content-longform li a strong,.content-longform li p a strong{color:inherit}.content-longform p+h2,.content-longform p+h3,.content-longform ul+h2,.content-longform ul+h3,.content-longform ol+h2,.content-longform ol+h3,.content-longform blockquote+h2,.content-longform blockquote+h3,.content-longform figure.quote+h2,.content-longform figure.quote+h3{margin-top:var(--longform-section-gap)}.content-longform h2+p,.content-longform h3+p,.content-longform h4+p,.content-longform h5+p,.content-longform h6+p{margin-top:-.75rem}.content-longform h2+.item-horiz,.content-longform h3+.item-horiz,.content-longform h4+.item-horiz,.content-longform h5+.item-horiz,.content-longform h6+.item-horiz{margin-top:calc(-1 * (var(--longform-active-gap) - 36px))}.content-longform figure.quote,.content-longform blockquote:not(figure.quote blockquote){border-left-width:2px;border-color:var(--accent-color);padding-left:1.25rem}.content-longform blockquote{font-style:italic}.content-longform figure.quote figcaption{margin-top:.25rem;font-size:1.125rem;font-weight:700}.content-longform ul:not(.pills-list),.content-longform ol:not(.pills-list){display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:.75rem}.content-longform ul:not(.pills-list) li,.content-longform ol:not(.pills-list) li{font-size:1.125rem;color:var(--theme-text-fade-color);line-height:var(--paragraph-line-height, 1.777777778em);position:relative;padding-left:2.25rem}.content-longform ul:not(.pills-list) li strong,.content-longform ol:not(.pills-list) li strong{font-weight:700;color:var(--theme-text-color)}.content-longform ul:not(.pills-list) li:before{content:"";position:absolute;top:.75rem;left:.625rem;height:.5rem;width:.5rem;background-color:var(--accent-color);border-radius:2px;transform:rotate(45deg)}.content-longform ol:not(.pills-list){list-style:none;counter-reset:cabeeb}.content-longform ol:not(.pills-list) li{counter-increment:cabeeb}.content-longform ol:not(.pills-list) li:before{content:counter(cabeeb);position:absolute;top:0;left:.625rem;font-weight:700;color:var(--accent-color)}.content-longform .content-section{--longform-active-gap: var(--longform-content-gap)}.content-longform .content-section>p{margin:var(--longform-elements-margin)}.content-longform .content-section>p:last-child{margin-bottom:0}.content-longform .content-section h2+p,.content-longform .content-section h3+p,.content-longform .content-section h4+p,.content-longform .content-section h5+p,.content-longform .content-section h6+p{margin-top:1rem}.content-longform.content-uses h2{margin-bottom:1rem}.content-longform.content-uses h4{display:flex;align-items:center;justify-content:flex-start;align-self:flex-start;line-height:2rem}.content-longform.content-uses h4 a{color:var(--theme-text-color)}.content-longform.content-uses h4 a:not(.no-icon){position:relative;padding-right:1.75rem}.content-longform.content-uses h4 a:not(.no-icon):after{position:absolute;right:0;top:50%;margin-top:-.75rem;display:block;height:1.5rem;width:1.25rem;background-color:var(--theme-text-fade-color);opacity:.5;transition:background .2s ease,opacity .2s ease;--icon-url: var(--icon-popout-sm);mask:var(--icon-url) center center no-repeat;-webkit-mask:var(--icon-url) center center no-repeat;mask-size:contain;-webkit-mask-size:contain;content:""}.content-longform.content-uses h4 a:not(.no-icon):hover:after{--tw-scale-x: 1;--tw-scale-y: 1;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));background-color:var(--accent-color);opacity:1}.content-longform.content-uses h4 a span[class^=icon-]{display:inline-block;height:2rem;width:1rem;background-color:var(--theme-text-fade-color);color:transparent;text-indent:-1000px;mask:var(--icon-url) center center no-repeat;-webkit-mask:var(--icon-url) center center no-repeat;mask-size:contain;-webkit-mask-size:contain}.content-longform.content-uses h4+p{margin-top:0}.content-longform.content-uses h6.sub-heading{margin-top:2rem;font-size:.6875rem;line-height:.75rem;color:var(--accent-color)}.content-longform.content-uses h6.sub-heading+h4{margin-top:-3px}.content-longform.content-uses ul{gap:1.25rem}.content-longform.content-uses li h6.sub-heading{margin-top:0}.content-longform.content-uses li h6.sub-heading+h4{margin-top:0}.content-longform.content-uses li h4{color:var(--theme-text-color)}.content-longform.content-uses li:has(h6.sub-heading:first-child):before{top:1.5rem}.content-longform.content-uses p+ul{margin-top:-.5rem}.content-longform.content-uses ul.sub-uses h4{font-size:1.125rem}.content-longform.content-uses ul.sub-uses h4+ul{margin-top:.375rem}.content-longform.content-uses ul.sub-uses h4+p{margin-top:0}.content-longform.content-uses ul.sub-uses li,.content-longform.content-uses ul.sub-uses p{font-size:.9375rem}.content-longform.content-uses ul.sub-uses ul{gap:.75rem}.content-longform.content-uses ul.sub-uses ul li,.content-longform.content-uses ul.sub-uses ul li a,.content-longform.content-uses ul.sub-uses ul li p{line-height:20px}.content-longform.content-uses ul.sub-uses ul li{padding-left:1.5rem}.content-longform.content-uses ul.sub-uses ul li:before{left:.25rem;top:7px;width:6px;height:6px;transform:rotate(45deg);border-radius:1px}.content-longform.content-uses ul.sub-uses ul a{color:var(--theme-text-fade-color)}.content-longform.content-uses ul.sub-uses ul a:not(.no-icon){position:relative;padding-right:1.75rem}.content-longform.content-uses ul.sub-uses ul a:not(.no-icon):after{position:absolute;right:0;top:50%;margin-top:-.625rem;display:block;height:1.25rem;width:1rem;background-color:var(--theme-text-fade-color);opacity:.5;transition:background .2s ease,opacity .2s ease;--icon-url: var(--icon-popout-sm);mask:var(--icon-url) center center no-repeat;-webkit-mask:var(--icon-url) center center no-repeat;mask-size:contain;-webkit-mask-size:contain;content:""}.content-longform.content-uses ul.sub-uses ul a:not(.no-icon):hover:after{--tw-scale-x: 1;--tw-scale-y: 1;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));background-color:var(--accent-color);opacity:1}.content-longform+footer{margin-top:60px}.content-longform .shiki{margin-left:-1.5rem;margin-right:-1.5rem;overflow-x:scroll;border-radius:.5rem;padding:1rem 1.5rem;margin-top:var(--longform-content-gap);margin-bottom:var(--longform-content-gap)}.content-longform code,.content-longform kbd,.content-longform samp,.content-longform pre{font-weight:400}.content-longform p code,.content-longform p kbd,.content-longform p samp,.content-longform p pre{border-radius:.25rem;padding-left:.25rem;padding-right:.25rem;font-weight:400;font-size:.9444444444em;background:#24273a;color:#cad3f5}@media (prefers-color-scheme: light){.content-longform p code,.content-longform p kbd,.content-longform p samp,.content-longform p pre{color:#24273a;background:#24273a0d}}.reading-progress{position:fixed;top:0;left:0;width:100%;height:3px;z-index:1001;background:var(--accent-color);transform:scaleX(0);transform-origin:left center;animation:reading-progress linear;animation-timeline:scroll(root block)}@keyframes reading-progress{to{transform:scaleX(1)}}.article-image{--article-image-footprint: 310px;--article-image-width: 440px;--article-image-offset-margin: calc(var(--article-image-footprint) - var(--article-image-width));overflow:hidden;border-radius:.5rem}.article-image.article-image-align-right{float:right;margin-left:1.5rem;margin-bottom:.5rem;margin-top:2.25rem;width:var(--article-image-width);margin-right:var(--article-image-offset-margin)}.article-image.article-image-align-left{float:left;margin-right:1.5rem;margin-bottom:.5rem;margin-top:2.25rem;width:var(--article-image-width);margin-left:var(--article-image-offset-margin)}.article-image.article-image-align-full.article-image-overflow{--overflow-margin: 4rem;width:calc(100% + var(--overflow-margin) + var(--overflow-margin));margin-left:calc(-1 * var(--overflow-margin));margin-right:calc(-1 * var(--overflow-margin))}.article-image[data-gallery-image]{cursor:zoom-in;transition:transform .2s ease}.article-image[data-gallery-image]:hover{transform:scale(1.02)}@media screen and (max-width: 1108px) and (min-width: 896px){.article-image{--article-image-width: calc(440px - ((1108px - 100dvw)/2)) }}@media screen and (max-width: 895px) and (min-width: 641px){.article-image{--article-image-width: 334px;--article-image-offset-margin: -24px}}@media screen and (max-width: 640px){.article-image{--article-image-width: 100%;float:none}.article-image.article-image-align-right,.article-image.article-image-align-left{float:none;margin-left:0;margin-right:0}}p+.article-image.article-image-align-left{margin-top:.25rem}p+.article-image.article-image-align-right{margin-top:0}.article-gallery{display:grid;gap:.75rem;--gallery-margin: -130px;margin-left:var(--gallery-margin);margin-right:var(--gallery-margin)}@media screen and (min-width: 761px){.article-gallery:has(>:last-child:nth-child(2)){grid-template-columns:repeat(2,minmax(0,1fr))}.article-gallery .max-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.article-gallery:has(>:last-child:nth-child(3)){grid-template-columns:repeat(3,minmax(0,1fr))}.article-gallery .max-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.article-gallery:has(>:last-child:nth-child(4)){grid-template-columns:repeat(4,minmax(0,1fr))}.article-gallery .max-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.article-gallery:has(>:last-child:nth-child(5)){grid-template-columns:repeat(5,minmax(0,1fr))}.article-gallery .max-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.article-gallery:has(>:last-child:nth-child(6)){grid-template-columns:repeat(6,minmax(0,1fr))}.article-gallery .max-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}}.article-gallery .article-gallery-image{overflow:hidden;border-radius:.25rem}.article-gallery .article-gallery-image[data-gallery-image]{cursor:zoom-in;transition:transform .2s ease}.article-gallery .article-gallery-image[data-gallery-image]:hover{transform:scale(1.02)}@media screen and (max-width: 1108px) and (min-width: 896px){.article-gallery{--gallery-margin: calc(-1*(130px - ((1108px - 100dvw)/2))) }}@media screen and (max-width: 895px) and (min-width: 761px){.article-gallery{--gallery-margin: -24px}}@media screen and (max-width: 760px){.article-gallery{grid-template-columns:repeat(1,minmax(0,1fr));--gallery-margin: 0;gap:24px}}.meta-container{margin-left:-1rem;margin-right:-1rem;border-radius:1rem;border-width:1px;border-style:solid;border-color:var(--accent-color);padding-left:1rem;padding-right:1rem;padding-bottom:1.25rem;position:relative;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:.5rem;--meta-margin-bottom: -32px;--meta-padding-horiz: calc(var(--padding-horiz) - 10px);margin:0 calc(var(--meta-padding-horiz) * -1) var(--meta-margin-bottom) calc(var(--meta-padding-horiz) * -1);padding-left:var(--meta-padding-horiz);padding-right:var(--meta-padding-horiz);--meta-padding-top: 1.5rem;padding-top:var(--meta-padding-top);--meta-padding-bottom: 1.25rem;padding-bottom:var(--meta-padding-bottom)}.meta-container .meta-title h4{color:var(--accent-color)}.meta-container .meta-content{display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;gap:1.25rem}.meta-container .meta-content-col{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:.5rem}.meta-container h3{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:2.25rem}.meta-container h3 strong{color:var(--accent-color)}.meta-container p{margin-top:.25rem;font-size:1.125rem;line-height:1.5;color:var(--theme-extreme-contrast)}.meta-container .meta-title{position:absolute;padding-left:.25rem;padding-right:.25rem;color:var(--theme-text-color);display:flex;align-items:center;justify-content:flex-start;background-color:var(--theme-background-color);height:5px;top:-3px;left:24px;left:calc(var(--meta-padding-horiz) - .25rem)}.meta-container .meta-title h4{font-size:1.125rem}.meta-container .meta-date{color:var(--accent-color)}.meta-container .meta-lib{display:flex;align-items:center;justify-content:flex-start;gap:.5rem}.meta-container .meta-lib dt{height:1.5rem;width:1.5rem;flex:none;font-size:0;color:transparent;background-image:var(--logo-url);background-size:contain;background-repeat:no-repeat;background-position:center center}.meta-container .meta-lib dd{font-size:.9375rem;font-weight:700;line-height:1.375;color:var(--theme-text-fade-color)}.meta-container .meta-lib-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;-moz-column-gap:1.5rem;column-gap:1.5rem;row-gap:.25rem;order:-9999}.meta-container .meta-lib-row .meta-date{margin-bottom:.125rem;width:100%;flex:none}@media (min-width: 640px){.meta-container{border-right-width:1px;border-left-width:1px;margin-left:-2rem;margin-right:-2rem;padding-left:2rem;padding-right:2rem;--meta-padding-top: 1.5rem;--meta-padding-bottom: 1.5rem;--meta-padding-horiz: var(--padding-horiz)}.meta-container .meta-title{padding-left:.5rem;padding-right:.5rem;left:24px}.meta-container p{margin-top:0}.meta-container:has(.meta-title h3){--meta-padding-top: 1.75rem}}@media screen and (min-width: 860px){.meta-container .meta-content{flex:none;flex-direction:row;align-items:center;gap:1.5rem}.meta-container .meta-content-col{width:61.8%}.meta-container .meta-lib-row{order:0;margin-bottom:-.25rem}.meta-container .meta-tags{margin-top:.25rem;flex:none;max-width:38.2%}}body{--logo-tailwind: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 54 33'%3E%3Cg clip-path='url(%23prefix__clip0)'%3E%3Cpath fill='%2338bdf8' fill-rule='evenodd' d='M27 0c-7.2 0-11.7 3.6-13.5 10.8 2.7-3.6 5.85-4.95 9.45-4.05 2.054.513 3.522 2.004 5.147 3.653C30.744 13.09 33.808 16.2 40.5 16.2c7.2 0 11.7-3.6 13.5-10.8-2.7 3.6-5.85 4.95-9.45 4.05-2.054-.513-3.522-2.004-5.147-3.653C36.756 3.11 33.692 0 27 0zM13.5 16.2C6.3 16.2 1.8 19.8 0 27c2.7-3.6 5.85-4.95 9.45-4.05 2.054.514 3.522 2.004 5.147 3.653C17.244 29.29 20.308 32.4 27 32.4c7.2 0 11.7-3.6 13.5-10.8-2.7 3.6-5.85 4.95-9.45 4.05-2.054-.513-3.522-2.004-5.147-3.653C23.256 19.31 20.192 16.2 13.5 16.2z' clip-rule='evenodd'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='prefix__clip0'%3E%3Cpath fill='%23fff' d='M0 0h54v32.4H0z'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");--logo-laravel: url("data:image/svg+xml,%3Csvg width='50' height='52' viewBox='0 0 50 52' xmlns='http://www.w3.org/2000/svg'%3E%3Ctitle%3ELogomark%3C/title%3E%3Cpath d='M49.626 11.564a.809.809 0 0 1 .028.209v10.972a.8.8 0 0 1-.402.694l-9.209 5.302V39.25c0 .286-.152.55-.4.694L20.42 51.01c-.044.025-.092.041-.14.058-.018.006-.035.017-.054.022a.805.805 0 0 1-.41 0c-.022-.006-.042-.018-.063-.026-.044-.016-.09-.03-.132-.054L.402 39.944A.801.801 0 0 1 0 39.25V6.334c0-.072.01-.142.028-.21.006-.023.02-.044.028-.067.015-.042.029-.085.051-.124.015-.026.037-.047.055-.071.023-.032.044-.065.071-.093.023-.023.053-.04.079-.06.029-.024.055-.05.088-.069h.001l9.61-5.533a.802.802 0 0 1 .8 0l9.61 5.533h.002c.032.02.059.045.088.068.026.02.055.038.078.06.028.029.048.062.072.094.017.024.04.045.054.071.023.04.036.082.052.124.008.023.022.044.028.068a.809.809 0 0 1 .028.209v20.559l8.008-4.611v-10.51c0-.07.01-.141.028-.208.007-.024.02-.045.028-.068.016-.042.03-.085.052-.124.015-.026.037-.047.054-.071.024-.032.044-.065.072-.093.023-.023.052-.04.078-.06.03-.024.056-.05.088-.069h.001l9.611-5.533a.801.801 0 0 1 .8 0l9.61 5.533c.034.02.06.045.09.068.025.02.054.038.077.06.028.029.048.062.072.094.018.024.04.045.054.071.023.039.036.082.052.124.009.023.022.044.028.068zm-1.574 10.718v-9.124l-3.363 1.936-4.646 2.675v9.124l8.01-4.611zm-9.61 16.505v-9.13l-4.57 2.61-13.05 7.448v9.216l17.62-10.144zM1.602 7.719v31.068L19.22 48.93v-9.214l-9.204-5.209-.003-.002-.004-.002c-.031-.018-.057-.044-.086-.066-.025-.02-.054-.036-.076-.058l-.002-.003c-.026-.025-.044-.056-.066-.084-.02-.027-.044-.05-.06-.078l-.001-.003c-.018-.03-.029-.066-.042-.1-.013-.03-.03-.058-.038-.09v-.001c-.01-.038-.012-.078-.016-.117-.004-.03-.012-.06-.012-.09v-.002-21.481L4.965 9.654 1.602 7.72zm8.81-5.994L2.405 6.334l8.005 4.609 8.006-4.61-8.006-4.608zm4.164 28.764l4.645-2.674V7.719l-3.363 1.936-4.646 2.675v20.096l3.364-1.937zM39.243 7.164l-8.006 4.609 8.006 4.609 8.005-4.61-8.005-4.608zm-.801 10.605l-4.646-2.675-3.363-1.936v9.124l4.645 2.674 3.364 1.937v-9.124zM20.02 38.33l11.743-6.704 5.87-3.35-8-4.606-9.211 5.303-8.395 4.833 7.993 4.524z' fill='%23FF2D20' fill-rule='evenodd'/%3E%3C/svg%3E");--logo-sass: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='547.827' height='547.827'%3E%3Cpath d='M2054.36 4108.71c1134.59 0 2054.35-919.77 2054.35-2054.36C4108.71 919.762 3188.95 0 2054.36 0S0 919.762 0 2054.35c0 1134.59 919.77 2054.36 2054.36 2054.36' style='fill:%23cc499c;fill-opacity:1;fill-rule:evenodd;stroke:none' transform='matrix(.13333 0 0 -.13333 0 547.827)'/%3E%3Cpath d='M1646.09 1370.04c29.89-110.56 26.61-213.66-4.26-307.03a505.963 505.963 0 0 0-11.31-30.77c-4.1-10.12-8.54-20.13-13.3-30.01-23.81-49.402-55.76-95.64-94.89-138.32-119.36-130.219-286.13-179.461-357.64-137.969-77.22 44.758-38.54 228.36 99.85 374.639 148.88 157.39 363.09 258.58 363.09 258.58l-.33.64c6.17 3.32 12.44 6.74 18.79 10.24zm1696.9 1859.38c-93.03 364.86-698.01 484.8-1270.59 281.38-340.75-121.05-709.64-311.05-974.88-559.15-315.368-294.98-365.661-551.72-344.93-659 73.117-378.54 591.79-625.97 805.01-809.55v-1.11c-62.87-30.95-523.04-263.83-630.729-501.912C813.242 728.91 944.957 548.672 1032.16 524.41c270.19-75.172 547.45 60.039 696.45 282.289 143.79 214.481 131.82 491.441 69.33 629.211 86.2 22.74 186.69 32.93 314.4 18.01 360.37-42.09 431.08-267.11 417.56-361.26-13.51-94.18-89.1-145.961-114.37-161.59-25.28-15.64-32.99-21.05-30.86-32.672 3.06-16.898 14.76-16.269 36.31-12.617 29.66 5 189.23 76.598 196.05 250.429 8.69 220.7-202.81 467.58-577.3 461.13-154.23-2.66-251.21-17.33-321.26-43.4-5.18 5.9-10.45 11.77-15.9 17.58-231.52 247.01-659.51 421.74-641.36 753.81 6.6 120.72 48.56 438.61 822.39 824.21 633.9 315.86 1141.36 228.94 1229.06 36.3 125.27-275.21-271.21-786.73-929.52-860.51-250.81-28.12-382.87 69.09-415.72 105.29-34.59 38.11-39.74 39.83-52.65 32.68-21.04-11.65-7.71-45.3 0-65.36 19.65-51.15 100.31-141.86 237.82-186.98 120.96-39.7 415.44-61.51 771.57 76.24 398.85 154.29 710.31 583.47 618.83 942.22' style='fill:%23fff;fill-opacity:1;fill-rule:nonzero;stroke:none' transform='matrix(.13333 0 0 -.13333 0 547.827)'/%3E%3C/svg%3E");--logo-github: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath d='M12 0C5.374 0 0 5.373 0 12c0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931 0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176 0 0 1.008-.322 3.301 1.23A11.509 11.509 0 0 1 12 5.803c1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221 0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576C20.566 21.797 24 17.3 24 12c0-6.627-5.373-12-12-12z'/%3E%3C/svg%3E");--logo-twitter: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath d='M24 4.557a9.83 9.83 0 0 1-2.828.775 4.932 4.932 0 0 0 2.165-2.724 9.864 9.864 0 0 1-3.127 1.195 4.916 4.916 0 0 0-3.594-1.555c-3.179 0-5.515 2.966-4.797 6.045A13.978 13.978 0 0 1 1.671 3.149a4.93 4.93 0 0 0 1.523 6.574 4.903 4.903 0 0 1-2.229-.616c-.054 2.281 1.581 4.415 3.949 4.89a4.935 4.935 0 0 1-2.224.084 4.928 4.928 0 0 0 4.6 3.419A9.9 9.9 0 0 1 0 19.54a13.94 13.94 0 0 0 7.548 2.212c9.142 0 14.307-7.721 13.995-14.646A10.025 10.025 0 0 0 24 4.557z'/%3E%3C/svg%3E");--logo-x: url("data:image/svg+xml,%3Csvg width='300' height='271' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M236 0h46L181 115l118 156h-92.6l-72.5-94.8-83 94.8h-46l107-123L-1.1 0h94.9l65.5 86.6zm-16.1 244h25.5L80.4 26H53z'/%3E%3C/svg%3E");--logo-mastodon: url("data:image/svg+xml,%3Csvg width='800' height='800' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg' xml:space='preserve'%3E%3Cpath d='M21.327 8.566c0-4.339-2.843-5.61-2.843-5.61-1.433-.658-3.894-.935-6.451-.956h-.063c-2.557.021-5.016.298-6.45.956 0 0-2.843 1.272-2.843 5.61 0 .993-.019 2.181.012 3.441.103 4.243.778 8.425 4.701 9.463 1.809.479 3.362.579 4.612.51 2.268-.126 3.541-.809 3.541-.809l-.075-1.646s-1.621.511-3.441.449c-1.804-.062-3.707-.194-3.999-2.409a4.523 4.523 0 0 1-.04-.621s1.77.433 4.014.536c1.372.063 2.658-.08 3.965-.236 2.506-.299 4.688-1.843 4.962-3.254.434-2.223.398-5.424.398-5.424zm-3.353 5.59h-2.081V9.057c0-1.075-.452-1.62-1.357-1.62-1 0-1.501.647-1.501 1.927v2.791h-2.069V9.364c0-1.28-.501-1.927-1.502-1.927-.905 0-1.357.546-1.357 1.62v5.099H6.026V8.903c0-1.074.273-1.927.823-2.558.566-.631 1.307-.955 2.228-.955 1.065 0 1.872.409 2.405 1.228l.518.869.519-.869c.533-.819 1.34-1.228 2.405-1.228.92 0 1.662.324 2.228.955.549.631.822 1.484.822 2.558v5.253z'/%3E%3C/svg%3E")}.logo-tailwind{--logo-url: var(--logo-tailwind)}.logo-laravel{--logo-url: var(--logo-laravel)}.logo-sass{--logo-url: var(--logo-sass)}.logo-github{--logo-url: var(--logo-github)}.logo-twitter{--logo-url: var(--logo-twitter)}.logo-x{--logo-url: var(--logo-x)}.logo-mastodon{--logo-url: var(--logo-mastodon)}body{--icon-link: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor' class='size-6'%3E%3Cpath fill-rule='evenodd' d='M19.902 4.098a3.75 3.75 0 0 0-5.304 0l-4.5 4.5a3.75 3.75 0 0 0 1.035 6.037.75.75 0 0 1-.646 1.353 5.25 5.25 0 0 1-1.449-8.45l4.5-4.5a5.25 5.25 0 1 1 7.424 7.424l-1.757 1.757a.75.75 0 1 1-1.06-1.06l1.757-1.757a3.75 3.75 0 0 0 0-5.304Zm-7.389 4.267a.75.75 0 0 1 1-.353 5.25 5.25 0 0 1 1.449 8.45l-4.5 4.5a5.25 5.25 0 1 1-7.424-7.424l1.757-1.757a.75.75 0 1 1 1.06 1.06l-1.757 1.757a3.75 3.75 0 1 0 5.304 5.304l4.5-4.5a3.75 3.75 0 0 0-1.035-6.037.75.75 0 0 1-.354-1Z' clip-rule='evenodd' /%3E%3C/svg%3E%0A");--icon-link-sm: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='currentColor'%3E%3Cpath d='M12.232 4.232a2.5 2.5 0 0 1 3.536 3.536l-1.225 1.224a.75.75 0 0 0 1.061 1.06l1.224-1.224a4 4 0 0 0-5.656-5.656l-3 3a4 4 0 0 0 .225 5.865.75.75 0 0 0 .977-1.138 2.5 2.5 0 0 1-.142-3.667l3-3Z' /%3E%3Cpath d='M11.603 7.963a.75.75 0 0 0-.977 1.138 2.5 2.5 0 0 1 .142 3.667l-3 3a2.5 2.5 0 0 1-3.536-3.536l1.225-1.224a.75.75 0 0 0-1.061-1.06l-1.224 1.224a4 4 0 1 0 5.656 5.656l3-3a4 4 0 0 0-.225-5.865Z' /%3E%3C/svg%3E%0A");--icon-popout: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor' %3E%3Cpath fill-rule='evenodd' d='M15.75 2.25H21a.75.75 0 0 1 .75.75v5.25a.75.75 0 0 1-1.5 0V4.81L8.03 17.03a.75.75 0 0 1-1.06-1.06L19.19 3.75h-3.44a.75.75 0 0 1 0-1.5Zm-10.5 4.5a1.5 1.5 0 0 0-1.5 1.5v10.5a1.5 1.5 0 0 0 1.5 1.5h10.5a1.5 1.5 0 0 0 1.5-1.5V10.5a.75.75 0 0 1 1.5 0v8.25a3 3 0 0 1-3 3H5.25a3 3 0 0 1-3-3V8.25a3 3 0 0 1 3-3h8.25a.75.75 0 0 1 0 1.5H5.25Z' clip-rule='evenodd' /%3E%3C/svg%3E%0A");--icon-popout-sm: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='currentColor'%3E%3Cpath fill-rule='evenodd' d='M4.25 5.5a.75.75 0 0 0-.75.75v8.5c0 .414.336.75.75.75h8.5a.75.75 0 0 0 .75-.75v-4a.75.75 0 0 1 1.5 0v4A2.25 2.25 0 0 1 12.75 17h-8.5A2.25 2.25 0 0 1 2 14.75v-8.5A2.25 2.25 0 0 1 4.25 4h5a.75.75 0 0 1 0 1.5h-5Z' clip-rule='evenodd' /%3E%3Cpath fill-rule='evenodd' d='M6.194 12.753a.75.75 0 0 0 1.06.053L16.5 4.44v2.81a.75.75 0 0 0 1.5 0v-4.5a.75.75 0 0 0-.75-.75h-4.5a.75.75 0 0 0 0 1.5h2.553l-9.056 8.194a.75.75 0 0 0-.053 1.06Z' clip-rule='evenodd' /%3E%3C/svg%3E%0A");--icon-sun: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'%3E%3Cpath d='M12 2.25a.75.75 0 0 1 .75.75v2.25a.75.75 0 0 1-1.5 0V3a.75.75 0 0 1 .75-.75ZM7.5 12a4.5 4.5 0 1 1 9 0 4.5 4.5 0 0 1-9 0ZM18.894 6.166a.75.75 0 0 0-1.06-1.06l-1.591 1.59a.75.75 0 1 0 1.06 1.061l1.591-1.59ZM21.75 12a.75.75 0 0 1-.75.75h-2.25a.75.75 0 0 1 0-1.5H21a.75.75 0 0 1 .75.75ZM17.834 18.894a.75.75 0 0 0 1.06-1.06l-1.59-1.591a.75.75 0 1 0-1.061 1.06l1.59 1.591ZM12 18a.75.75 0 0 1 .75.75V21a.75.75 0 0 1-1.5 0v-2.25A.75.75 0 0 1 12 18ZM7.758 17.303a.75.75 0 0 0-1.061-1.06l-1.591 1.59a.75.75 0 0 0 1.06 1.061l1.591-1.59ZM6 12a.75.75 0 0 1-.75.75H3a.75.75 0 0 1 0-1.5h2.25A.75.75 0 0 1 6 12ZM6.697 7.757a.75.75 0 0 0 1.06-1.06l-1.59-1.591a.75.75 0 0 0-1.061 1.06l1.59 1.591Z' /%3E%3C/svg%3E%0A");--icon-sun-sm: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='currentColor'%3E%3Cpath d='M10 2a.75.75 0 0 1 .75.75v1.5a.75.75 0 0 1-1.5 0v-1.5A.75.75 0 0 1 10 2ZM10 15a.75.75 0 0 1 .75.75v1.5a.75.75 0 0 1-1.5 0v-1.5A.75.75 0 0 1 10 15ZM10 7a3 3 0 1 0 0 6 3 3 0 0 0 0-6ZM15.657 5.404a.75.75 0 1 0-1.06-1.06l-1.061 1.06a.75.75 0 0 0 1.06 1.06l1.06-1.06ZM6.464 14.596a.75.75 0 1 0-1.06-1.06l-1.06 1.06a.75.75 0 0 0 1.06 1.06l1.06-1.06ZM18 10a.75.75 0 0 1-.75.75h-1.5a.75.75 0 0 1 0-1.5h1.5A.75.75 0 0 1 18 10ZM5 10a.75.75 0 0 1-.75.75h-1.5a.75.75 0 0 1 0-1.5h1.5A.75.75 0 0 1 5 10ZM14.596 15.657a.75.75 0 0 0 1.06-1.06l-1.06-1.061a.75.75 0 1 0-1.06 1.06l1.06 1.06ZM5.404 6.464a.75.75 0 0 0 1.06-1.06l-1.06-1.06a.75.75 0 1 0-1.061 1.06l1.06 1.06Z' /%3E%3C/svg%3E%0A");--icon-moon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'%3E%3Cpath fill-rule='evenodd' d='M9.528 1.718a.75.75 0 0 1 .162.819A8.97 8.97 0 0 0 9 6a9 9 0 0 0 9 9 8.97 8.97 0 0 0 3.463-.69.75.75 0 0 1 .981.98 10.503 10.503 0 0 1-9.694 6.46c-5.799 0-10.5-4.7-10.5-10.5 0-4.368 2.667-8.112 6.46-9.694a.75.75 0 0 1 .818.162Z' clip-rule='evenodd' /%3E%3C/svg%3E%0A");--icon-moon-sm: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='currentColor'%3E%3Cpath fill-rule='evenodd' d='M7.455 2.004a.75.75 0 0 1 .26.77 7 7 0 0 0 9.958 7.967.75.75 0 0 1 1.067.853A8.5 8.5 0 1 1 6.647 1.921a.75.75 0 0 1 .808.083Z' clip-rule='evenodd' /%3E%3C/svg%3E%0A")}.icon-link{--icon-url: var(--icon-link)}.icon-link-sm{--icon-url: var(--icon-link-sm)}.icon-popout{--icon-url: var(--icon-popout)}.icon-popout-sm{--icon-url: var(--icon-popout-sm)}.icon-moon{--icon-url: var(--icon-moon)}.icon-moon-sm{--icon-url: var(--icon-moon-sm)}.icon-sun{--icon-url: var(--icon-sun)}.icon-sun-sm{--icon-url: var(--icon-sun-sm)}.btn{border-radius:.5rem;padding:.25rem .75rem;font-size:1.125rem;min-height:34px;display:inline-flex;align-items:center;justify-content:center;text-align:center;font-weight:700;line-height:1.375;letter-spacing:-.025em;transition:color .2s ease-in-out,background-color .2s ease-in-out;color:#fff;--arrow-color: #fff;background:var(--accent-color, --theme-blue)}.btn.btn-sm{border-radius:.375rem;padding:.125rem .5rem;font-size:.9375rem;min-height:30px}.btn.btn-arrow:after{content:"";display:inline-block;width:1em;height:1em;margin-left:.5em;transition:transform var(--hover-duration, .2s) var(--hover-function, ease-in-out),color var(--hover-duration, .2s) var(--hover-function, ease-in-out);background:var(--arrow-color, --theme-text-color);mask:var(--icon-arrow-svg) center center no-repeat;-webkit-mask:var(--icon-arrow-svg) center center no-repeat;mask-size:contain;-webkit-mask-size:contain}.btn.btn-arrow:hover:after{transform:translate(.25em)}.pill{font-size:.8125rem;font-weight:700;line-height:1.375;letter-spacing:-.025em;display:inline-flex;align-items:center;justify-content:center;border-radius:.25rem;padding:.25rem .5rem;text-align:center;min-height:26px;color:var(--accent-color, --theme-red);background:rgba(var(--accent-color-rgb, --theme-red-rgb),.2)}.pill.pill-lg,.pills-lg .pill{border-radius:.5rem;padding:.375rem .5rem;font-size:.9375rem;letter-spacing:-.025em;min-height:32px}.pills-list{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:.5rem}.pills-list.pills-lg{gap:.625rem}.faux-ipad{--ipad-aspect-w: 2123;--ipad-aspect-h: 1628;--ipad-aspect-ratio: 2123 / 1628;--ipad-padding-x-raw: .0345643939;--ipad-padding-x: calc(var(--ipad-padding-x-raw) * 100%);--ipad-padding-y: .0462962963;--ipad-frame-image: url(/build/assets/ipad-frame-light-Bh9fgD2J.png);position:relative;aspect-ratio:var(--ipad-aspect-ratio);display:flex;align-items:stretch;justify-content:center;padding-left:var(--ipad-padding-x);padding-right:var(--ipad-padding-x);padding-top:calc(100% / (var(--ipad-aspect-w) / var(--ipad-aspect-h)) * var(--ipad-padding-y));padding-bottom:calc(100% / (var(--ipad-aspect-w) / var(--ipad-aspect-h)) * var(--ipad-padding-y))}.faux-ipad:before{position:absolute;top:0;left:0;z-index:10;height:100%;width:100%;content:"";background:var(--ipad-frame-image) center center no-repeat;background-size:contain}.faux-ipad .ipad-content{position:relative;display:flex;flex:1 1 auto;align-items:flex-start;justify-content:center;overflow:hidden}.faux-ipad .ipad-content img{position:absolute;top:0;height:auto;width:100%}@media (prefers-color-scheme: light){.faux-ipad{--ipad-frame-image: url(/build/assets/ipad-frame-dark-BIF5i9Fq.png)}}body.theme-light .faux-ipad{--ipad-frame-image: url(/build/assets/ipad-frame-dark-BIF5i9Fq.png)}body:has(dialog[open]){overflow:clip}body{--dialog-height: auto}dialog{--dialog-vertical-offset: 32px;--dialog-horizontal-offset: 20px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-width:0px;background-color:transparent;padding-left:3.5rem;padding-right:3.5rem;outline:2px solid transparent;outline-offset:2px;transform-origin:top;border-radius:.5rem;overflow:hidden;max-width:calc(100dvw - var(--dialog-horizontal-offset));max-height:calc(100dvh - var(--dialog-vertical-offset));transition:opacity .3s,transform .3s;transition:display .3s allow-discrete,overlay .3s allow-discrete;transform-origin:center center;animation:closeDialog .3s forwards}dialog:not(.tall-image){height:min((var(--dialog-image-rendered-height)),100dvh)}dialog.tall-image{height:calc(100dvh - var(--dialog-vertical-offset))}dialog .gallery-content{position:relative;height:100%;width:100%;overflow:hidden;border-radius:.5rem;z-index:100}dialog .gallery-content .gallery-image{display:grid;height:100%;width:100%;grid-template-columns:repeat(1,minmax(0,1fr));overflow:scroll}dialog .gallery-content .gallery-image img{display:none;height:auto;width:100%}dialog .gallery-content .gallery-image img.gallery-active-image{display:block}dialog .gallery-close{position:absolute;top:0;right:0;display:flex;align-items:center;justify-content:center;width:3.5rem;height:3.5rem;cursor:pointer;padding-left:.625rem;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity));color:var(--theme-text-color);outline:none;z-index:50}dialog .gallery-nav{position:absolute;top:50%;left:0;margin-top:-1.25rem;display:flex;height:2.5rem;width:100%;align-items:center;justify-content:space-between;padding-left:.25rem;padding-right:.25rem;z-index:40}dialog .gallery-nav .gallery-nav-item{width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;color:var(--theme-text-color);transition:opacity .2s,transform .2s}dialog .gallery-nav .gallery-nav-item:hover{transform:translate(-4px)}dialog .gallery-nav .gallery-nav-item.gallery-next:hover{transform:translate(4px)}dialog::backdrop{transition:background .3s,backdrop-filter .3s;background:rgba(var(--theme-extreme-color-rgb),0);-webkit-backdrop-filter:blur(0) saturate(1);backdrop-filter:blur(0) saturate(1)}dialog[open]{animation:openDialog .3s forwards}dialog[open]::backdrop{background:rgba(var(--theme-extreme-color-rgb),.7);-webkit-backdrop-filter:blur(12px) saturate(.8);backdrop-filter:blur(12px) saturate(.8)}dialog img{max-height:100%;max-width:100%}@keyframes openDialog{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes closeDialog{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}#header-primary{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;position:fixed;top:0;width:100vw;border-bottom-width:1px;border-style:solid;border-color:transparent;z-index:1000;height:80px;--header-mob-animation: .35s ease;transition:height var(--header-mob-animation),backdrop-filter var(--header-mob-animation),border var(--header-mob-animation),background var(--header-mob-animation)}@media (min-width: 640px){#header-primary{padding:6px 20px;top:16px}}#header-primary .nav-home{margin-right:1rem}#header-primary .logo{width:42px;height:auto}@media screen and (max-width: 640px){#header-primary.scrolled,.scrolled #header-primary{backdrop-filter:blur(12px) saturate(.8);-webkit-backdrop-filter:blur(12px) saturate(.8);background:rgba(var(--theme-background-color-rgb),.85);border-bottom:1px solid rgba(var(--theme-text-color-rgb),.05)}#header-primary.mob-expanded{backdrop-filter:blur(12px) saturate(.8);-webkit-backdrop-filter:blur(12px) saturate(.8);background:rgba(var(--theme-background-color-rgb),.85);border-bottom:1px solid rgba(var(--theme-text-color-rgb),.05);height:100vh;width:100vw}#header-primary.mob-expanded .nav-primary{top:0;left:0}#header-primary.mob-expanded .nav-primary .nav-pages{visibility:visible;opacity:1}.cloud-item#header-primary.mob-expanded .nav-primary .nav-pages,.cloud-web-dev#header-primary.mob-expanded .nav-primary .nav-pages{opacity:1}#header-primary.mob-expanded .nav-primary .nav-pages{transform:scale(1) translateY(0);height:calc(100dvh - 79px)}}#header-primary .nav-primary{display:flex;align-items:center;gap:1rem;padding-top:.375rem;padding-bottom:.375rem;padding-left:var(--padding-horiz);padding-right:var(--padding-horiz);border-bottom:1px solid transparent;z-index:100;transition:background .3s ease-in-out,backdrop-filter .3s ease-in-out,border-color .3s ease-in-out;width:100%;justify-content:space-between;height:80px}@media (min-width: 640px){#header-primary .nav-primary{height:auto;width:auto;flex:none;justify-content:center;align-self:center;border-radius:9999px;padding-left:1.75rem;padding-right:1.25rem}#header-primary .nav-primary.scrolled,.scrolled #header-primary .nav-primary{backdrop-filter:blur(12px) saturate(.8);-webkit-backdrop-filter:blur(12px) saturate(.8);background:var(--theme-nav-background);border-color:var(--theme-nav-border)}}#header-primary #nav-mobile-toggle{margin-right:-.5rem;height:3.5rem;width:3.5rem;padding:.5rem;color:var(--theme-text-fade-color);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}#header-primary #nav-mobile-toggle svg{height:100%;width:100%}#header-primary #nav-mobile-toggle:hover{color:var(--theme-text-color)}@media (min-width: 640px){#header-primary #nav-mobile-toggle{display:none}}#header-primary .nav-pages{gap:1rem;position:fixed;left:0;display:flex;width:100vw;visibility:hidden;flex-direction:column;align-items:center;justify-content:center;opacity:0;top:79px;height:0;transform:scale(.75) translateY(-10dvh);z-index:1001;transition:height var(--header-mob-animation),opacity var(--header-mob-animation),visibility var(--header-mob-animation),transform var(--header-mob-animation)}#header-primary .nav-pages .nav-mobile-actions{display:none}#header-primary .nav-pages .nav-item{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-size:1.75rem;color:var(--theme-text-color);display:flex;align-items:center;justify-content:center;text-align:center;font-weight:700;line-height:1.375;padding-left:.25rem;padding-right:.25rem;transition:color .2s ease-in-out,background-color .2s ease-in-out}#header-primary .nav-pages .nav-item:hover:not(.active){color:var(--accent-color)}#header-primary .nav-pages .nav-item.active{color:var(--accent-color)}@media (min-width: 640px){#header-primary .nav-pages .nav-item{border-radius:.5rem;border-bottom-width:0px;padding:.25rem .75rem;font-family:DM Sans,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-size:1.125rem;letter-spacing:-.025em;min-height:34px}#header-primary .nav-pages .nav-item.active{border-bottom-width:0px;background-color:var(--accent-color);--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity))}#header-primary .nav-pages .nav-item:hover:not(.active){color:var(--accent-color)}#header-primary .nav-pages{position:relative;top:auto;left:auto;height:auto;width:auto;flex-direction:row;visibility:visible;padding-top:.375rem;padding-bottom:.375rem;opacity:1}.cloud-item#header-primary .nav-pages,.cloud-web-dev#header-primary .nav-pages{opacity:1}#header-primary .nav-pages{transform:none}}.theme-toggle{position:relative;display:inline-flex;flex-shrink:0;cursor:pointer;align-items:center;justify-content:center;background:transparent;border:0;padding:0}.theme-toggle .theme-icon{display:inline-flex;align-items:center;justify-content:center}.theme-toggle .theme-icon-sun{display:none}.theme-toggle .theme-icon-moon{display:inline-flex}@media (prefers-color-scheme: light){.theme-toggle .theme-icon-sun{display:inline-flex}.theme-toggle .theme-icon-moon{display:none}}body.theme-light .theme-toggle .theme-icon-sun{display:inline-flex}body.theme-light .theme-toggle .theme-icon-moon{display:none}html.theme-dark body .theme-toggle .theme-icon-sun{display:none!important}html.theme-dark body .theme-toggle .theme-icon-moon,html.theme-light body .theme-toggle .theme-icon-sun{display:inline-flex!important}html.theme-light body .theme-toggle .theme-icon-moon{display:none!important}.theme-toggle-simple{width:36px;height:36px;color:var(--theme-text-fade-color);transition:color .2s ease}.theme-toggle-simple:hover{color:var(--theme-text-color)}@media screen and (max-width: 640px){.theme-toggle-simple{display:none}}.theme-toggle-mobile{display:none;align-items:center;justify-content:center;gap:.75rem;border-radius:9999px;padding:.5rem 1rem;font-size:.9375rem;font-weight:700;color:var(--theme-text-color);border:1px solid rgba(var(--theme-text-color-rgb),.08);background:rgba(var(--theme-text-color-rgb),.04);transition:color .2s ease,border-color .2s ease,background .2s ease,transform .2s ease}.theme-toggle-mobile .theme-toggle-label{line-height:1}.theme-toggle-mobile:hover{color:var(--accent-color);border-color:rgba(var(--accent-color-rgb),.28);background:rgba(var(--accent-color-rgb),.08);transform:translateY(-1px)}@media (min-width: 640px){.theme-toggle-mobile{display:none}}@media screen and (max-width: 640px){#header-primary .nav-pages .nav-mobile-actions{display:flex;align-items:center;justify-content:center;padding-top:1.5rem}.theme-toggle-mobile{display:inline-flex}}footer{border-top:1px solid rgba(var(--theme-extreme-contrast-rgb),var(--theme-footer-border-alpha))}footer .footer-content{margin-left:auto;margin-right:auto;width:100%;padding-left:var(--padding-horiz);padding-right:var(--padding-horiz);max-width:calc(var(--padding-horiz) * 2 + 800px);padding-top:3rem;padding-bottom:3rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:.25rem}@media (min-width: 768px){footer .footer-content{flex-direction:row;align-items:center;justify-content:space-between;gap:.75rem}}footer div.left p{font-size:.9375rem}footer div.left nav{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;font-size:.9375rem}footer div.left nav a{color:var(--theme-text-fade-color)}footer div.left nav a.active{font-weight:700;color:var(--accent-color);opacity:.8}footer nav.nav-social{display:flex;align-items:center;gap:1rem}footer nav.nav-social a{color:var(--accent-color);font-size:0;color:transparent;overflow:hidden;transition:color .2s ease-in-out;width:20px;height:20px}footer nav.nav-social a:before{background-color:var(--theme-text-fade-color);mask:var(--logo-url) center center no-repeat;-webkit-mask:var(--logo-url) center center no-repeat;mask-size:contain;-webkit-mask-size:contain;display:block;content:"";width:100%;height:100%;transition:background-color .2s ease}footer nav.nav-social a:hover:before{background-color:var(--theme-text-color)}.grid-listing{--listing-container-width: 960px;margin-left:auto;margin-right:auto;width:100%;padding-left:var(--padding-horiz);padding-right:var(--padding-horiz);max-width:calc(var(--padding-horiz) * 2 + var(--listing-container-width))}.grid-listing,.grid-items{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:3rem}@media (min-width: 640px){.grid-listing,.grid-items{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem;row-gap:2.5rem}}@media screen and (min-width: 960px){.grid-listing,.grid-items{gap:2rem;row-gap:3rem}.grid-listing:not(.max-cols-2),.grid-items:not(.max-cols-2){grid-template-columns:repeat(3,minmax(0,1fr))}}.grid-listing .grid-item .featured-image,.grid-items .grid-item .featured-image{margin-bottom:1.25rem;height:auto;width:100%;border-radius:1rem;aspect-ratio:16/10;border:1px solid var(--theme-subtle-border);background-repeat:no-repeat;background-position:center 0;background-size:cover}.grid-listing .grid-item h3,.grid-items .grid-item h3{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:1.25rem;color:var(--theme-text-color)}.grid-listing .grid-item h3 strong,.grid-items .grid-item h3 strong{color:var(--accent-color)}.grid-listing .grid-item h3+p,.grid-items .grid-item h3+p{margin-top:.25rem}.grid-listing .grid-item p,.grid-items .grid-item p{font-size:.9375rem;font-weight:400;color:var(--theme-text-fade-color)}.grid-listing .grid-item .pills-list,.grid-items .grid-item .pills-list{margin-top:.75rem}.item-horiz{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.item-horiz .item-image,.item-horiz .featured-image{border-radius:.5rem;background-size:cover;background-position:center;background-repeat:no-repeat;width:40%;flex:none;aspect-ratio:32/21;border:1px solid var(--theme-subtle-border)}.item-horiz .item-text{display:flex;flex:1 1 auto;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:.5rem}.item-horiz .item-text .date{margin-bottom:-.25rem;flex:none;font-size:.8125rem;font-weight:700;color:var(--theme-text-fade-color)}.item-horiz .item-text h3{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:1.75rem}.item-horiz .item-text h3 strong{color:var(--accent-color)}.item-horiz .item-text h3+p{margin-top:0}.item-horiz .item-text .pills-list{margin-top:.25rem}.item-horiz.flipped .item-image,.item-horiz.flipped .featured-image{order:2}.item-horiz.flipped .item-text{order:1}@media screen and (max-width: 640px){.item-horiz{flex-direction:column;gap:.75rem}.item-horiz .item-image,.item-horiz .featured-image{width:100%;aspect-ratio:20/9}}.featured-image.image-light{display:none}@media (prefers-color-scheme: light){.featured-image.image-light{display:block}.featured-image.image-dark{display:none}}.theme-light .featured-image.image-light{display:block}.theme-light .featured-image.image-dark{display:none}.text-listing{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:1.5rem}.text-listing h5{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:1.75rem}.text-listing h5 strong{color:var(--accent-color)}.text-listing .date{font-size:.9375rem;font-weight:700;color:var(--theme-text-fade-color)}.text-listing p,.text-listing h5+p{margin-top:.125rem}.text-listing .listing-item-title{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.text-listing .listing-item-title .date{flex:none}.text-listing.listing-sm h5{font-size:1.25rem;line-height:1.5}.text-listing.listing-sm .date{font-size:.8125rem;font-weight:700;color:var(--theme-text-fade-color)}.text-listing.listing-sm p,.text-listing.listing-sm h5+p{margin-top:.125rem;font-size:.9375rem}.blog-listing{gap:2.5rem;padding-top:3rem}.blog-list{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;padding-top:1.25rem}.blog-list h5{font-size:1.25rem;line-height:1.5}.blog-list .date{flex:none;font-size:.8125rem;font-weight:700;color:var(--theme-text-fade-color)}.blog-list .listing-item .date{width:7rem}.blog-list .listing-item .listing-item-content{flex:1 1 auto}.blog-list .listing-item p,.blog-list .listing-item h5+p{margin-top:.125rem;font-size:.9375rem}@media (min-width: 768px){.blog-list .listing-item{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.blog-list .listing-item .date{line-height:30px}}body{--hero-margin-top: clamp(8.5rem, 15vh, 11.5rem);--hero-padding-bottom: clamp(1.5rem, 4.5vh, 4.5rem);--hero-min-height: 0}@media (max-height: 800px) and (min-width: 768px){body{--hero-margin-top: clamp(8rem, 13vh, 9.5rem);--hero-padding-bottom: clamp(2rem, 4vh, 3rem);--hero-min-height: 0}}@media (min-height: 970px) and (min-width: 768px){body{--hero-margin-top: clamp(10.5rem, 17vh, 13rem);--hero-padding-bottom: clamp(3rem, 7vh, 5rem);--hero-min-height: clamp(15rem, 27vh, 20rem)}}@media (min-width: 1024px){body{--hero-margin-top: 20dvh;--hero-padding-bottom: 8dvh;--hero-min-height: 33dvh}}.hero{display:flex;align-items:center;justify-content:center;padding-top:150px}.hero .hero-content{flex:1 1 auto;margin-left:auto;margin-right:auto;width:100%;padding-left:var(--padding-horiz);padding-right:var(--padding-horiz);max-width:calc(var(--padding-horiz) * 2 + 724px)}.hero .hero-content p a{font-weight:600;transition:color .2s ease;color:var(--theme-article-link-color)}.hero .hero-content p a:hover{color:var(--accent-color)}.hero .hero-content p a strong{color:inherit}.hero.hero-spaced{padding-top:0}.hero.hero-spaced .hero-content{margin-top:var(--hero-margin-top);padding-bottom:var(--hero-padding-bottom)}.hero h1{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:3.5rem}.hero h1 strong{color:var(--accent-color)}@media screen and (max-width: 640px){.hero h1{font-size:3rem}}.hero h3{font-size:1.125rem;color:var(--theme-text-fade-color);line-height:var(--paragraph-line-height, 1.777777778em)}.hero h3 strong{font-weight:700;color:var(--theme-text-color)}.hero p{font-size:1.125rem;color:var(--theme-text-fade-color);line-height:var(--paragraph-line-height, 1.777777778em)}.hero p strong{font-weight:700;color:var(--theme-text-color)}.hero .cta{display:flex;align-items:center;justify-content:flex-start;align-self:flex-start;font-size:1.125rem;font-weight:700;color:var(--accent-color)}.hero .cta:after{content:"";display:inline-block;width:1em;height:1em;margin-left:.5em;transition:transform var(--hover-duration, .2s) var(--hover-function, ease-in-out),color var(--hover-duration, .2s) var(--hover-function, ease-in-out);background:var(--accent-color);mask:var(--icon-arrow-svg) center center no-repeat;-webkit-mask:var(--icon-arrow-svg) center center no-repeat;mask-size:contain;-webkit-mask-size:contain}.hero .cta:hover:after{transform:translate(.25em)}.hero.hero-home{align-items:flex-start;padding-top:0}.hero.hero-home .hero-content{display:flex;align-items:flex-start;justify-content:space-between;gap:1.25rem;margin-top:calc(var(--hero-margin-top) - 1.25em);padding-bottom:var(--hero-padding-bottom);min-height:var(--hero-min-height)}.hero.hero-home .hero-avatar{display:flex;height:8rem;width:8rem;flex:none;align-items:center;justify-content:center;overflow:hidden;mask:url("data:image/svg+xml,%3Csvg width='125' height='125' viewBox='0 0 125 125' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='-13' y='62.2792' width='106.461' height='106.461' rx='32' transform='rotate(-45 -13 62.2792)' fill='%23D9D9D9'/%3E%3C/svg%3E%0A") center center no-repeat;-webkit-mask:url("data:image/svg+xml,%3Csvg width='125' height='125' viewBox='0 0 125 125' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='-13' y='62.2792' width='106.461' height='106.461' rx='32' transform='rotate(-45 -13 62.2792)' fill='%23D9D9D9'/%3E%3C/svg%3E%0A") center center no-repeat;mask-size:cover;-webkit-mask-size:cover;background:#fff url(/build/assets/me-HFDrqqQi.jpg) center center no-repeat;background-size:contain}.hero.hero-home h1{position:relative}.hero.hero-home h1 .hero-avatar{margin-bottom:1rem;overflow:hidden}.hero.hero-home .hero-copy{position:relative;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:1rem;padding-top:1.25rem}@media (min-width: 768px){.hero.hero-home h1 .hero-avatar{position:absolute;top:50%;margin-top:-4rem;margin-bottom:0;left:-148px}.hero.hero-home .hero-copy{padding-left:148px}}.hero.hero-uses{padding-bottom:4rem}@media screen and (min-width: 500px){.hero.hero-uses h1 strong{white-space:nowrap}}@media screen and (max-width: 1024px){.hero.hero-post{padding-bottom:3rem}}.page-home{min-height:100dvh;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:2rem}.page-home .hero-home{flex:none}.page-home .page-content{padding-bottom:5rem}.page-home footer{margin-top:auto}.home-links{margin-left:auto;margin-right:auto;display:flex;width:100%;max-width:80rem;align-items:flex-start;justify-content:space-between;--home-links-gap: 24px;--home-links-gap: 2rem;gap:var(--home-links-gap);padding:0 var(--padding-horiz)}.home-links h2{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:2.25rem;margin-bottom:1rem}.home-links h2 strong{color:var(--accent-color)}.home-links .home-blog{flex:none;width:calc(33.33333333% - var(--home-links-gap) / 2);--accent-color: var(--color-blog);--accent-color-rgb: var(--color-blog-rgb)}.home-links .home-blog .grid-listing{display:flex;align-items:stretch;padding-left:0;padding-right:0}.home-links .home-blog .faux-image{width:100%;border-radius:.5rem;background-color:#ffffff0d}.home-links .home-blog .item-horiz{display:none}.home-links .home-blog h5{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:1.25rem;margin-bottom:.25rem}.home-links .home-blog h5 strong{color:var(--accent-color)}.home-links .home-blog p{font-size:.9375rem}.home-links .home-work{flex:1 1 auto;--accent-color: var(--color-projects);--accent-color-rgb: var(--color-projects-rgb)}.home-links .home-work .grid-listing{width:100%;gap:2rem;padding-left:0;padding-right:0}.home-links .home-work .projects-listing{padding-top:0}@media (min-width: 768px){.home-links .grid-listing{gap:1.5rem}.home-links .grid-listing .grid-item .featured-image{height:12rem}}.home-links.temp-small{margin-left:auto;margin-right:auto;width:100%;padding-left:var(--padding-horiz);padding-right:var(--padding-horiz);max-width:calc(var(--padding-horiz) * 2 + 800px)}@media screen and (max-width: 1070px){.home-links{flex-direction:column}.home-links .home-work{width:100%}.home-links .home-blog{margin-top:1.5rem;width:100%}.home-links .home-blog .grid-listing{display:none}.home-links .home-blog .item-horiz{display:flex}}@media screen and (max-width: 640px){.home-links .home-blog .grid-listing{display:flex}.home-links .home-blog .grid-listing .grid-item{width:100%}.home-links .home-blog .item-horiz{display:none}}.hero.hero-about .hero-content{max-width:calc(var(--padding-horiz) * 2 + 560px)}.hero.hero-about .hero-content h1{margin-bottom:1.5rem}#about-wrapper{position:relative;min-height:200dvh;width:100dvw;overflow:hidden}.about-snippet{padding-top:2rem}.cloud-item,.cloud-web-dev{position:absolute;flex:1 1 auto;white-space:nowrap;--fall-duration: 1.15s;--fade-in-duration: .65s;transition:top var(--fall-duration) ease-in,left var(--fall-duration) ease-in,transform 1s ease-in,opacity var(--fade-in-duration) ease-in;opacity:0;font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:2.25rem}.cloud-item strong,.cloud-web-dev strong{color:var(--accent-color)}.cloud-item.visible,.cloud-web-dev.visible{opacity:1}.about-cloud{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:2.25rem;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:1rem;overflow:visible}.about-cloud strong{color:var(--accent-color)}.about-cloud .cloud-row{display:flex;align-items:center;justify-content:center;gap:1rem;width:1px}.about-cloud .cloud-row .cloud-item{visibility:hidden;position:static;opacity:0;transition:none}.about-cloud .cloud-row .row-left{display:flex;width:1px;align-items:center;justify-content:flex-end}.about-cloud .cloud-row .row-right{display:flex;width:1px;align-items:center;justify-content:flex-start}.about-bullets{margin-left:auto;margin-right:auto;margin-top:3rem;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:4rem;padding:0 var(--padding-horiz);max-width:calc(var(--padding-horiz) * 2 + 800px)}.about-bullets>div h4{margin-bottom:1rem;font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:1.5rem}.about-bullets>div h4 strong{color:var(--accent-color)}.about-bullets>div h4 small{font-size:.9375rem;line-height:1.5;letter-spacing:0em}@media (min-width: 340px){.about-bullets>div h4 small{white-space:nowrap}}.about-bullets>div h4:before{display:inline-block;height:.5rem;width:.5rem;background-color:var(--accent-color);vertical-align:middle;border-radius:2px;content:"";transform:translateY(-.1em) rotate(45deg);margin-right:.35em}.about-bullets>div p{font-size:1.125rem;color:var(--theme-text-fade-color);line-height:var(--paragraph-line-height, 1.777777778em)}.about-bullets>div p strong{font-weight:700;color:var(--theme-text-color);color:var(--accent-color)}@property --xp-clone-x{syntax: "<length>"; inherits: false; initial-value: 0px;}@property --xp-clone-y{syntax: "<length>"; inherits: false; initial-value: 0px;}.about-xp{margin-left:auto;margin-right:auto;margin-top:4rem;margin-bottom:5rem;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:3rem;padding:0 var(--padding-horiz);max-width:calc(var(--padding-horiz) * 2 + 800px)}.about-xp h2{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:2.25rem;margin-bottom:-.5rem}.about-xp h2 strong{color:var(--accent-color)}.about-xp .xp-heading{margin-bottom:.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.about-xp .xp-heading .xp-years,.about-xp .xp-heading .xp-title h4{visibility:hidden;opacity:0}.about-xp .xp-title{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;transition:opacity var(--xp-duration-function),visibility var(--xp-duration-function)}.about-xp .xp-title .xp-divider{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;font-size:1.25rem;color:var(--accent-color);line-height:1.125em}.about-xp .xp-title .xp-divider strong{color:var(--accent-color)}@media screen and (max-width: 640px){.about-xp .xp-title{flex-direction:column;align-items:flex-start}.about-xp .xp-title .xp-divider{display:none}.about-xp .xp-title .xp-role{font-size:.9375rem;color:var(--accent-color)}}.about-xp .xp-years{white-space:nowrap;border-radius:9999px;padding:.25rem .75rem;font-size:.9375rem;font-weight:700;line-height:1;color:var(--accent-color);background:rgba(var(--accent-color-rgb),.1);--xp-years-top: var(--xp-years-collapsed-top);transition:top var(--xp-duration-function)}.about-xp .xp-years.years-abs{position:absolute;top:var(--xp-years-top);left:var(--xp-years-left)}@media screen and (max-width: 640px){.about-xp .xp-years{display:none}}.about-xp .xp-years-mob{margin-top:.5rem;display:inline-flex;align-self:flex-start;white-space:nowrap;border-radius:9999px;padding:.25rem .75rem;font-size:.9375rem;font-weight:700;line-height:1;color:var(--accent-color);background:rgba(var(--accent-color-rgb),.1)}@media (min-width: 640px){.about-xp .xp-years-mob{display:none}}.about-xp .xp-snippet{transition:opacity var(--xp-duration-function),visibility var(--xp-duration-function),transform var(--xp-duration-function),margin var(--xp-duration-function)}.about-xp .xp-snippet .cta{transition:transform var(--xp-duration-function)}.about-xp h4{letter-spacing:0!important;font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;font-size:1.25rem;line-height:1.125em}.about-xp h4 strong{color:var(--accent-color)}.about-xp p{font-size:1.125rem;color:var(--theme-text-fade-color);line-height:var(--paragraph-line-height, 1.777777778em)}.about-xp p strong{font-weight:700;color:var(--theme-text-color)}.about-xp p a{font-weight:600;transition:color .2s ease;color:var(--theme-article-link-color)}.about-xp p a:hover{color:var(--accent-color)}.about-xp p a strong{color:inherit}.about-xp .cta{margin-top:.5rem;display:flex;align-items:center;justify-content:flex-start;align-self:flex-start;font-size:.9375rem;font-weight:700;--tw-text-opacity: 1;color:rgb(57 172 201 / var(--tw-text-opacity))}.about-xp .cta:after{content:"";display:inline-block;width:1em;height:1em;margin-left:.5em;transition:transform var(--hover-duration, .2s) var(--hover-function, ease-in-out),color var(--hover-duration, .2s) var(--hover-function, ease-in-out);background:var(--accent-color);mask:var(--icon-arrow-svg) center center no-repeat;-webkit-mask:var(--icon-arrow-svg) center center no-repeat;mask-size:contain;-webkit-mask-size:contain}.about-xp .cta:hover:after{transform:translate(.25em)}.about-xp .xp-close{display:flex;height:2.5rem;width:2.5rem;align-items:center;justify-content:flex-start}.about-xp .xp-close .arrow{content:"";display:inline-block;width:1em;height:1em;transition:transform var(--hover-duration, .2s) var(--hover-function, ease-in-out),color var(--hover-duration, .2s) var(--hover-function, ease-in-out);background:var(--theme-text-color);mask:var(--icon-arrow-svg) center center no-repeat;-webkit-mask:var(--icon-arrow-svg) center center no-repeat;mask-size:contain;-webkit-mask-size:contain;font-size:25px;margin:0;--tw-rotate: 180deg;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))}.about-xp .xp-close.close-abs{visibility:hidden;position:absolute;transform-origin:left;--tw-translate-x: -.5rem;--tw-translate-y: -.25rem;--tw-scale-x: 0;--tw-scale-y: 0;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));opacity:0;left:var(--xp-close-left);top:var(--xp-close-top);transition:transform var(--xp-duration-function),visibility var(--xp-duration-function),opacity var(--xp-duration-function)}.about-xp .xp-item{position:relative;--xp-current-height: var(--xp-collapsed-height);--xp-expanded-height: calc(var(--xp-expanded-content-height) + 200px);--xp-expanded-content-margin: -13px;--xp-expanded-paragraph-line-height: 1px;--xp-expanded-content-gap: 1px;transition:height var(--xp-duration-function),margin var(--xp-duration-function),color var(--xp-duration-function),opacity .24s ease;--xp-duration-function: 0s linear}.about-xp .xp-item.is-init{--xp-duration-function: .45s cubic-bezier(.32, .72, 0, 1);height:var(--xp-current-height)}.about-xp .xp-item.is-not-expanded{opacity:.2;color:var(--theme-text-fade-color);--accent-color: var(--theme-text-fade-color)}.about-xp .xp-item.is-not-expanded .cta,.about-xp .xp-item.is-not-expanded p{color:var(--theme-text-fade-color)}.about-xp .xp-item.is-expanded{--xp-current-height: var(--xp-expanded-height);--xp-expanded-content-margin: 0;--xp-expanded-paragraph-line-height: var(--paragraph-line-height);--xp-expanded-content-gap: .75rem;border-color:rgba(var(--accent-color-rgb),.16)}.about-xp .xp-expanded-wrapper{position:absolute;top:0;left:0;width:100%}.about-xp .xp-expanded-wrapper .xp-expanded-heading{margin-bottom:.5rem;display:flex;align-items:center;justify-content:space-between;gap:2.5rem;visibility:hidden;opacity:0}.about-xp .xp-expanded-wrapper .xp-expanded-heading .xp-close-wrapper{margin-right:-2.5rem;width:2.5rem;flex:none}.about-xp .xp-expanded-wrapper .xp-expanded-heading .xp-title{display:flex;flex:1 1 auto;flex-direction:column;align-items:flex-start;justify-content:center;gap:0px}.about-xp .xp-expanded-wrapper .xp-expanded-heading .xp-biz{font-size:1.75rem;line-height:1.125em}.about-xp .xp-expanded-wrapper .xp-expanded-heading .xp-role{font-size:1.25rem;color:var(--accent-color)}.about-xp .xp-expanded-wrapper .xp-expanded-heading .xp-years{flex:none}.about-xp .xp-expanded-wrapper .xp-expanded-content{display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:.75rem;visibility:hidden;opacity:0;transition:margin var(--xp-duration-function),opacity var(--xp-duration-function),gap var(--xp-duration-function),visibility var(--xp-duration-function)}.about-xp .xp-expanded-wrapper.is-init .xp-expanded-content{margin-top:var(--xp-expanded-content-margin);gap:var(--xp-expanded-content-gap)}.about-xp .xp-expanded-wrapper.is-init .xp-expanded-content p{transition:visibility var(--xp-duration-function),opacity var(--xp-duration-function),transform var(--xp-duration-function),line-height var(--xp-duration-function);line-height:var(--xp-expanded-paragraph-line-height)}.about-xp .xp-expanded-wrapper.is-init .xp-expanded-content .cta{transition:visibility var(--xp-duration-function),transform var(--xp-duration-function),opacity var(--xp-duration-function),margin var(--xp-duration-function)}.about-xp .xp-clone{position:absolute;top:0;left:0;color:var(--theme-text-color);--xp-clone-x: var(--xp-clone-home-left);--xp-clone-y: var(--xp-clone-home-top);transform:translate(var(--xp-clone-x),var(--xp-clone-y));transition:color var(--xp-duration-function),margin var(--xp-duration-function),--xp-clone-x var(--xp-duration-function),--xp-clone-y var(--xp-duration-function),font-size var(--xp-duration-function)}@media screen and (max-width: 640px){.about-xp .xp-clone.xp-role{font-size:.9375rem;color:var(--accent-color)}}.about-xp .xp-item.is-expanded{position:relative}.about-xp .xp-item.is-expanded .xp-title{visibility:hidden;opacity:0}.about-xp .xp-item.is-expanded .xp-snippet{visibility:visible;opacity:0}.cloud-item.about-xp .xp-item.is-expanded .xp-snippet,.cloud-web-dev.about-xp .xp-item.is-expanded .xp-snippet{opacity:1}.about-xp .xp-item.is-expanded .xp-snippet,.about-xp .xp-item.is-expanded .xp-snippet .cta{transform:translateY(32px)}.about-xp .xp-item.is-expanded .xp-years.years-abs{--xp-years-top: var(--xp-years-expanded-top)}.about-xp .xp-item.is-expanded .xp-expanded-content{visibility:visible;opacity:1}.cloud-item.about-xp .xp-item.is-expanded .xp-expanded-content,.cloud-web-dev.about-xp .xp-item.is-expanded .xp-expanded-content{opacity:1}.about-xp .xp-item.is-expanded .xp-clone{visibility:visible;opacity:1}.cloud-item.about-xp .xp-item.is-expanded .xp-clone,.cloud-web-dev.about-xp .xp-item.is-expanded .xp-clone{opacity:1}.about-xp .xp-item.is-expanded .xp-clone{--xp-clone-x: var(--xp-clone-dest-left);--xp-clone-y: var(--xp-clone-dest-top)}.about-xp .xp-item.is-expanded .xp-clone.xp-biz{font-size:1.75rem}.about-xp .xp-item.is-expanded .xp-clone.xp-role{font-size:1.25rem;color:var(--accent-color)}.about-xp .xp-item.is-expanded .xp-close.close-abs{visibility:visible;--tw-translate-x: 0px;--tw-translate-y: 0px;--tw-scale-x: 1;--tw-scale-y: 1;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));opacity:1}.cloud-item.about-xp .xp-item.is-expanded .xp-close.close-abs,.cloud-web-dev.about-xp .xp-item.is-expanded .xp-close.close-abs{opacity:1}.about-xp .xp-test .xp-heading{z-index:100}.about-xp .xp-test .xp-expanded-heading,.about-xp .xp-test .xp-expanded-content{visibility:visible;z-index:10;opacity:1}.cloud-item.about-xp .xp-test .xp-expanded-heading,.cloud-web-dev.about-xp .xp-test .xp-expanded-heading,.cloud-item .about-xp .xp-test .xp-expanded-content,.cloud-web-dev .about-xp .xp-test .xp-expanded-content{opacity:1}.about-xp .xp-test .xp-expanded-heading,.about-xp .xp-test .xp-expanded-content{pointer-events:none}.about-personal{margin-left:auto;margin-right:auto;margin-top:4rem;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:2.5rem;padding:0 var(--padding-horiz);max-width:calc(var(--padding-horiz) * 2 + 800px)}.about-personal h2{font-family:Bricolage Grotesque,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-weight:800;letter-spacing:-.025em;line-height:1.1964285714em;font-size:2.25rem}.about-personal h2 strong{color:var(--accent-color)}.about-personal p{font-size:1.125rem;color:var(--theme-text-fade-color);line-height:var(--paragraph-line-height, 1.777777778em)}.about-personal p strong{font-weight:700;color:var(--theme-text-color)}.about-personal p .tx,.about-personal p code{display:inline-block;color:transparent;width:24px;height:32px;background-color:var(--theme-text-fade-color);-webkit-mask:url("data:image/svg+xml,%3Csvg width='92' height='86' viewBox='0 0 92 86' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M25.228 0.770996C32.167 0.770996 39.105 0.770996 46.045 0.770996C46.116 5.453 46.22 10.135 46.233 14.819C46.238 15.826 46.494 16.488 47.462 16.802C49.755 17.548 52.022 18.388 54.351 18.995C55.71 19.349 57.22 19.306 58.564 19.537C61.921 20.115 68.955 21.963 69.144 21.925C75.051 20.759 80.837 20.921 86.468 23.325C87.402 23.723 87.792 24.14 87.784 25.192C87.749 28.604 87.825 32.015 87.886 35.426C87.895 35.917 87.964 36.447 88.165 36.886C88.772 38.224 89.434 39.538 90.126 40.834C90.476 41.491 90.938 42.085 91.351 42.709C91.351 43.729 91.351 44.749 91.351 45.77C91.05 47.672 90.759 49.578 90.448 51.477C90.125 53.454 89.552 55.2 87.262 55.805C86.042 56.127 84.901 56.746 83.717 57.222C83.605 57.268 80.068 60.285 78.941 61.055C76.88 62.463 69.507 65.57 68.93 65.701C68.546 66.529 68.226 67.43 67.738 68.232C66.867 69.656 65.8 70.97 65 72.43C64.453 73.427 64.497 75.064 63.822 76.662C63.689 76.974 63.465 77.397 63.574 77.645C64.512 79.762 64.083 82.401 66.03 84.149C66.207 84.312 66.107 84.782 66.146 85.21C65.003 85.21 63.943 85.405 62.989 85.171C60.429 84.55 57.923 83.724 55.386 83.017C53.437 82.474 52.013 81.466 51.473 79.369C51.238 78.455 50.709 77.605 50.244 76.764C47.925 72.578 45.104 68.588 43.396 64.164C41.899 60.289 35.812 54.923 35.519 54.91C33.236 54.818 31.059 53.564 28.606 54.933C27.553 55.517 26.89 55.916 26.688 57.042C26.598 57.542 26.528 58.048 26.416 58.546C25.884 60.88 24.381 61.637 22.29 60.559C20.4 59.585 18.492 58.622 16.711 57.468C15.92 56.957 15.221 56.083 14.833 55.215C13.983 53.312 13.437 51.273 12.601 49.362C12.26 48.583 11.619 47.669 10.891 47.381C8.83001 46.572 7.47201 45.058 6.14301 43.434C5.66301 42.847 5.17701 41.974 4.56301 41.84C2.36701 41.365 1.43901 39.545 0.127014 38.114C0.127014 37.707 0.127014 37.298 0.127014 36.89C7.72401 36.854 15.32 36.772 22.916 36.822C24.465 36.832 24.855 36.421 24.864 34.872C24.924 23.507 25.093 12.139 25.228 0.770996Z' fill='%23718096'/%3E%3C/svg%3E%0A") center center no-repeat;mask:url("data:image/svg+xml,%3Csvg width='92' height='86' viewBox='0 0 92 86' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M25.228 0.770996C32.167 0.770996 39.105 0.770996 46.045 0.770996C46.116 5.453 46.22 10.135 46.233 14.819C46.238 15.826 46.494 16.488 47.462 16.802C49.755 17.548 52.022 18.388 54.351 18.995C55.71 19.349 57.22 19.306 58.564 19.537C61.921 20.115 68.955 21.963 69.144 21.925C75.051 20.759 80.837 20.921 86.468 23.325C87.402 23.723 87.792 24.14 87.784 25.192C87.749 28.604 87.825 32.015 87.886 35.426C87.895 35.917 87.964 36.447 88.165 36.886C88.772 38.224 89.434 39.538 90.126 40.834C90.476 41.491 90.938 42.085 91.351 42.709C91.351 43.729 91.351 44.749 91.351 45.77C91.05 47.672 90.759 49.578 90.448 51.477C90.125 53.454 89.552 55.2 87.262 55.805C86.042 56.127 84.901 56.746 83.717 57.222C83.605 57.268 80.068 60.285 78.941 61.055C76.88 62.463 69.507 65.57 68.93 65.701C68.546 66.529 68.226 67.43 67.738 68.232C66.867 69.656 65.8 70.97 65 72.43C64.453 73.427 64.497 75.064 63.822 76.662C63.689 76.974 63.465 77.397 63.574 77.645C64.512 79.762 64.083 82.401 66.03 84.149C66.207 84.312 66.107 84.782 66.146 85.21C65.003 85.21 63.943 85.405 62.989 85.171C60.429 84.55 57.923 83.724 55.386 83.017C53.437 82.474 52.013 81.466 51.473 79.369C51.238 78.455 50.709 77.605 50.244 76.764C47.925 72.578 45.104 68.588 43.396 64.164C41.899 60.289 35.812 54.923 35.519 54.91C33.236 54.818 31.059 53.564 28.606 54.933C27.553 55.517 26.89 55.916 26.688 57.042C26.598 57.542 26.528 58.048 26.416 58.546C25.884 60.88 24.381 61.637 22.29 60.559C20.4 59.585 18.492 58.622 16.711 57.468C15.92 56.957 15.221 56.083 14.833 55.215C13.983 53.312 13.437 51.273 12.601 49.362C12.26 48.583 11.619 47.669 10.891 47.381C8.83001 46.572 7.47201 45.058 6.14301 43.434C5.66301 42.847 5.17701 41.974 4.56301 41.84C2.36701 41.365 1.43901 39.545 0.127014 38.114C0.127014 37.707 0.127014 37.298 0.127014 36.89C7.72401 36.854 15.32 36.772 22.916 36.822C24.465 36.832 24.855 36.421 24.864 34.872C24.924 23.507 25.093 12.139 25.228 0.770996Z' fill='%23718096'/%3E%3C/svg%3E%0A") center center no-repeat;mask-size:contain;-webkit-mask:url("data:image/svg+xml,%3Csvg width='92' height='86' viewBox='0 0 92 86' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M25.228 0.770996C32.167 0.770996 39.105 0.770996 46.045 0.770996C46.116 5.453 46.22 10.135 46.233 14.819C46.238 15.826 46.494 16.488 47.462 16.802C49.755 17.548 52.022 18.388 54.351 18.995C55.71 19.349 57.22 19.306 58.564 19.537C61.921 20.115 68.955 21.963 69.144 21.925C75.051 20.759 80.837 20.921 86.468 23.325C87.402 23.723 87.792 24.14 87.784 25.192C87.749 28.604 87.825 32.015 87.886 35.426C87.895 35.917 87.964 36.447 88.165 36.886C88.772 38.224 89.434 39.538 90.126 40.834C90.476 41.491 90.938 42.085 91.351 42.709C91.351 43.729 91.351 44.749 91.351 45.77C91.05 47.672 90.759 49.578 90.448 51.477C90.125 53.454 89.552 55.2 87.262 55.805C86.042 56.127 84.901 56.746 83.717 57.222C83.605 57.268 80.068 60.285 78.941 61.055C76.88 62.463 69.507 65.57 68.93 65.701C68.546 66.529 68.226 67.43 67.738 68.232C66.867 69.656 65.8 70.97 65 72.43C64.453 73.427 64.497 75.064 63.822 76.662C63.689 76.974 63.465 77.397 63.574 77.645C64.512 79.762 64.083 82.401 66.03 84.149C66.207 84.312 66.107 84.782 66.146 85.21C65.003 85.21 63.943 85.405 62.989 85.171C60.429 84.55 57.923 83.724 55.386 83.017C53.437 82.474 52.013 81.466 51.473 79.369C51.238 78.455 50.709 77.605 50.244 76.764C47.925 72.578 45.104 68.588 43.396 64.164C41.899 60.289 35.812 54.923 35.519 54.91C33.236 54.818 31.059 53.564 28.606 54.933C27.553 55.517 26.89 55.916 26.688 57.042C26.598 57.542 26.528 58.048 26.416 58.546C25.884 60.88 24.381 61.637 22.29 60.559C20.4 59.585 18.492 58.622 16.711 57.468C15.92 56.957 15.221 56.083 14.833 55.215C13.983 53.312 13.437 51.273 12.601 49.362C12.26 48.583 11.619 47.669 10.891 47.381C8.83001 46.572 7.47201 45.058 6.14301 43.434C5.66301 42.847 5.17701 41.974 4.56301 41.84C2.36701 41.365 1.43901 39.545 0.127014 38.114C0.127014 37.707 0.127014 37.298 0.127014 36.89C7.72401 36.854 15.32 36.772 22.916 36.822C24.465 36.832 24.855 36.421 24.864 34.872C24.924 23.507 25.093 12.139 25.228 0.770996Z' fill='%23718096'/%3E%3C/svg%3E%0A") center center no-repeat;-webkit-mask-size:contain}.hero.hero-projects .hero-content{max-width:calc(var(--padding-horiz) * 2 + 800px)}.hero.hero-projects .hero-content h1{margin-bottom:1.5rem}@media (min-width: 640px){.hero.hero-projects .hero-content h1 strong{white-space:nowrap}}.hero.hero-project{margin-bottom:3.5rem}.hero.hero-project .hero-content{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:1.5rem;max-width:calc(var(--padding-horiz) * 2 + 688px)}.hero.hero-project .project-title h1{line-height:1.125em}.hero.hero-project .project-title h4{font-size:1.25rem;font-weight:700;line-height:1.25;letter-spacing:-.025em;color:var(--accent-color)}.hero.hero-project .project-title .btn-view{border-radius:.5rem;padding:.25rem .75rem;font-size:1.125rem;min-height:34px;display:inline-flex;align-items:center;justify-content:center;text-align:center;font-weight:700;line-height:1.375;letter-spacing:-.025em;transition:color .2s ease-in-out,background-color .2s ease-in-out;color:#fff;--arrow-color: #fff;background:var(--accent-color, --theme-blue);margin-top:.75rem;margin-bottom:1rem}.hero.hero-project .project-title .btn-view:after{content:"";display:inline-block;width:1em;height:1em;margin-left:.5em;transition:transform var(--hover-duration, .2s) var(--hover-function, ease-in-out),color var(--hover-duration, .2s) var(--hover-function, ease-in-out);background:var(--arrow-color, --theme-text-color);mask:var(--icon-arrow-svg) center center no-repeat;-webkit-mask:var(--icon-arrow-svg) center center no-repeat;mask-size:contain;-webkit-mask-size:contain}.hero.hero-project .project-title .btn-view:hover:after{transform:translate(.25em)}@media (min-width: 640px){.hero.hero-project .project-title{display:flex;width:100%;align-items:center;justify-content:space-between;gap:2rem;padding-left:1.5rem;padding-right:1.5rem}.hero.hero-project .project-title .btn-view{border-radius:.375rem;padding:.125rem .5rem;font-size:.9375rem;min-height:30px;flex:none;white-space:nowrap}}.hero.hero-project .project-featured-image{height:auto;width:100%;border-radius:1rem}.projects-listing{padding-top:3rem}.project-content .meta-container{--meta-margin-bottom: 0}.shiki-wrapper#m0vcra3n code .line:not(:last-child,:first-child) span:not(:first-child,:last-child),.shiki-wrapper#m0vcrsi8 code .line:not(:last-child,:first-child) span:not(:first-child,:last-child){color:#cad3f5!important}
