@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,300;9..144,400;9..144,500;9..144,600&family=IBM+Plex+Sans:wght@300;400;500;600&family=Noto+Serif+SC:wght@400;500;600&family=Noto+Sans+SC:wght@300;400;500&display=swap";:root{--ink: #0A0A0A;--ink-soft: #1A1A1A;--paper: #FAFAF7;--paper-warm: #F4F2EC;--mute: #6B6B68;--rule: #E5E5E0;--font-display: "Fraunces", "Noto Serif SC", Georgia, serif;--font-body: "IBM Plex Sans", "Noto Sans SC", -apple-system, system-ui, sans-serif;--maxw: 1440px;--gutter: clamp(1.25rem, 4vw, 3rem);--step--1: clamp(.875rem, .85rem + .1vw, .9375rem);--step-0: clamp(1rem, .95rem + .25vw, 1.125rem);--step-1: clamp(1.125rem, 1.05rem + .4vw, 1.375rem);--step-2: clamp(1.5rem, 1.3rem + 1vw, 2rem);--step-3: clamp(2rem, 1.6rem + 2vw, 3rem);--step-4: clamp(2.75rem, 2rem + 3.5vw, 4.5rem);--step-5: clamp(3.5rem, 2.4rem + 5.5vw, 7rem);--step-6: clamp(4.5rem, 2.8rem + 8vw, 10rem)}*,*:before,*:after{box-sizing:border-box}*{margin:0}html,body{height:100%}body{font-family:var(--font-body);font-size:var(--step-0);line-height:1.55;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}img,picture,svg{display:block;max-width:100%}button,input,textarea,select{font:inherit}a{color:inherit;text-decoration:none}h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:400;letter-spacing:-.02em;line-height:1.05;font-variation-settings:"opsz" 96,"SOFT" 50}h1{font-size:var(--step-5)}h2{font-size:var(--step-4)}h3{font-size:var(--step-3)}h4{font-size:var(--step-2)}p{max-width:65ch}::selection{background:var(--ink);color:var(--paper)}.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}.section{padding-block:clamp(4rem,8vw,9rem);border-top:1px solid var(--rule)}.section--first{border-top:0}.eyebrow{font-family:var(--font-body);font-size:.75rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);margin-bottom:1.5rem}.link{border-bottom:1px solid currentColor;padding-bottom:1px;transition:opacity .2s ease}.link:hover{opacity:.55}.arrow-link{display:inline-flex;align-items:baseline;gap:.5rem;font-weight:500;border-bottom:1px solid var(--ink);padding-bottom:2px;transition:gap .25s ease}.arrow-link:hover{gap:.85rem}.arrow-link:after{content:"→"}.site-header{position:sticky;top:0;z-index:50;background:#fafaf7eb;border-bottom:1px solid var(--rule);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.site-header__inner{display:flex;align-items:center;justify-content:space-between;height:4.5rem}.brand{font-family:var(--font-display);font-size:1.25rem;font-weight:500;letter-spacing:-.02em}.brand em{font-style:italic;font-weight:400}.nav{display:flex;gap:clamp(1.25rem,3vw,2.5rem)}.nav a{font-size:var(--step--1);font-weight:400;color:var(--ink);position:relative}.nav a:hover{color:var(--mute)}.nav a[aria-current=page]:after{content:"";position:absolute;left:0;right:0;bottom:-.3rem;height:1px;background:var(--ink)}@media(max-width:640px){.nav{gap:1rem;font-size:.8rem}}.site-footer{border-top:1px solid var(--rule);padding-block:3rem;font-size:var(--step--1);color:var(--mute)}.site-footer__inner{display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between}.site-footer a{color:var(--ink)}.site-footer a:hover{color:var(--mute)}.hero{padding-block:clamp(5rem,12vw,12rem) clamp(4rem,8vw,8rem)}.hero h1{font-size:var(--step-6);font-weight:300;font-variation-settings:"opsz" 144,"SOFT" 30;max-width:18ch}.hero h1 em{font-style:italic;font-weight:400;font-variation-settings:"opsz" 144,"SOFT" 100}.hero__lede{font-size:var(--step-2);font-weight:300;line-height:1.35;max-width:32ch;margin-top:2.5rem;color:var(--ink-soft)}.numbered{list-style:none;padding:0;counter-reset:item;display:grid;gap:0}.numbered>li{counter-increment:item;display:grid;grid-template-columns:4rem 1fr;gap:clamp(1rem,3vw,3rem);padding-block:clamp(1.5rem,3vw,2.5rem);border-top:1px solid var(--rule)}.numbered>li:last-child{border-bottom:1px solid var(--rule)}.numbered>li:before{content:counter(item,decimal-leading-zero);font-family:var(--font-body);font-size:.875rem;color:var(--mute);font-feature-settings:"tnum";padding-top:.5rem}.numbered h4{font-size:var(--step-2);margin-bottom:.75rem}.numbered p{color:var(--ink-soft);max-width:60ch}.split{display:grid;grid-template-columns:1fr;gap:clamp(2rem,5vw,5rem)}@media(min-width:768px){.split{grid-template-columns:1fr 2fr}}.split__label .eyebrow{margin-bottom:0}.project-list{list-style:none;padding:0}.project-list>li{border-top:1px solid var(--rule)}.project-list>li:last-child{border-bottom:1px solid var(--rule)}.project-list a{display:grid;grid-template-columns:1fr;gap:.5rem;padding-block:clamp(1.25rem,2.5vw,2rem);transition:padding-left .3s ease}.project-list a:hover{padding-left:1rem}@media(min-width:768px){.project-list a{grid-template-columns:minmax(0,2fr) 1fr 8rem;align-items:baseline;gap:2rem}}.project-list h3{font-size:var(--step-2);font-weight:400}.project-list .project-meta{font-size:var(--step--1);color:var(--mute)}.project-list .project-arrow{font-size:var(--step--1);color:var(--mute);text-align:right}.post-list{list-style:none;padding:0}.post-list>li{border-top:1px solid var(--rule)}.post-list>li:last-child{border-bottom:1px solid var(--rule)}.post-list a{display:block;padding-block:clamp(1.25rem,2.5vw,2rem);transition:padding-left .3s ease}.post-list a:hover{padding-left:1rem}.post-list h3{font-size:var(--step-2);font-weight:400;margin-bottom:.5rem}.post-list .post-meta{font-size:var(--step--1);color:var(--mute);font-feature-settings:"tnum"}.prose{max-width:68ch;font-size:var(--step-1);line-height:1.7}.prose h2{font-size:var(--step-3);margin-top:3rem;margin-bottom:1rem}.prose h3{font-size:var(--step-2);margin-top:2.5rem;margin-bottom:.75rem}.prose p{margin-bottom:1.25em;max-width:none}.prose p+p{margin-top:0}.prose ul,.prose ol{margin:1.25em 0;padding-left:1.5rem}.prose li{margin-bottom:.5em}.prose blockquote{border-left:2px solid var(--ink);padding-left:1.5rem;font-style:italic;color:var(--ink-soft);margin:2rem 0}.prose a{border-bottom:1px solid currentColor}.prose a:hover{opacity:.6}.contact-grid{display:grid;grid-template-columns:1fr;gap:0;margin-top:3rem}@media(min-width:768px){.contact-grid{grid-template-columns:repeat(2,1fr)}}.contact-grid>div{padding:2rem 0;border-top:1px solid var(--rule)}.contact-grid>div:last-child{border-bottom:1px solid var(--rule)}@media(min-width:768px){.contact-grid>div:nth-last-child(2){border-bottom:1px solid var(--rule)}.contact-grid>div:nth-child(odd){padding-right:2rem}.contact-grid>div:nth-child(2n){padding-left:2rem;border-left:1px solid var(--rule)}}.contact-grid .eyebrow{margin-bottom:.75rem}.contact-grid h4{font-size:var(--step-2);font-weight:400;margin-bottom:.5rem}.contact-grid p{color:var(--mute);font-size:var(--step--1)}.lede{font-size:var(--step-2);line-height:1.35;font-weight:300;max-width:32ch;color:var(--ink-soft)}.muted{color:var(--mute)}.italic{font-style:italic}.uppercase{text-transform:uppercase;letter-spacing:.16em;font-size:.75rem}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}.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}.visually-hidden:focus{position:static;width:auto;height:auto;clip:auto;padding:.5rem;background:var(--ink);color:var(--paper)}
