*,:after,:before{box-sizing:border-box}:root{font-size:14px;--color-text:#131313;--color-bg:#fff;--color-link:#000;--color-link-hover:#131313;--padding-sides:2rem;--padding-row:1rem;--color-row-border:#f0f0f0;--color-bg-row-hover:#f0f0f0;--color-text-alt:#000;--image-gap:1vw;--image-gap-large:2vw;--img-size:5vw;--img-size-large:10vw}body{margin:0;color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;font-family:auger-mono,monospace;font-weight:300;text-transform:uppercase}.oh,body{position:relative}.oh{overflow:hidden}.oh__inner{will-change:transform;display:inline-block}.js .loading:after,.js .loading:before{content:"";position:fixed;z-index:1000}.js .loading:before{top:0;left:0;width:100%;height:100%;background:var(--color-bg)}.js .loading:after{top:50%;left:50%;width:60px;height:60px;margin:-30px 0 0 -30px;border-radius:50%;opacity:.4;background:var(--color-link);animation:loaderAnim .7s linear infinite alternate forwards}@keyframes loaderAnim{to{opacity:1;transform:scale3d(.5,.5,1)}}a{text-decoration:none;color:var(--color-link);outline:none;cursor:pointer}.a_link,.a_link:hover{color:#fff;text-decoration:underline}.hover-line{overflow:hidden;position:relative}.hover-line:before{content:"";height:1px;width:100%;background:currentColor;position:absolute;top:92%;transition:transform .3s;transform-origin:0 50%}.hover-line:hover:before{transform:scaleX(0);transform-origin:100% 50%}a:hover{text-decoration:none;color:var(--color-link-hover);outline:none}a:focus{outline:none;background:#d3d3d3}a:focus:not(:focus-visible){background:transparent}a:focus-visible{outline:2px solid red;background:transparent}.unbutton{background:none;border:0;padding:0;margin:0;font:inherit;cursor:pointer}.unbutton:focus{outline:none}.frame{width:100%;padding:3rem var(--padding-sides);display:grid;grid-template-columns:1fr;grid-template-rows:auto auto auto;grid-template-areas:"title" "prevdemo" "sponsor";justify-content:start;grid-row-gap:1rem;align-items:end;justify-items:start}.frame__title{grid-area:title;display:flex;line-height:1}.frame__title-main{font-size:1.953rem;margin:0;font-weight:400;font-family:neue-haas-grotesk-display,sans-serif;text-transform:none}.frame__title-back{position:relative;display:flex;align-items:flex-end}.frame__title-back span{display:none}.frame__title-back svg{fill:currentColor}.frame__prevdemo{grid-area:prevdemo}.intro{padding:1rem var(--padding-sides) 3rem}.intro p{max-width:860px}.cover{background:var(--color-bg-row-hover);width:100%;height:0;opacity:0;pointer-events:none;z-index:10;position:fixed;left:0;will-change:height,top}.content{z-index:100;border-bottom:1px solid var(--color-row-border)}.row{z-index:1;color:var(--color-text);display:grid;grid-template-rows:var(--img-size);grid-template-columns:auto 1fr;grid-column-gap:5vw;align-items:center;padding:var(--padding-row) var(--padding-sides);border-top:1px solid var(--color-row-border);transition:background-color .3s ease-out,border-color .3s ease-out}.row:hover{background-color:var(--color-bg-row-hover)}.row--current{z-index:11;transition:border-color .3s ease-out}.cell{position:relative}.cell__title,.preview__item-title{margin:0;font-size:clamp(1.953rem,4vw,3.052rem);position:relative;font-weight:400;line-height:1;font-family:neue-haas-grotesk-display,sans-serif;white-space:nowrap}.cell__title--switch{font-family:lores-22-serif,sans-serif;font-weight:700}.cell__title{display:grid;grid-template-rows:100% 100%}.cell--images{display:grid;align-content:center;grid-auto-columns:auto;grid-auto-flow:column;grid-gap:var(--image-gap);justify-content:end;margin-left:auto}.cell__img{width:var(--img-size);display:grid;position:relative;grid-template-columns:100%;grid-template-rows:auto auto;will-change:transform,opacity;opacity:0}.cell__img-inner{background-size:cover;background-position:50% 50%;aspect-ratio:1;width:100%;border-radius:calc(var(--image-gap) / 3)}.cell__img-title{max-width:100%;font-size:1rem;font-weight:300;color:var(--color-text-alt);margin:0;height:0;opacity:0;white-space:nowrap;will-change:opacity,transform;display:none}.page-footer{padding:10vw 10vw 5vw}.page-footer__text{max-width:860px;margin:1.5rem auto;line-height:1.5}.page-footer__credits{padding-top:10vh;text-align:center}.preview{position:fixed;width:100%;height:100%;top:0;left:0;pointer-events:none;z-index:200}.preview__close{position:absolute;top:0;right:0;font-size:2rem;font-weight:400;line-height:1;padding:2rem;cursor:pointer;opacity:0;font-family:sans-serif}.preview__close--show{pointer-events:auto}.preview__item{width:100%;height:100%;display:grid;align-items:center;justify-items:center;align-content:center;grid-gap:10vh;height:0;opacity:0;overflow:hidden}.preview__item--current{pointer-events:auto;height:100vh;opacity:1}.preview__item-title{font-family:lores-22-serif,sans-serif;font-weight:700;font-size:clamp(1.563rem,6vw,3.815rem)}.grid{position:relative;display:grid;max-width:1200px;width:100%;grid-gap:var(--image-gap-large);justify-content:center;justify-items:center;--img-size:var(--img-size-large);grid-template-columns:repeat(7,var(--img-size));grid-template-rows:repeat(2,var(--img-size))}.grid .cell__img{width:var(--img-size-large)}@media screen and (min-width:61em){.frame{grid-template-rows:auto;grid-template-areas:"title prevdemo sponsor";grid-template-columns:auto auto 1fr;grid-column-gap:2rem}:root{--padding-sides:4rem;--padding-row:2rem}}.images-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:16px;gap:16px;position:relative}.image-wrapper{position:relative;overflow:hidden;border-radius:8px;transition:all .3s ease;cursor:pointer}.image-wrapper:hover{transform:scale(1.03);z-index:10}.hover-card{position:absolute;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.7);display:flex;flex-direction:column;justify-content:flex-end;opacity:0;transition:opacity .3s ease;pointer-events:none}.image-wrapper:hover .hover-card{opacity:1}.hover-card-content{background:linear-gradient(0deg,rgba(0,0,0,.9) 0,rgba(0,0,0,.7) 70%,transparent);padding:16px;color:#fff;text-align:left}.hover-card-title{font-size:16px;font-weight:600;margin-bottom:6px}.hover-card-description{font-size:12px;opacity:.9;margin-bottom:8px}.hover-card-tags{display:flex;flex-wrap:wrap;gap:4px}.hover-card-tag{background-color:hsla(0,0%,100%,.2);font-size:10px;padding:2px 6px;border-radius:4px}.content,.row{position:relative}.dimming-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:5}.image-wrapper:hover~.dimming-overlay{opacity:1}.portfolio-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;display:flex;align-items:center;justify-content:center}.overlay-background{position:absolute;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.85);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.overlay-content{position:relative;width:90%;max-width:1200px;max-height:90vh;background-color:#1a1a1a;border-radius:8px;padding:40px;color:#fff;overflow-y:auto;z-index:1001;box-shadow:0 10px 30px rgba(0,0,0,.5)}.overlay-close{position:absolute;top:20px;right:20px;font-size:24px;color:#fff;background:none;border:none;cursor:pointer;z-index:1002;transition:transform .3s ease}.overlay-close:hover{transform:rotate(90deg)}.overlay-content h2{font-size:36px;margin-bottom:30px;font-weight:700}.overlay-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:20px;margin-bottom:40px}.overlay-image{aspect-ratio:16/9;overflow:hidden;border-radius:4px}.overlay-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.overlay-image:hover img{transform:scale(1.05)}.overlay-details{padding-top:20px;border-top:1px solid hsla(0,0%,100%,.1)}.overlay-details h3{font-size:24px;margin-bottom:15px;font-weight:600}.overlay-details p{font-size:16px;line-height:1.6;margin-bottom:20px;color:hsla(0,0%,100%,.8)}.overlay-metadata{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:15px;margin:30px 0}.metadata-item{padding:10px;background-color:hsla(0,0%,100%,.05);border-radius:4px}.overlay-actions{display:flex;gap:15px;margin-top:30px}.action-button{padding:12px 24px;background-color:#3a86ff;color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer;transition:background-color .3s ease}.action-button:hover{background-color:#2667cc}body.overlay-open{overflow:hidden}.row{cursor:pointer;transition:opacity .3s ease}.row:hover{opacity:.9}.preview__item-description{margin:2rem 0;max-width:800px;padding:0 1rem}.preview__item-text{margin-bottom:1.5rem;line-height:1.6;font-size:1.1rem;color:#333}@media (max-width:768px){.preview__item-description{padding:0 1.5rem}.preview__item-text{font-size:1rem}}.gooey-container{filter:url(#gooey)}@keyframes blobFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1.1)}}.blob-1{animation:blobFloat 3s ease-in-out infinite}.blob-2{animation:blobFloat 4s ease-in-out .5s infinite}.blob-3{animation:blobFloat 3.5s ease-in-out 1s infinite}@keyframes popIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.pop-in{animation:popIn .3s cubic-bezier(.68,-.55,.27,1.55) forwards}.chat-button{transition:all .5s cubic-bezier(.68,-.55,.27,1.55)}.chat-button:hover{transform:scale(1.1)}.gooey-blob{background-color:#000;border-radius:50%;position:absolute;transition:all .5s cubic-bezier(.68,-.55,.27,1.55)}.flex-1{margin-bottom:12px;margin-top:12px}.cell__img-link{display:block;cursor:pointer;transition:transform .3s ease;text-decoration:none}.cell__img-link:hover{transform:translateY(-5px)}.grid a{display:contents}.cell__img-inner:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.1);opacity:0;transition:opacity .3s ease;border-radius:calc(var(--image-gap) / 3)}.cell__img-link:hover .cell__img-inner:after{opacity:1}.dialog-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.85);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;width:100%;height:100%;pointer-events:none;will-change:opacity;transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.dialog-backdrop.active{opacity:1;pointer-events:auto}.image-dialog-overlay{position:relative;width:1200px;max-width:calc(100% - 40px);height:auto;max-height:90vh;background:hsla(0,0%,100%,.15);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border:1px solid hsla(0,0%,100%,.2);border-radius:16px;box-shadow:0 8px 32px rgba(31,38,135,.2);z-index:10001;display:flex;flex-direction:column;overflow:hidden;transform:scale(.95);opacity:0;transition:all .3s cubic-bezier(.19,1,.22,1);color:#000}.image-dialog-overlay.active{opacity:1;transform:scale(1)}.image-dialog-content{width:100%;padding:0;display:flex;flex-direction:column;overflow-y:auto;max-height:90vh}.image-dialog-content::-webkit-scrollbar{display:none}.image-dialog-layout{display:flex;flex-direction:column}.image-dialog-image{width:100%;height:300px;overflow:hidden;margin-bottom:0;border-radius:15px 15px 0 0;display:flex;align-items:center;justify-content:center;background-color:#0a0a0a}.image-dialog-image img{max-width:100%;max-height:300px;width:auto;height:auto;object-fit:contain;display:block;transform:translateY(10px);transition:opacity .5s ease,transform .5s ease;transition-delay:.2s;opacity:0}.image-dialog-overlay.active .image-dialog-image img{opacity:1;transform:translateY(0)}.image-dialog-details{padding:30px;color:#fff;overflow-y:auto}.image-dialog-details h2{font-size:24px;margin-top:0;margin-bottom:20px;font-weight:700;color:#fff}.image-dialog-details h3{font-size:18px;margin-top:25px;margin-bottom:10px;font-weight:600;color:#f0f0f0}.image-dialog-description{margin-bottom:25px;line-height:1.6;color:hsla(0,0%,100%,.9);font-size:16px}.image-dialog-section{margin-bottom:25px}.image-dialog-section p{margin-top:0;line-height:1.6;color:hsla(0,0%,100%,.8)}.image-dialog-website{color:#fff;white-space:nowrap;font-size:28px}.image-dialog-metadata-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:15px;gap:15px;margin:25px 0;background-color:hsla(0,0%,100%,.05);padding:15px;border-radius:8px}.image-dialog-metadata{color:hsla(0,0%,100%,.7);font-size:14px}.image-dialog-technologies{margin:25px 0}.image-dialog-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.image-dialog-tag{background-color:hsla(0,0%,100%,.1);padding:8px 12px;border-radius:6px;font-size:14px;color:hsla(0,0%,100%,.9);font-weight:500}.image-dialog-features{margin:15px 0;padding-left:20px}.image-dialog-features li{margin-bottom:8px;color:hsla(0,0%,100%,.8);line-height:1.5}.image-dialog-link{margin-top:30px;display:flex;justify-content:center}.image-dialog-button{display:inline-block;padding:12px 24px;background-color:#3a86ff;color:#fff;text-decoration:none;border-radius:6px;font-weight:500;transition:background-color .3s ease,transform .3s ease;text-align:center}.image-dialog-button:hover{background-color:#2667cc;transform:translateY(-2px)}.image-dialog-details>*{opacity:0;transform:translateY(15px);transition:opacity .4s ease,transform .4s ease}.image-dialog-overlay.active .image-dialog-details>*{opacity:1;transform:translateY(0)}.image-dialog-overlay.active .image-dialog-details>:first-child{transition-delay:.3s}.image-dialog-overlay.active .image-dialog-details>:nth-child(2){transition-delay:.4s}.image-dialog-overlay.active .image-dialog-details>:nth-child(3){transition-delay:.5s}.image-dialog-overlay.active .image-dialog-details>:nth-child(4){transition-delay:.6s}.image-dialog-overlay.active .image-dialog-details>:nth-child(5){transition-delay:.7s}.image-dialog-close{position:absolute;top:15px;right:15px;width:36px;height:36px;font-size:20px;color:#fff;background:rgba(0,0,0,.5);border:none;border-radius:50%;cursor:pointer;z-index:10002;display:flex;align-items:center;justify-content:center;transition:background .3s ease,transform .3s ease;padding:0;line-height:1}.image-dialog-close:hover{background:hsla(0,0%,100%,.2);transform:rotate(90deg)}body.dialog-open{overflow:hidden}.technical-details-content{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.technical-details-content p{margin-bottom:1rem;line-height:1.6;color:hsla(0,0%,100%,.9)}.code-block-wrapper{margin:1.5rem 0;border-radius:8px;overflow:hidden;background-color:#1e1e1e;box-shadow:0 4px 8px rgba(0,0,0,.2)}.code-block-header{display:flex;align-items:center;padding:8px 16px;background-color:#252525;border-bottom:1px solid #333}.code-language{font-size:.8rem;font-weight:500;color:#e6e6e6;text-transform:uppercase;letter-spacing:.5px}.technical-details-content pre{margin:0;padding:16px;overflow-x:auto;font-family:Fira Code,Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:.9rem;line-height:1.5;-moz-tab-size:4;tab-size:4;color:#e6e6e6}.technical-details-content code{font-family:inherit;background:transparent;padding:0;white-space:pre}.language-javascript,.language-js,.language-ts,.language-typescript{color:#dcdcaa}.language-html{color:#ce9178}.language-css{color:#9cdcfe}.language-python{color:#4ec9b0}.image-dialog-details .technical-details-content code{color:hsla(0,0%,100%,.95)}@media (max-width:768px){.technical-details-content pre{font-size:.8rem;padding:12px}.code-block-header{padding:6px 12px}}.code-block-wrapper.theme-dark{background-color:#1a1a1a}.code-block-wrapper.theme-light{background-color:#f5f5f5}.code-block-wrapper.theme-light .code-block-header{background-color:#e0e0e0}.code-block-wrapper.theme-light .code-language,.code-block-wrapper.theme-light code,.code-block-wrapper.theme-light pre{color:#333}.technical-details-formatted{font-family:monospace;line-height:1.5;color:hsla(0,0%,100%,.9)}.code-section-heading{font-size:1rem;font-weight:700;color:#fff;background-color:#333;padding:8px 12px;margin:20px 0 0;border-top:1px solid #444;border-bottom:1px solid #444;font-family:monospace;letter-spacing:.5px}.heading-marker{color:#888}.code-language-label{display:block;background-color:#222;color:#888;padding:6px 12px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid #333}.code-block-container{margin:0 0 20px;background-color:#1a1a1a;border-radius:3px;overflow:hidden}.code-content{padding:12px;margin:0;background-color:#1a1a1a;overflow-x:auto;color:#ddd;font-family:Courier New,monospace;font-size:.9rem}.code-line{white-space:pre-wrap;line-height:1.4;padding:1px 0}.markdown-text{padding:8px 12px;margin:10px 0;line-height:1.6}.markdown-paragraph{margin:8px 0;color:#ccc}.markdown-list-item{margin:4px 0 4px 20px;list-style-type:disc;color:#ccc}.markdown-text p:first-child:not(:only-child){font-weight:700;margin-bottom:10px}.image-dialog-section .technical-details-content{background-color:#222;border-radius:6px;border:1px solid #333;overflow:hidden;font-family:monospace}.technical-details-formatted pre{overflow-x:auto}@media (max-width:768px){.code-content{font-size:.8rem}.code-language-label{font-size:.7rem}.code-section-heading{font-size:.9rem}}.image-dialog-video{margin:1rem 0;width:100%;max-height:400px;overflow:hidden}.project-video{width:100%;height:auto;max-height:400px;object-fit:contain;border-radius:4px;background-color:#000}