@media (prefers-color-scheme: dark){:root{--color-bg-primary: #161616;--color-bg-secondary: #202020;--color-bg-code: rgba(255, 255, 255, .1);--color-border: rgba(255, 255, 255, .2);--color-text-primary: #ffffff;--color-text-secondary: rgba(255, 255, 255, .5);--color-link: #FF5E5B;--button-primary-bg: #ffffff;--button-primary-hover-bg: #ffffff;--button-primary-text: #202020;--button-primary-hover-text: #202020;--button-secondary-bg: transparent;--button-secondary-hover-bg: transparent;--button-secondary-text: #ffffff;--button-secondary-hover-text: #FF5E5B;--tag-color: #FF5E5B;--outline-color: #FF5E5B;--cquircle: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjUiIGhlaWdodD0iNjUiIHZpZXdCb3g9IjAgMCA2NSA2NSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTAgMzJDMCAyMC43OTg5IDAgMTUuMTk4NCAyLjE3OTg3IDEwLjkyMDJDNC4wOTczNCA3LjE1Njk1IDcuMTU2OTUgNC4wOTczNCAxMC45MjAyIDIuMTc5ODdDMTUuMTk4NCAwIDIwLjc5OSAwIDMyIDBIMzNDNDQuMjAxMSAwIDQ5LjgwMTYgMCA1NC4wNzk4IDIuMTc5ODdDNTcuODQzMSA0LjA5NzM0IDYwLjkwMjcgNy4xNTY5NSA2Mi44MjAxIDEwLjkyMDJDNjUgMTUuMTk4NCA2NSAyMC43OTkgNjUgMzJWMzNDNjUgNDQuMjAxMSA2NSA0OS44MDE2IDYyLjgyMDEgNTQuMDc5OEM2MC45MDI3IDU3Ljg0MzEgNTcuODQzMSA2MC45MDI3IDU0LjA3OTggNjIuODIwMUM0OS44MDE2IDY1IDQ0LjIwMSA2NSAzMyA2NUgzMkMyMC43OTg5IDY1IDE1LjE5ODQgNjUgMTAuOTIwMiA2Mi44MjAxQzcuMTU2OTUgNjAuOTAyNyA0LjA5NzM0IDU3Ljg0MzEgMi4xNzk4NyA1NC4wNzk4QzAgNDkuODAxNiAwIDQ0LjIwMSAwIDMzVjMyWiIgZmlsbD0iIzIwMjAyMCIvPgo8L3N2Zz4K);--font-weight: 200}}@media (prefers-color-scheme: light){:root{--color-bg-primary: #F5F5F5;--color-bg-secondary: #EDEDED;--color-bg-code: rgba(34, 34, 34, .1);--color-border: rgba(34, 34, 34, .1);--color-text-primary: #222222;--color-text-secondary: rgba(34, 34, 34, .7);--color-link: #FF5E5B;--button-primary-bg: #161616;--button-primary-hover-bg: #FF5E5B;--button-primary-text: #ffffff;--button-primary-hover-text: #FF5E5B;--button-secondary-bg: transparent;--button-secondary-hover-bg: #FF5E5B;--button-secondary-text: #161616;--button-secondary-hover-text: #ffffff;--tag-color: #FF5E5B;--outline-color: #FF5E5B;--cquircle: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjUiIGhlaWdodD0iNjUiIHZpZXdCb3g9IjAgMCA2NSA2NSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTAgMzJDMCAyMC43OTg5IDAgMTUuMTk4NCAyLjE3OTg3IDEwLjkyMDJDNC4wOTczNCA3LjE1Njk1IDcuMTU2OTUgNC4wOTczNCAxMC45MjAyIDIuMTc5ODdDMTUuMTk4NCAwIDIwLjc5OSAwIDMyIDBIMzNDNDQuMjAxMSAwIDQ5LjgwMTYgMCA1NC4wNzk4IDIuMTc5ODdDNTcuODQzMSA0LjA5NzM0IDYwLjkwMjcgNy4xNTY5NSA2Mi44MjAxIDEwLjkyMDJDNjUgMTUuMTk4NCA2NSAyMC43OTkgNjUgMzJWMzNDNjUgNDQuMjAxMSA2NSA0OS44MDE2IDYyLjgyMDEgNTQuMDc5OEM2MC45MDI3IDU3Ljg0MzEgNTcuODQzMSA2MC45MDI3IDU0LjA3OTggNjIuODIwMUM0OS44MDE2IDY1IDQ0LjIwMSA2NSAzMyA2NUgzMkMyMC43OTg5IDY1IDE1LjE5ODQgNjUgMTAuOTIwMiA2Mi44MjAxQzcuMTU2OTUgNjAuOTAyNyA0LjA5NzM0IDU3Ljg0MzEgMi4xNzk4NyA1NC4wNzk4QzAgNDkuODAxNiAwIDQ0LjIwMSAwIDMzVjMyWiIgZmlsbD0iI0VERURFRCIvPgo8L3N2Zz4K);--font-weight: 300}}:root{--font-size-code: 14px;--font-size-small: 16px;--font-size-medium: 18px;--font-size-h1: clamp(3rem, 2.75rem + 1.3333vw, 3.75rem);--font-size-h2: 32px}h1{margin:80px 0;font-family:Merriweather,serif;font-weight:900;font-style:normal;font-size:var(--font-size-h1);line-height:120%}h1 .date{display:block;padding-top:20px;font-size:var(--font-size-small);font-weight:300;line-height:100%;color:var(--color-text-secondary)}h2{margin:60px 0 16px;font-family:Merriweather,serif;font-weight:900;font-style:normal;font-size:var(--font-size-h2);line-height:150%}h3{margin:0 0 8px;font-weight:500;font-size:clamp(1rem,.9457rem + .3478vw,1.25rem);line-height:150%}code:not(.example__code code){font-family:IBM Plex Mono,monospace;font-size:.9em;background:var(--color-bg-code);border-radius:4px;display:inline-block;padding:0 4px}p{font-weight:var(--font-weight);margin-bottom:20px;line-height:150%}p:last-child{margin:0}article p{line-height:170%}p:not(:last-child){margin:0 0 20px}.link,.link:visited,article a,article a:visited{color:currentColor;text-decoration-color:color-mix(in srgb,currentColor,transparent 70%);text-decoration-thickness:3px;transition:color .2s cubic-bezier(.22,.61,.36,1),text-decoration-color .2s cubic-bezier(.22,.61,.36,1),outline .2s cubic-bezier(.22,.61,.36,1)}.link:hover,.link:active,article a:hover,article a:active{color:var(--color-link);text-decoration-color:color-mix(in srgb,var(--color-link) 70%,transparent)}.link:focus-visible,article a:focus-visible{outline-color:var(--outline-color);outline-style:solid;outline-width:3px;outline-offset:2px;border-radius:2px;text-decoration-thickness:0}.merriweather-light{font-family:Merriweather,serif;font-weight:300;font-style:normal}.merriweather-regular{font-family:Merriweather,serif;font-weight:400;font-style:normal}.merriweather-bold{font-family:Merriweather,serif;font-weight:700;font-style:normal}.merriweather-black{font-family:Merriweather,serif;font-weight:900;font-style:normal}.merriweather-light-italic{font-family:Merriweather,serif;font-weight:300;font-style:italic}.merriweather-regular-italic{font-family:Merriweather,serif;font-weight:400;font-style:italic}.merriweather-bold-italic{font-family:Merriweather,serif;font-weight:700;font-style:italic}.merriweather-black-italic{font-family:Merriweather,serif;font-weight:900;font-style:italic}.ibm-plex-mono-regular{font-family:IBM Plex Mono,monospace;font-weight:400;font-style:normal}.ibm-plex-mono-semibold{font-family:IBM Plex Mono,monospace;font-weight:600;font-style:normal}.ibm-plex-mono-regular-italic{font-family:IBM Plex Mono,monospace;font-weight:400;font-style:italic}.ibm-plex-mono-semibold-italic{font-family:IBM Plex Mono,monospace;font-weight:600;font-style:italic}.ibm-plex-sans-light{font-family:IBM Plex Sans,sans-serif;font-weight:300;font-style:normal}.ibm-plex-sans-regular{font-family:IBM Plex Sans,sans-serif;font-weight:400;font-style:normal}.ibm-plex-sans-light-italic{font-family:IBM Plex Sans,sans-serif;font-weight:300;font-style:italic}.ibm-plex-sans-regular-italic{font-family:IBM Plex Sans,sans-serif;font-weight:400;font-style:italic}.tag-list{display:flex;justify-content:center;gap:8px}.tag{display:flex;align-items:center;height:28px;padding:0 12px;box-sizing:border-box;border:1px solid var(--tag-color);border-radius:99rem;font-size:var(--font-size-small);color:var(--tag-color);cursor:pointer;transition:color .2s cubic-bezier(.22,.61,.36,1),border-color .2s cubic-bezier(.22,.61,.36,1),outline .2s cubic-bezier(.22,.61,.36,1)}.button{display:flex;align-items:center;height:50px;padding:0 20px;gap:8px;border-radius:99em;text-decoration:none;box-sizing:border-box;transition:border-color .2s cubic-bezier(.22,.61,.36,1),background-color .2s cubic-bezier(.22,.61,.36,1),color .2s cubic-bezier(.22,.61,.36,1)}.button:has(svg){padding-left:16px}.button-primary{background-color:var(--button-primary-bg);color:var(--button-primary-text)}.button-secondary{background-color:var(--button-secondary-bg);color:var(--button-secondary-text);border:1px solid currentColor}.button-secondary:hover{background-color:var(--button-secondary-hover-bg);color:var(--button-secondary-hover-text)}.button-secondary:focus-visible{outline-color:var(--outline-color);outline-style:solid;outline-width:3px;outline-offset:2px}.example .controls{position:absolute;bottom:8px;left:50%;display:flex;flex-wrap:wrap;justify-content:center;max-width:100%;width:max-content;gap:8px;padding:8px;background:#d8d8d8;border-radius:8px;translate:-50%}.example .controls .color-picker{position:relative;width:32px;height:32px;background-color:var(--color, black);border-radius:4px}.example .controls .color-picker:before{content:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="none"><path stroke="%23fff" stroke-linecap="round" d="m7.927 4.788 3.535 3.535M13.23 3.02c-.707-.707-2.121-.707-2.828 0-.418.417-.712.958-.883 1.33a2.62 2.62 0 0 1-.512.772L2.86 11.27a1 1 0 0 0-.283.565l-.268 1.881a.2.2 0 0 0 .226.226l1.88-.268a1 1 0 0 0 .566-.283l6.149-6.148c.219-.22.488-.383.77-.512.373-.171.914-.465 1.331-.883.707-.707.707-2.121 0-2.828Z"/></svg>');width:16px;height:16px;line-height:16px;position:absolute;top:50%;left:50%;translate:-50% -50%;mix-blend-mode:exclusion}.example .controls .color-picker input{width:100%;height:100%;opacity:0;cursor:pointer}.example .controls label{display:flex;flex-direction:column;align-items:center;font-size:var(--font-size-code)}.example{position:relative;display:grid;margin-bottom:40px;border:1px solid var(--color-border);border-radius:8px;font-family:IBM Plex Mono,monospace;overflow:hidden}.example__view{position:relative;overflow:hidden}.example__code{padding:16px 20px;border-radius:0;background:var(--color-bg-code)}.example__code,.example__code code{margin:0}.example{accent-color:light-dark(#333,#fff)}@media (width < 600px){.example{grid-template-columns:1fr!important}}.example-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:40px}.example-grid .example{margin:0}code[class*=language-],pre[class*=language-]{color:var(--color-text-primary);font-family:IBM Plex Mono,monospace;font-size:var(--font-size-code);text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:150%;tab-size:4;hyphens:none}pre[class*=language-]{overflow:auto}:not(pre)>code[class*=language-]{white-space:normal}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:#708090}.token.punctuation{color:#999}.token.namespace{opacity:.7}.token.property,.token.tag,.token.boolean,.token.number,.token.constant,.token.symbol,.token.deleted{color:#ff5e5b}.token.selector,.token.attr-name,.token.string,.token.char,.token.builtin,.token.inserted{color:#009423}.token.operator,.token.entity,.token.url,.language-css .token.string,.style .token.string{color:#9a6e3a;background:#ffffff80}.token.atrule,.token.attr-value,.token.keyword{color:#07a}.token.function,.token.class-name{color:#dd4a68}.token.regex,.token.important,.token.variable{color:#e90}.token.important,.token.bold{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}:root{color-scheme:light dark}html{background:var(--color-bg-primary);color:var(--color-text-primary);font-family:IBM Plex Sans,sans-serif;font-size:var(--font-size-medium);font-weight:var(--font-weight);font-style:normal;line-height:150%;font-feature-settings:"lnum" on}body{margin:0 auto;padding:0 32px 40px}.main-page,.error-page{max-width:970px}.demo-page{max-width:970px;text-align:center}.post-page{max-width:640px}.post-page h1{text-align:center}.post-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:20px}.post-mini-list{display:grid;grid-template-columns:1fr 1fr;gap:8px}.demo{position:relative;max-width:1000px;height:100%;min-height:600px;margin:auto;border-radius:20px;overflow:hidden}.links{display:flex;gap:40px;margin:40px 0;align-items:center;justify-content:center}.caption,.caption a{margin-top:16px!important;font-size:var(--font-size-small);color:var(--color-text-secondary);text-align:center}ul{padding:0;list-style:none}.social-links{display:flex;flex-wrap:wrap;align-items:center;gap:20px;row-gap:8px;margin:0}.social-links .link{display:flex}.link.social-links__youtube:hover{color:red}.link.social-links__codepen:hover{color:#0ebeff}.link.social-links__twitter:hover{color:#1da1f2}.link.social-links__mastodon:hover{color:#4f45d7}.link.social-links__linkedin:hover{color:#0a66c2}.link.social-links__bluesky:hover{color:#1185fe}.toc #contents{display:none}@view-transition{navigation: auto;}.main-page[data-astro-cid-3ef6ksr2] .header[data-astro-cid-3ef6ksr2]{max-width:970px}.post-page[data-astro-cid-3ef6ksr2] .header[data-astro-cid-3ef6ksr2]{max-width:640px}.header[data-astro-cid-3ef6ksr2]{display:flex;padding:32px 0;margin:auto;justify-content:space-between;line-height:100%;position:sticky;top:-1px;z-index:2;transition-duration:.2s;transition-timing-function:cubic-bezier(.22,.61,.36,1);transition-property:padding,background-color,backdrop-filter}.header[data-astro-cid-3ef6ksr2].sticky{background-color:color-mix(in srgb,var(--color-bg-primary),transparent 10%);padding:16px 0;backdrop-filter:blur(1vw)}.header__logo[data-astro-cid-3ef6ksr2]{display:flex;gap:8px;align-items:center}@media (width < 450px){.header__logo[data-astro-cid-3ef6ksr2] span[data-astro-cid-3ef6ksr2]{display:none}}.header[data-astro-cid-3ef6ksr2] .link[data-astro-cid-3ef6ksr2],.header[data-astro-cid-3ef6ksr2] .link[data-astro-cid-3ef6ksr2]:focus-visible{text-decoration:none;border-radius:99rem;outline-offset:8px}.footer[data-astro-cid-sz7xmlte]{margin-top:80px;font-size:var(--font-size-small);color:var(--color-text-secondary);text-align:center}.footer[data-astro-cid-sz7xmlte] .social-links[data-astro-cid-sz7xmlte]{justify-content:center}.footer[data-astro-cid-sz7xmlte] .link[data-astro-cid-sz7xmlte]:not(:hover){color:var(--color-text-secondary)}
