*{box-sizing:border-box;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;padding:0;scroll-behavior:smooth}.App{scrollbar-color:var(--accentColor) #0000;scrollbar-width:thin}body{--primaryColor:#0f172a;--secondaryColor:#334155;--accentColor:#3b82f6;--accentHover:#2563eb;--backgroundColor:#fff;--surfaceColor:#f8fafc;--cardBackground:#fff;--textPrimary:#0f172a;--textSecondary:#475569;--textMuted:#64748b;--borderColor:#e2e8f0;--shadowSm:0 1px 2px 0 #0000000d;--shadowMd:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadowLg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadowXl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-size-5xl:3rem;--font-size-6xl:3.75rem;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.625;--gradientPrimary:linear-gradient(135deg,#667eea,#764ba2);--gradientAccent:linear-gradient(135deg,#3b82f6,#8b5cf6);--backgroundGradient:linear-gradient(180deg,#fff,#f8fafc);background:var(--backgroundGradient);background-attachment:fixed;color:var(--textPrimary);line-height:var(--leading-normal);transition:all .3s cubic-bezier(.4,0,.2,1)}body.dark-theme{--primaryColor:#f8fafc;--secondaryColor:#e2e8f0;--accentColor:#60a5fa;--accentHover:#3b82f6;--backgroundColor:#0f172a;--surfaceColor:#1e293b;--cardBackground:#1e293b;--textPrimary:#f8fafc;--textSecondary:#cbd5e1;--textMuted:#94a3b8;--borderColor:#334155;--shadowSm:0 1px 2px 0 #0000004d;--shadowMd:0 4px 6px -1px #0006,0 2px 4px -2px #0006;--shadowLg:0 10px 15px -3px #0006,0 4px 6px -4px #0006;--shadowXl:0 20px 25px -5px #0006,0 8px 10px -6px #0006;--gradientPrimary:linear-gradient(135deg,#4f46e5,#7c3aed);--gradientAccent:linear-gradient(135deg,#60a5fa,#a78bfa);--backgroundGradient:linear-gradient(180deg,#0f172a,#1e293b)}body.other-projects-open{overflow:hidden}.main-container{display:flex;flex-direction:column;gap:var(--space-3xl);margin-top:var(--space-3xl);margin-inline:auto;padding:0 var(--space-lg);width:min(90%,1200px)}h1,h2,h3,h4,h5,h6{color:var(--textPrimary);font-weight:600;line-height:var(--leading-tight)}h1{font-size:var(--font-size-5xl);font-weight:700}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}p{color:var(--textSecondary);line-height:var(--leading-relaxed)}a{color:var(--accentColor);text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1)}a:hover{color:var(--accentHover);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:2px}.btn{align-items:center;background:var(--accentColor);border:none;border-radius:var(--radius-lg);box-shadow:var(--shadowSm);color:#fff;cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);font-weight:500;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);transition:all .2s cubic-bezier(.4,0,.2,1)}.btn:hover{background:var(--accentHover);box-shadow:var(--shadowMd);transform:translateY(-1px)}.btn:active{box-shadow:var(--shadowSm);transform:translateY(0)}.btn-secondary{background:var(--surfaceColor);border:1px solid var(--borderColor);color:var(--textPrimary)}.btn-secondary:hover{color:var(--textPrimary)}.btn-secondary:hover,.card{background:var(--cardBackground)}.card{border:1px solid var(--borderColor);border-radius:var(--radius-xl);box-shadow:var(--shadowSm);padding:var(--space-xl);transition:all .3s cubic-bezier(.4,0,.2,1)}.card:hover{border-color:var(--accentColor);box-shadow:var(--shadowLg);transform:translateY(-2px)}section{padding:var(--space-3xl) 0;scroll-margin-top:80px}section:first-child{padding-top:var(--space-2xl);scroll-margin-top:0}.footer{background:var(--surfaceColor);border-top:1px solid var(--borderColor);flex-direction:column;gap:var(--space-lg);margin-top:var(--space-3xl);padding:var(--space-3xl) var(--space-lg)}.footer,.footer h4{align-items:center;display:flex}.footer h4{color:var(--textSecondary);font-size:var(--font-size-sm);font-weight:500;gap:var(--space-sm)}.footer h4 svg{color:var(--accentColor)}.footer-links{align-items:center;display:flex;gap:var(--space-xl)}.experience-link{color:var(--textSecondary);transition:color .2s ease}.experience-link:hover{color:var(--accentColor)}@media screen and (max-width:1024px){.main-container{padding:0 var(--space-md);width:95%}}@media screen and (max-width:768px){.main-container{gap:var(--space-2xl);margin-top:var(--space-2xl);padding:0 var(--space-md);width:100%}.footer{padding-bottom:calc(70px + var(--space-xl))}.card{padding:var(--space-lg)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-2xl)}section{padding:var(--space-2xl) 0}}nav{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid var(--borderColor);display:flex;height:80px;justify-content:space-between;padding:0 var(--space-xl);position:fixed;top:0;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%;z-index:100}body.dark-theme nav{background:#0f172af2;border-bottom-color:var(--borderColor)}.navbar-brand{align-items:center;display:flex;gap:var(--space-sm);text-decoration:none;transition:transform .2s ease}.navbar-brand:hover{transform:scale(1.05)}.navbar-logo{height:40px;object-fit:contain;transition:filter .3s ease;width:auto}body.dark-theme .navbar-logo{filter:invert(1) brightness(.9)}.nav-links{align-items:center;display:flex;gap:var(--space-lg);list-style:none}.nav-links li a{border-radius:var(--radius-md);color:var(--textSecondary);font-size:var(--font-size-base);font-weight:500;padding:var(--space-sm) var(--space-md);position:relative;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1)}.nav-links li a:hover{transform:translateY(-1px)}.nav-links li a.active-nav-link,.nav-links li a:hover{background:var(--surfaceColor);color:var(--accentColor)}.nav-links li a:after{background:var(--accentColor);border-radius:1px;bottom:-2px;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:all .3s cubic-bezier(.4,0,.2,1);width:0}.nav-links li a.active-nav-link:after,.nav-links li a:hover:after{width:80%}.nav-link-btn{background:none;border:none;border-radius:var(--radius-md);color:var(--textSecondary);cursor:pointer;font-family:inherit;font-size:var(--font-size-base);font-weight:500;padding:var(--space-sm) var(--space-md);position:relative;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1)}.nav-link-btn:hover{transform:translateY(-1px)}.nav-link-btn.active-nav-link,.nav-link-btn:hover{background:var(--surfaceColor);color:var(--accentColor)}.nav-link-btn:after{background:var(--accentColor);border-radius:1px;bottom:-2px;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:all .3s cubic-bezier(.4,0,.2,1);width:0}.nav-link-btn.active-nav-link:after,.nav-link-btn:hover:after{width:80%}.nav-controls{align-items:center;display:flex;gap:var(--space-md)}.theme-toggle-wrapper{position:relative}.darkmode-toggle-label{align-items:center;background:var(--surfaceColor);border:2px solid var(--borderColor);border-radius:50px;cursor:pointer;display:flex;height:32px;justify-content:space-between;overflow:hidden;padding:4px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:60px}.darkmode-toggle-label:hover{border-color:var(--accentColor);box-shadow:0 0 0 4px #3b82f61a}.darkmode-toggle-label:after{background:var(--accentColor);border-radius:50%;box-shadow:var(--shadowMd);content:"";height:22px;left:3px;position:absolute;top:3px;transition:all .3s cubic-bezier(.4,0,.2,1);width:22px;z-index:2}.darkmode-toggle-label .moon,.darkmode-toggle-label .sun{color:var(--textMuted);font-size:14px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1}.darkmode-toggle-label .sun{color:#ffa600}.darkmode-toggle-label .moon{color:#6366f1}#darkmode-toggle{height:0;opacity:0;pointer-events:none;position:absolute;width:0}#darkmode-toggle:checked+.darkmode-toggle-label{background:var(--surfaceColor)}#darkmode-toggle:checked+.darkmode-toggle-label:after{left:calc(100% - 25px)}#darkmode-toggle:checked+.darkmode-toggle-label .sun{transform:scale(.8)}#darkmode-toggle:checked+.darkmode-toggle-label .moon,#darkmode-toggle:not(:checked)+.darkmode-toggle-label .sun{opacity:1;transform:scale(1.1)}#darkmode-toggle:not(:checked)+.darkmode-toggle-label .moon{transform:scale(.8)}.mobile-menu-toggle{border-radius:var(--radius-md);cursor:pointer;display:none;flex-direction:column;gap:4px;padding:var(--space-sm);transition:background .2s ease}.mobile-menu-toggle:hover{background:var(--surfaceColor)}.mobile-menu-toggle span{background:var(--textPrimary);border-radius:2px;height:3px;transition:all .3s cubic-bezier(.4,0,.2,1);width:24px}.mobile-nav{background:var(--backgroundColor);height:calc(100vh - 80px);left:0;padding:var(--space-xl);position:fixed;top:80px;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:100%;z-index:99}.mobile-nav.open{transform:translateX(0)}.mobile-nav-links{display:flex;flex-direction:column;gap:var(--space-lg);list-style:none}.mobile-nav-links li a{border-radius:var(--radius-lg);color:var(--textPrimary);display:block;font-size:var(--font-size-lg);font-weight:500;padding:var(--space-lg);text-decoration:none;transition:all .2s ease}.mobile-nav-links li a.active,.mobile-nav-links li a:hover{background:var(--accentColor);color:#fff}@media screen and (max-width:768px){nav{height:70px;padding:0 var(--space-lg)}.nav-links{display:none}.mobile-menu-toggle{display:flex}.mobile-nav{height:calc(100vh - 70px);top:70px}.nav-controls{gap:var(--space-sm)}}@media screen and (max-width:480px){nav{padding:0 var(--space-md)}.navbar-logo{height:32px}.darkmode-toggle-label{height:28px;width:50px}.darkmode-toggle-label:after{height:18px;left:3px;top:3px;width:18px}#darkmode-toggle:checked+.darkmode-toggle-label:after{left:calc(100% - 21px)}.darkmode-toggle-label .moon,.darkmode-toggle-label .sun{font-size:10px}}.navbar-buttons{align-items:center;display:flex;gap:30px}.navbar-buttons a{background:var(--accentColor);border-radius:var(--radius);box-shadow:2px 2px 4px var(--boxShadow);color:#fff;padding:6px 24px;text-decoration:none}@media screen and (max-width:850px){nav{padding:8px 20px}.navbar-buttons a span,nav ul li a{display:none}.navbar-logo{margin-bottom:10px}}aside{left:var(--space-xl);position:fixed;top:50%;transform:translateY(-50%);width:60px;z-index:50}aside ul{background:var(--cardBackground);border:1px solid var(--borderColor);border-radius:var(--radius-xl);box-shadow:var(--shadowSm);display:flex;flex-direction:column;gap:var(--space-lg);list-style:none;padding:var(--space-lg);width:100%}aside ul li{position:relative}aside ul li a{align-items:center;background:var(--surfaceColor);border:1px solid var(--borderColor);border-radius:var(--radius-lg);display:flex;height:44px;justify-content:center;overflow:hidden;position:relative;width:44px}aside ul li a,aside ul li a:before{transition:all .3s cubic-bezier(.4,0,.2,1)}aside ul li a:before{background:var(--cardBackground);border:1px solid var(--borderColor);border-radius:var(--radius-md);box-shadow:var(--shadowMd);color:var(--textPrimary);content:attr(title);font-size:var(--font-size-sm);font-weight:500;left:calc(100% + var(--space-md));opacity:0;padding:var(--space-xs) var(--space-sm);position:absolute;top:50%;transform:translateY(-50%);visibility:hidden;white-space:nowrap;z-index:100}aside ul li a:hover:before{opacity:1;transform:translateY(-50%) translateX(8px);visibility:visible}aside ul li a svg{fill:var(--textSecondary);height:24px;transition:all .3s cubic-bezier(.4,0,.2,1);width:24px}aside ul li a:hover{background:var(--accentColor);border-color:var(--accentColor);box-shadow:var(--shadowLg);transform:translateX(8px) scale(1.1)}aside ul li a:hover svg{fill:#fff;transform:scale(1.1)}aside ul li a[title=linkedin]:hover{background:#0077b5;border-color:#0077b5}aside ul li a[title=github]:hover{background:#333;border-color:#333}aside ul li a[title=npm]:hover{background:#cb3837;border-color:#cb3837}aside ul li a[title="itch.io"]:hover{background:#fa5c5c;border-color:#fa5c5c}@media screen and (max-width:1024px){aside{left:var(--space-md);width:50px}aside ul{gap:var(--space-md);padding:var(--space-md)}aside ul li a{height:36px;width:36px}aside ul li a svg{height:20px;width:20px}aside ul li a:hover:before{display:none}}@media screen and (max-width:768px){aside{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--cardBackground);border-top:1px solid var(--borderColor);bottom:0;left:0;position:fixed;right:0;top:auto;transform:none;width:100%;z-index:90}aside ul{align-items:center;background:#0000;border:none;box-shadow:none;flex-direction:row;gap:var(--space-xl);height:70px;justify-content:center;padding:var(--space-md) var(--space-lg)}aside ul li a{background:var(--surfaceColor);border:1px solid var(--borderColor);height:44px;width:44px}aside ul li a:hover{background:var(--accentColor);transform:translateY(-4px) scale(1.1)}aside ul li a svg{height:24px;width:24px}aside ul li a:hover:before{display:none}}@media screen and (max-width:480px){aside ul{gap:var(--space-lg);height:60px;padding:var(--space-sm) var(--space-md)}aside ul li a{height:40px;width:40px}aside ul li a svg{height:20px;width:20px}}#home{align-items:center;display:flex;justify-content:space-between;min-height:calc(100vh - 80px);overflow:hidden;padding:var(--space-3xl) 0;position:relative}#home:before{background:var(--gradientAccent);border-radius:50% 0 0 50%;content:"";height:100%;opacity:.03;position:absolute;right:0;top:0;width:50%;z-index:-1}.home-text-wrapper{flex:1 1;max-width:600px;z-index:2}.home-text-wrapper h1{-webkit-text-fill-color:#0000;background:var(--gradientAccent);background-clip:text;-webkit-background-clip:text;font-size:clamp(2.5rem,8vw,4.5rem);font-weight:800;line-height:.9;margin-bottom:var(--space-lg);text-align:left}.home-text-wrapper h2{color:var(--textSecondary);font-size:var(--font-size-lg);font-weight:500;letter-spacing:3px;margin-bottom:var(--space-xl);position:relative;text-transform:uppercase}.home-text-wrapper h2:after{background:var(--accentColor);border-radius:2px;bottom:-8px;content:"";height:3px;left:0;position:absolute;width:60px}.home-description{color:var(--textSecondary);font-size:var(--font-size-lg);line-height:var(--leading-relaxed);margin-bottom:var(--space-2xl);max-width:500px}.home-cta{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-lg)}.home-cta .btn{font-size:var(--font-size-base);font-weight:600;padding:var(--space-md) var(--space-xl)}.home-image-wrapper{align-items:center;animation:float 6s ease-in-out infinite;display:flex;flex:1 1;justify-content:center;margin-left:var(--space-xl);max-width:500px;position:relative}.home-image-wrapper:hover{animation-play-state:paused}.home-image{border-radius:var(--radius-2xl);cursor:pointer;filter:drop-shadow(2px 2px 2px var(--shadowXl));height:auto;max-width:400px;transform:scale(1) rotate(0deg);transition:transform .6s cubic-bezier(.4,0,.2,1),filter .6s cubic-bezier(.4,0,.2,1);width:100%}.home-image:hover{filter:drop-shadow(4px 4px 8px var(--shadowXl)) brightness(1.1);transform:scale(1.05) rotate(1deg)}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}25%{transform:translateY(-10px) rotate(.5deg)}50%{transform:translateY(-20px) rotate(0deg)}75%{transform:translateY(-10px) rotate(-.5deg)}}.home-image-wrapper:before{animation:pulse 4s ease-in-out infinite;background:var(--accentColor);border-radius:50%;content:"";height:100px;opacity:.1;position:absolute;right:-20px;top:-20px;width:100px;z-index:-1}.home-image-wrapper:after{animation:morph 8s ease-in-out infinite;background:var(--gradientPrimary);border-radius:30% 70% 70% 30%/30% 30% 70% 70%;bottom:-30px;content:"";height:150px;left:-30px;opacity:.05;position:absolute;width:150px;z-index:-1}@keyframes morph{0%,to{border-radius:30% 70% 70% 30%/30% 30% 70% 70%}50%{border-radius:70% 30% 30% 70%/70% 70% 30% 30%}}.discover-more-wrapper{animation:bounce 2s infinite;bottom:var(--space-xl);left:50%;position:absolute;transform:translateX(-50%);z-index:10}.discover-more-btn{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#0000;background:#ffffff0d;border:1px solid var(--textMuted);border-radius:var(--radius-lg);color:var(--textMuted);cursor:pointer;display:flex;flex-direction:column;font-size:var(--font-size-xs);font-weight:400;gap:var(--space-xs);letter-spacing:.5px;opacity:.8;padding:var(--space-sm) var(--space-md);transition:all .3s cubic-bezier(.4,0,.2,1)}.discover-more-btn:hover{background:#ffffff1a;border-color:var(--textSecondary);box-shadow:var(--shadowSm);color:var(--textSecondary);opacity:1;transform:translateY(-1px)}.discover-more-btn:hover .discover-arrow{transform:translateY(1px)}.discover-arrow{color:var(--accentColor);font-size:var(--font-size-xs);transition:transform .3s ease}@keyframes bounce{0%,20%,50%,80%,to{transform:translateX(-50%) translateY(0)}40%{transform:translateX(-50%) translateY(-10px)}60%{transform:translateX(-50%) translateY(-5px)}}@media screen and (max-width:1024px){#home{flex-direction:column;gap:var(--space-3xl);padding:var(--space-2xl) 0;text-align:center}.home-image-wrapper{margin-left:0;order:-1}.home-text-wrapper{max-width:100%}.home-text-wrapper h2:after{left:50%;transform:translateX(-50%)}}@media screen and (max-width:768px){#home{gap:var(--space-2xl);min-height:calc(100vh - 60px);padding:var(--space-xl) 0}.home-text-wrapper h1{font-size:clamp(2rem,12vw,3rem);margin-bottom:var(--space-md)}.home-text-wrapper h2{font-size:var(--font-size-base);letter-spacing:2px;margin-bottom:var(--space-lg)}.home-description{font-size:var(--font-size-base);margin-bottom:var(--space-xl)}.home-cta{gap:var(--space-md);justify-content:center}.home-cta .btn{font-size:var(--font-size-sm);padding:var(--space-sm) var(--space-lg)}.home-image{max-width:300px}.discover-more-wrapper,.home-image-wrapper:after,.home-image-wrapper:before{display:none}}@media screen and (max-width:480px){.home-cta{flex-direction:column;width:100%}.home-cta .btn{justify-content:center;width:100%}.discover-more-wrapper{display:none}}#about{padding:var(--space-3xl) 0}.about-header{margin-bottom:var(--space-3xl);text-align:center}.about-header h2{-webkit-text-fill-color:#0000;background:var(--gradientAccent);background-clip:text;-webkit-background-clip:text;font-size:var(--font-size-4xl);margin-bottom:var(--space-md)}.about-header p{color:var(--textSecondary);font-size:var(--font-size-lg);line-height:var(--leading-relaxed);margin:0 auto;max-width:800px}.section-header{margin-bottom:var(--space-lg);text-align:center}.section-header h2{-webkit-text-fill-color:#0000;background:var(--gradientAccent);background-clip:text;-webkit-background-clip:text;font-size:var(--font-size-3xl);margin-bottom:var(--space-sm);position:relative}.section-header p{color:var(--textSecondary);font-size:var(--font-size-base);line-height:var(--leading-relaxed);margin:0 auto;max-width:600px}.timeline{margin:0 auto;max-width:900px;position:relative}.timeline:before{background:linear-gradient(to bottom,var(--accentColor),var(--accentColor) 80%,#0000);border-radius:2px;bottom:0;content:"";left:30px;position:absolute;top:0;width:4px}.timeline-item{margin-bottom:var(--space-xl);padding-left:80px;position:relative}.timeline-marker{background:var(--cardBackground);border:4px solid var(--accentColor);border-radius:50%;height:20px;left:22px;position:absolute;top:24px;transition:all .3s ease;width:20px;z-index:2}.timeline-marker.current{animation:pulse 2s infinite;background:var(--accentColor);box-shadow:0 0 20px #3b82f666}@keyframes pulse{0%{box-shadow:0 0 0 0 #3b82f6b3}70%{box-shadow:0 0 0 10px #3b82f600}to{box-shadow:0 0 0 0 #3b82f600}}.experience-card,.timeline-content{position:relative}.experience-card{background:var(--cardBackground);border:1px solid var(--borderColor);border-radius:var(--radius-xl);overflow:hidden;padding:var(--space-lg);transition:all .3s cubic-bezier(.4,0,.2,1)}.experience-card:before{background:var(--accentColor);content:"";height:100%;left:0;position:absolute;top:0;transform:scaleY(0);transition:transform .3s ease;width:4px}.experience-card:hover{border-color:var(--accentColor);box-shadow:var(--shadowLg);transform:translateY(-4px)}.experience-card:hover:before{transform:scaleY(1)}.experience-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:var(--space-md);justify-content:space-between;margin-bottom:var(--space-md)}.experience-meta{display:flex;flex-direction:column;gap:var(--space-sm)}.experience-date,.experience-location{align-items:center;color:var(--textSecondary);display:flex;font-size:var(--font-size-sm);font-weight:500;gap:var(--space-sm)}.experience-date svg,.experience-location svg{color:var(--accentColor);height:14px;width:14px}.visit-link{align-items:center;background:var(--accentColor);border-radius:var(--radius-lg);box-shadow:var(--shadowSm);color:#fff;display:inline-flex;font-size:var(--font-size-sm);font-weight:500;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.visit-link:hover{background:var(--accentHover);box-shadow:var(--shadowMd);color:#fff!important;text-decoration:none;transform:translateY(-1px)}.experience-title{margin-bottom:var(--space-md)}.experience-title h3{color:var(--textPrimary);font-size:var(--font-size-lg);font-weight:600;margin:0 0 var(--space-xs) 0}.experience-title h4{color:var(--accentColor);font-size:var(--font-size-base);font-weight:500;margin:0}.experience-description{display:flex;flex-direction:column;gap:var(--space-sm)}.experience-summary{color:var(--textSecondary);font-size:var(--font-size-sm);font-style:italic;line-height:var(--leading-relaxed);margin:0}.experience-bullets{display:block;list-style-position:outside!important;list-style-type:disc!important;margin:0;padding-left:var(--space-lg)}.experience-bullets li{background:none!important;border:none!important;border-radius:0!important;box-shadow:none!important;color:var(--textSecondary);font-size:var(--font-size-sm);line-height:var(--leading-normal);margin-left:var(--space-lg);overflow:visible!important;padding:0!important;position:static!important;transform:none!important;transition:none!important}.experience-bullets li:before{display:none!important}.experience-bullets li:hover{background:none!important;border:none!important;border-color:initial!important;box-shadow:none!important;transform:none!important}.highlight-achievement{background:#3b82f61a;border-left:4px solid var(--accentColor);border-radius:var(--radius-md);color:var(--textPrimary);font-size:var(--font-size-base);line-height:var(--leading-relaxed);padding:var(--space-md)}.achievement-list{display:flex;flex-direction:column;gap:var(--space-md);list-style:none;margin:0;padding:0}.achievement-list li{color:var(--textSecondary);font-size:var(--font-size-base);line-height:var(--leading-relaxed);padding-left:var(--space-lg);position:relative}.achievement-list li:before{color:var(--accentColor);content:"▸";font-size:var(--font-size-lg);font-weight:700;left:0;position:absolute}.tech-stack{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-lg)}.tech-tag{background:#3b82f61a;border:1px solid #3b82f633;border-radius:var(--radius-full);color:var(--accentColor);display:inline-block;transition:all .2s ease}.tech-tag:hover{background:var(--accentColor);color:#fff;transform:translateY(-1px)}.education-grid{grid-gap:var(--space-xl);display:grid;gap:var(--space-xl);grid-template-columns:1fr;margin:0 auto;max-width:900px}.education-card{background:var(--cardBackground);border:1px solid var(--borderColor);border-radius:var(--radius-xl);display:flex;gap:var(--space-md);overflow:hidden;padding:var(--space-lg);position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.education-card:before{background:var(--accentColor);content:"";height:100%;left:0;position:absolute;top:0;transform:scaleY(0);transition:transform .3s ease;width:4px}.education-card:hover{border-color:var(--accentColor);box-shadow:var(--shadowLg);transform:translateY(-4px)}.education-card:hover:before{transform:scaleY(1)}.education-icon{align-items:center;background:linear-gradient(135deg,var(--accentColor),var(--accentHover));border-radius:var(--radius-xl);color:#fff;display:flex;flex-shrink:0;font-size:var(--font-size-xl);height:60px;justify-content:center;width:60px}.education-content{display:flex;flex:1 1;flex-direction:column;gap:var(--space-md)}.education-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:var(--space-md);justify-content:space-between}.education-meta{display:flex;flex-direction:column;gap:var(--space-sm)}.education-date,.education-location{align-items:center;color:var(--textSecondary);display:flex;font-size:var(--font-size-sm);font-weight:500;gap:var(--space-sm)}.education-date svg,.education-location svg{color:var(--accentColor);height:14px;width:14px}.education-details h3{color:var(--textPrimary);font-size:var(--font-size-lg);font-weight:600;margin:0 0 var(--space-xs) 0}.education-details h4{color:var(--accentColor);font-size:var(--font-size-base);font-weight:500;margin:0 0 var(--space-sm) 0}.education-details p{color:var(--textSecondary);font-size:var(--font-size-sm);line-height:var(--leading-relaxed);margin:0}.tools-wrapper{margin-bottom:var(--space-3xl)}.tools-header{margin-bottom:var(--space-2xl);text-align:center}.tools-header h3{color:var(--textPrimary);font-size:var(--font-size-2xl);margin-bottom:var(--space-sm)}.tools-header p{color:var(--textSecondary);font-size:var(--font-size-base)}.tool-category{margin-bottom:var(--space-2xl);text-align:center}.category-title{color:var(--textPrimary);font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-lg);position:relative}.category-title:after{background:var(--accentColor);border-radius:2px;bottom:-8px;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:60px}.tool-cards-wrapper{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(100px,1fr));margin:0 auto;max-width:900px}.tool-card{align-items:center;background:var(--cardBackground);border:1px solid var(--borderColor);border-radius:var(--radius-xl);cursor:pointer;display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-lg);transition:all .3s cubic-bezier(.4,0,.2,1)}.tool-card:hover{border-color:var(--accentColor);box-shadow:var(--shadowLg);transform:translateY(-4px)}.tool-card img{height:48px;object-fit:contain;transition:transform .2s ease;width:48px}.tool-card img[alt="mcp servers"],.tool-card img[alt=aws],.tool-card img[alt=github],.tool-card img[alt=openai]{background:#fff;border-radius:var(--radius-sm);padding:4px}.tool-card:hover img{transform:scale(1.1)}.tool-card h3{color:var(--textSecondary);font-size:var(--font-size-sm);font-weight:500;margin:0;text-align:center}.about-info-wrapper{grid-gap:var(--space-3xl);display:grid;gap:var(--space-3xl);grid-template-columns:1fr 1fr}.about-item-wrapper{display:flex;flex-direction:column;gap:var(--space-xl)}.about-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-lg)}.about-item-header h3{color:var(--textPrimary);font-size:var(--font-size-2xl);margin:0}.about-item-header a{align-items:center;background:var(--accentColor);border-radius:var(--radius-lg);box-shadow:var(--shadowSm);color:#fff;display:inline-flex;font-size:var(--font-size-sm);font-weight:500;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1)}.about-item-header a:hover{background:var(--accentHover);box-shadow:var(--shadowMd);transform:translateY(-1px)}.about-item-wrapper ul{display:flex;flex-direction:column;gap:var(--space-sm);list-style:none;margin:0;padding:0}.about-item-wrapper ul li{background:var(--cardBackground);border:1px solid var(--borderColor);border-radius:var(--radius-xl);overflow:hidden;padding:var(--space-xl);position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.about-item-wrapper ul li:before{background:var(--accentColor);content:"";height:100%;left:0;position:absolute;top:0;transform:scaleY(0);transition:transform .3s ease;width:4px}.about-item-wrapper ul li:hover{border-color:var(--accentColor);box-shadow:var(--shadowLg);transform:translateY(-2px)}.about-item-wrapper ul li:hover:before{transform:scaleY(1)}.about-item-content{display:flex;flex-direction:column;gap:var(--space-md)}.about-item-title{color:var(--textPrimary);font-size:var(--font-size-lg);font-weight:600;margin:0}.about-item-subtitle{color:var(--accentColor);font-size:var(--font-size-base);font-weight:500;margin:0}.about-item-date{color:var(--textMuted);font-size:var(--font-size-sm);font-weight:400;margin:0}.about-item-description{color:var(--textSecondary);font-size:var(--font-size-base);line-height:var(--leading-relaxed);margin:0}@media screen and (max-width:1024px){.about-info-wrapper{gap:var(--space-2xl);grid-template-columns:1fr}.tool-cards-wrapper{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(80px,1fr))}.timeline:before{left:20px}.timeline-item{padding-left:60px}.timeline-marker{left:12px}.education-card{flex-direction:column;gap:var(--space-md)}.education-icon{align-self:flex-start}}@media screen and (max-width:768px){.about-header h2{font-size:var(--font-size-3xl)}.about-header p{font-size:var(--font-size-base)}.section-header h2{font-size:var(--font-size-2xl)}.tool-cards-wrapper{gap:var(--space-sm);grid-template-columns:repeat(auto-fit,minmax(70px,1fr))}.category-title{font-size:var(--font-size-md);margin-bottom:var(--space-md)}.tool-card{padding:var(--space-md)}.tool-card img{height:40px;width:40px}.timeline:before{display:none}.timeline-item{margin-bottom:var(--space-2xl);padding-left:0}.timeline-marker{display:none}.education-card,.experience-card{padding:var(--space-lg)}.education-header,.experience-header{align-items:flex-start;flex-direction:column;gap:var(--space-sm)}.visit-link{justify-content:center;width:100%}.experience-title h3{font-size:var(--font-size-lg)}.education-details h3,.experience-title h4{font-size:var(--font-size-base)}.education-details h4{font-size:var(--font-size-sm)}}@media screen and (max-width:480px){.tool-cards-wrapper{grid-template-columns:repeat(3,1fr)}.education-card,.experience-card{padding:var(--space-md)}.education-meta,.experience-meta{flex-direction:row;flex-wrap:wrap}.tech-stack{gap:var(--space-xs)}.tech-tag{font-size:10px;padding:4px 8px}}#projects{padding:var(--space-3xl) 0}.projects-header{margin-bottom:var(--space-3xl);text-align:center}.projects-header h2{-webkit-text-fill-color:#0000;background:var(--gradientAccent);background-clip:text;-webkit-background-clip:text;font-size:var(--font-size-4xl);margin-bottom:var(--space-md)}.projects-header p{color:var(--textSecondary);font-size:var(--font-size-lg);line-height:var(--leading-relaxed);margin:0 auto var(--space-xl);max-width:600px}.project-filters{display:flex;flex-wrap:wrap;gap:var(--space-md);justify-content:center;margin-bottom:var(--space-3xl)}.filter-btn{background:var(--surfaceColor);border:1px solid var(--borderColor);border-radius:var(--radius-lg);color:var(--textSecondary);cursor:pointer;font-size:var(--font-size-sm);font-weight:500;padding:var(--space-sm) var(--space-lg);transition:all .2s cubic-bezier(.4,0,.2,1)}.filter-btn.active,.filter-btn:hover{background:var(--accentColor);border-color:var(--accentColor);box-shadow:var(--shadowSm);color:#fff;transform:translateY(-1px)}.project-cards-wrapper{grid-gap:var(--space-2xl);display:grid;gap:var(--space-2xl);grid-template-columns:repeat(2,1fr);margin-bottom:var(--space-2xl)}.project-card{background:var(--cardBackground);border:1px solid var(--borderColor);border-radius:var(--radius-xl);overflow:hidden;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.project-card:hover{border-color:var(--accentColor);box-shadow:var(--shadowXl);transform:translateY(-8px)}.project-media-container{background:var(--surfaceColor);height:240px;overflow:hidden;position:relative;width:100%}.project-media{height:100%;object-fit:cover;object-position:center;transition:transform .3s ease;width:100%}video:fullscreen{background:#000;object-fit:contain!important}video:-webkit-full-screen{background:#000;object-fit:contain!important}video:-moz-full-screen{background:#000;object-fit:contain!important}video:-ms-fullscreen{background:#000;object-fit:contain!important}.project-card:hover .project-media{transform:scale(1.05)}.project-type-badge{background:var(--accentColor);border-radius:var(--radius-md);color:#fff;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.5px;padding:var(--space-xs) var(--space-sm);position:absolute;right:var(--space-md);text-transform:uppercase;top:var(--space-md)}.project-content{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-xl)}.project-header{align-items:flex-start;display:flex;gap:var(--space-md);justify-content:space-between}.project-title{color:var(--textPrimary);font-size:var(--font-size-xl);font-weight:600;line-height:var(--leading-tight);margin:0}.project-links{display:flex;flex-shrink:0;gap:var(--space-sm)}.project-link{align-items:center;background:var(--surfaceColor);border:1px solid var(--borderColor);border-radius:var(--radius-md);color:var(--textSecondary);display:flex;height:36px;justify-content:center;text-decoration:none;transition:all .2s ease;width:36px}.project-link:hover{background:var(--accentColor);border-color:var(--accentColor);color:#fff;transform:translateY(-1px)}.project-description{color:var(--textSecondary);font-size:var(--font-size-base);line-height:var(--leading-relaxed);margin:0}.project-tech-stack{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.tech-tag{color:var(--textMuted);font-size:var(--font-size-xs);font-weight:500;padding:var(--space-xs) var(--space-sm)}.tech-icon,.tech-tag{background:var(--surfaceColor);border:1px solid var(--borderColor);border-radius:var(--radius-md)}.tech-icon{align-items:center;display:flex;height:28px;justify-content:center;padding:4px;transition:all .2s ease;width:28px}.tech-icon:hover{background:var(--accentColor);border-color:var(--accentColor);transform:scale(1.1)}.tech-icon img{height:20px;object-fit:contain;width:20px}.featured-projects{margin-bottom:var(--space-3xl)}.featured-projects h3{color:var(--textPrimary);font-size:var(--font-size-2xl);margin-bottom:var(--space-xl);text-align:center}.show-more-container{display:flex;justify-content:center;margin-top:var(--space-2xl)}.show-more-btn{background:var(--accentColor);border:none;border-radius:var(--radius-lg);box-shadow:var(--shadowSm);color:#fff;cursor:pointer;font-size:var(--font-size-base);font-weight:600;padding:var(--space-md) var(--space-2xl);transition:all .2s cubic-bezier(.4,0,.2,1)}.show-more-btn:hover{background:var(--accentHover);box-shadow:var(--shadowMd);transform:translateY(-1px)}.project-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000c;display:flex;height:100%;justify-content:center;left:0;opacity:0;position:fixed;top:0;transition:all .3s ease;visibility:hidden;width:100%;z-index:1000}.project-overlay.open{opacity:1;visibility:visible}.project-modal{background:var(--cardBackground);border-radius:var(--radius-xl);max-height:90vh;max-width:90vw;overflow-y:auto;padding:var(--space-2xl);position:relative}.modal-close,.project-modal{border:1px solid var(--borderColor)}.modal-close{background:var(--surfaceColor);position:absolute;right:var(--space-lg);top:var(--space-lg)}.modal-close:hover{background:var(--accentColor);border-color:var(--accentColor);color:#fff}.other-projects-button{background:var(--surfaceColor);border:1px solid var(--borderColor);border-radius:var(--radius-lg);color:var(--textPrimary);cursor:pointer;display:block;font-size:var(--font-size-base);font-weight:500;margin:0 auto;padding:var(--space-md) var(--space-xl);transition:all .2s ease}.other-projects-button:hover{background:var(--accentColor);border-color:var(--accentColor);box-shadow:var(--shadowSm);color:#fff;transform:translateY(-1px)}.other-projects-wrapper{display:flex;flex-direction:column;z-index:100}.other-projects-wrapper,.overlay{height:100vh;left:0;position:fixed;top:0;width:100vw}.overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000c}.other-projects-content{border:1px solid var(--borderColor);border-radius:var(--radius-xl);box-shadow:var(--shadowXl);flex-direction:column;margin:var(--space-xl) auto;max-height:calc(100vh - 2rem);position:relative;width:min(90%,1200px);z-index:20}.modal-header,.other-projects-content{background:var(--backgroundColor);display:flex}.modal-header{align-items:center;border-bottom:1px solid var(--borderColor);border-radius:var(--radius-xl) var(--radius-xl) 0 0;justify-content:space-between;min-height:64px;padding:var(--space-xl) var(--space-2xl);position:-webkit-sticky;position:sticky;top:0;z-index:10}.modal-header h3{color:var(--textPrimary);font-size:var(--font-size-2xl);line-height:1;margin:0}.modal-close,.modal-header h3{align-items:center;display:flex}.modal-close{background:none;border:none;border-radius:var(--radius-md);color:var(--textSecondary);cursor:pointer;flex-shrink:0;font-size:var(--font-size-xl);height:40px;justify-content:center;padding:0;transition:all .2s ease;width:40px}.modal-close:hover{background:var(--surfaceColor);color:var(--textPrimary)}.modal-body{flex:1 1;overflow-y:auto;padding:var(--space-lg) var(--space-2xl) var(--space-2xl)}@media screen and (max-width:1024px){.project-cards-wrapper{gap:var(--space-xl);grid-template-columns:repeat(2,1fr)}}@media screen and (max-width:768px){.projects-header h2{font-size:var(--font-size-3xl)}.projects-header p{font-size:var(--font-size-base)}.project-cards-wrapper{gap:var(--space-lg);grid-template-columns:1fr}.project-filters{gap:var(--space-sm)}.filter-btn{font-size:var(--font-size-xs);padding:var(--space-sm) var(--space-md)}.project-content{padding:var(--space-lg)}.project-header{align-items:flex-start;flex-direction:column;gap:var(--space-sm)}.project-links{align-self:stretch;justify-content:flex-end}.other-projects-content{margin:var(--space-md);max-height:calc(100vh - 4rem);width:calc(100vw - 2rem)}.modal-header{padding:var(--space-lg) var(--space-lg) var(--space-md)}.modal-header h3{font-size:var(--font-size-xl)}.modal-body{padding:var(--space-md) var(--space-lg) var(--space-lg)}}@media screen and (max-width:480px){.project-modal{margin:var(--space-md);max-width:calc(100vw - 2rem);padding:var(--space-lg)}.project-tech-stack{gap:var(--space-xs)}.tech-tag{font-size:10px;padding:2px var(--space-xs)}.tech-icon{height:22px;padding:2px;width:22px}.tech-icon img{height:18px;width:18px}}#contact{padding:var(--space-3xl) 0}.contact-header{margin-bottom:var(--space-3xl);text-align:center}.contact-header h2{-webkit-text-fill-color:#0000;background:var(--gradientAccent);background-clip:text;-webkit-background-clip:text;font-size:var(--font-size-4xl);margin-bottom:var(--space-md)}.contact-header p{color:var(--textSecondary);font-size:var(--font-size-lg);line-height:var(--leading-relaxed);margin:0 auto;max-width:600px}.contact-content{grid-gap:var(--space-3xl);align-items:start;display:grid;gap:var(--space-3xl);grid-template-columns:1fr 1fr}.contact-info{background:var(--cardBackground);border:1px solid var(--borderColor);border-radius:var(--radius-xl);box-shadow:var(--shadowSm);padding:var(--space-3xl);transition:all .3s cubic-bezier(.4,0,.2,1)}.contact-info:hover{box-shadow:var(--shadowLg);transform:translateY(-2px)}.contact-info-header{margin-bottom:var(--space-2xl);text-align:center}.contact-info-header img{border-radius:10%;margin-bottom:var(--space-lg);transition:transform .3s ease;width:180px}.contact-info-header img:hover{transform:scale(1.1) rotate(5deg)}.contact-info-header h3{color:var(--textPrimary);font-size:var(--font-size-2xl);margin:0}.contact-info-details{display:flex;flex-direction:column;gap:var(--space-lg)}.contact-detail{align-items:center;background:var(--surfaceColor);border:1px solid var(--borderColor);border-radius:var(--radius-lg);display:flex;gap:var(--space-md);padding:var(--space-md);transition:all .2s ease}.contact-detail:hover{background:var(--accentColor);color:#fff;transform:translateX(4px)}.contact-detail-icon{align-items:center;background:var(--accentColor);border-radius:var(--radius-lg);color:#fff;display:flex;flex-shrink:0;font-size:var(--font-size-lg);height:48px;justify-content:center;width:48px}.contact-detail:hover .contact-detail-icon{background:#fff;color:var(--accentColor)}.contact-detail-content{flex:1 1}.contact-detail-content h4{color:var(--textMuted);font-size:var(--font-size-sm);font-weight:600;letter-spacing:.5px;margin:0 0 var(--space-xs) 0;text-transform:uppercase}.contact-detail:hover .contact-detail-content h4{color:#fffc}.contact-detail-content p{color:var(--textPrimary);font-size:var(--font-size-base);font-weight:500;margin:0}.contact-detail:hover .contact-detail-content p{color:#fff}.contact-detail-content a{color:inherit;text-decoration:none;transition:color .2s ease}.contact-detail-content a:hover{text-decoration:underline}.contact-form{background:var(--cardBackground);border:1px solid var(--borderColor);border-radius:var(--radius-xl);box-shadow:var(--shadowSm);padding:var(--space-3xl);transition:all .3s cubic-bezier(.4,0,.2,1)}.contact-form:hover{box-shadow:var(--shadowLg);transform:translateY(-2px)}.contact-form h3{color:var(--textPrimary);font-size:var(--font-size-2xl);margin:0 0 var(--space-xl) 0;text-align:center}.contact-form form{display:flex;flex-direction:column;gap:var(--space-lg)}.contact-form-group{display:flex;flex-direction:column;gap:var(--space-sm)}.contact-form-group label{color:var(--textPrimary);font-size:var(--font-size-sm);font-weight:600;letter-spacing:.5px;text-transform:uppercase}.contact-form input,.contact-form textarea{background:var(--surfaceColor);border:1px solid var(--borderColor);border-radius:var(--radius-lg);color:var(--textPrimary);font-family:inherit;font-size:var(--font-size-base);padding:var(--space-md);resize:none;transition:all .2s ease}.contact-form input:focus,.contact-form textarea:focus{background:var(--cardBackground);border-color:var(--accentColor);box-shadow:0 0 0 3px #3b82f61a;outline:none}.contact-form textarea{max-height:200px;min-height:120px}.contact-form button{align-items:center;background:var(--accentColor);border:none;border-radius:var(--radius-lg);box-shadow:var(--shadowSm);color:#fff;cursor:pointer;display:flex;font-size:var(--font-size-base);font-weight:600;gap:var(--space-sm);justify-content:center;margin-top:var(--space-md);padding:var(--space-md) var(--space-xl);transition:all .2s cubic-bezier(.4,0,.2,1)}.contact-form button:hover{background:var(--accentHover);box-shadow:var(--shadowMd);transform:translateY(-1px)}.contact-form button:active{box-shadow:var(--shadowSm);transform:translateY(0)}body.dark-theme .contact-info-header img{filter:invert(1) brightness(.9)}@media screen and (max-width:1024px){.contact-content{gap:var(--space-2xl);grid-template-columns:1fr}}@media screen and (max-width:768px){.contact-header h2{font-size:var(--font-size-3xl)}.contact-header p{font-size:var(--font-size-base)}.contact-form,.contact-info{padding:var(--space-xl)}.contact-info-header img{width:80px}.contact-detail{padding:var(--space-sm)}.contact-detail-icon{font-size:var(--font-size-base);height:40px;width:40px}}@media screen and (max-width:480px){.contact-form,.contact-info{padding:var(--space-lg)}.contact-detail{flex-direction:column;gap:var(--space-sm);text-align:center}.contact-detail:hover{transform:translateY(-2px)}}
/*# sourceMappingURL=main.4c719d65.css.map*/