:root{--bg:#f4efe6;--ink:#1f1b16;--accent:#c97a55;--accent-ink:#fff;--bg-elev:color-mix(in oklab, var(--bg) 92%, var(--ink));--rule:color-mix(in oklab, var(--ink) 14%, transparent);--rule-soft:color-mix(in oklab, var(--ink) 7%,  transparent);--ink-2:color-mix(in oklab, var(--ink) 65%, var(--bg));--ink-3:color-mix(in oklab, var(--ink) 40%, var(--bg));--font-mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--font-sans:"DM Sans", ui-sans-serif, system-ui, -apple-system, sans-serif;--pad-y:96px;--pad-x:clamp(24px, 6vw, 88px);--gap:56px;--gap-s:24px;--gap-xs:12px;--base:16px;--h1:56px;--h2:28px;--h3:20px;--label:12px;color-scheme:light}[data-site=personal]{--bg:#f3f4f1;--ink:#14171b;--accent:#3a8c84}@media(prefers-color-scheme:dark){:root{--bg:#14110d;--ink:#f4efe6;color-scheme:dark}[data-site=personal]{--bg:#111314;--ink:#f3f4f1}}*,*::before,*::after{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-size:var(--base);line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"ss01","kern";min-height:100svh;background-image:radial-gradient(color-mix(in oklab,var(--ink) 2%,transparent) 1px,transparent 1px),radial-gradient(color-mix(in oklab,var(--bg) 2%,transparent) 1px,transparent 1px);background-size:3px 3px,7px 7px;background-position:0 0,1px 2px;background-attachment:fixed}a{color:inherit;text-decoration:none;border-bottom:1px solid var(--rule);transition:border-color .15s,color .15s}a:hover{border-color:var(--accent);color:var(--accent)}p{margin:0 0 1em;max-width:60ch;text-wrap:pretty}p:last-child{margin-bottom:0}h1,h2,h3,h4{font-family:var(--font-mono);font-weight:500;letter-spacing:-.01em;margin:0;text-wrap:balance}ul,ol{margin:0;padding:0}.mono{font-family:var(--font-mono)}.label{font-family:var(--font-mono);font-size:var(--label);letter-spacing:.04em;text-transform:lowercase;color:var(--ink-3)}.container{width:100%;max-width:1180px;margin:0 auto;padding:0 var(--pad-x)}.container-tight{max-width:760px}.hr{height:1px;background:var(--rule);border:0;margin:0}.hr-soft{height:1px;background:var(--rule-soft);border:0;margin:0}.dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);vertical-align:middle;margin-right:8px}.chip{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;padding:6px 12px;border:1px solid var(--rule);border-radius:999px;color:var(--ink-2);background:0 0;transition:border-color .15s,color .15s;text-decoration:none}.chip:hover{border-color:var(--accent);color:var(--accent)}.tag{display:inline-block;font-family:var(--font-mono);font-size:11px;letter-spacing:.03em;color:var(--ink-2);background:var(--rule-soft);padding:3px 8px;border-radius:4px;border-bottom:0}.tag:hover{border-bottom:0;color:var(--accent);background:var(--rule-soft)}.arrow::after{content:" →";display:inline-block;transition:transform .15s}.arrow:hover::after{transform:translateX(2px)}.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:13px;padding:10px 16px;border-radius:6px;border:1px solid var(--ink);background:var(--ink);color:var(--bg);cursor:pointer;border-bottom-width:1px;transition:background .15s,border-color .15s,color .15s}.btn:hover{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.btn-ghost{background:0 0;color:var(--ink);border-color:var(--rule)}.btn-ghost:hover{background:0 0;border-color:var(--accent);color:var(--accent)}.placeholder{position:relative;background:repeating-linear-gradient( 135deg,var(--rule-soft) 0 1px,transparent 1px 14px ),var(--bg-elev);border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;color:var(--ink-3);font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;text-transform:lowercase;overflow:hidden}.placeholder span{background:var(--bg);padding:4px 10px;border-radius:999px;border:1px solid var(--rule)}html{scroll-behavior:smooth}.site-nav{position:sticky;top:0;z-index:10;background:color-mix(in oklab,var(--bg) 88%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--rule-soft)}.site-nav-inner{display:flex;align-items:center;justify-content:space-between;padding-top:18px;padding-bottom:18px}.site-nav-brand{font-family:var(--font-mono);font-size:14px;letter-spacing:-.01em;border-bottom:0;color:var(--ink)}.site-nav-brand:hover{color:var(--accent);border-bottom:0}.site-nav-links{list-style:none;display:flex;gap:24px}.site-nav-links a{font-family:var(--font-mono);font-size:13px;border-bottom:0;color:var(--ink-2)}.site-nav-links a:hover{color:var(--accent)}.site-footer{margin-top:auto;border-top:1px solid var(--rule-soft);padding:32px 0}.site-footer-inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}.site-footer-meta{display:flex;gap:12px;flex-wrap:wrap}.section-label{display:flex;align-items:baseline;gap:14px;font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;color:var(--ink-3);margin-bottom:18px}.section-label-num{border:1px solid var(--rule);border-radius:4px;padding:2px 8px;font-variant-numeric:tabular-nums;color:var(--ink-2)}.section-label-text.accent{color:var(--accent)}.photostrip{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}@media(max-width:880px){.photostrip{grid-template-columns:repeat(2,1fr)}}.photostrip-fig{margin:0}.photostrip-frame{position:relative;width:100%;height:0;overflow:hidden}.photostrip-frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}.photostrip-cap{display:flex;justify-content:space-between;align-items:baseline;margin-top:10px;font-size:12px;color:var(--ink-2)}.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;background:radial-gradient( circle at 30% 25%,color-mix(in oklab,var(--accent) 35%,var(--bg-elev)) 0%,var(--bg-elev) 70% );border:1px solid var(--rule);font-family:var(--font-mono);font-weight:500;color:var(--ink);letter-spacing:.02em}.fam-hero{padding:var(--pad-y)0 calc(var(--pad-y) * .6)}.fam-hero-row{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:end}@media(max-width:880px){.fam-hero-row{grid-template-columns:1fr;gap:32px}}.fam-hero-title{font-size:var(--h1);line-height:1;letter-spacing:-.025em;margin-top:18px;margin-bottom:28px}.fam-hero-amp{color:var(--accent);font-style:italic;font-family:dm serif display,serif;font-weight:400;font-size:1.15em;padding-right:12px}.fam-hero-sub{font-size:calc(var(--base) + 2px);color:var(--ink-2);max-width:50ch;margin-bottom:28px}.fam-hero-meta{display:flex;gap:20px;flex-wrap:wrap}.fam-hero-photo{width:100%;aspect-ratio:4/3}.fam-hero-photo img{width:100%;height:100%;object-fit:cover;border-radius:4px;display:block}.fam-section{padding:var(--pad-y)0}.fam-section-alt{background:var(--bg-elev)}.fam-section-head{margin-bottom:var(--gap);max-width:60ch}.fam-section-intro{font-size:calc(var(--base) + 1px);color:var(--ink-2);margin:0}.fam-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}@media(max-width:980px){.fam-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.fam-grid{grid-template-columns:1fr}}.fam-card{display:flex;flex-direction:column;background:var(--bg-elev);border:1px solid var(--rule);border-radius:4px;overflow:hidden;transition:border-color .2s,transform .2s}.fam-card:hover{border-color:var(--accent);transform:translateY(-2px)}.fam-card-portrait{aspect-ratio:4/3;border-bottom:1px solid var(--rule)}.fam-card-portrait img{width:100%;height:100%;object-fit:cover;display:block}.fam-card-initials{font-size:56px;font-weight:500;color:var(--ink-2)}.fam-card-body{padding:22px 24px 24px;display:flex;flex-direction:column;gap:10px;flex:1}.fam-card-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;flex-wrap:wrap}.fam-card-name{font-size:var(--h3)}.fam-card-bio{font-size:calc(var(--base) - 1px);color:var(--ink-2);flex:1}.fam-card-link{font-family:var(--font-mono);font-size:13px;border-bottom:0;color:var(--accent);margin-top:auto}.fam-card-link:hover{border-bottom:0;color:var(--accent)}.fam-card-link.is-disabled{color:var(--ink-3)}.fam-card.is-pet .fam-card-portrait{background:color-mix(in oklab,var(--accent) 8%,var(--bg-elev))}.fam-outbox{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;border-top:1px solid var(--rule);padding-top:28px}@media(max-width:880px){.fam-outbox{grid-template-columns:1fr}}.fam-outbox-label{margin-bottom:14px}.fam-outbox-list{list-style:none;display:flex;flex-direction:column;gap:10px}.fam-outbox-link{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:10px 0;border-bottom:1px solid var(--rule-soft);border-top:0;border-left:0;border-right:0}.fam-outbox-link:hover{border-bottom-color:var(--accent)}.fam-outbox-name{font-size:calc(var(--base) - 1px)}.fam-outbox-url{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-3)}.fam-outbox-link:hover .fam-outbox-url{color:var(--accent)}.fam-news{margin-top:var(--gap);padding:28px 32px;background:var(--bg);border:1px solid var(--rule);border-radius:4px}.fam-news-label{margin-bottom:16px}.fam-news-list{list-style:none}.fam-news-item{display:grid;grid-template-columns:140px 1fr;gap:24px;padding:14px 0;border-top:1px dashed var(--rule)}.fam-news-item:first-child{border-top:0;padding-top:0}.fam-news-text{color:var(--ink-2)}@media(max-width:600px){.fam-news-item{grid-template-columns:1fr;gap:4px}}.fam-links{list-style:none;border-top:1px solid var(--rule)}.fam-links-row{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:20px 0;border-bottom:1px solid var(--rule);flex-wrap:wrap}.fam-links-identity{display:flex;align-items:baseline;gap:16px}.fam-links-name{font-family:var(--font-mono);font-size:var(--h3);font-weight:500}.fam-links-right{display:flex;align-items:center;gap:24px}.fam-links-what{white-space:nowrap}.fam-links-url{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--accent);border-bottom-color:color-mix(in oklab,var(--accent) 40%,transparent);white-space:nowrap}.fam-links-url:hover{color:var(--accent)}@media(max-width:600px){.fam-links-row{flex-direction:column;align-items:flex-start;gap:10px}}.fam-contact{display:grid;grid-template-columns:repeat(3,1fr);gap:36px}@media(max-width:880px){.fam-contact{grid-template-columns:1fr;gap:28px}}.fam-contact-block{display:flex;flex-direction:column;gap:12px}.fam-contact-body{font-size:calc(var(--base) - 1px);color:var(--ink-2);line-height:1.7}.dev-hero{padding:var(--pad-y)0 calc(var(--pad-y) * .7)}.dev-hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:start}@media(max-width:880px){.dev-hero-grid{grid-template-columns:1fr;gap:40px}}.dev-hero-title{font-size:var(--h1);line-height:1.05;letter-spacing:-.03em;margin-top:18px;margin-bottom:24px}.dev-hero-title-2{color:var(--accent);font-weight:400}.dev-hero-lede{font-size:calc(var(--base) + 2px);color:var(--ink-2);max-width:60ch;margin-bottom:18px}.dev-hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}.dev-card{background:var(--bg-elev);border:1px solid var(--rule);border-radius:6px;padding:20px;display:flex;flex-direction:column;gap:18px}.dev-card-portrait{aspect-ratio:1;border-radius:4px;overflow:hidden}.dev-card-portrait img{width:100%;height:100%;object-fit:cover;display:block}.dev-meta{margin:0;display:grid;grid-template-columns:1fr;gap:0;font-family:var(--font-mono);font-size:12px}.dev-meta>div{display:grid;grid-template-columns:84px 1fr;gap:12px;padding:7px 0;border-top:1px solid var(--rule-soft)}.dev-meta>div:first-child{border-top:0;padding-top:0}.dev-meta dt{color:var(--ink-3);margin:0}.dev-meta dd{margin:0;color:var(--ink)}.dev-section{padding:var(--pad-y)0}.dev-section-alt{background:var(--bg-elev)}.dev-section-head{margin-bottom:var(--gap);max-width:60ch}.dev-section-head-row{display:flex;justify-content:space-between;align-items:flex-end;max-width:none;gap:32px;margin-bottom:var(--gap)}.dev-lede{font-size:calc(var(--base) + 1px);color:var(--ink-2);margin:0}.dev-posts{list-style:none;border-top:1px solid var(--rule)}.dev-post{border-bottom:1px solid var(--rule)}.dev-post-link{display:grid;grid-template-columns:140px 1fr 32px;gap:28px;padding:28px 0;align-items:start;border-bottom:0;color:var(--ink);transition:padding-left .2s}.dev-post-link:hover{border-bottom:0;padding-left:12px}.dev-post-link:hover .dev-post-title{color:var(--accent)}@media(max-width:720px){.dev-post-link{grid-template-columns:1fr;gap:12px;padding:22px 0}}.dev-post-meta{display:flex;flex-direction:column;gap:6px;padding-top:4px}.dev-post-meta time{font-size:13px;font-family:var(--font-mono);color:var(--ink-2)}.dev-post-title{font-size:calc(var(--h3) + 4px);line-height:1.25;margin-bottom:8px;letter-spacing:-.01em;transition:color .15s}.dev-post-excerpt{color:var(--ink-2);font-size:calc(var(--base) - 1px);margin:0 0 12px;max-width:none}.dev-post-tags{display:flex;gap:6px;flex-wrap:wrap}.dev-post-arrow{color:var(--ink-3);padding-top:6px}.dev-archive{display:inline-block;margin-top:32px;font-family:var(--font-mono);font-size:13px;color:var(--ink-2);border-bottom-color:var(--rule)}.dev-projects{display:flex;flex-direction:column}.dev-proj{display:grid;grid-template-columns:200px 1fr;gap:32px;padding:28px 0;border-top:1px solid var(--rule)}.dev-proj:first-child{border-top:0;padding-top:0}@media(max-width:720px){.dev-proj{grid-template-columns:1fr;gap:12px}}.dev-proj-year{font-size:12px;color:var(--ink-3);letter-spacing:.03em;padding-top:6px;font-family:var(--font-mono)}.dev-proj-head{display:flex;justify-content:space-between;align-items:baseline;gap:16px;flex-wrap:wrap;margin-bottom:10px}.dev-proj-title{font-size:var(--h3)}.dev-proj-summary{color:var(--ink-2);font-size:calc(var(--base) - 1px);margin:0 0 14px;max-width:none}.dev-proj-foot{display:flex;justify-content:space-between;align-items:baseline;gap:16px;flex-wrap:wrap}.dev-proj-stack{display:flex;gap:6px;flex-wrap:wrap}.dev-proj-link{font-family:var(--font-mono);font-size:13px;color:var(--accent);border-bottom-color:var(--rule-soft)}.dev-social{list-style:none;border-top:1px solid var(--rule)}.dev-social-row{display:grid;grid-template-columns:160px 1fr;gap:24px;border-bottom:1px solid var(--rule)}.dev-social-name{padding:18px 0}.dev-social-link{display:flex;justify-content:space-between;align-items:center;padding:18px 0;border-bottom:0;color:var(--ink)}.dev-social-link:hover{color:var(--accent);border-bottom:0}.dev-social-arrow{color:var(--ink-3)}.dev-social-link:hover .dev-social-arrow{color:var(--accent)}@media(max-width:600px){.dev-social-row{grid-template-columns:1fr;gap:0}.dev-social-name{padding-bottom:0}}.dev-coffee{margin-top:var(--gap);padding:28px 32px;background:var(--bg);border:1px solid var(--rule);border-radius:4px}.dev-coffee-text{margin:12px 0 0;font-size:calc(var(--base) + 2px);max-width:60ch}.post-wrap{padding:var(--pad-y)0}.post-header{margin-bottom:var(--gap-s)}.post-title{font-size:var(--h1);line-height:1.05;letter-spacing:-.03em;margin:18px 0 20px}.post-meta{display:flex;gap:20px;flex-wrap:wrap}.post-body{margin-top:var(--gap);max-width:68ch;font-size:calc(var(--base) + 1px);line-height:1.7}.post-body p{max-width:none;margin-bottom:1.4em}.post-body h2,.post-body h3{margin:2em 0 .6em}.post-body h2{font-size:var(--h2)}.post-body h3{font-size:var(--h3)}.post-body a{color:var(--accent);border-bottom-color:color-mix(in oklab,var(--accent) 40%,transparent)}.post-body code{font-family:var(--font-mono);font-size:.88em;background:var(--rule-soft);padding:2px 6px;border-radius:3px}.post-body pre{background:var(--bg-elev);border:1px solid var(--rule);border-radius:6px;padding:20px 24px;overflow-x:auto;margin:1.6em 0}.post-body pre code{background:0 0;padding:0}.post-body blockquote{border-left:3px solid var(--accent);margin:1.4em 0;padding:0 0 0 20px;color:var(--ink-2)}.post-body img{max-width:100%;border-radius:4px;display:block}.post-body ul,.post-body ol{padding-left:1.4em}.post-body li{margin-bottom:.4em}.post-back{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:13px;color:var(--ink-2);border-bottom:0;margin-bottom:36px}.post-back:hover{color:var(--accent);border-bottom:0}.post-back::before{content:"←"}