.scroll-top-button[data-v-4bb6cca7]{position:fixed;z-index:20;left:max(clamp(18px,4vw,56px),env(safe-area-inset-left));bottom:max(clamp(18px,4vw,48px),env(safe-area-inset-bottom));display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;padding:0;border:1px solid rgba(244,241,232,.24);border-radius:0;background:#0d0f11b8;color:#fff;opacity:0;pointer-events:none;transform:translateY(14px);transition:opacity .18s ease,transform .18s ease,border-color .18s ease,background .18s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.scroll-top-button.is-visible[data-v-4bb6cca7]{opacity:1;pointer-events:auto;transform:translateY(0)}.scroll-top-button[data-v-4bb6cca7]:hover,.scroll-top-button[data-v-4bb6cca7]:focus-visible{border-color:#f4f1e8b8;background:#0d0f11eb}.scroll-top-button[data-v-4bb6cca7]:focus-visible{outline:1px solid currentColor;outline-offset:6px}.scroll-top-button svg[data-v-4bb6cca7]{width:25px;height:25px}@media(max-width:780px){.scroll-top-button[data-v-4bb6cca7]{left:max(18px,env(safe-area-inset-left));bottom:max(18px,env(safe-area-inset-bottom));width:48px;height:48px}}:root{--page-x: clamp(18px, 5vw, 72px);--page-header-base: 14vh;--page-header-offset: clamp(10px, 2.4vh, 28px);--page-header-top: calc(var(--page-header-base) + var(--page-header-offset));--mobile-page-title-size: clamp(1.35rem, 7.7vw, 2.45rem);color:#f4f1e8;background:#0d0f11;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background:#0d0f11}a{color:inherit;text-decoration:none}.site-header{position:fixed;z-index:10;top:0;left:0;right:0;height:12.5vh;height:12.5svh;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:0 clamp(18px,4vw,56px);color:#f4f1e8;mix-blend-mode:difference}.wordmark{display:flex;align-items:center;height:100%;font-size:1.02rem;font-weight:680;line-height:1;letter-spacing:0;text-transform:uppercase;transform:translateY(-.06em)}.site-nav{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center;height:100%;gap:clamp(14px,2.4vw,34px);font-size:.98rem;font-weight:680}.site-nav a{display:flex;align-items:center;height:100%;line-height:1}.nav-label{display:flex;line-height:1}.nav-letter{position:relative;display:inline-block;height:1.22em;vertical-align:bottom}.nav-letter-window{display:block;height:1em;overflow:hidden}.nav-letter-track{display:block}.nav-face{display:block;height:1em;line-height:1}.nav-underline-window{position:absolute;left:-.5px;right:-.5px;top:0;height:1px;overflow:hidden;opacity:0;pointer-events:none}.nav-hover-overline{position:absolute;left:-.5px;right:-.5px;top:0;height:1.22em;overflow:hidden;opacity:0;pointer-events:none}.nav-hover-overline:before,.nav-hover-overline:after{content:"";position:absolute;left:0;right:0;height:1px;background:currentColor}.nav-hover-overline:before{top:0}.nav-hover-overline:after{top:0;transform:translateY(1.22em)}.nav-label.is-active .nav-underline-window,.site-nav a:focus-visible .nav-underline-window,.nav-letter.is-rolling .nav-underline-window{opacity:1}.nav-label.is-active .nav-letter.is-rolling .nav-underline-window{opacity:0}.nav-underline-track{display:block}.nav-underline{display:block;height:1px;background:currentColor}.nav-letter.is-rolling .nav-letter-track{animation:nav-letter-roll .42s cubic-bezier(.76,0,.24,1) both}.nav-letter.is-rolling .nav-hover-overline{opacity:1}.nav-letter.is-rolling .nav-hover-overline:before{animation:nav-hover-overline-exit .42s cubic-bezier(.76,0,.24,1) both}.nav-letter.is-rolling .nav-hover-overline:after{animation:nav-hover-overline-enter .42s cubic-bezier(.76,0,.24,1) both}.nav-letter.is-rolling .nav-underline-track{animation:nav-underline-roll .42s cubic-bezier(.76,0,.24,1) both}@keyframes nav-letter-roll{0%{transform:translateY(0)}to{transform:translateY(-50%)}}@keyframes nav-underline-roll{0%{transform:translateY(0)}to{transform:translateY(-50%)}}@keyframes nav-hover-overline-exit{0%{transform:translateY(0);opacity:1}42%,to{transform:translateY(-.22em);opacity:0}}@keyframes nav-hover-overline-enter{0%,42%{transform:translateY(1.22em);opacity:0}43%{opacity:1}to{transform:translateY(0);opacity:1}}.hero{position:relative;height:100vh;height:100svh;min-height:100vh;min-height:100svh;display:grid;align-items:end;overflow:hidden;background:#111315}.hero-media{position:absolute;top:0;right:0;bottom:0;left:0;height:100%}.hero-copy{position:relative;max-width:980px;padding:0 var(--page-x) 9vh}.hero-copy p,.section-kicker{margin:0 0 12px;color:#6fcabd;font-size:.78rem;font-weight:760;text-transform:uppercase}.hero-copy h1{margin:0;color:#f4f1e8;font-size:clamp(2.1rem,6.2vw,5.9rem);line-height:.9;letter-spacing:0}.hero-copy h1 span{display:block;white-space:nowrap}.project-stack{display:grid;gap:1px;background:#31363a}.project-module{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,420px);background:#0d0f11}.project-media{position:relative;aspect-ratio:16 / 9;min-height:0;overflow:hidden;background:#151719}.p5-host{width:100%;height:100%;min-height:0;overflow:hidden;background:#111315}.p5-host canvas{display:block;width:100%!important;height:100%!important}.media-fill{display:block;width:100%;height:100%;min-height:0;object-fit:cover}.media-image{transition:transform .52s ease}.project-media:hover .media-image{transform:scale(1.045)}.media-embed{position:absolute;top:0;right:0;bottom:0;left:0;border:0;pointer-events:none}.media-poster{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;transition:opacity .18s ease,visibility .18s ease}.project-media:hover .media-poster{opacity:0;visibility:hidden}.project-info{align-self:end;padding:clamp(22px,3.6vw,44px) clamp(30px,4.8vw,64px) clamp(22px,3.6vw,44px) clamp(22px,3.6vw,44px);border-left:1px solid #31363a;background:#0d0f11}.project-info h2{margin:0;color:#f4f1e8;font-size:clamp(1.35rem,2.45vw,2.35rem);line-height:1;letter-spacing:0}.profile-section h2{margin:0;color:#f4f1e8;font-size:clamp(1.6rem,3vw,3rem);line-height:1;letter-spacing:0}.project-kicker{margin:14px 0 0;color:#6fcabd;font-size:.72rem;font-weight:760;text-transform:uppercase}.project-year{margin:8px 0 0;color:#f4f1e8;font-size:.78rem;font-weight:700}.project-info p:not(.section-kicker):not(.project-kicker):not(.project-year){margin:18px 0 0;max-width:58ch;color:#b9b5aa;font-size:.9rem;line-height:1.55}.profile-section p{margin:18px 0 0;max-width:58ch;color:#b9b5aa;font-size:.98rem;line-height:1.6}.profile-copy p:first-child{margin-top:0}.project-info ul{display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:28px 0 0;list-style:none}.project-info li{padding:7px 10px;border:1px solid #3c4246;color:#f4f1e8;font-size:.72rem}.project-detail-link,.back-link,.project-live-link{display:inline-flex;width:fit-content;margin-top:28px;color:#6fcabd;font-size:.78rem;font-weight:760;text-transform:uppercase;transition:color .18s ease}.project-detail-link:hover,.project-detail-link:focus-visible,.back-link:hover,.back-link:focus-visible,.project-live-link:hover,.project-live-link:focus-visible{color:#f06d4f}.projects-page,.about-page,.project-detail-page{min-height:100vh;min-height:100svh;background:#0d0f11}.work-single{display:grid;gap:clamp(28px,4vw,54px);min-height:100vh;min-height:100svh;padding:var(--page-header-top) var(--page-x) clamp(24px,4vw,44px);background:#0d0f11}.work-header{display:grid;grid-template-columns:minmax(0,.8fr) minmax(280px,1fr);align-items:start;gap:clamp(28px,6vw,90px)}.projects-heading{display:flex;align-items:flex-start;gap:clamp(14px,2vw,24px)}.projects-back-link{display:inline-flex;align-items:center;justify-content:center;width:clamp(38px,4vw,52px);height:clamp(38px,4vw,52px);margin-top:.18em;color:#fff;transition:color .18s ease,transform .18s ease}.projects-back-link:hover,.projects-back-link:focus-visible{color:#6fcabd;transform:translate(-4px)}.projects-back-link:focus-visible{outline:1px solid currentColor;outline-offset:6px}.projects-back-link svg{width:clamp(28px,3vw,38px);height:clamp(28px,3vw,38px)}.project-detail-back-link{display:inline-flex;align-items:center;justify-content:center;width:clamp(38px,4vw,52px);height:clamp(38px,4vw,52px);color:#fff;transition:color .18s ease,transform .18s ease}.project-detail-back-link:hover,.project-detail-back-link:focus-visible{color:#6fcabd;transform:translate(-4px)}.project-detail-back-link:focus-visible{outline:1px solid currentColor;outline-offset:6px}.project-detail-back-link svg{width:clamp(28px,3vw,38px);height:clamp(28px,3vw,38px)}.projects-heading h1{margin:0;color:#f4f1e8;font-size:clamp(1.65rem,3.6vw,3.9rem);line-height:.92;letter-spacing:0;white-space:nowrap}.about-single{display:grid;grid-template-columns:minmax(0,.9fr) minmax(220px,.42fr) minmax(280px,.72fr);gap:clamp(28px,5.4vw,88px);align-items:end;height:100vh;height:100svh;min-height:720px;padding:var(--page-header-base) var(--page-x) 0;overflow:hidden}.about-heading{display:flex;align-items:flex-start;align-self:start;gap:clamp(14px,2vw,24px);padding-top:var(--page-header-offset)}.about-heading h1{max-width:860px;margin:0;color:#f4f1e8;font-size:clamp(2rem,4.7vw,5.4rem);line-height:.92;letter-spacing:0}.about-portrait{display:flex;align-items:flex-end;justify-content:center;align-self:end;margin:0;width:100%;height:100%;min-height:0;overflow:visible;background:#f4f1e8}.about-portrait img{display:block;width:min(142%,470px);max-width:none;height:auto;max-height:min(78svh,720px);filter:contrast(1.04)}.about-content{align-self:start;display:grid;gap:clamp(24px,4vw,42px);padding-top:var(--page-header-offset)}.about-copy p{max-width:66ch}.project-detail-hero h1{margin:0;color:#f4f1e8;font-size:clamp(2rem,5.4vw,5.4rem);line-height:.92;letter-spacing:0}.project-filters{display:grid;justify-items:end;gap:10px}.project-filter-group{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.project-filters button{min-height:34px;padding:7px 11px;border:1px solid #3c4246;border-radius:0;background:transparent;color:#f4f1e8;font:inherit;font-size:.72rem;font-weight:760;text-transform:uppercase;cursor:pointer;transition:border-color .18s ease,color .18s ease}.project-filters button:hover,.project-filters button:focus-visible,.project-filters button.is-active{border-color:#6fcabd;color:#6fcabd}.project-stack-filtered{grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;padding:0;scroll-snap-align:start}.project-stack-filtered .project-module{display:grid;grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr);min-height:0;border:1px solid #31363a}.project-stack-filtered .project-media{aspect-ratio:16 / 10}.project-stack-filtered .project-info{align-self:stretch;display:flex;flex-direction:column;padding:16px;border-top:1px solid #31363a;border-left:0}.project-stack-filtered .project-info h2{order:2;font-size:clamp(1.12rem,1.8vw,1.55rem)}.project-stack-filtered .project-kicker{order:3;margin-top:10px}.project-stack-filtered .project-year{order:1;margin:0 0 10px}.project-stack-filtered .project-info p:not(.section-kicker):not(.project-kicker):not(.project-year){order:4;display:-webkit-box;margin-top:14px;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.project-stack-filtered .project-info ul{order:5;display:none}.project-stack-filtered .project-detail-link{order:6;margin-top:auto;padding-top:18px}.project-detail{display:grid;gap:clamp(44px,7vw,92px);padding:var(--page-header-top) var(--page-x) clamp(48px,8vw,110px)}.project-detail-hero{display:grid;grid-template-columns:auto minmax(0,1fr) minmax(280px,420px);align-items:start;gap:clamp(14px,3vw,42px)}.project-detail-hero .project-detail-back-link{margin-top:.18em}.project-detail-hero p:not(.section-kicker){max-width:68ch;margin:22px 0 0;color:#b9b5aa;font-size:clamp(1rem,1.4vw,1.22rem);line-height:1.5}.project-detail-facts{display:grid;gap:18px;margin:0;align-self:start}.project-detail-facts div{display:grid;gap:5px;padding-top:14px;border-top:1px solid #31363a}.project-detail-facts dt,.project-detail-meta h2{color:#6fcabd;font-size:.72rem;font-weight:760;text-transform:uppercase}.project-detail-facts dd{margin:0;color:#f4f1e8;font-size:.9rem;line-height:1.45}.project-gallery{display:grid;grid-template-rows:minmax(0,1fr) auto;gap:16px;height:100vh;height:100svh;min-height:620px}.gallery-frame{margin:0;min-height:0;background:#151719;overflow:hidden}.gallery-frame img{display:block;width:100%;height:100%;object-fit:cover}.gallery-controls{display:flex;align-items:center;justify-content:flex-end;gap:12px}.gallery-controls button{display:inline-grid;place-items:center;width:38px;height:38px;border:1px solid #3c4246;background:transparent;color:#f4f1e8;font:inherit;cursor:pointer;transition:border-color .18s ease,color .18s ease}.gallery-controls button:hover:not(:disabled),.gallery-controls button:focus-visible{border-color:#6fcabd;color:#6fcabd}.gallery-controls button:disabled{cursor:default;opacity:.35}.gallery-controls p{min-width:46px;margin:0;color:#b9b5aa;font-size:.8rem;font-weight:700;text-align:center}.project-detail-body{display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,360px);gap:clamp(34px,7vw,100px);align-items:start}.project-copy p{max-width:78ch;margin:0;color:#d8d4c9;font-size:clamp(1rem,1.25vw,1.14rem);line-height:1.68}.project-copy p+p{margin-top:22px}.project-detail-meta{display:grid;gap:28px}.project-detail-meta h2{margin:0 0 12px}.project-detail-meta ul{display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:0;list-style:none}.project-detail-meta li{padding:7px 10px;border:1px solid #3c4246;color:#f4f1e8;font-size:.72rem}.profile-section{display:grid;grid-template-columns:minmax(0,.85fr) minmax(220px,.42fr) minmax(260px,.65fr);align-items:end;gap:clamp(30px,7vw,120px);min-height:100vh;min-height:100svh;padding:clamp(80px,12vw,170px) var(--page-x) 0;background:#f4f1e8;color:#0d0f11}.profile-section h2,.profile-section p{color:#0d0f11}.profile-section .section-kicker{color:#c64e37}.profile-portrait{display:flex;justify-content:flex-end;align-items:center;align-self:end;margin:0;min-height:0;overflow:visible;background:transparent}.profile-portrait img{display:block;width:min(132%,430px);max-width:none;height:auto;max-height:min(82svh,760px);filter:contrast(1.04)}.site-footer{display:flex;align-items:center;justify-content:space-between;gap:28px;min-height:24vh;min-height:24svh;padding:clamp(34px,6vw,72px) var(--page-x);background:#0d0f11;color:#f4f1e8}.social-links,.legal-nav{display:flex;align-items:center}.social-links{gap:18px}.legal-nav{gap:18px;color:#b9b5aa;font-size:.78rem;font-weight:700;text-transform:uppercase}.legal-nav a{transition:color .18s ease}.legal-nav a:hover,.legal-nav a:focus-visible{color:#f06d4f}.social-link{display:inline-flex;align-items:center;justify-content:center;width:72px;height:44px;color:#6fcabd;transition:color .18s ease,transform .18s ease}.social-link:hover,.social-link:focus-visible{color:#f06d4f;transform:translateY(-2px)}.social-link:focus-visible{outline:1px solid currentColor;outline-offset:8px}.social-link svg{display:block}.mail-link svg,.soundcloud-link svg{width:32px;height:32px}.linkedin-link svg{width:32px;height:32px}@media(max-width:1080px){.project-stack-filtered{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:780px){:root{--page-header-base: 12.5svh;--page-header-offset: 0px}html{scroll-snap-type:none;scroll-padding-top:0}.site-nav{position:static;justify-content:flex-end;margin-left:auto;transform:none;gap:12px}.hero{height:100vh;height:100svh;height:100dvh;min-height:100vh;min-height:100svh}.hero-copy{padding-bottom:7vh}.hero-copy h1{font-size:clamp(1.35rem,6.3vw,2.55rem)}.work-header{grid-template-columns:1fr;gap:24px}.projects-heading,.about-heading{flex-direction:column;gap:8px}.projects-back-link,.project-detail-hero .project-detail-back-link{margin-top:0;margin-left:-6px}.project-detail-hero{gap:8px}.about-heading h1,.project-detail-hero h1,.projects-heading h1{font-size:var(--mobile-page-title-size)}.about-single{grid-template-columns:1fr;gap:28px;height:auto;min-height:100vh;min-height:100svh;min-height:100dvh;padding-top:var(--page-header-top);padding-bottom:0;overflow:visible}.about-heading{align-self:start}.about-portrait{align-items:center;justify-content:center;order:3;height:auto;min-height:0}.about-portrait img{width:min(82vw,320px);max-width:100%;height:auto;max-height:none;object-fit:contain}.about-content{align-self:start;gap:24px}.project-filters{justify-items:start;max-height:32vh;overflow:auto}.project-filter-group{justify-content:flex-start}.project-module{height:100vh;height:100svh;height:100dvh;min-height:100vh;min-height:100svh;grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) auto}.project-media{aspect-ratio:auto;min-height:0}.project-stack-filtered{grid-template-columns:1fr 1fr;padding-right:0;padding-left:0}.project-stack-filtered .project-module{height:auto;min-height:0;grid-template-rows:auto minmax(0,1fr);scroll-snap-align:none;scroll-snap-stop:normal}.project-stack-filtered .project-media{aspect-ratio:1 / 1}.project-stack-filtered .project-info{padding:14px}.project-stack-filtered .project-info h2{font-size:clamp(.98rem,5vw,1.2rem)}.project-stack-filtered .project-info p:not(.section-kicker):not(.project-kicker):not(.project-year){display:none}.project-stack-filtered .project-info ul{display:none}.project-stack-filtered .project-detail-link{margin-top:18px;padding-top:0}.project-info{border-left:0;border-top:1px solid #31363a}.project-detail{gap:40px;padding-top:var(--page-header-top)}.project-detail-hero,.project-detail-body{grid-template-columns:1fr}.project-detail-facts{gap:12px}.project-gallery{height:auto;min-height:0;grid-template-rows:auto auto}.gallery-frame{aspect-ratio:16 / 9}.gallery-controls{justify-content:flex-end}.profile-section{grid-template-columns:1fr;height:100vh;height:100svh;height:100dvh;min-height:100vh;min-height:100svh;padding-bottom:0}.site-footer{height:100vh;height:100svh;height:100dvh;min-height:100vh;min-height:100svh;flex-direction:column;justify-content:center}.profile-section>div{order:1}.profile-copy{order:2}.profile-portrait{order:3;max-width:420px;justify-self:center;align-self:end}.profile-portrait img{width:min(112%,420px);max-height:52svh}}
