@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@300;400;500&family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,500;1,9..144,300;1,9..144,500&display=swap");*,:after,:before{margin:0;padding:0;box-sizing:border-box}:root{--mono:"IBM Plex Mono",monospace;--serif:"Fraunces",serif;--bg:#fff;--surface:#f7f6f3;--surface2:#eeecea;--border:#e0ddd8;--border-hover:#b8b4ae;--text:#1a1917;--muted:#6b6860;--faint:#a8a49e;--accent:#2563a8;--accent-green:#1a7a50;--accent-amber:#92600a;--accent-dim:rgba(37,99,168,.06);--transition:background-color 0.3s ease,border-color 0.3s ease,color 0.2s ease}.dark{--bg:#0f0f0f;--surface:#1a1a1a;--surface2:#242424;--border:#2c2c2c;--border-hover:#3a3a3a;--text:#eaeaea;--muted:#a0a0a0;--faint:#6b6b6b;--accent:#4d9eff;--accent-green:#2d9c6e;--accent-amber:#c47a2a;--accent-dim:rgba(77,158,255,.08)}html{font-size:16px;scroll-behavior:smooth}body,html{transition:var(--transition)}body{font-family:var(--mono);background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none;transition:color .2s ease}img{display:block;max-width:100%}.site-wrap{max-width:760px;margin:0 auto;padding:0 1.5rem}.site-nav{border-bottom:1px solid var(--border);padding:1.25rem 0;position:-webkit-sticky;position:sticky;top:0;background:var(--bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:100;transition:var(--transition)}.nav-inner{max-width:760px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center}.nav-logo{font-size:13px;font-weight:500;color:var(--accent);letter-spacing:.5px;transition:var(--transition)}.nav-links{display:flex;gap:2rem;list-style:none;align-items:center}.nav-links a{font-size:12px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;transition:color .2s}.nav-links a.active,.nav-links a:hover{color:var(--text)}.theme-toggle{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:6px 10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--muted)}.theme-toggle:hover{border-color:var(--border-hover);background:var(--surface2);color:var(--text)}.theme-toggle svg{width:16px;height:16px}.rule{border:none;border-top:1px solid var(--border);margin:2.5rem 0}.rule,.sec-label{transition:var(--transition)}.sec-label{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--faint);margin-bottom:1.5rem;display:flex;align-items:center;gap:12px}.sec-label:after{content:"";flex:1 1;border-top:1px solid var(--border)}.tags{display:flex;flex-wrap:wrap;gap:6px}.tag{font-size:11px;padding:3px 10px;border-radius:3px;border:1px solid var(--border);color:var(--muted);background:var(--surface);transition:border-color .2s,color .2s,background .2s}.tag:hover{border-color:var(--border-hover);color:var(--text)}.tag.live{color:var(--accent-green);border-color:#b6deca;background:#f0faf5}.dark .tag.live{color:#3db87f;border-color:#2a5a44;background:#1a3328}.tag.wip{color:var(--accent-amber);border-color:#f2d9a2;background:#fffbf0}.dark .tag.wip{color:#e6a44c;border-color:#6e4f1a;background:#2a2418}.avail{display:inline-flex;align-items:center;gap:7px;font-size:11px;color:var(--accent-green);transition:var(--transition)}.avail-dot{width:7px;height:7px;border-radius:50%;background:currentColor;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.stats{display:flex;gap:2.5rem;flex-wrap:wrap;padding:1.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:1.75rem 0}.stat strong,.stats{transition:var(--transition)}.stat strong{font-family:var(--serif);font-size:26px;font-weight:300;font-style:italic;color:var(--accent);display:block;line-height:1;margin-bottom:3px}.stat span{font-size:11px;color:var(--faint);transition:var(--transition)}.xp-item{margin-bottom:1.5rem}.xp-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:2px;flex-wrap:wrap;gap:4px}.xp-title{font-size:13px;font-weight:500;transition:var(--transition)}.xp-date{color:var(--faint)}.xp-co,.xp-date{font-size:11px;transition:var(--transition)}.xp-co{margin-bottom:5px}.xp-co,.xp-desc{color:var(--muted)}.xp-desc{font-size:13px;line-height:1.8;transition:var(--transition)}.proj-card{border:1px solid var(--border);border-radius:6px;padding:1.25rem;margin-bottom:.75rem;transition:border-color .2s,background .2s}.proj-card:hover{border-color:var(--border-hover);background:var(--surface)}.proj-card-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px;flex-wrap:wrap;gap:4px}.proj-card-name{font-size:13px;font-weight:500;transition:var(--transition)}.proj-card-year{font-size:11px;color:var(--faint);transition:var(--transition)}.proj-card-desc{font-size:13px;color:var(--muted);line-height:1.75;margin-bottom:12px;transition:var(--transition)}.proj-card-link{font-size:11px;color:var(--accent);transition:color .2s}.proj-card-link:hover{text-decoration:underline}.two-col{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);grid-gap:2.5rem;gap:2.5rem}.sg{margin-bottom:1rem}.sg-name{font-size:11px;color:var(--muted);margin-bottom:8px}.cert,.sg-name{transition:var(--transition)}.cert{display:flex;justify-content:space-between;align-items:baseline;padding:9px 0;border-bottom:1px solid var(--border)}.cert:first-child{border-top:1px solid var(--border)}.cert-name{font-size:13px}.cert-name,.cert-yr{transition:var(--transition)}.cert-yr{font-size:11px;color:var(--faint)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:0;gap:0}.c-item{padding:10px 0;border-bottom:1px solid var(--border);transition:var(--transition)}.c-item:nth-child(odd){border-right:1px solid var(--border);padding-right:1.5rem}.c-item:nth-child(2n){padding-left:1.5rem}.c-key{font-size:10px;color:var(--faint);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:3px;transition:var(--transition)}.c-val{font-size:12px;color:var(--muted);transition:color .2s}.c-val:hover{color:var(--text)}.proj-entry{border:1px solid var(--border);border-radius:6px;overflow:hidden;margin-bottom:1.25rem;transition:border-color .2s}.proj-entry:hover{border-color:var(--border-hover)}.proj-entry-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:8px;transition:var(--transition)}.proj-entry-header-left h2{font-size:15px;font-weight:500;margin-bottom:5px;transition:var(--transition)}.proj-entry-header-left p{font-size:12px;color:var(--muted);line-height:1.6;max-width:480px;transition:var(--transition)}.proj-entry-header-right{text-align:right}.proj-year-badge{font-size:11px;color:var(--faint);display:block;margin-bottom:6px;transition:var(--transition)}.proj-body{padding:1.25rem 1.5rem}.steps{list-style:none;counter-reset:step}.steps li{counter-increment:step;display:grid;grid-template-columns:26px 1fr;grid-gap:12px;gap:12px;margin-bottom:1rem;align-items:start}.steps li:before{content:counter(step);font-size:11px;color:var(--faint);padding-top:2px}.step-title{font-size:13px;font-weight:500;margin-bottom:4px;transition:var(--transition)}.step-desc,pre{font-size:12px;color:var(--muted);line-height:1.7;transition:var(--transition)}pre{border:1px solid var(--border);border-radius:4px;padding:1rem 1.25rem;overflow-x:auto;margin:.75rem 0}code,pre{background:var(--surface);font-family:var(--mono)}code{font-size:12px;color:var(--accent);padding:1px 6px;border-radius:3px;transition:var(--transition)}pre code{color:var(--muted);background:transparent;padding:0}.post-row{display:grid;grid-template-columns:80px 1fr;grid-gap:16px;gap:16px;padding:1.25rem 0;border-bottom:1px solid var(--border);align-items:start;cursor:pointer;transition:background .15s;border-radius:4px}.post-row:first-of-type{border-top:1px solid var(--border)}.post-row:hover{background:var(--surface);padding-left:8px;padding-right:8px;margin:0 -8px}.post-date{font-size:11px;color:var(--faint);padding-top:2px}.post-date,.post-title{transition:var(--transition)}.post-title{font-size:14px;font-weight:500;margin-bottom:5px}.post-excerpt{font-size:12px;color:var(--muted);line-height:1.7;margin-bottom:8px;transition:var(--transition)}.post-meta{display:flex;align-items:center;gap:12px}.read-time{font-size:11px;color:var(--faint)}.article-header,.read-time{transition:var(--transition)}.article-header{padding:3rem 0 2rem;border-bottom:1px solid var(--border);margin-bottom:2rem}.article-back{font-size:12px;color:var(--muted);cursor:pointer;margin-bottom:1.5rem;display:inline-block;transition:color .2s}.article-back:hover{color:var(--text)}.article-date{font-size:11px;color:var(--faint);letter-spacing:1px;text-transform:uppercase;margin-bottom:10px;transition:var(--transition)}.article-title{font-family:var(--serif);font-size:clamp(24px,4vw,36px);font-weight:300;font-style:italic;line-height:1.15;margin-bottom:12px;transition:var(--transition)}.article-meta{display:flex;gap:1rem;align-items:center}.article-meta span{font-size:11px;color:var(--faint);transition:var(--transition)}.article-body{font-size:14px;line-height:1.9;color:var(--muted);max-width:620px;transition:var(--transition)}.article-body h2{font-size:16px;margin:2rem 0 .75rem}.article-body h2,.article-body h3{font-weight:500;color:var(--text);transition:var(--transition)}.article-body h3{font-size:14px;margin:1.5rem 0 .5rem}.article-body p{margin-bottom:1.25rem}.article-body ol,.article-body ul{padding-left:1.25rem;margin-bottom:1.25rem}.article-body li{margin-bottom:.4rem}.article-body blockquote{border-left:2px solid var(--accent);padding-left:1rem;color:var(--muted);margin:1.5rem 0;font-style:italic;transition:var(--transition)}.article-body a{text-decoration:underline;text-underline-offset:3px}.article-body a,.highlight{color:var(--accent)}.proj-links{display:flex;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.proj-link{font-size:11px;color:var(--accent);letter-spacing:.5px}.proj-link:hover{text-decoration:underline}.proj-link.secondary{color:var(--muted)}.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:2rem}.filter-btn{font-size:11px;font-family:var(--mono);padding:4px 12px;border-radius:3px;border:1px solid var(--border);color:var(--muted);background:transparent;cursor:pointer;transition:all .2s}.filter-btn.active,.filter-btn:hover{border-color:var(--accent);color:var(--accent)}.page-hero{padding:3rem 0 2rem}.page-hero h1{font-family:var(--serif);font-size:clamp(28px,5vw,40px);font-weight:300;font-style:italic;margin-bottom:8px}.page-hero h1,.page-hero p{transition:var(--transition)}.page-hero p{font-size:13px;color:var(--muted)}.site-footer{border-top:1px solid var(--border);padding:2rem 0;margin-top:4rem;background:var(--bg);transition:var(--transition)}.footer-inner{max-width:760px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.footer-inner span{font-size:11px;color:var(--faint);transition:var(--transition)}.footer-links{display:flex;gap:1.5rem}.footer-links a{font-size:11px;color:var(--faint);transition:color .2s}.footer-links a:hover{color:var(--muted)}.page-content{animation:fadein .35s ease}@keyframes fadein{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}@media (max-width:600px){.contact-grid,.two-col{grid-template-columns:1fr}.c-item:nth-child(odd){border-right:none;padding-right:0}.c-item:nth-child(2n){padding-left:0}.nav-links{gap:1.25rem}.nav-links a{font-size:11px}.post-row{grid-template-columns:1fr;gap:4px}.proj-entry-header{flex-direction:column}.proj-entry-header-right{text-align:left}}@media (max-width:400px){.nav-logo{font-size:11px}.nav-links{gap:1rem}}