.article-toc[data-v-ac5b813c]{max-height:calc(100vh - 120px);padding:0;font-size:14px;position:sticky;top:96px;overflow:auto}.toc-title[data-v-ac5b813c]{color:color-mix(in srgb, var(--brand-text-muted) 75%, white);align-items:center;gap:.5rem;margin:0 0 .5rem;font-size:14px;font-weight:500;display:flex}.toc-title__icon[data-v-ac5b813c]{color:var(--brand-text-muted);flex:none}.article-toc .toc-list[data-v-ac5b813c]{margin:0;padding:0;list-style:none;position:relative}.article-toc li[data-v-ac5b813c]{margin:0;padding:0;line-height:1;position:relative}.article-toc .toc-link[data-v-ac5b813c]{color:var(--brand-text-muted);align-items:center;min-height:14px;padding-block:6px;line-height:1;text-decoration:none;transition:color .15s;display:flex;position:relative}.article-toc .toc-list>li+li[data-v-ac5b813c],.article-toc .toc-list--nested>li+li[data-v-ac5b813c]{margin-top:0}.article-toc .toc-link[data-v-ac5b813c]:hover,.article-toc li.active .toc-link[data-v-ac5b813c],.article-toc li.visible .toc-link[data-v-ac5b813c]{color:var(--brand-pink)}.article-toc .toc-vert[data-v-ac5b813c]{background:var(--toc-stroke);inset-block:0;width:1px;position:absolute;top:0;bottom:0}.article-toc .toc-diag[data-v-ac5b813c]{position:absolute;top:-6px;overflow:visible}.article-toc .toc-stroke[data-v-ac5b813c]{stroke:var(--toc-stroke)}.article-toc li[data-v-ac5b813c]{--toc-stroke:color-mix(in srgb, var(--brand-border) 65%, transparent)}.article-toc li.active[data-v-ac5b813c],.article-toc li.visible[data-v-ac5b813c]{--toc-stroke:var(--brand-pink)}.article-toc .toc-vert--cut-top[data-v-ac5b813c]{top:6px}.article-toc .toc-vert--cut-bottom[data-v-ac5b813c]{bottom:6px}.related-posts[data-v-d473c38d]{margin-top:40px}.related-posts-heading[data-v-d473c38d]{color:var(--brand-text);margin-bottom:16px;font-size:1.25rem;font-weight:700}.blog-article{color:var(--brand-text);font-size:1.0625rem;line-height:1.75}.blog-article>:first-child,.blog-article>:first-child>:first-child{margin-top:0}.blog-article h1,.blog-article h2,.blog-article h3,.blog-article h4{color:var(--brand-cyan);letter-spacing:-.02em;scroll-margin-top:96px;font-weight:700}.blog-article h1{margin:0 0 1rem;font-size:clamp(1.75rem,4vw,2.25rem);line-height:1.2}.blog-article h2{border-bottom:1px solid var(--brand-border);margin:2.25rem 0 .75rem;padding-bottom:.35rem;font-size:1.35rem}.blog-article h3{margin:1.75rem 0 .5rem;font-size:1.125rem}.blog-article h4{margin:1.25rem 0 .35rem;font-size:1rem}.blog-article p{margin:0 0 1rem}.blog-article a{color:var(--brand-pink);border-bottom:1px solid #0000;text-decoration:none;transition:color .15s,border-color .15s}.blog-article a:hover{border-bottom-color:#ff006b73}.blog-article ul,.blog-article ol{margin:0 0 1rem;padding-left:1.35rem}.blog-article li{margin:.35rem 0}.blog-article blockquote{border-left:4px solid var(--brand-pink);color:var(--brand-text-muted);background:#ff006b0f;border-radius:0 8px 8px 0;margin:1.25rem 0;padding:.75rem 1rem}.blog-article hr{border:none;border-top:1px solid var(--brand-border);margin:2rem 0}.blog-article img{border:1px solid var(--brand-border);border-radius:12px;max-width:100%;height:auto}.blog-article table{border-collapse:collapse;width:100%;margin:1.25rem 0;font-size:.95rem;display:block;overflow-x:auto}.blog-article th,.blog-article td{border:1px solid var(--brand-border);text-align:left;padding:.5rem .75rem}.blog-article th{background:var(--brand-surface-2);font-weight:600}.blog-article code{font-family:var(--font-mono,"Roboto Mono", monospace);background:var(--brand-surface-2);border:1px solid var(--brand-border);border-radius:6px;padding:.12em .4em;font-size:.9em}.blog-article pre:not(.shiki){background:var(--brand-surface);border:1px solid var(--brand-border);border-radius:10px;margin:1.25rem 0;padding:1rem 1.1rem;font-size:.8125rem;line-height:1.55;overflow-x:auto}.blog-article pre.shiki{border:1px solid var(--brand-border);border-radius:10px;margin:1.25rem 0;padding:1rem 1.1rem;font-size:.8125rem;line-height:1.55;overflow-x:auto;background:var(--brand-surface)!important}.blog-article pre code{font-size:inherit;background:0 0;border:none;padding:0}.blog-article .blog-code{border:1px solid var(--brand-border);background:var(--brand-surface-2);border-radius:10px;margin:1.25rem 0;overflow:hidden}.blog-article .blog-code-header{background:0 0;align-items:center;gap:12px;padding:0;display:flex}.blog-article .blog-code-title{color:var(--brand-text-muted);text-overflow:ellipsis;white-space:nowrap;min-width:0;padding:0 16px;font-size:.8125rem;font-weight:600;overflow:hidden}.blog-article .blog-code-tabs{scrollbar-width:thin;outline:none;gap:14px;padding:0 16px;display:flex;overflow-x:auto}.blog-article .blog-code-tab{appearance:none;color:var(--brand-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:1px solid #0000;padding:8px 0;font-size:.875rem;font-weight:500;line-height:1.25rem;transition:color .15s}.blog-article .blog-code-tab[aria-selected=true]{color:var(--brand-pink);border-bottom-color:var(--brand-pink)}.blog-article .blog-code-tab:hover:not([aria-selected=true]){color:var(--brand-text)}.blog-article .blog-code-tab:focus-visible{border-radius:10px;outline:none;margin-left:-6px;margin-right:-6px;padding-left:6px;padding-right:6px;box-shadow:0 0 0 2px #ff006b73}.blog-article .blog-code-copy{width:28px;height:28px;color:var(--brand-text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s;display:inline-flex}.blog-article .blog-code-copy:hover{color:var(--brand-pink)}.blog-article .blog-code-copy:focus-visible{outline:none;box-shadow:0 0 0 2px #ff006b73}.blog-article .blog-code-body{border-top:1px solid var(--brand-border);background:var(--brand-surface);max-height:600px;padding:14px 16px;font-size:.8125rem;position:relative;overflow:auto}.blog-article .blog-code-copy-wrapper{z-index:2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;position:absolute;top:10px;right:8px}.blog-article .blog-code-render{font-size:inherit;line-height:1.55}.blog-article .blog-code-render pre{border:none;border-radius:0;margin:0;padding:0;background:0 0!important}.blog-article .blog-code-render pre.shiki{border:none;padding:0}.blog-article .sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.blog-article .table-of-contents{background:var(--brand-surface);border:1px solid var(--brand-border);border-radius:12px;margin:1.5rem 0;padding:1rem 1.25rem;font-size:.95rem}.blog-article .table-of-contents ul{margin:0;padding-left:0;list-style:none}.blog-article .table-of-contents li{margin:.25rem 0}.blog-article .table-of-contents a{color:var(--brand-text-muted)}.blog-article .table-of-contents a:hover{color:var(--brand-text)}.blog-layout[data-v-14f0af31]{background-color:var(--brand-bg);min-height:100vh}.blog-hero[data-v-14f0af31]{background-color:var(--brand-bg);position:relative;overflow:hidden}.blog-hero-glow[data-v-14f0af31]{pointer-events:none;z-index:0;background:radial-gradient(#ff006b24 0%,#7c3aed14 45%,#0000 70%);width:900px;height:480px;position:absolute;top:-180px;left:50%;translate:-50%}.blog-hero-inner[data-v-14f0af31]{z-index:1;padding-top:100px;padding-bottom:24px;position:relative}.section-overline[data-v-14f0af31]{text-transform:uppercase;letter-spacing:.12em;color:var(--brand-pink);margin-bottom:10px;font-size:.75rem;font-weight:700}.blog-title[data-v-14f0af31]{letter-spacing:-.03em;color:var(--brand-text);margin:0 0 12px;font-size:clamp(1.85rem,4vw,2.5rem);font-weight:800;line-height:1.15}.blog-meta[data-v-14f0af31]{color:var(--brand-text-muted);margin:0;font-size:.875rem}.blog-meta-sep[data-v-14f0af31]{margin-inline:8px}.blog-post-tags[data-v-14f0af31]{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.blog-breadcrumbs[data-v-14f0af31]{flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:16px;font-size:.875rem;display:flex}.bc-sep[data-v-14f0af31],.bc-current[data-v-14f0af31]{color:var(--brand-text-muted)}.blog-hero-img[data-v-14f0af31]{border:1px solid var(--brand-border);margin-bottom:24px}.blog-content-container[data-v-14f0af31]{padding-top:32px;padding-bottom:32px}.related-posts-offset[data-v-14f0af31]{margin-top:32px}.blog-toc-col[data-v-14f0af31]{padding-left:16px}@media (width<=839px){.blog-toc-col[data-v-14f0af31]{display:none}}@layer vuetify-components{.v-alert{--v-border-color:currentColor;flex:1;grid-template-columns:max-content auto max-content max-content;grid-template-areas:"prepend content append close"".content. .";padding:16px;display:grid;position:relative;overflow:hidden}.v-alert--absolute{position:absolute}.v-alert--fixed{position:fixed}.v-alert--sticky{position:sticky}.v-alert{border-radius:4px}.v-alert--variant-plain,.v-alert--variant-outlined,.v-alert--variant-text,.v-alert--variant-tonal{color:inherit;background:0 0}.v-alert--variant-plain{opacity:.62}.v-alert--variant-plain:focus,.v-alert--variant-plain:hover{opacity:1}.v-alert--variant-plain .v-alert__overlay{display:none}.v-alert--variant-elevated,.v-alert--variant-flat{background:rgb(var(--v-theme-surface-light));color:color-mix(in srgb, rgb(var(--v-theme-on-surface-light)) calc(var(--v-high-emphasis-opacity) * 100%), transparent)}.v-alert--variant-elevated{box-shadow:0px 1px 2px 0px rgba(var(--v-shadow-color), var(--v-shadow-key-opacity,.3)), 0px 1px 3px 1px rgba(var(--v-shadow-color), var(--v-shadow-ambient-opacity,.15));--v-elevation-overlay:color-mix(in srgb, var(--v-elevation-overlay-color) 2%, transparent)}.v-alert--variant-flat{box-shadow:0px 0px 0px 0px rgba(var(--v-shadow-color), var(--v-shadow-key-opacity,.3)), 0px 0px 0px 0px rgba(var(--v-shadow-color), var(--v-shadow-ambient-opacity,.15));--v-elevation-overlay:color-mix(in srgb, var(--v-elevation-overlay-color) 0%, transparent)}.v-alert--variant-outlined{border:thin solid}.v-alert--variant-text .v-alert__overlay{background:currentColor}.v-alert--variant-tonal .v-alert__underlay{opacity:var(--v-activated-opacity);border-radius:inherit;pointer-events:none;background:currentColor;inset:0}.v-alert .v-alert__underlay{position:absolute}.v-alert--prominent{grid-template-areas:"prepend content append close""prepend content. ."}.v-alert.v-alert--border{--v-border-opacity:.38}.v-alert.v-alert--border.v-alert--border-start{padding-inline-start:24px}.v-alert.v-alert--border.v-alert--border-end{padding-inline-end:24px}.v-alert--variant-plain{transition:opacity .2s cubic-bezier(.4,0,.2,1)}.v-alert--density-default{padding-top:16px;padding-bottom:16px}.v-alert--density-default.v-alert--border-top{padding-top:24px}.v-alert--density-default.v-alert--border-bottom{padding-bottom:24px}.v-alert--density-comfortable{padding-top:12px;padding-bottom:12px}.v-alert--density-comfortable.v-alert--border-top{padding-top:20px}.v-alert--density-comfortable.v-alert--border-bottom{padding-bottom:20px}.v-alert--density-compact{padding-top:8px;padding-bottom:8px}.v-alert--density-compact.v-alert--border-top{padding-top:16px}.v-alert--density-compact.v-alert--border-bottom{padding-bottom:16px}.v-alert:not(:has(.v-alert-title)) .v-alert__content{padding-block:.125rem}.v-alert__border{border-radius:inherit;opacity:var(--v-border-opacity);pointer-events:none;border:0 solid;width:100%;position:absolute;inset:0}.v-alert__border--border{box-shadow:none;border-width:8px}.v-alert--border-start .v-alert__border{border-inline-start-width:8px}.v-alert--border-end .v-alert__border{border-inline-end-width:8px}.v-alert--border-top .v-alert__border{border-top-width:8px}.v-alert--border-bottom .v-alert__border{border-bottom-width:8px}.v-alert__close{flex:0 auto;grid-area:close}.v-alert__close>.v-btn{margin-block:calc(-1 * (var(--v-btn-height) + 12px - 1.75rem) / 2)}.v-alert__content{grid-area:content;align-self:center;overflow:hidden}.v-alert__content>:first-child{margin-top:0}.v-alert__content>:last-child{margin-bottom:0}.v-alert__append,.v-alert__close{margin-inline-start:16px}.v-alert__append{grid-area:append;align-self:flex-start}.v-alert__append+.v-alert__close{margin-inline-start:16px}.v-alert__prepend{grid-area:prepend;align-self:flex-start;align-items:center;min-height:1.75rem;margin-inline-end:16px;display:flex}.v-alert__prepend>.v-icon{width:1.75rem;height:1.75rem;font-size:1.75rem}.v-alert--prominent .v-alert__prepend{align-self:center}.v-alert__underlay{grid-area:none;position:absolute}.v-alert--border-start .v-alert__underlay{border-top-left-radius:0;border-bottom-left-radius:0}.v-alert--border-end .v-alert__underlay{border-top-right-radius:0;border-bottom-right-radius:0}.v-alert--border-top .v-alert__underlay{border-top-left-radius:0;border-top-right-radius:0}.v-alert--border-bottom .v-alert__underlay{border-bottom-right-radius:0;border-bottom-left-radius:0}.v-alert-title{-webkit-hyphens:auto;hyphens:auto;letter-spacing:normal;overflow-wrap:normal;text-transform:none;word-break:normal;word-wrap:break-word;align-self:center;align-items:center;font-size:1.5rem;font-weight:400;line-height:1.75rem;display:flex}@media (forced-colors:active){.v-alert:not(.v-alert--variant-text,.v-alert--variant-plain){border-style:solid}.v-alert--variant-outlined,.v-alert--variant-tonal{border-width:medium}.v-alert--variant-elevated,.v-alert--variant-flat{border-width:thick}}}.blog-post-loading[data-v-4c0207c4]{justify-content:center;min-height:40vh;padding-top:64px;padding-bottom:64px;display:flex}.blog-post-notfound[data-v-4c0207c4]{padding-top:64px;padding-bottom:64px}
