:root{color-scheme:light;--bg: #fbfaf7;--surface: #fffdf8;--ink: #20231f;--muted: #62665f;--line: #ded8cc;--green: #315f4b;--red: #a9473f;--gold: #b98a36;--graphite: #2d3130;--shadow: 0 18px 50px rgb(45 49 48 / 12%);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{background:var(--bg);color:var(--ink);scroll-behavior:smooth}body{margin:0;min-width:320px;font-size:16px;line-height:1.6}a{color:inherit}img{display:block;max-width:100%}.page-shell{min-height:100vh}.site-header{align-items:center;display:flex;gap:24px;justify-content:space-between;margin:0 auto;max-width:1160px;padding:22px 24px}.brand,.site-header nav{align-items:center;display:flex}.brand{gap:10px;font-weight:760;text-decoration:none}.brand-mark{align-items:center;background:var(--graphite);border-radius:6px;color:#fffaf0;display:inline-flex;font-size:.78rem;height:34px;justify-content:center;letter-spacing:0;width:34px}.site-header nav{gap:18px;color:var(--muted);font-size:.95rem}.site-header nav a{text-decoration:none}.site-header nav a:hover{color:var(--ink)}.eyebrow,.section-label{color:var(--green);font-size:.78rem;font-weight:760;letter-spacing:.08em;margin:0 0 12px;text-transform:uppercase}h1,h2,h3,p{margin-top:0}h1{font-size:clamp(3rem,8vw,6.5rem);letter-spacing:0;line-height:.95;margin-bottom:28px}.lede{color:var(--graphite);font-size:clamp(1.12rem,2vw,1.45rem);line-height:1.45;margin-bottom:32px;max-width:31rem}.blog-hero,.post-list,.article{margin:0 auto;max-width:1160px;padding:0 24px}.blog-hero{padding-bottom:64px;padding-top:96px}.blog-hero h1{max-width:9ch}.post-list{padding-bottom:92px}.post-preview{border-top:1px solid var(--line)}.post-preview:last-child{border-bottom:1px solid var(--line)}.post-preview a{display:block;padding:32px 0;text-decoration:none}.post-preview a:hover h2{color:var(--red)}.post-preview time,.article-header time{color:var(--muted);display:block;font-size:.92rem;margin-bottom:10px}h2{font-size:clamp(1.65rem,4vw,3rem);letter-spacing:0;line-height:1.08;margin-bottom:10px}.post-preview p{color:var(--muted);margin-bottom:14px;max-width:700px}.post-preview ul,.article-tags{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:0;padding:0}.post-preview li,.article-tags li{border:1px solid var(--line);border-radius:999px;color:var(--green);font-size:.84rem;padding:3px 10px}.article{max-width:820px;padding-bottom:92px;padding-top:78px}.article-header{border-bottom:1px solid var(--line);margin-bottom:42px;padding-bottom:34px}.article-header h1{font-size:clamp(2.5rem,6vw,5rem);max-width:12ch}.article-header p{color:var(--muted);font-size:1.2rem}.back-link{color:var(--red);display:inline-block;font-weight:720;margin-bottom:28px;text-decoration-thickness:2px;text-underline-offset:4px}.prose{font-size:1.08rem}.prose :is(h2,h3){margin-top:2.2em}.timeline-post .prose{border-left:1px solid var(--line);margin-left:10px;padding-left:34px}.timeline-post .prose h2{position:relative}.timeline-post .prose h2:before{background:var(--green);border:4px solid var(--bg);border-radius:999px;box-shadow:0 0 0 1px var(--line);content:"";height:13px;left:-42px;position:absolute;top:.42em;width:13px}.timeline-post .prose h2:after{color:var(--muted);content:"";font-size:.78rem;font-weight:760;left:-124px;letter-spacing:0;position:absolute;text-align:right;top:.58em;width:70px}.timeline-post .prose h2:nth-of-type(1):after{content:"1990s"}.timeline-post .prose h2:nth-of-type(2):after{content:"Early 2000s"}.timeline-post .prose h2:nth-of-type(3):after{content:"2004"}.timeline-post .prose h2:nth-of-type(4):after{content:"2007-2021"}.timeline-post .prose h2:nth-of-type(5):after{content:"2021-2023"}.timeline-post .prose h2:nth-of-type(6):after{content:"2023-now"}.timeline-post .prose h2:nth-of-type(7):after{content:"Now"}.prose p,.prose li{color:var(--graphite)}.prose a{color:var(--red);font-weight:650}.social-links{display:flex;flex-wrap:wrap;gap:14px}.social-links a{text-decoration-thickness:2px;text-underline-offset:4px}.prose code{background:#eee7dc;border-radius:5px;font-size:.94em;padding:.1em .35em}.prose pre{background:var(--graphite);border-radius:8px;color:#fffaf0;overflow-x:auto;padding:18px}.prose pre code{background:transparent;padding:0}.resume{margin:0 auto;max-width:960px;padding:78px 24px 92px}.resume-header{align-items:start;border-bottom:1px solid var(--line);display:grid;gap:24px;grid-template-columns:minmax(0,1fr) auto;margin-bottom:42px;padding-bottom:34px}.resume-header h1{font-size:clamp(2.8rem,7vw,5.5rem);margin-bottom:16px}.resume-subtitle{color:var(--graphite);font-size:clamp(1.1rem,2vw,1.35rem);line-height:1.4;margin-bottom:10px;max-width:720px}.resume-meta{color:var(--muted);margin-bottom:0}.resume-download{align-items:center;background:var(--ink);border-radius:7px;color:#fffaf0;display:inline-flex;font-weight:720;min-height:46px;padding:10px 16px;text-decoration:none;white-space:nowrap}.resume-section{border-bottom:1px solid var(--line);padding:34px 0}.resume-section h2{font-size:clamp(1.5rem,3vw,2.2rem);margin-bottom:18px}.resume-section p,.resume-role li{color:var(--graphite)}.strength-list{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:0;padding:0}.strength-list li{border:1px solid var(--line);border-radius:999px;color:var(--green);font-size:.9rem;padding:5px 11px}.role-list{display:grid;gap:28px}.resume-role{display:grid;gap:14px}.resume-role header{align-items:start;display:grid;gap:16px;grid-template-columns:minmax(0,1fr) auto}.resume-role h3{font-size:1.25rem;line-height:1.25;margin-bottom:4px}.resume-role header p,.resume-role header span{color:var(--muted);margin:0}.resume-role header span{font-weight:720;white-space:nowrap}.resume-role ul{margin:0;padding-left:1.2rem}.resume-role li+li{margin-top:8px}footer{color:var(--muted);margin:0 auto;max-width:1160px;padding:28px 24px 40px}@media(max-width:820px){.site-header{align-items:flex-start;flex-direction:column}.blog-hero{padding-bottom:44px;padding-top:56px}.resume-header,.resume-role header{grid-template-columns:1fr}.resume-download{justify-content:center;width:100%}.timeline-post .prose{margin-left:0;padding-left:24px}.timeline-post .prose h2:before{height:11px;left:-31px;top:.48em;width:11px}.timeline-post .prose h2:after{display:block;font-size:.75rem;margin-top:4px;position:static;text-align:left;width:auto}}@media(max-width:520px){.site-header nav{gap:12px;width:100%}.site-header nav a{font-size:.9rem}.article,.blog-hero,.post-list,.resume{padding-left:20px;padding-right:20px}}
