:root{--paper: #eef3f0;--paper-2: #f8faf7;--ink: #17201c;--muted: #64716b;--soft: #d9e2dc;--line: rgba(23, 32, 28, .13);--green: #1f6f58;--blue: #315f93;--amber: #a7652d;--rose: #8f4d5f;--panel: rgba(255, 255, 255, .58);--shadow: 0 24px 80px rgba(23, 32, 28, .12);--font-body: "IBM Plex Sans", "Noto Sans SC", system-ui, sans-serif;--font-display: "IBM Plex Serif", "Noto Serif SC", Georgia, serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, monospace}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;background:radial-gradient(circle at 12% 10%,rgba(49,95,147,.18),transparent 28rem),radial-gradient(circle at 86% 4%,rgba(31,111,88,.18),transparent 26rem),linear-gradient(135deg,#eef3f0,#f7f7ee 48%,#edf3f8);color:var(--ink);font-family:var(--font-body);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(23,32,28,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(23,32,28,.045) 1px,transparent 1px);background-size:44px 44px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.32),transparent 70%)}a{color:inherit}img{display:block;max-width:100%}main{min-height:calc(100vh - 150px)}.grain{position:fixed;inset:0;pointer-events:none;opacity:.2;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E")}.site-header{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:minmax(210px,1fr) auto minmax(170px,1fr);align-items:center;gap:.75rem;width:min(1180px,calc(100% - 32px));margin:0 auto;padding:14px 0;backdrop-filter:blur(18px)}.brand,.site-nav,.header-actions{min-height:48px;border:1px solid var(--line);background:#f8faf7b8;box-shadow:0 12px 35px #17201c12;border-radius:999px}.brand{justify-self:start;display:inline-flex;align-items:center;gap:.6rem;min-width:0;padding:.38rem 1rem .38rem .48rem;text-decoration:none;font-family:var(--font-mono);font-weight:600}.brand img{flex:0 0 auto;width:36px;height:36px;border-radius:50%}.brand-text{display:grid;min-width:0;line-height:1.1}.brand-name,.brand-subtitle{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.brand-name{font-size:.8rem;color:var(--ink)}.brand-subtitle{margin-top:.12rem;color:var(--muted);font-size:.68rem}.site-nav{display:inline-flex;align-items:center;gap:3px;padding:3px;justify-content:center}.site-nav a{min-height:38px;display:inline-flex;align-items:center;justify-content:center;padding:0 1.25rem;border-radius:999px;text-decoration:none;font-family:var(--font-mono);font-size:.72rem;font-weight:600;color:var(--muted);transition:background .18s ease,color .18s ease,transform .18s ease}.site-nav a:hover,.site-nav a.active{background:var(--ink);color:var(--paper-2)}.header-actions{justify-self:end;display:flex;align-items:center;justify-content:center;gap:.3rem;padding:3px}.header-link{min-height:38px;display:inline-flex;align-items:center;justify-content:center;padding:0 .85rem;border-radius:999px;text-decoration:none;font-family:var(--font-mono);font-size:.74rem;font-weight:600;color:var(--muted);transition:background .18s ease,color .18s ease,transform .18s ease}.header-link:hover,.header-link.primary{background:var(--ink);color:var(--paper-2)}.section{width:min(1180px,calc(100% - 32px));margin:0 auto}.eyebrow{margin:0 0 .8rem;color:var(--green);font-family:var(--font-mono);font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.page-title,.hero-title{margin:0;font-family:var(--font-display);font-weight:700;letter-spacing:0;line-height:.98}.hero-title{max-width:980px;font-size:clamp(3.6rem,9vw,8.4rem)}.page-title{font-size:clamp(2.8rem,7vw,5.8rem)}.lead{max-width:720px;margin:1.25rem 0 0;color:var(--muted);font-size:clamp(1rem,1.9vw,1.24rem)}.button-row{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}.button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 1.15rem;border:1px solid var(--line);border-radius:999px;background:#ffffff80;color:var(--ink);text-decoration:none;font-family:var(--font-mono);font-size:.78rem;font-weight:600}.button.primary{background:var(--ink);color:var(--paper-2)}.button:hover{transform:translateY(-1px);box-shadow:0 12px 28px #17201c1f}.panel,.project-card,.resume-block,.detail-card{border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:var(--shadow);backdrop-filter:blur(18px)}.tag-list{display:flex;flex-wrap:wrap;gap:.5rem}.tag,.status{display:inline-flex;align-items:center;min-height:28px;padding:0 .65rem;border:1px solid var(--line);border-radius:999px;background:#ffffff7a;color:var(--muted);font-family:var(--font-mono);font-size:.7rem;white-space:nowrap}.status.active{color:var(--green)}.status.published{color:var(--blue)}.status.completed{color:var(--amber)}.site-footer{position:relative;z-index:1;display:flex;justify-content:space-between;gap:1rem;width:min(1180px,calc(100% - 32px));margin:5rem auto 0;padding:1.5rem 0 2rem;border-top:1px solid var(--line);color:var(--muted);font-family:var(--font-mono);font-size:.75rem}.site-footer div{display:flex;gap:.8rem;flex-wrap:wrap}.site-footer strong{color:var(--ink)}.hero{position:relative;z-index:1;padding:6.5rem 0 4rem}.hero-content{display:contents}.hero-top{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(260px,.5fr);gap:2rem;align-items:start}.hero-intro{min-width:0}.hero-visual{overflow:hidden;min-height:420px;position:relative}.hero-visual img{width:100%;height:100%;min-height:420px;object-fit:cover;filter:saturate(.95) contrast(1.04)}.hero-visual:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(23,32,28,.38),transparent 55%)}.visual-caption{position:absolute;left:1.2rem;right:1.2rem;bottom:1.2rem;z-index:1;color:#fff;font-family:var(--font-mono);font-size:.78rem}.hero-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;overflow:hidden;margin-top:2.8rem;background:var(--line);border:1px solid var(--line);border-radius:8px}.hero-meta div{padding:1.1rem;background:#f8faf7c7}.hero-meta span{display:block;color:var(--muted);font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase}.hero-meta strong{display:block;margin-top:.25rem;font-size:.95rem}.split{display:grid;grid-template-columns:.48fr 1fr;gap:2rem;padding:4rem 0}.section-heading{position:sticky;top:96px;align-self:start}.section-heading h2{margin:0;font-family:var(--font-display);font-size:clamp(2rem,4vw,3.4rem);line-height:1.05}.section-heading p{margin:1rem 0 0;color:var(--muted)}.work-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.project-card{display:flex;min-height:290px;flex-direction:column;padding:1.25rem;text-decoration:none;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.project-card-img{margin:-1.25rem -1.25rem 1rem;overflow:hidden;max-height:200px}.project-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-card:hover .project-card-img img{transform:scale(1.03)}.project-card:hover{transform:translateY(-3px);border-color:#1f6f586b}.project-card.featured{grid-column:span 2;min-height:330px;background:linear-gradient(135deg,#1f6f5824,#315f931f),var(--panel)}.project-card-top{display:flex;align-items:center;justify-content:space-between;gap:1rem}.project-kind{color:var(--muted);font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase}.project-card h3{margin:1.1rem 0 .25rem;font-family:var(--font-display);font-size:clamp(1.6rem,4vw,2.55rem);line-height:1}.project-card p{margin:.8rem 0 0;color:var(--muted)}.project-card .tag-list{margin-top:auto;padding-top:1.4rem}.project-gallery{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.5rem}.project-gallery img{flex:1 1 0;min-width:0;max-height:400px;border-radius:8px;border:1px solid var(--line);object-fit:cover}@media(max-width:640px){.project-gallery{flex-direction:column}.project-gallery img{max-height:300px}}.timeline{display:grid;gap:1rem}.timeline-item{display:grid;grid-template-columns:130px 1fr;gap:1rem;padding:1.2rem}.timeline-item time{color:var(--green);font-family:var(--font-mono);font-size:.76rem}.timeline-item h3{margin:0;font-size:1.08rem}.timeline-item p{margin:.35rem 0 0;color:var(--muted)}.resume-list{display:grid;gap:1rem}.resume-block{padding:1.35rem}.resume-block h2{margin:0 0 1rem;font-family:var(--font-mono);font-size:.78rem;color:var(--green);text-transform:uppercase}.resume-row{display:grid;grid-template-columns:140px 1fr;gap:1rem;padding:.9rem 0;border-top:1px solid var(--line)}.resume-row:first-of-type{border-top:0;padding-top:0}.resume-row time,.resume-row span{color:var(--muted);font-family:var(--font-mono);font-size:.76rem}.resume-row h3{margin:0;font-size:1rem}.resume-row p{margin:.35rem 0 0;color:var(--muted)}.project-page-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:1.25rem;align-items:start;padding-top:2rem}.detail-card{padding:1.25rem}.detail-card h2{margin:0 0 1rem;font-family:var(--font-mono);font-size:.76rem;color:var(--green);text-transform:uppercase}.clean-list{margin:0;padding:0;list-style:none;display:grid;gap:.7rem}.clean-list li{display:grid;grid-template-columns:1.2rem 1fr;gap:.55rem;color:var(--muted)}.clean-list li:before{content:"";width:.45rem;height:.45rem;margin-top:.62rem;border-radius:50%;background:var(--green)}.metric-list{display:grid;gap:.65rem}.metric-list div{display:flex;justify-content:space-between;gap:1rem;padding-bottom:.65rem;border-bottom:1px solid var(--line)}.metric-list span{color:var(--muted);font-family:var(--font-mono);font-size:.74rem}.metric-list strong{text-align:right}.page-hero{position:relative;z-index:1;padding:5rem 0 2rem}.page-hero.compact{padding-bottom:.5rem}@media(max-width:920px){.site-header{grid-template-columns:1fr auto;gap:.5rem}.site-nav{grid-column:1 / -1;justify-self:stretch;order:3}.site-nav a{flex:1 1 0;padding:0 .9rem}.header-actions{min-width:0}.hero{padding:4rem 0 2.5rem}.hero-top{grid-template-columns:1fr .55fr;gap:1.5rem;align-items:start}.split,.project-page-grid{grid-template-columns:1fr}.section-heading{position:static}.hero-visual,.hero-visual img{min-height:340px}.split{padding:2.5rem 0}.archive-photo-grid{grid-template-columns:1fr}}@media(max-width:680px){.site-header{grid-template-columns:minmax(0,1fr) auto;width:min(100% - 20px,1180px);padding:10px 0;gap:.5rem}.brand{width:auto;justify-self:start;min-height:46px;padding-right:.8rem}.brand img{width:34px;height:34px}.brand-name{font-size:.76rem}.brand-subtitle{font-size:.64rem}.site-nav{grid-column:auto;order:initial;width:auto;justify-self:end}.site-nav a{min-height:36px;padding:0 .62rem;font-size:.68rem}.header-actions{display:none}.section{width:min(100% - 24px,1180px)}.hero{padding:2rem 0 1.5rem}.hero-top{grid-template-columns:1fr 100px;gap:.75rem;align-items:start;margin-bottom:1rem}.hero-title{font-size:clamp(1.8rem,9vw,2.6rem)}.hero-visual{min-height:130px;border-radius:10px;overflow:hidden}.hero-visual img{min-height:130px;border-radius:10px}.visual-caption{display:none}.button-row{flex-wrap:nowrap}.hero-meta{grid-template-columns:repeat(3,1fr);margin-top:1.2rem}.hero-meta div{padding:.65rem .5rem;text-align:center}.work-grid{grid-template-columns:1fr}.project-card{min-height:auto;padding:1rem}.project-card.featured{grid-column:auto;min-height:auto}.project-card-img{margin:-1rem -1rem .8rem;max-height:160px}.project-card h3{font-size:clamp(1.3rem,5vw,1.8rem)}.project-card p{font-size:.88rem}.page-hero{padding:3rem 0 1.5rem}.page-title{font-size:clamp(2rem,10vw,3.5rem)}.split{padding:2rem 0}.section-heading h2{font-size:clamp(1.5rem,6vw,2.2rem)}.timeline-item,.resume-row{grid-template-columns:1fr;gap:.25rem;padding:.8rem 1rem}.resume-block,.detail-card{padding:1rem}.button-row{gap:.5rem;margin-top:1.5rem}.button{min-height:40px;padding:0 1rem;font-size:.72rem}.tag-list{gap:.4rem}.tag{min-height:26px;padding:0 .55rem;font-size:.65rem}.site-footer{flex-direction:column;gap:.5rem;padding:1rem 0 1.5rem}}@media(max-width:360px){.brand-name{display:none}.brand-subtitle{margin-top:0;font-size:.7rem}.site-nav a{padding:0 .5rem}}
