:root{--font-mono: "JetBrains Mono", "SF Mono", ui-monospace, Menlo, Monaco, Consolas, monospace;--font-display: Fraunces, Georgia, serif;--text-base-size: 14px;--text-base-line: 2;--text-secondary-size: 11.5px;--text-secondary-line: 1.6;--text-secondary-tracking: .02em;--project-text-width: 55.1429rem;--page-pad: clamp(1.5rem, 1.7vw, 2rem);--grid-gap: .5rem;--radius-sm: 2px;--radius-card: 2px;--ease: .3s ease}:root[data-theme=light]{--bg: #f7f7f4;--surface: #efefeb;--card-hover: #ffffff;--surface-strong: #ffffff;--text: #323f45;--muted: #657077;--faint: rgba(50, 63, 69, .1);--line: rgba(50, 63, 69, .12)}:root[data-theme=dark]{--bg: #182b31;--surface: #1d343b;--card-hover: #17272d;--surface-strong: #203941;--text: #e9ece9;--muted: #9fadad;--faint: rgba(233, 236, 233, .1);--line: rgba(233, 236, 233, .12)}*{box-sizing:border-box}html{background:var(--bg);color:var(--text);font-family:var(--font-mono);font-size:var(--text-base-size);line-height:var(--text-base-line);letter-spacing:0;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text);font-size:var(--text-base-size);line-height:var(--text-base-line)}a{color:inherit;text-decoration:none}button{border:0;font:inherit}img{display:block;max-width:100%}.site-header{position:sticky;top:0;z-index:10;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:2rem;padding:2rem var(--page-pad) 2rem;background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(12px)}.wordmark{width:122px}:root[data-theme=dark] .wordmark,:root[data-theme=dark] .theme-toggle img,:root[data-theme=dark] .contact-action img,:root[data-theme=dark] .contact-close img,:root[data-theme=dark] .project-download__button img,:root[data-theme=dark] .project-nav img,:root[data-theme=dark] .site-footer img{filter:invert(95%) sepia(6%) saturate(108%) hue-rotate(39deg) brightness(101%) contrast(88%)}.header-actions{justify-self:end;display:flex;align-items:center;gap:1.5rem}.site-nav{display:flex;align-items:center;gap:1.25rem;font-family:var(--font-mono);font-size:.8214rem;font-weight:400;letter-spacing:.04em;line-height:1.1429;text-transform:uppercase}.site-nav a,.site-nav a:hover,.site-nav a[aria-current=page]{color:var(--text)}.site-nav a[aria-current=page]{text-decoration:underline;text-underline-offset:.2em}.theme-toggle{display:grid;width:1.5rem;height:1.5rem;place-items:center;border-radius:50%;background:transparent;cursor:pointer;color:var(--text);padding:0}.theme-toggle:hover,.theme-toggle:focus-visible{background:var(--faint)}.theme-toggle img{width:1.25rem;height:1.25rem}.work-index{padding:0 var(--page-pad) 4rem}.section-heading{display:flex;align-items:end;justify-content:space-between;margin-bottom:1rem}.eyebrow,.project-card__kicker,.project-card__index,.site-footer,.project-body aside{font-family:var(--font-mono);font-size:.8214rem;line-height:1.1429;text-transform:uppercase}.project-card__kicker,.project-card__index{color:var(--text);font-weight:400;letter-spacing:.04em}.section-heading h1,.about-page h1,.project-hero h1{margin:0;font-size:52px;font-weight:700;line-height:1}.about-page h1,.project-hero h1{font-family:var(--font-display);font-style:italic}.project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--grid-gap)}.project-card{position:relative;display:grid;grid-template-rows:minmax(0,1fr) auto;aspect-ratio:598 / 640;overflow:hidden;border:1px solid var(--line);border-radius:6px;background:var(--bg);outline-offset:4px;transition:background var(--ease)}.project-card:hover,.project-card:focus-visible{background:var(--card-hover)}.project-card__art{position:relative;min-height:0;overflow:hidden}.project-card__mark{position:absolute;left:var(--mark-x);top:var(--mark-y);width:var(--mark-width);max-width:none;opacity:var(--mark-opacity);transform:translate(-50%,-50%);transition:opacity var(--ease),transform var(--ease)}:root[data-theme=dark] .project-card__mark{filter:invert(95%) sepia(6%) saturate(108%) hue-rotate(39deg) brightness(101%) contrast(88%)}.project-card__preview{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity var(--ease)}.project-card:hover .project-card__preview,.project-card:focus-visible .project-card__preview{opacity:1}.project-card:hover .project-card__mark,.project-card:focus-visible .project-card__mark{opacity:0;transform:translate(-50%,-50%) scale(1.02)}.project-card__meta{position:relative;display:grid;grid-template-rows:max-content max-content max-content;align-content:end;gap:12px;padding:1.75rem 2rem 1.5rem;background:transparent}.project-card__title-row{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:baseline}.project-card__title{font-size:.8214rem;font-weight:700;letter-spacing:.04em;line-height:1.1429;text-transform:uppercase}.project-card__kicker{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-card__dek{max-width:33rem;color:var(--muted);font-size:.8571rem;font-weight:400;letter-spacing:0;line-height:1.6667}.about-page,.project-page{padding:3rem var(--page-pad) 6rem}.about-page__intro,.project-hero{max-width:52rem;margin:0 auto 4rem;text-align:center}.project-hero{max-width:none}.project-hero .eyebrow{margin:0 0 16px}.about-page__intro p,.project-hero p{color:var(--muted)}.about-page__content,.project-body{max-width:54rem;margin:0 auto}.project-body{max-width:var(--project-text-width)}.project-body{display:block}.project-body>div{width:100%;min-width:0}.about-page__content>*,.project-body>div>*{margin-top:0;margin-bottom:0}.about-page__content p,.project-body p{margin:0;max-width:var(--project-text-width)}.about-page__content a,.project-body a{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:.18em}.about-page__content h2,.about-page__content h3,.project-body h2,.project-body h3{margin:0;font-family:var(--font-mono);font-size:var(--text-base-size);font-weight:700;letter-spacing:0;line-height:var(--text-base-line)}.project-flow-image{margin:0}.project-flow-image img{width:100%;border-radius:6px}.project-flow-image--natural{width:fit-content;max-width:100%}.project-flow-image--natural img{width:auto;max-width:100%}.project-flow-image--edge{position:relative;left:50%;width:min(calc(100vw - 16px),var(--image-width, 2000px));max-width:none;transform:translate(-50%)}.project-flow-image--edge img{border-radius:6px}.project-flow-image--wide{position:relative;left:50%;width:min(calc(100vw - 16px),1020px);max-width:1020px;transform:translate(-50%)}.project-flow-image--two-up,.project-flow-image--two-up-large{position:relative;left:50%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;transform:translate(-50%)}.project-flow-image--two-up{width:min(calc(100vw - 16px),1020px);max-width:1020px}.project-flow-image--two-up-large{width:min(calc(100vw - 16px),1500px);max-width:1500px}.project-flow-image--two-up img,.project-flow-image--two-up-large img{height:100%;object-fit:cover}.project-flow-video{overflow:hidden;margin:0;border-radius:6px;background:var(--surface)}.project-flow-video--wide{position:relative;left:50%;width:min(calc(100vw - 16px),1020px);max-width:1020px;aspect-ratio:16 / 9;transform:translate(-50%)}.project-flow-video iframe{width:100%;height:100%;border:0}.about-page__content>*:not(:first-child),.project-body>div>*+*{margin-top:48px}.about-page__content>h3+p:not(:first-child),.about-page__content>h2+p:not(:first-child),.project-body h2+p,.project-body h3+p{margin-top:8px}.about-page__content>p+p:not(:first-child),.project-body p+p{margin-top:24px}.project-body figure+figure{margin-top:24px}.project-download{display:flex;max-width:var(--project-text-width)}.project-body .project-download__button{display:inline-flex;align-items:center;gap:.65rem;border:1px solid var(--line);border-radius:var(--radius-sm);padding:.7rem .9rem;background:transparent;color:var(--text);cursor:pointer;font-size:.8214rem;font-weight:700;letter-spacing:.04em;line-height:1.1429;text-decoration:none;text-transform:uppercase}.project-body .project-download__button:hover,.project-body .project-download__button:focus-visible{background:var(--faint)}.project-download__button img{width:1.25rem;height:1.25rem;flex:0 0 auto}.about-page__content>p+h3:not(:first-child),.project-body p+h3{margin-top:24px}.project-nav{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:2rem;width:min(calc(100vw - 16px),1020px);max-width:1020px;margin:5.5rem auto 0;border-top:1px dashed var(--line);padding:2.25rem 0 0}.project-nav__link,.project-nav__all{color:var(--text);font-size:.8214rem;font-weight:700;letter-spacing:.12em;line-height:1.35;text-transform:uppercase}.project-nav__link{display:inline-flex;align-items:center;gap:1.1rem;min-width:0;max-width:100%}.project-nav__link--previous{justify-self:start}.project-nav__link--next{justify-self:end;text-align:right}.project-nav__link strong,.project-nav__link span span{display:block}.project-nav__link>span{min-width:0}.project-nav__link span span{color:var(--muted);font-weight:400}.project-nav__link img{width:20px;height:20px;flex:0 0 auto}.project-nav__all{justify-self:center;text-align:center}.contact-panel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:32px;width:min(100%,var(--project-text-width));max-width:var(--project-text-width);margin-right:auto;margin-left:auto;margin-top:3rem}.about-page .contact-panel{margin-top:48px}.contact-action{display:grid;justify-items:center;gap:.45rem;border-top:1px dashed var(--line);padding-top:1.8rem;background:transparent;color:var(--text);cursor:pointer;font-size:.8214rem;font-weight:700;letter-spacing:.04em;line-height:1.1429;text-transform:uppercase}.contact-action img,.contact-close img{width:1.25rem;height:1.25rem}.contact-dialog{width:min(calc(100vw - 3rem),34rem);border:1px solid var(--line);border-radius:var(--radius-card);padding:0;background:var(--bg);color:var(--text)}.contact-dialog::backdrop{background:color-mix(in srgb,var(--text) 26%,transparent);backdrop-filter:blur(4px)}.contact-form{position:relative;display:grid;gap:1rem;padding:2rem}.contact-form h2{margin:0 0 .5rem;font-size:1rem;line-height:1.4;text-transform:uppercase}.contact-form label{display:grid;gap:.4rem;color:var(--muted);font-size:var(--text-secondary-size);letter-spacing:var(--text-secondary-tracking);line-height:var(--text-secondary-line);text-transform:uppercase}.contact-form input,.contact-form textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius-sm);padding:.75rem;background:var(--surface);color:var(--text);font:inherit;font-size:var(--text-base-size);line-height:var(--text-base-line);resize:vertical}.contact-form input:focus,.contact-form textarea:focus{outline:1px solid var(--text);outline-offset:2px}.contact-close{position:absolute;top:1rem;right:1rem;display:grid;width:2rem;height:2rem;place-items:center;border-radius:50%;background:transparent;cursor:pointer}.contact-close:hover,.contact-close:focus-visible,.contact-submit:hover,.contact-submit:focus-visible{background:var(--faint)}.contact-submit{justify-self:start;border:1px solid var(--line);border-radius:var(--radius-sm);padding:.55rem .85rem;background:transparent;color:var(--text);cursor:pointer;font-size:.8214rem;letter-spacing:.04em;line-height:1.1429;text-transform:uppercase}.contact-status{margin:0;color:var(--muted);font-size:.8571rem;line-height:1.6667}.site-footer{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:2.5rem;justify-content:center;max-width:36rem;margin:7rem auto 5.5rem;color:var(--muted);font-family:var(--font-mono);font-size:var(--text-secondary-size);letter-spacing:var(--text-secondary-tracking);line-height:var(--text-secondary-line);text-transform:uppercase}.site-footer p{margin:0;white-space:nowrap}.site-footer p:first-child{justify-self:end}.site-footer p:last-child{justify-self:start;text-transform:none}.site-footer img{width:7rem;height:7rem;opacity:.68}@media(min-width:2000px){.project-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(max-width:1000px){.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.project-nav{gap:1rem;width:min(calc(100vw - 40px),1020px)}.project-nav__link{gap:.75rem}}@media(max-width:640px){.site-header{align-items:center;gap:1rem;padding-top:1.25rem;padding-bottom:2rem}.header-actions,.site-nav{gap:1rem;min-width:0}.project-grid{grid-template-columns:1fr}.project-card{min-height:21rem}.site-footer{grid-template-columns:1fr;gap:1.25rem;justify-items:center;margin:4rem auto 3rem;text-align:center}.site-footer p:first-child,.site-footer p:last-child{justify-self:center}.section-heading{align-items:start;flex-direction:column;gap:.5rem}.project-nav{grid-template-columns:1fr;gap:1.75rem;text-align:center}.project-nav__link,.project-nav__link--previous,.project-nav__link--next,.project-nav__all{justify-self:center;text-align:center}.project-nav__link{display:grid;grid-template-columns:20px minmax(0,auto) 20px;column-gap:1.1rem}.project-nav__link:before,.project-nav__link:after{content:"";display:none;width:20px;height:20px}.project-nav__link--previous:after{display:block;grid-column:3}.project-nav__link--next:before{display:block;grid-column:1}.project-nav__link--previous img{grid-column:1}.project-nav__link--previous>span,.project-nav__link--next>span{grid-column:2}.project-nav__link--next img{grid-column:3}.project-flow-image--two-up,.project-flow-image--two-up-large{grid-template-columns:1fr}.contact-panel{grid-template-columns:1fr;gap:1.75rem}}
