@import "https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Mono:wght@300;400;500&display=swap";
::selection{color:var(--text);background:#4af0c440}:root{--bg:#0e0e0e;--bg-card:#161616;--bg-hover:#1e1e1e;--text:#f0ece4;--text-muted:#b0aca4;--text-dim:#777770;--accent:#4af0c4;--accent-dim:#4af0c41f;--border:#2a2a2a;--font-display:"DM Serif Display", Georgia, serif;--font-body:"DM Mono", "Courier New", monospace}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.7}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.container{max-width:1100px;margin:0 auto;padding:0 2rem}.container--narrow{max-width:680px;margin:0 auto;padding:0 2rem}.nav{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:2rem 0;display:flex}.nav__logo{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text);font-size:1.25rem}.nav__logo span{color:var(--accent)}.nav__links{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);gap:2rem;font-size:12px;display:flex}.nav__links a:hover{color:var(--text)}.hero{padding:6rem 0 4rem}.hero__eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem;font-size:11px}.hero__title{font-family:var(--font-display);letter-spacing:-.03em;color:var(--text);max-width:14ch;margin-bottom:2rem;font-size:clamp(3rem,8vw,6rem);line-height:1}.hero__title em{color:var(--text-muted);font-style:italic}.hero__body{color:var(--text-muted);max-width:48ch;font-size:14px;line-height:1.8}.project-grid{background:var(--border);border:1px solid var(--border);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1px;margin:4rem 0;display:grid}.project-card{background:var(--bg);color:inherit;flex-direction:column;gap:1.25rem;padding:2rem;text-decoration:none;transition:background .15s;display:flex}.project-card:hover{background:var(--bg-hover)}.project-card__image{aspect-ratio:16/9;background:var(--bg-card);justify-content:center;align-items:center;display:flex;overflow:hidden}.project-card__image img{object-fit:contain;filter:grayscale(20%);width:100%;height:100%;transition:opacity .3s}.project-card:hover .project-card__image img{filter:grayscale(0%)}.project-card__meta{letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);font-size:11px}.project-card__title{font-family:var(--font-display);letter-spacing:-.02em;font-size:1.4rem;line-height:1.2}.project-card__excerpt{color:var(--text-muted);font-size:13px;line-height:1.7}.project-card__link{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-top:auto;font-size:11px}.project-header{border-bottom:1px solid var(--border);padding:5rem 0 3rem}.project-header__eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);gap:1.5rem;margin-bottom:1.5rem;font-size:11px;display:flex}.project-header__eyebrow a{color:var(--text-dim)}.project-header__eyebrow a:hover{color:var(--accent)}.project-header__title{font-family:var(--font-display);letter-spacing:-.03em;margin-bottom:1.5rem;font-size:clamp(2.5rem,6vw,4.5rem);line-height:1.05}.project-header__subtitle{color:var(--text-muted);max-width:52ch;font-size:15px;line-height:1.8}.project-image{background:var(--bg-card);border:1px solid var(--border);justify-content:center;align-items:center;width:100%;margin:3rem 0;padding:1.5rem;display:flex}.project-image img{object-fit:contain;width:100%;height:auto;display:block}.project-body{padding:2rem 0 6rem}.project-body p{color:var(--text-muted);max-width:62ch;margin-bottom:1.5rem;font-size:14px;line-height:1.9}.project-body p:first-child{color:var(--text);font-size:16px;line-height:1.8}.project-body h2{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text);margin:3rem 0 1rem;font-size:1.6rem}.coverage{border:1px solid var(--border);background:var(--bg-card);margin:3rem 0;padding:2rem}.coverage__label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:1rem;font-size:11px}.coverage__list{flex-wrap:wrap;gap:.75rem;list-style:none;display:flex}.coverage__list li span{color:var(--text-muted);border:1px solid var(--border);padding:.35rem .75rem;font-size:12px;display:inline-block}.about-section{padding:5rem 0}.about-section h1{font-family:var(--font-display);letter-spacing:-.03em;margin-bottom:2.5rem;font-size:clamp(2.5rem,5vw,4rem);line-height:1.05}.about-section p{color:var(--text-muted);max-width:58ch;margin-bottom:1.5rem;font-size:14px;line-height:1.9}.section-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:3rem 0 1.5rem;font-size:11px;display:flex}.section-label a{color:var(--accent);letter-spacing:.08em;font-size:11px}.blog-list{border-bottom:1px solid var(--border);margin-bottom:4rem;list-style:none}.blog-list__item{border-top:1px solid var(--border)}.blog-list__item a{color:inherit;grid-template-columns:1fr auto;align-items:baseline;gap:2rem;padding:1.25rem 0;transition:color .15s;display:grid}.blog-list__item a:hover .blog-list__title{color:var(--accent)}.blog-list__title{font-family:var(--font-display);letter-spacing:-.02em;font-size:1.2rem;line-height:1.3;transition:color .15s}.blog-list__meta{color:var(--text-dim);letter-spacing:.06em;white-space:nowrap;font-size:11px}.blog-header{border-bottom:1px solid var(--border);padding:5rem 0 3rem}.blog-header h1{font-family:var(--font-display);letter-spacing:-.03em;margin-bottom:1rem;font-size:clamp(2.5rem,5vw,4rem);line-height:1.05}.blog-header p{color:var(--text-muted);max-width:52ch;font-size:14px;line-height:1.8}.post-header{border-bottom:1px solid var(--border);padding:5rem 0 3rem}.post-header__eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);gap:1.5rem;margin-bottom:1.5rem;font-size:11px;display:flex}.post-header__eyebrow a{color:var(--text-dim)}.post-header__eyebrow a:hover{color:var(--accent)}.post-header h1{font-family:var(--font-display);letter-spacing:-.03em;margin-bottom:1.25rem;font-size:clamp(2rem,5vw,3.5rem);line-height:1.08}.post-header__subtitle{color:var(--text-muted);max-width:52ch;font-size:15px;line-height:1.8}.post-body{padding:3rem 0 6rem}.post-body p{color:var(--text-muted);max-width:62ch;margin-bottom:1.5rem;font-size:14px;line-height:1.9}.post-body p:first-child{color:var(--text);font-size:16px;line-height:1.8}.post-body h2{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text);margin:3rem 0 1rem;font-size:1.6rem}.post-body a{color:var(--accent);text-underline-offset:3px;text-decoration:underline}.footer{border-top:1px solid var(--border);color:var(--text-dim);justify-content:space-between;align-items:center;padding:2.5rem 0;font-size:12px;display:flex}.footer a{color:var(--text-dim)}.footer a:hover{color:var(--text-muted)}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:.5s forwards fadeUp}.fade-up--delay-1{opacity:0;animation-delay:.1s}.fade-up--delay-2{opacity:0;animation-delay:.2s}.fade-up--delay-3{opacity:0;animation-delay:.35s}@media (max-width:640px){.container,.container--narrow{padding:0 1.25rem}.nav__links{gap:1.25rem}.project-grid{grid-template-columns:1fr}.footer{text-align:center;flex-direction:column;gap:.5rem}}
