:root{--color-background: #fbf9eb;--color-text: #272727;--color-text-muted: #5a5a5a;--color-border: #d4d0bb;--color-accent: #272727;--color-focus-ring: #0060df;--color-focus-ring-inverse: #fbf9eb;--color-error: #ff9e9e;--color-inverse-bg: #272727;--color-inverse-text: #fbf9eb;--color-overlay: rgba(39, 39, 39, .6);--color-backdrop: rgba(0, 0, 0, .85);--color-feedback-success-bg: rgba(251, 249, 235, .1);--color-feedback-error-bg: rgba(255, 158, 158, .15);--font-family: system-ui, "Inter", "Helvetica Neue", Arial, sans-serif;--type-display: clamp(2.5rem, 6vw, 6rem);--type-body: clamp(1rem, 1.2vw, 1.125rem);--type-label: .8125rem;--line-height-body: 1.6;--max-ch-body: 70ch;--space-1: .5rem;--space-2: 1rem;--space-3: 1.5rem;--space-4: 2rem;--space-6: 3rem;--space-8: 4rem;--space-12: 6rem;--space-16: 8rem;--grid-columns: 4;--grid-gutter: var(--space-2);--grid-margin: var(--space-2);--grid-max-width: 1440px;--logo-height-mobile: 32px;--logo-height-desktop: 40px;--z-dropdown: 50;--z-sticky: 100;--z-modal: 200;--z-skip-link: 300;--transition-fast: .15s ease;--transition-base: .25s ease;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-quart: cubic-bezier(.25, 1, .5, 1)}@media (min-width: 768px){:root{--grid-columns: 8;--grid-gutter: var(--space-3);--grid-margin: var(--space-4)}}@media (min-width: 1200px){:root{--grid-columns: 12;--grid-gutter: var(--space-4);--grid-margin: var(--space-6)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}[hidden]{display:none!important}html{font-size:100%}body{font-family:var(--font-family);font-size:var(--type-body);line-height:var(--line-height-body);background-color:var(--color-background);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-wrap:break-word}img,video{max-width:100%;display:block}ul,ol{list-style:none}a{color:inherit;text-decoration:underline}button{cursor:pointer;font-family:inherit;font-size:inherit}*:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:3px}.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;background:var(--color-background);color:var(--color-text);padding:var(--space-2) var(--space-3);text-decoration:none;font-weight:600;z-index:var(--z-skip-link);border:2px solid var(--color-focus-ring)}.skip-link:focus{position:fixed;left:var(--space-2);top:var(--space-2);width:auto;height:auto;overflow:visible}.container{max-width:var(--grid-max-width);margin-inline:auto;padding-inline:var(--grid-margin)}.grid{display:grid;grid-template-columns:repeat(var(--grid-columns),1fr);gap:var(--grid-gutter)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.site-header{position:sticky;top:0;z-index:var(--z-sticky);background-color:var(--color-background);border-bottom:1px solid var(--color-border)}.site-nav{display:flex;align-items:center;justify-content:space-between;max-width:var(--grid-max-width);margin-inline:auto;padding-inline:var(--grid-margin);padding-block:var(--space-2);gap:var(--space-2)}.nav-logo{display:inline-flex;align-items:center;flex-shrink:0;text-decoration:none}.nav-logo-img{height:var(--logo-height-mobile);width:auto}@media (min-width: 1200px){.nav-logo-img{height:var(--logo-height-desktop)}}.nav-toggle{display:flex;flex-direction:column;justify-content:space-between;width:44px;height:44px;padding:10px;background:none;border:none;flex-shrink:0;color:var(--color-text)}.nav-toggle-line{display:block;width:100%;height:2px;background-color:currentColor}.nav-list{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-1);position:absolute;top:100%;left:0;right:0;background-color:var(--color-background);border-bottom:1px solid var(--color-border);padding:var(--space-2) var(--grid-margin);z-index:var(--z-dropdown)}.nav-list a{display:inline-flex;align-items:center;min-height:44px;padding-inline:var(--space-1);text-decoration:none;font-size:var(--type-label);font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text)}@media (min-width: 768px){.nav-toggle{display:none}#primary-navigation{display:flex!important;flex-direction:row;flex-wrap:wrap;align-items:center;gap:var(--space-2);position:static;background:none;border:none;padding:0}}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;min-width:44px;padding:.625rem var(--space-3);font-size:var(--type-label);font-weight:600;letter-spacing:.05em;text-transform:uppercase;text-decoration:none;border:2px solid var(--color-text);white-space:nowrap}.btn--primary{background-color:var(--color-text);color:var(--color-background)}.btn--secondary{background-color:transparent;color:var(--color-text)}.section-heading{font-size:clamp(1.5rem,3vw,2.5rem);font-weight:700;letter-spacing:-.02em;margin-bottom:var(--space-6);text-wrap:balance}.hero{min-height:100svh;display:flex;align-items:center;padding-block:var(--space-8)}.hero .container{display:flex;flex-direction:column;gap:var(--space-6);width:100%}.hero-about{align-self:start;display:flex;flex-direction:column;gap:var(--space-3);max-width:70ch}.hero-logo-heading{margin:0}.hero-logo-main{display:block;width:clamp(150px,18vw,260px);height:auto}.hero-copy{display:flex;flex-direction:column;gap:var(--space-3)}.hero-copy p{margin:0;font-size:var(--type-body);line-height:var(--line-height-body);text-wrap:pretty}.hero-ctas{display:flex;flex-wrap:wrap;gap:var(--space-2)}.hero-video{aspect-ratio:16 / 9;overflow:hidden;background:var(--color-text);position:relative}.hero-video iframe{width:100%;height:100%;border:0;display:block}.yt-facade{position:relative;display:block;width:100%;height:100%;padding:0;margin:0;border:0;background:none;cursor:pointer}.yt-facade-thumb{display:block;width:100%;height:100%;object-fit:cover}.yt-facade-play{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.yt-facade-play svg{opacity:.85}@media (prefers-reduced-motion: no-preference){.yt-facade-play svg{transition:opacity .15s ease,transform .15s ease}.yt-facade:hover .yt-facade-play svg,.yt-facade:focus-visible .yt-facade-play svg{opacity:1;transform:scale(1.08)}}.yt-facade:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:3px}@media (min-width: 768px){.hero .container{flex-direction:row;align-items:stretch;gap:var(--space-6)}.hero-about{flex:1 1 40%;align-self:stretch;height:100%;display:flex;flex-direction:column;max-width:none}.hero-ctas{margin-top:auto;margin-bottom:0}.hero-video-col{flex:1 1 55%}}@media (min-width: 1200px){.hero .container{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);gap:var(--space-8)}}.work{padding-block:var(--space-12);border-top:1px solid var(--color-border)}.work-grid{display:grid;grid-template-columns:1fr;gap:var(--grid-gutter);align-items:start}@media (max-width: 767px){.work-grid:not(.is-expanded) .work-card:nth-child(n+4){display:none}}@media (min-width: 768px){.work-grid{grid-template-columns:repeat(2,1fr)}.work-card--featured{grid-column:span 2}}@media (min-width: 1200px){.work-grid{grid-template-columns:repeat(3,1fr)}}.work-actions{display:flex;justify-content:center;margin-top:var(--space-4)}@media (min-width: 768px){.work-actions{display:none}}.work-card{border:1px solid var(--color-border);overflow:hidden;display:flex;flex-direction:column}.work-card--featured .work-card-media img{aspect-ratio:3 / 2}.work-card--featured .work-card-title{font-weight:700}.work-card--featured .work-card-body{padding:var(--space-3)}.work-card-media{position:relative;display:block;width:100%;padding:0;border:none;background:none;overflow:hidden;cursor:pointer}.work-card-media img{width:100%;height:auto;aspect-ratio:16 / 9;object-fit:cover;display:block}.work-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;padding:var(--space-3);background:linear-gradient(to top,rgba(39,39,39,.85) 0%,transparent 55%);opacity:0;pointer-events:none}.work-card-overlay-text{font-size:var(--type-label);font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--color-background)}.work-card-media:hover .work-card-overlay,.work-card-media:focus-visible .work-card-overlay{opacity:1}.work-card-body{padding:var(--space-2);display:flex;flex-direction:column;gap:var(--space-1)}.work-card-title{font-size:var(--type-body);font-weight:600;letter-spacing:-.01em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.work-card-meta{display:flex;flex-direction:row;gap:var(--space-2);align-items:center}.work-card-category,.work-card-year{font-size:var(--type-label);color:var(--color-text-muted);letter-spacing:.05em;text-transform:uppercase}.work-card-caption{font-size:var(--type-label);color:var(--color-text-muted);line-height:1.5;text-wrap:pretty;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.work-empty{grid-column:1 / -1;text-align:center;color:var(--color-text-muted);padding:var(--space-8) 0;font-size:var(--type-body)}.is-scroll-locked{overflow:hidden}.work-card-media img[src]:after{content:attr(alt);display:flex;align-items:center;justify-content:center;position:absolute;top:0;right:0;bottom:0;left:0;background-color:var(--color-text);color:var(--color-background);font-size:var(--type-label);letter-spacing:.05em;text-transform:uppercase;text-align:center;padding:var(--space-2)}.work-card-body,.hero-about,.hero-video-col{min-width:0}.scroll-reveal-failsafe{opacity:1!important;transform:none!important;clip-path:none!important}.project-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--space-3)}.project-lightbox-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background-color:var(--color-backdrop)}.project-lightbox-panel{position:relative;width:100%;max-width:900px;max-height:90vh;overflow-y:auto;background-color:var(--color-background);border:1px solid var(--color-border)}.project-lightbox-panel[data-orientation=vertical]{max-width:520px}.project-lightbox-panel[data-orientation=square]{max-width:700px}.project-lightbox-close{position:absolute;top:var(--space-1);right:var(--space-1);z-index:1;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;font-size:1.5rem;line-height:1;background:var(--color-background);border:1px solid var(--color-border);color:var(--color-text);cursor:pointer}.project-lightbox-media{position:relative;width:100%;background-color:var(--color-text)}.project-lightbox-media.is-landscape{aspect-ratio:16 / 9}.project-lightbox-media.is-vertical{aspect-ratio:9 / 16;max-width:420px;margin-inline:auto}.project-lightbox-media.is-square{aspect-ratio:1 / 1;max-width:640px;margin-inline:auto}.project-lightbox-media iframe{width:100%;height:100%;border:0;display:block}.project-lightbox-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:var(--type-body);font-weight:600;color:var(--color-background);letter-spacing:.02em}.project-lightbox-content{padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.project-lightbox-content h2{font-size:clamp(1.125rem,2vw,1.5rem);font-weight:700;letter-spacing:-.01em;text-wrap:balance}.project-lightbox-platform{font-size:var(--type-label);font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted)}.project-lightbox-meta{font-size:var(--type-label);color:var(--color-text-muted);letter-spacing:.05em;text-transform:uppercase}.project-lightbox-caption{font-size:var(--type-body);line-height:var(--line-height-body);color:var(--color-text);margin-top:var(--space-1);text-wrap:pretty}.lightbox-loader{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}.lightbox-loader-bar{display:block;width:48px;height:3px;background-color:var(--color-background);opacity:.25}.contact{padding-block:var(--space-12);background-color:var(--color-inverse-bg);color:var(--color-inverse-text);border-top:1px solid var(--color-border)}.contact .section-heading{color:var(--color-inverse-text)}.contact *:focus-visible{outline-color:var(--color-focus-ring-inverse)}.form-group{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-3)}.form-group label{font-size:var(--type-label);font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--color-inverse-text)}.form-group input,.form-group textarea{width:100%;min-height:44px;padding:.625rem var(--space-2);font-family:var(--font-family);font-size:var(--type-body);color:var(--color-text);background-color:var(--color-background);border:1px solid var(--color-border);-moz-appearance:none;appearance:none;-webkit-appearance:none}.form-group textarea{min-height:auto;resize:vertical}.form-error{font-size:var(--type-label);color:var(--color-error);min-height:1.2em}.form-error.is-visible{display:block}.contact .btn--primary{background-color:var(--color-inverse-text);color:var(--color-inverse-bg);border-color:var(--color-inverse-text);margin-bottom:var(--space-3)}.contact .btn--primary:hover{background-color:var(--color-border);border-color:var(--color-border)}.form-feedback{padding:var(--space-2) var(--space-3);margin-top:var(--space-2)}.form-feedback--success{background-color:var(--color-feedback-success-bg);border:1px solid var(--color-focus-ring-inverse);color:var(--color-inverse-text)}.form-feedback--error{background-color:var(--color-feedback-error-bg);border:1px solid var(--color-error);color:var(--color-error)}.form-feedback a{color:inherit}.site-footer{padding-block:var(--space-4);border-top:1px solid var(--color-border);background-color:var(--color-background)}.footer-inner{display:flex;flex-direction:row;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-2)}.footer-copyright{font-size:var(--type-label);color:var(--color-text-muted)}.footer-social{display:flex;flex-direction:row;gap:var(--space-3)}.footer-social a{display:inline-flex;align-items:center;min-height:44px;font-size:var(--type-label);font-weight:600;letter-spacing:.05em;text-transform:uppercase;text-decoration:none;color:var(--color-text)}.btn--primary:hover{background-color:var(--color-text-muted);border-color:var(--color-text-muted)}.btn--secondary:hover{background-color:var(--color-text);color:var(--color-background)}.nav-list a:hover,.footer-social a:hover{text-decoration:underline}@media (prefers-reduced-motion: no-preference){html{scroll-behavior:smooth}.btn,.nav-list a,.footer-social a{transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.btn:active{transform:scale(.97);transition:transform 80ms ease}.work-card-media img{transition:transform 4s var(--ease-out-quart)}.work-card:nth-child(4n+2) .work-card-media img{transform-origin:30% 20%}.work-card:nth-child(4n+3) .work-card-media img{transform-origin:70% 80%}.work-card:nth-child(4n) .work-card-media img{transform-origin:25% 75%}.work-card-media:hover img,.work-card-media:focus-visible img{transform:scale(1.08)}.work-card-overlay{transition:opacity .4s var(--ease-out-expo)}.work-card-overlay-text{opacity:0;transform:translateY(10px);transition:opacity .35s var(--ease-out-expo) 80ms,transform .35s var(--ease-out-expo) 80ms}.work-card-media:hover .work-card-overlay-text,.work-card-media:focus-visible .work-card-overlay-text{opacity:1;transform:translateY(0)}.hero-logo-heading{animation:clip-reveal-up .7s var(--ease-out-expo) both}.hero-copy>p:first-child{animation:clip-reveal-up .6s var(--ease-out-expo) .2s both}.hero-copy>p:nth-child(2){animation:clip-reveal-up .6s var(--ease-out-expo) .35s both}.hero-ctas{animation:clip-reveal-up .5s var(--ease-out-expo) .5s both}.hero-video-col{animation:focus-pull .9s var(--ease-out-expo) .25s both}.scroll-reveal{opacity:0;clip-path:inset(100% 0 0 0);transition:opacity .6s var(--ease-out-expo),clip-path .6s var(--ease-out-expo)}.scroll-reveal.is-visible{opacity:1;clip-path:inset(0)}.scroll-reveal-heading{opacity:0;clip-path:inset(0 100% 0 0);transition:opacity .5s var(--ease-out-expo),clip-path .5s var(--ease-out-expo)}.scroll-reveal-heading.is-visible{opacity:1;clip-path:inset(0)}.scroll-reveal-stagger{opacity:0;clip-path:inset(100% 0 0 0);transition:opacity .5s var(--ease-out-expo),clip-path .5s var(--ease-out-expo)}.scroll-reveal-stagger.is-visible{opacity:1;clip-path:inset(0)}.project-lightbox:not([hidden]) .project-lightbox-backdrop{animation:fade-in .25s ease both}.project-lightbox:not([hidden]) .project-lightbox-panel{animation:iris-open .4s var(--ease-out-expo) both}.lightbox-loader-bar{animation:pulse-load 1.4s ease infinite}.lightbox-loader-bar:nth-child(2){animation-delay:.2s}.lightbox-loader-bar:nth-child(3){animation-delay:.4s}.project-lightbox-media iframe{opacity:0;transition:opacity .4s var(--ease-out-expo)}.project-lightbox-media.is-loaded iframe{opacity:1}.project-lightbox-media.is-loaded .lightbox-loader{opacity:0;transition:opacity .2s ease;pointer-events:none}}@keyframes clip-reveal-up{0%{opacity:0;clip-path:inset(100% 0 0 0)}to{opacity:1;clip-path:inset(0)}}@keyframes focus-pull{0%{opacity:0;filter:blur(6px);transform:scale(1.03)}40%{opacity:1}to{opacity:1;filter:blur(0);transform:scale(1)}}@keyframes iris-open{0%{opacity:0;clip-path:inset(40% 40% 40% 40%)}to{opacity:1;clip-path:inset(0)}}@keyframes fade-in{0%{opacity:0}}@keyframes pulse-load{0%,to{opacity:.12}50%{opacity:.4}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.scroll-reveal,.scroll-reveal-heading,.scroll-reveal-stagger{opacity:1!important;clip-path:none!important;transform:none!important}}
