@import"https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,600;1,9..144,300;1,9..144,400&family=Source+Serif+4:ital,opsz,wght@0,8..60,300;0,8..60,400;0,8..60,600;1,8..60,300;1,8..60,400&family=JetBrains+Mono:wght@400;500&display=swap";:root{--cream: #faf6e8;--ink: #1c1b18;--ink-muted: #6b6454;--green: #7bc043;--green-dark: #4f821c;--blue: #0392cf;--nav-h: 3.2rem;--blue-dark: #0270a0;--border: #e0d9c4;--font-display: "Fraunces", Georgia, serif;--font-body: "Source Serif 4", Georgia, serif;--font-mono: "JetBrains Mono", "Courier New", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{background:var(--cream);color:var(--ink);font-family:var(--font-body);font-size:18px;line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100vh}a{color:var(--blue);text-decoration:none;text-underline-offset:3px;text-decoration-thickness:1px;transition:color .15s ease}a:hover{color:var(--green)}.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:.65rem 2.5rem;background:var(--cream);border-bottom:1px solid var(--border)}.nav-logo{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:1.25rem;letter-spacing:.01em;color:var(--blue);text-shadow:1px 1px 0 var(--green);text-decoration:none;white-space:nowrap;transition:opacity .15s ease}.nav-logo:hover{opacity:.75;color:var(--blue)}.nav-links{display:flex;gap:2rem;list-style:none}.nav-links a{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;color:var(--ink-muted);text-decoration:none;transition:color .15s ease}.nav-links a:hover,.nav-links a[data-active]{color:var(--green)}@media(max-width:600px){.nav{padding:1rem 1.25rem}.nav-links{gap:1rem}.nav-links a{font-size:.66rem}}@media(max-width:400px){.nav{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.nav-logo{font-size:.95rem}.nav-links{gap:.8rem;width:100%;justify-content:flex-start}.nav-links a{font-size:.62rem}.page-wrapper{padding-top:6rem}}body.landing{height:100vh;overflow:hidden;isolation:isolate}.landing-dots{position:fixed;inset:0;background-image:radial-gradient(circle,var(--border) 1px,transparent 1px);background-size:26px 26px;z-index:-2;pointer-events:none}.landing-content{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;text-align:center;gap:0}.landing-logo-h{width:80%;max-width:680px;min-width:300px;height:auto;display:block}.landing-logo-v{display:none;width:85vw;max-width:340px;height:auto}@media(max-width:480px){.landing-logo-h{display:none}.landing-logo-v{display:block}}.landing-tagline{font-family:var(--font-display);font-style:italic;font-weight:300;font-size:clamp(.8rem,1.6vw,1rem);color:var(--ink-muted);letter-spacing:.01em;margin-top:.75rem;margin-bottom:2.25rem}.landing-nav{list-style:none;display:flex;flex-direction:column;gap:0;line-height:1.5}.landing-nav a{font-family:var(--font-display);font-weight:400;font-size:clamp(2.2rem,6.5vw,5rem);color:var(--blue);text-decoration:none;letter-spacing:-.025em;transition:color .15s ease;display:block}.landing-nav a:hover{color:var(--green)}.page-wrapper{padding-top:4.5rem}.page-inner{max-width:680px;margin:0 auto;padding:3.5rem 2rem 8rem}.page-title{font-family:var(--font-display);font-weight:400;font-size:clamp(2.5rem,6vw,4rem);line-height:1.1;letter-spacing:-.03em;margin-bottom:2.5rem;color:var(--ink)}.page-title:after{content:"";display:block;width:32px;height:3px;background:var(--green);border-radius:2px;margin-top:.7rem}body:not(.landing){background-image:radial-gradient(circle,var(--border) 1px,transparent 1px);background-size:26px 26px;background-attachment:fixed}.about-placeholder{font-family:var(--font-mono);font-size:.82rem;color:var(--ink-muted);background:#00000008;border:1px dashed var(--border);border-radius:4px;padding:2rem;text-align:center;line-height:1.6}.about-body p{margin-bottom:1.4rem;font-size:1.05rem}.about-connect{margin-top:3rem;padding:1.5rem 1.75rem;border:1px solid var(--border);border-left:3px solid var(--green);background:#ffffff80;border-radius:0 3px 3px 0}.about-connect-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:.75rem}.about-connect-links{display:flex;flex-wrap:wrap;gap:.5rem 1.75rem}.about-connect-links a{font-family:var(--font-mono);font-size:.82rem;color:var(--ink);text-decoration:none;letter-spacing:.01em;transition:color .15s ease}.about-connect-links a:hover{color:var(--green)}.about-body p:last-child{margin-bottom:0}.timeline{display:flex;flex-direction:column;gap:0}.timeline-item{display:grid;grid-template-columns:130px 1fr;gap:1.5rem;align-items:start;padding:2rem 0;border-bottom:1px solid var(--border)}.timeline-item:first-child{border-top:1px solid var(--border)}@media(max-width:540px){.timeline-item{grid-template-columns:1fr;gap:.4rem}}.timeline-date{font-family:var(--font-mono);font-size:.7rem;color:var(--ink-muted);letter-spacing:.03em;padding-top:.25rem}.timeline-role{font-family:var(--font-display);font-weight:400;font-size:1.2rem;letter-spacing:-.02em;line-height:1.3;margin-bottom:.2rem}.timeline-org{color:var(--green-dark)}.timeline-desc{font-size:.9rem;color:var(--ink-muted);line-height:1.6;margin-top:.5rem}.timeline-link{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.04em;text-decoration:none;color:var(--blue);display:inline-block;margin-top:.6rem;transition:color .15s ease}.timeline-link:hover{color:var(--green)}.projects-section{margin-bottom:3.5rem}.projects-section-title{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}.project-card{border:1px solid var(--border);border-radius:3px;overflow:hidden;transition:border-color .15s ease,box-shadow .15s ease;text-decoration:none;color:inherit;display:block;background:#ffffff80}.project-card:hover{border-color:var(--green);box-shadow:0 2px 12px #7bc0431f;color:inherit}.project-card-preview{height:150px;background:var(--border);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.project-card-preview-label{font-family:var(--font-mono);font-size:.68rem;color:var(--ink-muted);letter-spacing:.05em}.project-card-preview img{width:100%;height:100%;object-fit:cover}.project-card-body{padding:1.1rem 1.3rem 1.3rem}.project-card-type{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:.35rem}.project-card-title{font-family:var(--font-display);font-weight:400;font-size:1.25rem;letter-spacing:-.02em;margin-bottom:.5rem;color:var(--ink)}.project-card-desc{font-size:.875rem;color:var(--ink-muted);line-height:1.55}.writings-list{display:flex;flex-direction:column}.writing-item{display:grid;grid-template-columns:110px 1fr;gap:1.5rem;align-items:baseline;padding:1.75rem 0;border-bottom:1px solid var(--border);text-decoration:none;color:inherit}.writing-item:first-child{border-top:1px solid var(--border)}.writing-item:hover .writing-title{color:var(--green)}.writing-date{font-family:var(--font-mono);font-size:.7rem;color:var(--ink-muted);letter-spacing:.03em}.writing-title{font-family:var(--font-display);font-weight:400;font-size:1.3rem;letter-spacing:-.025em;transition:color .15s ease;margin-bottom:.35rem}.writing-desc{font-size:.875rem;color:var(--ink-muted);line-height:1.55}@media(max-width:480px){.writing-item{grid-template-columns:1fr;gap:.3rem}}.writings-empty{font-family:var(--font-mono);font-size:.82rem;color:var(--ink-muted);padding:3rem 0;text-align:center;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.post-header{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}.post-meta{font-family:var(--font-mono);font-size:.7rem;color:var(--ink-muted);letter-spacing:.06em;margin-bottom:1rem}.post-title{font-family:var(--font-display);font-weight:400;font-size:clamp(2rem,5vw,3.2rem);letter-spacing:-.03em;line-height:1.15;margin-bottom:1rem}.post-description{font-size:1.05rem;color:var(--ink-muted);font-style:italic}.post-body{font-size:1.05rem;line-height:1.8}.post-body h2{font-family:var(--font-display);font-weight:400;font-size:1.8rem;letter-spacing:-.025em;color:var(--ink);margin-top:3rem;margin-bottom:1rem;line-height:1.2}.post-body h3{font-family:var(--font-display);font-weight:400;font-size:1.3rem;letter-spacing:-.02em;color:var(--ink);margin-top:2.5rem;margin-bottom:.75rem}.post-body p{margin-bottom:1.5rem}.post-body ul,.post-body ol{padding-left:1.5rem;margin-bottom:1.5rem}.post-body li{margin-bottom:.5rem}.post-body code{font-family:var(--font-mono);font-size:.875em;background:#0000000f;padding:.15em .4em;border-radius:3px}.post-body pre{background:#0000000a;border:1px solid var(--border);border-radius:4px;padding:1.25rem;overflow-x:auto;margin-bottom:1.5rem}.post-body pre code{background:none;padding:0;font-size:.875rem}.post-body blockquote{border-left:3px solid var(--green);padding-left:1.25rem;margin:2rem 0;color:var(--ink-muted);font-style:italic}.post-body iframe{border:1px solid var(--border)!important;border-radius:3px;box-shadow:0 2px 12px #00000012;margin:1.5rem 0;display:block}.post-body img{max-width:100%;border-radius:3px;margin:1.5rem 0;border:1px solid var(--border);box-shadow:0 2px 12px #00000012;display:block}.post-body hr{border:none;border-top:1px solid var(--border);margin:2.5rem 0}.post-back{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.04em;text-decoration:none;color:var(--ink-muted);display:inline-flex;align-items:center;gap:.4rem;margin-bottom:2rem;transition:color .15s ease}.post-back:hover{color:var(--green)}.footer{padding:1.5rem 2.5rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.footer-copy{font-family:var(--font-mono);font-size:.68rem;color:var(--ink-muted);letter-spacing:.04em}.footer-links{display:flex;gap:1.5rem;list-style:none}.footer-links a{font-family:var(--font-mono);font-size:.68rem;color:var(--ink-muted);text-decoration:none;letter-spacing:.04em;transition:color .15s ease}.footer-links a:hover{color:var(--green)}@media(max-width:480px){.footer{flex-direction:column;gap:.75rem;text-align:center;padding:1.25rem 1rem}}body.project-page{height:100vh;overflow:hidden;display:flex;flex-direction:column}.project-nav-spacer{flex-shrink:0;height:var(--nav-h)}.project-strip{flex-shrink:0;background:var(--cream);border-bottom:1px solid var(--border);padding:.5rem 2rem;display:flex;align-items:baseline;gap:.75rem;overflow:hidden}.project-strip-back{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.04em;color:var(--ink-muted);text-decoration:none;white-space:nowrap;flex-shrink:0;transition:color .15s ease}.project-strip-back:hover{color:var(--green)}.project-strip-sep{color:var(--border);font-size:.75rem;flex-shrink:0}.project-strip-type{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-muted);white-space:nowrap;flex-shrink:0}.project-strip-title{font-family:var(--font-display);font-style:italic;font-size:1rem;letter-spacing:-.01em;color:var(--ink);white-space:nowrap;flex-shrink:0}.project-strip-desc{font-family:var(--font-body);font-size:.8rem;color:var(--ink-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}@media(max-width:600px){.project-strip-desc{display:none}}.project-embed-wrap{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;background:var(--cream);padding:2rem}.project-embed{width:min(580px,90vmin);height:min(580px,90vmin);border:none;display:block;border-radius:4px}
