: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}}.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}nav.global{position:fixed;z-index:900;top:0;left:0;right:0;display:flex;.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem;background-color:#000c;backdrop-filter:blur(.5rem);border-radius:0;box-shadow:0 3px 6px #00000040;gap:.5rem}.tabs{display:flex;align-items:center;gap:.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;flex:1;min-width:0;&::-webkit-scrollbar{display:none}.tab{display:flex;align-items:center;justify-content:center;gap:1px;height:1.5rem;margin:0;padding:0 .5rem;border-radius:.25rem;color:#bfbfbf;text-decoration:none;line-height:var(--xxs-line-height);font-size:11px;font-weight:500;letter-spacing:0;white-space:nowrap;flex-shrink:0;cursor:pointer;transition:background .7s,color .7s;&[data-name=home]{padding-left:.5rem}svg{display:inline-block;width:.875rem;height:.875rem;fill:#bfbfbf;transition:fill .7s}&:hover{background:hsl(0 0 100/.1);color:#fff;transition:none;svg{fill:#fff;transition:none}}&.active,&.router-link-active{background:transparent;background:hsl(0 0 100/.25);color:#fff;font-weight:600;svg{fill:#fff}}}}}@media(min-width:600px){nav.global{top:.5rem;left:50%;right:auto;transform:translate(-50%);z-index:900;width:auto;.nav-inner{border-radius:.5rem;width:auto;justify-content:center;gap:.25rem}.tabs{flex:none;overflow-x:visible;.tab{border-radius:.25rem;line-height:var(--xs-line-height);font-size:var(--xs-font-size);padding:0 .75rem;svg{width:1rem;height:1rem}}}}}.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;.cta-container{padding:3rem 0 4rem}.hero{position:relative;display:flex;flex-direction:column;padding-top:120px;padding-bottom:80px;overflow:hidden;background-color:#000;.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;-webkit-mask-image:linear-gradient(180deg,#000 0,#000 30%,transparent 90%);mask-image:linear-gradient(180deg,#000 0,#000 30%,transparent 90%);img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}}.hero-content{position:relative;z-index:1;width:100%;flex:1;display:flex;flex-direction:column}.hero-branding{display:flex;flex-direction:row;align-items:center;gap:16px;margin-bottom:80px}.hero-logo{width:64px;height:64px;align-items:center;justify-content:center;.logo-wrapper{display:grid;grid-template-columns:1fr;grid-template-rows:1fr;place-items:start;position:relative;width:48px;height:64px}.logo-part-1{margin-left:9.48px;margin-top:0;display:block}.logo-part-1,.logo-part-2-wrapper{grid-area:1/1;width:29.2px;height:35.2px}.logo-part-2-wrapper{margin-left:0;margin-top:24.92px;display:flex;align-items:center;justify-content:center}.logo-part-2{width:100%;height:100%;transform:rotate(180deg);display:block}}.hero-brand-text{font-size:48px;font-weight:500;color:#fff;margin:0;letter-spacing:-.02em}.hero-main{max-width:800px;display:flex;flex-direction:column;align-items:flex-start}.hero-main a:hover{background-color:transparent}.hero-main h1{font-weight:500;line-height:1.1;margin-bottom:24px;letter-spacing:-.03em;background:linear-gradient(180deg,#fff,#ffffffb3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-fill-color:transparent}.hero-main .description{max-width:700px;margin-top:.25rem;margin-bottom:4rem;color:#fffc;line-height:var(--l-line-height);font-size:var(--l-font-size)}}.editors-picks{position:relative;padding-top:80px;padding-bottom:120px;overflow:hidden;background-color:#000}@keyframes glow-pulse{0%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}to{opacity:.6;transform:scale(1)}}.editors-picks:before{content:"";position:absolute;bottom:-30%;left:0;width:100%;height:100%;background:radial-gradient(ellipse at bottom,rgba(255,69,0,.4) 0,rgba(255,140,0,.2) 40%,transparent 70%);filter:blur(100px);z-index:0;pointer-events:none;animation:glow-pulse 8s ease-in-out infinite}.editors-picks>*{position:relative;z-index:1}.editors-picks h2{font-size:40px;margin-bottom:16px;font-weight:500;color:#fff}.subtitle{color:var(--color-text-secondary);margin-bottom:60px;font-size:18px;line-height:1.4}.picks-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:80px}.pick-card{background:transparent}.editors-picks .card-link{color:inherit}.editors-picks .card-link:hover{background-color:#ffffff08;transform:scale(1.02)}.editors-picks .card-image{width:100%;aspect-ratio:16/10;background:#111;padding:10px;border-bottom:3px solid #333;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;border-radius:4px;display:flex;align-items:center;justify-content:center;margin-bottom:24px}.editors-picks .card-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:2px}.pick-content h3{font-size:20px;margin-bottom:8px;font-weight:500;color:#fff}.year-row{font-size:15px;color:#999;margin-bottom:4px}.tags-row{font-size:15px;color:#666;margin-bottom:12px}.pick-content .description{font-size:16px;margin:0 0 24px;padding:0;text-indent:0;line-height:1.5;color:#ccc}.author-row{font-size:14px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;width:100%}.avatar{width:24px;height:24px;background-size:cover;border-radius:50%}.picks-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:32px;align-items:stretch}.picks-grid>*{min-width:0}.pick-card{height:100%;background:#ffffff0a;border:1px solid hsla(0,0%,100%,.06);border-radius:16px;padding:8px;box-shadow:0 0 0 1px #0000000f,0 1px 1px -.5px #0000000f;transition:transform .25s ease,box-shadow .25s ease}.pick-card,.pick-card .card-link{display:flex;flex-direction:column}.pick-card .card-link{flex:1;text-decoration:none;color:inherit}.pick-card:hover{transform:translateY(-4px);box-shadow:0 0 0 1px #ffffff14,0 8px 30px #00000059}.pick-card .preview-frame{flex-shrink:0;background:#ffffff0d;border-radius:8px;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}.pick-card .preview-inner{width:100%;height:100%;border-radius:6px;overflow:hidden;box-shadow:0 0 0 1px #0000000f,0 1px 1px -.5px #0000000f}.pick-card .preview-inner img{width:100%;height:292px;-o-object-fit:cover;object-fit:cover;display:block;transition:transform .3s ease}.pick-card:hover .preview-inner img{transform:scale(1.03)}.pick-card .tile-info{display:flex;flex-direction:column;gap:8px;padding:16px;flex:1}.pick-card .tile-title{font-size:24px;font-weight:400;color:#fff;line-height:1.2;margin:0;padding:0 8px;min-height:57.6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.pick-card .tile-author{font-size:15px;line-height:1.6;color:#fff9;padding:0 8px;text-decoration:underline;text-decoration-style:dotted;text-decoration-color:#ffffff59;text-underline-offset:3px}.pick-card .tile-divider{width:100%;height:1px;background:#ffffff14}.pick-card .tile-divider-bottom{margin-top:auto}.pick-card .tile-description{font-size:15px;line-height:1.6;color:#ffffff73;margin:0;padding:0 8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.pick-card .tile-tags{display:flex;flex-wrap:nowrap;gap:4px;padding:0;overflow:hidden}.pick-card .tile-tag{display:inline-flex;align-items:center;gap:2px;font-size:15px;line-height:1.6;color:#ffffff80;padding:2px 8px;text-decoration:underline;text-decoration-style:dotted;text-decoration-color:#fff3;text-underline-offset:3px}.pick-card .tile-tag .hash{color:#ffffff4d;margin-right:1px}.pick-card .tile-bottom{display:flex;align-items:center;justify-content:space-between;padding:0 8px}.pick-card .tile-date{font-size:15px;line-height:1.6;color:#ffffff59}.pick-card .tile-actions{display:flex;gap:8px}.pick-card .tile-stat{display:inline-flex;align-items:center;gap:6px;height:32px;padding:4px 8px;font-size:15px;line-height:1.6;color:#ffffff59;background:#ffffff0a;border-radius:6px;box-shadow:0 0 0 1px #ffffff14,0 1px 1px -.5px #0000000f}.pick-card .tile-stat svg{width:16px;height:16px;opacity:.7}@media(max-width:900px){.picks-grid{grid-template-columns:repeat(2,1fr);gap:24px}}@media(max-width:580px){.picks-grid{grid-template-columns:1fr;gap:20px}.pick-card .preview-frame{height:220px}}.latest-experiments{padding-top:120px;padding-bottom:60px;background:#fdfdfd;color:#111}.latest-experiments h2{font-size:40px;margin-bottom:16px;font-weight:500}.latest-experiments .subtitle{margin-bottom:0}.experiments-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:0}.latest-experiments .browse-tab{color:#111;border-color:#ddd}.latest-experiments .browse-tab:hover{background:#f0f0f0}.latest-experiments .browse-tab.active{background:#111;color:#fdfdfd;border-color:#111}.experiment-description{margin:2px 0 4px;font-size:13px;color:#6f6f6f;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.latest-experiments .tags-list,.latest-experiments .tags-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;margin-bottom:4px}.latest-experiments .tags-list .tag,.latest-experiments .tags-row .tag{margin:0;padding:2px 8px;font-size:13px}.experiments-list{margin-top:24px;border-top:1px solid #eee}.load-more-link:hover{background-color:transparent}.list-item{display:grid;grid-template-columns:100px 3fr 2fr;padding:16px;margin:0 -16px;align-items:start;border-bottom:1px solid #eee;font-size:15px;color:inherit;border-radius:12px;transition:all .2s ease}.list-item:hover{background-color:#f5f5f5;transform:scale(1.02);z-index:10;position:relative;border-bottom-color:transparent}.list-item--api{grid-template-columns:100px 1fr;position:relative;cursor:pointer}.row-overlay{position:absolute;inset:0;z-index:0;border-radius:inherit;padding:0;margin:0;color:inherit}.row-overlay,.row-overlay:hover{background:transparent!important}.inner-link{position:relative;z-index:1}.meta-row{display:flex;flex-wrap:wrap;align-items:center;gap:4px 6px;margin-top:6px;font-size:12px;color:#6f6f6f}.meta-author{font-weight:500;color:#333}.meta-avatar{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#222;color:#fff;font-size:10px;font-weight:600;flex-shrink:0;line-height:1;letter-spacing:0}.meta-avatar--img{-o-object-fit:cover;object-fit:cover;background:transparent}.meta-sep{color:#ccc;-webkit-user-select:none;-moz-user-select:none;user-select:none}.meta-date{color:#999}.meta-stat{display:inline-flex;align-items:center;gap:3px;color:#6f6f6f}.meta-stat svg{flex-shrink:0;opacity:.55}.date{color:#6f6f6f}.title-cell{display:flex;flex-direction:column;gap:4px}.project-link{text-decoration:none;color:inherit;display:block}.project-link:hover{background-color:transparent}.project-link:hover .project-name{text-decoration:underline}.project-name{font-weight:500;font-size:15px}.tags-row{font-size:13px;color:#6f6f6f;line-height:1.4}.tag-link{color:#999;text-decoration:none;transition:color .2s}.tag-link:hover{color:#111;background-color:transparent}.author-cell{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#6f6f6f;font-size:15px}.avatar-small{width:24px;height:24px;background-color:#eee;background-size:cover;border-radius:50%}.topic{color:#6f6f6f}.preview-cell{display:flex;gap:8px;justify-content:flex-start}.preview-cell img{width:72px;aspect-ratio:16/10;-o-object-fit:cover;object-fit:cover;border-radius:4px}.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:768px){.hero-main h1{font-size:48px}.list-item{grid-template-columns:1fr 1fr;gap:16px}.list-item:not(.list-item--api)>:nth-child(n+3){display:none}.list-item--api{grid-template-columns:100px 1fr}.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-00cd83bc]{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-00cd83bc]{width:8px;height:8px;border-radius:50%;background:#22c55e;flex-shrink:0;box-shadow:0 0 6px #22c55e;animation:pulse-dot-00cd83bc 1.8s ease-in-out infinite}@keyframes pulse-dot-00cd83bc{0%,to{opacity:1;box-shadow:0 0 6px #22c55e}50%{opacity:.5;box-shadow:0 0 12px #22c55e}}.running-indicator__content[data-v-00cd83bc]{white-space:nowrap}.running-indicator a[data-v-00cd83bc]{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-00cd83bc]:hover{color:#fff;text-decoration-color:#fffc;background:none}.running-indicator__close[data-v-00cd83bc]{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-00cd83bc]:hover{background:#ffffff2e;color:#fff}.indicator-slide-enter-active[data-v-00cd83bc],.indicator-slide-leave-active[data-v-00cd83bc]{transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s ease}.indicator-slide-enter-from[data-v-00cd83bc],.indicator-slide-leave-to[data-v-00cd83bc]{transform:translateY(1rem);opacity:0}.nav-auth[data-v-0336b530]{position:relative;flex-shrink:0}.nav-auth[data-v-0336b530],.nav-signin[data-v-0336b530]{display:flex;align-items:center;margin-left:.25rem}.nav-signin[data-v-0336b530]{justify-content:center;height:1.5rem;padding:0 .75rem;background:hsl(0 0 100/.1);color:#fff;border:1px solid hsl(0 0 100/.2);border-radius:.25rem;font-weight:500;font-size:var(--xxs-font-size);line-height:var(--xxs-line-height);text-decoration:none;transition:all .2s ease}@media(min-width:432px){.nav-signin[data-v-0336b530]{font-size:var(--xs-font-size);line-height:var(--xs-line-height)}}.nav-signin[data-v-0336b530]:hover{background:hsl(0 0 100/.2);border-color:hsl(0 0 100/.4);color:#fff;box-shadow:0 0 8px hsl(0 0 100/.1)}.user-menu[data-v-0336b530]{display:flex;align-items:center;gap:.5rem;height:1.5rem;padding:0 .75rem;border-radius:.25rem;cursor:pointer;background:transparent;color:#bfbfbf;border:1px solid transparent;font-weight:500;transition:all .2s ease;margin-left:.25rem}.user-menu[data-v-0336b530]:hover{background:hsl(0 0 100/.2);border-color:hsl(0 0 100/.4);color:#fff;box-shadow:0 0 8px hsl(0 0 100/.1)}.user-menu--active[data-v-0336b530]{color:#fff}.user-menu--active .user-name[data-v-0336b530]{text-decoration:underline;text-underline-offset:4px}.user-avatar[data-v-0336b530]{width:20px;height:20px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.user-avatar--placeholder[data-v-0336b530]{display:flex;align-items:center;justify-content:center;background:var(--color-primary,#6366f1);color:#fff;font-weight:600;font-size:.65rem}.user-name[data-v-0336b530]{font-size:var(--xxs-font-size);line-height:var(--xxs-line-height);font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(min-width:432px){.user-name[data-v-0336b530]{font-size:var(--xs-font-size);line-height:var(--xs-line-height)}}.dropdown-icon[data-v-0336b530]{opacity:.6}.user-dropdown[data-v-0336b530]{position:absolute;top:calc(100% + .5rem);right:0;background:#18181bf2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid hsl(0 0 100/.1);border-radius:.5rem;box-shadow:0 4px 24px #0006;min-width:180px;padding:.5rem;z-index:100}.dropdown-item[data-v-0336b530]{display:block;width:100%;padding:.625rem .75rem;border:none;background:none;text-align:left;font-size:var(--xxs-font-size);line-height:var(--xxs-line-height);color:#e6e6e6;border-radius:.25rem;cursor:pointer;text-decoration:none;transition:background .15s}@media(min-width:432px){.dropdown-item[data-v-0336b530]{font-size:var(--xs-font-size);line-height:var(--xs-line-height)}}.dropdown-item[data-v-0336b530]:hover{background:hsl(0 0 100/.1);color:#fff}.dropdown-item--danger[data-v-0336b530]{color:var(--color-error,#ef4444)}.dropdown-item--danger[data-v-0336b530]:hover{background:#ff000026;color:#fa7979}.dropdown-divider[data-v-0336b530]{height:1px;background:hsl(0 0 100/.1);margin:.5rem 0}.dropdown-credits[data-v-0336b530]{display:flex;justify-content:space-between;align-items:center;padding:.625rem .75rem;color:#e6e6e6}.credits-label[data-v-0336b530]{color:#b3b3b3}.credits-label[data-v-0336b530],.credits-value[data-v-0336b530]{font-size:var(--xxs-font-size);line-height:var(--xxs-line-height)}.credits-value[data-v-0336b530]{font-weight:600;color:#fff}@media(min-width:432px){.credits-label[data-v-0336b530],.credits-value[data-v-0336b530]{font-size:var(--xs-font-size);line-height:var(--xs-line-height)}}@media(max-width:768px){.dropdown-icon[data-v-0336b530],.user-name[data-v-0336b530]{display:none}}.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)}
