@import "https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,400&family=Fira+Code:wght@400;500&display=swap";:root{--bg-primary:#080d1a;--bg-secondary:#0d1526;--bg-card:#111c30;--bg-card-hover:#162038;--accent:#64ffda;--accent-dim:#64ffda1f;--accent-dim2:#64ffda0f;--text-primary:#e6f1ff;--text-secondary:#8892b0;--text-muted:#4a5568;--navy-border:#64ffda26;--shadow:0 20px 60px #0006;--font-display:"Syne", sans-serif;--font-body:"DM Sans", sans-serif;--font-mono:"Fira Code", monospace;--transition:all .3s cubic-bezier(.4, 0, .2, 1);--radius:12px;--max-width:1100px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:80px}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--accent-dim);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}a{text-decoration:none}ul{list-style:none}img{max-width:100%;display:block}.container{width:90%;max-width:var(--max-width);margin:0 auto}.section-label{font-family:var(--font-mono);color:var(--accent);letter-spacing:2px;text-transform:uppercase;margin-bottom:12px;font-size:13px}.section-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:16px;font-size:clamp(28px,4vw,40px);font-weight:700}.section-divider{background:linear-gradient(90deg, var(--accent), transparent);border-radius:2px;width:60px;height:3px;margin-bottom:60px}.fade-in{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(30px)}.fade-in.visible{opacity:1;transform:translateY(0)}.navbar{z-index:1000;width:100%;transition:var(--transition);justify-content:space-between;align-items:center;padding:22px 60px;display:flex;position:fixed;top:0}.navbar.scrolled{-webkit-backdrop-filter:blur(16px);background:#080d1aeb;border-bottom:1px solid #64ffda14;padding:16px 60px;box-shadow:0 4px 30px #0000004d}.nav-logo{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.5px;font-size:22px;font-weight:800}.nav-logo span{color:var(--accent)}.nav-links{align-items:center;gap:8px;display:flex}.nav-links a{font-family:var(--font-mono);color:var(--text-secondary);transition:var(--transition);letter-spacing:.3px;text-transform:lowercase;border-radius:6px;padding:8px 14px;font-size:13px}.nav-links a:hover,.nav-links a.active{color:var(--accent);background:var(--accent-dim2)}.nav-num{color:var(--accent);margin-right:4px}.nav-resume{border-radius:6px;margin-left:12px;border:1px solid var(--accent)!important;color:var(--accent)!important;padding:8px 18px!important}.nav-resume:hover{background:var(--accent-dim)!important}.hamburger{cursor:pointer;z-index:1001;background:0 0;border:none;flex-direction:column;gap:5px;padding:4px;display:none}.hamburger span{background:var(--accent);width:24px;height:2px;transition:var(--transition);transform-origin:50%;border-radius:2px;display:block}.hamburger.open span:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}@media (width<=768px){.navbar{padding:18px 24px}.navbar.scrolled{padding:14px 24px}.hamburger{display:flex}.nav-links{background:var(--bg-card);border-left:1px solid var(--navy-border);flex-direction:column;justify-content:center;gap:4px;width:min(75vw,300px);height:100vh;padding:40px 24px;transition:transform .4s cubic-bezier(.4,0,.2,1);position:fixed;top:0;right:0;transform:translate(100%)}.nav-links.open{transform:translate(0)}.nav-links a{padding:12px 16px;font-size:15px}.nav-resume{text-align:center;margin-top:12px;display:block;margin-left:0!important}.nav-links li{opacity:0;transform:translate(20px)}.nav-links.open li{animation:.4s forwards slideInRight;animation-delay:calc(var(--i) * 60ms + .1s)}@keyframes slideInRight{to{opacity:1;transform:translate(0)}}}.hero{background:var(--bg-primary);align-items:center;min-height:100vh;padding:120px 0 80px;display:flex;position:relative;overflow:hidden}.hero-bg-grid{pointer-events:none;background-image:radial-gradient(circle,#64ffda0f 1px,#0000 1px);background-size:40px 40px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 80%,#000,#0000);mask-image:radial-gradient(80% 80%,#000,#0000)}.hero-container{justify-content:space-between;align-items:center;gap:60px;display:flex}.hero-left{flex:1;max-width:580px}.hero-intro{font-family:var(--font-mono);color:var(--accent);align-items:center;gap:12px;margin-bottom:16px;font-size:14px;display:flex}.intro-line{background:var(--accent);flex-shrink:0;width:40px;height:1px;display:block}.hero-name{font-family:var(--font-display);letter-spacing:-2px;color:var(--text-primary);margin-bottom:10px;font-size:clamp(42px,6vw,72px);font-weight:800;line-height:1.05}.hero-role{font-family:var(--font-display);color:var(--text-secondary);align-items:center;gap:2px;min-height:50px;margin-bottom:24px;font-size:clamp(22px,3.5vw,38px);font-weight:600;display:flex}.typed-text{color:var(--accent)}.cursor{color:var(--accent);font-weight:300;animation:1s step-end infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-desc{color:var(--text-secondary);max-width:480px;margin-bottom:36px;font-size:16px;line-height:1.75}.hero-actions{flex-wrap:wrap;gap:16px;margin-bottom:40px;display:flex}.btn-primary{background:var(--accent);color:var(--bg-primary);font-family:var(--font-mono);transition:var(--transition);letter-spacing:.5px;border-radius:8px;padding:14px 28px;font-size:14px;font-weight:600}.btn-primary:hover{color:var(--accent);box-shadow:0 0 0 1px var(--accent), 0 0 20px #64ffda33;background:0 0}.btn-secondary{border:1px solid var(--accent);color:var(--accent);font-family:var(--font-mono);transition:var(--transition);border-radius:8px;padding:14px 28px;font-size:14px;font-weight:500}.btn-secondary:hover{background:var(--accent-dim)}.hero-socials{gap:16px;display:flex}.hero-socials a{color:var(--text-secondary);border:1px solid var(--text-muted);width:40px;height:40px;transition:var(--transition);border-radius:8px;justify-content:center;align-items:center;display:flex}.hero-socials a:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-dim2);transform:translateY(-3px)}.hero-right{flex-shrink:0}.hero-img-wrapper{width:500px;position:relative}.hero-img-wrapper img{z-index:1;border-radius:16px;width:100%;animation:5s ease-in-out infinite float;position:relative}.img-glow{z-index:0;background:radial-gradient(circle,#64ffda26 0%,#0000 70%);border-radius:50%;animation:5s ease-in-out infinite glowPulse;position:absolute;inset:-20px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}@keyframes glowPulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.scroll-indicator{color:var(--text-secondary);font-family:var(--font-mono);letter-spacing:1px;opacity:0;flex-direction:column;align-items:center;gap:8px;font-size:11px;animation:1s 1.5s forwards fadeInUp;display:flex;position:absolute;bottom:30px;left:50%;transform:translate(-50%)}.scroll-mouse{border:1px solid var(--text-muted);border-radius:11px;justify-content:center;width:22px;height:34px;padding-top:6px;display:flex}.scroll-dot{background:var(--accent);border-radius:50%;width:4px;height:4px;animation:1.8s ease-in-out infinite scrollDown}@keyframes scrollDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(14px)}}@keyframes fadeInUp{to{opacity:1}}@media (width<=900px){.hero-container{text-align:center;flex-direction:column-reverse;gap:40px}.hero-intro,.hero-actions,.hero-socials{justify-content:center}.hero-img-wrapper{width:360px;margin:0 auto}.hero-desc{margin-left:auto;margin-right:auto}}.about{background:var(--bg-secondary);padding:120px 0}.about-inner{align-items:flex-start;gap:80px;display:flex}.about-image-side{flex-shrink:0}.about-img-wrapper{width:280px;position:relative}.about-img-wrapper img{border-radius:var(--radius);z-index:1;filter:grayscale(20%);width:100%;transition:var(--transition);position:relative}.about-img-wrapper:hover img{filter:none}.about-img-border{border:2px solid var(--accent);border-radius:var(--radius);z-index:0;width:100%;height:100%;transition:var(--transition);position:absolute;top:16px;left:16px}.about-img-wrapper:hover .about-img-border{top:10px;left:10px}.about-text-side{flex:1}.about-para{color:var(--text-secondary);margin-bottom:16px;font-size:16px;line-height:1.8}.about-para strong{color:var(--text-primary);font-weight:600}.about-highlights{grid-template-columns:1fr 1fr;gap:10px;margin:24px 0;display:grid}.about-highlights li{color:var(--text-secondary);align-items:flex-start;gap:8px;font-size:14px;line-height:1.5;display:flex}.highlight-arrow{color:var(--accent);flex-shrink:0;margin-top:1px}.about-badges{flex-wrap:wrap;gap:10px;margin-top:24px;display:flex}.about-badges span{font-family:var(--font-mono);background:var(--accent-dim);color:var(--accent);border:1px solid #64ffda33;border-radius:20px;padding:6px 14px;font-size:12px}@media (width<=768px){.about-inner{flex-direction:column;gap:40px}.about-img-wrapper{width:220px;margin:0 auto}.about-highlights{grid-template-columns:1fr}}.skills{background:var(--bg-primary);padding:120px 0}.skills-grid{grid-template-columns:repeat(3,1fr);gap:28px;display:grid}.skill-category{background:var(--bg-card);border-radius:var(--radius);transition:var(--transition);border:1px solid #ffffff0f;padding:32px 28px}.skill-category:hover{border-color:var(--navy-border);box-shadow:var(--shadow);transform:translateY(-4px)}.cat-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:2px;color:var(--accent);border-bottom:1px solid #64ffda1f;margin-bottom:24px;padding-bottom:12px;font-size:12px}.skill-bars{flex-direction:column;gap:18px;display:flex}.skill-meta{justify-content:space-between;margin-bottom:7px;display:flex}.skill-name{color:var(--text-primary);font-size:14px;font-weight:500}.skill-pct{font-family:var(--font-mono);color:var(--accent);font-size:12px}.skill-bar-bg{background:#ffffff0f;border-radius:2px;height:4px;overflow:hidden}.skill-bar-fill{background:linear-gradient(90deg, var(--accent), #64ffda80);border-radius:2px;width:0;height:100%;transition:width 1.2s cubic-bezier(.4,0,.2,1) .3s}.fade-in.visible .skill-bar-fill{width:var(--level)}@media (width<=900px){.skills-grid{grid-template-columns:1fr;max-width:500px}}.projects{background:var(--bg-secondary);padding:120px 0}.featured-projects{flex-direction:column;gap:60px;margin-bottom:80px;display:flex}.featured-project{background:var(--bg-card);transition:var(--transition);border:1px solid #ffffff0f;border-radius:16px;grid-template-columns:1fr 1fr;align-items:center;gap:48px;padding:48px;display:grid;position:relative}.featured-project:hover{border-color:var(--navy-border);box-shadow:var(--shadow)}.feat-tag{font-family:var(--font-mono);color:var(--accent);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:12px;font-size:12px;display:block}.feat-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.feat-date{font-family:var(--font-mono);color:var(--accent);letter-spacing:.5px;white-space:nowrap;font-size:13px;font-weight:500;position:absolute;top:48px;right:48px}.featured-content h3{font-family:var(--font-display);color:var(--text-primary);margin-bottom:20px;font-size:26px;font-weight:700}.feat-desc-box{background:var(--bg-secondary);border-radius:8px;margin-bottom:20px;padding:20px}.feat-desc-box p{color:var(--text-secondary);font-size:15px;line-height:1.75}.tech-tags{flex-wrap:wrap;gap:10px;margin-bottom:24px;display:flex}.tech-tags span{font-family:var(--font-mono);color:var(--accent);background:var(--accent-dim2);border-radius:4px;padding:4px 12px;font-size:12px}.proj-links{align-items:center;gap:14px;display:flex}.proj-link{font-family:var(--font-mono);color:var(--text-secondary);transition:var(--transition);border:1px solid #ffffff1a;border-radius:8px;align-items:center;gap:7px;padding:10px 18px;font-size:13px;display:flex}.proj-link:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-dim2)}.proj-link.primary{background:var(--accent);color:var(--bg-primary);border-color:var(--accent);font-weight:600}.proj-link.primary:hover{color:var(--accent);background:0 0}.featured-visual{justify-content:center;display:flex}.proj-mockup{background:var(--bg-primary);border:1px solid #ffffff14;border-radius:10px;width:100%;max-width:360px;overflow:hidden}.mockup-bar{background:#ffffff05;border-bottom:1px solid #ffffff0f;gap:6px;padding:12px 14px;display:flex}.mockup-bar span{background:#ffffff1f;border-radius:50%;width:10px;height:10px}.mockup-content{flex-direction:column;gap:14px;padding:20px;display:flex}.mockup-line{background:#64ffda1f;border-radius:4px;height:8px}.w80{width:80%}.w60{width:60%}.w50{width:50%}.mockup-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.mockup-card{background:#64ffda0f;border:1px solid #64ffda1a;border-radius:6px;height:60px}.other-projects-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.proj-card{background:var(--bg-card);border-radius:var(--radius);transition:var(--transition);border:1px solid #ffffff0f;flex-direction:column;padding:30px;display:flex}.proj-card:hover{border-color:var(--navy-border);box-shadow:var(--shadow);background:var(--bg-card-hover);transform:translateY(-5px)}.card-top{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.folder-icon{color:var(--accent)}.card-links{gap:14px;display:flex}.card-links a{color:var(--text-secondary);transition:var(--transition)}.card-links a:hover{color:var(--accent)}.card-title{font-family:var(--font-display);color:var(--text-primary);transition:var(--transition);margin-bottom:12px;font-size:18px;font-weight:700}.proj-card:hover .card-title{color:var(--accent)}.card-desc{color:var(--text-secondary);flex:1;margin-bottom:20px;font-size:14px;line-height:1.7}.card-tech{flex-wrap:wrap;gap:10px;display:flex}.card-tech span{font-family:var(--font-mono);color:var(--text-secondary);font-size:11px}@media (width<=900px){.featured-projects{gap:40px}.featured-project{grid-template-columns:1fr}.featured-visual{display:none}.other-projects-grid{grid-template-columns:1fr}}.proj-badge{font-family:var(--font-mono);color:#ffc400;letter-spacing:.5px;text-transform:uppercase;background:#ffc4001a;border:1px solid #ffc40040;border-radius:20px;padding:3px 10px;font-size:10px}.card-icon-link{color:var(--text-secondary);transition:var(--transition)}.card-icon-link:hover{color:var(--accent)}.education{background:var(--bg-primary);padding:120px 0}.timeline{padding-left:32px;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, var(--accent), transparent);width:1px;position:absolute;top:0;bottom:0;left:7px}.timeline-item{margin-bottom:40px;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-dot{justify-content:center;align-items:center;width:16px;height:16px;display:flex;position:absolute;top:22px;left:-32px}.dot-inner{background:var(--accent);border-radius:50%;width:10px;height:10px;box-shadow:0 0 12px #64ffda80}.timeline-card{background:var(--bg-card);border-radius:var(--radius);transition:var(--transition);border:1px solid #ffffff0f;padding:28px 32px}.timeline-card:hover{border-color:var(--navy-border);transform:translate(6px)}.tl-type{font-family:var(--font-mono);color:var(--accent);letter-spacing:1px;text-transform:uppercase;opacity:.8;margin-bottom:10px;font-size:11px;display:block}.tl-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:4px;display:flex}.tl-header h3{font-family:var(--font-display);color:var(--text-primary);font-size:19px;font-weight:700}.tl-period{font-family:var(--font-mono);color:var(--accent);white-space:nowrap;flex-shrink:0;font-size:12px}.tl-org{color:var(--text-secondary);margin-bottom:12px;font-size:14px;font-style:italic}.tl-desc{color:var(--text-secondary);margin-bottom:16px;font-size:14px;line-height:1.75}.tl-tags{flex-wrap:wrap;gap:8px;display:flex}.tl-tags span{font-family:var(--font-mono);color:var(--accent);background:var(--accent-dim2);border:1px solid #64ffda1f;border-radius:4px;padding:3px 10px;font-size:11px}@media (width<=600px){.tl-header{flex-direction:column;gap:4px}}.certifications{background:var(--bg-secondary);padding:120px 0}.certs-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;display:grid}.cert-card{background:var(--bg-card);border:1px solid #ffffff0f;border-top:3px solid var(--cert-color,var(--accent));border-radius:var(--radius);color:inherit;transition:var(--transition);flex-direction:column;gap:18px;padding:28px 24px 20px;text-decoration:none;display:flex;position:relative;overflow:hidden}.cert-card:before{content:"";background:linear-gradient(180deg, rgba(var(--cert-color,100,255,218), .06) 0%, transparent 100%);pointer-events:none;height:80px;position:absolute;top:0;left:0;right:0}.cert-card:hover{border-color:var(--cert-color,var(--accent));transform:translateY(-6px);box-shadow:0 20px 50px #00000059}.cert-icon{background:color-mix(in srgb, var(--cert-color,var(--accent)) 15%, transparent);width:52px;height:52px;color:var(--cert-color,var(--accent));border-radius:12px;justify-content:center;align-items:center;display:flex}.cert-body{flex:1}.cert-body h3{font-family:var(--font-display);color:var(--text-primary);transition:var(--transition);margin-bottom:5px;font-size:17px;font-weight:700;line-height:1.4}.cert-card:hover .cert-body h3{color:var(--cert-color,var(--accent))}.cert-issuer{font-family:var(--font-mono);color:var(--cert-color,var(--accent));letter-spacing:.5px;text-transform:uppercase;margin-bottom:10px;font-size:11px}.cert-desc{color:var(--text-secondary);font-size:13.5px;line-height:1.65}.cert-footer{border-top:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding-top:14px;display:flex}.cert-year{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}.cert-view{font-family:var(--font-mono);color:var(--cert-color,var(--accent));opacity:0;transition:var(--transition);font-size:12px;transform:translate(-6px)}.cert-card:hover .cert-view{opacity:1;transform:translate(0)}@media (width<=600px){.certs-grid{grid-template-columns:1fr}}.contact{background:var(--bg-secondary);padding:120px 0}.contact-inner{grid-template-columns:1fr 1.2fr;align-items:flex-start;gap:72px;display:grid}.contact-blurb{color:var(--text-secondary);margin-bottom:40px;font-size:16px;line-height:1.8}.contact-details{flex-direction:column;gap:16px;display:flex}.contact-item{background:var(--bg-card);border-radius:var(--radius);color:inherit;transition:var(--transition);border:1px solid #ffffff0f;align-items:center;gap:16px;padding:16px 20px;display:flex}.contact-item:hover{border-color:var(--navy-border);background:var(--bg-card-hover);transform:translate(6px)}.contact-icon{background:var(--accent-dim);width:40px;height:40px;color:var(--accent);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ci-label{font-family:var(--font-mono);color:var(--accent);text-transform:uppercase;letter-spacing:1px;margin-bottom:3px;font-size:11px;display:block}.ci-value{color:var(--text-primary);font-size:14px;display:block}.contact-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{font-family:var(--font-mono);color:var(--accent);text-transform:uppercase;letter-spacing:1px;font-size:12px}.form-group input,.form-group textarea{background:var(--bg-card);font-family:var(--font-body);color:var(--text-primary);transition:var(--transition);resize:vertical;border:1px solid #ffffff14;border-radius:8px;outline:none;padding:14px 18px;font-size:15px}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);background:var(--bg-card-hover);box-shadow:0 0 0 3px var(--accent-dim2)}.form-submit{background:var(--accent);color:var(--bg-primary);font-family:var(--font-mono);letter-spacing:.5px;cursor:pointer;transition:var(--transition);border:none;border-radius:8px;align-self:flex-start;padding:16px 32px;font-size:14px;font-weight:700}.form-submit:hover{color:var(--accent);box-shadow:0 0 0 1px var(--accent), 0 0 20px #64ffda26;background:0 0}.success-msg{font-family:var(--font-mono);color:var(--accent);font-size:13px}@media (width<=768px){.contact-inner{grid-template-columns:1fr;gap:48px}}.footer{background:var(--bg-primary);border-top:1px solid #ffffff0d;padding:28px 0}.footer-inner{justify-content:space-between;align-items:center;display:flex}.footer-copy{font-family:var(--font-mono);color:var(--text-muted);font-size:13px}.footer-copy a{color:var(--accent);transition:var(--transition)}.footer-copy a:hover{text-decoration:underline}.footer-stack{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}@media (width<=600px){.footer-inner{text-align:center;flex-direction:column;gap:8px}}
