*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;word-wrap:break-word;color:#2d3748;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;overflow-wrap:break-word}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}html{scroll-behavior:smooth}body,html{overflow-x:hidden}a{color:inherit;text-decoration:none}img{height:auto;max-width:100%}ol,ul{list-style:none}input,select,textarea{font-family:inherit}:focus{outline:2px solid #667eea;outline-offset:2px}::-webkit-scrollbar{background:#fefefe;width:8px}::-webkit-scrollbar-track{background:#0000!important}::-webkit-scrollbar-thumb{border-radius:4px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1)}::-webkit-scrollbar-button{border:none}::-webkit-scrollbar-button,::-webkit-scrollbar-corner{background:#fefefe!important}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2)}::selection{background:#667eea4d;color:#2d3748}@media (hover:none) and (pointer:coarse){.btn{min-width:44px;padding:.875rem 1.5rem}.btn,.nav-link{min-height:44px}.nav-link{padding:.75rem 1rem}.menu-toggle,.social-icon,.social-link{min-height:44px;min-width:44px}.project-link{min-height:44px;padding:.5rem 0}.scroll-to-top{min-height:50px;min-width:50px}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media (max-width:768px) and (orientation:landscape){.hero{min-height:100vh;padding-top:50px}.hero-container{gap:1.5rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.125rem}.hero-description{font-size:.9rem;margin-bottom:1.5rem}}@media (max-width:768px){.btn:focus,.menu-toggle:focus,.nav-link:focus,.social-icon:focus,.social-link:focus{outline:3px solid #667eea;outline-offset:2px}.btn,.nav-link,.social-icon,.social-link{position:relative}.btn:before,.nav-link:before,.social-icon:before,.social-link:before{bottom:-8px;content:"";left:-8px;position:absolute;right:-8px;top:-8px;z-index:-1}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (max-width:480px){.btn-primary{box-shadow:0 2px 8px #667eea66}.btn-secondary{border-width:2px}.section-title{text-shadow:0 1px 2px #0000001a}}@media (prefers-color-scheme:dark){body{background:#1a202c;color:#e2e8f0}::-webkit-scrollbar-track{background:#0000!important}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2)}::-webkit-scrollbar-button{border:none}::-webkit-scrollbar-button,::-webkit-scrollbar-corner{background:#fefefe!important}}.App{animation:fadeInApp .5s ease-in-out;display:flex;flex-direction:column;max-width:100%;min-height:100vh;text-align:center}@keyframes fadeInApp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}main{flex:1 1}section{width:100%}.container{margin:0 auto;max-width:1200px;padding:0 2rem}.btn{font-size:.875rem;gap:.5rem;padding:.75rem 1.5rem}.btn-primary:hover{box-shadow:0 8px 25px #667eea4d}@media (max-width:1200px){.container{max-width:100%;padding:0 1.5rem}}@media (max-width:1024px){.container{padding:0 1.25rem}.section-title{font-size:2.25rem}}@media (max-width:768px){.section-title{font-size:2rem}.container{max-width:100%;padding:0 1.25rem}}@media (max-width:480px){.section-title{font-size:1.75rem}.container{max-width:100%;padding:0 1rem}}@media (max-width:414px){.section-title{font-size:1.8rem}.container{max-width:100%;padding:0 1.2rem}}@media (max-width:320px){.section-title{font-size:1.5rem}.container{padding:0 .5rem}}.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #0000001a;left:0;position:fixed;right:0;top:0;transition:all .3s ease;z-index:1000}.header.scrolled{background:#fffffffa;box-shadow:0 2px 20px #0000001a}.header-container{align-items:center;display:flex;height:70px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.logo h1{-webkit-text-fill-color:#0000;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#2d3748;font-size:1.5rem;font-weight:700;margin:0;-webkit-user-select:none;user-select:none}.logo h1,.logo h1:focus{outline:none}.nav{align-items:center;display:flex}.nav-list{display:flex;gap:2rem;list-style:none;margin:0;padding:0}.nav-link{background:none;border:none;border-radius:8px;color:#4a5568;cursor:pointer;font-size:1rem;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease}.nav-link:hover{background:#667eea1a;color:#667eea;transform:translateY(-2px)}.menu-toggle{background:none;border:none;border-radius:8px;color:#4a5568;cursor:pointer;display:none;font-size:1.5rem;padding:.5rem;transition:all .3s ease}.menu-toggle:hover{background:#667eea1a;color:#667eea}@media (max-width:1200px){.header-container{padding:0 1.5rem}}@media (max-width:1024px){.header-container{padding:0 1.25rem}.nav-list{gap:1.5rem}.nav-link{font-size:.95rem;padding:.4rem .8rem}}@media (max-width:768px){.header-container{padding:0 1.25rem}.nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffffa;border-bottom:1px solid #0000001a;box-shadow:0 4px 20px #0000001a;left:0;opacity:0;position:fixed;right:0;top:70px;transform:translateY(-100%);transition:all .3s ease;visibility:hidden}.nav.nav-open{opacity:1;transform:translateY(0);visibility:visible}.nav-list{flex-direction:column;gap:0;padding:1rem 0}.nav-link{border-radius:0;display:block;font-size:1rem;font-weight:500;padding:1rem 2rem;text-align:left;width:100%}.nav-link:hover{background:#667eea1a;transform:none}.menu-toggle{display:block;font-size:1.75rem;margin-right:-.25rem;padding:.75rem}}@media (max-width:480px){.header-container{height:60px;padding:0 1rem}.logo h1{font-size:1.25rem}.nav{top:60px}.nav-link{font-size:.95rem;padding:.875rem 1.5rem}.menu-toggle{font-size:1.5rem;margin-right:-.25rem;padding:.5rem}}@media (max-width:414px){.header-container{height:60px;padding:0 1.2rem}.logo h1{font-size:1.3rem}.nav{top:60px}.nav-link{font-size:.95rem;padding:.875rem 1.5rem}.menu-toggle{font-size:1.6rem;margin-right:-.25rem;padding:.5rem}}@media (max-width:320px){.header-container{padding:0 .5rem}.logo h1{font-size:1.125rem}.nav-link{font-size:.9rem;padding:.75rem 1rem}}@media (prefers-reduced-motion:reduce){.header,.menu-toggle,.nav,.nav-link{transition:none}}@media (prefers-contrast:high){.header{background:#fff;border-bottom:2px solid #000}.nav-link{color:#000}.nav-link:hover{background:#000;color:#fff}}.hero{background:linear-gradient(135deg,#f8fafc,#e2e8f0 50%,#f1f5f9);justify-content:center;min-height:100vh;overflow:hidden;padding-top:70px}.hero,.hero-container{align-items:center;display:flex;position:relative}.hero-container{gap:4rem;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem;z-index:2}.hero-content{flex:1 1;max-width:600px}.hero-title{color:#2d3748;font-size:3.5rem;font-weight:700;line-height:1.2;margin:0 0 1rem}.highlight{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:#4a5568;font-size:1.5rem;font-weight:600;margin:0 0 1.5rem}.hero-description{color:#718096;font-size:1.125rem;line-height:1.7;margin:0 0 2.5rem;max-width:500px}.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem}.btn,.hero-buttons{align-items:center;justify-content:center}.btn{border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;min-width:140px;padding:.875rem 2rem;text-decoration:none;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea4d;color:#fff}.btn-primary:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.btn-secondary{background:#0000;border:2px solid #667eea;color:#667eea}.btn-secondary:hover{background:#667eea;color:#fff;transform:translateY(-2px)}.hero-social{flex-direction:column;gap:1rem}.hero-social,.social-link{align-items:center;display:flex}.social-link{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #667eea33;border-radius:50%;box-shadow:0 4px 15px #0000001a;color:#4a5568;font-size:1.25rem;height:50px;justify-content:center;transition:all .3s ease;width:50px}.social-link:hover{background:#667eea1a;border-color:#667eea;box-shadow:0 6px 20px #667eea4d;color:#667eea;transform:translateY(-2px)}.hero-background{bottom:0;left:0;position:absolute;right:0;top:0;z-index:1}.gradient-1{animation:float 6s ease-in-out infinite;background:linear-gradient(135deg,#667eea14,#764ba214);height:300px;right:10%;top:20%;width:300px}.gradient-1,.gradient-2{border-radius:50%;filter:blur(40px);position:absolute}.gradient-2{animation:float 8s ease-in-out infinite reverse;background:linear-gradient(135deg,#764ba214,#667eea14);bottom:20%;height:250px;left:10%;width:250px}.gradient-3{animation:float 10s ease-in-out infinite;background:linear-gradient(135deg,#667eea0d,#764ba20d);border-radius:50%;filter:blur(60px);height:400px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:400px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@media (max-width:1200px){.hero-container{max-width:100%;padding:0 1.5rem}.hero-title{font-size:3rem}}@media (max-width:1024px){.hero-container{flex-direction:column;gap:2.5rem;padding:0 1.25rem}.hero-container,.hero-content{max-width:100%;text-align:center}.hero-title{font-size:2.75rem}.hero-subtitle{font-size:1.375rem}.hero-description{font-size:1.125rem;max-width:100%}.hero-social{flex-direction:row;justify-content:center}}@media (max-width:768px){.hero{min-height:90vh;padding-top:60px}.hero-container{gap:2rem;max-width:100%;padding:0 1.25rem}.hero-title{font-size:2.5rem;line-height:1.1}.hero-subtitle{font-size:1.25rem}.hero-description{font-size:1rem;margin-bottom:2rem}.hero-buttons{gap:.75rem;justify-content:center}.btn{font-size:.875rem;min-width:120px;padding:.75rem 1.5rem}.gradient-1,.gradient-2,.gradient-3{display:none}}@media (max-width:480px){.hero{min-height:85vh;padding-top:50px}.hero-container{gap:1.5rem;max-width:100%;padding:0 1rem}.hero-title{font-size:2rem;line-height:1.1}.hero-subtitle{font-size:1.125rem}.hero-description{font-size:.875rem;margin-bottom:1.5rem}.hero-buttons{align-items:center;flex-direction:column;gap:.75rem;width:100%}.btn{font-size:.875rem;max-width:200px;padding:.75rem 1.25rem;width:100%}.hero-social{gap:.75rem}.social-link{font-size:1.125rem;height:45px;width:45px}}@media (max-width:414px){.hero{min-height:88vh;padding-top:50px}.hero-container{gap:1.75rem;max-width:100%;padding:0 1.2rem}.hero-title{font-size:2.2rem;line-height:1.1}.hero-subtitle{font-size:1.2rem}.hero-description{font-size:.95rem;line-height:1.6;margin-bottom:1.75rem}.hero-buttons{gap:.875rem}.btn{font-size:.9rem;max-width:220px;padding:.875rem 1.5rem;width:100%}.hero-social{gap:.875rem}.social-link{font-size:1.2rem;height:48px;width:48px}}@media (max-width:320px){.hero-container{padding:0 .5rem}.hero-title{font-size:1.75rem}.hero-subtitle{font-size:1rem}.btn,.hero-description{font-size:.8rem}.btn{padding:.625rem 1rem}.social-link{font-size:1rem;height:40px;width:40px}}@media (prefers-reduced-motion:reduce){.gradient-1,.gradient-2,.gradient-3{animation:none}.btn:hover,.social-link:hover{transform:none}}@media (prefers-contrast:high){.hero{background:#fff}.hero-title{color:#000}.hero-subtitle{color:#333}.hero-description{color:#555}.btn-primary{background:#000;color:#fff}.btn-secondary{border-color:#000;color:#000}.btn-secondary:hover{background:#000;color:#fff}}.about{background:#f8fafc;overflow:hidden;padding:6rem 0}.about-container{margin:0 auto;max-width:1200px;padding:0 2rem}.about-content{text-align:center}.section-title{color:#2d3748;font-size:2.5rem;font-weight:700;margin:0 0 3rem;position:relative}.section-title:after{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px;bottom:-10px;content:"";height:4px;left:50%;position:absolute;transform:translateX(-50%);width:60px}.about-grid{grid-gap:4rem;align-items:start;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:3rem 0}.about-text{text-align:left}.about-text h3{color:#2d3748;font-size:1.5rem;font-weight:600;margin:0 0 1.5rem}.about-text p{color:#4a5568;font-size:1.125rem;line-height:1.7;margin:0 0 1.5rem}.about-stats{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.stat-item{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2rem;text-align:center;transition:all .3s ease}.stat-item:hover{box-shadow:0 8px 30px #00000026;transform:translateY(-5px)}.stat-item h4{color:#667eea;font-size:2.5rem;font-weight:700;margin:0 0 .5rem}.stat-item p{color:#4a5568;font-size:1rem;font-weight:500;margin:0}.about-values{margin-top:4rem}.about-values h3{color:#2d3748;font-size:1.5rem;font-weight:600;margin:0 0 2rem}.values-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(min(250px,100%),1fr));margin-top:2rem}.value-item{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2rem;text-align:left;transition:all .3s ease}.value-item:hover{box-shadow:0 8px 30px #00000026;transform:translateY(-5px)}.value-item h4{color:#2d3748;font-size:1.25rem;font-weight:600;margin:0 0 1rem}.value-item p{color:#4a5568;font-size:1rem;line-height:1.6;margin:0}@media (max-width:1200px){.about-container{padding:0 1.5rem}.about-grid{gap:3.5rem}}@media (max-width:1024px){.about-container{padding:0 1.25rem}.about-grid{gap:3rem;grid-template-columns:1fr}.about-text{text-align:center}.about-stats{gap:1.5rem;grid-template-columns:1fr 1fr}.values-grid{grid-template-columns:repeat(auto-fit,minmax(min(200px,100%),1fr))}}@media (max-width:768px){.about{padding:4rem 0}.about-container{padding:0 1rem}.section-title{font-size:2rem}.about-text h3{font-size:1.25rem}.about-text p{font-size:1rem}.about-stats{gap:1rem;grid-template-columns:1fr 1fr}.stat-item{padding:1.5rem}.stat-item h4{font-size:2rem}.values-grid{gap:1.5rem;grid-template-columns:1fr}.value-item{padding:1.5rem}}@media (max-width:480px){.about{padding:3rem 0}.about-container{max-width:100%;padding:0 1rem}.section-title{font-size:1.75rem;margin-bottom:2rem}.about-text h3{font-size:1.125rem}.about-text p{font-size:.875rem}.about-stats{gap:1rem;grid-template-columns:1fr}.stat-item{padding:1rem}.stat-item h4{font-size:1.75rem}.value-item{padding:1rem}.value-item h4{font-size:1.125rem}.value-item p{font-size:.875rem}}@media (max-width:414px){.about{padding:3.5rem 0}.about-container{max-width:100%;padding:0 1.2rem}.section-title{font-size:1.9rem;margin-bottom:2.25rem}.about-text h3{font-size:1.2rem}.about-text p{font-size:.9rem;line-height:1.6}.about-stats{gap:1.25rem;grid-template-columns:1fr}.stat-item{padding:1.25rem}.stat-item h4{font-size:1.9rem}.stat-item p{font-size:.9rem}.value-item{padding:1.25rem}.value-item h4{font-size:1.2rem}.value-item p{font-size:.9rem}}@media (max-width:320px){.about-container{padding:0 .5rem}.section-title,.stat-item h4{font-size:1.5rem}}@media (prefers-reduced-motion:reduce){.stat-item:hover,.value-item:hover{transform:none}}@media (prefers-contrast:high){.about{background:#fff}.about-text h3,.section-title,.value-item h4{color:#000}.about-text p,.value-item p{color:#333}.stat-item,.value-item{background:#fff;border:2px solid #000}.stat-item h4{color:#000}}.skills{background:#fff;overflow:hidden;padding:6rem 0}.skills-container{margin:0 auto;max-width:1200px;padding:0 2rem}.skills-content{text-align:center}.skills-description{color:#4a5568;font-size:1.125rem;line-height:1.7;margin:0 auto 3rem;max-width:600px}.skills-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(min(300px,100%),1fr));margin:3rem 0}.skill-card{background:#f8fafc;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2rem;text-align:left;transition:all .3s ease}.skill-card:hover{box-shadow:0 8px 30px #00000026;transform:translateY(-5px)}.skill-icon{color:#667eea;font-size:2.5rem;margin-bottom:1rem}.skill-card h3{color:#2d3748;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.skill-category{color:#667eea;font-size:.875rem;font-weight:500;letter-spacing:.5px;margin:0 0 1rem;text-transform:uppercase}.skill-description{color:#4a5568;font-size:.875rem;line-height:1.6;margin:0 0 1.5rem}.skill-level{align-items:center;display:flex;gap:1rem}.skill-bar{background:#e2e8f0;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.skill-progress{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;height:100%;transition:width 1s ease}.skill-percentage{color:#667eea;font-size:.875rem;font-weight:600;min-width:40px}.skills-summary{margin-top:4rem}.skills-summary h3{color:#2d3748;font-size:1.5rem;font-weight:600;margin:0 0 2rem}.specialties-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(min(250px,100%),1fr))}.specialty-item{background:#f8fafc;border-radius:12px;padding:2rem;text-align:center;transition:all .3s ease}.specialty-item:hover{box-shadow:0 8px 30px #00000026;transform:translateY(-5px)}.specialty-item svg{color:#667eea;font-size:2.5rem;margin-bottom:1rem}.specialty-item h4{color:#2d3748;font-size:1.125rem;font-weight:600;margin:0 0 1rem}.specialty-item p{color:#4a5568;font-size:.875rem;line-height:1.6;margin:0}@media (max-width:1200px){.skills-container{padding:0 1.5rem}.skills-grid{gap:2rem;grid-template-columns:repeat(auto-fit,minmax(min(280px,100%),1fr))}.specialties-grid{grid-template-columns:repeat(auto-fit,minmax(min(200px,100%),1fr))}}@media (max-width:1024px){.skills-container{padding:0 1.25rem}.skills-grid{gap:1.75rem;grid-template-columns:repeat(auto-fit,minmax(min(250px,100%),1fr))}.specialties-grid{grid-template-columns:repeat(auto-fit,minmax(min(180px,100%),1fr))}}@media (max-width:768px){.skills{padding:4rem 0}.skills-container{padding:0 1rem}.skills-grid{gap:1.5rem;grid-template-columns:1fr}.skill-card{padding:1.5rem}.specialties-grid{gap:1.5rem;grid-template-columns:1fr}.specialty-item{padding:1.5rem}}@media (max-width:480px){.skills{padding:3rem 0}.skills-container{max-width:100%;padding:0 1rem}.skills-description{font-size:1rem;margin-bottom:2rem}.skill-card{padding:1rem}.skill-icon{font-size:2rem}.skill-card h3{font-size:1.125rem}.skill-description{font-size:.8rem}.skill-level{gap:.75rem}.skill-percentage{font-size:.8rem;min-width:35px}.specialty-item{padding:1rem}.specialty-item svg{font-size:2rem}.specialty-item h4{font-size:1rem}.specialty-item p{font-size:.8rem}}@media (max-width:414px){.skills{padding:3.5rem 0}.skills-container{max-width:100%;padding:0 1.2rem}.skills-description{font-size:.95rem;margin-bottom:2.25rem}.skills-grid{gap:1.75rem}.skill-card{padding:1.25rem}.skill-icon{font-size:2.25rem}.skill-card h3{font-size:1.2rem}.skill-description{font-size:.85rem;line-height:1.5}.skill-level{gap:.875rem}.skill-percentage{font-size:.85rem;min-width:38px}.specialties-grid{gap:1.75rem}.specialty-item{padding:1.25rem}.specialty-item svg{font-size:2.25rem}.specialty-item h4{font-size:1.1rem}.specialty-item p{font-size:.85rem}}@media (max-width:320px){.skills-container{padding:0 .5rem}.skill-card{padding:.75rem}.skill-icon{font-size:1.75rem}.skill-card h3{font-size:1rem}.specialty-item{padding:.75rem}.specialty-item svg{font-size:1.75rem}}@media (prefers-reduced-motion:reduce){.skill-card:hover,.specialty-item:hover{transform:none}.skill-progress{transition:none}}@media (prefers-contrast:high){.skills{background:#fff}.skill-card,.specialty-item{background:#fff;border:2px solid #000}.skill-card h3,.specialty-item h4{color:#000}.skill-description,.specialty-item p{color:#333}.skill-bar{background:#ccc}.skill-progress{background:#000}.skill-percentage{color:#000}}.projects{background:#f8fafc;overflow:hidden;padding:6rem 0}.projects-container{margin:0 auto;max-width:1200px;padding:0 2rem}.projects-content{text-align:center}.projects-description{color:#4a5568;font-size:1.125rem;line-height:1.7;margin:0 auto 3rem;max-width:600px}.projects-grid{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(min(350px,100%),1fr));margin:3rem 0}.project-card{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;display:flex;flex-direction:column;overflow:hidden;transform:scale(1)}.project-card,.project-card.expanded{transition:all .4s cubic-bezier(.4,0,.2,1)}.project-card.expanded{box-shadow:0 8px 30px #00000026;transform:scale(1.02)}.project-card:hover:not(.expanded){box-shadow:0 8px 30px #00000026;transform:translateY(-5px)}.project-image{height:200px;overflow:hidden;position:relative}.project-image img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.project-card:hover .project-image img{transform:scale(1.05)}.project-overlay{align-items:center;background:#667eeae6;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.project-card:hover .project-overlay{opacity:1}.project-btn{align-items:center;background:#fff;border:none;border-radius:8px;color:#667eea;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.project-btn:hover{background:#667eea;color:#fff;transform:translateY(-2px)}.project-content{display:flex;flex-direction:column;min-height:0;padding:1.5rem}.project-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.project-header h3{color:#2d3748;flex:1 1;font-size:1.25rem;font-weight:600;margin:0}.project-category{background:#667eea1a;border-radius:12px;color:#667eea;font-size:.75rem;font-weight:500;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.project-description{color:#4a5568;font-size:.875rem;line-height:1.6;margin:0 0 1.5rem}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.tech-tag{background:#f1f5f9;border-radius:12px;color:#4a5568;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.project-links{align-items:stretch;display:flex;gap:1rem;margin-top:1rem}.project-link{align-items:center;color:#667eea;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;text-decoration:none;transition:all .3s ease}.project-link:hover{color:#4c51bf;transform:translateY(-1px)}.project-details{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin:1rem 0;overflow:hidden}.details-content{padding:1rem;text-align:left}.details-content h4{color:#2d3748;font-size:1rem;font-weight:600;margin:0 0 1rem}.details-content ul{margin:0 0 1.5rem;padding-left:1.5rem}.details-content li{color:#4a5568;font-size:.875rem;line-height:1.6;margin-bottom:.5rem}.tech-details{display:flex;flex-wrap:wrap;gap:.5rem}.tech-detail{background:#667eea1a;border-radius:12px;color:#667eea;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.projects-cta{margin-top:3rem;text-align:center}.projects-cta p{color:#4a5568;font-size:1.125rem;margin:0 0 1.5rem}@media (max-width:1200px){.projects-container{padding:0 1.5rem}.projects-grid{gap:2rem;grid-template-columns:repeat(auto-fit,minmax(min(320px,100%),1fr))}}@media (max-width:1024px){.projects-container{padding:0 1.25rem}.projects-grid{gap:1.75rem;grid-template-columns:repeat(auto-fit,minmax(min(300px,100%),1fr))}.project-card{max-width:100%}}@media (max-width:768px){.projects{padding:4rem 0}.projects-container{padding:0 1rem}.projects-grid{gap:1.5rem;grid-template-columns:1fr}.project-card{margin:0 auto;max-width:min(400px,100%)}.project-content{padding:1rem}.project-header{align-items:flex-start}.project-header,.project-links{flex-direction:column;gap:.5rem}.project-link{justify-content:center}}@media (max-width:480px){.projects{padding:3rem 0}.projects-container{max-width:100%;padding:0 1rem}.projects-description{font-size:1rem;margin-bottom:2rem}.project-image{height:150px}.project-content{padding:.75rem}.project-header h3{font-size:1.125rem}.project-description{font-size:.8rem}.project-links{gap:.75rem}.project-link{font-size:.8rem;padding:.5rem 0}.details-content{padding:.75rem}.details-content h4{font-size:.9rem}.details-content li{font-size:.8rem}}@media (max-width:414px){.projects{padding:3.5rem 0}.projects-container{max-width:100%;padding:0 1.2rem}.projects-description{font-size:.95rem;margin-bottom:2.25rem}.projects-grid{gap:1.75rem}.project-card{max-width:100%}.project-image{height:180px}.project-content{padding:1rem}.project-header h3{font-size:1.2rem}.project-description{font-size:.85rem;line-height:1.5}.project-links{gap:.875rem}.project-link{font-size:.85rem;padding:.5rem 0}.details-content{padding:1rem}.details-content h4{font-size:.95rem}.details-content li{font-size:.8rem}}@media (max-width:320px){.projects-container{padding:0 .5rem}.project-image{height:120px}.project-content{padding:.5rem}.project-header h3{font-size:1rem}.project-description{font-size:.75rem}}@media (prefers-reduced-motion:reduce){.project-btn:hover,.project-card:hover,.project-card:hover .project-image img,.project-link:hover{transform:none}}@media (prefers-contrast:high){.project-card,.projects{background:#fff}.project-card{border:2px solid #000}.project-header h3{color:#000}.project-description{color:#333}.tech-tag{background:#ccc}.project-link,.tech-tag{color:#000}.project-link:hover{background:#000;color:#fff}.project-details{background:#f0f0f0;border-top:2px solid #000}.details-content h4{color:#000}.details-content li{color:#333}.tech-detail{background:#ccc;color:#000}}.contact{background:#fff;overflow:hidden;padding:6rem 0}.contact-container{margin:0 auto;max-width:1200px;padding:0 2rem}.contact-content{text-align:center}.contact-description{color:#4a5568;font-size:1.125rem;line-height:1.7;margin:0 auto 3rem;max-width:600px}.contact-grid{grid-gap:4rem;align-items:start;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:3rem 0}.contact-info{text-align:left}.contact-info h3{color:#2d3748;font-size:1.5rem;font-weight:600;margin:0 0 2rem}.info-items{margin-bottom:2rem}.info-item{align-items:flex-start;background:#f8fafc;border-radius:8px;display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem;transition:all .3s ease}.info-item:hover{background:#e2e8f0;transform:translateY(-2px)}.info-icon{color:#667eea;font-size:1.25rem;margin-top:.25rem}.info-content h4{color:#2d3748;font-size:1rem;font-weight:600;margin:0 0 .5rem}.info-content p,.info-link{color:#4a5568;font-size:.875rem;margin:0;overflow-wrap:break-word;text-decoration:none;transition:color .3s ease;word-break:break-word}.info-link:hover{color:#667eea}.social-links h4{color:#2d3748;font-size:1rem;font-weight:600;margin:0 0 1rem}.social-icon{font-size:1.25rem;height:50px;width:50px}.contact-form{text-align:left}.contact-form h3{color:#2d3748;font-size:1.5rem;font-weight:600;margin:0 0 2rem}.form{gap:1.5rem}.form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#2d3748;font-size:.875rem;font-weight:600}.form-group input,.form-group textarea{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:.875rem;padding:.75rem;transition:all .3s ease}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group textarea{min-height:120px;resize:vertical}.submit-btn{font-size:1rem;font-weight:600;margin-top:1rem;padding:.875rem 2rem}.submit-btn:disabled{cursor:not-allowed;opacity:.7}.success-message{background:#d4edda;color:#155724}.error-message,.success-message{border-radius:8px;font-size:.875rem;margin-top:1rem;padding:1rem;text-align:center}.error-message{background:#f8d7da;color:#721c24}@media (max-width:1200px){.contact-container{padding:0 1.5rem}.contact-grid{gap:3.5rem}}@media (max-width:1024px){.contact-container{padding:0 1.25rem}.contact-grid{gap:3rem;grid-template-columns:1fr}.contact-info{text-align:center}.info-item,.social-icons{justify-content:center}}@media (max-width:768px){.contact{padding:4rem 0}.contact-container{padding:0 1rem}.contact-grid{gap:2rem}.contact-description{font-size:1rem;margin-bottom:2rem}.contact-form h3,.contact-info h3{font-size:1.25rem}.info-item{padding:.75rem}.social-icon{font-size:1.125rem;height:45px;width:45px}.form-group input,.form-group textarea{padding:.75rem}}@media (max-width:480px){.contact{padding:3rem 0}.contact-container{max-width:100%;padding:0 1rem}.contact-grid{gap:1.5rem}.contact-description{font-size:.9rem}.contact-form h3,.contact-info h3{font-size:1.125rem}.info-item{flex-direction:column;gap:.5rem;padding:.75rem;text-align:center}.info-content h4{font-size:.9rem}.info-content p,.info-link{font-size:.8rem}.social-icons{gap:.75rem}.social-icon{font-size:1rem;height:40px;width:40px}.form-group label{font-size:.8rem}.form-group input,.form-group textarea{font-size:.8rem;padding:.625rem}.submit-btn{font-size:.9rem;padding:.75rem 1.5rem}}@media (max-width:414px){.contact{padding:3.5rem 0}.contact-container{max-width:100%;padding:0 1.2rem}.contact-grid{gap:1.75rem}.contact-description{font-size:.95rem;margin-bottom:2.25rem}.contact-form h3,.contact-info h3{font-size:1.2rem}.info-item{flex-direction:column;gap:.5rem;padding:1rem;text-align:center}.info-content h4{font-size:.95rem}.info-content p,.info-link{font-size:.85rem}.social-icons{gap:.875rem}.social-icon{font-size:1.1rem;height:42px;width:42px}.form-group label{font-size:.85rem}.form-group input,.form-group textarea{font-size:.85rem;padding:.75rem}.submit-btn{font-size:.95rem;padding:.875rem 1.75rem}}@media (max-width:320px){.contact-container{padding:0 .5rem}.contact-form h3,.contact-info h3{font-size:1rem}.info-item{padding:.5rem}.social-icon{font-size:.9rem;height:35px;width:35px}.form-group input,.form-group textarea{font-size:.75rem;padding:.5rem}.submit-btn{font-size:.8rem;padding:.625rem 1.25rem}}@media (prefers-reduced-motion:reduce){.info-item:hover,.social-icon:hover{transform:none}}@media (prefers-contrast:high){.contact{background:#fff}.contact-form h3,.contact-info h3{color:#000}.info-item{background:#fff;border:2px solid #000}.info-item:hover{background:#f0f0f0}.info-content h4{color:#000}.info-content p,.info-link{color:#333}.info-link:hover,.social-links h4{color:#000}.social-icon{background:#e2e8f0;border:2px solid #000;color:#000}.social-icon:hover{background:#000;color:#fff}.form-group label{color:#000}.form-group input,.form-group textarea{background:#fff;border:2px solid #000;color:#000}.form-group input:focus,.form-group textarea:focus{border-color:#000;box-shadow:0 0 0 3px #0003}.success-message{background:#d4edda}.error-message,.success-message{border:2px solid #000;color:#000}.error-message{background:#f8d7da}}.footer{background:#1a202c;color:#fff;padding:4rem 0 2rem}.footer-container{margin:0 auto;max-width:1200px;padding:0 2rem}.footer-content{display:flex;flex-direction:column;gap:3rem}.footer-main{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:2fr 1fr 1fr 1fr;justify-items:center;text-align:center}.footer-info h3{color:#667eea;font-size:1.5rem;font-weight:600;margin:0 0 1rem;text-align:center}.footer-info p{color:#a0aec0;font-size:.875rem;line-height:1.6;margin:0;text-align:center}.footer-contact h4,.footer-links h4,.footer-social h4{color:#e2e8f0;font-size:1rem;font-weight:600;margin:0 0 1rem;text-align:center}.footer-links ul{list-style:none;margin:0;padding:0;text-align:center}.footer-links li{margin-bottom:.5rem}.footer-links a{color:#a0aec0;font-size:.875rem;text-decoration:none;transition:color .3s ease}.footer-links a:hover{color:#667eea}.footer-contact p{color:#a0aec0;font-size:.875rem;line-height:1.6;margin:0 0 .5rem;overflow-wrap:break-word;text-align:center;word-break:break-word}.social-icons{display:flex;gap:1rem}.social-icon{align-items:center;background:#e2e8f0;border-radius:50%;color:#667eea;color:var(--social-color,#667eea);display:flex;font-size:1rem;height:40px;justify-content:center;text-decoration:none;transition:all .3s ease;width:40px}.social-icon:hover{background:#667eea;background:var(--social-color,#667eea);color:#fff;transform:translateY(-2px)}.footer-bottom{border-top:1px solid #2d3748;gap:2rem;padding-top:2rem}.footer-bottom,.footer-copyright p{align-items:center;display:flex;justify-content:center}.footer-copyright p{color:#a0aec0;flex-wrap:wrap;font-size:.875rem;gap:.5rem;margin:0;text-align:center}.made-with{align-items:center;display:flex;gap:.25rem;margin-left:1rem}.heart-icon{animation:heartbeat 2s infinite;color:#e53e3e}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.scroll-to-top{align-items:center;background:#667eea;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.125rem;height:50px;justify-content:center;transition:all .3s ease;width:50px}.scroll-to-top:hover{background:#4c51bf;transform:translateY(-2px)}@media (max-width:1200px){.footer-container{padding:0 1.5rem}.footer-main{gap:2.5rem}}@media (max-width:1024px){.footer-container{padding:0 1.25rem}.footer-main{gap:2rem;grid-template-columns:1fr 1fr}.footer-info{grid-column:1/-1}}@media (max-width:768px){.footer{padding:3rem 0 1.5rem}.footer-container{padding:0 1rem}.footer-main{gap:2rem;grid-template-columns:1fr;text-align:center}.footer-info{grid-column:1}.social-icons{justify-content:center}.footer-bottom{flex-direction:column;gap:1rem;text-align:center}.footer-copyright p{justify-content:center}.made-with{margin-left:0;margin-top:.5rem}}@media (max-width:480px){.footer{padding:2.5rem 0 1rem}.footer-container{max-width:100%;padding:0 1rem}.footer-main{gap:1.5rem}.footer-info h3{font-size:1.25rem}.footer-info p{font-size:.8rem}.footer-contact h4,.footer-links h4,.footer-social h4{font-size:.875rem}.footer-contact p,.footer-links a{font-size:.75rem}.social-icons{gap:.75rem}.social-icon{font-size:.875rem;height:35px;width:35px}.footer-copyright p{font-size:.75rem}.scroll-to-top{font-size:1rem;height:45px;width:45px}}@media (max-width:414px){.footer{padding:3rem 0 1.25rem}.footer-container{max-width:100%;padding:0 1.2rem}.footer-main{gap:1.75rem}.footer-info h3{font-size:1.3rem}.footer-info p{font-size:.85rem}.footer-contact h4,.footer-links h4,.footer-social h4{font-size:.9rem}.footer-contact p,.footer-links a{font-size:.8rem}.social-icons{gap:.875rem}.social-icon{font-size:.95rem;height:38px;width:38px}.footer-copyright p{font-size:.8rem}.scroll-to-top{font-size:1.1rem;height:48px;width:48px}}@media (max-width:320px){.footer-container{padding:0 .5rem}.footer-info h3{font-size:1.125rem}.footer-contact p,.footer-copyright p,.footer-links a{font-size:.7rem}.social-icon{font-size:.8rem;height:30px;width:30px}.scroll-to-top{font-size:.9rem;height:40px;width:40px}}@media (prefers-reduced-motion:reduce){.heart-icon{animation:none}.scroll-to-top:hover,.social-icon:hover{transform:none}}@media (prefers-contrast:high){.footer{background:#000}.footer,.footer-info h3{color:#fff}.footer-contact p,.footer-copyright p,.footer-info p,.footer-links a{color:#ccc}.footer-links a:hover{color:#fff}.social-icon{background:#e2e8f0;border:2px solid #000;color:#000}.social-icon:hover{background:#000;color:#fff}.scroll-to-top{background:#fff;border:2px solid #000;color:#000}.scroll-to-top:hover{background:#000;color:#fff}.footer-bottom{border-top:2px solid #fff}.heart-icon{color:red}}.loading-overlay{animation:fadeIn .3s ease-in-out;background:linear-gradient(135deg,#f8fafc,#e2e8f0 50%,#f1f5f9);height:100%;left:0;position:fixed;top:0;width:100%;z-index:9999}.loading-container,.loading-overlay{align-items:center;display:flex;justify-content:center}.loading-container{color:#4a5568;flex-direction:column;text-align:center}.loading-balls{align-items:center;display:flex;height:60px;justify-content:center;margin:0 auto 30px;position:relative;width:120px}.ball{animation:ballMove 1.5s ease-in-out infinite;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;height:20px;position:absolute;width:20px}.ball-1{animation-delay:0s;left:0}.ball-2{animation-delay:.75s;right:0}.loading-text{animation:pulse 2s ease-in-out infinite;color:#4a5568;font-size:1.1rem;font-weight:500;margin:0}@keyframes ballMove{0%,to{opacity:.7;transform:translateX(0)}50%{opacity:1;transform:translateX(50px)}}@keyframes pulse{0%,to{opacity:.8}50%{opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.loading-overlay.fade-out{animation:fadeOut .5s ease-in-out forwards}@keyframes fadeOut{0%{opacity:1}to{opacity:0;visibility:hidden}}@media (max-width:768px){.loading-balls{height:50px;width:100px}.ball{height:16px;width:16px}@keyframes ballMove{0%,to{opacity:.7;transform:translateX(0)}50%{opacity:1;transform:translateX(42px)}}.loading-text{font-size:1rem}}@media (max-width:480px){.loading-balls{height:40px;width:80px}.ball{height:14px;width:14px}@keyframes ballMove{0%,to{opacity:.7;transform:translateX(0)}50%{opacity:1;transform:translateX(33px)}}}
/*# sourceMappingURL=main.ac0ff452.css.map*/