:root{--bg:#0d0f11;--bg-card:#1a1d20;--border:#2a2d32;--accent:#7ee8a2;--accent-dim:#3d7a55;--text-primary:#e8eaed;--text-secondary:#8b9099;--text-muted:#4a5060;--font-mono:"IBM Plex Mono", monospace;--font-serif:"Fraunces", Georgia, serif;--radius:6px;--ease:.2s ease;--max-width:960px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text-primary);font-family:var(--font-mono);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.7}a{color:var(--accent);text-decoration:none}.nav{z-index:100;height:56px;transition:background var(--ease), border-color var(--ease);border-bottom:1px solid #0000;justify-content:space-between;align-items:center;padding:0 2rem;display:flex;position:fixed;top:0;left:0;right:0}.nav--scrolled{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom-color:var(--border);background:#0d0f11eb}.nav-logo{color:var(--accent);letter-spacing:.05em;font-size:.85rem;font-weight:600}.nav-links{gap:2rem;list-style:none;display:flex}.nav-btn{all:unset;cursor:pointer;font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.06em;transition:color var(--ease);font-size:.8rem}.nav-btn:hover{color:var(--text-primary)}section{border-bottom:1px solid var(--border)}section:last-of-type{border-bottom:none}.section-inner{max-width:var(--max-width);margin:0 auto;padding:6rem 2rem}.section-label{letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;font-size:.72rem}#hero{align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}#hero:before{content:"";pointer-events:none;background:radial-gradient(60% 50% at 70%,#7ee8a20a 0%,#0000 70%);position:absolute;inset:0}.hero-inner{max-width:var(--max-width);width:100%;margin:0 auto;padding:0 2rem;animation:.8s both fadeUp}.hero-greeting{letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:1.25rem;font-size:.8rem}.hero-name{font-family:var(--font-serif);margin-bottom:1rem;font-size:clamp(2.8rem,8vw,5.5rem);font-weight:600;line-height:1.05}.hero-sub{color:var(--text-secondary);max-width:480px;margin-bottom:2.5rem;font-size:.95rem;line-height:1.8}.hero-cta{all:unset;cursor:pointer;border:1px solid var(--accent);color:var(--accent);border-radius:var(--radius);font-family:var(--font-mono);letter-spacing:.06em;transition:background var(--ease), color var(--ease);align-items:center;gap:.5rem;padding:.6rem 1.4rem;font-size:.82rem;display:inline-flex}.hero-cta:hover{background:var(--accent);color:var(--bg)}.hero-scroll-hint{color:var(--text-muted);letter-spacing:.1em;margin-top:4rem;font-size:.7rem;animation:2s infinite bounce;display:block}.about-grid{grid-template-columns:1fr 1fr;align-items:start;gap:4rem;display:grid}@media (width<=640px){.about-grid{grid-template-columns:1fr;gap:2rem}}.about-heading{font-family:var(--font-serif);margin-bottom:1.5rem;font-size:clamp(1.8rem,4vw,2.8rem);font-style:italic;font-weight:300;line-height:1.2}.about-bio p{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem}.skills-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.75rem;font-size:.72rem}.skills-chips{flex-wrap:wrap;gap:.5rem;display:flex}.chip{border:1px solid var(--border);color:var(--text-secondary);background:var(--bg-card);letter-spacing:.04em;border-radius:99px;padding:.3rem .75rem;font-size:.75rem}.projects-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:2.5rem;display:flex}.projects-heading{font-family:var(--font-serif);font-size:clamp(1.8rem,4vw,2.8rem);font-style:italic;font-weight:300}.projects-github-link{color:var(--text-secondary);letter-spacing:.06em;border-bottom:1px solid var(--border);transition:color var(--ease);padding-bottom:1px;font-size:.78rem}.projects-github-link:hover{color:var(--text-primary)}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:inherit;transition:border-color var(--ease), transform var(--ease);flex-direction:column;gap:.75rem;padding:1.5rem;display:flex}.project-card:hover{border-color:var(--accent-dim);transform:translateY(-2px)}.project-name{letter-spacing:.02em;font-size:.9rem;font-weight:600}.project-desc{color:var(--text-secondary);flex:1;font-size:.8rem;line-height:1.6}.project-meta{color:var(--text-muted);gap:1rem;font-size:.72rem;display:flex}.project-lang:before{content:"◆ ";color:var(--accent-dim)}.project-stars:before{content:"★ "}.projects-loading{color:var(--text-muted);padding:2rem 0;font-size:.85rem}.projects-error{color:#e07070;padding:2rem 0;font-size:.85rem}.contact-heading{font-family:var(--font-serif);margin-bottom:1rem;font-size:clamp(1.8rem,4vw,2.8rem);font-style:italic;font-weight:300}.contact-sub{color:var(--text-secondary);max-width:480px;margin-bottom:2rem;font-size:.88rem}.contact-links{flex-wrap:wrap;gap:1rem;display:flex}.contact-link{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);letter-spacing:.04em;transition:border-color var(--ease), color var(--ease);align-items:center;gap:.5rem;padding:.65rem 1.2rem;font-size:.82rem;display:flex}.contact-link:hover{border-color:var(--accent);color:var(--accent)}.blog-list{flex-direction:column;gap:.5rem;display:flex}.blog-card{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);transition:border-color var(--ease), color var(--ease);grid-template-columns:120px 1fr auto;align-items:center;gap:1.5rem;padding:1rem 1.25rem;display:grid}.blog-card:hover{border-color:var(--accent-dim);color:var(--text-primary)}.blog-date{color:var(--text-muted);letter-spacing:.06em;font-size:.72rem}.blog-title{font-size:.88rem}.blog-arrow{color:var(--text-muted)}.footer{border-top:1px solid var(--border);color:var(--text-muted);letter-spacing:.06em;justify-content:space-between;padding:1.5rem 2rem;font-size:.72rem;display:flex}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}
