@font-face{font-family:space grotesk;font-style:normal;font-weight:400 500;font-display:swap;src:url(/fonts/space-grotesk-latin.woff2)format("woff2")}@font-face{font-family:space mono;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/space-mono-regular-latin.woff2)format("woff2")}@font-face{font-family:space mono;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/space-mono-bold-latin.woff2)format("woff2")}:root{color-scheme:dark;--bg:oklch(21% 0.01 250);--bg-soft:oklch(24% 0.012 250);--surface:oklch(28% 0.014 250);--surface-strong:oklch(31% 0.016 250);--text:oklch(92% 0.016 250);--muted:oklch(72% 0.036 255);--muted-dim:oklch(56% 0.032 255);--line:oklch(40% 0.02 250);--accent-cyan:oklch(76% 0.16 205);--focus:oklch(74% 0.18 205);--max-page:112rem;--max-prose:48rem;--space-1:0.35rem;--space-2:0.7rem;--space-3:1rem;--space-4:1.55rem;--space-5:2.4rem;--space-6:4rem;--ease-out:cubic-bezier(0.16, 1, 0.3, 1);--mono:"Space Mono", ui-monospace, "SFMono-Regular", "Cascadia Mono", "Liberation Mono", Menlo, Consolas, monospace;--sans:"Space Grotesk", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}@view-transition{navigation: auto;
}*{box-sizing:border-box}html{min-height:100%;background:var(--bg);color:var(--text);font-family:var(--sans);letter-spacing:0;scrollbar-gutter:stable}body{min-height:100vh;margin:0;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none;text-underline-offset:.18em}a:hover{color:var(--text)}a:focus-visible,button:focus-visible{outline:2px solid var(--focus);outline-offset:5px}img{display:block;max-width:100%}.skip-link{position:fixed;left:var(--space-3);top:var(--space-3);z-index:20;transform:translateY(-160%);border:1px solid var(--line);background:var(--surface);padding:var(--space-2)var(--space-3);color:var(--text);font:.95rem/1 var(--mono);transition:transform 160ms var(--ease-out)}.skip-link:focus{transform:translateY(0)}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.page-frame{min-height:100vh}.page-content-transition{min-height:100vh;view-transition-name:page-content}.home-main,.page-main{width:min(var(--max-page),calc(100% - clamp(2rem,7vw,8rem)));margin-inline:auto}.home-main{min-height:100vh;padding-block:clamp(2rem,5vh,4rem);overflow:clip}.home-hero{position:relative;display:grid;place-items:center;min-height:calc(100vh - clamp(4rem,10vh,8rem));padding-block:clamp(2rem,6vh,5rem)}.home-copy{position:relative;z-index:1;width:min(100%,54rem);margin-inline:auto}.home-title-row{margin-bottom:var(--space-4)}.home-title-row h1{font-size:clamp(2.65rem,6vw,5.65rem);font-weight:520;line-height:.94;overflow-wrap:normal;word-break:normal}.home-title-row h1 span{display:block;overflow-wrap:normal;word-break:keep-all}h1,h2,h3,.nav__link,.home-index__link,.site-brand,.post-list time,.project-card__title,.contact-list a{font-family:var(--mono)}h1,h2,h3,p{overflow-wrap:anywhere}h1{margin:0;color:var(--text);font-size:clamp(2.55rem,5vw,4.2rem);font-weight:500;line-height:1.05}.home-intro{max-width:44rem;margin:0 0 clamp(2rem,5vw,4.5rem);color:var(--muted);font-size:clamp(1rem,1.8vw,1.25rem);line-height:1.7}.home-index__list{display:grid;grid-template-columns:repeat(2,minmax(8rem,max-content));gap:var(--space-3)clamp(1.4rem,4vw,3rem);max-width:32rem;margin:0;padding:0;list-style:none}.home-index__link{display:inline-flex;align-items:center;min-height:2rem;color:var(--text);font-size:clamp(1rem,1.7vw,1.2rem);line-height:1.1;transition:color 180ms var(--ease-out),transform 180ms var(--ease-out)}.home-index__link:hover,.home-index__link:focus-visible{color:var(--accent-cyan);transform:translateX(.35rem)}.nav__list{display:flex;flex-wrap:wrap;align-items:center;gap:clamp(1.1rem,3vw,2.2rem);margin:0;padding:0;list-style:none}.nav__link{display:inline-flex;min-height:2rem;align-items:center;color:var(--text);font-size:clamp(1.05rem,2vw,1.35rem);font-weight:500;line-height:1.2;text-decoration:none;transition:color 160ms var(--ease-out),transform 160ms var(--ease-out)}.nav__link:hover,.nav__link[aria-current=page]{color:var(--accent-cyan);transform:translateY(-1px)}.site-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);width:min(var(--max-page),calc(100% - clamp(2rem,7vw,8rem)));margin-inline:auto;padding-block:clamp(1.4rem,3vw,2rem)}.site-brand{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--text);font-size:clamp(1rem,1.6vw,1.2rem);line-height:1;white-space:nowrap}.site-brand img{width:3.25rem;height:3.25rem;image-rendering:pixelated;object-fit:contain}.site-nav .nav__list{justify-content:flex-end;gap:clamp(1.2rem,3vw,2.5rem)}.site-nav .nav__link{font-size:clamp(1rem,1.6vw,1.2rem)}.page-main{min-height:calc(100vh - 5rem);padding-block:clamp(2.4rem,7vh,5rem)clamp(4rem,10vh,7rem)}.page-main--centered,.prose{width:min(var(--max-prose),calc(100% - clamp(2rem,7vw,8rem)))}.page--post{--max-prose:56rem}.page-header{max-width:var(--max-prose);margin-bottom:var(--space-5)}.eyebrow{margin:0 0 var(--space-2);color:var(--muted-dim);font:.95rem/1.3 var(--mono);text-transform:lowercase}.page-title-count{color:var(--muted-dim)}.page-header h1{font-size:clamp(2.4rem,4.8vw,4.3rem);line-height:1.05}.page--blog .page-header h1{display:inline-flex;align-items:flex-end;gap:var(--space-3)}.content{max-width:var(--max-prose);color:var(--muted);font-size:clamp(1.08rem,1.15vw,1.18rem);line-height:1.78}.content p,.content ul,.content ol{margin:0 0 var(--space-4)}.content h2{margin:var(--space-6)0 var(--space-3);color:var(--text);font-size:clamp(1.6rem,3vw,2rem);font-weight:500;line-height:1.2;text-transform:lowercase}.content ul,.content ol{padding-left:2rem}.content ul{list-style:disc}.content ol{list-style:decimal}.content li{margin:0;padding-left:.15rem}.content li+li{margin-top:var(--space-1)}.content li::marker{color:var(--muted-dim)}.content li:has(>input[type=checkbox]){list-style:none}.content input[type=checkbox]{width:1em;height:1em;margin:0 .55rem 0 0;accent-color:var(--accent-cyan);vertical-align:-.12em}.content h3{margin:var(--space-5)0 var(--space-2);color:var(--text);font-size:clamp(1.22rem,2.2vw,1.45rem);font-weight:500;line-height:1.25;text-transform:lowercase}.content strong{color:var(--text);font-weight:700}.content em{color:var(--text)}.post-figure{display:block;max-width:min(100%,28rem);margin:var(--space-5)auto}.content img{display:block;max-width:100%;height:auto;margin:0 auto}.post-figure__caption{display:block;margin-top:var(--space-2);color:var(--muted-dim);font:.92rem/1.5 var(--mono);text-align:center}.content blockquote{margin:0 0 var(--space-4);padding-left:var(--space-3);border-left:1px solid var(--line);color:var(--muted)}.content blockquote p:last-child{margin-bottom:0}.content code{color:var(--text);font-family:var(--mono);font-size:.92em}.content :not(pre)>code{padding:.08rem .28rem;background:var(--surface)}.content pre{overflow-x:auto;margin:0 0 var(--space-4);padding:var(--space-3);background:var(--surface)}.content pre code{padding:0;background:0 0;font-size:.95rem;line-height:1.65}.content table{width:100%;margin:0 0 var(--space-4);border-collapse:collapse;font-family:var(--mono);font-size:.96rem}.content th,.content td{padding:.55rem .7rem;border:1px solid var(--line);text-align:left;vertical-align:top}.content th{color:var(--text);font-weight:700}.content hr{height:1px;margin:var(--space-5)0;border:0;background:var(--line)}.page--about .content ul{display:grid;gap:var(--space-1);padding:0;list-style:none}.page--about .content li{margin:0;padding-left:0;font-family:var(--mono)}.page--about .content li+li{margin-top:0}.icon-link{display:flex;align-items:baseline;gap:.55rem;margin:0 0 var(--space-4);color:var(--text);font-family:var(--mono)}.icon-link__icon{display:inline-flex;width:1.12em;height:1.12em;align-items:center;color:var(--muted);transform:translateY(.15em)}.icon-link__icon svg{display:block;width:100%;height:100%}.icon-link a{color:var(--text)}.icon-link a::after{content:"↗";color:var(--muted);font-size:.85em}.content a,.text-link{color:var(--text);font-family:var(--mono)}.content a::after,.text-link::after{content:" ↗";color:var(--muted);font-size:.85em}.page--about .content a{display:inline-flex;align-items:baseline;gap:.4rem;vertical-align:baseline}.page--about .content a::after{content:" ↗";color:var(--muted);font-size:.85em}.theme-palette{display:flex;flex-wrap:wrap;align-items:stretch;margin:var(--space-3)0 var(--space-4);font-family:var(--mono);font-size:.92rem;line-height:1}.theme-palette__swatch{display:inline-flex;min-width:4rem;min-height:1.35rem;align-items:center;justify-content:center;padding-inline:.7rem;color:var(--text)}.theme-palette__swatch--bg{background:var(--bg)}.theme-palette__swatch--bg-soft{background:var(--bg-soft)}.theme-palette__swatch--surface{background:var(--surface)}.theme-palette__swatch--muted-dim{background:var(--muted-dim);color:var(--bg)}.theme-palette__swatch--muted{background:var(--muted);color:var(--bg)}.theme-palette__swatch--text{background:var(--text);color:var(--bg)}.theme-palette__swatch--text-strong{background:oklch(96% .01 250);color:var(--bg)}.theme-palette__swatch--blue{background:var(--accent-cyan);color:var(--bg)}.project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(2rem,3vw,3rem);max-width:var(--max-page)}.project-card{min-width:0}.project-card__preview{display:grid;aspect-ratio:16/9;place-items:center;overflow:hidden;background:linear-gradient(135deg,var(--surface),var(--bg-soft));color:var(--muted-dim)}.project-card__preview img{width:100%;height:100%;object-fit:cover}.project-card__body{padding-block:var(--space-3)var(--space-5)}.project-card__title{margin:0 0 var(--space-2);color:var(--text);font-size:clamp(1.25rem,2vw,1.55rem);font-weight:500;line-height:1.25;text-transform:lowercase}.project-card__title a::after{content:" ->";color:var(--muted)}.project-card p,.empty-state{margin:0;color:var(--muted-dim);font-size:clamp(1.02rem,1.05vw,1.1rem);line-height:1.65}.post-list,.contact-list{display:grid;gap:var(--space-5);max-width:var(--max-prose);margin:0;padding:0;list-style:none}.post-list__item{display:grid;grid-template-columns:7.5rem minmax(0,1fr);gap:var(--space-4);align-items:start}.post-list time{color:var(--muted);font-size:clamp(1.02rem,1.05vw,1.12rem);line-height:1.35;white-space:nowrap}.post-meta{display:inline-block;color:var(--muted);font:clamp(1rem,1.05vw,1.1rem)/1.35 var(--mono)}.post-meta-row{display:flex;flex-wrap:wrap;align-items:baseline;gap:var(--space-2)var(--space-3);margin-top:var(--space-3)}.post-list__body{min-width:0}.post-list__title{display:inline-flex;align-items:baseline;color:var(--text);font:500 clamp(1.24rem,2vw,1.55rem)/1.35 var(--mono)}.post-list__description{margin:var(--space-1)0 0;color:var(--muted-dim);font-size:clamp(1.02rem,1.05vw,1.1rem);line-height:1.65}.tag-list{display:inline-flex;flex-wrap:wrap;gap:.35rem .7rem;margin:0;padding:0;list-style:none}.post-list .tag-list{display:flex;margin-top:var(--space-2)}.tag-link{color:var(--muted-dim);font:.95rem/1.35 var(--mono);transition:color 160ms var(--ease-out)}.tag-link:hover,.tag-link:focus-visible{color:var(--accent-cyan)}.taxonomy-list{display:grid;gap:var(--space-2);max-width:var(--max-prose);margin:0;padding:0;list-style:none}.taxonomy-list li{display:flex;align-items:baseline;gap:var(--space-2);font-family:var(--mono)}.taxonomy-list a{color:var(--text);font-size:clamp(1.15rem,1.8vw,1.35rem)}.taxonomy-list a:hover,.taxonomy-list a:focus-visible{color:var(--accent-cyan)}.taxonomy-list span{color:var(--muted-dim)}.feed-link{color:var(--muted);font:.95rem/1.2 var(--mono)}.feed-link--heading{display:inline-flex;align-items:center;gap:.2rem;padding-bottom:.18em;font-size:clamp(1.05rem,1.5vw,1.22rem);line-height:1}.feed-link--heading::after{content:"↗";color:var(--muted-dim);font-size:.86em}.contact-list{gap:var(--space-3)}.contact-list li{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem;color:var(--muted);font-size:clamp(1.04rem,1.1vw,1.16rem)}.contact-list__icon{display:inline-flex;width:1.15em;height:1.15em;align-items:center;color:var(--muted);transform:translateY(.15em)}.contact-list__icon svg{display:block;width:100%;height:100%}.contact-list__label,.contact-list__arrow{color:var(--muted-dim);font-family:var(--mono)}.contact-list a{color:var(--text);font-size:clamp(1.16rem,1.45vw,1.3rem)}.contact-list a::before{content:""}.contact-list a::after{content:" ↗";color:var(--muted);font-size:.85em}::view-transition{background:var(--bg)}::view-transition-old(root),::view-transition-new(root){animation:none;background:var(--bg);mix-blend-mode:normal}::view-transition-group(page-content){animation:none;overflow:clip}::view-transition-old(page-content),::view-transition-new(page-content){animation-fill-mode:both;animation-timing-function:var(--ease-out);background:var(--bg);mix-blend-mode:normal}::view-transition-old(page-content){animation-duration:170ms;animation-name:page-fade-out}::view-transition-new(page-content){animation-delay:80ms;animation-duration:220ms;animation-name:page-fade-in}html:active-view-transition-type(forwards)::view-transition-old(page-content){animation-name:slide-out-left}html:active-view-transition-type(forwards)::view-transition-new(page-content){animation-name:slide-in-right}html:active-view-transition-type(backwards)::view-transition-old(page-content){animation-name:slide-out-right}html:active-view-transition-type(backwards)::view-transition-new(page-content){animation-name:slide-in-left}html:active-view-transition-type(deeper)::view-transition-old(page-content){animation-name:slide-out-up}html:active-view-transition-type(deeper)::view-transition-new(page-content){animation-name:slide-in-down}html:active-view-transition-type(shallower)::view-transition-old(page-content){animation-name:slide-out-down}html:active-view-transition-type(shallower)::view-transition-new(page-content){animation-name:slide-in-up}@keyframes page-fade-out{to{opacity:0}}@keyframes page-fade-in{from{opacity:0}}@keyframes slide-out-left{to{opacity:0;transform:translate3d(-22vh,0,0)}}@keyframes slide-in-right{from{opacity:0;transform:translate3d(22vh,0,0)}}@keyframes slide-out-right{to{opacity:0;transform:translate3d(22vh,0,0)}}@keyframes slide-in-left{from{opacity:0;transform:translate3d(-22vh,0,0)}}@keyframes slide-out-up{to{opacity:0;transform:translate3d(0,-18vh,0)}}@keyframes slide-in-down{from{opacity:0;transform:translate3d(0,18vh,0)}}@keyframes slide-out-down{to{opacity:0;transform:translate3d(0,18vh,0)}}@keyframes slide-in-up{from{opacity:0;transform:translate3d(0,-18vh,0)}}@media(max-width:960px){.home-hero{align-content:center}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:680px){.home-main,.page-main,.page-main--centered,.prose,.site-header{width:min(100% - 1.5rem,var(--max-page))}.home-main{padding-block:1rem 3rem}.home-hero{min-height:auto;padding-block:clamp(2rem,8vh,4rem)}.home-title-row{grid-template-columns:1fr;gap:var(--space-3)}.home-title-row h1{font-size:min(clamp(2.1rem,10vw,4.6rem),calc((100vw - 1.5rem)/9.9))}.home-index__list{grid-template-columns:1fr}.site-header{align-items:flex-start;flex-direction:column}.site-nav .nav__list{justify-content:flex-start}.project-grid{grid-template-columns:1fr}.post-list__item{grid-template-columns:1fr;gap:var(--space-2)}}@media(max-width:420px){.home-index__link{min-height:3.15rem}.nav__list{gap:var(--space-2)var(--space-4)}}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:1ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:1ms!important}::view-transition-old(root),::view-transition-new(root),::view-transition-old(page-content),::view-transition-new(page-content){animation:none}}