@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&family=Newsreader:opsz,wght,ital@6..72,300..700,0;6..72,300..700,1&family=Source+Serif+4:opsz,wght@8..60,400;8..60,500;8..60,600&display=swap";:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f5f5f3;--surface:#fbfbfa;--surface-soft:#f0f0ed;--text:#111;--muted:#565656;--accent:#e65b2e;--border:#d7d7d3;--shadow:none;--ring:none;--code-bg:#ece9e3;--code-text:#1f2428;--code-keyword:#9a3412;--code-string:#0f766e;--code-number:#7c3aed;--code-comment:#6b7280;--code-title:#1d4ed8;--code-built-in:#7c2d12;--font-body:"Source Serif 4", serif;--font-ui:"Manrope", sans-serif;--font-display:"Newsreader", serif;--shell-pad-inline:1rem}:root.darkmode{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#0f1011;--surface:#151617;--surface-soft:#1e2022;--text:#ededec;--muted:#a8a8a5;--accent:#ff6d3d;--border:#2d3033;--shadow:none;--ring:none;--code-bg:#161819;--code-text:#e8e6e1;--code-keyword:#f6ad55;--code-string:#7dd3c7;--code-number:#c4b5fd;--code-comment:#94a3b8;--code-title:#93c5fd;--code-built-in:#fdba74}*{box-sizing:border-box}html,body{min-height:100%;margin:0;padding:0;overflow-x:clip}html{scroll-behavior:smooth}#selected-work{scroll-margin-top:5.5rem}body{font-family:var(--font-body);background:linear-gradient(to right, color-mix(in srgb, var(--border) 28%, transparent) 1px, transparent 1px) 0 0 / 36px 36px, linear-gradient(to bottom, color-mix(in srgb, var(--border) 20%, transparent) 1px, transparent 1px) 0 0 / 36px 36px, var(--bg);color:var(--text);line-height:1.55}a{color:inherit;text-decoration:none}.site-shell{max-width:1240px;padding:1.2rem var(--shell-pad-inline) 0rem;margin:0 auto}.site-header{border-bottom:1px solid var(--border);z-index:30;background:var(--bg);justify-content:space-between;align-items:center;margin-bottom:clamp(1.45rem,2vw,2.25rem);padding:.8rem 0;display:flex;position:sticky;top:0}.site-footer{isolation:isolate;border-top:1px solid var(--border);font-family:var(--font-ui);color:var(--muted);margin-top:3rem;padding-top:1.2rem;padding-bottom:1.1rem;font-size:.92rem;position:relative}.site-footer:before{content:"";z-index:-1;top:-1px;bottom:0;left:calc(50% - 50dvw - var(--shell-pad-inline));right:calc(50% - 50dvw - var(--shell-pad-inline));background:color-mix(in srgb, var(--surface) 86%, var(--bg));border-top:1px solid var(--border);position:absolute}.site-footer>*{z-index:1;position:relative}.site-footer p{margin:0}.footer-brand{font-family:var(--font-display);color:var(--text);font-size:clamp(1.8rem,3vw,2rem);line-height:1}.footer-top{grid-template-columns:1.4fr 1fr 1fr;gap:2.2rem;padding:.8rem 0 2rem;display:grid}.footer-col{align-content:start;gap:.7rem;display:grid}.footer-col.footer-intro{align-content:space-between}.footer-intro p{max-width:24ch;font-size:1.05rem;line-height:1.45}.footer-label{letter-spacing:.03em;color:color-mix(in srgb, var(--muted) 88%, var(--text));font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:.78rem}.footer-links,.footer-colophon{gap:.62rem;display:grid}.footer-links a,.footer-colophon li{font-size:.85rem;line-height:1.35}.footer-colophon{margin:0;padding:0;list-style:none}.footer-bottom{border-top:1px solid var(--border);text-align:center;gap:.28rem;padding-top:1rem;font-size:.9rem;display:grid}.site-footer a:hover{color:var(--text)}.brand{font-family:var(--font-display);letter-spacing:.01em;font-size:1.55rem;line-height:1}.site-header nav{font-family:var(--font-ui);color:var(--muted);align-items:center;gap:1rem;font-size:.95rem;font-weight:600;display:flex}.site-header nav a:hover{color:var(--text)}.site-header nav .nav-current{color:var(--text);cursor:default;text-underline-offset:4px;text-decoration:underline;text-decoration-thickness:1px}.theme-toggle{font:inherit;border:1px solid var(--border);color:var(--text);background:var(--surface);cursor:pointer;border-radius:2px;justify-content:center;align-items:center;padding:.34rem;display:inline-flex}.theme-toggle svg{width:1.05rem;height:1.05rem}.hero{box-shadow:var(--shadow);border-radius:2px;margin-bottom:2.2rem;padding:1.25rem;position:relative;overflow:hidden}.hero-pro{margin-top:.2rem;padding:2rem clamp(1.15rem,2.2vw,1.9rem) 2rem 0;position:relative;overflow:hidden}.eyebrow{font-family:var(--font-ui);letter-spacing:.25em;color:var(--accent);text-transform:uppercase;margin:0 0 .9rem;font-size:.76rem;font-weight:400}.hero-tech{letter-spacing:.02em;color:color-mix(in srgb, var(--muted) 90%, var(--text));margin:-.15rem 0 .8rem;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:.78rem}.hero-title{max-width:18ch;font-family:var(--font-display);letter-spacing:-.012em;font-optical-sizing:auto;margin:0;font-size:clamp(2.75rem,3.5vw,6rem);font-weight:400;line-height:1.1}.hero-title em{color:color-mix(in srgb, var(--muted) 88%, var(--text));font-style:italic;font-weight:400}.hero-byline{font-family:var(--font-ui);letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:.85rem 0 0;font-size:.92rem}.hero-byline strong{color:var(--text)}.hero-copy{max-width:44ch;font-family:var(--font-ui);color:var(--muted);margin:.9rem 0 0;font-size:clamp(1.08rem,1.2vw,1rem);line-height:1.42}.cta-row{z-index:1;flex-wrap:wrap;gap:.65rem;margin-top:1.1rem;display:flex;position:relative}.cta-tight{margin-top:1.05rem}.btn{font-family:var(--font-ui);letter-spacing:.02em;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:2px;align-items:center;padding:.5rem .9rem;font-size:.86rem;font-weight:700;transition:transform .2s,border-color .2s;display:inline-flex}.btn:hover{border-color:var(--accent);transform:none}.btn.primary{background:color-mix(in srgb, var(--accent) 86%, var(--surface));border-color:color-mix(in srgb, var(--accent) 82%, var(--surface));color:#fff}.btn-arrow{width:1rem;height:1rem;margin-left:.36rem}.section-head{justify-content:space-between;align-items:baseline;gap:1rem;margin:.8rem 0 1rem;display:flex}.section-head-lined{align-items:baseline;gap:.75rem}.section-index{letter-spacing:.16em;color:var(--accent);margin:0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.7rem;font-weight:700;transform:translateY(1px)}.section-rule{background:var(--border);flex:1;align-self:flex-end;height:1px;margin-bottom:.56rem}.section-head-lined h1,.section-head-lined h2{font-size:clamp(1.9rem,3.4vw,2.7rem);line-height:1}.section-head h1,.section-head h2{margin:0;font-family:Newsreader,serif;line-height:1.1}.section-head h1{font-size:clamp(2rem,4.2vw,3.2rem)}.section-head h2{font-size:clamp(1.5rem,2.5vw,2.1rem)}.section-head a{color:var(--muted);font-size:.88rem;font-weight:700}.section-head a:hover{color:var(--accent)}.section-head-block{align-items:flex-start;margin-top:.5rem}.lede{max-width:56ch;color:var(--muted);margin:.85rem 0 0;font-size:1.03rem}.meta{font-family:var(--font-ui);color:var(--muted);margin-bottom:.85rem;font-size:.88rem}.more-link{margin:-.8rem 0 2rem;font-size:.9rem;font-weight:700}.more-link a{text-underline-offset:4px;text-decoration:underline;text-decoration-thickness:1px}.selected-grid{gap:1rem;margin-bottom:2rem;display:grid}.selected-top{grid-template-columns:2fr 1fr;align-items:start;gap:1rem;display:grid}.selected-bottom{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.selected-bottom .project-card{height:100%}.selected-bottom .project-content{min-height:220px}.selected-top .project-media{height:280px}.selected-bottom .project-media,.project-grid-dense .project-media{height:220px}.feature-layout-work{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.feature-layout-work .project-media{height:260px}.feature-stack{align-content:start;gap:1rem;display:grid}.project-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-bottom:2rem;display:grid}.project-grid-dense .project-card h3{font-size:1.25rem}.project-card{border:1px solid var(--border);background:var(--surface);box-shadow:var(--ring), var(--shadow);border-radius:2px;transition:border-color .2s;display:grid;overflow:hidden}.project-card:hover{border-color:color-mix(in srgb, var(--accent) 55%, var(--border));transform:none}.project-media{background:var(--surface-soft);display:block;position:relative}.media-frame{width:100%;height:100%;display:block;overflow:hidden}.project-media:after{content:"";pointer-events:none;background:linear-gradient(#0000,#0000005c);height:36%;position:absolute;inset:auto 0 0}.project-card img{object-fit:cover;transform-origin:50%;width:100%;height:100%;transition:transform .26s;display:block;transform:scale(1)}.project-card video{object-fit:cover;pointer-events:none;transform-origin:50%;width:100%;height:100%;transition:transform .26s;display:block;transform:scale(1)}.project-card:hover .project-media img,.project-card:hover .project-media video{transform:scale(1.018)}.year-pill{color:#f4f6fa;letter-spacing:.02em;z-index:2;background:#0a0c129e;border-radius:2px;padding:.26rem .56rem;font-size:.78rem;font-weight:700;position:absolute;bottom:.75rem;left:.75rem}.project-content{grid-template-rows:auto auto minmax(3.4em,auto) auto auto;gap:.52rem;padding:.95rem;display:grid}.project-content h3{-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:2.34em;margin:0;font-family:Newsreader,serif;font-size:clamp(1.22rem,2.1vw,1.65rem);line-height:1.17;display:-webkit-box;overflow:hidden}.project-content p{color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:3.1em;margin:0;display:-webkit-box;overflow:hidden}.pill-row{flex-wrap:wrap;align-content:start;align-items:center;gap:.42rem;display:flex}.stack{color:gray;margin-top:.5rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:.75rem}.project-grid .pill-row,.selected-bottom .pill-row{min-height:1.5rem}.project-content .cta-row{margin-top:auto}.pill{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.09em;background:color-mix(in srgb, var(--accent) 18%, var(--surface));min-height:1.35rem;color:color-mix(in srgb, var(--accent) 72%, var(--text));border-radius:2px;justify-content:center;align-items:center;padding:.2rem .48rem;font-size:.7rem;font-weight:700;line-height:1;display:inline-flex}.page-wrap{max-width:980px;margin:0 auto;padding-bottom:2rem}.work-wrap{max-width:none;padding-bottom:2rem}.project-page{max-width:62ch}.project-page p a{border-bottom:1px solid color-mix(in srgb, var(--text) 88%, var(--muted));padding-bottom:.1rem}.project-lead-media{margin:1.3rem 0 1.5rem}.project-lead-media img,.project-lead-media video{border:1px solid var(--border);background:var(--surface-soft);width:100%;height:auto;display:block}.project-lead-media figcaption{font-family:var(--font-ui);color:color-mix(in srgb, var(--muted) 88%, white);margin-top:.45rem;font-size:.78rem;line-height:1.5}.about-wrap{max-width:1100px;margin:0 auto;padding-bottom:2rem}.about-head{margin-top:clamp(1.6rem,4.8vw,2.8rem);margin-bottom:clamp(1rem,1.8vw,1.35rem)}.project-page>h1{max-width:20ch}.page-wrap h1,.page-wrap h2{font-family:Newsreader,serif;line-height:1.15}.page-wrap h1{margin:2rem 0 0;font-size:clamp(2rem,4vw,2.5rem)}.page-wrap h2{margin:1.55rem 0 .65rem;font-size:clamp(1.3rem,2.2vw,1.75rem)}.page-wrap p,.page-wrap li{color:color-mix(in srgb, var(--text) 88%, var(--muted));list-style-type:circle}.project-page p{margin-top:0;margin-bottom:1rem}.project-page>h2{margin-top:2rem}.project-page>p+h2,.project-page>ul+h2,.project-page>article+h2,.project-page>.cta-row+h2{margin-top:2.3rem}p.meta{color:#8b8b8b;font-size:.8rem}.link-list{padding-left:1.2rem}.link-list a{text-decoration:underline;-webkit-text-decoration-color:color-mix(in srgb, var(--accent) 65%, transparent);text-decoration-color:color-mix(in srgb, var(--accent) 65%, transparent);text-underline-offset:3px}.rich-content{grid-template-columns:minmax(0,1fr);margin-top:1rem;display:grid}.project-page .rich-content>p,.project-page .rich-content>ul,.project-page .rich-content>ol,.project-page .rich-content>blockquote,.project-page .rich-content>h2,.project-page .rich-content>h3,.project-page .rich-content>h4,.project-page .rich-content>pre,.project-page .rich-content>table{justify-self:start;width:100%;max-width:62ch;margin-left:0;margin-right:0}.project-page .rich-content>ol,.project-page .rich-content>ul{margin-bottom:1rem}.rich-content>*{margin:0}.project-page .rich-content h2,.project-page .rich-content h3,.project-page .rich-content h4{margin-top:3rem;font-family:Newsreader,serif;line-height:1.15}.project-page .rich-content h2{line-height:1.35}.rich-content h2{font-size:clamp(1.32rem,2.2vw,1.78rem)}.rich-content h3{font-size:clamp(1.14rem,1.9vw,1.4rem)}.rich-content p,.rich-content li{color:color-mix(in srgb, var(--text) 88%, var(--muted))}.rich-content ul,.rich-content ol{gap:.48rem;margin:0;padding-left:2rem;display:grid}.rich-content a{text-decoration:underline;-webkit-text-decoration-color:color-mix(in srgb, var(--accent) 65%, transparent);text-decoration-color:color-mix(in srgb, var(--accent) 65%, transparent);text-underline-offset:3px}.rich-content blockquote{border-left:2px solid var(--accent);background:color-mix(in srgb, var(--surface-soft) 72%, transparent);color:color-mix(in srgb, var(--text) 88%, var(--muted));margin:0;padding:.75rem .9rem}.rich-content pre{border:1px solid var(--border);background:var(--code-bg);color:var(--code-text);margin:.3rem 0;padding:.78rem .86rem;font-size:.84rem;line-height:1.45;overflow-x:auto}.rich-content code{background:color-mix(in srgb, var(--surface-soft) 90%, var(--surface));border:1px solid var(--border);border-radius:2px;padding:.05rem .28rem;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:.88em}.rich-content pre code{background:0 0;border:0;padding:0;display:block}.rich-content code.hljs{color:var(--code-text)}.rich-content .hljs-comment,.rich-content .hljs-quote{color:var(--code-comment);font-style:italic}.rich-content .hljs-keyword,.rich-content .hljs-selector-tag,.rich-content .hljs-literal,.rich-content .hljs-doctag,.rich-content .hljs-section,.rich-content .hljs-name,.rich-content .hljs-strong{color:var(--code-keyword)}.rich-content .hljs-string,.rich-content .hljs-attr,.rich-content .hljs-regexp,.rich-content .hljs-addition{color:var(--code-string)}.rich-content .hljs-number,.rich-content .hljs-symbol,.rich-content .hljs-bullet,.rich-content .hljs-meta,.rich-content .hljs-variable,.rich-content .hljs-template-variable,.rich-content .hljs-link{color:var(--code-number)}.rich-content .hljs-title,.rich-content .hljs-title.class_,.rich-content .hljs-title.function_,.rich-content .hljs-function .hljs-title,.rich-content .hljs-params,.rich-content .hljs-type{color:var(--code-title)}.rich-content .hljs-built_in,.rich-content .hljs-tag,.rich-content .hljs-selector-id,.rich-content .hljs-selector-class,.rich-content .hljs-attribute,.rich-content .hljs-deletion{color:var(--code-built-in)}.rich-content img,.rich-content video,.rich-content iframe,.rich-content .legacy-media,.rich-content .video-asset{max-width:100%}.rich-content img,.rich-content video,.rich-content iframe{border:1px solid var(--border);background:var(--surface-soft);width:100%;height:auto;display:block}.rich-content .ai2html img,.rich-content .ai2html video,.rich-content .ai2html iframe{background:0 0;border:0}.rich-content figure,.rich-content .legacy-media,.rich-content .video-asset{gap:.45rem;margin:.35rem 0;display:grid}.project-page .rich-content :where(figure,.legacy-media,.video-asset,.ai2html,p>img,p>video){max-width:100%;margin-bottom:1rem;margin-left:0;margin-right:0;transform:none}.project-page .rich-content :where(figure,.legacy-media,.video-asset,.ai2html,img,video,iframe).media-wide,.project-page .rich-content p.media-wide{justify-self:center;width:min(100vw - 2rem,980px);max-width:none;margin-bottom:2rem;margin-left:0;margin-right:0;position:static;left:auto;transform:none}.project-page .rich-content p.media-wide>:where(img,video,iframe){width:100%;max-width:100%;margin-left:0;margin-right:0;transform:none}.project-page .rich-content pre.media-wide{justify-self:center;width:min(100vw - 2rem,980px);max-width:none;margin-left:0;margin-right:0}.project-page .rich-content :where(figure,.legacy-media,.video-asset,.ai2html,img,video,iframe).media-column,.project-page .rich-content p.media-column>:where(img,video,iframe){width:100%;max-width:100%;margin-left:0;margin-right:0;position:static;left:auto;transform:none}.project-page .rich-content pre.media-column{justify-self:start;width:100%;max-width:62ch}.rich-content figcaption,p img+em,.rich-content .video-asset>em{font-family:var(--font-ui);color:var(--muted);margin:.5rem 0;font-size:.82rem;font-style:normal;line-height:1.55;display:block}.rich-content table{border-collapse:collapse;border:1px solid var(--border);width:100%;font-size:.92rem}.rich-content th,.rich-content td{border:1px solid var(--border);text-align:left;padding:.46rem .55rem}.darkmode .rich-content .ai2html{background:#fff;border-color:#0000}.minimal-wrap{max-width:860px;margin:0 auto;padding-bottom:2rem}.about-grid{grid-template-columns:minmax(0,1.45fr) minmax(0,1fr);align-items:start;gap:clamp(1.4rem,2.5vw,2.3rem);margin-top:1rem;display:grid}.about-grid article,.about-aside{background:0 0;border:0;padding:0}.about-grid article{width:min(100%,66ch);padding-right:.25rem}.about-grid p{color:color-mix(in srgb, var(--text) 88%, var(--muted));margin:0 0 .9rem}.about-grid p:last-child{margin-bottom:0}.about-aside{border-left:1px solid color-mix(in srgb, var(--border) 90%, transparent);gap:.25rem;padding-left:clamp(.9rem,2vw,1.35rem);display:grid}.about-aside h2{margin:0 0 .35rem;font-family:Newsreader,serif;font-size:1.2rem}.about-aside h2+p,.about-aside h2+ul{margin-top:0}.about-aside h2:not(:first-child){margin-top:1rem}.about-aside ul{color:color-mix(in srgb, var(--text) 88%, var(--muted));margin:0 0 1.1rem;padding-left:1.1rem}.about-aside a{text-underline-offset:3px;text-decoration:underline}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.minimal-header h1{margin:.25rem 0 .5rem;font-family:Newsreader,serif;font-size:clamp(2rem,4vw,2.8rem)}.minimal-header p{color:var(--muted);max-width:64ch;margin:0}.minimal-list{border-top:1px solid var(--border);margin:1.5rem 0 0;padding:0;list-style:none}.minimal-list li{border-bottom:1px solid var(--border)}.minimal-list a{justify-content:space-between;align-items:baseline;gap:1rem;padding:.86rem .1rem;transition:color .2s;display:flex}.minimal-list a:hover{color:var(--accent)}.minimal-list span{font-family:Newsreader,serif;font-size:1.2rem;line-height:1.2}.minimal-list small{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);white-space:nowrap;font-size:.78rem}@media (width<=980px){.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.feature-layout-work,.selected-top,.selected-bottom{grid-template-columns:1fr}.project-card-default img,.project-card-default video{height:100%}.selected-top .project-media,.selected-bottom .project-media,.feature-layout-work .project-media,.project-grid-dense .project-media{height:240px}}@media (width<=680px){:root{--shell-pad-inline:.78rem}.site-shell{padding:.8rem var(--shell-pad-inline) 0rem}.site-footer{margin-top:2rem}.site-header{margin-bottom:1.2rem}.footer-top{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.35rem 0;padding-bottom:.5rem}.footer-intro{grid-column:1/-1;gap:0}.footer-links,.footer-colophon{gap:.45rem}.footer-links a,.footer-colophon li{font-size:.96rem}.about-grid{grid-template-columns:1fr;gap:1rem}.about-head{margin-top:2rem}.about-grid article{padding-right:0}.about-aside{border-left:0;border-top:1px solid color-mix(in srgb, var(--border) 85%, transparent);padding-top:.95rem;padding-left:0}.brand{font-size:1.36rem}.project-grid{grid-template-columns:1fr}.selected-top .project-media,.selected-bottom .project-media,.feature-layout-work .project-media,.project-grid-dense .project-media,.project-card img,.project-card video{height:220px}.section-head,.section-head-lined{align-items:baseline}.section-head-lined{gap:.55rem}.section-head-lined h1,.section-head-lined h2{font-size:clamp(1.6rem,8vw,2rem)}.section-index{transform:translateY(.5px)}.section-rule{margin-bottom:.21rem}.minimal-list a{flex-direction:column;align-items:flex-start;gap:.35rem}}.bigger-title{color:#646464;font-size:clamp(2rem,5vw,3.5rem);display:block}
