@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=JetBrains+Mono:wght@300;400;500&display=swap";
:root{--bg:#f5f4f0;--bg-secondary:#eceae4;--bg-card:#fff;--text-primary:#0d0d0d;--text-secondary:#4a4a4a;--text-muted:#888;--accent:#096;--accent-rgb:0, 153, 102;--accent-glow:#00996626;--accent-subtle:#00996614;--border:#0000001a;--border-strong:#0003;--shadow:0 4px 24px #00000014;--shadow-hover:0 8px 40px #00000024;--tag-bg:#0099661a;--tag-text:#075;--nav-bg:#f5f4f0d9;--hero-overlay:#f5f4f099}@media (prefers-color-scheme:dark){:root{--bg:#080c0a;--bg-secondary:#0f1410;--bg-card:#111915;--text-primary:#eef2ee;--text-secondary:#a8b8a8;--text-muted:#565;--accent:#0fa;--accent-rgb:0, 255, 170;--accent-glow:#0fa3;--accent-subtle:#00ffaa0f;--border:#00ffaa14;--border-strong:#0fa3;--shadow:0 4px 24px #0006;--shadow-hover:0 8px 40px #00ffaa1f;--tag-bg:#00ffaa14;--tag-text:#0fa;--nav-bg:#080c0ad9;--hero-overlay:#080c0a66}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background-color:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Outfit,sans-serif;line-height:1.6;transition:background-color .3s,color .3s;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}ul{list-style:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:2px}h1,h2,h3,h4,h5{letter-spacing:-.03em;font-family:Outfit,sans-serif;font-weight:700;line-height:1.1}code,.mono{font-family:JetBrains Mono,monospace;font-size:.875em}.container{max-width:1100px;margin:0 auto;padding:0 2rem}.section{padding:7rem 0}.section-label{color:var(--accent);text-transform:uppercase;letter-spacing:.12em;align-items:center;gap:.6rem;margin-bottom:1.2rem;font-family:Fira Code,monospace;font-size:.78rem;font-weight:500;display:inline-flex}.section-label:before{content:"";background:var(--accent);width:2rem;height:1px;display:inline-block}.section-title{color:var(--text-primary);margin-bottom:1rem;font-size:clamp(2rem,4vw,3rem)}.section-desc{color:var(--text-secondary);max-width:520px;font-size:1.05rem;line-height:1.7}.navbar{z-index:100;transition:background .4s,-webkit-backdrop-filter .4s,backdrop-filter .4s,border-color .4s;position:fixed;top:0;left:0;right:0}.navbar-inner{justify-content:space-between;align-items:center;max-width:1100px;height:64px;margin:0 auto;padding:0 2rem;display:flex}.navbar.top{-webkit-backdrop-filter:none;background:0 0;border-bottom:1px solid #0000}.navbar.scrolled{background:var(--nav-bg);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(20px)}.navbar-logo{color:var(--accent);letter-spacing:.05em;font-family:Fira Code,monospace;font-size:1rem;font-weight:500}.navbar-logo span{color:var(--text-muted)}.navbar-links{align-items:center;gap:2.5rem;display:flex}.navbar-links a{color:var(--text-secondary);letter-spacing:.04em;font-size:.88rem;font-weight:500;transition:color .2s;position:relative}.navbar-links a:after{content:"";background:var(--accent);width:0;height:1px;transition:width .25s;position:absolute;bottom:-3px;left:0}.navbar-links a:hover{color:var(--accent)}.navbar-links a:hover:after{width:100%}.hamburger{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;padding:0;transition:border-color .2s;display:none}.hamburger:hover{border-color:var(--accent)}.hamburger span{background:var(--text-primary);transform-origin:50%;border-radius:2px;width:18px;height:1.5px;transition:transform .3s,opacity .3s,width .3s;display:block}.hamburger.open span:first-child{transform:translateY(6.5px)rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0;width:0}.hamburger.open span:nth-child(3){transform:translateY(-6.5px)rotate(-45deg)}@media (max-width:768px){.navbar-links{display:none}.hamburger{display:flex}}.mobile-menu{z-index:200;pointer-events:none;visibility:hidden;position:fixed;inset:0}.mobile-menu.open{pointer-events:all;visibility:visible}.mobile-menu-backdrop{-webkit-backdrop-filter:blur(4px);opacity:0;background:#0009;transition:opacity .3s;position:absolute;inset:0}.mobile-menu.open .mobile-menu-backdrop{opacity:1}.mobile-menu-drawer{background:var(--bg-card);border-left:1px solid var(--border-strong);flex-direction:column;width:min(320px,85vw);transition:transform .35s cubic-bezier(.32,.72,0,1);display:flex;position:absolute;top:0;bottom:0;right:0;transform:translate(100%)}.mobile-menu.open .mobile-menu-drawer{transform:translate(0)}.mobile-menu-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:64px;padding:0 1.5rem;display:flex}.mobile-menu-close{border:1px solid var(--border);width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;font-size:.85rem;transition:all .2s;display:flex}.mobile-menu-close:hover{color:var(--accent);border-color:var(--accent)}.mobile-menu-nav{flex-direction:column;flex:1;padding:1.5rem 0;display:flex;overflow-y:auto}.mobile-menu-link{color:var(--text-secondary);border-bottom:1px solid var(--border);opacity:0;align-items:center;gap:1rem;padding:1rem 1.5rem;font-size:1.1rem;font-weight:600;transition:all .2s;display:flex;transform:translate(20px)}.mobile-menu.open .mobile-menu-link{animation:.3s forwards slide-in}@keyframes slide-in{to{opacity:1;transform:translate(0)}}.mobile-menu-link:hover{color:var(--accent);background:var(--accent-subtle);padding-left:1.75rem}.mobile-link-num{color:var(--accent);opacity:.6;min-width:24px;font-family:Fira Code,monospace;font-size:.72rem}.mobile-link-arr{color:var(--text-muted);margin-left:auto;font-size:.85rem;transition:transform .2s}.mobile-menu-link:hover .mobile-link-arr{color:var(--accent);transform:translate(4px)}.mobile-menu-footer{border-top:1px solid var(--border);flex-shrink:0;gap:1rem;padding:1.5rem;display:flex}.mobile-social{color:var(--text-muted);border:1px solid var(--border);border-radius:7px;padding:.5rem .85rem;font-family:Fira Code,monospace;font-size:.75rem;transition:all .2s}.mobile-social:hover{color:var(--accent);border-color:var(--border-strong)}.hero{flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:64px 2rem 4rem;display:flex;position:relative;overflow:hidden}.hero-content{text-align:center;z-index:1;flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:720px;display:flex;position:relative}.hero-sys-line{color:var(--accent);letter-spacing:.14em;border:1px solid var(--border-strong);background:var(--accent-subtle);border-radius:999px;align-items:center;gap:8px;padding:.4rem 1rem;font-family:Fira Code,monospace;font-size:.72rem;animation:.5s both fade-up;display:inline-flex}.sys-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.7)}}.hero-name{letter-spacing:-.04em;font-size:clamp(3rem,9vw,6.5rem);font-weight:800;line-height:1;animation:.5s .1s both fade-up}.hero-name .accent{color:var(--accent)}.hero-role-wrap{color:var(--text-secondary);justify-content:center;align-items:center;gap:2px;min-height:2rem;font-family:Fira Code,monospace;font-size:clamp(1rem,2.5vw,1.35rem);animation:.5s .15s both fade-up;display:flex}.hero-role-prefix{color:var(--accent);flex-shrink:0}.hero-role-text{color:var(--text-primary);font-weight:500}.t-cursor{background:var(--accent);vertical-align:middle;flex-shrink:0;width:2px;height:1.2em;margin-left:2px;animation:1s step-end infinite blink-cur;display:inline-block}@keyframes blink-cur{0%,to{opacity:1}50%{opacity:0}}.hero-desc{color:var(--text-secondary);max-width:500px;font-size:clamp(.95rem,2vw,1.05rem);line-height:1.75;animation:.5s .2s both fade-up}.hero-actions{flex-wrap:wrap;justify-content:center;gap:1rem;animation:.5s .25s both fade-up;display:flex}.hero-chips{flex-wrap:wrap;justify-content:center;gap:.5rem;animation:.5s .3s both fade-up;display:flex}.hero-chip{color:var(--text-muted);border:1px solid var(--border);background:var(--bg-card);padding:.3rem .75rem;font-family:Fira Code,monospace;font-size:.72rem;transition:all .2s}.hero-chip:hover{color:var(--accent);border-color:var(--border-strong)}@keyframes scroll-line{0%{transform-origin:top;transform:scaleY(0)}50%{transform-origin:top;transform:scaleY(1)}51%{transform-origin:bottom;transform:scaleY(1)}to{transform-origin:bottom;transform:scaleY(0)}}@media (max-width:480px){.hero{padding:64px 1.25rem 4rem}.hero-actions{flex-direction:column;width:100%}.hero-actions .btn{justify-content:center;width:100%}}.about{background:var(--bg-secondary);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.about-grid{grid-template-columns:1fr 1fr;align-items:center;gap:5rem;display:grid}.about-text p{color:var(--text-secondary);margin-bottom:1.2rem;font-size:1rem;line-height:1.8}.about-text p:last-child{margin-bottom:0}.about-highlight{font-weight:600;color:var(--accent)!important}.about-info{flex-direction:column;gap:1.25rem;display:flex}.info-row{background:var(--bg-card);border:1px solid var(--border);align-items:flex-start;gap:1rem;padding:1.25rem;transition:border-color .2s,box-shadow .2s;display:flex}.info-row:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}.info-icon{background:var(--accent-subtle);border:1px solid var(--border);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.1rem;display:flex}.info-label{color:var(--text-muted);margin-bottom:.2rem;font-family:Fira Code,monospace;font-size:.72rem}.info-value{color:var(--text-primary);font-size:.95rem;font-weight:600}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-top:3.5rem;display:grid}.skill-card{background:var(--bg-card);border:1px solid var(--border);padding:1.75rem;transition:all .25s;position:relative;overflow:hidden}.skill-card:before{content:"";background:var(--accent);transform-origin:bottom;width:3px;height:100%;transition:transform .25s;position:absolute;top:0;left:0;transform:scaleY(0)}.skill-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-hover);transform:translateY(-4px)}.skill-card:hover:before{transform:scaleY(1)}.skill-card-icon{margin-bottom:1rem;font-size:1.8rem}.skill-card-title{color:var(--text-primary);margin-bottom:.5rem;font-size:1rem;font-weight:700}.skill-card-desc{color:var(--text-muted);margin-bottom:1.25rem;font-family:Fira Code,monospace;font-size:.85rem;line-height:1.6}.skill-tags{flex-wrap:wrap;gap:.4rem;display:flex}.skill-tag{background:var(--tag-bg);color:var(--tag-text);border:1px solid var(--border);border-radius:6px;padding:.3rem .6rem;font-family:Fira Code,monospace;font-size:.7rem}.projects{background:var(--bg-secondary);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.projects-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.5rem;margin-bottom:3.5rem;display:flex}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.75rem;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border);flex-direction:column;transition:all .3s;display:flex;overflow:hidden}.project-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-hover);transform:translateY(-6px)}.project-thumbnail{height:200px;position:relative;overflow:hidden}.project-thumb-bg{justify-content:center;align-items:center;width:100%;height:100%;font-size:3.5rem;display:flex;position:relative}.project-thumb-bg:after{content:"";background:linear-gradient(to bottom, transparent 40%, var(--bg-card));position:absolute;inset:0}.project-body{flex-direction:column;flex:1;padding:1.5rem;display:flex}.project-meta{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.project-type{color:var(--accent);background:var(--tag-bg);border-radius:5px;padding:.25rem .6rem;font-family:Fira Code,monospace;font-size:.7rem}.project-year{color:var(--text-muted);font-family:Fira Code,monospace;font-size:.7rem}.project-title{color:var(--text-primary);margin-bottom:.6rem;font-size:1.15rem;font-weight:700}.project-desc{color:var(--text-secondary);flex:1;margin-bottom:1.25rem;font-size:.88rem;line-height:1.65}.project-stack{flex-wrap:wrap;gap:.4rem;margin-bottom:1.25rem;display:flex}.project-stack span{color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border);border-radius:5px;padding:.25rem .5rem;font-family:Fira Code,monospace;font-size:.68rem}.project-links{gap:.75rem;display:flex}.project-link{color:var(--accent);align-items:center;gap:.35rem;font-size:.82rem;font-weight:600;transition:opacity .2s;display:inline-flex}.project-link:hover{opacity:.7}.project-link.secondary{color:var(--text-muted)}.timeline{margin-top:3.5rem;padding-left:2rem;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, var(--accent), transparent);width:1px;position:absolute;top:8px;bottom:0;left:0}.timeline-item{padding-bottom:3rem;padding-left:2rem;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{background:var(--accent);border:2px solid var(--bg);width:10px;height:10px;box-shadow:0 0 0 2px var(--accent);border-radius:50%;position:absolute;top:6px;left:-2.45rem}.timeline-period{color:var(--accent);margin-bottom:.4rem;font-family:Fira Code,monospace;font-size:.75rem}.timeline-role{color:var(--text-primary);margin-bottom:.2rem;font-size:1.1rem;font-weight:700}.timeline-company{color:var(--text-muted);margin-bottom:.75rem;font-family:Fira Code,monospace;font-size:.88rem}.timeline-desc{color:var(--text-secondary);font-size:.92rem;line-height:1.7}.contact-inner{text-align:center;max-width:680px;margin:0 auto}.contact-inner .section-label{justify-content:center}.contact-inner .section-label:before{display:none}.contact-cta{letter-spacing:-.04em;margin-bottom:1.25rem;font-size:clamp(2.5rem,5vw,4rem);font-weight:800;line-height:1.05}.contact-cta .accent{color:var(--accent)}.contact-sub{color:var(--text-secondary);margin-bottom:2.5rem;font-size:1.05rem;line-height:1.7}.contact-socials{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.social-link{color:var(--text-muted);border:1px solid var(--border);background:var(--bg-card);align-items:center;gap:.5rem;padding:.6rem 1.1rem;font-family:Fira Code,monospace;font-size:.82rem;transition:all .2s;display:inline-flex}.social-link:hover{color:var(--accent);border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-2px)}.footer{border-top:1px solid var(--border);position:relative;overflow:hidden}.footer-top{padding:5rem 0 3rem}.footer-container{max-width:1100px;margin:0 auto;padding:0 2rem}.footer-top .footer-container{grid-template-columns:1.4fr 1fr;align-items:flex-start;gap:4rem;display:grid}.footer-brand{flex-direction:column;gap:1rem;display:flex}.footer-logo{color:var(--accent);letter-spacing:.05em;width:fit-content;font-family:Fira Code,monospace;font-size:1.1rem;font-weight:500}.footer-logo span{color:var(--text-muted)}.footer-tagline{color:var(--text-secondary);max-width:300px;font-size:.92rem;line-height:1.7}.footer-email{color:var(--text-muted);border:1px solid var(--border);background:var(--bg-card);width:fit-content;padding:.5rem 1rem;font-family:Fira Code,monospace;font-size:.82rem;transition:all .2s}.footer-email:hover{color:var(--accent);border-color:var(--border-strong)}.footer-nav{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid}.footer-col-title{color:var(--accent);text-transform:uppercase;letter-spacing:.12em;margin-bottom:1.1rem;font-family:Fira Code,monospace;font-size:.72rem}.footer-col ul{flex-direction:column;gap:.65rem;display:flex}.footer-link{color:var(--text-muted);font-size:.88rem;transition:color .2s,padding-left .2s;display:inline-block}.footer-link:hover{color:var(--text-primary);padding-left:4px}.footer-big-name{letter-spacing:-.04em;color:#0000;-webkit-text-stroke:1px var(--border-strong);text-align:center;-webkit-user-select:none;user-select:none;padding:1rem 0;font-family:Syne,sans-serif;font-size:clamp(3rem,10vw,8rem);font-weight:800;line-height:1;transition:-webkit-text-stroke-color .3s}.footer-big-name:hover{-webkit-text-stroke-color:var(--accent)}.footer-bottom{border-top:1px solid var(--border);background:var(--bg-secondary);padding:1.5rem 0}.footer-bottom-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.footer-copy{color:var(--text-muted);font-family:Fira Code,monospace;font-size:.78rem}.footer-copy .accent{color:var(--accent)}.footer-bottom-right{align-items:center;gap:1.5rem;display:flex}.footer-stack{color:var(--text-muted);opacity:.6;font-family:Fira Code,monospace;font-size:.72rem}@media (max-width:768px){.footer-top .footer-container{grid-template-columns:1fr;gap:2.5rem}.footer-nav{grid-template-columns:repeat(3,1fr);gap:1.25rem}.footer-bottom-inner{text-align:center;flex-direction:column}.footer-big-name{font-size:clamp(2.5rem,12vw,5rem)}}@media (max-width:480px){.footer-nav{grid-template-columns:1fr 1fr}}@keyframes fade-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.reveal{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(30px)}.reveal.visible{opacity:1;transform:translateY(0)}@media (max-width:768px){.navbar-links{display:none}.hero-content{text-align:center;grid-template-columns:1fr;gap:3rem}.hero-desc{margin:0 auto}.hero-actions{justify-content:center}.hero-visual{order:-1}.hero-card{width:280px;height:330px}.about-grid{grid-template-columns:1fr;gap:2.5rem}.projects-header{flex-direction:column;align-items:flex-start}.projects-grid,.skills-grid{grid-template-columns:1fr}.contact-cta{font-size:2rem}.footer-inner{text-align:center;flex-direction:column}.section{padding:4.5rem 0}}@media (max-width:480px){.container{padding:0 1.25rem}.hero-name{font-size:2.8rem}}
