@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;600;700&family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg:#0a0a0a;--surface:#111;--surface-2:#161616;--border:#1e1e1e;--border-light:#2a2a2a;--green:#22c55e;--green-dim:#16a34a;--green-glow:#22c55e26;--red:#ef4444;--red-dim:#dc2626;--red-glow:#ef444426;--text:#f0f0f0;--text-muted:#6b7280;--text-dim:#374151;--font-body:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Courier New", monospace;--radius:8px;--radius-lg:16px;--shadow:0 4px 24px #0006;--shadow-lg:0 8px 48px #0009;--nav-height:64px;--transition:.2s ease;--transition-slow:.35s cubic-bezier(.4,0,.2,1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font:inherit;background:0 0;border:none}ul{list-style:none}code,pre{font-family:var(--font-mono)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px}.accent-red{color:var(--red)}.mono{font-family:var(--font-mono)}.container{max-width:1100px;margin:0 auto;padding:0 1.5rem}.section{padding:96px 0}.section-dark{background:var(--surface)}.section-header{text-align:center;margin-bottom:3rem}.section-tag{font-family:var(--font-mono);color:var(--green);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.5rem;font-size:.75rem;display:block}.section-title{letter-spacing:-.02em;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700}.section-subtitle{color:var(--text-muted);margin-top:.75rem;font-size:1rem}.btn-primary{background:var(--green);color:#000;border-radius:var(--radius);transition:background var(--transition), transform var(--transition);align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary:hover{background:var(--green-dim);transform:translateY(-1px)}.btn-outline{border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text);transition:border-color var(--transition), background var(--transition), transform var(--transition);align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:500;display:inline-flex}.btn-outline:hover{border-color:var(--green);background:var(--green-glow);transform:translateY(-1px)}.btn-ghost{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);transition:color var(--transition), border-color var(--transition);align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:500;display:inline-flex}.btn-ghost:hover{color:var(--text);border-color:var(--border-light)}.tag{background:var(--surface-2);border:1px solid var(--border);font-size:.72rem;font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;border-radius:4px;padding:.2rem .6rem;display:inline-block}.tag-green{border-color:var(--green-dim);color:var(--green);background:var(--green-glow)}.tag-red{border-color:var(--red-dim);color:var(--red);background:var(--red-glow)}.spinner{border:2px solid var(--border-light);border-top-color:var(--green);border-radius:50%;width:32px;height:32px;margin:0 auto 1rem;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.drawer-overlay{z-index:200;opacity:0;background:#000000b3;animation:.2s forwards fadeIn;position:fixed;inset:0}@keyframes fadeIn{to{opacity:1}}@media (width<=768px){.section{padding:64px 0}.section-header{margin-bottom:2rem}}.navbar{z-index:100;height:var(--nav-height);-webkit-backdrop-filter:blur(16px);transition:background var(--transition-slow), border-color var(--transition-slow), box-shadow var(--transition-slow), backdrop-filter var(--transition-slow);background:#161616bf;border-bottom:1px solid #22c55e1a;position:fixed;top:0;left:0;right:0}.navbar.scrolled{background:#121212e6;border-bottom:1px solid #22c55e33;box-shadow:0 10px 30px -10px #000000b3}.nav-inner{align-items:center;max-width:1100px;height:100%;margin:0 auto;padding:0 1.5rem;display:flex}.nav-logo{font-family:var(--font-mono);letter-spacing:-.03em;flex-shrink:0;margin-right:auto;font-size:1.2rem;font-weight:700}.nav-links{align-items:center;gap:.25rem;margin-right:1rem;display:flex}.nav-link{height:36px;font-size:.875rem;font-family:var(--font-body);color:var(--text-muted);border-radius:var(--radius);cursor:pointer;transition:color var(--transition), background var(--transition);white-space:nowrap;background:0 0;border:none;align-items:center;padding:0 .75rem;line-height:1;display:inline-flex}.nav-link:hover{color:var(--text);background:var(--surface)}.nav-link.active{color:var(--green)}.hamburger{border-radius:var(--radius);flex-direction:column;flex-shrink:0;justify-content:center;gap:5px;margin-left:.75rem;padding:8px;display:none}.hamburger span{background:var(--text);width:22px;height:2px;transition:transform var(--transition), opacity var(--transition);border-radius:1px;display:block}.hamburger.open span:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-menu{top:var(--nav-height);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);opacity:0;pointer-events:none;transition:transform var(--transition-slow), opacity var(--transition-slow);z-index:99;background:#0a0a0af7;flex-direction:column;gap:.15rem;padding:.75rem 1.5rem 1.25rem;display:flex;position:fixed;left:0;right:0;transform:translateY(-110%)}.mobile-menu.open{opacity:1;pointer-events:auto;transform:translateY(0)}.mobile-menu a,.mobile-nav-btn{width:100%;font-size:.95rem;font-family:var(--font-body);color:var(--text-muted);border-radius:var(--radius);text-align:left;cursor:pointer;transition:color var(--transition), background var(--transition);background:0 0;border:none;padding:.7rem 1rem;line-height:1.4;display:block}.mobile-menu a:hover,.mobile-nav-btn:hover{color:var(--text);background:var(--surface)}@media (width<=768px){.nav-links,.nav-resume{display:none}.hamburger{display:flex}}.hero{min-height:100svh;padding:calc(var(--nav-height) + 2rem) 1.5rem 4rem;justify-content:center;align-items:center;display:flex}.hero-terminal{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-lg);background:#1e1e2099;border:1px solid #ffffff14;width:100%;max-width:800px;overflow:hidden;box-shadow:0 20px 40px #0006}.terminal-header{background:#ffffff08;border-bottom:1px solid #ffffff0d;align-items:center;gap:.5rem;padding:.8rem 1rem;display:flex}.t-dot{border-radius:50%;width:12px;height:12px}.t-dot-red{background:#ff5f57}.t-dot-yellow{background:#febc2e}.t-dot-green{background:#28c840}.terminal-body{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;padding:3rem 2.5rem;display:flex}.hero-name{letter-spacing:-.03em;margin:0;font-size:clamp(2.5rem,6vw,4rem);font-weight:700;line-height:1.1}.accent-green{color:var(--green)}.hero-roles{font-family:var(--font-mono);color:var(--text);min-height:1.5em;margin:0;font-size:clamp(1rem,2.5vw,1.25rem)}.cursor{background:var(--green);vertical-align:middle;width:2px;height:1.1em;margin-left:4px;animation:1s step-end infinite blink;display:inline-block}.hero-bio{color:var(--text-muted);max-width:600px;margin:0;font-size:1.15rem;line-height:1.6}.hero-cta{flex-wrap:wrap;gap:1rem;margin-top:1rem;display:flex}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@media (width<=600px){.terminal-body{gap:1.25rem;padding:2rem 1.5rem}.hero-bio{font-size:1rem}.hero-cta{flex-direction:column;width:100%}.hero-cta a{text-align:center;justify-content:center;width:100%}}.about-text-center{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;max-width:800px;margin:0 auto;display:flex}.about-paragraph{color:var(--text-muted);font-size:1.15rem;line-height:1.8}.about-footer{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:.5rem;display:flex}.about-footer .btn-outline{width:fit-content}.experience-list{flex-direction:column;gap:1.5rem;max-width:800px;margin:0 auto;display:flex}.experience-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition);padding:1.5rem 2rem}.experience-card:hover{border-color:var(--green)}.exp-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.25rem;display:flex}.exp-title-row{flex-wrap:wrap;align-items:baseline;gap:.5rem;display:flex}.exp-title-row h4{color:var(--green);margin:0;font-size:1.15rem;font-weight:600}.exp-company-name{color:var(--text);font-size:1.05rem;font-weight:500}.exp-date{font-size:.85rem;font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap}.exp-location{color:var(--text-muted);margin-top:.25rem;margin-bottom:1rem;font-size:.85rem}.exp-bullets{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.exp-bullets li{color:var(--text-muted);padding-left:1.25rem;font-size:.95rem;line-height:1.6;position:relative}.exp-bullets li:before{content:"▹";color:var(--green);position:absolute;left:0}@media (width<=600px){.experience-card{padding:1.25rem}.exp-header{flex-direction:column;align-items:flex-start;gap:.25rem}}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.skill-group{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.4rem}.skill-group-title{font-size:.78rem;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;margin-bottom:.85rem}.skill-tags{flex-wrap:wrap;gap:.4rem;display:flex}@media (width<=640px){.skills-grid{grid-template-columns:1fr}}.contact-grid{grid-template-columns:1fr 1fr;align-items:start;gap:2rem;display:grid}.contact-links{flex-direction:column;gap:.75rem;display:flex}.contact-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition), transform var(--transition);align-items:center;gap:1rem;padding:1.1rem 1.25rem;display:flex}.contact-card:hover{border-color:var(--green);transform:translate(4px)}.contact-icon{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);width:40px;height:40px;color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;display:flex}.contact-info{flex:1}.contact-info h4{font-size:.9rem;font-weight:600}.contact-info p{color:var(--text-muted);font-size:.8rem}.contact-arrow{color:var(--text-dim);font-size:1.1rem}.contact-card:hover .contact-arrow{color:var(--green)}.note-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}.note-tag{font-family:var(--font-mono);color:var(--text-dim);margin-bottom:1rem;font-size:.75rem}.note-list{flex-direction:column;gap:.6rem;display:flex}.note-list li{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.9rem;display:flex}.site-footer{border-top:1px solid var(--border);padding:1.5rem 0}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.footer-copy{color:var(--text-dim);font-size:.8rem}.footer-link{color:var(--text-dim);transition:color var(--transition);font-size:.8rem}.footer-link:hover{color:var(--text-muted)}@media (width<=768px){.contact-grid{grid-template-columns:1fr}}.drawer-backdrop{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#000000b3;animation:.2s fadeIn;position:fixed;inset:0}.drawer{background:var(--surface-2);border-left:1px solid var(--border);z-index:201;width:min(520px,100vw);transition:transform var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-8px 0 48px #00000080}.drawer.open{transform:translate(0)}.drawer-header{background:var(--surface-2);border-bottom:1px solid var(--border);z-index:1;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex;position:sticky;top:0}.drawer-title{font-size:1.1rem;font-weight:600}.drawer-close{border-radius:var(--radius);width:32px;height:32px;color:var(--text-muted);transition:background var(--transition), color var(--transition);justify-content:center;align-items:center;font-size:1.2rem;display:flex}.drawer-close:hover{background:var(--surface);color:var(--text)}.drawer-body{flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex}.drawer-screenshot{border-radius:var(--radius);object-fit:contain;border:1px solid var(--border);background:var(--surface);width:100%;max-height:400px;display:block}.drawer-screenshot-placeholder{aspect-ratio:16/9;border-radius:var(--radius);border:1px dashed var(--border-light);width:100%;color:var(--text-dim);font-size:.8rem;font-family:var(--font-mono);background:var(--surface);justify-content:center;align-items:center;display:flex}.drawer-tags{flex-wrap:wrap;gap:.4rem;display:flex}.drawer-section-label{font-size:.7rem;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.4rem}.drawer-description{color:var(--text-muted);font-size:.9rem;line-height:1.75}.drawer-features{flex-direction:column;gap:.5rem;display:flex}.drawer-feature{color:var(--text-muted);align-items:baseline;gap:.6rem;font-size:.875rem;display:flex}.drawer-feature:before{content:"→";color:var(--green);font-family:var(--font-mono);flex-shrink:0}.drawer-cta{flex-wrap:wrap;gap:.75rem;padding-top:.25rem;display:flex}.drawer-cta a{text-align:center;flex:1;justify-content:center;min-width:140px}@media (width<=540px){.drawer{border-left:none;border-top:1px solid var(--border);width:100vw}}.filter-bar{flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:2rem;display:flex}.filter-btn{border:1px solid var(--border);font-size:.82rem;font-family:var(--font-mono);color:var(--text-muted);transition:all var(--transition);border-radius:100px;padding:.4rem 1rem}.filter-btn:hover{border-color:var(--green);color:var(--text)}.filter-btn.active{background:var(--green);border-color:var(--green);color:#000;font-weight:600}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;display:grid}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--transition), transform var(--transition), box-shadow var(--transition);flex-direction:column;gap:.75rem;padding:1.4rem;display:flex;position:relative;overflow:hidden}.project-card:before{content:"";background:var(--green);opacity:0;height:2px;transition:opacity var(--transition);position:absolute;top:0;left:0;right:0}.project-card:hover{border-color:var(--border-light);transform:translateY(-3px);box-shadow:0 8px 32px #0000004d}.project-card:hover:before{opacity:1}.project-card-top{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.project-name{font-size:1rem;font-weight:600}.project-lang-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:4px}.project-tagline{color:var(--text-muted);flex:1;font-size:.85rem;line-height:1.6}.project-tags{flex-wrap:wrap;gap:.35rem;display:flex}.project-card-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:auto;padding-top:.25rem;display:flex}.project-open-hint{font-size:.75rem;font-family:var(--font-mono);color:var(--text-dim)}.project-gh-link{color:var(--text-muted);border:1px solid var(--border);transition:all var(--transition);border-radius:4px;padding:.2rem .5rem;font-size:.75rem}.project-gh-link:hover{color:var(--green);border-color:var(--green)}.projects-footer{text-align:center;margin-top:2.5rem}.loading-state{text-align:center;color:var(--text-muted);grid-column:1/-1;padding:3rem}@media (width<=640px){.projects-grid{grid-template-columns:1fr}}.featured-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:2rem;display:flex}.featured-see-all{white-space:nowrap}@media (width<=520px){.featured-header{flex-direction:column;align-items:flex-start}}.blog-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;display:grid}.blog-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--transition), transform var(--transition);flex-direction:column;gap:.75rem;padding:1.4rem;display:flex}.blog-card:hover{border-color:var(--green);transform:translateY(-2px)}.blog-card-meta{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.blog-date{font-family:var(--font-mono);color:var(--text-dim);font-size:.72rem}.blog-tags{flex-wrap:wrap;gap:.35rem;display:flex}.blog-card h3{font-size:1rem;font-weight:600;line-height:1.4}.blog-excerpt{color:var(--text-muted);flex:1;font-size:.85rem;line-height:1.7}.blog-read-more{font-size:.78rem;font-family:var(--font-mono);color:var(--green);margin-top:auto}.blog-post-date{font-family:var(--font-mono);color:var(--text-muted);font-size:.75rem}.blog-post-body{color:var(--text-muted);font-size:.9rem;line-height:1.85}.blog-post-body h3{color:var(--text);margin:1.25rem 0 .5rem;font-size:.95rem;font-weight:600}.blog-post-body p{margin-bottom:.75rem}.blog-post-body ul{margin-bottom:.75rem;padding-left:1rem}.blog-post-body li{margin-bottom:.4rem}.blog-post-body pre{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin:.75rem 0;padding:.85rem 1rem;font-size:.8rem;overflow-x:auto}.blog-post-body code{background:var(--surface);color:var(--green);border-radius:3px;padding:.1em .35em;font-size:.85em}.blog-post-body strong{color:var(--text)}@media (width<=640px){.blog-grid{grid-template-columns:1fr}}.latest-blog-card{max-width:640px}.page-hero{padding:calc(var(--nav-height) + 3rem) 0 2.5rem;border-bottom:1px solid var(--border)}.page-hero-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem}.page-title{letter-spacing:-.02em;margin-bottom:.4rem;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700}.page-subtitle{color:var(--text-muted);font-size:.95rem}.page-body{max-width:1100px;margin:0 auto;padding:3rem 1.5rem}
