@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=Outfit:wght@300;400;500;600;700;800&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}img,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font:inherit}ul,ol{list-style:none}:root{--c-bg: #0f1729;--c-bg-alt: #162032;--c-bg-card: #1a2540;--c-text: #e2e8f0;--c-text-muted: #8b9dc3;--c-primary: #3b82f6;--c-primary-soft: rgba(59, 130, 246, .12);--c-primary-hover: #60a5fa;--c-accent: #06d6a0;--c-accent-soft: rgba(6, 214, 160, .12);--c-border: rgba(59, 130, 246, .15);--c-border-hover: rgba(59, 130, 246, .35);--c-code-bg: #1e293b;--c-shadow: 0 4px 24px rgba(0,0,0,.3);--c-glow: 0 0 40px rgba(59,130,246,.08);--s-xs: .25rem;--s-sm: .5rem;--s-md: 1rem;--s-lg: 1.5rem;--s-xl: 2rem;--s-2xl: 3rem;--s-3xl: 4rem;--s-4xl: 6rem;--f-body: "Outfit", system-ui, -apple-system, sans-serif;--f-mono: "JetBrains Mono", "Fira Code", monospace;--f-size-xs: .75rem;--f-size-sm: .875rem;--f-size-base: 1rem;--f-size-lg: 1.125rem;--f-size-xl: 1.25rem;--f-size-2xl: 1.5rem;--f-size-3xl: 2rem;--f-size-4xl: 2.5rem;--f-size-5xl: 3.5rem;--radius: .625rem;--radius-lg: 1rem;--radius-full: 9999px;--transition: .2s ease;--transition-slow: .4s ease}.light{--c-bg: #f8fafc;--c-bg-alt: #f1f5f9;--c-bg-card: #ffffff;--c-text: #1e293b;--c-text-muted: #64748b;--c-primary: #2563eb;--c-primary-soft: rgba(37, 99, 235, .08);--c-primary-hover: #1d4ed8;--c-accent: #059669;--c-accent-soft: rgba(5, 150, 105, .08);--c-border: rgba(37, 99, 235, .12);--c-border-hover: rgba(37, 99, 235, .3);--c-code-bg: #f1f5f9;--c-shadow: 0 4px 24px rgba(0,0,0,.06);--c-glow: 0 0 40px rgba(37,99,235,.04)}body{font-family:var(--f-body);font-size:var(--f-size-base);line-height:1.7;color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--s-lg)}.section{padding:var(--s-4xl) 0}h1,h2,h3,h4{font-weight:700;line-height:1.2;color:var(--c-text)}h1{font-size:var(--f-size-5xl)}h2{font-size:var(--f-size-4xl)}h3{font-size:var(--f-size-2xl)}@media(max-width:768px){h1{font-size:var(--f-size-3xl)}h2{font-size:var(--f-size-2xl)}h3{font-size:var(--f-size-xl)}}.text-gradient{background:linear-gradient(135deg,var(--c-primary),var(--c-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-muted{color:var(--c-text-muted)}.text-primary{color:var(--c-primary)}.text-accent{color:var(--c-accent)}.font-mono{font-family:var(--f-mono)}.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:var(--s-md) 0;transition:var(--transition-slow);background:transparent}.nav.scrolled{background:#0f1729d9;backdrop-filter:blur(16px);border-bottom:1px solid var(--c-border)}.light .nav.scrolled{background:#f8fafcd9}.nav-inner{display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:var(--f-mono);font-size:var(--f-size-xl);font-weight:700}.nav-logo .bracket{color:var(--c-primary)}.nav-links{display:flex;align-items:center;gap:var(--s-xl)}.nav-links a{font-size:var(--f-size-sm);font-weight:500;color:var(--c-text-muted);transition:var(--transition);position:relative}.nav-links a:hover,.nav-links a.active{color:var(--c-primary)}.nav-links a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--c-primary);transition:var(--transition)}.nav-links a:hover:after,.nav-links a.active:after{width:100%}.nav-dropdown{position:relative}.nav-dropdown-trigger{display:flex;align-items:center;gap:4px;font-size:var(--f-size-sm);font-weight:500;color:var(--c-text-muted);cursor:pointer;transition:var(--transition)}.nav-dropdown-trigger:hover{color:var(--c-primary)}.nav-dropdown-trigger svg{width:14px;height:14px;transition:var(--transition)}.nav-dropdown:hover .nav-dropdown-trigger svg{transform:rotate(180deg)}.nav-dropdown-menu{position:absolute;top:calc(100% + 12px);left:-16px;min-width:280px;background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--radius-lg);box-shadow:var(--c-shadow);opacity:0;visibility:hidden;transform:translateY(8px);transition:var(--transition);overflow:hidden}.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.nav-dropdown-category{padding:var(--s-xs) var(--s-md);font-size:var(--f-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--c-primary);background:var(--c-primary-soft);border-bottom:1px solid var(--c-border)}.nav-dropdown-menu a{display:block;padding:var(--s-xs) var(--s-md);font-size:var(--f-size-sm);color:var(--c-text-muted);transition:var(--transition)}.nav-dropdown-menu a:hover{color:var(--c-primary);background:var(--c-primary-soft)}.theme-toggle{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);color:var(--c-text-muted);transition:var(--transition)}.theme-toggle:hover{background:var(--c-primary-soft);color:var(--c-primary)}.mobile-toggle{display:none;width:36px;height:36px;align-items:center;justify-content:center;color:var(--c-text)}.mobile-menu{display:none;position:fixed;inset:60px 0 0;background:var(--c-bg);padding:var(--s-xl);overflow-y:auto;z-index:99}.mobile-menu.open{display:block}.mobile-menu a{display:block;padding:var(--s-sm) 0;font-size:var(--f-size-lg);font-weight:500;color:var(--c-text-muted);border-bottom:1px solid var(--c-border);transition:var(--transition)}.mobile-menu a:hover{color:var(--c-primary)}.mobile-menu-category{font-size:var(--f-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--c-primary);margin-top:var(--s-lg);margin-bottom:var(--s-xs)}.mobile-menu .sub-link{padding-left:var(--s-lg);font-size:var(--f-size-base)}@media(max-width:768px){.nav-links{display:none}.mobile-toggle{display:flex}}.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:80px}.hero-bg{position:absolute;inset:0;z-index:-1}.hero-bg:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,var(--c-primary-soft) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,var(--c-accent-soft) 0%,transparent 50%)}.hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--c-border) 1px,transparent 1px),linear-gradient(90deg,var(--c-border) 1px,transparent 1px);background-size:60px 60px;opacity:.3;mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%)}.hero-content{max-width:800px}.hero-terminal{background:var(--c-code-bg);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:var(--s-xl) var(--s-2xl);box-shadow:var(--c-glow);margin-bottom:var(--s-2xl)}.terminal-dots{display:flex;gap:8px;margin-bottom:var(--s-lg)}.terminal-dots span{width:12px;height:12px;border-radius:50%}.terminal-dots span:nth-child(1){background:#ef4444}.terminal-dots span:nth-child(2){background:#eab308}.terminal-dots span:nth-child(3){background:#22c55e}.terminal-line{font-family:var(--f-mono);margin-bottom:var(--s-sm)}.terminal-prompt{color:var(--c-text-muted)}.terminal-cmd{color:var(--c-accent)}.hero-name{font-size:var(--f-size-5xl);font-weight:800;margin:var(--s-md) 0}.hero-role{font-family:var(--f-mono);font-size:var(--f-size-xl);color:var(--c-primary);margin-bottom:var(--s-md)}.hero-stack{font-family:var(--f-mono);font-size:var(--f-size-sm);color:var(--c-text-muted)}.hero-stack .keyword{color:var(--c-accent)}.hero-stack .string{color:var(--c-primary)}.hero-actions{display:flex;gap:var(--s-md);flex-wrap:wrap}@media(max-width:768px){.hero-terminal{padding:var(--s-lg)}.hero-name{font-size:var(--f-size-3xl)}.hero-role{font-size:var(--f-size-lg)}}.btn{display:inline-flex;align-items:center;gap:var(--s-sm);padding:var(--s-sm) var(--s-xl);font-weight:600;font-size:var(--f-size-sm);border-radius:var(--radius);transition:var(--transition)}.btn-primary{background:var(--c-primary);color:#fff}.btn-primary:hover{background:var(--c-primary-hover);transform:translateY(-1px);box-shadow:0 4px 16px #3b82f64d}.btn-outline{border:1px solid var(--c-border-hover);color:var(--c-primary)}.btn-outline:hover{background:var(--c-primary-soft);border-color:var(--c-primary);transform:translateY(-1px)}.section-header{text-align:center;margin-bottom:var(--s-3xl)}.section-header p{color:var(--c-text-muted);font-size:var(--f-size-lg);margin-top:var(--s-sm);max-width:600px;margin-inline:auto}.about-grid{display:grid;grid-template-columns:280px 1fr;gap:var(--s-3xl);align-items:start}.about-photo{width:280px;height:280px;border-radius:50%;overflow:hidden;border:3px solid var(--c-border-hover);position:relative}.about-photo:before{content:"";position:absolute;inset:-6px;border-radius:50%;background:linear-gradient(135deg,var(--c-primary),var(--c-accent));opacity:.2;z-index:-1;filter:blur(12px)}.about-photo img{width:100%;height:100%;object-fit:cover}.about-bio p{color:var(--c-text-muted);margin-bottom:var(--s-md)}.about-bio strong{color:var(--c-text);font-weight:600}.about-tags{display:flex;flex-wrap:wrap;gap:var(--s-sm);margin-top:var(--s-lg)}.about-tag{padding:var(--s-xs) var(--s-md);background:var(--c-primary-soft);color:var(--c-primary);font-size:var(--f-size-sm);font-weight:500;border-radius:var(--radius-full)}.timeline{margin-top:var(--s-3xl)}.timeline-item{display:flex;gap:var(--s-lg);padding-bottom:var(--s-xl);position:relative}.timeline-item:not(:last-child):before{content:"";position:absolute;left:20px;top:44px;bottom:0;width:2px;background:var(--c-border)}.timeline-dot{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:var(--c-primary-soft);border:2px solid var(--c-border-hover);display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-size:var(--f-size-xs);font-weight:700;color:var(--c-primary)}.timeline-content h4{font-size:var(--f-size-base);font-weight:600;margin-bottom:2px}.timeline-content .year{font-family:var(--f-mono);font-size:var(--f-size-xs);color:var(--c-primary);font-weight:600}.timeline-content p{font-size:var(--f-size-sm);color:var(--c-text-muted);margin-top:4px}@media(max-width:768px){.about-grid{grid-template-columns:1fr;justify-items:center;text-align:center}.about-photo{width:200px;height:200px}.about-tags{justify-content:center}}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--s-xl)}.project-card{background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition)}.project-card:hover{border-color:var(--c-border-hover);transform:translateY(-4px);box-shadow:var(--c-shadow)}.project-card-image{aspect-ratio:16/9;background:linear-gradient(135deg,var(--c-primary-soft),var(--c-accent-soft));display:flex;align-items:center;justify-content:center;overflow:hidden}.project-card-image img{width:100%;height:100%;object-fit:cover}.project-card-initials{font-size:var(--f-size-4xl);font-weight:800;color:var(--c-primary);opacity:.2}.project-card-body{padding:var(--s-lg)}.project-card-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--s-sm)}.project-card-category{font-size:var(--f-size-xs);font-weight:600;color:var(--c-primary)}.project-card-year{font-family:var(--f-mono);font-size:var(--f-size-xs);color:var(--c-text-muted)}.project-card h3{font-size:var(--f-size-xl);margin-bottom:var(--s-sm)}.project-card p{font-size:var(--f-size-sm);color:var(--c-text-muted);margin-bottom:var(--s-md);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card-tech{display:flex;flex-wrap:wrap;gap:var(--s-xs);margin-bottom:var(--s-md)}.tech-tag{font-size:var(--f-size-xs);padding:2px var(--s-sm);background:var(--c-bg-alt);border-radius:var(--radius);color:var(--c-text-muted)}.project-card-link{font-size:var(--f-size-sm);font-weight:600;color:var(--c-primary);display:inline-flex;align-items:center;gap:4px;transition:var(--transition)}.project-card-link:hover{gap:8px}@media(max-width:768px){.projects-grid{grid-template-columns:1fr}}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--s-lg)}.skill-group{background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:var(--s-lg);transition:var(--transition)}.skill-group:hover{border-color:var(--c-border-hover)}.skill-group-header{display:flex;align-items:center;gap:var(--s-sm);margin-bottom:var(--s-md)}.skill-group-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--c-primary-soft);border-radius:var(--radius);color:var(--c-primary);font-size:var(--f-size-lg)}.skill-group h3{font-size:var(--f-size-base);font-weight:600}.skill-list{display:flex;flex-wrap:wrap;gap:var(--s-xs)}.skill-item{font-size:var(--f-size-xs);padding:4px var(--s-sm);background:var(--c-bg-alt);border-radius:var(--radius);color:var(--c-text-muted);transition:var(--transition)}.skill-item:hover{color:var(--c-primary);background:var(--c-primary-soft)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-3xl);align-items:start}.contact-item{display:flex;align-items:center;gap:var(--s-md);padding:var(--s-lg);background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--radius-lg);transition:var(--transition)}.contact-item:hover{border-color:var(--c-border-hover);transform:translateY(-2px)}.contact-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--c-primary-soft);border-radius:var(--radius);color:var(--c-primary);flex-shrink:0}.contact-label{font-size:var(--f-size-xs);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.05em}.contact-value{font-weight:600;font-size:var(--f-size-base)}@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}.cta-section{text-align:center;padding:var(--s-3xl);background:linear-gradient(135deg,var(--c-primary-soft),var(--c-accent-soft));border:1px solid var(--c-border);border-radius:var(--radius-lg)}.cta-section p{color:var(--c-text-muted);font-size:var(--f-size-lg);margin:var(--s-md) auto var(--s-xl);max-width:500px}.footer{padding:var(--s-2xl) 0;border-top:1px solid var(--c-border)}.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--s-md)}.footer-text{font-size:var(--f-size-sm);color:var(--c-text-muted)}.footer-links{display:flex;gap:var(--s-lg)}.footer-links a{font-size:var(--f-size-sm);color:var(--c-text-muted);transition:var(--transition)}.footer-links a:hover{color:var(--c-primary)}.breadcrumbs{padding:var(--s-md) 0;font-size:var(--f-size-sm);color:var(--c-text-muted)}.breadcrumbs a{transition:var(--transition)}.breadcrumbs a:hover{color:var(--c-primary)}.breadcrumbs span[aria-hidden]{margin:0 var(--s-sm);opacity:.5}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeInUp .6s ease forwards;opacity:0}.animate-delay-1{animation-delay:.1s}.animate-delay-2{animation-delay:.2s}.animate-delay-3{animation-delay:.3s}.animate-delay-4{animation-delay:.4s}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--c-bg)}::-webkit-scrollbar-thumb{background:var(--c-primary);border-radius:4px;opacity:.5}.faq-item{border:1px solid var(--c-border);border-radius:var(--radius);margin-bottom:var(--s-sm);overflow:hidden}.faq-item summary{padding:var(--s-md) var(--s-lg);font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;transition:var(--transition)}.faq-item summary:hover{background:var(--c-primary-soft)}.faq-item summary:after{content:"+";font-size:var(--f-size-xl);color:var(--c-primary);transition:var(--transition)}.faq-item[open] summary:after{transform:rotate(45deg)}.faq-item .faq-answer{padding:0 var(--s-lg) var(--s-lg);color:var(--c-text-muted);font-size:var(--f-size-sm);line-height:1.8}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.projects-page-link{display:inline-flex;align-items:center;gap:6px;color:var(--c-primary);font-weight:600;font-size:var(--f-size-sm);transition:var(--transition)}.projects-page-link:hover{gap:10px}.projects-page-link svg{width:16px;height:16px}
