@import url(https://fonts.googleapis.com/css2?family=Nunito+Sans:ital,opsz,wght@0,6..12,200..1000;1,6..12,200..1000&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;margin:0}code{font-family:IBM Plex Mono,source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.projects-all-categories{display:flex;flex-direction:column;gap:3rem;width:100%}.category-section{grid-gap:0 1rem;align-items:start;border-top:1px solid var(--border);display:grid;gap:0 1rem;grid-template-columns:clamp(130px,16%,190px) 1fr;opacity:0;padding-bottom:6rem;padding-top:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}.category-section.visible{opacity:1;transform:translateY(0)}.category-section:nth-child(2){transition-delay:.05s}.category-section:nth-child(3){transition-delay:.1s}.category-sidebar{align-items:center;display:flex;flex-direction:row;gap:.2rem;padding-top:.1rem;position:sticky;top:calc(var(--nav-h) + 2rem);width:100%}.category-name{color:var(--fg);font-family:var(--sans);font-size:.62rem;font-weight:500;letter-spacing:.18em;line-height:1.4;text-transform:uppercase;width:100%}.category-count{color:var(--fg-subtle);font-family:var(--mono);font-size:.8rem;letter-spacing:.04em}.category-content{min-width:0}.category-filter-label{color:var(--fg-muted);font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;margin-bottom:1rem}.filter-tag{color:var(--fg);font-weight:500}.projects-loading{animation:loadingPulse 1s step-end infinite;color:var(--fg-muted);font-family:var(--mono);font-size:.875rem;padding:3rem 0}@keyframes loadingPulse{0%,to{opacity:1}50%{opacity:.3}}.projects-container{grid-gap:1px;border:1px solid var(--border);box-sizing:border-box;display:grid;gap:1px;grid-template-columns:repeat(3,1fr);max-width:100%;width:100%}.project-link{color:inherit;display:flex;flex-direction:column;min-height:0;text-decoration:none}.project-link.project-full{aspect-ratio:16/9;grid-column:span 3}.project-link.project-half{aspect-ratio:3/2;grid-column:span 2}.project-link.project-regular{aspect-ratio:3/4;grid-column:span 1}.project-item{background:var(--border);cursor:pointer;display:flex;flex:1 1;flex-direction:column;min-height:0;opacity:0;overflow:hidden;position:relative;transform:translateY(24px);transition:opacity .65s cubic-bezier(.16,1,.3,1),transform .65s cubic-bezier(.16,1,.3,1)}.project-item.visible{opacity:1;transform:translateY(0)}.project-item .corner-bl,.project-item .corner-br,.project-item:after,.project-item:before{display:none}.project-item:hover img,.project-item:hover video{opacity:.88}.project-item img,.project-item video{background-color:#fff;background-color:var(--bg-media,#fff);display:block;flex:1 1;min-height:0;object-fit:cover;object-position:top center;transition:opacity .3s ease;width:100%}.project-placeholder{background:var(--fg);display:flex;flex:1 1;flex-direction:column;justify-content:flex-end;min-height:0;padding:1.5rem 1.25rem 1.25rem;position:relative;width:100%}.project-placeholder-mark{color:#ffffff2e;font-size:.55rem;left:1rem;letter-spacing:.1em;position:absolute;top:1rem}.project-placeholder-quote{color:#ffffff38;font-family:var(--sans);font-size:clamp(1.1rem,2.2vw,1.6rem);font-weight:500;letter-spacing:-.02em;line-height:1.15;margin:0 0 .75rem;white-space:pre-line}.project-placeholder-attr{color:#ffffff1f;font-family:var(--mono);font-size:.58rem;font-style:normal;letter-spacing:.14em;text-transform:uppercase}.project-overlay{align-items:flex-start;background:var(--bg);border-top:1px solid var(--border);display:flex;flex-direction:column;height:3rem;opacity:1;overflow:hidden;padding:.5rem;position:relative;width:100%}.project-alt-text{color:var(--fg);font-size:.65rem;font-weight:500;letter-spacing:.08em;line-height:1.3;margin:0 0 2px}.project-alt-text,.project-tags{font-family:var(--mono);text-transform:uppercase}.project-tags{color:var(--fg-muted);font-size:.6rem;font-weight:400;letter-spacing:.06em;margin:0}@media (min-width:2560px){.projects-container{background:var(--border);gap:1px}.project-alt-text{font-size:.75rem}.project-tags{font-size:.65rem}}@media (min-width:1920px) and (max-width:2559px){.projects-container{background:var(--border);gap:1px}}@media (min-width:1440px) and (max-width:1919px){.projects-container{background:var(--border);gap:1px}}@media (min-width:769px) and (max-width:1199px){.projects-container{background:var(--border);gap:1px;grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.projects-all-categories{gap:2rem}.category-section{gap:1rem 0;grid-template-columns:1fr;padding-bottom:2rem}.category-sidebar{align-items:baseline;flex-direction:row;gap:1rem;padding:.5rem .5rem 0;position:static}.projects-container{background:var(--border);gap:1px;grid-template-columns:1fr}.project-link.project-full,.project-link.project-half,.project-link.project-regular{aspect-ratio:4/3;grid-column:span 1}.project-item{opacity:1!important;transform:none!important}.category-count,.category-name{font-size:.6rem}}@media (max-width:480px){.projects-all-categories{gap:2rem}.projects-container{background:var(--border);gap:1px}}.projects-list{border:1px solid var(--border);width:100%}.project-list-item{grid-gap:.75rem;align-items:center;background:var(--bg);border-bottom:1px solid var(--border);color:inherit;display:grid;gap:.75rem;grid-template-columns:1.5rem 72px 1fr;padding:.75rem 1rem;text-decoration:none;transition:background .1s ease}.project-list-item:last-child{border-bottom:none}.project-list-item:active{background:var(--fg)}.project-list-item:active .pli-num{color:#ffffff59}.project-list-item:active .pli-title{color:#fffffff2}.project-list-item:active .pli-tags{color:#ffffff73}.pli-num{color:var(--fg-subtle);font-family:var(--mono);font-size:.58rem;letter-spacing:.06em;line-height:1;transition:color .1s ease}.pli-thumb{background:var(--bg-alt);flex-shrink:0;height:54px;overflow:hidden;width:72px}.pli-thumb img,.pli-thumb video{display:block;height:100%;object-fit:cover;object-position:top center;width:100%}.pli-thumb-fallback{align-items:center;background:var(--fg);color:#ffffff40;display:flex;font-size:.58rem;height:100%;justify-content:center;width:100%}.pli-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.pli-title{color:var(--fg);font-size:.65rem;font-weight:500;letter-spacing:.06em;line-height:1.3}.pli-tags,.pli-title{font-family:var(--mono);margin:0;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase;transition:color .1s ease;white-space:nowrap}.pli-tags{color:var(--fg-subtle);font-size:.55rem;letter-spacing:.04em}.blogs-list{animation:blogsReveal .6s cubic-bezier(.16,1,.3,1) both;display:flex;flex-direction:column;width:100%}@keyframes blogsReveal{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes blogRowReveal{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.blog-row:first-child{animation:blogRowReveal .6s cubic-bezier(.16,1,.3,1) .1s both}.blog-row:nth-child(2){animation:blogRowReveal .6s cubic-bezier(.16,1,.3,1) .18s both}.blog-row:nth-child(3){animation:blogRowReveal .6s cubic-bezier(.16,1,.3,1) .26s both}.blog-row:nth-child(4){animation:blogRowReveal .6s cubic-bezier(.16,1,.3,1) .32s both}.blog-row:nth-child(5){animation:blogRowReveal .6s cubic-bezier(.16,1,.3,1) .38s both}.blog-row:nth-child(6){animation:blogRowReveal .6s cubic-bezier(.16,1,.3,1) .43s both}.blog-row{grid-gap:0 1rem;align-items:start;color:inherit;display:grid;gap:0 1rem;grid-template-columns:3rem 1fr auto;padding:1rem 0;position:relative;text-decoration:none;transition:opacity .22s ease}.blog-row:hover{opacity:.72}.blog-num{color:var(--fg-muted);font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;line-height:1;padding-top:.2rem}.blog-body{display:flex;flex-direction:column;gap:.5rem;min-width:0}.blog-title{color:var(--fg);display:inline-block;font-family:var(--sans);font-size:clamp(1rem,1.8vw,1.3rem);font-weight:600;letter-spacing:-.015em;line-height:1.25;margin:0;max-width:100%;position:relative;width:fit-content}.blog-title:after{background:var(--fg);bottom:-2px;content:"";height:1px;left:0;position:absolute;transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.19,1,.22,1);width:100%}.blog-row:hover .blog-title:after{transform:scaleX(1);transform-origin:left}.blog-excerpt{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;font-size:.875rem;line-height:1.65;margin:0;max-width:68ch;overflow:hidden}.blog-cat,.blog-excerpt{color:var(--fg-muted);font-family:var(--sans)}.blog-cat{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase}.blog-end{align-items:flex-end;display:flex;flex-direction:column;gap:.5rem;padding-top:.15rem;white-space:nowrap}.blog-date{color:var(--fg-muted);font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase}.blog-arrow{color:var(--fg-subtle);font-size:1rem;opacity:0;transform:translate(-4px,4px);transition:opacity .25s ease,transform .3s cubic-bezier(.19,1,.22,1),color .2s ease}.blog-row:hover .blog-arrow{color:var(--fg);opacity:1;transform:translate(0)}.blogs-state{color:var(--fg-muted);font-family:var(--sans);font-size:.875rem;padding:3rem 0}.blogs-state--error{color:var(--fg-subtle)}@media (max-width:768px){.blog-row{grid-template-columns:2.25rem 1fr;grid-template-rows:auto auto;padding-left:1rem;padding-right:1rem}.blog-end{align-items:center;flex-direction:row;gap:1rem;grid-column:2;grid-row:2;padding-top:.25rem}.blog-arrow{opacity:1;transform:none}.blogs-state{padding-left:1rem;padding-right:1rem}}@media (max-width:480px){.blog-num{font-size:.65rem}.blog-title{font-size:.95rem}.blog-excerpt{-webkit-line-clamp:2;font-size:.825rem}}@media (min-width:2560px){.blog-title{font-size:1.5rem}.blog-excerpt{font-size:1rem}.blog-cat{font-size:.75rem}.blog-date{font-size:.8rem}}.app-footer{background-color:var(--fg);border-top:1px solid var(--border-strong);color:var(--bg);overflow-x:hidden;padding:0;width:100%}.next-case-study-container{background:#0000;border-bottom:1px solid #ffffff1f;border-radius:0;margin-bottom:1rem;padding:1rem;text-align:right}.next-case-study-link{color:var(--bg);font-family:var(--sans);font-size:clamp(1.2rem,2.2vw,1.8rem);font-weight:500;letter-spacing:-.01em;text-decoration:none;transition:opacity .2s ease}.next-case-study-link:hover{opacity:.6}.brand-header{border-bottom:2.5px solid var(--border-strong);border-top:1px solid var(--border-strong);box-sizing:border-box;color:var(--fg);font-family:var(--sans);font-size:clamp(8vw,12vw,10vw);font-weight:700;letter-spacing:-.04em;line-height:1;margin-left:calc(50% - 50vw);overflow:hidden;padding:1rem 1rem 2rem;white-space:nowrap;width:100vw}.footer-grid{grid-gap:1px;background:#ffffff1a;display:grid;gap:1px;grid-template-columns:1fr 1fr 1fr;margin-top:0}.footer-col{background:var(--fg);display:flex;flex-direction:column;gap:.35rem;padding:1rem}.footer-col-header{color:hsla(240,2%,90%,.576);font-weight:400;letter-spacing:.18em;margin-bottom:.5rem}.footer-col-header,.footer-link{font-family:var(--sans);font-size:.8rem;text-transform:uppercase}.footer-link{color:var(--bg);letter-spacing:0;text-decoration:none;transition:color .1s ease}.footer-link:hover{color:#d3d7ff;text-decoration:line-through}.footer-meta{color:var(--bg);font-family:var(--sans);font-size:.8rem;letter-spacing:0;line-height:1.6;text-transform:uppercase}.footer-bottom-row{align-items:center;border-top:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:.75rem var(--pad)}.copyright-text{color:#ffffff4d;font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;margin:0;text-transform:uppercase}@media (max-width:768px){.brand-header{font-size:10vw;margin-bottom:0}.footer-grid{grid-template-columns:1fr}.footer-bottom-row{align-items:flex-start;flex-direction:column;gap:.5rem;padding:1rem var(--pad) 1rem}}@media (max-width:480px){.brand-header{font-size:10vw;margin-bottom:0}}@media (min-width:2560px){.brand-header{font-size:16vw}}@media (min-width:1920px) and (max-width:2559px){.brand-header{font-size:14vw}}.case-study{animation:csReveal .6s cubic-bezier(.16,1,.3,1) both;overflow-x:hidden;width:100%}@keyframes csReveal{0%{opacity:0}to{opacity:1}}.cs-inner{margin:0 auto;max-width:var(--max-w);padding:0}.cs-nav{align-items:center;background:var(--bg);border-bottom:1px solid var(--border-strong);display:flex;height:var(--nav-h);padding-left:1rem;padding-right:1rem;position:sticky;top:0;z-index:100}.cs-back{color:var(--fg-muted);font-family:var(--sans);font-size:clamp(.75rem,1.5vw,1rem);letter-spacing:.05em;position:relative;text-decoration:none;transition:color .18s ease}.cs-back:after{background:var(--fg);bottom:-2px;content:"";height:1px;left:0;position:absolute;transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.19,1,.22,1);width:100%}.cs-back:hover{color:var(--fg);text-decoration:line-through}.cs-back:hover:after{transform:scaleX(0);transform-origin:left}@keyframes csHeaderReveal{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cs-header{animation:csHeaderReveal .8s cubic-bezier(.16,1,.3,1) .1s both;padding:3rem 0 1rem}.cs-hero{animation:csHeaderReveal .8s cubic-bezier(.16,1,.3,1) .22s both}.cs-header-text{margin-bottom:1rem}.cs-title{color:var(--fg);font-size:clamp(2.75rem,6.5vw,7.5rem);font-weight:700;letter-spacing:-.03em;line-height:.95;margin:0 0 1.25rem}.cs-desc,.cs-title{font-family:var(--sans);padding-left:1rem;padding-right:1rem}.cs-desc{color:var(--fg-muted);font-size:clamp(1rem,2vw,1.5rem);font-weight:400;letter-spacing:-.01em;line-height:1.3;margin:0;max-width:60ch}.cs-brief{grid-gap:1rem 2rem;border-top:1px solid var(--border);display:grid;gap:1rem 2rem;grid-template-columns:repeat(2,1fr);padding-left:1rem;padding-right:1rem;padding-top:1.5rem}.cs-brief-item{display:flex;flex-direction:column;gap:0}.cs-brief-key{color:var(--fg-muted);font-family:var(--sans);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase}.cs-brief-val{color:var(--fg);font-family:var(--sans);font-size:.9rem;letter-spacing:.01em;line-height:1.45}.cs-hero{align-items:center;background:var(--bg);display:flex;flex-direction:column;margin:1rem 0 0;overflow:hidden;width:100%}.cs-hero-media{-webkit-appearance:none;appearance:none;display:block;max-height:auto;object-fit:cover;outline:none;width:100%}.cs-content{display:flex;flex-direction:column;padding-bottom:0;padding-top:1rem}@keyframes csRowReveal{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.cs-section{grid-column-gap:2.5%;grid-row-gap:1rem;animation:csRowReveal .4s cubic-bezier(.16,1,.3,1) both;border-top:1px solid var(--border-strong);column-gap:2.5%;display:grid;grid-template-columns:20% 1fr 2fr 1fr;grid-template-rows:auto auto;padding:1rem;row-gap:1rem}.cs-section:first-child{animation-delay:.08s}.cs-section:nth-child(2){animation-delay:.13s}.cs-section:nth-child(3){animation-delay:.18s}.cs-section:nth-child(4){animation-delay:.23s}.cs-section:nth-child(5){animation-delay:.27s}.cs-section:nth-child(6){animation-delay:.3s}.cs-section:nth-child(7){animation-delay:.33s}.cs-section:nth-child(8){animation-delay:.35s}.cs-section-title{align-self:start;color:var(--fg-muted);font-family:var(--sans);font-size:.8rem;font-weight:400;grid-column:1;grid-row:1;letter-spacing:.1em;line-height:1.4;margin:0;position:sticky;text-transform:uppercase;top:calc(var(--nav-h) + 2rem)}.cs-section-text{column-count:2;column-fill:balance;column-gap:clamp(1rem,3vw,2rem);grid-column:2/4;grid-row:1}.cs-section-media{grid-column:2/-1;grid-row:2}.cs-section-text p{break-inside:avoid-column;color:var(--fg-muted);font-family:var(--sans);font-size:clamp(1rem,1.05vw,1.6rem);letter-spacing:-.02em;line-height:1.4;margin:0 0 1rem}.cs-section-text p:last-child{margin-bottom:0}.cs-section-text .highlight,.cs-section-text span,.cs-section-text strong{color:var(--fg);font-weight:500}.cs-section-text a{color:var(--fg);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}.cs-section--full{border-top:none;display:block;padding:0}.cs-media,.cs-section-media img,.cs-section-media video{-webkit-appearance:none;appearance:none;background:var(--bg-media);border-radius:0;display:block;height:auto;outline:none;width:100%}.cs-section--full .cs-media,.cs-section--full .cs-section-media img,.cs-section--full .cs-section-media video{border-radius:0}.cs-hero-media,.cs-media--video{-webkit-appearance:none;appearance:none;height:100%}@media (max-width:768px){.cs-hero-media::-webkit-media-controls,.cs-hero-media::-webkit-media-controls-enclosure,.cs-media--video::-webkit-media-controls,.cs-media--video::-webkit-media-controls-enclosure{display:none!important}video.cs-hero-media,video.cs-media--video{pointer-events:none;-webkit-user-select:none;user-select:none}}.cs-credits{align-items:flex-start;background:var(--bg);border-radius:0;border-top:1px solid var(--border-strong);display:flex;gap:4rem;margin-bottom:8rem;margin-top:4rem;padding:1rem}.cs-credits-label{color:var(--fg);font-family:var(--sans);font-size:1rem;letter-spacing:-.02em;min-width:80px;white-space:nowrap}.cs-credits ul{display:flex;flex-direction:column;gap:.3rem;list-style:none;margin:0;padding:0}.cs-credits li{color:var(--fg);font-family:var(--sans);font-size:.9rem;letter-spacing:-.01em;line-height:1.2}.cs-message{color:var(--fg-muted);font-family:var(--sans);font-size:.875rem;margin:0 auto;max-width:var(--max-w);padding:4rem var(--pad)}.cs-message--loading{animation:csPulse 1s step-end infinite}@keyframes csPulse{0%,to{opacity:1}50%{opacity:.3}}@media (max-width:1100px){.cs-section{column-gap:3%;grid-template-columns:24% 1fr 1fr}.cs-section-text{grid-column:2/4}.cs-section-media{grid-column:2/-1}}@media (max-width:720px){.cs-brief{gap:1.25rem 1.5rem;grid-template-columns:repeat(2,1fr)}}@media (max-width:820px){.cs-section{grid-template-columns:1fr;grid-template-rows:auto auto auto;padding:1rem;row-gap:1rem}.cs-section-title{grid-column:1;grid-row:1;position:static}.cs-section-text{column-count:2;grid-column:1;grid-row:2}.cs-section-media{grid-column:1;grid-row:3}.cs-hero-media{max-height:60vw}}@media (max-width:560px){.cs-section{padding:1rem;row-gap:1rem}.cs-section-text{column-count:1}.cs-hero-media{max-height:65vw}}@media (max-width:480px){.cs-title{font-size:clamp(2rem,10vw,3.5rem);letter-spacing:-.025em}.cs-brief{gap:1rem 1.25rem;grid-template-columns:1fr 1fr}.cs-credits{flex-direction:column;gap:.75rem}}@media (max-width:375px){.cs-brief,.cs-header,.cs-section{padding-left:.75rem;padding-right:.75rem}.cs-brief{grid-template-columns:1fr}}@media (min-width:2560px){.cs-section-text p{font-size:1.15rem}.cs-brief-val,.cs-credits li{font-size:1rem}}@media (min-width:1920px) and (max-width:2559px){.cs-section-text p{font-size:1.05rem}}.about-page{animation:aboutReveal .5s cubic-bezier(.16,1,.3,1) both;width:100%}@keyframes aboutReveal{0%{opacity:0}to{opacity:1}}.ab-layout{align-items:start;border-bottom:1px solid var(--border-strong);display:grid;grid-template-columns:38% 62%}.ab-sticky-left{background:var(--fg);display:flex;flex-direction:column;height:calc(100vh - var(--nav-h));overflow:hidden;position:sticky;top:var(--nav-h)}.ab-chapter-indicator{align-items:baseline;display:flex;gap:.5rem;left:1rem;pointer-events:none;position:absolute;top:1rem;z-index:10}.ab-chapter-num{color:#ffffff4d}.ab-chapter-label,.ab-chapter-num{font-family:var(--mono);font-size:.58rem;letter-spacing:.18em}.ab-chapter-label{color:#fff6;text-transform:uppercase}.ab-sticky-portrait{display:block;filter:grayscale(20%) contrast(1.05);height:100%;object-fit:cover;object-position:center top;transition:filter .6s ease;width:100%}.ab-sticky-left:hover .ab-sticky-portrait{filter:grayscale(0) contrast(1)}.ab-progress-track{background:#ffffff14;height:100%;position:absolute;right:0;top:0;width:2px}.ab-progress-fill{background:#ffffff8c;height:100%;transform:scaleY(0);transform-origin:top center;transition:transform .12s linear;width:100%}.ab-sticky-bottom{background:linear-gradient(0deg,#0c0c0bf7 0,#0c0c0bb3 55%,#0c0c0b00);bottom:0;display:flex;flex-direction:column;gap:1rem;left:0;padding:3.5rem 1.25rem 1.25rem;pointer-events:none;position:absolute;right:0}.ab-sticky-identity{display:flex;flex-direction:column;gap:.4rem}.ab-sticky-name{color:#fff;font-family:var(--sans);font-size:clamp(1.8rem,3.2vw,2.8rem);font-weight:700;letter-spacing:-.035em;line-height:.95;margin:0;text-transform:uppercase}.ab-sticky-meta{display:flex;flex-direction:column;gap:.2rem}.ab-sticky-role{color:#fffc}.ab-sticky-loc,.ab-sticky-role{font-family:var(--mono);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase}.ab-sticky-loc{color:#ffffff59}.ab-scroll-right{border-left:1px solid var(--border-strong)}.ab-scroll-right,.ab-story{display:flex;flex-direction:column}.ab-story{gap:2rem;padding:3.75rem 3.75rem 5rem}.ab-story-para{color:var(--fg);font-family:var(--sans);font-size:clamp(1.35rem,2.4vw,2.25rem);font-weight:500;letter-spacing:-.025em;line-height:1.4;margin:0;opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,1,.3,1) 0s,transform .7s cubic-bezier(.16,1,.3,1) 0s;transition:opacity .7s cubic-bezier(.16,1,.3,1) var(--delay,0s),transform .7s cubic-bezier(.16,1,.3,1) var(--delay,0s)}.ab-story-para.visible{opacity:1;transform:translateY(0)}.ab-key{cursor:default;display:inline;position:relative;transition:color .2s ease}.ab-key:after{background:var(--fg);bottom:.05em;content:"";height:1px;left:0;position:absolute;transform:scaleX(0);transform-origin:left center;transition:transform .25s cubic-bezier(.16,1,.3,1);width:100%}.ab-story-para:hover .ab-key:after{transform:scaleX(1)}.ab-story-para:last-of-type{color:var(--fg)}.ab-avail-row{align-items:center;border-top:1px solid var(--border);display:flex;font-size:0!important;gap:.6rem;padding-top:1rem}.ab-avail-dot{animation:availPulse 2.4s ease-in-out infinite;background:var(--fg);flex-shrink:0;height:5px;width:5px}@keyframes availPulse{0%,to{opacity:1}50%{opacity:.12}}.ab-avail-text{color:var(--fg-subtle);font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase}@media (max-width:960px){.ab-layout{grid-template-columns:1fr}.ab-sticky-left{height:460px;position:relative;top:0}.ab-progress-track{display:none}.ab-scroll-right{border-left:none;border-top:1px solid var(--border-strong)}.ab-story{gap:1.75rem;padding:2.5rem 2rem 3.5rem}}@media (max-width:768px){.ab-sticky-left{height:360px}.ab-sticky-name{font-size:1.6rem}.ab-story{gap:1.5rem;padding:2rem 1.25rem 3rem}}@media (max-width:480px){.ab-sticky-left{height:300px}}@media (min-width:1440px){.ab-layout{grid-template-columns:34% 66%}.ab-story{gap:2.5rem;padding:4.5rem 4.5rem 6rem}}@media (min-width:1920px){.ab-layout{grid-template-columns:32% 68%}.ab-story{gap:3rem;padding:5rem 5rem 7rem}}.mp-hero{border-bottom:1px solid var(--border-strong);display:flex;flex-direction:column;gap:.5rem;padding:2.5rem 1rem 2rem}.mp-hero-title{color:var(--fg);font-family:var(--sans);font-size:clamp(2rem,5vw,4rem);font-weight:700;letter-spacing:-.03em;line-height:1.05;margin:.5rem 0 0}.mp-hero-desc{color:var(--fg-muted);font-family:var(--mono);font-size:.75rem;letter-spacing:.08em;margin:.25rem 0 0;text-transform:uppercase}.mp-grid-section{padding-top:2rem}@media (max-width:768px){.mp-hero{padding:1.5rem 1rem}.mp-hero-title{font-size:2rem}}.scramble-char{color:var(--fg);font-family:var(--mono);font-size:.82em;opacity:.25}.hero{align-items:center;display:flex;flex:1 1;flex-direction:row;gap:4rem;justify-content:space-between;overflow:hidden;position:relative;width:100%}.hero-canvas{height:100%;inset:0;position:absolute;width:100%;z-index:0}.hero-canvas canvas{display:block}.hero-body,.hero-name-block{position:relative;z-index:1}@keyframes heroFadeUp{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}.hero-meta{align-items:center;display:flex;flex-wrap:wrap;font-family:var(--mono);font-size:.62rem;gap:1rem;letter-spacing:.18em;margin-bottom:1rem;text-transform:uppercase}.hero-meta,.hero-tag,.hero-tag-sep{color:var(--fg-muted)}.hero-tag-sep{opacity:.5}.hero-telemetry{color:var(--fg-muted);font-family:var(--mono);font-size:.62rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase}.hero-name-block{animation:heroFadeUp .85s cubic-bezier(.16,1,.3,1) .05s both;line-height:1;margin-bottom:1rem}.hero-name{color:var(--fg);font-family:var(--sans);font-size:clamp(4rem,11vw,10rem);font-weight:700;letter-spacing:-.04em;line-height:.95;margin-bottom:1rem;margin-left:0}.cursor-blink{animation:cursorBlink 1.1s step-end infinite;color:var(--fg);display:inline-block}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.hero-lead{color:var(--fg);font-size:clamp(1.5rem,3vw,2.75rem);font-weight:500;letter-spacing:-.02em;line-height:1.15;margin:0 0 1rem;max-width:26ch}.hero-body,.hero-lead{font-family:var(--sans)}.hero-body{animation:heroFadeUp .85s cubic-bezier(.16,1,.3,1) .2s both;color:var(--fg-muted);font-size:1rem;font-weight:400;line-height:1.75;max-width:52ch}.hero-body p{margin:0 0 .9rem}.hero-body p:last-child{margin-bottom:0}.hero-body strong{color:var(--fg);font-weight:600}.hero-body a{color:var(--fg);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;transition:opacity .2s ease}.hero-body a:hover{opacity:.45}@media (max-width:768px){.hero{flex-direction:column;gap:1rem}.hero-name-block{margin-bottom:1rem;margin-left:0}.hero-lead{font-size:clamp(1.35rem,5vw,1.9rem);margin-bottom:1rem}}@media (max-width:480px){.hero-meta{font-size:.6rem}.hero-name{font-size:clamp(2.75rem,12vw,4rem);letter-spacing:-.03em}.hero-lead{font-size:1.25rem;line-height:1.2;margin-bottom:1rem}.hero-body{font-size:.875rem}}.cursor-dot,.cursor-ring{border-radius:50%;left:0;margin:-3px 0 0 -3px;mix-blend-mode:difference;pointer-events:none;position:fixed;top:0;will-change:transform;z-index:9999}.cursor-dot{background-color:#fff;height:6px;width:6px}.cursor-ring{background:#0000;border:1px solid #fff;height:36px;margin:-18px 0 0 -18px;width:36px}@media (hover:none){.cursor-dot,.cursor-ring{display:none}}:root{--bg:#fff;--fg:#0c0c0b;--fg-muted:#555;--fg-subtle:#888;--border:#c8c8c8;--border-strong:#000;--bg-media:#fff;--bg-alt:#f0f0ef;--mono:"Helvetica Neue",Helvetica,Arial,sans-serif;--sans:"Helvetica Neue",Helvetica,Arial,sans-serif;--nav-h:48px;--pad:1rem;--max-w:2000px}html{scroll-behavior:smooth;scroll-padding-top:calc(48px + 1rem);scroll-padding-top:calc(var(--nav-h) + 1rem)}body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;background-color:var(--bg);color:#0c0c0b;color:var(--fg);font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-family:var(--sans);height:100%;margin:0;overflow-x:hidden;padding:0}*,:after,:before{box-sizing:border-box;cursor:none}.App{animation:appReveal .4s cubic-bezier(.16,1,.3,1) both;background-color:#fff;background-color:var(--bg);display:flex;flex-direction:column;min-height:100vh;width:100%}@keyframes appReveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.top-nav{align-items:stretch;background:#fff;background:var(--bg);border-bottom:1px solid #c8c8c8;border-bottom:1px solid var(--border);display:flex;height:48px;height:var(--nav-h);justify-content:flex-start;padding:0;position:sticky;top:0;z-index:100}.nav-item{align-items:center;border-right:1px solid #c8c8c8;border-right:1px solid var(--border);color:#555;color:var(--fg-muted);display:inline-flex;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-family:var(--sans);font-size:.68rem;font-weight:500;height:100%;letter-spacing:.12em;min-width:14rem;padding:0 1rem;text-decoration:none;text-transform:uppercase;transition:background .1s ease,color .1s ease;white-space:nowrap}.nav-item:hover{text-decoration:line-through}.nav-item.active,.nav-item:hover{background:#0c0c0b;background:var(--fg);color:#fff;color:var(--bg)}.nav-text-short{display:none;font-size:.9rem;line-height:1}.nav-text-full{display:inline}.main-container{margin:0 auto;max-width:2000px;max-width:var(--max-w);min-height:calc(100vh - 48px);min-height:calc(100vh - var(--nav-h));padding:0;width:100%}.hero-section,.main-container{display:flex;flex-direction:column}.hero-section{height:calc(100vh - 48px);height:calc(100vh - var(--nav-h));padding:0 1rem}.projects-section{padding:1rem 1rem 6rem}.social-section{padding:1rem 0}.section-label{color:#555;color:var(--fg-muted);display:block;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-family:var(--sans);font-size:.62rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase}.footer-section{margin-left:calc(50% - 50vw);margin-top:auto;padding-top:0;width:100vw}.page-header{border-bottom:1px solid #000;border-bottom:1px solid var(--border-strong);margin-bottom:1rem;padding:1rem}.page-header-label{color:#555;color:var(--fg-muted);display:block;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;margin-bottom:.75rem;text-transform:uppercase}.page-header-title{color:#0c0c0b;color:var(--fg);font-size:clamp(2rem,5vw,4rem);font-weight:500;letter-spacing:-.02em;line-height:1.1;margin:0 0 .75rem}.page-header-desc,.page-header-title{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-family:var(--sans)}.page-header-desc{color:#555;color:var(--fg-muted);font-size:.95rem;line-height:1.6;margin:0;max-width:50ch}.main-h1,h1{font-size:clamp(1.5rem,4vw,4.5rem);letter-spacing:-.02em;line-height:1.1}.main-h1,.main-h2,h1,h2{color:#0c0c0b;color:var(--fg);font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-family:var(--sans);font-weight:500;margin:0 0 1rem}.main-h2,h2{font-size:clamp(1.25rem,3vw,3rem);letter-spacing:-.015em;line-height:1.15}.main-label{align-items:center;color:#0c0c0b;color:var(--fg);display:inline-flex;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-family:var(--mono);font-size:clamp(.75rem,1.2vw,.875rem);font-weight:400;gap:.4rem;letter-spacing:.03em;padding-bottom:.25rem;text-decoration:none;transition:all .2s ease}.main-label:hover{color:#0c0c0b;color:var(--fg);text-decoration:line-through}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInFromLeft{0%{opacity:0;transform:translateX(-24px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInFromBottom{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@media (min-width:2560px){.top-nav{height:60px}.nav-item{font-size:.9rem}.main-container{max-width:2400px}.main-h1,h1{font-size:5.5rem}.main-h2,h2{font-size:4rem}}@media (min-width:1920px) and (max-width:2559px){.main-container{max-width:1800px}}@media (min-width:1440px) and (max-width:1919px){.main-container{max-width:1600px}}@media (max-width:768px){:root{--nav-h:44px}.top-nav{gap:0;height:44px;padding:0}.nav-item{font-size:.6rem;letter-spacing:.08em;min-width:0;padding:0 .75rem}.hero-section{height:auto;padding:2rem 1rem 1rem}.projects-section{padding:1rem 0 4rem}.social-section{padding:1rem}.main-h1,h1{font-size:2.5rem}.main-h2,h2{font-size:2rem}}@media (max-width:600px){.nav-text-full{display:none}.nav-text-short{display:inline}.nav-item{justify-content:center;min-width:0;padding:0 .875rem}}@media (max-width:480px){.nav-item{font-size:.58rem;letter-spacing:.06em;padding:0 .6rem}}@media (max-width:375px){.nav-item{letter-spacing:0;padding:0 .5rem}}
/*# sourceMappingURL=main.ed9bfc18.css.map*/