:root{--black:#0a0a0a;--white:#fff;--grey-50:#f8f8f8;--grey-100:#f0f0f0;--grey-200:#e0e0e0;--grey-400:#aaa;--grey-600:#666;--grey-800:#333;--max-width:960px;--spacing-xs:.5rem;--spacing-sm:1rem;--spacing-md:2rem;--spacing-lg:4rem;--spacing-xl:6rem;--font-mono:"JetBrains Mono", "Fira Code", "Courier New", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background-color:var(--white);color:var(--black);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}a:hover{text-underline-offset:3px;text-decoration:underline}img{max-width:100%;display:block}ul{list-style:none}.container{max-width:var(--max-width);padding:0 var(--spacing-md);margin:0 auto}.section{padding:var(--spacing-xl) 0;border-top:1px solid var(--grey-200)}.section-label{letter-spacing:.15em;text-transform:uppercase;color:var(--grey-400);margin-bottom:var(--spacing-md);font-size:.7rem;font-weight:600;font-family:var(--font-mono)}h1,h2,h3,h4{letter-spacing:-.02em;font-weight:600;line-height:1.2}@media (width<=640px){.container{padding:0 var(--spacing-sm)}.section{padding:var(--spacing-lg) 0}}.header{z-index:100;background-color:var(--white);border-bottom:1px solid var(--grey-200);position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;height:56px;display:flex}.header-logo{letter-spacing:-.01em;color:var(--black);font-size:.95rem;font-weight:600}.header-logo:hover{text-decoration:none}.header-nav{align-items:center;gap:var(--spacing-md);display:flex}.header-nav a{color:var(--grey-600);font-size:.85rem;transition:color .15s}.header-nav a:hover{color:var(--black);text-decoration:none}@media (width<=480px){.header-nav{gap:var(--spacing-sm)}.header-nav .hide-mobile{display:none}}.hero{padding:var(--spacing-xl) 0}.hero-name{letter-spacing:-.03em;margin-bottom:var(--spacing-sm);color:var(--black);font-size:clamp(2.5rem,7vw,4.5rem);font-weight:700;line-height:1}.hero-title{color:var(--grey-600);margin-bottom:var(--spacing-md);font-size:clamp(1rem,2.5vw,1.25rem);font-weight:400}.hero-tagline{color:var(--grey-600);max-width:520px;margin-bottom:var(--spacing-lg);font-size:1rem;line-height:1.7}.hero-links{gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.hero-link{color:var(--black);justify-content:center;align-items:center;padding:.25rem;transition:opacity .15s;display:inline-flex}.hero-link:hover{opacity:.5;text-decoration:none}.hero-link svg{flex-shrink:0;width:20px;height:20px}@media (width<=640px){.hero{padding:var(--spacing-lg) 0}}.about-content{max-width:640px}.about-content p{color:var(--grey-800);font-size:1.05rem;line-height:1.75}.about-meta{margin-top:var(--spacing-md);color:var(--grey-400);font-size:.875rem;font-family:var(--font-mono);align-items:center;gap:.5rem;display:flex}.projects-grid{background-color:var(--grey-200);border:1px solid var(--grey-200);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1px;display:grid}.project-card{background-color:var(--white);padding:var(--spacing-md);transition:background-color .15s}.project-card:hover{background-color:var(--grey-50)}.project-name{font-size:.95rem;font-weight:600;font-family:var(--font-mono);margin-bottom:var(--spacing-xs);align-items:center;gap:.5rem;display:flex}.project-name a{color:var(--black)}.project-name a:hover{text-underline-offset:3px;text-decoration:underline}.project-description{color:var(--grey-600);margin-bottom:var(--spacing-sm);font-size:.875rem;line-height:1.65}.project-footer{align-items:center;gap:var(--spacing-sm);display:flex}.project-lang{font-size:.75rem;font-family:var(--font-mono);color:var(--grey-400)}.project-stars{color:var(--grey-400);align-items:center;gap:.25rem;font-size:.75rem;display:flex}@media (width<=640px){.projects-grid{grid-template-columns:1fr}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg, var(--grey-100) 25%, var(--grey-200) 50%, var(--grey-100) 75%);background-size:200% 100%;border-radius:2px;animation:1.4s ease-in-out infinite shimmer}.skeleton--title{width:60%;height:14px;margin-bottom:.75rem}.skeleton--line{width:100%;height:11px;margin-bottom:.4rem}.skeleton--short{width:75%}.skeleton--tag{width:20%;height:11px;margin-top:.75rem}.project-card--skeleton{pointer-events:none}.projects-error{color:var(--grey-600);padding:var(--spacing-md) 0;font-size:.9rem}.projects-error a{color:var(--black);text-underline-offset:3px;text-decoration:underline}.built-list{border:1px solid var(--grey-200);background-color:var(--grey-200);gap:1px;display:grid}.built-item{background-color:var(--white)}.built-link{justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);display:flex}.built-link:hover{background-color:var(--grey-50);text-decoration:none}.built-name{font-size:.95rem;font-weight:600;font-family:var(--font-mono)}.built-url{color:var(--grey-400);font-size:.8rem;font-family:var(--font-mono);text-align:right}@media (width<=640px){.built-link{flex-direction:column;align-items:flex-start}.built-url{text-align:left}}.resume-grid{gap:var(--spacing-lg);grid-template-columns:1fr 1fr;display:grid}.resume-block-title{color:var(--black);margin-bottom:var(--spacing-sm);font-size:.875rem;font-weight:600}.resume-tags{flex-wrap:wrap;gap:.5rem;display:flex}.resume-tag{font-size:.8rem;font-family:var(--font-mono);color:var(--grey-800);background-color:var(--grey-100);border-radius:2px;padding:.3rem .65rem}.resume-experience{list-style:none}.resume-experience-item{padding:var(--spacing-sm) 0;border-bottom:1px solid var(--grey-100)}.resume-experience-item:last-child{border-bottom:none}.resume-experience-header{flex-direction:column;gap:.15rem;margin-bottom:.25rem;display:flex}.resume-experience-role{color:var(--black);font-size:.9rem;font-weight:600}.resume-experience-company{color:var(--grey-600);font-size:.85rem}.resume-experience-meta{font-size:.75rem;font-family:var(--font-mono);color:var(--grey-400)}@media (width<=640px){.resume-grid{gap:var(--spacing-md);grid-template-columns:1fr}}.footer{border-top:1px solid var(--grey-200);padding:var(--spacing-lg) 0}.footer-inner{justify-content:space-between;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.footer-copy{color:var(--grey-400);font-size:.8rem;font-family:var(--font-mono)}.footer-links{gap:var(--spacing-md);display:flex}.footer-links a{color:var(--grey-400);font-size:.8rem;transition:color .15s}.footer-links a:hover{color:var(--black);text-decoration:none}@media (width<=480px){.footer-inner{flex-direction:column;align-items:flex-start}}.post{padding:var(--spacing-xl) 0}.post-not-found{padding:var(--spacing-xl) 0;color:var(--grey-600)}.post-not-found a{color:var(--black);font-size:.875rem}.post-nav{margin-bottom:var(--spacing-lg)}.post-back{color:var(--grey-400);font-size:.85rem;transition:color .15s}.post-back:hover{color:var(--black);text-decoration:none}.post-header{max-width:680px;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--grey-200)}.post-date{font-size:.75rem;font-family:var(--font-mono);color:var(--grey-400);margin-bottom:var(--spacing-sm);display:block}.post-title{letter-spacing:-.03em;margin-bottom:var(--spacing-sm);color:var(--black);font-size:clamp(1.5rem,4vw,2.25rem);font-weight:700;line-height:1.15}.post-summary{color:var(--grey-600);font-size:1rem;line-height:1.7}.post-body{max-width:680px}.post-body p{color:var(--grey-800);margin-bottom:var(--spacing-sm);font-size:1rem;line-height:1.8}.post-body h2{letter-spacing:-.02em;color:var(--black);margin-top:var(--spacing-lg);margin-bottom:var(--spacing-xs);font-size:1.15rem;font-weight:600}.post-body h3{color:var(--black);margin-top:var(--spacing-md);margin-bottom:var(--spacing-xs);font-size:1rem;font-weight:600}.post-body ul{margin-bottom:var(--spacing-sm);padding-left:var(--spacing-sm)}.post-body ul li{color:var(--grey-800);margin-bottom:.25rem;font-size:1rem;line-height:1.8;list-style:outside}.post-body pre{background-color:var(--grey-50);border:1px solid var(--grey-200);padding:var(--spacing-sm);margin-bottom:var(--spacing-sm);border-radius:2px;position:relative;overflow-x:auto}.post-body pre[data-lang]:before{content:attr(data-lang);font-size:.7rem;font-family:var(--font-mono);color:var(--grey-400);letter-spacing:.05em;text-transform:uppercase;margin-bottom:.5rem;display:block}.post-body code{font-family:var(--font-mono);color:var(--black);white-space:pre;font-size:.82rem;line-height:1.7}.post-note{border-left:2px solid var(--grey-200);padding-left:var(--spacing-sm);margin-bottom:var(--spacing-sm);color:var(--grey-600);font-size:.875rem;line-height:1.7}@media (width<=640px){.post{padding:var(--spacing-lg) 0}}.skip-link{background-color:var(--black);color:var(--white);z-index:9999;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;transition:top .15s;position:absolute;top:-100%;left:0}.skip-link:focus{text-decoration:none;top:0}
