@font-face{font-family:TWK Lausanne;src:url(../TWK-Lausanne.woff2) format("woff2")}*,*:after,*:before{box-sizing:border-box;margin:0;padding:0}:root{font-size:12px;--color-text: #1a1a1a;--color-bg: #f8dfbc;--color-link: #1a1a1a;--color-link-hover: #1a1a1a;--page-padding: 1.5rem}body{margin:0;color:var(--color-text);background-color:var(--color-bg);font-family:ui-monospace,monospace;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.skip-link{position:absolute;top:-40px;left:6px;background:var(--color-text);color:var(--color-bg);padding:8px;text-decoration:none;border-radius:4px;z-index:10000;font-weight:600;transition:top .3s}.skip-link:focus{top:6px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}html,body{max-width:100vw;overflow-x:hidden;font-family:TWK Lausanne,sans-serif;touch-action:manipulation;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{margin:0}@media (scripting: enabled){.loading:before,.loading:after{content:"";position:fixed;z-index:10000}.loading:before{top:0;left:0;width:100%;height:100%;background:var(--color-bg)}.loading:after{top:50%;left:50%;width:100px;height:1px;margin:0 0 0 -50px;background:var(--color-link);animation:loaderAnim 1.5s ease-in-out infinite alternate forwards}}@keyframes loaderAnim{0%{transform:scaleX(0);transform-origin:0% 50%}50%{transform:scaleX(1);transform-origin:0% 50%}50.1%{transform:scaleX(1);transform-origin:100% 50%}to{transform:scaleX(0);transform-origin:100% 50%}}a{text-decoration:none;color:var(--color-link);outline:none;cursor:pointer}a:hover{text-decoration:underline;color:var(--color-link-hover)}a:focus{outline:none;background:#d3d3d3}a:focus:not(:focus-visible){background:transparent}a:focus:focus-visible{outline:2px solid #0066cc;outline-offset:2px;background:transparent}.frame{display:grid;z-index:2;grid-row-gap:1rem;grid-column-gap:1.5rem;pointer-events:none;justify-items:start;align-content:start;padding:var(--page-padding);height:100vh;position:fixed;top:0;left:0;width:100%;grid-template-columns:auto 1fr auto auto auto auto auto;grid-template-rows:auto 1fr;grid-template-areas:"title title x github linkedin instagram youtube" "sponsor sponsor sponsor sponsor sponsor sponsor sponsor"}@media (max-width: 970px){.frame{grid-template-columns:1fr;grid-template-rows:auto auto auto 1fr;grid-template-areas:"title" "socials" "search" "sponsor";justify-items:start}}.frame #cdawrap{max-width:260px;align-self:end}.frame a,.frame button{pointer-events:auto}.frame .frame__title{display:flex;justify-content:center;align-items:center;grid-area:title;margin:0;padding:.75rem 1.5rem;background:#f8dfbccc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:2rem;border:1px solid rgba(26,26,26,.1)}@media (max-width: 970px){.frame .frame__title{width:100%}}.frame .frame__title h1{font-size:1.15rem}.frame .frame__social{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;transition:all .3s ease;background:#f8dfbccc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(26,26,26,.1)}.frame .frame__social:hover{background:#f8dfbce6;transform:scale(1.1);text-decoration:none;border-color:#1a1a1a33}.frame .frame__social svg{width:20px;height:20px;fill:var(--color-text);transition:fill .3s ease}.frame .frame__social:nth-of-type(1){grid-area:x}.frame .frame__social:nth-of-type(2){grid-area:github}.frame .frame__social:nth-of-type(3){grid-area:linkedin}.frame .frame__social:nth-of-type(4){grid-area:instagram}.frame .frame__social:nth-of-type(5){grid-area:youtube}.frame .socials-wrapper{display:contents}@media (max-width: 970px){.frame .socials-wrapper{grid-area:socials;display:flex;flex-wrap:wrap;gap:.8rem;width:100%;justify-content:space-between}}.frame .frame__tags{grid-area:tags;display:flex;flex-wrap:wrap;gap:1rem}.frame .frame__demos{grid-area:demos;display:flex;flex-wrap:wrap;gap:1rem}.content{padding:var(--page-padding);display:flex;flex-direction:column;width:100vw;position:relative}@media screen and (min-width: 53em){.content{min-height:100vh;justify-content:center;align-items:center}}.line,.char{transform:translate3d(0,100%,0)}.container{position:fixed;width:100vw;height:100vh;top:0;left:0;transform-origin:center center;will-change:transform}.container:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-color:#000;z-index:2;pointer-events:none;opacity:0;transition:opacity .45s ease-in-out}.grid{position:absolute;width:max-content;height:max-content;display:flex;gap:5vw;will-change:transform;transform:translateZ(0);backface-visibility:hidden}.grid:focus-visible{outline:2px solid #0066cc;outline-offset:4px}.--is-loaded{overflow:hidden}.--is-loaded .grid{transition:transform .45s cubic-bezier(.33,1,.68,1);cursor:grab;will-change:transform}@media (max-width: 600px){.--is-loaded.--is-details-showing{overflow:visible}}.column{display:flex;flex-direction:column;gap:5vw}.column:nth-child(2n){margin-top:10vw}.short{position:relative;width:18.5vw;aspect-ratio:9 / 16;border-radius:1vw;overflow:hidden;will-change:transform,opacity;transform:translateZ(0);backface-visibility:hidden;contain:layout style paint}.short div{width:100%;height:100%;overflow:hidden;border-radius:1vw;will-change:transform,opacity;transform:translateZ(0)}.short img{position:absolute;width:auto;height:100%;min-width:100%;left:50%;top:50%;transform:translate(-50%,-50%);object-fit:cover;object-position:center center;will-change:transform;transition:transform .3s ease-in-out}.short .video-overlay{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;pointer-events:none;z-index:10;border-radius:1vw;overflow:hidden;transition:opacity .3s ease-in-out}.short .video-overlay iframe{width:100%;height:100%;border:none;border-radius:1vw}.short.playing .video-overlay{opacity:1;pointer-events:auto}.short.playing img{opacity:0}.short .info-button{position:absolute;top:.5vw;right:.5vw;width:2.5vw;height:2.5vw;background-color:#000000b3;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);transition:all .3s ease;cursor:pointer;z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none}.short .info-button svg{width:1.2vw;height:1.2vw;fill:#fff}.short .info-button:hover{background-color:#000000e6;transform:scale(1)}.short .info-button:focus-visible{outline:2px solid #0066cc;outline-offset:2px}@media (max-width: 600px){.short .info-button{top:2vw;right:2vw;width:8vw;height:8vw}.short .info-button svg{width:4vw;height:4vw}}.short.playing .info-button{opacity:1;transform:scale(1)}.short :hover img{transform:translate(-50%,-50%) scale(1.05)}.details{position:fixed;top:0;right:0;width:50vw;height:100vh;padding:3vw 4vw;background-color:#f1f1f1;transform:translate3d(50vw,0,0);z-index:6}@media (max-width: 600px){.details{width:100%;height:100vh;padding:12vw 7vw 20vw;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;box-sizing:border-box;position:fixed;top:0;left:0;right:0;z-index:10;will-change:transform}}.details__close{position:absolute;top:2vw;right:2vw;width:3vw;height:3vw;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:transform .2s ease}.details__close:hover{transform:scale(1.1)}.details__close:focus-visible{outline:2px solid #0066cc;outline-offset:2px}.details__close svg{width:2vw;height:2vw}@media (max-width: 600px){.details__close{position:fixed;top:4vw;right:4vw;width:8vw;height:8vw;background:#f1f1f1e6;border-radius:50%;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.details__close svg{width:5vw;height:5vw}}.details__title{margin-bottom:4vw;position:relative;display:grid}@media (max-width: 600px){.details__title{margin-bottom:6vw;margin-top:0}}.details__title p{grid-area:1 / -1;overflow:hidden;font-size:3vw}@media (max-width: 600px){.details__title p{font-size:2rem}}.details__body{display:flex;flex-wrap:wrap;align-items:flex-start;gap:3vw;height:calc(100vh - 12vw)}@media (max-width: 600px){.details__body{flex-direction:column-reverse;align-items:center;gap:6vw;height:auto;min-height:auto;padding-bottom:4vw;flex:none}}.details__texts{position:relative;flex:1;min-width:0;padding:2vw 1rem;line-height:1.5;background-color:#ff00001a}.details__texts .current-desc{display:block}.details__texts .project-tags{font-size:.9rem;color:#666;margin-bottom:1.5rem;line-height:1.4;letter-spacing:.5px}.details__texts .project-description{font-size:1rem;line-height:1.6;margin-bottom:2rem;color:#333}.details__texts .view-project-btn{appearance:none;border:none;display:inline-block;background-color:#000;color:#fff;margin-top:1rem;border-radius:2rem;padding:.75rem 2rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;text-align:center}.details__texts .view-project-btn:hover{background-color:#333;transform:translateY(-2px)}@media (max-width: 600px){.details__texts .view-project-btn{margin-top:1rem;padding:1rem 2.5rem}}@media (max-width: 600px){.details__texts{padding:2rem 1rem;width:100%}}.details__texts [data-text]{position:relative}.details__thumb{position:relative;width:18vw;aspect-ratio:9 / 16;z-index:3;will-change:transform;border-radius:1vw;overflow:hidden;flex-shrink:0}@media (max-width: 600px){.details__thumb{width:100%;max-width:60vw;margin-bottom:4vw}}.details__thumb div{position:absolute;width:100%;height:100%;overflow:hidden;border-radius:1vw}.details__thumb img{position:absolute;width:auto;height:100%;min-width:100%;left:50%;top:50%;transform:translate(-50%,-50%);object-fit:cover;object-position:center center}p{font-size:.85rem;margin-bottom:1vw}.cross{position:fixed;width:3vw;height:3vw;transform:translate(-50%,-50%);z-index:5;pointer-events:none;transform:scale(0)}.cross svg{width:3vw;height:3vw}.--is-details-showing{cursor:pointer}.--is-details-showing .grid{pointer-events:none}@media (max-width: 600px){.--is-details-showing{overflow:visible}}.--is-showing{opacity:1}.search-overlay{position:fixed;top:var(--page-padding);left:50%;transform:translate(-50%);z-index:1000;pointer-events:auto}@media (max-width: 970px){.search-overlay{position:static;top:auto;left:auto;transform:none;grid-area:search;width:100%}}.search-container{background:#f8dfbcf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 2px 8px #0000001a;border:1px solid rgba(26,26,26,.1);overflow:hidden;transition:all .3s ease;width:300px;max-width:90vw}.search-container.expanded{width:600px;max-width:95vw}@media (max-width: 970px){.search-container{width:100%;max-width:100%;margin:0;border-radius:12px}.search-container.expanded{width:100%;max-width:100%}}.search-input-wrapper{position:relative;display:flex;align-items:center}@media (max-width: 970px){.search-input-wrapper{padding:4px}}.search-input{width:100%;padding:12px 16px 12px 40px;border:none;background:transparent;outline:none;font-size:16px;touch-action:manipulation;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}@media (max-width: 970px){.search-input{font-size:16px;-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent;transform:translateZ(0)}}@media (max-width: 970px){input[type=text],input[type=search],input[type=email],input[type=tel],input[type=url],input[type=password],textarea,select{font-size:16px!important;-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}}.search-icon{position:absolute;left:12px;color:#666;pointer-events:none;z-index:2;transition:opacity .3s ease}.search-clear{position:absolute;right:12px;background:none;border:none;color:#666;cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s ease;z-index:2}.search-clear:hover{background:#0000001a;color:#333}.search-clear:focus-visible{outline:2px solid #0066cc;outline-offset:2px}.search-clear.visible{opacity:1;visibility:visible}.search-input{width:100%;padding:10px 36px;border:none;background:transparent;font-size:14px;color:#333;outline:none;transition:all .3s ease}.search-input::placeholder{color:#666;font-weight:400}.search-input:focus-visible{background:transparent}.search-categories{display:none;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;padding:16px;max-width:100%;transition:all .3s ease}.search-categories.visible{display:grid}@media (min-width: 480px){.search-categories{grid-template-columns:repeat(2,1fr)}}@media (max-width: 970px){.search-categories{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:6px;padding:12px 16px}}@media (min-width: 640px){.search-categories{grid-template-columns:repeat(3,1fr)}}@media (min-width: 800px){.search-categories{grid-template-columns:repeat(4,1fr)}}.category-button{padding:8px 12px;background:#ffffffb3;border:1px solid rgba(26,26,26,.1);border-radius:12px;font-size:12px;font-weight:500;color:#333;cursor:pointer;text-align:center;transition:all .3s ease;-webkit-user-select:none;user-select:none}.category-button:hover{background:#ffffffe6;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.category-button:focus-visible{outline:2px solid #0066cc;outline-offset:2px}.category-button.active{background:#000c;color:#fff;border-color:#000c}
