:root{--bg: #111827;--bg-secondary: #1f2937;--bg-card: #1f2937;--border: rgba(255, 255, 255, .1);--border-hover: rgba(132, 204, 22, .4);--primary: #84cc16;--primary-dim: rgba(132, 204, 22, .14);--primary-dim2: rgba(132, 204, 22, .28);--fg: #f9fafb;--fg-muted: #9ca3af;--fg-subtle: #6b7280;--radius: .75rem;--radius-sm: .5rem;--font: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg);color:var(--fg);font-family:var(--font);line-height:1.7;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}ul{list-style:none}.container{max-width:56rem;margin:0 auto;padding:0 1.5rem}.section{padding:5rem 0}.header{position:sticky;top:0;z-index:100;background:#111827e0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:3.5rem}.logo{font-weight:700;font-size:1rem;color:var(--fg);letter-spacing:-.01em}.logo span{color:var(--primary)}.nav{display:flex;align-items:center;gap:2rem}.nav-link{font-size:.875rem;color:var(--fg-muted);transition:color .2s;font-weight:500;background:none;border:none;cursor:pointer;font-family:inherit}.nav-link:hover,.nav-link.active{color:var(--fg)}.nav-cta{font-size:.875rem;font-weight:600;color:var(--primary);padding:.4rem .9rem;border:1px solid var(--primary-dim2);border-radius:var(--radius-sm);transition:background .2s,color .2s}.nav-cta:hover{background:var(--primary-dim)}.menu-toggle{display:none;background:none;border:none;color:var(--fg-muted);cursor:pointer;padding:.25rem;line-height:0}.menu-toggle svg{width:22px;height:22px}.mobile-nav{display:none;flex-direction:column;gap:0;border-top:1px solid var(--border);padding:.5rem 0}.mobile-nav.open{display:flex}.mobile-nav-link{padding:.75rem 1.5rem;font-size:.875rem;color:var(--fg-muted);transition:color .2s,background .2s;font-weight:500;display:block}.mobile-nav-link:hover{color:var(--fg);background:var(--bg-secondary)}.hero{padding:6rem 0 4rem}.hero-inner{display:flex;flex-direction:column;gap:2.5rem}.hero-avatar{width:10rem;height:10rem;border-radius:50%;border:none;object-fit:cover;background:var(--bg-secondary)}.hero-greeting{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}.hero-name{font-size:clamp(1.75rem,5vw,2.5rem);font-weight:800;letter-spacing:-.03em;line-height:1.15;color:var(--fg);margin-bottom:.5rem}.hero-title{font-size:1rem;color:var(--fg-muted);font-weight:500;margin-bottom:1rem}.hero-bio{font-size:.9375rem;color:var(--fg-muted);line-height:1.75;margin-bottom:1.5rem}.hero-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.hero-socials{display:flex;align-items:center;gap:.75rem;margin-top:1.25rem}.btn{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;padding:.55rem 1.25rem;border-radius:var(--radius-sm);transition:all .2s;cursor:pointer;border:none;font-family:inherit}.btn-primary{background:var(--primary);color:#000}.btn-primary:hover{background:#a3e635}.btn-outline{background:transparent;color:var(--fg-muted);border:1px solid var(--border)}.btn-outline:hover{color:var(--fg);border-color:#fff3;background:var(--bg-secondary)}.social-link{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;border:1px solid var(--border);color:var(--fg-muted);transition:all .2s}.social-link:hover{color:var(--primary);border-color:var(--primary-dim2);background:var(--primary-dim)}.social-link svg{width:16px;height:16px}.section-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.section-title{font-size:1.125rem;font-weight:700;letter-spacing:-.01em;white-space:nowrap;color:var(--fg)}.section-line{flex:1;height:1px;background:var(--border)}.edu-card{border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;background:var(--bg-card);transition:border-color .2s}.edu-card:hover{border-color:var(--border-hover)}.edu-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:.35rem}.edu-institution{font-weight:700;font-size:.9375rem;color:var(--fg)}.edu-degree{font-size:.875rem;color:var(--primary);font-weight:500;margin-top:.15rem}.edu-right{text-align:right}.edu-period{font-size:.8rem;color:var(--fg-subtle);font-weight:500}.edu-gpa{font-size:.8rem;font-weight:600;color:var(--primary);background:var(--primary-dim);padding:.15rem .55rem;border-radius:999px;margin-top:.25rem;display:inline-block}.edu-location{font-size:.8rem;color:var(--fg-subtle)}.skills-grid{display:flex;flex-wrap:wrap;gap:.5rem}.skill-badge{font-size:.8rem;font-weight:500;padding:.3rem .75rem;border-radius:999px;background:var(--primary-dim);color:var(--primary);border:1px solid rgba(132,204,22,.2);transition:background .2s}.skill-badge:hover{background:var(--primary-dim2)}.experience-list{display:flex;flex-direction:column}.exp-item{display:flex;gap:1.25rem;padding:1.5rem 0;border-bottom:1px solid var(--border)}.exp-item:last-child{border-bottom:none}.exp-dot-col{display:flex;flex-direction:column;align-items:center;padding-top:.35rem;flex-shrink:0}.exp-dot{width:10px;height:10px;border-radius:50%;background:var(--primary-dim2);border:2px solid var(--primary);flex-shrink:0}.exp-dot-line{width:1px;flex:1;min-height:2rem;background:var(--border);margin-top:.5rem}.exp-body{flex:1;min-width:0}.exp-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.25rem}.exp-company{font-weight:700;font-size:.9375rem;color:var(--fg);transition:color .2s}.exp-item:hover .exp-company{color:var(--primary)}.exp-period{font-size:.8rem;color:var(--fg-subtle);font-weight:500;white-space:nowrap}.exp-role{font-size:.875rem;color:var(--primary);font-weight:500;margin-bottom:.5rem}.exp-desc{font-size:.875rem;color:var(--fg-muted);line-height:1.7;margin-bottom:.75rem}.exp-tech{display:flex;flex-wrap:wrap;gap:.4rem}.tech-badge{font-size:.75rem;font-weight:500;padding:.2rem .55rem;border-radius:999px;background:var(--bg-secondary);color:var(--fg-muted);border:1px solid var(--border)}.projects-grid{display:grid;grid-template-columns:1fr;gap:1rem}.project-card{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--bg-card);transition:border-color .2s,transform .2s,box-shadow .2s;display:flex;flex-direction:column}.project-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:0 8px 32px #84cc160f}.project-image{width:100%;height:11rem;object-fit:cover;background:var(--bg-secondary)}.project-body{padding:1.25rem;flex:1;display:flex;flex-direction:column;gap:.5rem}.project-title{font-size:.9375rem;font-weight:700;color:var(--fg)}.project-desc{font-size:.8125rem;color:var(--fg-muted);line-height:1.65;flex:1}.project-tech{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.25rem}.project-highlights{list-style:none;display:flex;flex-direction:column;gap:.3rem;margin-top:.5rem}.project-highlight-item{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--primary);font-weight:500}.highlight-dot{width:5px;height:5px;border-radius:50%;background:var(--primary);flex-shrink:0}.project-links{display:flex;align-items:center;gap:.75rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.project-link{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:500;color:var(--fg-muted);transition:color .2s}.project-link svg{width:14px;height:14px}.project-link:hover{color:var(--primary)}.projects-toggle{display:flex;justify-content:center;margin-top:2rem}.blog-list{display:flex;flex-direction:column}.blog-item{display:flex;gap:1.25rem;padding:1.25rem 0;border-bottom:1px solid var(--border);transition:all .2s;cursor:pointer}.blog-item:last-child{border-bottom:none}.blog-item:hover .blog-item-title{color:var(--primary)}.blog-item-img{width:4.5rem;height:4.5rem;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;background:var(--bg-secondary)}.blog-item-body{flex:1;min-width:0}.blog-item-meta{display:flex;align-items:center;gap:.75rem;margin-bottom:.35rem}.blog-item-date,.blog-item-read{font-size:.75rem;color:var(--fg-subtle);font-weight:500}.blog-item-title{font-size:.9375rem;font-weight:600;color:var(--fg);margin-bottom:.25rem;transition:color .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.blog-item-excerpt{font-size:.8125rem;color:var(--fg-muted);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}.blog-tag{font-size:.7rem;font-weight:500;padding:.15rem .5rem;border-radius:999px;background:var(--bg-secondary);color:var(--fg-subtle);border:1px solid var(--border)}.view-all{display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;font-weight:500;color:var(--primary);transition:gap .2s;white-space:nowrap}.view-all:hover{gap:.65rem}.view-all svg{width:16px;height:16px}.footer{border-top:1px solid var(--border);padding:2rem 0}.footer-inner{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.footer-text{font-size:.8125rem;color:var(--fg-subtle)}.footer-text a{color:var(--fg-muted);transition:color .2s}.footer-text a:hover{color:var(--primary)}.blog-page-hero{padding:4rem 0 2.5rem}.blog-page-title{font-size:clamp(1.5rem,4vw,2rem);font-weight:800;letter-spacing:-.03em;color:var(--fg);margin-bottom:.5rem}.blog-page-sub{font-size:.9375rem;color:var(--fg-muted)}.blog-filter{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.filter-btn{font-size:.8rem;font-weight:500;padding:.35rem .85rem;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--fg-muted);cursor:pointer;transition:all .2s;font-family:inherit}.filter-btn:hover,.filter-btn.active{background:var(--primary-dim);color:var(--primary);border-color:var(--primary-dim2)}.blog-grid{display:grid;grid-template-columns:1fr;gap:1.25rem;padding-bottom:5rem}.blog-card{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--bg-card);transition:border-color .2s,transform .2s,box-shadow .2s;display:flex;flex-direction:column;cursor:pointer}.blog-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:0 8px 32px #84cc160f}.blog-card:hover .blog-card-title{color:var(--primary)}.blog-card-img{width:100%;height:10rem;object-fit:cover;background:var(--bg-secondary)}.blog-card-body{padding:1.25rem;flex:1;display:flex;flex-direction:column;gap:.4rem}.blog-card-meta{display:flex;align-items:center;gap:.6rem;font-size:.75rem;color:var(--fg-subtle)}.blog-card-title{font-size:.9375rem;font-weight:700;color:var(--fg);line-height:1.45;transition:color .2s}.blog-card-excerpt{font-size:.8125rem;color:var(--fg-muted);line-height:1.65;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.blog-card-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.25rem}.post-back{display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;color:var(--fg-muted);margin-bottom:2rem;transition:color .2s}.post-back:hover{color:var(--primary)}.post-back svg{width:16px;height:16px}.post-hero{padding:3rem 0 2rem}.post-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.post-tag{font-size:.75rem;font-weight:600;padding:.25rem .65rem;border-radius:999px;background:var(--primary-dim);color:var(--primary);border:1px solid rgba(132,204,22,.2)}.post-title{font-size:clamp(1.5rem,5vw,2.25rem);font-weight:800;letter-spacing:-.03em;line-height:1.2;color:var(--fg);margin-bottom:1rem}.post-meta{display:flex;align-items:center;gap:1rem;font-size:.8125rem;color:var(--fg-subtle);margin-bottom:1.5rem}.post-meta-item{display:inline-flex;align-items:center;gap:.35rem}.post-meta-item svg{width:14px;height:14px}.post-cover{width:100%;height:20rem;object-fit:cover;border-radius:var(--radius);margin-bottom:2.5rem;border:1px solid var(--border)}.post-content{font-size:1rem;color:var(--fg-muted);line-height:1.8;max-width:68ch;padding-bottom:4rem}.post-content h1,.post-content h2,.post-content h3{color:var(--fg);font-weight:700;letter-spacing:-.02em;margin:2rem 0 .75rem;line-height:1.3}.post-content h1{font-size:1.75rem}.post-content h2{font-size:1.375rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.post-content h3{font-size:1.125rem}.post-content p{margin-bottom:1.25rem}.post-content a{color:var(--primary);text-decoration:underline;text-underline-offset:3px;text-decoration-color:#84cc1666}.post-content a:hover{text-decoration-color:var(--primary)}.post-content code{font-family:var(--font-mono);font-size:.85em;background:var(--bg-secondary);color:var(--primary);padding:.15em .4em;border-radius:.3rem;border:1px solid var(--border)}.post-content pre{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:1.25rem 1.5rem;overflow-x:auto;margin:1.5rem 0;font-family:var(--font-mono);font-size:.875rem;line-height:1.7}.post-content pre code{background:none;border:none;padding:0;color:var(--fg);font-size:inherit}.post-content ul,.post-content ol{margin:1rem 0 1.25rem 1.5rem}.post-content ul{list-style:disc}.post-content ol{list-style:decimal}.post-content li{margin-bottom:.35rem}.post-content blockquote{border-left:3px solid var(--primary);padding:.5rem 0 .5rem 1.25rem;margin:1.5rem 0;color:var(--fg-muted);background:var(--primary-dim);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.post-content strong{color:var(--fg);font-weight:600}.post-content hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.post-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border);padding-bottom:5rem}.post-nav{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.project-card-link{display:block}.project-title-link{text-decoration:none}.project-title-link:hover .project-title{color:var(--primary)}.project-detail{padding-top:3rem;padding-bottom:5rem}.pd-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;flex-wrap:wrap;margin-bottom:1.25rem}.pd-title{font-size:clamp(1.5rem,4vw,2.25rem);font-weight:800;letter-spacing:-.03em;color:var(--fg);margin-bottom:.5rem}.pd-short-desc{font-size:.9375rem;color:var(--fg-muted);max-width:60ch;line-height:1.7}.pd-links{display:flex;gap:.75rem;flex-shrink:0;flex-wrap:wrap}.pd-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.pd-gallery{margin-bottom:3rem}.pd-gallery-main{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--bg-secondary);margin-bottom:.75rem}.pd-gallery-img{width:100%;height:22rem;object-fit:cover;display:block;transition:opacity .2s}@media(min-width:640px){.pd-gallery-img{height:30rem}}.pd-gallery-thumbs{display:flex;gap:.6rem;flex-wrap:wrap}.pd-thumb{width:5.5rem;height:3.75rem;border-radius:var(--radius-sm);overflow:hidden;border:2px solid var(--border);background:none;padding:0;cursor:pointer;transition:border-color .2s;flex-shrink:0}.pd-thumb img{width:100%;height:100%;object-fit:cover;display:block}.pd-thumb.active{border-color:var(--primary)}.pd-thumb:hover{border-color:var(--primary-dim2)}.pd-body{display:flex;gap:2.5rem;align-items:flex-start}.pd-main{flex:1;min-width:0}.pd-section{margin-bottom:2.5rem}.pd-section-title{font-size:1rem;font-weight:700;color:var(--fg);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.pd-para{font-size:.9375rem;color:var(--fg-muted);line-height:1.8;margin-bottom:1rem}.pd-features{display:flex;flex-direction:column;gap:.75rem}.pd-feature-card{padding:1rem 1.25rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);transition:border-color .2s}.pd-feature-card:hover{border-color:var(--border-hover)}.pd-feature-title{font-size:.875rem;font-weight:600;color:var(--fg);margin-bottom:.3rem}.pd-feature-desc{font-size:.8125rem;color:var(--fg-muted);line-height:1.65}.pd-sidebar{width:16rem;flex-shrink:0}.pd-sidebar-card{border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;background:var(--bg-card);position:sticky;top:5rem}.pd-sidebar-title{font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-subtle);margin-bottom:1rem}.pd-impact-list{display:flex;flex-direction:column;gap:.65rem}.pd-impact-item{display:flex;align-items:flex-start;gap:.6rem;font-size:.8125rem;color:var(--primary);font-weight:500;line-height:1.5}.pd-impact-item .highlight-dot{margin-top:.4rem;flex-shrink:0}@media(max-width:768px){.pd-body{flex-direction:column}.pd-sidebar{width:100%}.pd-sidebar-card{position:static}}.fade-up{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}.fade-up.visible{opacity:1;transform:translateY(0)}@media(min-width:640px){.hero-inner{flex-direction:row;align-items:center;gap:3rem}.hero-avatar{width:13rem;height:13rem}.projects-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}.post-cover{height:26rem}}@media(max-width:640px){.nav{display:none}.menu-toggle{display:block}.hero{padding:3.5rem 0 2.5rem}.section{padding:3.5rem 0}.blog-item-img{width:3.5rem;height:3.5rem}.post-cover{height:14rem}}[id]{scroll-margin-top:5rem}
