:root{--line-height:24px;--line-height-half:calc(var(--line-height)/2);--line-height-quarter:calc(var(--line-height)/4);--line-height-eighth:calc(var(--line-height)/8);--column-width:calc(var(--line-height)*2);--columns-max:24;backface-visibility:hidden;interpolate-size:allow-keywords}:root,body,html{font-size:var(--line-height);line-height:var(--line-height)}:root{--font-family-sans-serif:"Inter",system-ui,-apple-system,"Helvetica Neue","Helvetica","Roboto","Arial",sans-serif,"Apple Color Emoji","Segoe UI Emoji",sans-serif;--font-family-serif:"Roboto Serif","Crimson Pro","Georgia",serif;--font-family-monospace:"Fira Code","JetBrains Mono","Courier New",monospace;--padding-top:0px;--padding-bottom:0px;--font-size:.66667rem;--font-weight:400}body{line-height:var(--line-height);font-size:var(--font-size);font-family:var(--font-family-sans-serif);font-weight:var(--font-weight);--xxs-line-height:.75rem;--xxs-font-size:.5rem;--xs-line-height:1rem;--xs-font-size:.58333rem;--s-line-height:1rem;--s-font-size:.66667rem;--m-line-height:1.25rem;--m-font-size:.75rem;--l-line-height:1.25rem;--l-font-size:.91667rem;--l-font-size:.83333rem;--xl-line-height:2rem;--xl-font-size:1.66667rem;--xl-font-size:1.4rem;--xxl-line-height:3rem;--xxl-font-size:2.75rem;--xxxl-line-height:3.5rem;--xxxl-font-size:3.33333rem;font-variant-numeric:oldstyle-nums;letter-spacing:-.02em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"calt","liga","hist","onum","pnum";text-rendering:optimizeLegibility;overflow-wrap:break-word;hanging-punctuation:first allow-end}@media screen and (max-width:768px){body{-webkit-text-size-adjust:100%;--xl-line-height:1.5rem;--xl-font-size:1.33rem;--l-line-height:1.25rem;--l-font-size:1rem;--xxl-line-height:2rem;--xxl-font-size:1.666rem;--xxxl-line-height:2.25rem;--xxxl-font-size:2.1rem}}.serif{font-family:var(--font-family-serif)}.sans-serif,button{font-family:var(--font-family-sans-serif)}.code,.mono,.monospace,.timecode,code,pre{font-family:var(--font-family-monospace);hyphens:none}.align-left{text-align:left}.align-center{text-align:center}.align-right{text-align:right}h1,h2,h3,h4,h5,h6,p{scroll-margin-top:5rem;margin:0;padding:0}.hero-text{line-height:var(--xxl-line-height);font-size:var(--xxl-font-size);font-weight:500;letter-spacing:-.04em;@media(min-width:432px){line-height:var(--xxxl-line-height);font-size:var(--xxxl-font-size)}}.hed,h1{line-height:var(--xl-line-height);font-size:var(--xl-font-size)}.dek,.hed,h1,h2{font-weight:600;letter-spacing:-.02em}.dek,h2{line-height:var(--l-line-height);font-size:var(--l-font-size)}h3{line-height:var(--m-line-height);font-size:var(--m-font-size)}h4,h5,h6{line-height:var(--s-line-height);font-size:var(--s-font-size)}.grafs,.lede{line-height:var(--s-line-height);font-size:var(--s-font-size);letter-spacing:-.015em;h2,h3{font-weight:600}h4,h5,h6{font-weight:700}}.caption,.meta,figcaption{line-height:var(--xs-line-height);font-size:var(--xs-font-size)}.numeric{font-feature-settings:"tnum";letter-spacing:.02em}.pad-ragged-abs{padding:0 .125rem 0 .25rem}blockquote{margin:.5rem 0;border-left:2px solid var(--color-link-text);background-color:var(--color-code-background);padding:1rem;font-family:var(--font-family-serif);p:first-child{text-indent:0!important}}.pad-ragged-abs>blockquote{margin-left:-.5rem;margin-right:-.5rem}.grafs li{margin-bottom:.5rem}code,pre{background-color:var(--color-code-background);color:var(--color-text)}code{margin:-.25em -.125em;padding:.25em .125em;transition:background-color .2s}pre{border-radius:.25rem;padding:1rem;overflow:auto;code{margin:0;padding:0}}.pad-ragged-abs>pre{margin-left:-.5rem;margin-right:-.5rem}a:hover code{background-color:transparent;transition:none}a{margin:-.25em;padding:.25em;text-decoration:none;transition:background-color .2s,color .2s}a:hover{color:inherit;transition:none}math{mtd{text-align:center}mi{font-weight:500;letter-spacing:-.025em}mtext *{display:inline!important}code{background-color:transparent!important}}figure>math{margin:.5rem 0}@media(hover:hover){mtd{background-color:transparent;transition:background-color 1s;&:hover{background-color:var(--color-link-background-hover);transition:background-color .1s}}}table{margin:1rem 0;border-collapse:collapse;border-spacing:0;td,th{padding:.5rem;text-align:left}th{background-color:var(--color-code-background)}}.pad-ragged-abs>table{margin-left:-.5rem;margin-right:-.5rem}.tabular{font-variant-numeric:tabular-nums}:root{color-scheme:dark light}.theme-dark,html{color-scheme:dark;--color-root-background:#000;--color-page-background:#000;--color-content-background:#1a1a1a;--color-footer-background:#1a1a1a;--color-figure-background:gray;--color-figure-frame:#2b2b2b;--color-code-background:#0f263d;--color-text:#d9d9d9;--color-text-emphasis:#e6e6e6;--color-text-separator:gray;--color-fill:#d9d9d9;--color-fill-emphasis:#e6e6e6;--color-rule:#404040;--color-link-background:transparent;--color-link-background-hover:#fff;--color-link-text:#fff;--color-link-text-hover:#000;--color-link-text-selected:#fff;--color-link-text-active:var(--color-link-text-selected);--color-link-decoration:#404040;--color-link-decoration-hover:var(--color-link-decoration);--color-link-fill:#ccc;--color-link-fill-hover:#e6e6e6;--color-link-fill-selected:#d9d9d9;--color-link-fill-active:var(--color-fill-selected);--color-tag-background:hsl(0 0 100/.1);--color-tag-background-hover:hsl(0 0 100/.18);--color-tag-text:#d1d1d1;--color-tag-text-hover:#f5f5f5;--color-surface:hsl(0 0 100/.03);--color-surface-hover:hsl(0 0 100/.06);.midground{--color-text:hsla(0,0%,100%,.35);--color-text-emphasis:hsla(0,0%,100%,.4);--color-text-separator:hsla(0,0%,100%,.2);--color-link-text:var(--color-text-hover);--color-link-text-hover:hsla(0,0%,100%,.7);--color-link-text-selected:#fff;--color-link-text-active:var(--color-text-selected);--color-link-fill:hsla(0,0%,100%,.3);--color-link-fill-hover:hsla(0,0%,100%,.7)}}.theme-light{color-scheme:light;--color-root-background:#fff;--color-page-background:#fafafa;--color-content-background:#fff;--color-footer-background:#1f1f1f;--color-figure-background:gray;--color-figure-frame:#e6e6e6;--color-code-background:#f3f5f7;--color-text:#121212;--color-text-emphasis:#000;--color-text-separator:gray;--color-fill:#1a1a1a;--color-fill-emphasis:#000;--color-rule:#e6e6e6;--color-link-background:transparent;--color-link-background-hover:#1466b8;--color-link-text:#2966a3;--color-link-text-hover:#fff;--color-link-text-selected:#2966a3;--color-link-text-active:#000;--color-link-decoration:#0f66bd;--color-link-decoration-hover:var(--color-link-decoration);--color-link-fill:#08192b;--color-link-fill-hover:#08192b;--color-link-fill-selected:#08192b;--color-link-fill-active:#08192b;--color-tag-background:#fff;--color-tag-background-hover:#f7f7f7;--color-tag-text:#707070;--color-tag-text-hover:#454545;--color-surface:rgba(0,0,0,.03);--color-surface-hover:rgba(0,0,0,.06);.midground{--color-text:#737f8c;--color-text-emphasis:rgba(0,0,0,.37);--color-text-separator:rgba(0,0,0,.2);--color-link-text:var(--color-text);--color-link-text-hover:rgba(0,0,0,.7);--color-link-text-selected:#000;--color-link-text-active:var(--color-text-selected);--color-link-fill:rgba(0,0,0,.3);--color-link-fill-hover:rgba(0,0,0,.7)}}body{background-color:var(--color-footer-background);color:var(--color-text);transition-property:background-color,color;transition-duration:1s}.nav-global3-buffer,main{background-color:var(--color-page-background)}svg{fill:var(--color-fill)}.hed,h1,h2,h3,h4,h5,h6{color:var(--color-text-emphasis)}.midground{color:var(--color-text)}*{-webkit-tap-highlight-color:transparent}.hyperlink-internal,a{background-color:var(--color-link-background);color:var(--color-link-text);text-decoration-color:var(--color-link-decoration);cursor:pointer;svg{fill:var(--color-link-fill)}&.active,&:active{color:var(--color-link-text-active);svg{fill:var(--color-link-fill-active)}}&.selected{color:var(--color-link-text-selected);svg{fill:var(--color-link-fill-selected)}}&.active,&.router-link-active,&.router-link-exact-active{color:var(--color-link-text-active)}@media(hover:hover){&:hover{background-color:var(--color-link-background-hover);color:var(--color-link-text-hover);svg{fill:var(--color-link-fill-hover)}}}}@media(hover:hover){a:has(button):hover{background-color:transparent;color:inherit}}:root{--color-nav-accent:#ff6a00;--color-nav-accent-muted:color-mix(in srgb,var(--color-nav-accent) 50%,transparent)}.page{background-color:var(--color-accent);color:var(--color-bg-primary);min-height:100vh;padding-top:120px;.container{max-width:1400px;margin:0 auto;padding:0 60px;@media(max-width:768px){padding:0 24px}}.hero-section{padding:60px 0 100px;border-bottom:1px solid rgba(0,0,0,.1);.hero-text{margin-bottom:1rem}.hero-description{font-size:24px;max-width:700px;color:var(--color-text-secondary);line-height:1.4}}.category-section{padding:80px 0}}.category-section{padding:80px 0;border-bottom:1px solid rgba(0,0,0,.1)}.category-section:last-child{border-bottom:none}.section-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:48px}.section-header h2{font-size:40px;font-weight:500;margin-bottom:16px;letter-spacing:-.02em}.section-subtitle{font-size:18px;color:var(--color-text-secondary);max-width:600px}.contributors-index,.contributors-slug{padding-left:6rem;padding-bottom:6rem}@media(prefers-color-scheme:dark){.category-section,.hero-section{border-bottom-color:#ffffff1a}}:root{--color-text-primary:#fdfdfd;--color-text-secondary:#949494;--color-bg-primary:#111;--color-bg-secondary:#1a1a1a;--color-accent:#fdfdfd;--font-sans:"Inter",sans-serif}*,:after,:before{box-sizing:border-box}body,html{width:100%}body{margin:0;padding:0;font-family:var(--font-sans);color:var(--color-text-primary);background-color:var(--color-bg-primary);-webkit-font-smoothing:antialiased}.container{max-width:1400px;width:100%;margin:0 auto;padding:0 60px;box-sizing:border-box}.flex{display:flex}.grid{display:grid}.text-secondary{color:var(--color-text-secondary)}@media(max-width:1400px){.container{padding:0 10px;max-width:100%}}.page-wrapper{background-color:var(--color-background);min-height:100vh;color:var(--color-text-emphasis)}.dark-container{background:var(--color-bg-primary);width:100%;position:relative;z-index:0}.dark-container:before{content:"";position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:-1;background-image:url(../media/footer-bg.webp);background-position:bottom;background-repeat:no-repeat;background-size:cover;pointer-events:none}.ui-callout{display:inline-block;padding:6px 12px;border:1px solid hsla(0,0%,100%,.2);border-radius:4px;background:#ffffff0d;color:#ffffffe6;font-size:13px;font-weight:500;margin-bottom:24px}iframe.js-runtime{display:none;position:absolute;border:0;position-area:center;justify-self:stretch;align-self:stretch}iframe.js-runtime.fullscreen{position:fixed;inset:0;height:100vh;z-index:1000;border-radius:0}nav.global{position:fixed;z-index:900;top:0;left:0;right:0}nav.global .nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;height:48px;padding:0 24px;background-color:#262626}nav.global .nav-group{display:flex;align-items:center;gap:24px;height:100%;min-width:0}nav.global .nav-subgroup{display:flex;align-items:center;gap:16px;height:100%}nav.global .nav-brand{display:flex;align-items:center;gap:8px;height:100%;flex-shrink:0;text-decoration:none;color:#fafafa}nav.global .nav-brand:hover{background-color:transparent}nav.global .nav-logo{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;background:#191919}nav.global .nav-logo-mark{width:14px;height:14px}nav.global .nav-brand-name{display:flex;align-items:center;height:100%;border-bottom:2px solid transparent;font-size:14px;font-weight:500;color:#fafafa;white-space:nowrap;transition:border-color .15s}nav.global .nav-brand:hover .nav-brand-name{border-bottom-color:var(--color-nav-accent-muted)}nav.global .nav-brand--active .nav-brand-name,nav.global .nav-brand--active:hover .nav-brand-name{border-bottom-color:var(--color-nav-accent)}nav.global .nav-link{display:flex;align-items:center;height:100%;border-bottom:2px solid transparent;color:#fafafa;font-size:14px;font-weight:500;line-height:1.2;text-decoration:none;white-space:nowrap;transition:color .15s,border-color .15s}nav.global .nav-link:hover{background-color:transparent;color:#fff;border-bottom-color:var(--color-nav-accent-muted)}nav.global .nav-link--active,nav.global .nav-link--active:hover{border-bottom-color:var(--color-nav-accent)}nav.global .nav-cta{display:flex;align-items:center;height:32px;padding:0 12px;border-radius:8px;background:var(--color-nav-accent);color:#191919;font-size:14px;font-weight:600;line-height:1.2;text-decoration:none;white-space:nowrap;transition:background .15s}nav.global .nav-cta:hover{background:color-mix(in srgb,var(--color-nav-accent) 88%,#000);color:#191919}nav.global .nav-signin{display:flex;align-items:center;height:32px;padding:0 12px;border-radius:8px;background:#191919;box-shadow:0 1px 1px #fafafa0f,0 0 0 1px #fafafa14;color:#fafafa;font-size:14px;font-weight:500;text-decoration:none;white-space:nowrap;cursor:pointer;transition:background .15s,box-shadow .15s}nav.global .nav-signin:hover{background:#2a2a2a;box-shadow:0 1px 1px #fafafa0f,0 0 0 1px var(--color-nav-accent-muted)}nav.global .nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:4px;width:32px;height:32px;padding:0 7px;border:none;border-radius:8px;background:#191919;box-shadow:0 0 0 1px #fafafa14;cursor:pointer}nav.global .nav-hamburger span{display:block;width:100%;height:2px;border-radius:2px;background:#fafafa}@media(max-width:859px){nav.global .nav-cta,nav.global .nav-link,nav.global .nav-signin{display:none}nav.global .nav-hamburger{display:flex}}.button,button{display:inline-block;border:none;border-radius:.5rem;padding:.5rem 1rem;background:#000000e6;backdrop-filter:blur(.5rem);-webkit-backdrop-filter:blur(.5rem);color:#fff;white-space:nowrap;line-height:var(--m-line-height);font-size:var(--m-font-size);font-weight:500;letter-spacing:-.025em;transition:all .25s ease;cursor:pointer;&:hover{background-color:hsl(0 0 15/.9);color:#fff;transform:scale(1.02);transition:all .1s ease}.icon{margin-left:.125rem;width:.5rem;height:.5rem}&.light-on-light{background-color:hsl(0 0 100/.1);&:hover{background:hsl(0 0 100/.2)}}&.dark-on-light{background-color:hsl(0 0 100/.8);color:#000;.icon{filter:invert(1)}&:hover{background:hsl(0 0 100/.9)}}}.cta-container{display:block;width:100%;padding:1.5rem 0;text-align:center}.text-btn{background:transparent;border:none;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;display:flex;align-items:center;gap:8px;color:var(--color-text);opacity:.7;line-height:var(--s-line-height);font-size:var(--s-font-size);transition:all .2s ease;&:hover{color:var(--color-text-emphasis);opacity:1;background:#0000000d;transform:scale(1.02)}.icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;line-height:1;font-size:14px}}.read-more-btn{width:100%;padding:4px 12px;background:transparent;color:var(--color-text-emphasis);border:1px solid rgba(17,17,17,.2);border-radius:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;font-weight:400;transition:all .2s;line-height:var(--s-line-height);font-size:var(--s-font-size);&:hover{transform:scale(1.02);background:#1111110d;color:var(--color-text-emphasis)}.icon{width:12px;height:10px}}.tags{display:flex;flex-wrap:wrap;gap:16px;margin-top:.25rem}.tags-index .breadcrumbs,.topics-index .breadcrumbs,.topics-slug .breadcrumbs{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-family:JetBrains Mono,monospace;font-size:13px;color:#888;flex-wrap:wrap}.tags-index .crumb-link,.topics-index .crumb-link,.topics-slug .crumb-link{color:inherit;text-decoration:none;background-color:transparent;transition:color .15s ease;&:hover{color:#111;background-color:transparent}}.tags-index .crumb-sep,.topics-index .crumb-sep,.topics-slug .crumb-sep{color:#ccc;font-size:13px}.tags-index .crumb-current,.topics-index .crumb-current,.topics-slug .crumb-current{color:#555}.tags-cloud{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-start;justify-content:flex-start;margin-top:40px;margin-bottom:56px}.tag{background-color:var(--color-tag-background);color:var(--color-tag-text);text-decoration:none;display:inline-flex;align-items:center;gap:2px;height:28px;border-radius:4px;padding:0 8px;line-height:1.6;font-size:15px;font-weight:400;box-shadow:0 1px 1px #0000000f,0 0 0 1px #00000014;transition:background-color .15s ease,box-shadow .15s ease,color .15s ease;.tag-count{font-size:.8em;font-weight:400;opacity:.6;margin-left:3px}}.tag-hash{opacity:.4}.tag-link{cursor:pointer;@media(hover:hover){&:hover{background-color:var(--color-tag-background-hover);color:var(--color-tag-text-hover);text-decoration:none}}}.tags-pagination{display:flex;align-items:center;gap:12px;margin-top:48px;margin-bottom:80px}.tags-pagination-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;border:1px solid rgba(0,0,0,.12);background-color:#fff;font-size:14px;font-weight:500;color:#1a1a1a;cursor:pointer;transition:background-color .15s ease,box-shadow .15s ease,opacity .15s ease;&:hover:not(:disabled){background-color:#f5f5f5;box-shadow:0 1px 2px #00000014,0 0 0 1px #0000001f}&:disabled{opacity:.35;cursor:not-allowed}}.tags-pagination-label{font-size:13px;color:var(--color-text-secondary);min-width:48px;text-align:center}.topics-filter-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:40px;margin-bottom:8px}.topics-filter-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;border:1px solid transparent;background:transparent;font-size:13px;font-weight:500;color:#666;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,color .15s ease;&:hover{background-color:#0000000d;color:#111}&.active{background-color:#0000000f;border-color:#0000001f;color:#111}}.topics-filter-count{font-size:11px;font-weight:600;padding:1px 5px;border-radius:10px;background:#0000000f;color:inherit;min-width:18px;text-align:center}.tag-source-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-left:4px;opacity:.7}.tag-source-dot--articles{background-color:#6366f1}.tag-source-dot--projects{background-color:#f59e0b}.tag-source-dot--both{background-color:#10b981}.topics-empty{padding:48px 0;color:var(--color-text-secondary);font-size:15px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:40px}.card{.card-link{text-decoration:none;color:inherit;display:block;padding:16px;margin:-16px;border-radius:12px;transition:all .2s ease;&:hover{background:var(--color-surface-hover);box-shadow:0 0 0 1px #00000014,0 2px 4px -1px #00000014,0 8px 16px -4px #00000014}}.card-image{border-radius:.5rem;overflow:hidden;margin-bottom:.675rem;img{width:100%;aspect-ratio:16/10;-o-object-fit:cover;object-fit:cover;display:block}}.card-content{padding:0 .375rem .5rem;.hed,h3{margin:0 0 .375rem;padding:0;line-height:1rem;font-size:.875rem;font-weight:600}.dek,.description{margin-top:0;line-height:1.4;font-size:.6rem;font-weight:400;letter-spacing:-.02em;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.dek,.description,.meta{color:var(--color-text-secondary)}.meta{margin-top:.25rem;line-height:.875rem;font-size:.5rem}.tags-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px;margin-bottom:6px}.tags-row .tag{margin:0;padding:2px 6px;font-size:11px}}}.article-main{max-width:26rem;.hero img{max-width:26rem;width:100%;height:auto}.hed{margin-top:2rem}.dek{margin-top:1rem}.meta{margin-top:1.25rem}.meta+.lede{margin-top:1.5rem}h2,h3,h4,h5,h6{margin-top:1rem;margin-bottom:.25rem}h2{margin-top:1.25rem}h3{margin-top:.75rem}.indent-first [chunk-index="0"] p:first-child{text-indent:1rem}.indent-first [chunk-index="0"] li p:first-child{text-indent:0}figure.image{max-width:80%;margin-left:auto;margin-right:auto}figure{margin:.5rem 0 1rem;width:100%;text-align:center;iframe,img,video{max-width:100%;width:100%;height:auto;border-radius:.25rem;display:block}iframe{aspect-ratio:16/10;background-color:#000}figcaption{margin-top:.375rem;font-family:var(--font-family-serif);color:var(--color-text);opacity:.7;text-align:center;font-style:italic}}.media-embed{.embed-container{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;max-width:100%;border-radius:4px;background:var(--color-surface);embed,iframe,object{position:absolute;top:0;left:0;width:100%;height:100%}}}.grafs p:has(>img:only-child){text-align:center}.grafs p>img:only-child{max-width:80%;height:auto;border-radius:.25rem;display:block;margin:.5rem auto 1rem}}.article-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:1.5rem;width:100%;max-width:1440px;margin:0 auto;padding:1.75rem 1rem;align-items:start}@media(min-width:1024px){.article-layout{grid-template-columns:320px minmax(0,1fr);padding:3.75rem 2rem;gap:2rem}}@media(max-width:768px){.article-main,.article-main .hero img,article{max-width:100%}}.code-block-wrapper{position:relative;margin:1rem 0}.code-block-wrapper pre{margin:0}.code-copy-btn{position:absolute;top:.5rem;right:.5rem;display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;color:var(--color-text);opacity:.7;background:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:6px;cursor:pointer;opacity:0;transition:opacity .2s,background-color .2s,color .2s;z-index:1}.code-copy-btn svg{width:16px;height:16px;fill:none!important}.code-block-wrapper:hover .code-copy-btn{opacity:1}.code-copy-btn:hover{background:var(--color-background);color:var(--color-text-emphasis);border-color:#0003}.code-copy-btn.copied{background:#22c55e;color:#fff;border-color:#22c55e}.article-sidebar{align-self:start;min-height:100%;display:none;@media(min-width:1024px){display:block}}.sticky-container{position:sticky;top:0}.back-link{a{display:inline-block;margin-bottom:1.5rem;text-decoration:none;font-size:var(--xs-font-size);transition:color .2s;&:hover{color:var(--color-text-emphasis)}}}.toc{padding:3.5rem 0 4rem;.toc-title{font-family:var(--font-family-sans-serif);font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text);opacity:.5;margin-bottom:16px}ul{list-style:none;padding:0;margin:0;li a{margin:0;padding:.25rem .25rem .25rem .5rem;font-size:var(--s-font-size);line-height:var(--s-line-height);font-weight:500;text-decoration:none;display:block;&.active,&:hover{transition:none}&[level=h2]{padding-left:.5rem}&[level=h3]{padding-left:1.25rem}&[level=h4],&[level=h5],&[level=h6]{padding-left:2rem}}}}.home-index{background-color:var(--color-bg-primary);color:var(--color-text-primary);overflow-x:hidden;--accent:var(--color-nav-accent);--accent-2:#ff9a3d;--radius-xs:4px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-stacked:0 0 0 1px rgba(0,0,0,.06),0 1px 1px -.5px rgba(0,0,0,.06),0 3px 3px -1.5px rgba(0,0,0,.06),0 6px 6px -3px rgba(0,0,0,.06),0 12px 12px -6px rgba(0,0,0,.06),0 24px 24px -12px rgba(0,0,0,.06);--shadow-soft:0 1px 1px -.5px rgba(0,0,0,.06),0 0 0 1px rgba(0,0,0,.06);.cta-container{padding:3rem 0 4rem}.qhome-hero{position:relative;overflow:hidden;background-color:#000;padding:132px 0 52px;.hero-bg{inset:0;background-image:url(../media/hero-bg.webp);background-size:cover;background-position:50%;opacity:.85;-webkit-mask-image:linear-gradient(180deg,#000 0,#000 40%,transparent);mask-image:linear-gradient(180deg,#000 0,#000 40%,transparent)}.hero-bg,.hero-glow{position:absolute;z-index:0;pointer-events:none}.hero-glow{left:50%;top:-120px;transform:translate(-50%);width:min(1000px,92vw);height:420px;background:radial-gradient(ellipse at center,var(--accent) 0,var(--accent-2) 26%,transparent 62%);filter:blur(90px);opacity:.42;animation:qhome-hero-pulse 8s ease-in-out infinite}.hero-inner{position:relative;z-index:2}}@keyframes qhome-hero-pulse{0%,to{opacity:.42;transform:translate(-50%) scale(1)}50%{opacity:.62;transform:translate(-50%) scale(1.05)}}.qhome-hero-title{margin:0 0 18px;max-width:20ch;font-weight:600;font-size:clamp(40px,5.2vw,64px);line-height:1.06;letter-spacing:-.03em;background:linear-gradient(180deg,#fff,#ffffffb8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.qhome-hero-lede{max-width:52ch;margin:0 0 28px;font-size:18px;line-height:1.5;letter-spacing:-.015em;color:var(--color-text);opacity:.82}.qhome-hero-ctas{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.qhome-gallery{position:relative;background-color:#000;padding:30px 0 96px;.gallery-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:26px;.titles h2{font-size:28px;font-weight:600;letter-spacing:-.025em;color:var(--color-text-emphasis);margin:0}.titles p{margin:6px 0 0;font-size:15px;color:var(--color-text);opacity:.62;letter-spacing:-.01em}}.section-link{font-size:14px;font-weight:500;color:var(--color-text-emphasis);text-decoration:none;white-space:nowrap;padding:6px 10px;margin:-6px -10px;border-radius:var(--radius-sm);transition:background .15s,color .15s;&:hover{background:#fff;color:#000}}.browse-bar{display:flex;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:22px}.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.pgrid--state{display:block;min-height:200px;color:var(--color-text);opacity:.65;text-align:center;padding:48px 0}.tile-wrap{position:relative;min-width:0}.tile{position:relative;display:block;text-decoration:none;cursor:pointer;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-rule);border-radius:var(--radius-xl);padding:8px;box-shadow:var(--shadow-stacked);transition:transform .2s ease,background .15s ease,border-color .15s ease;&:hover{transform:translateY(-4px);background:var(--color-surface-hover);color:var(--color-text)}}.tile:hover .ui-preview-img{transform:scale(1.03)}.tile-badges{position:absolute;top:18px;left:18px;display:flex;gap:6px;z-index:2;pointer-events:none}.tile-body{padding:14px 8px 6px}.tile-title{font-size:17px;font-weight:600;color:var(--color-text-emphasis);letter-spacing:-.02em;margin-bottom:5px;line-height:1.22;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tile-authors{display:flex;align-items:center;gap:6px;min-width:0;font-size:13px;color:var(--color-text);opacity:.6;margin-bottom:10px}.tile-author{border-bottom:1px dotted var(--color-rule);padding-bottom:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tile-rule{margin:11px 0}.tile-desc{font-size:13.5px;color:var(--color-text);opacity:.78;line-height:1.5;letter-spacing:-.01em;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tile-tags{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.tile-meta{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-family-monospace);font-feature-settings:"tnum";font-size:12px;color:var(--color-text);opacity:.6;.stats{display:flex;gap:12px}.stat{display:inline-flex;align-items:center;gap:4px}.stat svg{width:12px;height:12px;opacity:.8}}.gallery-empty{border:1px solid var(--color-rule);border-radius:var(--radius-xl);background:var(--color-surface);padding:48px 24px;text-align:center;.empty-ico{width:40px;height:40px;margin:0 auto 14px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:#ff6a0029;color:var(--accent)}.empty-ico svg{width:20px;height:20px}.empty-title{font-size:16px;font-weight:600;color:var(--color-text-emphasis);margin-bottom:6px}.empty-sub{font-size:14px;opacity:.65;margin-bottom:18px}}}.learn-section{padding-top:60px;padding-bottom:120px;background:#fdfdfd;color:#111}.learn-header{margin-bottom:72px}.learn-title-container{max-width:600px}.learn-title-container a:hover{background-color:transparent}.learn-section h2{font-size:64px;line-height:1.11;letter-spacing:-.02em;font-weight:500;color:#111;margin-bottom:0}.learn-section .description{color:#111;opacity:.7;font-size:24px;line-height:1.6}.column-tag{font-family:KH Teka TRIAL,sans-serif;font-size:15px;font-weight:400;font-style:normal;line-height:1.6;letter-spacing:0;color:#fdfdfd;background-color:#111;padding:2px 6px;display:inline-block}.learn-columns{display:grid;grid-template-columns:repeat(3,1fr);gap:88px}.learn-column{display:flex;flex-direction:column;gap:32px}.column-header{margin-bottom:8px}.column-content{display:flex;flex-direction:column;gap:40px;flex:1}.card-link{text-decoration:none;color:#111;display:block;padding:16px;margin:-16px;border-radius:12px;transition:all .2s ease}.card-link:hover{background-color:#f5f5f5;transform:scale(1.02)}.learn-card{display:flex;flex-direction:column;gap:0}.learn-card img{width:100%;aspect-ratio:16/10;-o-object-fit:cover;object-fit:cover;border-radius:6px;padding:4px;background:#fdfdfd;box-shadow:0 0 0 1px #0000000f,0 1px 1px -.5px #0000000f,0 3px 3px -1.5px #0000000f,0 6px 6px -3px #0000000f,0 12px 12px -6px #0000000f,0 24px 24px -12px #0000000f;margin-bottom:16px}.learn-card h3{font-size:20px;font-weight:600;line-height:1.3}.learn-card h3,.learn-card p{margin:0 0 16px;padding-bottom:16px;border-bottom:1px solid #eee;color:#111}.learn-card p{font-size:15px;opacity:.7;line-height:1.6}.read-more-link{text-decoration:none;display:block}.read-more-link:hover{background-color:transparent}.author-small{display:flex;align-items:center;gap:0;font-size:13px;color:#111;opacity:.5}.avatar-tiny{width:16px;height:16px;background-color:#333;background-size:cover;border-radius:50%}.learn-more-links{display:flex;gap:20px;flex-wrap:wrap}.promo-banner-inline{display:inline-flex;align-items:center;gap:14px;margin-bottom:4px;padding:8px 14px;width:-moz-fit-content;width:fit-content;max-width:680px;text-decoration:none;color:inherit;background:#00000040;border:1px solid hsla(0,0%,100%,.1);border-radius:8px;transition:background .2s,border-color .2s}.promo-banner-inline:hover{background:#00000059;border-color:#ffffff26}.promo-badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff;background:linear-gradient(135deg,#ff6a00,#ee0979);border-radius:4px;flex-shrink:0;line-height:1.6}.promo-text{font-size:15px;color:#ffffffbf;margin:0;line-height:1.5}.promo-text strong{color:#fff;font-weight:500}.promo-announcement-link{display:inline-block;margin-top:0;margin-bottom:20px;font-size:13px;font-weight:500;color:#ffffffa6;text-decoration:underline;text-decoration-color:#ffffff4d;text-underline-offset:3px;transition:color .2s,text-decoration-color .2s}.promo-announcement-link:hover{color:#fffffff2;text-decoration-color:#fff9;background-color:transparent}@media(max-width:640px){.promo-banner-inline{flex-wrap:wrap;gap:6px}.promo-text{font-size:14px}}@media(max-width:1100px){.qhome-gallery .pgrid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.qhome-hero{padding-top:104px}.qhome-gallery .pgrid{grid-template-columns:1fr}.qhome-gallery .gallery-head{flex-direction:column;align-items:flex-start}.learn-section{padding:60px 20px}.learn-columns{grid-template-columns:1fr;gap:60px}.footer-content h2{font-size:40px}.main-footer{flex-direction:column;gap:20px}.footer-links{flex-wrap:wrap}}}.hero-title-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.hero-title-row .my-project-tile-cta-btn{align-self:center}.projects-slug{.article-layout{padding-top:120px}@media(min-width:1024px){.article-layout{padding-top:180px}}.card-image{margin-bottom:60px}}.page.learn-index,.page.projects-index{.hero-section{padding-bottom:40px;border-bottom:none}.category-section{padding-top:40px}@media(max-width:768px){.hero-section{padding-top:0;padding-bottom:32px}.hero-text{font-size:3rem;line-height:1.1;margin-bottom:16px}.hero-description{font-size:1.125rem;line-height:1.5}.category-section{padding-top:32px;padding-bottom:48px}}}.my-projects-section{padding:40px 0 48px;border-bottom:1px solid var(--color-rule)}.my-projects-pagination,.projects-load-more{display:flex;align-items:center;justify-content:center;gap:.625rem;margin-top:24px;padding-top:20px;border-top:1px solid var(--color-rule)}.my-projects-page-label{font-size:13px;color:var(--color-text-secondary);min-width:3.5rem;text-align:center}.my-projects-load-more-btn{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 16px;background:var(--color-surface);border:1px solid var(--color-rule);border-radius:8px;font-size:15px;font-weight:500;color:var(--color-text-emphasis);cursor:pointer;transition:background .1s ease,color .1s ease}.my-projects-load-more-btn:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text-emphasis);border-color:var(--color-text-emphasis)}.my-projects-load-more-btn:disabled{color:var(--color-text-secondary,#999);background:var(--color-surface);cursor:not-allowed}.my-projects-label{font-size:24px;font-weight:600;letter-spacing:-.02em;color:var(--color-text-emphasis);margin:0 0 24px}.my-projects-row{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;align-items:stretch}@media(max-width:1024px){.my-projects-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.my-projects-row{grid-template-columns:1fr}}.my-project-tile--cta{border:1.5px dashed var(--color-rule);border-radius:16px;padding:8px;min-height:180px;display:flex;align-items:stretch}.my-project-tile-cta-inner{display:flex;flex-direction:column;gap:24px;padding:16px;width:100%}.my-project-tile-cta-text{display:flex;flex-direction:column;gap:8px;flex:1}.my-project-tile-cta-headline{font-size:24px;font-weight:600;line-height:1.2;letter-spacing:-.02em;color:var(--color-text-emphasis);margin:0}.my-project-tile-cta-body{font-size:15px;line-height:1.6;color:var(--color-text);opacity:.6;margin:0}.my-project-tile-cta-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--color-text-emphasis);color:var(--color-page-background);border-radius:8px;font-size:15px;font-weight:500;text-decoration:none;transition:opacity .15s ease;align-self:flex-start}.my-project-tile-cta-btn:hover{opacity:.85}.join-cta-section{padding-bottom:0}.join-cta-card{display:flex;align-items:center;justify-content:space-between;gap:2.5rem;padding:1.75rem 2rem;background:var(--color-surface);border:1px solid var(--color-rule);border-radius:16px}.join-cta-text{display:flex;flex-direction:column;gap:.3rem;flex:1;min-width:0}.join-cta-headline{font-size:1rem;font-weight:600;letter-spacing:-.015em;color:var(--color-text-emphasis);margin:0;line-height:1.3}.join-cta-body{font-size:.875rem;line-height:1.5;color:var(--color-text);opacity:.6;margin:0;padding:0}.join-cta-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.join-cta-sign-in{font-size:14px;font-weight:500;color:var(--color-text);text-decoration:none;opacity:.65;transition:opacity .15s ease;white-space:nowrap}.join-cta-sign-in:hover{opacity:1}.my-project-tile{background:var(--color-surface);border:1px solid var(--color-rule);border-radius:16px;padding:8px;display:flex;flex-direction:column;gap:16px;text-decoration:none;color:inherit;box-shadow:0 0 0 1px #0000000f,0 1px 1px -.5px #0000000f,0 3px 3px -1.5px #0000000f,0 6px 6px -3px #0000000f;transition:background .15s ease,box-shadow .15s ease}a.my-project-tile:hover{color:inherit;background:var(--color-surface-hover);box-shadow:0 0 0 1px #00000014,0 2px 4px -1px #00000014,0 8px 16px -4px #00000014}.my-project-tile--loading{align-items:center;justify-content:center;color:var(--color-text);opacity:.5;font-size:15px;min-height:120px}.my-project-thumb-frame{background:var(--color-surface-hover);border-radius:8px;padding:4px;box-shadow:0 0 0 1px #0000000f,0 1px 1px -.5px #0000000f,0 3px 3px -1.5px #0000000f,0 6px 6px -3px #0000000f;align-self:flex-start;flex-shrink:0}.my-project-thumb{width:72px;height:72px;border-radius:6px;overflow:hidden;box-shadow:0 0 0 1px #0000000f,0 1px 1px -.5px #0000000f}.my-project-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.my-project-info{display:flex;flex-direction:column;gap:8px;padding:0 8px 8px;flex:1;justify-content:space-between}.my-project-title{font-size:24px;font-weight:600;line-height:1.2;letter-spacing:-.02em;color:var(--color-text-emphasis);margin:0}.my-project-divider{height:1px;background:var(--color-rule);width:100%}.my-project-main-content-wrapper{flex:max-content}.my-project-author,.my-project-description{font-size:15px;line-height:1.6;color:var(--color-text);display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.my-project-description{opacity:.6;line-clamp:2;-webkit-line-clamp:2;height:48px;margin:0}.my-project-author{opacity:.4;line-clamp:1;-webkit-line-clamp:1;height:24px;margin:6px 0}.my-project-tags{display:flex;flex-wrap:wrap;gap:4px;padding:0 8px}.my-project-bottom{display:flex;align-items:center;justify-content:space-between;min-height:32px;padding:0 8px}.my-project-date{font-size:15px;color:var(--color-text);opacity:.5}.my-project-actions{display:flex;align-items:center;gap:8px}.my-project-action{gap:6px;height:32px;padding:4px 8px;background:var(--base-50,#fff);border-radius:6px;color:var(--base-500,#919191);box-shadow:0 .975px .975px -.488px #0000000f,0 0 0 1px var(--base-300,#ebebeb)}.my-project-action,.my-project-draft-badge{display:inline-flex;align-items:center;font-size:15px}.my-project-draft-badge{gap:4px;color:var(--base-600,#4c4c4c)}.my-project-stats{gap:8px}.my-project-stat,.my-project-stats{display:inline-flex;align-items:center}.my-project-stat{gap:6px;height:32px;padding:4px 8px;background:var(--base-50,#fff);border-radius:6px;font-size:15px;color:var(--base-500,#919191);box-shadow:0 .975px .975px -.488px #0000000f,0 0 0 1px var(--base-300,#ebebeb)}.featured-projects-heading{font-size:64px;font-weight:600;letter-spacing:-.01em;line-height:1.1;color:var(--color-text-emphasis);margin:0 0 40px}@media(max-width:768px){.featured-projects-heading{font-size:40px;margin-bottom:24px}}.project-tile{background:var(--color-surface);border:1px solid var(--color-rule);border-radius:16px;padding:8px;display:flex;flex-direction:column;gap:16px;overflow:hidden;transition:box-shadow .15s ease,background .15s ease}.project-tile:hover{background:var(--color-surface-hover);box-shadow:0 0 0 1px #00000014,0 2px 4px -1px #00000014,0 8px 16px -4px #00000014}.project-tile-link{display:flex;flex-direction:column;gap:16px;text-decoration:none;color:inherit;flex:1}.project-tile-link:hover{color:inherit;background-color:transparent}.project-tile-preview{background:var(--color-surface-hover);border-radius:8px;height:300px;padding:4px;overflow:hidden;box-shadow:0 0 0 1px #0000000f,0 1px 1px -.5px #0000000f,0 3px 3px -1.5px #0000000f,0 6px 6px -3px #0000000f,0 12px 12px -6px #0000000f,0 24px 24px -12px #0000000f;flex-shrink:0;position:relative}.project-tile-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:6px;display:block}.project-tile-content{gap:16px;padding:8px;justify-content:space-between}.project-tile-body,.project-tile-content{display:flex;flex-direction:column;flex:1}.project-tile-body{gap:8px}.project-tile-title{padding:0 8px}.project-tile-title h3{font-size:24px;font-weight:500;line-height:1.2;letter-spacing:-.02em;color:var(--color-text-emphasis);margin:0}.project-tile-authors{padding:0 8px;display:flex;flex-wrap:wrap;gap:2px;font-size:15px}.project-tile-author-link{text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px;color:var(--color-text-emphasis)}.project-tile-author-link:hover{opacity:.7}.project-tile-divider{height:1px;background:var(--color-rule);margin:4px 8px}.project-tile-dek{padding:0 8px;font-size:15px;line-height:1.6;color:var(--color-text);opacity:.7;display:-webkit-box;line-clamp:3;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-tile-tags{padding:0 8px;display:flex;flex-wrap:wrap;gap:4px}.project-tile-tag{display:inline-flex;align-items:center;gap:2px;padding:2px 8px;border-radius:6px;font-size:15px;line-height:1.6;text-decoration:none;color:var(--color-text-emphasis);.tag-hash{opacity:.5}&:hover{text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px}}.project-tile-bottom{display:flex;align-items:center;justify-content:space-between;padding:0 8px}.project-tile-date{font-size:15px;color:var(--color-text);opacity:.5}.project-tile-actions{display:flex;align-items:center;gap:8px}.project-tile-action{display:inline-flex;align-items:center;gap:6px;height:32px;padding:4px 8px;background:var(--color-page-background);border:1px solid var(--color-rule);border-radius:6px;font-size:15px;color:var(--color-text);opacity:.7;box-shadow:0 1px 1px -.5px #0000000f}.learn-layout{display:block}@media(min-width:1024px){.learn-layout{display:grid;grid-template-columns:200px 1fr;gap:40px}}.learn-sidebar{display:none}@media(min-width:1024px){.learn-sidebar{display:block}}.learn-toc{position:sticky;top:80px}.learn-toc-title{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text);opacity:.5;margin:0 0 .75rem}.learn-toc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem}.learn-toc-link{display:block;padding:.375rem .75rem;border-radius:.5rem;font-size:.75rem;font-weight:400;color:var(--color-text);opacity:.7;text-decoration:none;transition:all .15s ease}.learn-toc-link:hover{opacity:1;background:var(--color-surface-hover);color:var(--color-text-emphasis)}.browse-section{padding-bottom:64px}.browse-header{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:24px}.browse-header .featured-projects-heading{margin-bottom:0}.browse-tabs{display:flex;align-items:center;gap:4px;flex-shrink:0}.browse-tab{display:inline-flex;align-items:center;height:36px;padding:0 14px;border:1px solid var(--color-rule);border-radius:8px;background:transparent;font-size:15px;font-weight:400;color:var(--color-text);cursor:pointer;transition:background .1s ease,color .1s ease,border-color .1s ease}.browse-tab:hover{background:var(--color-surface-hover);color:var(--color-text-emphasis)}.browse-tab.active,.browse-tab:hover{border-color:var(--color-text-emphasis)}.browse-tab.active{background:var(--color-text-emphasis);color:var(--color-page-background);font-weight:500}.browse-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px}.browse-tag{border:1px solid var(--color-rule);background:transparent;cursor:pointer;transition:background .1s ease,color .1s ease,border-color .1s ease}.browse-tag:hover{background:var(--color-surface-hover)}.browse-tag.active{background:var(--color-text-emphasis);color:var(--color-page-background);border-color:var(--color-text-emphasis)}.browse-loading{width:100%}.browse-empty{display:flex;justify-content:center;padding:48px 0;font-size:15px;color:var(--color-text);opacity:.5}.browse-pagination{gap:8px}@media(max-width:768px){.browse-header{flex-direction:column;align-items:flex-start}.browse-tabs{flex-wrap:wrap}}.promo-banner-light{display:inline-flex;align-items:center;gap:14px;margin-top:20px;margin-bottom:4px;padding:8px 14px;width:-moz-fit-content;width:fit-content;max-width:680px;text-decoration:none;color:inherit;background:#00000008;border:1px solid rgba(0,0,0,.1);border-radius:8px;transition:background .2s,border-color .2s}.promo-banner-light:hover{background:#0000000f;border-color:#00000026;color:inherit}.promo-banner-light .promo-badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff;background:linear-gradient(135deg,#ff6a00,#ee0979);border-radius:4px;flex-shrink:0;line-height:1.6}.promo-banner-light .promo-text{font-size:15px;color:var(--color-text,#666);margin:0;line-height:1.5}.promo-banner-light .promo-text strong{color:var(--color-text-emphasis,#111);font-weight:500}.promo-announcement-link--light{display:block;width:-moz-fit-content;width:fit-content;margin-top:0;font-size:13px;font-weight:500;--color-link-text:#333;--color-link-text-hover:#000;--color-link-background:transparent;--color-link-background-hover:transparent;color:#333;text-decoration:underline;text-decoration-color:#00000059;text-underline-offset:3px;transition:color .2s,text-decoration-color .2s}.promo-announcement-link--light:hover{color:#000;text-decoration-color:#0009;background-color:transparent}@media(max-width:640px){.promo-banner-light{flex-wrap:wrap;gap:6px}.promo-banner-light .promo-text{font-size:14px}}.project-content{line-height:var(--s-line-height,1rem);font-size:var(--s-font-size,16px);letter-spacing:-.015em;color:var(--color-text-emphasis);margin:0 auto;max-width:700px}.project-content h1{line-height:var(--xl-line-height,2rem);font-size:var(--xl-font-size,40px);margin:0 0 1.5rem}.project-content h1,.project-content h2{font-weight:600;letter-spacing:-.02em;color:var(--color-text-emphasis)}.project-content h2{line-height:var(--l-line-height,1.25rem);font-size:var(--l-font-size,22px);margin:2.5rem 0 1rem}.project-content h3,.project-content h4,.project-content h5,.project-content h6{line-height:var(--m-line-height,1.25rem);font-size:var(--m-font-size,18px);font-weight:600;margin:2rem 0 .75rem;color:var(--color-text-emphasis)}.project-content p{margin-bottom:1.5rem;line-height:1.7}.project-content p+p{text-indent:0}.project-content em{font-style:italic}.project-content strong{font-weight:600}.project-content a{color:#06c;text-decoration:underline;text-decoration-color:#0066cc4d;transition:text-decoration-color .2s}.project-content a:hover{background-color:transparent;color:#06c;text-decoration-color:currentColor}.project-content img{max-width:100%;height:auto;border-radius:4px;margin:2rem auto;display:block}.project-content iframe,.project-content video{max-width:min(800px,100%);margin:2rem auto;display:block;background:#000}.project-content figure{margin:2.5rem 0}.project-content figcaption{line-height:var(--xs-line-height,1rem);font-size:var(--xs-font-size,14px);color:var(--color-text);opacity:.7;text-align:center;margin-top:.75rem;font-style:italic}.project-content blockquote{border-left:3px solid var(--color-rule);padding-left:1.5rem;margin:2rem 0;color:var(--color-text);opacity:.8;font-style:italic}.project-content pre{color:var(--color-text);padding:1rem;border-radius:.25rem;overflow-x:auto;font-size:14px;line-height:1.5;margin:1.5rem 0}.project-content code,.project-content pre{background:var(--color-code-background);font-family:var(--font-family-monospace,"JetBrains Mono","SF Mono",Monaco,monospace)}.project-content code{hyphens:none}.project-content pre code{background:none}.project-content ol,.project-content ul{margin:1.5rem 0;padding-left:1.5rem}.project-content li{margin-bottom:.5rem;line-height:1.7}.project-content li>p{margin:0;line-height:1.7}@media(max-width:600px){.project-content{max-width:100%;overflow-x:hidden;word-break:break-word}.project-content h1{font-size:28px;line-height:1.2}.project-content h2{font-size:20px}.project-content h3,.project-content h4{font-size:17px}.project-content pre{font-size:12px;padding:12px;margin-left:-16px;margin-right:-16px;border-radius:0;width:calc(100% + 32px)}.project-content iframe,.project-content img,.project-content video{margin-left:-16px;margin-right:-16px;width:calc(100% + 32px);max-width:calc(100% + 32px);border-radius:0}.project-content blockquote,.project-content li,.project-content p,.project-content td,.project-content th{word-break:break-word;overflow-wrap:break-word;hyphens:auto}.project-content .katex-display,.project-content .math-display,.project-content math,.project-content mjx-container{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}.project-content table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}}@media(max-width:400px){.project-content :deep(pre){margin-left:-12px;margin-right:-12px;width:calc(100% + 24px)}.project-content :deep(img){margin-left:-12px;margin-right:-12px;width:calc(100% + 24px);max-width:calc(100% + 24px)}}.running-indicator[data-v-6c4bd2b2]{position:fixed;bottom:1.5rem;right:1.5rem;z-index:900;display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem .5rem 1rem;background:#191919e6;border-radius:.25rem;box-shadow:0 0 0 1px #262626,0 4px 24px #0006;color:#fafafa;font-size:.75rem;line-height:1.5;font-family:inherit;letter-spacing:.01em;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.running-indicator__dot[data-v-6c4bd2b2]{width:8px;height:8px;border-radius:50%;background:#22c55e;flex-shrink:0;box-shadow:0 0 6px #22c55e;animation:pulse-dot-6c4bd2b2 1.8s ease-in-out infinite}@keyframes pulse-dot-6c4bd2b2{0%,to{opacity:1;box-shadow:0 0 6px #22c55e}50%{opacity:.5;box-shadow:0 0 12px #22c55e}}.running-indicator__content[data-v-6c4bd2b2]{white-space:nowrap}.running-indicator a[data-v-6c4bd2b2]{color:#fff;text-decoration:underline;text-underline-offset:2px;text-decoration-color:#fff6;transition:color .15s,text-decoration-color .15s}.running-indicator a[data-v-6c4bd2b2]:hover{color:#fff;text-decoration-color:#fffc;background:none}.running-indicator__close[data-v-6c4bd2b2]{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;border-radius:.1875rem;background:#ffffff1a;color:#b0b0b0;cursor:pointer;flex-shrink:0;margin-left:.375rem;font-size:1rem;line-height:1;transition:color .15s,background .15s}.running-indicator__close[data-v-6c4bd2b2]:hover{background:#ffffff2e;color:#fff}.indicator-slide-enter-active[data-v-6c4bd2b2],.indicator-slide-leave-active[data-v-6c4bd2b2]{transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s ease}.indicator-slide-enter-from[data-v-6c4bd2b2],.indicator-slide-leave-to[data-v-6c4bd2b2]{transform:translateY(1rem);opacity:0}.account[data-v-3df8e871]{position:relative;height:100%}.account[data-v-3df8e871],.account-pill[data-v-3df8e871]{display:flex;align-items:center}.account-pill[data-v-3df8e871]{gap:8px;height:32px;padding:0 8px;border:none;border-radius:8px;background:#191919;box-shadow:0 1px 1px #fafafa0f,0 0 0 1px #fafafa14;color:#fafafa;cursor:pointer;transition:background .15s}.account-pill[data-v-3df8e871]:hover{background:#2a2a2a}.account-avatar[data-v-3df8e871]{width:24px;height:24px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.account-avatar--placeholder[data-v-3df8e871]{display:flex;align-items:center;justify-content:center;background:var(--color-nav-accent);color:#fafafa;font-size:11px;font-weight:500;letter-spacing:-.22px}.account-divider[data-v-3df8e871]{width:1px;height:16px;background:#fafafa1f}.account-credits[data-v-3df8e871]{display:flex;flex-direction:column;justify-content:center;gap:4px}.account-credits-figure[data-v-3df8e871]{font-size:12px;line-height:1.2}.account-credits-current[data-v-3df8e871]{color:#fafafa}.account-credits-cap[data-v-3df8e871]{color:#525252}.account-credits-track[data-v-3df8e871]{width:100%;height:2px;border-radius:6px;background:#525252}.account-credits-fill[data-v-3df8e871]{display:block;height:2px;border-radius:6px;background:#fafafa}.account-chevron[data-v-3df8e871]{color:#919191;transition:transform .15s}.account-chevron--open[data-v-3df8e871]{transform:rotate(180deg)}.account-dropdown[data-v-3df8e871]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;padding:6px;border-radius:8px;background:#191919;box-shadow:0 0 0 1px #fafafa14,0 8px 24px #00000080;z-index:1000}.account-dropdown-credits[data-v-3df8e871]{display:flex;justify-content:space-between;align-items:center;padding:8px 10px}.account-dropdown-credits-label[data-v-3df8e871]{font-size:12px;color:#919191}.account-dropdown-credits-value[data-v-3df8e871]{font-size:12px;font-weight:600;color:#fafafa}.account-dropdown-item[data-v-3df8e871]{display:block;width:100%;padding:8px 10px;border:none;border-radius:6px;background:none;color:#fafafa;font-size:14px;font-weight:500;text-align:left;text-decoration:none;cursor:pointer;transition:background .15s}.account-dropdown-item[data-v-3df8e871]:hover{background:#fafafa14}.account-dropdown-item--danger[data-v-3df8e871]{color:#fa7979}.account-dropdown-item--danger[data-v-3df8e871]:hover{background:#fa1e1e1f}.account-dropdown-divider[data-v-3df8e871]{height:1px;margin:6px 0;background:#fafafa1a}.drawer-root[data-v-dd8da6db]{position:fixed;inset:0;z-index:1000}.drawer-backdrop[data-v-dd8da6db]{position:absolute;inset:0;background:#00000080}.drawer-panel[data-v-dd8da6db]{position:absolute;top:0;right:0;width:280px;max-width:80vw;height:100%;padding:64px 16px 16px;background:#191919;box-shadow:-8px 0 24px #00000080;overflow-y:auto}.drawer-close[data-v-dd8da6db]{position:absolute;top:12px;right:12px;display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:8px;background:transparent;color:#919191;cursor:pointer}.drawer-close[data-v-dd8da6db]:hover{background:#fafafa14;color:#fafafa}.drawer-links[data-v-dd8da6db]{display:flex;flex-direction:column;gap:4px}.drawer-link[data-v-dd8da6db]{display:block;padding:12px;border-radius:8px;color:#fafafa;font-size:16px;font-weight:500;text-decoration:none}.drawer-link[data-v-dd8da6db]:hover{background:#fafafa14;box-shadow:inset 2px 0 0 var(--color-nav-accent-muted)}.drawer-link--active[data-v-dd8da6db],.drawer-link--active[data-v-dd8da6db]:hover{box-shadow:inset 2px 0 0 var(--color-nav-accent);color:#fff}.drawer-link--cta[data-v-dd8da6db],.drawer-link--cta[data-v-dd8da6db]:hover{margin-top:8px;background:var(--color-nav-accent);box-shadow:none;color:#191919;font-weight:600}.drawer-link--cta[data-v-dd8da6db]:hover{background:color-mix(in srgb,var(--color-nav-accent) 88%,#000)}.drawer-signin[data-v-dd8da6db]{margin-top:8px;padding:12px;border:none;border-radius:8px;background:#fafafa14;color:#fafafa;font-size:16px;font-weight:500;text-align:left;cursor:pointer}.drawer-signin[data-v-dd8da6db]:hover{background:#fafafa24}.drawer-enter-active[data-v-dd8da6db],.drawer-leave-active[data-v-dd8da6db]{transition:opacity .2s ease}.drawer-enter-from[data-v-dd8da6db],.drawer-leave-to[data-v-dd8da6db]{opacity:0}.drawer-enter-active .drawer-panel[data-v-dd8da6db],.drawer-leave-active .drawer-panel[data-v-dd8da6db]{transition:transform .2s ease}.drawer-enter-from .drawer-panel[data-v-dd8da6db],.drawer-leave-to .drawer-panel[data-v-dd8da6db]{transform:translate(100%)}.error-page-root{position:fixed;inset:0;z-index:9999;overflow:auto}.error-container{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background-color:#000}.error-container .hero-bg{position:absolute;top:0;right:0;width:100%;height:100%;z-index:0;pointer-events:none;background-image:url(../media/hero-bg.webp);background-size:cover;background-position:50%;opacity:.8}.error-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem;max-width:600px}.error-code{font-size:clamp(8rem,20vw,14rem);font-weight:800;line-height:1;margin:0 0 .5rem;background:linear-gradient(180deg,#fff,#ffffffb3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.05em}.error-message{font-size:clamp(1.5rem,4vw,2.5rem);font-weight:600;margin:0 0 1.5rem;color:#fff;letter-spacing:-.03em}.error-description{font-size:clamp(1rem,2vw,1.2rem);color:#fff9;margin:0 0 3rem;line-height:1.7;max-width:450px}.error-cta{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;background:#fdfdfd26;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.2);border-radius:50px;color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:inherit}.error-cta:hover{background:#fdfdfd40;border-color:#fff6;transform:translateY(-2px)}.error-cta .arrow{transition:transform .3s ease}.error-cta:hover .arrow{transform:translate(4px)}
