@import "https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,700;1,9..144,400;1,9..144,500&family=Raleway:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:root,:host{--font-mono:var(--font-mono);--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--ease-out:cubic-bezier(0, 0, .2, 1);--default-font-family:var(--font-body);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.visible{visibility:visible}.sticky{position:sticky}.table{display:table}.italic{font-style:italic}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}}:root{--color-paper:oklch(100% 0 0);--color-paper-2:oklch(96% .002 17.2);--color-rule:oklch(92.2% .005 34.3);--color-mute:oklch(54.7% .021 43.1);--color-ink-soft:oklch(35% .006 49.3);--color-ink:oklch(14.7% .004 49.3);--color-accent:oklch(52.7% .154 150.069);--color-accent-2:oklch(62.7% .194 149.214);--color-focus:oklch(52.7% .154 150.069);--color-selection:oklch(87.1% .15 154.449);--font-display:"Fraunces", ui-serif, Georgia, serif;--font-body:"Raleway", ui-sans-serif, system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--space-3xs:.125rem;--space-2xs:.25rem;--space-xs:.5rem;--space-sm:.75rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2.5rem;--space-2xl:4rem;--space-3xl:6rem;--space-4xl:9rem;--text-xs:.8rem;--text-sm:.9rem;--text-base:1rem;--text-md:1.125rem;--text-lg:1.375rem;--text-xl:1.75rem;--text-2xl:2.2rem;--text-3xl:2.75rem;--text-display:clamp(2.5rem, 4.4vw + 1rem, 4.5rem);--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in:cubic-bezier(.7, 0, .84, 0);--ease-in-out:cubic-bezier(.65, 0, .35, 1);--dur-micro:.12s;--dur-short:.22s;--dur-long:.42s;--rule:1px solid var(--color-rule);--measure:62ch;--page-gutter:clamp(1.25rem, 4vw, 2.5rem)}html,body{overflow-x:clip}html{background:var(--color-paper);color:var(--color-ink)}body{min-height:100dvh;font-family:var(--font-body);font-size:var(--text-md);color:var(--color-ink);background:var(--color-paper);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"ss01", "cv11";margin:0;line-height:1.6}::selection{background:var(--color-selection);color:var(--color-ink)}:focus-visible{outline:2px solid var(--color-focus);outline-offset:3px;border-radius:2px}a{color:var(--color-ink);text-decoration:underline;-webkit-text-decoration-color:var(--color-rule);-webkit-text-decoration-color:var(--color-rule);-webkit-text-decoration-color:var(--color-rule);text-decoration-color:var(--color-rule);text-underline-offset:.18em;transition:text-decoration-color var(--dur-short) var(--ease-out), color var(--dur-short) var(--ease-out);text-decoration-thickness:1px}a:hover{-webkit-text-decoration-color:var(--color-accent);-webkit-text-decoration-color:var(--color-accent);-webkit-text-decoration-color:var(--color-accent);text-decoration-color:var(--color-accent);color:var(--color-ink)}p{max-width:var(--measure);margin:0}p+p{margin-top:var(--space-md)}strong{color:var(--color-ink);font-weight:600}em{font-family:var(--font-display);font-style:italic;font-weight:400}code,kbd,pre{font-family:var(--font-mono);font-feature-settings:"tnum";font-size:.92em}code{background:var(--color-paper-2);border:var(--rule);border-radius:3px;padding:.1em .4em;font-size:.86em}pre code{font-size:inherit;background:0 0;border:0;border-radius:0;padding:0}.reveal{opacity:0;animation:reveal var(--dur-long) var(--ease-out) forwards;animation-delay:calc(var(--i,0) * 70ms);transform:translateY(8px)}@keyframes reveal{to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.15s!important;animation-duration:.15s!important;animation-iteration-count:1!important}.reveal{transform:none}}.page{grid-template-rows:auto 1fr auto;grid-template-columns:minmax(0,1fr);width:100%;max-width:100%;min-height:100dvh;display:grid}.page>*{min-width:0;max-width:100%}.gutter{padding-inline:var(--page-gutter);box-sizing:border-box;min-width:0;max-width:100%}.measure{max-width:var(--measure)}.nav{justify-content:space-between;align-items:center;gap:var(--space-sm) var(--space-md);padding-block:var(--space-md);border-bottom:var(--rule);flex-wrap:wrap;display:flex}.nav__mark{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:var(--text-lg);letter-spacing:-.01em;color:var(--color-ink);font-variation-settings:"opsz" 36;align-items:center;gap:.6rem;line-height:1;text-decoration:none;display:inline-flex}.nav__glyph{object-fit:cover;border-radius:50%;flex-shrink:0;width:28px;height:28px;display:block}.nav__mark:hover{color:var(--color-accent)}.nav__cta{font-family:var(--font-body);font-size:var(--text-sm);letter-spacing:.04em;text-transform:uppercase;color:var(--color-ink-soft);white-space:nowrap;border-bottom:1px solid var(--color-rule);padding-bottom:.15em;text-decoration:none}.nav__cta:hover{color:var(--color-ink);border-bottom-color:var(--color-accent)}.nav__links{justify-content:flex-end;align-items:baseline;gap:var(--space-sm) var(--space-lg);flex-wrap:wrap;min-width:0;display:flex}.nav__cta--primary{color:var(--color-ink);border-bottom-color:var(--color-accent)}.nav__cta--primary:hover{color:var(--color-accent)}.article{width:100%;max-width:min(42rem,100%);padding-block:clamp(var(--space-2xl), 8vw, var(--space-3xl)) var(--space-3xl);font-size:var(--text-md);box-sizing:border-box;min-width:0;margin-inline:auto}.article>*+*{margin-top:var(--space-lg)}.article>section{min-width:0}.hero{padding-block:var(--space-xl) clamp(var(--space-2xl), 8vw, var(--space-3xl))}.hero__salutation{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:var(--text-md);font-variation-settings:"opsz" 24;color:var(--color-accent);margin-bottom:var(--space-md);letter-spacing:.005em}.hero__lede{font-family:var(--font-display);font-variation-settings:"opsz" 96;letter-spacing:-.015em;color:var(--color-ink);overflow-wrap:anywhere;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;min-width:0;max-width:30ch;font-size:clamp(1.4rem,1.5vw + 1rem,2.2rem);font-weight:400;line-height:1.25}.hero__lede em{color:var(--color-ink);font-style:italic;font-weight:500}.hero__meta{gap:var(--space-md);margin-top:var(--space-lg);font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.04em;text-transform:uppercase;color:var(--color-mute);align-items:center;display:flex}.hero__meta:before{content:"";background:var(--color-rule);width:2.5rem;height:1px;display:block}.h-section{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:var(--text-xl);font-variation-settings:"opsz" 60;letter-spacing:-.01em;color:var(--color-ink);margin-top:var(--space-2xl);margin-bottom:var(--space-md);overflow-wrap:anywhere;min-width:0;line-height:1.2}.h-section--first{margin-top:0}.aside{font-family:var(--font-display);font-style:italic;font-size:var(--text-md);font-variation-settings:"opsz" 18;color:var(--color-ink-soft);border-inline-start:2px solid var(--color-accent);padding-inline-start:var(--space-md)}.steps{gap:var(--space-xl);margin:0;padding:0;list-style:none;display:grid}.steps>li{gap:var(--space-md);grid-template-columns:4rem 1fr;align-items:baseline;display:grid}.steps__num{font-family:var(--font-mono);font-size:var(--text-sm);letter-spacing:.02em;color:var(--color-accent);font-feature-settings:"tnum"}.steps__title{font-family:var(--font-display);font-style:normal;font-weight:500;font-size:var(--text-lg);font-variation-settings:"opsz" 40;letter-spacing:-.01em;margin:0 0 var(--space-2xs) 0;color:var(--color-ink);overflow-wrap:anywhere;min-width:0}.steps__body{color:var(--color-ink-soft);font-size:var(--text-base);max-width:52ch;margin:0}.spec{border-collapse:collapse;width:100%;font-size:var(--text-sm);font-feature-settings:"tnum";text-align:start}.spec th,.spec td{padding-block:var(--space-sm);border-bottom:var(--rule);vertical-align:baseline;text-align:start}.spec th{font-family:var(--font-mono);letter-spacing:.02em;color:var(--color-ink-soft);font-weight:500;font-size:var(--text-xs);text-transform:uppercase;width:7.5rem;padding-inline-end:var(--space-md)}.spec td{color:var(--color-ink);font-family:var(--font-body)}.spec td .muted{color:var(--color-mute);font-size:var(--text-xs);margin-top:var(--space-2xs);display:block}.code{background:var(--color-paper-2);border:var(--rule);padding:var(--space-md) var(--space-lg);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-ink);-webkit-overflow-scrolling:touch;border-radius:4px;min-width:0;max-width:100%;line-height:1.7;position:relative;overflow-x:auto}.code__label{font-size:var(--text-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--color-mute);margin-bottom:var(--space-sm);display:block}.code pre{white-space:pre;margin:0}.code .prompt{color:var(--color-accent);-webkit-user-select:none;user-select:none;margin-inline-end:.5em}.code .comment{color:var(--color-mute)}.link-cta{font-family:var(--font-body);font-weight:500;font-size:var(--text-md);color:var(--color-ink);border-bottom:1px solid var(--color-ink);white-space:nowrap;align-items:baseline;gap:.5em;padding-bottom:.1em;text-decoration:none;display:inline-flex}.link-cta:hover{color:var(--color-accent);border-bottom-color:var(--color-accent)}.link-cta:active{color:var(--color-accent-2);transform:translateY(1px)}.link-cta[aria-disabled=true],.link-cta:disabled{color:var(--color-mute);border-bottom-color:var(--color-rule);cursor:not-allowed;pointer-events:none}.link-cta__arrow{transition:transform var(--dur-short) var(--ease-out);display:inline-block}.link-cta:hover .link-cta__arrow{transform:translate(2px)}.screens-section>p{color:var(--color-ink-soft);font-size:var(--text-base)}.screens{gap:var(--space-lg);margin-top:var(--space-xl);margin-bottom:var(--space-md);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.screen{gap:var(--space-md);flex-direction:column;min-width:0;margin:0;display:flex}.screen__frame{background:var(--color-paper-2);border:1px solid var(--color-rule);border-radius:14px;overflow:hidden;box-shadow:0 1px 2px oklch(14.7% .004 49.3/.04),0 8px 24px -12px oklch(14.7% .004 49.3/.08)}.screen__frame img{width:100%;height:auto;display:block}.screen__caption{font-family:var(--font-display);font-variation-settings:"opsz" 24;font-style:italic;font-weight:400;font-size:var(--text-base);color:var(--color-ink-soft);max-width:28ch;padding-inline:var(--space-2xs);line-height:1.4}.absent{gap:var(--space-sm);margin:0;padding:0;list-style:none;display:grid}.absent>li{gap:var(--space-sm);color:var(--color-ink-soft);font-size:var(--text-base);grid-template-columns:1.25rem 1fr;align-items:baseline;max-width:56ch;display:grid}.absent>li:before{content:"×";font-family:var(--font-display);font-style:italic;font-size:var(--text-md);color:var(--color-accent);text-align:center}.hiw__back{font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-ink-soft);border-bottom:1px solid var(--color-rule);transition:color var(--dur-short) var(--ease-out), border-bottom-color var(--dur-short) var(--ease-out);padding-bottom:.1em;text-decoration:none}.hiw__back:hover{color:var(--color-accent);border-bottom-color:var(--color-accent)}.hiw__list{margin:var(--space-md) 0;gap:var(--space-xs);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-ink-soft);font-feature-settings:"tnum";max-width:56ch;padding:0;list-style:none;display:grid}.hiw__list>li{border-inline-start:1px solid var(--color-rule);padding-inline-start:var(--space-md)}.hiw__list strong{color:var(--color-ink);font-weight:600}.hiw__refs{margin:var(--space-md) 0 0;color:var(--color-ink-soft);font-size:var(--text-sm);max-width:60ch;padding-inline-start:var(--space-lg)}.hiw__refs>li{margin-block:var(--space-sm);line-height:1.55}.hiw__refs>li::marker{color:var(--color-mute);font-family:var(--font-mono);font-size:.85em}.hiw__sup{font-feature-settings:"sups";font-size:.75em}.hiw__sup a{color:var(--color-accent);margin-inline-start:.15em;text-decoration:none}.hiw__sup a:hover{color:var(--color-accent-2);text-decoration:underline}.steps__more{margin-top:var(--space-lg);font-size:var(--text-sm);color:var(--color-ink-soft);padding-inline-start:4rem}@media (width<=40rem){.steps__more{padding-inline-start:3rem}}.foot{border-top:var(--rule);padding-block:var(--space-xl);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-mute);letter-spacing:.01em;line-height:1.7}.foot__inner{gap:var(--space-md);max-width:52rem;margin-inline:auto;display:grid}.foot__line{max-width:70ch;margin:0}.foot__meta{gap:0 var(--space-md);color:var(--color-ink-soft);flex-wrap:wrap;align-items:baseline;display:flex}.foot__meta span{white-space:nowrap}.foot__meta .dot{color:var(--color-rule)}.foot__creator,.foot__github{color:var(--color-ink-soft);text-decoration:underline;-webkit-text-decoration-color:var(--color-rule);-webkit-text-decoration-color:var(--color-rule);-webkit-text-decoration-color:var(--color-rule);text-decoration-color:var(--color-rule);text-underline-offset:.18em;transition:text-decoration-color var(--dur-short) var(--ease-out), color var(--dur-short) var(--ease-out)}.foot__creator:hover,.foot__github:hover{color:var(--color-accent);-webkit-text-decoration-color:var(--color-accent);-webkit-text-decoration-color:var(--color-accent);-webkit-text-decoration-color:var(--color-accent);text-decoration-color:var(--color-accent)}@media (width<=48rem){.screens{gap:var(--space-xl);grid-template-columns:minmax(0,1fr);max-width:22rem;margin-inline:auto}.screen__caption{text-align:center;max-width:none}}@media (width<=40rem){.nav__cta{letter-spacing:.04em;font-size:.75rem}.nav__links{gap:var(--space-xs) var(--space-md)}.nav__glyph{width:24px;height:24px}.nav__mark{font-size:var(--text-md)}.steps>li{gap:var(--space-sm);grid-template-columns:3rem 1fr}.spec th{width:6rem;font-size:.7rem}.code{padding:var(--space-sm) var(--space-md)}.hero__lede{max-width:100%}}@media (width<=24rem){.nav__cta{font-size:.7rem}}@media (width<=28rem){.spec,.spec tbody,.spec tr{display:block}.spec th,.spec td{border-bottom:0;width:100%;padding-inline:0;display:block}.spec th{padding-bottom:var(--space-2xs);border-bottom:0}.spec td{padding-top:0;padding-bottom:var(--space-md);border-bottom:var(--rule)}}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}
