*{box-sizing:border-box;margin:0;padding:0}body{font-feature-settings:"liga" 1,"kern" 1;background:#fff;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Helvetica Neue,Arial,Segoe UI,Roboto,sans-serif;line-height:1.6;min-height:100vh;overflow-x:hidden;scroll-behavior:smooth;transition:all .4s cubic-bezier(.165,.84,.44,1)}body.dark-mode{color:#e5e7eb}body.dark-mode .section-title{color:#fff}body.dark-mode .section-subtitle{color:#9ca3af}body.dark-mode .card{background:#1f2937;border-color:#374151;color:#e5e7eb}body.dark-mode .card:hover{border-color:#60a5fa}.header{position:relative!important;z-index:1000!important}main{position:relative;width:100%;z-index:1}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{margin:0 auto;max-width:1200px;padding:0 20px}.container,.section{position:relative;z-index:1}.section{padding:80px 0}.section-dark{background:#1f2937;color:#fff}.section-dark .section-title{color:#fff}.section-dark .card{background:#374151;border-color:#4b5563;color:#fff}.section-dark .card:hover{border-color:#60a5fa}.section-title{animation:fadeInUp .8s cubic-bezier(.165,.84,.44,1) forwards;animation-delay:.2s;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Helvetica Neue,sans-serif;opacity:0;transform:translateY(30px)}.section-subtitle{animation:fadeInUp .8s cubic-bezier(.165,.84,.44,1) forwards;animation-delay:.4s;font-weight:400;line-height:1.5;opacity:0;text-align:center;transform:translateY(20px)}.btn{-webkit-tap-highlight-color:transparent;border-radius:25px;display:inline-block;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Helvetica Neue,sans-serif;overflow:hidden;padding:16px 32px;position:relative;text-decoration:none;transition:all .4s cubic-bezier(.165,.84,.44,1)}.btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s cubic-bezier(.165,.84,.44,1);width:100%}.btn:hover:before{left:100%}.btn-primary{background:linear-gradient(135deg,#1f2937,#374151);box-shadow:0 4px 15px #0000001a;color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#111827,#1f2937);box-shadow:0 15px 35px #00000026;transform:translateY(-3px) scale(1.02)}.btn-primary:active{transform:translateY(-1px) scale(.98);transition:all .1s ease}.btn-secondary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #1f293733;color:#1f2937}.btn-secondary:hover{background:#1f2937;border-color:#1f2937;box-shadow:0 15px 35px #1f293733;color:#fff;transform:translateY(-3px) scale(1.02)}.btn-secondary:active{transform:translateY(-1px) scale(.98);transition:all .1s ease}@keyframes fadeInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes gentleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.reveal{opacity:0;transform:translateY(30px);transition:all .8s cubic-bezier(.165,.84,.44,1)}.reveal.visible{opacity:1;transform:translateY(0)}*{-webkit-tap-highlight-color:transparent;touch-action:manipulation}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}a,button,input,textarea{min-height:44px;min-width:44px}@media (max-width:768px){.container{max-width:100%;padding:0 1rem}.section{padding:3rem 0}.section-title{font-size:2rem;line-height:1.2}.section-subtitle{font-size:1rem;padding:0 1rem}}@media (max-width:480px){.container{padding:0 .75rem}.section{padding:2.5rem 0}.section-title{font-size:1.75rem}.section-subtitle{font-size:.95rem}}.header{left:50%;max-width:90vw;padding:0;pointer-events:none;position:fixed;top:1.5rem;transform:translateX(-50%);transition:all .4s cubic-bezier(.25,.8,.25,1);width:auto;z-index:1000}.nav-wrapper{justify-content:center;pointer-events:auto}.nav,.nav-wrapper{align-items:center;display:flex;position:relative}.nav{-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);background:#ffffffd9;border:1px solid #fff3;border-radius:50px;box-shadow:0 12px 40px #00000026,0 4px 12px #0000001a,inset 0 1px 2px #fffffff2,inset 0 -1px 2px #fff3;gap:3rem;justify-content:space-between;min-width:650px;overflow:hidden;padding:.75rem 1.5rem;transition:all .4s cubic-bezier(.165,.84,.44,1)}.logo{flex-shrink:0;transition:all .4s cubic-bezier(.25,.8,.25,1)}.logo h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1a1a1a,#2563eb);-webkit-background-clip:text;background-clip:text;color:#1a1a1a;font-size:1.1rem;font-weight:700;margin:0}.nav .mobile-logo{display:none}.nav-list{flex:1 1;gap:.5rem;list-style:none;margin:0;padding:0}.dark-mode-toggle,.nav-list{align-items:center;display:flex;justify-content:center}.dark-mode-toggle{background:#0000000d;border:1px solid #0000001a;border-radius:50%;cursor:pointer;flex-shrink:0;font-size:1.25rem;height:36px;transition:all .3s ease;width:36px}.dark-mode-toggle:hover{background:#ffffffe6;box-shadow:0 6px 20px #00000026,inset 0 1px 2px #fffffff2;transform:translateY(-50%) scale(1.05)}.header.scrolled .nav{background:#ffffffd9;box-shadow:0 12px 40px #00000026,0 4px 12px #0000001a,inset 0 1px 2px #fffffff2,inset 0 -1px 2px #fff3}.nav:before{background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .8s cubic-bezier(.4,0,.2,1);width:100%}.nav:hover:before{left:100%}.nav:after{background:radial-gradient(circle,#2563eb1a 0,#0000 70%);border-radius:50px;content:"";height:150%;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%) scale(0);transition:transform .6s cubic-bezier(.34,1.56,.64,1);width:150%;z-index:-1}.header.scrolled .nav:after{transform:translate(-50%,-50%) scale(1)}.nav-list li button{border-radius:20px;color:#4b5563;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Helvetica Neue,sans-serif;padding:.5rem 1rem;transition:all .3s ease}.nav-list li button:hover{background:#2563eb1a}.nav-list li{position:relative}.nav-list li button{background:none;border:none;border-radius:25px;color:#374151;cursor:pointer;font-size:.9rem;font-weight:500;overflow:hidden;padding:.75rem 1.25rem;position:relative;transition:all .3s cubic-bezier(.25,.8,.25,1);white-space:nowrap}.nav-list li button:before{background:#2563eb1a;border-radius:25px;bottom:0;content:"";left:0;position:absolute;right:0;top:0;transform:scale(0);transition:transform .3s cubic-bezier(.34,1.56,.64,1);z-index:-1}.nav-list li button:hover{color:#2563eb;transform:translateY(-1px)}.nav-list li button:hover:before{transform:scale(1)}.nav-list li button:active{transform:translateY(0)}.mobile-menu-toggle,.nav-list.mobile-dropdown{display:none}.mobile-menu-toggle span{background:linear-gradient(90deg,#374151,#2563eb);border-radius:1px;height:2px;margin:2px 0;transition:all .3s cubic-bezier(.25,.8,.25,1);width:20px}@media (max-width:768px){.header{left:1rem;max-width:none;right:1rem;top:1rem;transform:none}.nav{gap:1rem;min-width:auto}.nav-wrapper{width:100%}.nav-wrapper>.logo{display:none}.nav .mobile-logo{display:block!important;order:1;position:static;transform:none}.nav .mobile-logo h2{font-size:1rem;font-weight:600}.nav>.nav-list:not(.mobile-dropdown){display:none!important}.nav-list.mobile-dropdown{animation:slideDown .4s cubic-bezier(.34,1.56,.64,1);-webkit-backdrop-filter:blur(25px) saturate(180%);backdrop-filter:blur(25px) saturate(180%);background:#fffffff2;border-radius:16px;box-shadow:0 20px 60px #0003,0 4px 16px #0000001a,inset 0 1px 2px #ffffffe6;display:flex;flex-direction:column;gap:0;left:0;list-style:none;margin:0;padding:.75rem;position:absolute;right:0;top:calc(100% + .75rem);width:100%;z-index:100}.dark-mode-toggle{flex-shrink:0;font-size:1.125rem;height:36px;order:4;position:static;transform:none;width:36px}.nav{align-items:center;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);background:#ffffffe6;border-radius:20px;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014,inset 0 1px 1px #ffffffe6;display:flex;justify-content:space-between;max-width:100%;padding:.6rem 1rem;position:relative;width:100%}.mobile-menu-toggle{-webkit-tap-highlight-color:transparent;background:none;border:none;border-radius:8px;box-shadow:none;cursor:pointer;display:flex!important;flex-direction:column;order:3;padding:.5rem;position:static;transform:none;transition:background .2s ease;z-index:10}.mobile-menu-toggle:active,.mobile-menu-toggle:hover{background:#2563eb1a}.hero{padding-top:120px!important}}@media (max-width:480px){.header{left:.5rem;right:.5rem;top:.5rem}.nav{border-radius:16px;padding:.5rem .75rem}.nav .mobile-logo h2{font-size:.9rem}.dark-mode-toggle{font-size:1rem;height:32px;width:32px}.mobile-menu-toggle{padding:.375rem}.mobile-menu-toggle span{height:1.5px;width:16px}.nav-list.mobile-dropdown{border-radius:12px;padding:.5rem;top:calc(100% + .5rem)}.nav-list.mobile-dropdown li button{font-size:.95rem;padding:.75rem .875rem}.hero{padding-top:100px!important}}body.dark-mode{background:#0a0a0a;color:#fff}body.dark-mode .header{background:#000c}body.dark-mode .nav{background:#000c;border-color:#ffffff1a;box-shadow:0 8px 32px #0006,0 2px 8px #0000004d,inset 0 1px 1px #ffffff1a}body.dark-mode .header.scrolled .nav{background:#000000e6;box-shadow:0 12px 40px #0009,0 4px 12px #0006,inset 0 1px 2px #ffffff1a}body.dark-mode .logo h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#60a5fa);-webkit-background-clip:text;background-clip:text}body.dark-mode .nav-list li button{color:#e5e7eb}body.dark-mode .nav-list li button:hover{background:#60a5fa1a;color:#60a5fa}body.dark-mode .dark-mode-toggle{background:#000c;border-color:#ffffff1a;box-shadow:0 4px 16px #0000004d,inset 0 1px 1px #ffffff1a}body.dark-mode .dark-mode-toggle:hover{background:#000000e6;box-shadow:0 6px 20px #0006,inset 0 1px 2px #ffffff26}body.dark-mode .nav-list.mobile-dropdown{background:#000000e6;border:1px solid #ffffff1a;box-shadow:0 20px 60px #000c,0 4px 16px #0009,inset 0 1px 2px #ffffff1a}body.dark-mode .nav-list.mobile-dropdown li button{color:#e5e7eb}body.dark-mode .nav-list.mobile-dropdown li button:hover{background:#60a5fa1a;color:#60a5fa}@keyframes navFloat{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.header.scrolled .nav{animation:navFloat .6s cubic-bezier(.34,1.56,.64,1) forwards}.hero{background:#0000;color:#1f2937;min-height:80vh;overflow:hidden;padding:140px 0 80px;position:relative;width:100%;z-index:1}body.dark-mode .hero{background:#0000;color:#e5e7eb}body.dark-mode .hero-title{color:#fff}body.dark-mode .highlight{color:#60a5fa}body.dark-mode .hero-description,body.dark-mode .hero-subtitle{color:#9ca3af}body.dark-mode .btn-primary{background:#2563eb;color:#fff}body.dark-mode .btn-primary:hover{background:#1d4ed8}body.dark-mode .btn-secondary{background:#0000;border-color:#60a5fa;color:#60a5fa}body.dark-mode .btn-secondary:hover{background:#60a5fa;color:#0a0a0a}body.dark-mode .profile-image{box-shadow:0 20px 40px #0006}@media (max-width:768px){.hero{min-height:70vh;padding:120px 0 3rem}.hero-content{gap:2.5rem;grid-template-columns:1fr;text-align:center}.hero-title{font-size:2.5rem;margin-bottom:1rem}.hero-subtitle{font-size:1.25rem;margin-bottom:1.25rem}.hero-description{font-size:1rem;margin-bottom:2rem;max-width:100%}.hero-buttons{flex-direction:column;gap:1rem;margin-bottom:2rem}.hero-buttons .btn{font-size:1rem;margin:0 auto;max-width:280px;padding:1rem 2rem;width:100%}.hero-links{flex-wrap:wrap;gap:1.5rem;justify-content:center}.hero-visual{order:-1}.profile-image-wrapper{height:200px;margin:0 auto;width:200px}.profile-image{height:100%;width:100%}}@media (max-width:480px){.hero{min-height:65vh;padding:100px 0 2.5rem}.hero-content{gap:2rem}.hero-title{font-size:2rem;line-height:1.1}.hero-subtitle{font-size:1.125rem}.hero-description{font-size:.95rem;line-height:1.5}.hero-buttons .btn{font-size:.95rem;max-width:240px;padding:.875rem 1.5rem}.profile-image-wrapper{height:160px;width:160px}.hero-links{gap:1rem}}.hero-content{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;position:relative;z-index:1}.hero-title{animation:fadeInUp 1s cubic-bezier(.165,.84,.44,1) forwards;animation-delay:.2s;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Helvetica Neue,sans-serif;font-size:3.5rem;font-weight:700;letter-spacing:-.025em;line-height:1.1;margin-bottom:1rem;opacity:0;transform:translateY(50px)}.highlight{-webkit-text-fill-color:#0000;animation:gentleFloat 3s ease-in-out infinite;animation-delay:1s;background:linear-gradient(135deg,#2563eb,#1d4ed8 50%,#3b82f6);-webkit-background-clip:text;background-clip:text;color:#2563eb;font-weight:700}@keyframes textGlow{0%,to{filter:drop-shadow(0 0 10px rgba(79,172,254,.5))}50%{filter:drop-shadow(0 0 20px rgba(67,227,123,.8))}}.hero-subtitle{animation:fadeInUp 1s cubic-bezier(.165,.84,.44,1) forwards;animation-delay:.4s;color:#4b5563;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Helvetica Neue,sans-serif;font-size:1.8rem;font-weight:500;margin-bottom:1.5rem;opacity:0;transform:translateY(30px)}.hero-description{color:#6b7280;font-size:1.2rem;line-height:1.8;margin-bottom:2.5rem}.hero-buttons{display:flex;gap:1rem;margin-bottom:2rem}.hero-buttons .btn{font-size:1.1rem;padding:15px 30px}.hero-links{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}.hero-visual{align-items:center;display:flex;justify-content:center}.hero-image-container{position:relative}.profile-image-wrapper{background:#fff;border:4px solid #e5e7eb;border-radius:50%;box-shadow:0 20px 25px -5px #0000001a;height:300px;padding:8px;position:relative;transition:all .3s ease;width:300px}.profile-image-wrapper:hover{border-color:#2563eb;box-shadow:0 25px 50px -12px #00000040;transform:translateY(-8px)}@keyframes borderRotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes profileGlow{0%{box-shadow:0 20px 60px #0003,inset 0 2px 4px #ffffff4d,0 0 40px #4facfe4d}to{box-shadow:0 20px 60px #0003,inset 0 2px 4px #ffffff4d,0 0 60px #8e44ad80}}.profile-image{border:3px solid #ffffff80;border-radius:50%;height:100%;object-fit:cover;width:100%}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-15px) rotate(1deg)}66%{transform:translateY(-10px) rotate(-1deg)}}@keyframes glow{0%{box-shadow:0 8px 32px #0000001a,inset 0 1px 0 #fff6,0 0 20px #667eea4d}to{box-shadow:0 8px 32px #0000001a,inset 0 1px 0 #fff6,0 0 40px #764ba266}}@media (max-width:768px){.hero{padding:100px 0 60px}.hero-content{gap:3rem;grid-template-columns:1fr;text-align:center}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.25rem}.hero-description{font-size:1rem}.hero-buttons{align-items:center;flex-direction:column}.hero-buttons .btn{width:200px}.profile-circle{font-size:4rem;height:200px;width:200px}.hero-links{justify-content:center}}.social-icon{align-items:center;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;color:#64748b;display:inline-flex;height:44px;justify-content:center;text-decoration:none;transition:all .3s ease;width:44px}.social-icon:hover{background-color:#2563eb;border-color:#2563eb;box-shadow:0 4px 12px #2563eb4d;color:#fff;transform:translateY(-2px)}.social-icon svg{transition:transform .3s ease}.social-icon:hover svg{transform:scale(1.1)}@media (max-width:768px){.social-icon{height:40px;width:40px}}@media (max-width:480px){.social-icon{height:36px;width:36px}.social-icon svg{height:18px;width:18px}}.about{background:#fafafa;padding:6rem 0}.about-content{grid-gap:4rem;align-items:start;display:grid;gap:4rem;grid-template-columns:2fr 1fr;margin:0 auto;max-width:1200px}.about-text{font-size:1.125rem;line-height:1.7}.about-text p{color:#4b5563;margin-bottom:1.5rem}.about-stats{grid-gap:1.5rem;display:grid;gap:1.5rem}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:2rem;text-align:center;transition:all .3s cubic-bezier(.165,.84,.44,1)}.stat-card:hover{border-color:#2563eb;box-shadow:0 10px 30px #0000001a;transform:translateY(-4px)}.stat-number{color:#2563eb;font-size:2.5rem;font-weight:700;line-height:1;margin-bottom:.5rem}.stat-label{color:#6b7280;font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}body.dark-mode .about{background:#111827}body.dark-mode .about-text p{color:#9ca3af}body.dark-mode .stat-card{background:#1f2937;border-color:#374151}body.dark-mode .stat-card:hover{border-color:#60a5fa;box-shadow:0 10px 30px #0006}body.dark-mode .stat-number{color:#60a5fa}body.dark-mode .stat-label{color:#9ca3af}@media (max-width:768px){.about{padding:4rem 0}.section-title{font-size:2rem}.about-content{gap:3rem;grid-template-columns:1fr}.about-text{font-size:1rem}.about-stats{gap:1rem;grid-template-columns:repeat(3,1fr)}.stat-card{padding:1.5rem 1rem}.stat-number{font-size:2rem}.stat-label{font-size:.75rem}}.skills{background:#0000;padding:6rem 0}.skills-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1200px}.skill-category{background:#fff;border:1px solid #f3f4f6;border-radius:16px;padding:2.5rem;transition:all .3s cubic-bezier(.165,.84,.44,1)}.skill-category:hover{border-color:#e5e7eb;box-shadow:0 20px 40px #0000001a;transform:translateY(-4px)}.category-title{border-bottom:2px solid #f3f4f6;color:#1a1a1a;font-size:1.5rem;font-weight:600;margin-bottom:2rem;padding-bottom:.75rem;text-align:center}.skills-list{display:flex;flex-direction:column;gap:1.5rem}.skill-item{animation-delay:var(--delay);opacity:0;transform:translateX(-20px);transition:all .4s cubic-bezier(.165,.84,.44,1)}.skill-item.visible{animation:slideInLeft .6s ease forwards;opacity:1;transform:translateX(0)}.skill-content{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.skill-name{color:#1f2937;font-size:1rem;font-weight:500}.skill-level{color:#6b7280;font-size:.875rem;font-weight:600}.skill-bar{background-color:#f3f4f6;height:6px;overflow:hidden}.skill-bar,.skill-progress{border-radius:3px;position:relative}.skill-progress{background:linear-gradient(90deg,#2563eb,#1d4ed8);height:100%;transition:width 1.2s cubic-bezier(.4,0,.2,1)}.skill-progress:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}body.dark-mode .skills{background:#0000}body.dark-mode .skill-category{background:#1f2937;border-color:#374151}body.dark-mode .skill-category:hover{border-color:#60a5fa;box-shadow:0 20px 40px #0006}body.dark-mode .category-title{border-bottom-color:#374151;color:#fff}body.dark-mode .skill-item{background:#374151;border-color:#4b5563}body.dark-mode .skill-item:hover{background:#4b5563;border-color:#60a5fa}body.dark-mode .skill-name{color:#e5e7eb}body.dark-mode .skill-level{color:#9ca3af}body.dark-mode .skill-bar{background-color:#4b5563}body.dark-mode .skill-progress{background:linear-gradient(90deg,#60a5fa,#3b82f6)}@media (max-width:768px){.skills{padding:4rem 0}.section-title{font-size:2rem}.skills-grid{gap:2rem;grid-template-columns:1fr}.skill-category{padding:2rem}}.projects{background:#0000;padding:6rem 0}.projects-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:3rem}.project-card{animation-delay:var(--delay);background:#fff;border:1px solid #f3f4f6;border-radius:16px;opacity:0;overflow:hidden;transform:translateY(30px);transition:all .4s cubic-bezier(.165,.84,.44,1)}.project-card.visible{animation:fadeInUp .6s ease forwards;opacity:1;transform:translateY(0)}.project-card:hover{border-color:#e5e7eb;box-shadow:0 20px 40px #0000001a;transform:translateY(-8px)}.project-image{aspect-ratio:16/10;background:#f9fafb;overflow:hidden;position:relative}.project-image img{height:100%;object-fit:cover;transition:transform .4s ease;width:100%}.project-card:hover .project-image img{transform:scale(1.05)}.image-fallback{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:none;font-size:1.1rem;font-weight:500;height:100%;width:100%}.image-fallback,.project-overlay{align-items:center;justify-content:center}.project-overlay{background:#000000b3;bottom:0;display:flex;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.project-card:hover .project-overlay{opacity:1}.overlay-links{display:flex;gap:1rem}.overlay-link{align-items:center;background:#fff;border-radius:50%;color:#1a1a1a;display:flex;height:48px;justify-content:center;text-decoration:none;transition:all .2s ease;width:48px}.overlay-link:hover{background:#2563eb;color:#fff;transform:scale(1.1)}.project-content{padding:1.5rem}.project-meta{margin-bottom:.5rem}.project-category{color:#2563eb;display:inline-block;font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.project-title{color:#1a1a1a;font-size:1.5rem;font-weight:600;line-height:1.3;margin-bottom:.75rem}.project-description{color:#6b7280;font-size:.95rem;line-height:1.6;margin-bottom:1.25rem}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem}body.dark-mode .projects{background:#0000}body.dark-mode .project-card{background:#1f2937;border-color:#374151}body.dark-mode .project-card:hover{border-color:#60a5fa;box-shadow:0 20px 40px #0006}body.dark-mode .project-category{color:#60a5fa}body.dark-mode .project-title{color:#fff}body.dark-mode .project-description{color:#9ca3af}body.dark-mode .overlay-link{background:#1f2937;color:#e5e7eb}body.dark-mode .overlay-link:hover{background:#2563eb;color:#fff}body.dark-mode .image-fallback{background:linear-gradient(135deg,#374151,#4b5563)}@media (max-width:768px){.projects{padding:3rem 0}.section-header{margin-bottom:3rem}.section-title{font-size:2rem}.projects-grid{gap:1.5rem;grid-template-columns:1fr;margin-top:2rem}.project-card{margin-bottom:0}.project-image{aspect-ratio:16/9}.project-content{padding:1.25rem}.project-title{font-size:1.25rem;line-height:1.3}.project-description{font-size:.9rem;line-height:1.5;margin-bottom:1rem}.project-technologies{gap:.375rem;margin-bottom:0}.tech-tag{font-size:.8rem;padding:.2rem .6rem}.overlay-links{gap:.75rem}.overlay-link{height:40px;width:40px}}@media (max-width:480px){.projects{padding:2.5rem 0}.section-header{margin-bottom:2.5rem}.section-title{font-size:1.75rem}.section-subtitle{font-size:.95rem}.projects-grid{gap:1.25rem}.project-content{padding:1rem}.project-title{font-size:1.125rem}.project-description{font-size:.875rem}.tech-tag{font-size:.75rem;padding:.15rem .5rem}}.experience{background:#fafafa;padding:6rem 0}.experience-grid{grid-gap:4rem;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1000px}.experience-column{display:flex;flex-direction:column}.column-title{border-bottom:2px solid #e5e7eb;color:#1a1a1a;font-size:1.5rem;font-weight:600;margin-bottom:2rem;padding-bottom:.5rem;text-align:center}.items-list{display:flex;flex-direction:column;gap:2rem}.experience-item{animation-delay:var(--delay);background:#fff;border:1px solid #e5e7eb;border-radius:12px;opacity:0;padding:2rem;transform:translateY(20px);transition:all .3s cubic-bezier(.165,.84,.44,1)}.experience-item.visible{animation:slideIn .6s ease forwards;opacity:1;transform:translateY(0)}.experience-item:hover{border-color:#2563eb;box-shadow:0 10px 30px #0000001a;transform:translateY(-4px)}.item-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem}.item-title{color:#1a1a1a;flex:1 1;font-size:1.25rem;font-weight:600;line-height:1.3}.item-period{background:#f3f4f6;border-radius:12px;color:#6b7280;font-size:.875rem;font-weight:500;padding:.25rem .75rem;white-space:nowrap}.item-company{color:#2563eb;font-size:1rem;font-weight:500;margin-bottom:1rem}.item-description{color:#6b7280;font-size:.95rem;line-height:1.6;margin-bottom:1.25rem}.item-technologies{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{background:#f3f4f6;border-radius:12px;color:#374151;font-size:.875rem;font-weight:500;padding:.25rem .75rem;transition:all .2s ease}.tech-tag:hover{background:#e5e7eb;color:#1f2937}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}body.dark-mode .experience{background:#111827}body.dark-mode .column-title{border-bottom-color:#374151;color:#fff}body.dark-mode .experience-item{background:#1f2937;border-color:#374151}body.dark-mode .experience-item:hover{border-color:#60a5fa;box-shadow:0 10px 30px #0006}body.dark-mode .item-title{color:#fff}body.dark-mode .item-period{background:#374151;color:#9ca3af}body.dark-mode .item-company{color:#60a5fa}body.dark-mode .item-description{color:#9ca3af}body.dark-mode .tech-tag{background:#374151;color:#e5e7eb}body.dark-mode .tech-tag:hover{background:#4b5563;color:#fff}@media (max-width:768px){.experience{padding:4rem 0}.section-title{font-size:2rem}.experience-grid{gap:3rem;grid-template-columns:1fr}.experience-item{padding:1.5rem}.item-header{align-items:flex-start;flex-direction:column;gap:.5rem}.item-period{align-self:flex-start}}.contact{background:#0000;color:#1a1a1a;padding:6rem 0}.section-header{margin-bottom:4rem;text-align:center}.section-title{color:#1a1a1a;font-size:2.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1rem}.section-subtitle{color:#6b7280;font-size:1.125rem;margin:0 auto;max-width:600px}.contact-content{grid-gap:4rem;align-items:start;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px}.contact-info h3{color:#1a1a1a;font-size:2rem;font-weight:600;line-height:1.3;margin-bottom:1.5rem}.contact-info p{color:#4b5563;font-size:1.125rem;line-height:1.7;margin-bottom:2rem}.contact-methods{display:flex;flex-direction:column;gap:2rem}.contact-method h4{color:#1a1a1a;font-size:1.125rem;font-weight:600;margin-bottom:.75rem}.contact-method a,.contact-method span{color:#2563eb;font-weight:500;text-decoration:none;transition:all .2s ease}.contact-method a:hover{color:#1d4ed8;text-decoration:underline}.contact-method span{color:#6b7280}.contact-form{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;padding:2.5rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#374151;display:block;font-size:.875rem;font-weight:500;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.form-group input,.form-group textarea{border:1px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:1rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-group textarea{min-height:120px;resize:vertical}.btn{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s ease;width:100%}.btn:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px)}.btn:disabled{cursor:not-allowed;opacity:.6}.form-message{border-radius:8px;font-weight:500;margin-top:1rem;padding:.75rem 1rem}.form-message.success{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.form-message.error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}body.dark-mode .contact{background:#0000;color:#e5e7eb}body.dark-mode .contact-info h3{color:#fff}body.dark-mode .contact-info p{color:#9ca3af}body.dark-mode .contact-method h4{color:#fff}body.dark-mode .contact-method a{color:#60a5fa}body.dark-mode .contact-method a:hover{color:#3b82f6}body.dark-mode .contact-method span{color:#9ca3af}body.dark-mode .contact-form{background:#1f2937;border-color:#374151;box-shadow:0 4px 6px -1px #0006}body.dark-mode .form-group label{color:#e5e7eb}body.dark-mode .form-group input,body.dark-mode .form-group textarea{background:#374151;border-color:#4b5563;color:#e5e7eb}body.dark-mode .form-group input:focus,body.dark-mode .form-group textarea:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}body.dark-mode .btn{background:#2563eb;color:#fff}body.dark-mode .btn:hover:not(:disabled){background:#1d4ed8}body.dark-mode .form-message.success{background:#064e3b;border-color:#047857;color:#34d399}body.dark-mode .form-message.error{background:#7f1d1d;border-color:#dc2626;color:#f87171}@media (max-width:768px){.contact{padding:4rem 0}.section-title{font-size:2rem}.contact-content{gap:3rem;grid-template-columns:1fr}.contact-info h3{font-size:1.5rem}.contact-form{padding:2rem}}.footer{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-top:1px solid #ffffff1a;color:#fff;padding:4rem 0 2rem;position:relative}.footer:before{background:radial-gradient(circle at 25% 25%,#ffffff0d 0,#0000 50%),radial-gradient(circle at 75% 75%,#ffffff05 0,#0000 50%);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.footer-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:2fr 1fr 1fr 1fr;margin-bottom:3rem}.footer-section h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4facfe,#00f2fe);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 15px rgba(79,172,254,.5));font-size:1.8rem;font-weight:600;margin-bottom:1rem}.footer-section h4{color:#ffffffe6;font-size:1.3rem;font-weight:600;margin-bottom:1rem;text-shadow:0 0 10px #ffffff4d}.footer-section p{color:#fffc;font-size:1.1rem;line-height:1.7;margin-bottom:1.5rem;text-shadow:0 0 5px #fff3}.social-links{display:flex;gap:1.5rem}.social-links a{color:#ffffffe6;font-size:1.1rem;font-weight:500;text-decoration:none;text-shadow:0 0 5px #fff3;transition:all .3s ease}.social-links a:hover{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4facfe,#00f2fe);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 15px rgba(79,172,254,.6));transform:translateY(-2px)}.footer-links{list-style:none;padding:0}.footer-links li{margin-bottom:.75rem}.footer-links button{background:none;border:none;color:#fffc;cursor:pointer;font-size:1.1rem;padding:0;text-align:left;text-shadow:0 0 5px #ffffff1a;transition:all .3s ease}.footer-links button:hover{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#43e97b,#38f9d7);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 10px rgba(67,227,123,.5));transform:translateX(5px)}.footer-links li:not(:has(button)){color:#ffffffb3;font-size:1rem;text-shadow:0 0 5px #ffffff1a}.back-to-top{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:25px;box-shadow:0 4px 20px #0003,inset 0 1px 0 #ffffff1a;color:#fff;cursor:pointer;font-size:1rem;font-weight:400;padding:1rem 2rem;transition:all .4s ease}.back-to-top:hover{background:#fff3;border:1px solid #ffffff4d;box-shadow:0 8px 30px #0000004d,inset 0 1px 0 #fff3;transform:translateY(-2px) scale(1.05)}.footer-bottom{align-items:center;border-top:1px solid #ffffff1a;color:#ffffffb3;display:flex;font-size:1rem;justify-content:space-between;padding-top:2rem;text-align:center}.footer-bottom p{margin:0;text-shadow:0 0 5px #ffffff1a}body.dark-mode .footer{background:linear-gradient(135deg,#0a0a0a,#1f2937);border-top-color:#ffffff0d}body.dark-mode .footer:before{background:radial-gradient(circle at 25% 25%,#60a5fa0d 0,#0000 50%),radial-gradient(circle at 75% 75%,#8b5cf605 0,#0000 50%)}body.dark-mode .footer-section h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#60a5fa,#3b82f6);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 15px rgba(96,165,250,.5))}body.dark-mode .footer-section h4{color:#e5e7eb;text-shadow:0 0 10px #fff3}body.dark-mode .footer-section p{color:#e5e7ebcc;text-shadow:0 0 5px #ffffff1a}body.dark-mode .social-links a{color:#e5e7ebe6;text-shadow:0 0 5px #ffffff1a}body.dark-mode .social-links a:hover{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#60a5fa,#3b82f6);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 15px rgba(96,165,250,.6))}body.dark-mode .footer-links button{color:#e5e7ebcc;text-shadow:0 0 5px #ffffff0d}body.dark-mode .footer-links button:hover{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#34d399,#10b981);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 10px rgba(52,211,153,.5))}body.dark-mode .footer-links li:not(:has(button)){color:#e5e7ebb3;text-shadow:0 0 5px #ffffff0d}body.dark-mode .back-to-top{background:#0000004d;border-color:#ffffff1a;box-shadow:0 4px 20px #0006,inset 0 1px 0 #ffffff0d;color:#e5e7eb}body.dark-mode .back-to-top:hover{background:#00000080;border-color:#fff3;box-shadow:0 8px 30px #0009,inset 0 1px 0 #ffffff1a}body.dark-mode .footer-bottom{border-top-color:#ffffff0d;color:#e5e7ebb3}body.dark-mode .footer-bottom p{text-shadow:0 0 5px #ffffff0d}@media (max-width:768px){.footer-content{gap:2rem;grid-template-columns:1fr}.footer-bottom,.footer-content,.footer-links button{text-align:center}.footer-bottom{flex-direction:column;gap:1rem}.social-links{justify-content:center}}.floating-elements{height:100%;left:0;overflow:hidden;pointer-events:none;position:fixed;top:0;width:100%;z-index:-1}.floating-shape{animation-iteration-count:infinite;animation-timing-function:linear;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:radial-gradient(circle,#ffffff1a 0,#ffffff05 100%);border-radius:50%;position:absolute}.floating-shape-1{animation:float1 15s infinite;background:radial-gradient(circle,#667eea1a 0,#667eea05 100%);height:120px;left:10%;top:10%;width:120px}.floating-shape-2{animation:float2 12s infinite;background:radial-gradient(circle,#764ba21a 0,#764ba205 100%);height:80px;right:15%;top:60%;width:80px}.floating-shape-3{animation:float3 18s infinite;background:radial-gradient(circle,#f093fb1a 0,#f093fb05 100%);height:100px;left:20%;top:80%;width:100px}.floating-shape-4{animation:float4 14s infinite;background:radial-gradient(circle,#a8edea1a 0,#a8edea05 100%);height:60px;right:30%;top:20%;width:60px}.floating-shape-5{animation:float5 16s infinite;background:radial-gradient(circle,#fed6e31a 0,#fed6e305 100%);height:90px;left:5%;top:40%;width:90px}.floating-shape-6{animation:float6 13s infinite;background:radial-gradient(circle,#f5576c1a 0,#f5576c05 100%);height:70px;right:5%;top:70%;width:70px}@keyframes float4{0%,to{transform:translateY(0) translateX(0) rotate(0deg)}50%{transform:translateY(25px) translateX(-25px) rotate(180deg)}}@keyframes float5{0%,to{transform:translateY(0) translateX(0) rotate(0deg)}25%{transform:translateY(15px) translateX(-10px) rotate(90deg)}50%{transform:translateY(30px) translateX(-20px) rotate(180deg)}75%{transform:translateY(15px) translateX(-10px) rotate(270deg)}}@keyframes float6{0%,to{transform:translateY(0) translateX(0) rotate(0deg)}30%{transform:translateY(-35px) translateX(20px) rotate(108deg)}60%{transform:translateY(35px) translateX(40px) rotate(216deg)}90%{transform:translateY(-10px) translateX(10px) rotate(324deg)}}@media (max-width:768px){.floating-shape{display:none}}.liquid-background{background:linear-gradient(180deg,#fff,#f8fafc 50%,#f1f5f9);height:100vh;left:0;overflow:hidden;pointer-events:none;position:fixed;top:0;width:100vw;z-index:-1}.liquid-blob{opacity:.6;position:absolute}.liquid-blob-1{animation:float1 20s ease-in-out infinite;background:#2563eb1a;border-radius:30% 70% 70% 30%/30% 30% 70% 70%;height:200px;left:10%;top:10%;width:200px}.liquid-blob-2{animation:float2 25s ease-in-out infinite;background:#8b5cf614;border-radius:40% 60% 60% 40%/40% 40% 60% 60%;height:150px;right:15%;top:60%;width:150px}.liquid-blob-3{animation:float3 18s ease-in-out infinite;background:#2563eb0f;border-radius:50% 50% 50% 50%/60% 40% 60% 40%;height:120px;left:70%;top:30%;width:120px}@keyframes float1{0%,to{border-radius:30% 70% 70% 30%/30% 30% 70% 70%;transform:translateY(0) rotate(0deg)}50%{border-radius:70% 30% 30% 70%/70% 70% 30% 30%;transform:translateY(-20px) rotate(180deg)}}@keyframes float2{0%,to{border-radius:40% 60% 60% 40%/40% 40% 60% 60%;transform:translateY(0) rotate(0deg)}50%{border-radius:60% 40% 40% 60%/60% 60% 40% 40%;transform:translateY(-15px) rotate(-180deg)}}@keyframes float3{0%,to{border-radius:50% 50% 50% 50%/60% 40% 60% 40%;transform:translateY(0) rotate(0deg)}50%{border-radius:50% 50% 50% 50%/40% 60% 40% 60%;transform:translateY(-10px) rotate(180deg)}}body.dark-mode .liquid-background{background:linear-gradient(180deg,#0a0a0a,#111827 50%,#1f2937)}body.dark-mode .liquid-blob-1{background:#60a5fa1a}body.dark-mode .liquid-blob-2{background:#8b5cf614}body.dark-mode .liquid-blob-3{background:#60a5fa0f}.App{background:#fff;display:flex;flex-direction:column;min-height:100vh;position:relative;width:100%;z-index:1}main{flex:1 1}section{position:relative;scroll-margin-top:80px;z-index:1}*{transition:all .4s cubic-bezier(.23,1,.32,1)}html{scroll-behavior:smooth}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}::-webkit-scrollbar-thumb{background:#2563eb;border-radius:3px;-webkit-transition:background .3s ease;transition:background .3s ease}::-webkit-scrollbar-thumb:hover{background:#1d4ed8}h1,h2,h3,h4,h5,h6{color:#1a1a1a;font-weight:600;line-height:1.3}p{color:#4a5568;margin-bottom:1rem}a{color:#1a1a1a;text-decoration:none;transition:all .3s ease}a:hover{opacity:.7}.card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:2rem;position:relative;transition:all .3s ease}.card:hover{border-color:#2563eb;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;transform:translateY(-8px)}.grid{grid-gap:2rem;display:grid;gap:2rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp .6s ease forwards}
/*# sourceMappingURL=main.609c0af6.css.map*/