:root{--site-header-height: calc(2rem + max(2.75rem, clamp(1.75rem, 4.5vw, 2.375rem)) + 1px) ;--bg: #121212;--surface: #1f1f1f;--fg: #f5f5f5;--muted: #a3a3a3;--line: #3a3a3a;--accent: #e5e5e5;--max: 68rem;--font-section-title: "Century Gothic", CenturyGothic, "Trebuchet MS", "Gill Sans", sans-serif;color-scheme:dark;font-family:Inter,system-ui,sans-serif;line-height:1.5;color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased}html{scroll-behavior:smooth;scroll-padding-top:var(--site-header-height)}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}*,*:before,*:after{box-sizing:border-box}body{margin:0}#root{min-height:100svh}h1,h2,h3{font-family:Syne,system-ui,sans-serif}a:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.site-header{--header-text: #141414;--header-muted: #525252;--header-mark-bg: #f0f0f0;--header-mark-border: #d4d4d4;--header-mark-fg: #404040;--header-nav-hover-bg: #141414;--header-nav-hover-fg: #ffffff;position:fixed;top:0;left:0;right:0;z-index:100;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;padding:1rem clamp(1.25rem,4vw,2.5rem);background:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--header-mark-border);color:var(--header-text);transition:transform .25s ease,border-color .2s ease}.site-header--hidden{transform:translateY(-100%)}.site-header__brand{grid-column:1;justify-self:start;font-weight:600;letter-spacing:-.02em;color:var(--header-text);text-decoration:none}.site-header__brand:hover{color:#000}.site-header__brand--mark{display:inline-flex;align-items:center;line-height:1}.site-header__brand--mark:hover .site-header__logo{opacity:.88}.site-header__logo{display:block;height:clamp(1.75rem,4.5vw,2.375rem);width:auto;max-width:min(11rem,42vw);object-fit:contain;transition:opacity .2s ease}.site-header__nav{justify-self:center;grid-column:2}.site-header__nav ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.25rem .35rem;justify-content:center}.site-header__nav a{display:inline-block;font-size:1.0625rem;font-weight:500;color:var(--header-muted);text-decoration:none;padding:.5rem .9rem;border-radius:0;transition:background-color .2s ease,color .2s ease}.site-header__nav a:hover{color:var(--header-nav-hover-fg);background:var(--header-nav-hover-bg)}.site-header__nav a:focus-visible{color:var(--header-nav-hover-fg);background:var(--header-nav-hover-bg)}.site-header__menu-toggle{display:none;grid-column:3;justify-self:end;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;padding:0;border:1px solid var(--header-mark-border);border-radius:.25rem;background:var(--header-mark-bg);color:var(--header-text);cursor:pointer;transition:border-color .2s ease,background-color .2s ease,color .2s ease}.site-header__menu-toggle:hover{border-color:#000;color:#000}.site-header__menu-icon{display:block}.site-header__overlay{display:none}@media (max-width: 767px){.site-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:.75rem}.site-header__brand{grid-column:auto;justify-self:start}.site-header__nav--desktop{display:none}.site-header__menu-toggle{display:inline-flex}.site-header__overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .28s ease,visibility .28s ease}.site-header__overlay--open{pointer-events:auto;opacity:1;visibility:visible}.site-header__overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000e6}.site-header__overlay-panel{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(4rem,12vh,5rem) 1.5rem 2rem;opacity:0;transform:scale(.97);transition:opacity .28s ease,transform .28s ease}.site-header__overlay--open .site-header__overlay-panel{opacity:1;transform:scale(1)}.site-header__overlay-close{position:absolute;top:1rem;right:clamp(1rem,4vw,1.5rem);display:inline-flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;padding:0;border:1px solid rgba(255,255,255,.35);border-radius:.25rem;background:#ffffff14;color:#fff;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.site-header__overlay-close:hover{background:#ffffff29;border-color:#ffffff8c}.site-header__overlay-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;align-items:center;gap:.25rem}.site-header__overlay-nav a{display:block;padding:.85rem 1.25rem;font-size:clamp(1.35rem,5vw,1.75rem);font-weight:600;color:#f5f5f5;text-decoration:none;text-align:center;border-radius:.375rem;transition:background-color .2s ease,color .2s ease}.site-header__overlay-nav a:hover,.site-header__overlay-nav a:focus-visible{color:#fff;background:#ffffff1a;outline:none}.site-header__overlay-nav a:focus-visible{outline:2px solid #ffffff;outline-offset:3px}}.hero{position:relative;overflow:hidden;min-height:100svh;display:flex;flex-direction:column;align-items:stretch;justify-content:center;padding:clamp(3.75rem,7vh,4.75rem) clamp(1.25rem,4vw,2.5rem) clamp(6.5rem,14vh,9rem);border-bottom:1px solid var(--line)}.hero__foreground{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;min-height:100svh}.hero__stage{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.hero__inner{position:relative;text-align:center;max-width:40rem}.hero__name{font-family:var(--font-section-title);font-size:clamp(2.25rem,6vw,3.5rem);font-weight:600;letter-spacing:-.03em;line-height:1.1;margin:0 0 1rem;color:var(--fg);opacity:0;animation:hero-name-in .8s cubic-bezier(.22,1,.36,1) .14s forwards}.hero__tagline{margin:0 0 0 10px;font-size:1.0625rem;line-height:1.55;color:var(--muted);opacity:0;animation:hero-tagline-in .72s cubic-bezier(.22,1,.36,1) .92s forwards}.hero__social{margin-top:1.5rem;margin-left:10px;opacity:0;animation:hero-social-in .68s cubic-bezier(.22,1,.36,1) 1.15s forwards}.hero__social ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.65rem 1.35rem;justify-content:center}.hero__social a{font-size:.9375rem;font-weight:500;color:var(--muted);text-decoration:none;border-bottom:1px solid transparent;padding-bottom:.1rem;transition:color .2s ease,border-color .2s ease}.hero__social a:hover{color:var(--fg);border-bottom-color:var(--line)}@keyframes hero-social-in{0%{opacity:0;transform:translate3d(0,.5rem,0)}to{opacity:1;transform:translateZ(0)}}@keyframes hero-name-in{0%{opacity:0}to{opacity:1}}@keyframes hero-tagline-in{0%{opacity:0;transform:translate3d(0,.75rem,0)}to{opacity:1;transform:translateZ(0)}}@media (prefers-reduced-motion: reduce){.hero__name,.hero__tagline,.hero__social,.hero__logo{animation:none;opacity:1;transform:translate3d(var(--hero-logo-nudge-x),0,0)}}@media (min-width: 960px){.hero{flex-direction:row;align-items:stretch;justify-content:flex-start;padding:clamp(3.5rem,6.5vh,4.75rem) clamp(1.5rem,4vw,2.75rem) clamp(6rem,12vh,8.5rem) clamp(2rem,5vw,4.5rem)}.hero__foreground{min-height:0;flex:1 1 auto;align-items:flex-start;justify-content:center;align-self:stretch;width:auto}.hero__stage{position:relative;inset:auto;flex:0 0 min(58%,760px);max-width:760px;min-width:340px;align-self:stretch;height:auto;min-height:0}.hero__inner{text-align:left;max-width:min(36rem,42vw);margin-left:0;margin-right:auto}.hero__social ul{justify-content:flex-start}}.hero__logo{--hero-logo-nudge-x: clamp(.4rem, 1.35vw, 1.05rem);display:block;width:min(290px,88vw);height:auto;margin-bottom:-3.2rem;margin-inline:auto;opacity:0;transform:translate3d(var(--hero-logo-nudge-x),-10px,0);animation:logoFadeIn .8s ease forwards;animation-delay:.2s}@media (min-width: 960px){.hero__logo{--hero-logo-nudge-x: clamp(.95rem, 2.75vw, 2.35rem);margin-inline:0;margin-right:auto}}@keyframes logoFadeIn{to{opacity:1;transform:translate3d(var(--hero-logo-nudge-x),0,0)}}.section-heading{max-width:36rem;margin-bottom:clamp(2rem,5vw,3rem)}.section-heading__eyebrow{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0 0 .5rem}.section-heading__title{font-family:var(--font-section-title);font-size:clamp(1.75rem,4vw,2.25rem);font-weight:600;letter-spacing:-.02em;margin:0 0 .75rem;color:var(--fg)}.section-heading__intro{margin:0;line-height:1.6;color:var(--muted)}.art-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:clamp(.75rem,3vw,1.5rem);box-sizing:border-box}.art-lightbox__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:none;padding:0;margin:0;cursor:pointer;background:color-mix(in srgb,var(--fg) 55%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.art-lightbox__panel{position:relative;z-index:1;box-sizing:border-box;width:80vw;height:80vh;max-width:min(80vw,72rem);max-height:min(80vh,52rem);display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:.25rem;box-shadow:0 24px 48px #0000002e;overflow:hidden}@media (max-width: 720px){.art-lightbox__panel{width:95vw;height:90vh;max-width:95vw;max-height:90vh}}.art-lightbox__close{position:absolute;top:.65rem;right:.65rem;z-index:2;width:2.25rem;height:2.25rem;display:grid;place-items:center;border:1px solid var(--line);border-radius:.25rem;background:var(--surface);color:var(--fg);font-size:1.35rem;line-height:1;cursor:pointer}.art-lightbox__close:hover{background:var(--bg)}.art-lightbox__layout{display:grid;grid-template-columns:1fr min(16rem,32vw);grid-template-rows:minmax(0,1fr);gap:0;min-height:0;flex:1;overflow:hidden}@media (max-width: 720px){.art-lightbox__layout{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) auto}}.art-lightbox__visual{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:clamp(.35rem,1.5vw,.65rem);min-height:0;min-width:0;height:100%;background:var(--bg);padding:clamp(.5rem,1.5vw,1rem) clamp(.35rem,1vw,.75rem);overflow:hidden}.art-lightbox__nav{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;padding:0;border:1px solid var(--line);border-radius:.25rem;background:var(--surface);color:var(--fg);cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.art-lightbox__nav:hover{background:var(--bg)}.art-lightbox__nav:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.art-lightbox__media{flex:1;align-self:stretch;min-width:0;min-height:0;display:flex;align-items:center;justify-content:center;padding:clamp(.35rem,1vw,.75rem);overflow:hidden}.art-lightbox__media img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.art-lightbox__aside{min-height:0;padding:clamp(1.25rem,3vw,1.75rem);border-left:1px solid var(--line);overflow-y:auto;overflow-x:hidden}@media (max-width: 720px){.art-lightbox__aside{border-left:none;border-top:1px solid var(--line);max-height:min(36vh,14rem);flex-shrink:0}}.art-lightbox__title{font-family:Syne,system-ui,sans-serif;font-size:1.25rem;font-weight:600;margin:0 0 .75rem;padding-right:2.5rem;color:var(--fg)}.art-lightbox__desc{margin:0;font-size:.9375rem;line-height:1.6;color:var(--muted)}.art-lightbox__counter{margin:1rem 0 0;font-size:.8125rem;color:var(--muted);letter-spacing:.04em}.art{padding:clamp(4rem,10vw,6rem) clamp(1.25rem,4vw,2.5rem);border-bottom:1px solid var(--line);background-color:#f5f5f5;color:#141414;--fg: #141414;--muted: #525252;--line: #d4d4d4;--surface: #ebebeb;--bg: #e0e0e0;--accent: #141414;transition:background-color .5s ease}@media (prefers-reduced-motion: reduce){.art{transition-duration:.01ms}}.art__container{max-width:var(--max);margin:0 auto}.art__grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,16rem),1fr));gap:clamp(1rem,2vw,1.5rem)}.art__figure{margin:0}.art__thumb{display:block;width:100%;padding:0;margin:0;border:none;cursor:zoom-in;background:var(--surface);border-radius:.125rem;overflow:hidden}.art__thumb:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.art__thumb:hover img{opacity:.92}.art__thumb img{width:100%;height:auto;display:block;background:var(--surface);aspect-ratio:4 / 5;object-fit:cover;transition:opacity .2s ease}.art__figure figcaption{margin-top:.5rem;font-size:.8125rem;color:var(--muted)}.projects{padding:clamp(4rem,10vw,6rem) clamp(1.25rem,4vw,2.5rem);border-bottom:1px solid var(--line);background-color:var(--bg);color:var(--fg);transition:background-color .5s ease}@media (prefers-reduced-motion: reduce){.projects{transition-duration:.01ms}}.projects__container{max-width:var(--max);margin:0 auto}.projects__list{list-style:none;margin:0;padding:0;display:grid;gap:1.25rem;grid-template-columns:1fr;max-width:min(100%,28rem)}.project-card{height:100%;padding:1.5rem;border:1px solid #d4d4d4;border-radius:.25rem;background:#fff;color:#141414;text-decoration:none;display:flex;flex-direction:column;gap:.75rem;--project-hover-glow: #d4d4d4;box-shadow:0 2px 10px #00000024;transition:box-shadow .28s ease}.project-card:focus-visible{outline:2px solid #141414;outline-offset:3px}.project-card:hover{box-shadow:0 4px 28px color-mix(in srgb,var(--project-hover-glow) 42%,transparent),0 8px 40px color-mix(in srgb,var(--project-hover-glow) 22%,transparent),0 2px 10px #00000029}@media (prefers-reduced-motion: reduce){.project-card{transition-duration:.01ms}}.project-card__title{font-size:1.125rem;font-weight:600;margin:0;color:#000}.project-card__desc{margin:0;flex:1;font-size:.9375rem;line-height:1.55;color:#404040}.project-card__stack{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}.project-card__stack li{font-size:.75rem;letter-spacing:.04em;text-transform:uppercase;padding:.25rem .5rem;border:1px solid #d4d4d4;border-radius:.125rem;color:#525252}.project-card__cta{font-size:.875rem;font-weight:600;color:#000;margin-top:.25rem}.project-card__image{width:100%;height:180px;object-fit:cover;border-radius:12px;margin-bottom:12px}.resume{position:relative;padding:clamp(4rem,10vw,6rem) clamp(1.25rem,4vw,2.5rem);border-bottom:1px solid var(--line);background-color:#e6e3dc;background-image:repeating-linear-gradient(180deg,rgba(52,48,42,.078) 0 1px,transparent 1px 2.5rem),linear-gradient(178deg,#ebe8e1,#e4e1d9 55%,#dcd8cf);background-repeat:repeat,no-repeat;background-size:auto,100% 100%;color:#141414;--fg: #141414;--muted: #525252;--line: #d0ccc2;--surface: #ebe8e0;--bg: #ddd9d0;--accent: #141414;transition:background-color .5s ease;overflow:hidden}.resume:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.085;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 256 256'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");background-size:160px 160px}@media (prefers-reduced-motion: reduce){.resume{transition-duration:.01ms}}.resume__container{position:relative;z-index:1;max-width:var(--max);margin:0 auto;padding:clamp(2.25rem,5.5vw,3.25rem) clamp(1.75rem,5vw,3rem);border-radius:2px 3px 3px 2px;border:1px solid color-mix(in srgb,#5c4d3d 22%,transparent);border-left:4px solid color-mix(in srgb,#4a3b30 55%,#2a221c);background:linear-gradient(105deg,color-mix(in srgb,#faf7ef 88%,#c4b8a4),#faf8f3 18%,#f7f4ec 55%,#f3efe4);box-shadow:inset 1px 0 #ffffff8c,inset 0 1px #ffffff59,0 1px #0000000a,0 14px 36px #2a241e1f,2px 0 #3e342c14}.resume__pdf-lead{margin:0 0 2rem;font-size:.9375rem;line-height:1.5;color:var(--muted)}.resume__pdf-link{font-weight:500;color:var(--accent);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--accent) 40%,transparent)}.resume__pdf-link:hover{border-bottom-color:var(--accent)}.resume__section-label{font-family:Syne,system-ui,sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 1rem}.resume__roles{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}.resume__role{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.5rem 1.25rem;padding:1rem 0;border-bottom:1px solid var(--line)}.resume__role-text{display:flex;flex-direction:column;gap:.2rem;min-width:min(100%,16rem)}.resume__role-title{font-size:1rem;font-weight:600;color:var(--fg)}.resume__role-meta{font-size:.875rem;color:var(--muted);line-height:1.4}.resume__role-dates{font-size:.8125rem;color:var(--muted);white-space:nowrap;margin-left:auto}.contact{position:relative;padding:clamp(3.25rem,8vw,5rem) clamp(1.25rem,4vw,2.5rem) clamp(2.75rem,7vw,4.25rem);background-color:var(--bg);color:var(--fg);transition:background-color .5s ease;overflow:hidden}.contact__ambient{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;display:grid;grid-template-columns:auto minmax(0,1fr) auto;grid-template-rows:1fr;padding:0;margin:0;pointer-events:none}.contact__tools--rail{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.32rem;list-style:none;margin:0;padding:0;align-self:stretch;min-height:0;height:100%;overflow:hidden;pointer-events:auto}.contact__tools--rail-left{grid-column:1;grid-row:1}.contact__tools--rail-right{grid-column:3;grid-row:1}.contact__tool{display:flex;flex-direction:column;flex:0 0 auto;align-items:center;width:4.65rem;gap:.3rem;margin-block:0;margin-inline:0;padding:0;text-align:center;text-decoration:none;color:inherit;border:none;border-radius:0;background:none;box-shadow:none}.contact__tool-icon{width:clamp(1.35rem,3vw,1.7rem);height:clamp(1.35rem,3vw,1.7rem);flex-shrink:0;line-height:0;opacity:.72;transition:opacity .2s ease,transform .2s ease;filter:drop-shadow(0 0 .5px rgba(255,255,255,.2)) brightness(1.06) saturate(.58)}.contact__tool-icon svg{width:100%;height:100%;display:block}.contact__tool-label{font-size:.625rem;font-weight:500;letter-spacing:.03em;text-transform:none;color:color-mix(in srgb,var(--muted) 82%,var(--fg));max-width:6.25rem;line-height:1.25}.contact__tool:hover .contact__tool-icon{opacity:.9;transform:scale(1.04);filter:drop-shadow(0 0 .5px rgba(255,255,255,.28)) brightness(1.08) saturate(.68)}.contact__tool:hover .contact__tool-label{color:color-mix(in srgb,var(--muted) 55%,var(--fg))}.contact__tool:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 85%,transparent);outline-offset:3px}@media (prefers-reduced-motion: reduce){.contact__tool:hover .contact__tool-icon{transform:none}.contact__tool-icon,.contact{transition-duration:.01ms}}.contact__container{position:relative;z-index:1;max-width:var(--max);margin:0 auto}.contact__design-blurb{margin:0 0 1rem;max-width:36rem;font-size:.9375rem;line-height:1.65;color:var(--muted)}.contact__design-blurb:last-of-type{margin-bottom:1.5rem}.contact__links{display:flex;flex-direction:column;gap:1.35rem;align-items:flex-start;width:100%}.contact__email{font-size:clamp(1.2rem,2.8vw,1.5rem);font-weight:600;letter-spacing:.01em;color:var(--fg);text-decoration:none;border-bottom:2px solid color-mix(in srgb,var(--fg) 35%,transparent);padding-bottom:.2rem}.contact__email:hover{color:var(--accent);border-color:var(--accent)}.contact__social{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;justify-content:flex-start}.contact__social a{color:var(--muted);text-decoration:none;font-size:.9375rem}.contact__social a:hover{color:var(--fg)}.scroll-to-top{position:fixed;bottom:1.5rem;right:1.5rem;z-index:90;width:3rem;height:3rem;padding:0;display:grid;place-items:center;border:1px solid var(--line);border-radius:50%;background:var(--surface);color:var(--fg);cursor:pointer;box-shadow:0 4px 14px #0000001f;opacity:0;visibility:hidden;transform:translateY(.5rem);transition:opacity .25s ease,visibility .25s ease,transform .25s ease,background .2s ease,color .2s ease,border-color .2s ease}.scroll-to-top--visible{opacity:1;visibility:visible;transform:translateY(0)}.scroll-to-top:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.scroll-to-top:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.scroll-to-top__icon{display:block;margin-top:2px}@media (max-width: 540px){.scroll-to-top{bottom:1.25rem;right:1.25rem}}.app{min-height:100svh}.app main{display:block}main>section{min-height:100svh;box-sizing:border-box}
