@import"https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap";:root{--background-primary: #f5f5f5;--background-secondary: #ffffff;--text-primary: #333333;--text-secondary: #555555;--accent-primary: #007bff;--accent-secondary: #00b894;--accent-primary-rgb: 0, 123, 255;--success-color: #28a745;--error-color: #e74c3c;--font-family: "Poppins", system-ui, Avenir, Helvetica, Arial, sans-serif;--transition: all .3s ease;--section-spacing: clamp(4rem, 8vw, 6rem);--shadow: 0 2px 4px rgba(0, 0, 0, .1);--card-padding: clamp(.6rem, 1.2vw, .8rem);--card-height: clamp(100px, 15vw, 140px)}body{margin:0;width:100%;min-width:320px;background-color:var(--background-primary);color:var(--text-primary);font-family:var(--font-family);line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}a{font-weight:500;color:var(--accent-primary);text-decoration:none;font-size:clamp(.9rem,1.3vw,1rem)}a:hover{color:#0056b3}h1{font-size:clamp(2.2rem,4vw,2.8rem);line-height:1.2}h2,h3{font-size:clamp(1.8rem,3.5vw,2.4rem);position:relative;display:inline-block;margin-bottom:2rem}h2:after,h3:after{content:"";position:absolute;bottom:-10px;left:0;width:60px;height:4px;background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));border-radius:2px}h3{font-size:clamp(1.4rem,2.5vw,1.8rem)}h4{font-size:clamp(1.1rem,2vw,1.3rem)}button{border-radius:8px;border:none;padding:clamp(.5rem,1vw,.7rem) clamp(1rem,2vw,1.2rem);font-size:clamp(.9rem,1.3vw,1rem);font-weight:500;font-family:var(--font-family);background-color:var(--background-secondary);color:var(--text-primary);cursor:pointer;transition:var(--transition)}button:hover{background-color:#e6f0ff}button:focus,button:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}section{padding:var(--section-spacing) 1rem}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}@media (max-width: 768px){a{font-size:clamp(.85rem,1.2vw,.95rem)}button{padding:clamp(.4rem,.8vw,.6rem) clamp(.8rem,1.5vw,1rem);font-size:clamp(.85rem,1.2vw,.95rem)}section{padding:clamp(3rem,6vw,4rem) 1rem}h2,h3{margin-bottom:1.5rem}}@media (max-width: 576px){a{font-size:clamp(.8rem,1.1vw,.9rem)}button{padding:clamp(.3rem,.7vw,.5rem) clamp(.6rem,1.2vw,.8rem);font-size:clamp(.8rem,1.1vw,.9rem)}}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--background-primary);width:100%;min-width:320px;font-family:var(--font-family);color:var(--text-primary);overflow-x:hidden}.app{width:100%;display:flex;flex-direction:column;padding:clamp(.75rem,1.5vw,1rem)}main{flex:1;width:100%}section{width:100%;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;animation:fadeIn 1s ease-out}html{scroll-behavior:smooth}@keyframes fadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.app{padding:clamp(.5rem,1vw,.75rem)}}@media (max-width: 576px){.app{padding:clamp(.5rem,.8vw,.6rem)}}.header-modern{position:fixed;top:0;left:0;right:0;background:#111827cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(55,65,81,.3);color:#d1d5db;padding:.75rem 0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;transition:all .3s ease;z-index:9998;opacity:0;transform:translateY(-20px)}.header-modern.mounted{opacity:1;transform:translateY(0);animation:fadeInDown .5s ease-out forwards}.header-modern.scrolled{background:#111827f2;box-shadow:0 4px 20px #0000001a;padding:.5rem 0}.header-modern.menu-open{height:auto}body.menu-open{padding-top:var(--mobile-menu-height, 0)}.header-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}@media (min-width: 768px){.header-container{padding:0 2rem}}.header-brand{flex-shrink:0}.header-brand-link{text-decoration:none;color:#fff;transition:color .3s ease;outline:none;border-radius:.375rem;padding:.25rem;margin:-.25rem;display:block}.header-brand-link:hover{color:#60a5fa}.header-brand-link:focus{box-shadow:0 0 0 2px #3b82f6}.header-logo-wrapper{display:flex;align-items:center;gap:.5rem}.header-logo-icon{width:2rem;height:2rem;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#1f2937;transition:transform .3s ease}.header-brand-link:hover .header-logo-icon{transform:scale(1.1) rotate(12deg)}.header-logo-text{display:flex;flex-direction:column;line-height:1.2}.header-logo-text h1{font-size:1.125rem;font-weight:700;letter-spacing:.025em;margin:0;line-height:1.2}.header-logo-text p{font-size:.75rem;color:#9ca3af;font-weight:300;margin:0;line-height:1.2}.header-navigation{display:none}@media (min-width: 768px){.header-navigation{display:block}}.header-nav-list{display:flex;list-style:none;gap:2rem;margin:0;padding:0}.header-nav-link{color:#9ca3af;font-size:.875rem;font-weight:500;text-decoration:none;position:relative;padding:.5rem;transition:color .3s ease;outline:none;border-radius:.375rem}.header-nav-link:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:2px;background:#3b82f6;transition:width .3s ease;border-radius:2px}.header-nav-link:hover,.header-nav-link:focus,.header-nav-link.active{color:#fff}.header-nav-link:hover:after,.header-nav-link:focus:after,.header-nav-link.active:after{width:calc(100% - 1rem)}.header-nav-link:focus{box-shadow:0 0 0 2px #3b82f6}.header-actions{display:none;align-items:center;gap:1rem}@media (min-width: 768px){.header-actions{display:flex}}.header-social-icons{display:flex;gap:.5rem}.header-social-icon{width:2.25rem;height:2.25rem;background:#374151;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#9ca3af;text-decoration:none;transition:all .2s ease;outline:none}.header-social-icon:hover{transform:scale(1.1) rotate(6deg)}.header-social-icon:focus{box-shadow:0 0 0 2px #3b82f6}.header-social-icon[data-color="#181717"]:hover{background:#181717;color:#fff}.header-social-icon[data-color="#0A66C2"]:hover{background:#0a66c2;color:#fff}.header-social-icon[data-color="#1DA1F2"]:hover{background:#1da1f2;color:#fff}.header-social-icon[data-color="#25D366"]:hover{background:#25d366;color:#fff}.header-cv-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#2563eb;color:#fff!important;text-decoration:none;border-radius:9999px;font-size:.875rem;font-weight:600;transition:all .3s ease;outline:none;position:relative;z-index:1}.header-cv-button:hover{background:#1d4ed8;color:#fff!important;box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}.header-cv-button:focus{box-shadow:0 0 0 2px #3b82f6;color:#fff!important}.header-cv-button:visited{color:#fff!important}.header-cv-button[aria-disabled=true]{opacity:.7;cursor:not-allowed}.header-menu-button{display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;background:#374151;border:none;border-radius:.75rem;color:#9ca3af;cursor:pointer;transition:all .3s ease;outline:none;position:relative;z-index:9999}.header-menu-button:hover{background:#4b5563;color:#fff;transform:scale(1.05)}.header-menu-button:focus{box-shadow:0 0 0 3px #3b82f666}.header-menu-button:active{transform:scale(.95)}@media (min-width: 768px){.header-menu-button{display:none}}.header-mobile-menu-container{position:relative;width:100%;background:#111827f2;border-top:1px solid rgba(55,65,81,.3);z-index:9997;padding:1rem;opacity:0;transform:translateY(-20px);animation:slideIn .3s ease-out forwards;text-align:center}@media (min-width: 768px){.header-mobile-menu-container{display:none}}.header-mobile-nav{display:flex;align-items:center;justify-content:center;width:100%;max-width:400px;margin:0 auto}.header-mobile-nav ul{list-style:none;padding:0;margin:1rem 0 0;display:flex;flex-direction:column;gap:.5rem;width:100%;align-items:center}.header-mobile-nav li{width:100%;max-width:300px}.header-mobile-nav-link{display:block;width:100%;color:#fff;font-size:.95rem;font-weight:600;text-decoration:none;text-align:center;padding:.75rem 1rem;background:#374151;border:2px solid #6b7280;border-radius:.5rem;transition:all .3s ease;min-height:44px}.header-mobile-nav-link:hover,.header-mobile-nav-link:focus,.header-mobile-nav-link.active{background:#3b82f6;border-color:#2563eb;color:#fff;transform:translateY(-2px)}.header-mobile-actions{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;width:100%;max-width:400px;padding-top:.5rem;margin:0 auto}.header-mobile-social{display:flex;justify-content:center;align-items:center;gap:1rem;width:100%;max-width:280px;margin:0 auto;flex-wrap:wrap}.header-mobile-social-icon{width:2.5rem;height:2.5rem;background:#374151;border:2px solid #6b7280;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;transition:all .3s ease;outline:none}.header-mobile-social-icon:hover{transform:scale(1.1);box-shadow:0 4px 15px #0000004d}.header-mobile-social-icon[data-color="#181717"]:hover{background:#181717;border-color:#181717}.header-mobile-social-icon[data-color="#0A66C2"]:hover{background:#0a66c2;border-color:#0a66c2}.header-mobile-social-icon[data-color="#1DA1F2"]:hover{background:#1da1f2;border-color:#1da1f2}.header-mobile-social-icon[data-color="#25D366"]:hover{background:#25d366;border-color:#25d366}.header-mobile-cv-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;background:#2563eb;color:#fff!important;text-decoration:none;border:2px solid #1d4ed8;border-radius:.5rem;font-size:.95rem;font-weight:600;transition:all .3s ease;outline:none;width:100%;max-width:280px;min-height:44px;margin:0 auto}.header-mobile-cv-button:hover{background:#1d4ed8;color:#fff!important;transform:translateY(-2px);box-shadow:0 4px 15px #2563eb4d}.header-mobile-cv-button[aria-disabled=true]{opacity:.7;cursor:not-allowed}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.header-container{padding:0 .75rem}.header-logo-icon{width:1.5rem;height:1.5rem;font-size:.75rem}.header-logo-text h1{font-size:.875rem}.header-logo-text p{font-size:.625rem}.header-menu-button{width:2.25rem;height:2.25rem}.header-mobile-menu-container{padding:.75rem}.header-mobile-nav-link{font-size:.875rem;padding:.625rem .875rem;min-height:44px}.header-mobile-social-icon{width:2.25rem;height:2.25rem}.header-mobile-cv-button{font-size:.875rem;padding:.625rem 1rem;min-height:44px}.header-mobile-actions{gap:.75rem;max-width:240px;margin:0 auto}.header-mobile-social{gap:.75rem;max-width:200px}}@media (max-width: 360px){.header-mobile-nav-link{font-size:.75rem;padding:.5rem .75rem}.header-mobile-social-icon{width:2rem;height:2rem}.header-mobile-cv-button{font-size:.75rem;padding:.5rem .875rem}.header-mobile-menu-container{padding:.5rem}}@media (hover: none) and (pointer: coarse){.header-menu-button{min-width:44px;min-height:44px}.header-mobile-nav-link{min-height:44px;padding:.75rem 1rem}.header-mobile-social-icon{min-width:44px;min-height:44px}.header-mobile-cv-button{min-height:44px}}@media (prefers-reduced-motion: reduce){.header-modern,.header-logo-icon,.header-social-icon,.header-mobile-social-icon,.header-cv-button,.header-mobile-cv-button,.header-mobile-menu-container{transition:none;animation:none}.header-modern.mounted{opacity:1;transform:translateY(0);animation:none}}.header-mobile-overlay{display:none!important}.hero{background:linear-gradient(135deg,#f0f4f8,#fff);color:var(--text-primary);width:100%;min-height:90vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:var(--section-spacing) 1rem;position:relative;overflow:hidden}.hero__container{max-width:1200px;width:100%;padding:0 clamp(.5rem,1vw,.75rem);z-index:1}.hero__content{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}.hero__text{order:1;max-width:100%}.hero__image-container{order:2;display:flex;justify-content:center;align-items:center}.hero__image-wrapper{position:relative;width:clamp(180px,25vw,280px);height:clamp(180px,25vw,280px)}.hero__profile-image{width:100%;height:100%;border-radius:50%;object-fit:cover;box-shadow:0 2px 12px #0000001a;transition:var(--transition);background-color:#f0f0f0}.hero__image-wrapper:hover .hero__profile-image{transform:scale(1.05);box-shadow:0 4px 16px #00000026}.greeting{font-size:clamp(.9rem,1.3vw,1rem);color:var(--text-secondary);margin-bottom:.5rem;display:flex;align-items:center}.wave{display:inline-block;animation:wave 2s infinite;margin-right:6px}@keyframes wave{0%,to{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}60%{transform:rotate(0)}}.hero h1{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;margin:0;margin-bottom:.5rem;line-height:1.2}.dynamic-text{min-height:50px;margin-bottom:1rem;font-weight:600;font-size:clamp(1.1rem,2.5vw,1.6rem);display:flex;align-items:center;line-height:1.3}.dynamic-text span{color:var(--accent-secondary)}.cursor-blink{font-size:clamp(1.1rem,2.5vw,1.6rem);color:var(--accent-secondary);margin-left:2px;animation:blink 1s infinite}@keyframes blink{0%{opacity:1}50%{opacity:0}to{opacity:1}}.hero-tagline{font-size:clamp(.9rem,1.2vw,1rem);color:var(--text-secondary);max-width:90%;margin-bottom:2rem;line-height:1.6}.hero-social-links{display:flex;gap:clamp(.75rem,1.5vw,1rem);margin:1.5rem 0;flex-wrap:wrap;justify-content:flex-start}.hero-social-link{display:inline-block;transition:var(--transition);border-radius:4px}.hero-social-link img{height:clamp(28px,4vw,32px);width:auto;display:block}.hero-social-link:hover{transform:scale(1.05);box-shadow:0 2px 8px #0000001a}.hero__cta-container{display:flex;gap:clamp(.75rem,1.5vw,1rem);margin-top:1rem;flex-wrap:wrap}.hero__cta{font-size:clamp(.9rem,1.2vw,1rem);font-weight:600;padding:.75rem 1.5rem;border-radius:.5rem;text-decoration:none;color:#fff!important;background-color:var(--accent-primary);transition:var(--transition);display:flex;align-items:center;gap:.5rem;position:relative;z-index:1}.hero__cta:hover{background-color:#2b6cb0;color:#fff!important;box-shadow:0 4px 12px #3182ce66;transform:translateY(-1px)}.hero__cta:focus{color:#fff!important;box-shadow:0 0 0 2px #3b82f6}.hero__cta:visited{color:#fff!important}.hero__cta.secondary{background-color:transparent;color:var(--accent-primary)!important;border:1px solid var(--accent-primary);box-shadow:none}.hero__cta.secondary:hover{background-color:#3182ce1a;color:var(--accent-primary)!important;box-shadow:0 4px 12px #3182ce33;transform:translateY(-1px)}.hero__cta.secondary:focus{color:var(--accent-primary)!important;box-shadow:0 0 0 2px #3b82f6}.hero__cta.secondary:visited{color:var(--accent-primary)!important}.hero__cta svg{margin-left:.25rem;transition:var(--transition)}.hero__cta:hover svg{transform:translate(5px)}.hero__cta.secondary:hover svg{transform:translate(-5px)}@keyframes fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fade-in .6s ease-out forwards;opacity:0}.hero-bg-elements{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:0}.hero-bg-orb-1,.hero-bg-orb-2,.hero-bg-orb-3{position:absolute;border-radius:50%;background:#8b5cf61a;-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);filter:blur(20px);opacity:0;animation-duration:20s;animation-iteration-count:infinite;animation-timing-function:linear}.hero-bg-orb-1{width:clamp(200px,20vw,400px);height:clamp(200px,20vw,400px);top:10%;left:15%;animation-name:orb-animation-1;animation-delay:0s}.hero-bg-orb-2{width:clamp(150px,15vw,300px);height:clamp(150px,15vw,300px);top:70%;left:80%;background:#3182ce1a;animation-name:orb-animation-2;animation-delay:-5s}.hero-bg-orb-3{width:clamp(100px,10vw,200px);height:clamp(100px,10vw,200px);top:40%;left:50%;background:#64c8961a;animation-name:orb-animation-3;animation-delay:-10s}@keyframes orb-animation-1{0%{transform:translate(0) scale(1);opacity:.2}25%{transform:translate(20vw,15vh) scale(1.1);opacity:.3}50%{transform:translate(5vw,-5vh) scale(.9);opacity:.2}75%{transform:translate(-10vw,10vh) scale(1.2);opacity:.3}to{transform:translate(0) scale(1);opacity:.2}}@keyframes orb-animation-2{0%{transform:translate(0) scale(1);opacity:.2}25%{transform:translate(-15vw,-10vh) scale(1.2);opacity:.3}50%{transform:translate(-5vw,5vh) scale(1.1);opacity:.2}75%{transform:translate(10vw,-10vh) scale(1.3);opacity:.3}to{transform:translate(0) scale(1);opacity:.2}}@keyframes orb-animation-3{0%{transform:translate(0) scale(1);opacity:.2}30%{transform:translate(10vw,-10vh) scale(1.1);opacity:.3}60%{transform:translate(-5vw,15vh) scale(.9);opacity:.2}to{transform:translate(0) scale(1);opacity:.2}}@media (max-width: 768px){.hero__content{grid-template-columns:1fr;gap:3rem}.hero__text{order:2;text-align:center}.hero__image-container{order:1;justify-content:center}.hero h1{font-size:clamp(1.8rem,8vw,2.8rem)}.dynamic-text{font-size:clamp(1.1rem,5vw,1.6rem)}.hero-tagline{text-align:center;max-width:100%}.hero-social-links,.hero__cta-container{justify-content:center}.hero-bg-elements{display:none}}.about{display:flex;justify-content:center;align-items:center;padding:var(--section-spacing) clamp(.5rem,1vw,.75rem);font-family:var(--font-family)}.about-container{max-width:1200px;width:100%;margin:0 auto;padding:0 clamp(.5rem,1vw,.75rem)}.about-content{width:100%;max-width:1000px;margin:0 auto}.about-header{margin-bottom:clamp(1.5rem,2vw,2rem);text-align:center}.about-header h2{font-size:clamp(1.8rem,3.5vw,2.3rem);color:var(--text-primary);font-weight:700;margin-bottom:.8rem;letter-spacing:.5px;position:static}.about-header h2:after{content:none}.services-header{margin-bottom:clamp(1.5rem,2vw,2rem);text-align:center}.services-header h3{font-size:clamp(1.6rem,2.8vw,2rem);color:var(--text-primary);margin-bottom:.8rem;font-weight:700;letter-spacing:.5px;position:static}.services-header h3:after{content:none}.about-header:hover .divider,.services-header:hover .divider{width:80px}.about-text{background:var(--background-secondary);border-radius:10px;padding:clamp(.75rem,1.5vw,1rem);margin-bottom:clamp(1.5rem,3vw,2rem);box-shadow:var(--shadow)}.about-text p{font-size:clamp(.85rem,1.2vw,.95rem);color:var(--text-secondary);line-height:1.5;margin-bottom:.8rem;text-align:left}.highlight{color:var(--accent-primary);font-weight:600;position:relative}.highlight:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:2px;background:var(--accent-primary);transform:scaleX(0);transform-origin:right;transition:transform .3s ease}.highlight:hover:after{transform:scaleX(1);transform-origin:left}.services-section{margin:clamp(2rem,4vw,3rem) 0}.services-intro{color:var(--text-secondary);font-size:clamp(.85rem,1.2vw,1rem);text-align:center;max-width:700px;margin:0 auto 2rem;line-height:1.5}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:clamp(1rem,2vw,1.5rem);align-items:stretch}.service-card{padding:1.8rem 1.2rem;background:var(--background-secondary);border-radius:10px;box-shadow:var(--shadow);text-align:center;cursor:pointer;min-height:200px;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;border:1px solid rgba(0,0,0,.05);transition:all .3s ease-in-out;transform-style:preserve-3d}.service-card:before{content:"";position:absolute;inset:-2px;background:linear-gradient(45deg,var(--accent-primary),var(--accent-secondary));z-index:-1;border-radius:12px;opacity:0;transition:opacity .3s ease-in-out}.service-card:hover{transform:translateY(-8px) rotateX(2deg) rotateY(2deg) scale(1.03);box-shadow:0 15px 30px #3b82f633}.service-card:hover:before{opacity:1}.service-card:after{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.service-card:hover:after{transform:scaleX(1)}.service-card:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.service-icon{margin-bottom:1rem;transition:transform .3s ease}.service-card:hover .service-icon{transform:scale(1.1)}.icon-bg{width:40px;height:40px;background:#e6f0ff;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto}.icon-bg span{font-size:1.5rem;color:var(--accent-primary)}.service-card h4{font-size:1.1rem;color:var(--text-primary);margin:0;font-weight:600;white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-width:100%;line-height:1.4}.service-description{color:var(--text-secondary);font-size:clamp(.75rem,1.1vw,.85rem);margin-top:.6rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.service-modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100vh;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;overflow-y:auto;padding:0}.service-modal-content{background:var(--background-secondary);border-radius:10px;box-shadow:0 4px 8px #0003;width:90%;max-width:500px;max-height:calc(100vh - 1rem);overflow-y:auto;position:relative;padding:2rem}.service-modal-close{position:absolute;top:8px;right:8px;background:#e6f0ff;border:none;width:28px;height:28px;border-radius:50%;color:var(--accent-primary);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .3s ease,background .3s ease}.service-modal-close:hover,.service-modal-close:focus{background:#d0e0ff;transform:rotate(90deg)}.service-modal-close:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.service-modal-icon{text-align:center;margin-bottom:.8rem}.service-modal-icon .icon-bg{width:50px;height:50px;background:#e6f0ff;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.service-modal-icon span{font-size:1.8rem;color:var(--accent-primary)}.service-modal-details{padding:0 clamp(.5rem,1vw,.75rem)}.service-modal-details h3{font-size:clamp(1.2rem,1.8vw,1.5rem);color:var(--text-primary);text-align:center;margin:0 0 .8rem}.service-modal-description{font-size:clamp(.8rem,1.1vw,.9rem);color:var(--text-secondary);line-height:1.5;margin-bottom:.8rem;text-align:center}.service-modal-section{margin-bottom:1.5rem}.service-modal-section h4{font-size:clamp(.9rem,1.3vw,1rem);color:var(--accent-primary);margin-bottom:.6rem;text-align:center;position:relative;padding-bottom:5px}.service-modal-section h4:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:40px;height:2px;background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));border-radius:1px}.service-modal-section ul{list-style:none;padding:0}.service-modal-section li{font-size:clamp(.75rem,1vw,.85rem);color:var(--text-secondary);margin-bottom:.5rem;display:flex;align-items:flex-start;padding-left:1.2rem;position:relative}.feature-bullet{color:var(--accent-primary);position:absolute;left:0;font-size:.8rem}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.tech-tag{padding:4px 10px;border-radius:15px;font-size:clamp(.7rem,1vw,.8rem);font-weight:500;color:var(--text-primary);background:#e6f0ff;transition:transform .3s ease,background .3s ease}.tech-tag:hover{background:#d0e0ff;transform:scale(1.05)}.about-cta{margin-top:clamp(1.5rem,3vw,2rem);display:flex;flex-direction:column;align-items:center;gap:clamp(.5rem,1vw,.75rem);text-align:center}.cta-button{display:inline-block;padding:clamp(.5rem,1.2vw,.7rem) clamp(1.2rem,2.5vw,1.5rem);background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));color:var(--background-secondary);border-radius:6px;font-size:clamp(.85rem,1.2vw,.95rem);font-weight:600;text-decoration:none;transition:transform .3s ease,box-shadow .3s ease;position:relative;overflow:hidden;z-index:1}.cta-button:hover{transform:scale(1.05);box-shadow:0 6px 12px #007bff33;animation:pulseShadow 1.5s infinite}@keyframes pulseShadow{0%{box-shadow:0 0 #3b82f666}70%{box-shadow:0 0 20px #3b82f699}to{box-shadow:0 0 #3b82f600}}.cta-button:focus{outline:2px solid var(--accent-primary);outline-offset:2px;background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));color:var(--background-secondary);box-shadow:0 6px 12px #007bff33}.cta-button:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to right,#0056b3,#00876c);opacity:0;transition:opacity .3s ease;z-index:-1}.cta-button:hover:before{opacity:1}.cta-button:focus:before{opacity:0}.cta-subtext{color:var(--text-secondary);font-size:clamp(.75rem,1vw,.85rem);text-align:center}.animate-fade-in{opacity:0;transform:translateY(20px);animation:fadeIn .8s ease-out forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-service-card{opacity:0;transform:translateY(20px) scale(.95);animation:serviceCardFadeIn .6s ease-out forwards}@keyframes serviceCardFadeIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-modal-backdrop{animation:backdropFadeIn .4s ease-out forwards}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.animate-modal-content{animation:modalScaleIn .4s ease-out forwards}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.animate-tech-tag{opacity:0;transform:translateY(10px);animation:techTagFadeIn .5s ease-out forwards}@keyframes techTagFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (min-width: 992px){.about-content{max-width:1200px}.services-grid{grid-template-columns:repeat(3,1fr)}.service-card{min-height:200px;padding:1.8rem 1.2rem}}@media (min-width: 576px){.services-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media (max-width: 768px){.about{padding:clamp(3rem,6vw,4rem) clamp(.3rem,.8vw,.5rem)}.about-header h2{font-size:clamp(1.6rem,3vw,2rem)}.services-header h3{font-size:clamp(1.4rem,2.5vw,1.8rem)}.about-text{padding:clamp(.5rem,1.2vw,.8rem)}.about-text p{font-size:clamp(.8rem,1.1vw,.9rem)}.services-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:clamp(.5rem,1vw,.75rem)}.service-card{min-height:180px;padding:1.5rem 1rem}.service-card h4{font-size:1rem}.service-modal-content{width:95%;max-width:360px;padding:1.5rem}.service-modal-icon .icon-bg{width:40px;height:40px}.service-modal-icon span{font-size:1.5rem}.service-modal-details h3{font-size:clamp(1rem,1.5vw,1.3rem)}.cta-button{padding:clamp(.4rem,1vw,.6rem) clamp(1rem,2vw,1.3rem);font-size:clamp(.8rem,1.1vw,.9rem)}.cta-subtext{font-size:clamp(.7rem,1vw,.8rem)}}@media (max-width: 576px){.about-header h2{font-size:clamp(1.4rem,2.5vw,1.8rem)}.services-header h3{font-size:clamp(1.2rem,2vw,1.6rem)}.about-text{padding:clamp(.4rem,1vw,.6rem)}.services-grid{grid-template-columns:1fr}.service-card{min-height:160px}.service-modal-content{padding:1.5rem;max-width:300px}.service-modal-section li{font-size:.9rem}.tech-tag{font-size:clamp(.65rem,.9vw,.75rem);padding:3px 8px}.cta-button{padding:clamp(.3rem,.8vw,.5rem) clamp(.8rem,1.5vw,1.2rem);font-size:clamp(.75rem,1vw,.85rem)}.cta-subtext{font-size:clamp(.65rem,.9vw,.75rem)}}.project-card{background:var(--background-secondary);border-radius:12px;overflow:hidden;cursor:pointer;box-shadow:0 4px 12px #0000001a;position:relative;height:360px;border:1px solid rgba(var(--accent-primary-rgb),.2)}.project-card:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.image-container{position:relative;height:200px;overflow:hidden;border-bottom:2px solid linear-gradient(to right,var(--accent-primary),var(--accent-secondary));background:linear-gradient(135deg,rgba(var(--accent-primary-rgb),.05),rgba(var(--accent-secondary-rgb),.05))}.project-card__image{width:100%;height:100%;object-fit:cover;border-radius:8px 8px 0 0}.project-card__content{padding:clamp(1rem,1.5vw,1.2rem);background:var(--background-secondary);display:flex;flex-direction:column;justify-content:center;height:160px;border-top:1px solid rgba(0,0,0,.05);position:relative}.project-card__content:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:50px;height:2px;background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));border-radius:1px}.project-card h3{font-size:clamp(1.2rem,1.9vw,1.4rem);font-weight:700;margin-bottom:.5rem;color:var(--text-primary);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-card__brief{font-size:clamp(.95rem,1.3vw,1.05rem);line-height:1.5;margin:0;color:var(--text-secondary);text-align:center;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;white-space:normal}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;display:flex;justify-content:center;align-items:center;z-index:2000;overflow-y:auto;padding:clamp(1rem,2vw,1.5rem)}.modal-content{background:var(--background-secondary);border-radius:12px;box-shadow:0 15px 50px #0000004d;width:90%;max-width:800px;max-height:90vh;overflow-y:auto;position:relative;padding:clamp(1.5rem,2.5vw,2rem)}.modal-close{position:absolute;top:15px;right:15px;background:var(--background-secondary);border:1px solid rgba(0,0,0,.1);width:40px;height:40px;border-radius:50%;color:var(--accent-primary);font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10}.modal-close:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.modal-image-container{height:350px;overflow:hidden;border-radius:8px;margin-bottom:1rem}.modal-image{width:100%;height:100%;object-fit:cover}.modal-details{padding:clamp(1rem,1.8vw,1.5rem)}.modal-details h3{font-size:clamp(1.5rem,2.5vw,1.9rem);color:var(--text-primary);text-align:center;margin:0 0 1rem;font-weight:700}.modal-description{font-size:clamp(1rem,1.3vw,1.15rem);color:var(--text-secondary);line-height:1.7;margin-bottom:1.5rem;text-align:center}.modal-section{margin-bottom:clamp(1.5rem,2vw,2rem)}.modal-section h4{font-size:clamp(1.1rem,1.6vw,1.3rem);color:var(--accent-primary);margin-bottom:clamp(.8rem,1.2vw,1rem);text-align:center;position:relative;padding-bottom:8px}.modal-section h4:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:50px;height:3px;background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));border-radius:2px}.features-list{list-style:none;padding:0;max-width:600px;margin:0 auto}.features-list li{font-size:clamp(.95rem,1.2vw,1.05rem);color:var(--text-secondary);margin-bottom:clamp(.6rem,1vw,.8rem);display:flex;align-items:flex-start;padding-left:1.5rem;position:relative}.feature-bullet{color:var(--accent-primary);position:absolute;left:0;top:.3rem;font-size:1.1rem}.tech-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:600px;margin:0 auto}.tech-tag{padding:clamp(.4rem,.6vw,.5rem) clamp(.8rem,1.2vw,1rem);border-radius:20px;font-size:clamp(.85rem,1.1vw,.95rem);font-weight:500;box-shadow:0 2px 6px #0000001a}.modal-links{display:flex;justify-content:center;gap:clamp(1rem,1.8vw,1.5rem);margin-top:clamp(1.5rem,2.5vw,2rem)}.modal-link{padding:clamp(.6rem,1vw,.8rem) clamp(1.2rem,2vw,1.8rem);border-radius:6px;background:var(--background-secondary);color:var(--accent-primary);text-decoration:none;font-weight:600;font-size:clamp(.95rem,1.2vw,1.05rem);box-shadow:0 2px 10px #0000001a;display:flex;align-items:center;gap:8px;border:1px solid rgba(0,0,0,.1)}.modal-link:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.link-icon{font-size:1.2rem}@media (max-width: 992px){.project-card{height:340px}.image-container{height:180px}.project-card__content{height:160px}}@media (max-width: 768px){.project-card{height:320px}.image-container,.project-card__content{height:160px}.modal-image-container{height:250px}.modal-details{padding:clamp(1rem,1.8vw,1.5rem)}.modal-details h3{font-size:clamp(1.3rem,2.2vw,1.6rem)}.modal-description{font-size:clamp(.95rem,1.2vw,1.05rem)}.features-list li{font-size:clamp(.9rem,1.1vw,1rem)}.modal-links{flex-direction:column;gap:.8rem}.modal-link{justify-content:center}}@media (max-width: 576px){.project-card{height:300px}.image-container{height:140px}.project-card__content{height:160px;padding:clamp(.8rem,1.2vw,1rem)}.project-card h3{font-size:clamp(1rem,1.5vw,1.2rem)}.project-card__brief{font-size:clamp(.85rem,1.1vw,.95rem)}.modal-image-container{height:200px}.modal-details h3{font-size:clamp(1.2rem,1.9vw,1.4rem)}}.projects{padding:var(--section-spacing) clamp(.5rem,1vw,.75rem);background:var(--background-primary);font-family:var(--font-family)}.projects__container{max-width:1200px;width:100%;margin:0 auto;padding:0 clamp(.5rem,1vw,.75rem)}.section-header h2{font-size:clamp(1.8rem,3.5vw,2.3rem);color:var(--text-primary);font-weight:700;margin-bottom:.8rem;position:relative;display:inline-block}.section-header h2:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:60px;height:4px;background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));border-radius:2px}.divider{height:3px;background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));border-radius:2px;width:60px;margin:.8rem auto}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(1.5rem,3vw,2.5rem);margin-bottom:clamp(2rem,4vw,3rem)}.projects__cta{text-align:center}.cta-container{display:inline-flex;flex-direction:column;align-items:center;gap:.5rem}.cta-button{display:inline-block;padding:clamp(.7rem,1.2vw,.9rem) clamp(1.5rem,2.5vw,2rem);border-radius:6px;background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));color:var(--background-secondary)!important;font-weight:600;font-size:clamp(.9rem,1.3vw,1.1rem);text-decoration:none;box-shadow:0 4px 15px #007bff33;transition:all .3s ease;position:relative;z-index:1}.cta-button:hover{color:var(--background-secondary)!important;transform:translateY(-2px);box-shadow:0 6px 20px #007bff4d}.cta-button:focus{color:var(--background-secondary)!important;outline:2px solid var(--accent-primary);outline-offset:2px}.cta-button:visited{color:var(--background-secondary)!important}.cta-subtext{font-size:clamp(.85rem,1.2vw,1rem);color:var(--text-secondary);max-width:300px;margin:.5rem 0 0}@media (max-width: 992px){.projects-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media (max-width: 768px){.projects{padding:clamp(3rem,6vw,4rem) clamp(.3rem,.8vw,.5rem)}.section-header h2{font-size:clamp(1.6rem,3vw,2rem)}.subtitle{font-size:clamp(.85rem,1.2vw,1rem)}.projects-grid{grid-template-columns:1fr;gap:clamp(1.2rem,2.5vw,1.8rem)}.cta-button{padding:clamp(.6rem,1vw,.8rem) clamp(1.2rem,2vw,1.6rem);font-size:clamp(.85rem,1.2vw,1rem)}}@media (max-width: 576px){.section-header h2{font-size:clamp(1.4rem,2.5vw,1.8rem)}.cta-button{padding:clamp(.5rem,.9vw,.7rem) clamp(1rem,1.8vw,1.4rem);font-size:clamp(.8rem,1.1vw,.95rem)}.cta-subtext{font-size:clamp(.8rem,1.1vw,.9rem)}}.skills{display:flex;justify-content:center;padding:clamp(4rem,8vw,8rem) clamp(.5rem,1vw,.75rem);background:var(--background-primary);font-family:var(--font-family)}.skills__container{max-width:1200px;width:100%;margin:0 auto;padding:0 clamp(.5rem,1vw,.75rem)}.section-header{text-align:center;margin-bottom:clamp(2rem,4vw,3rem)}.section-header h2{font-size:clamp(1.8rem,3.5vw,2.3rem);color:var(--text-primary);font-weight:700;margin-bottom:.8rem;position:static}.section-header h2:after{content:none}.divider{height:3px;background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));border-radius:2px;width:60px;margin:0 auto;transition:width .3s ease}.section-header:hover .divider{width:80px}.subtitle{font-size:clamp(.9rem,1.3vw,1.1rem);color:var(--text-secondary);max-width:700px;margin:1rem auto 0;line-height:1.6}.skills__categories{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(1.5rem,3vw,2.5rem)}.skills__category{background:var(--background-secondary);border-radius:12px;padding:clamp(1.5rem,2.5vw,2rem);box-shadow:var(--shadow);transition:var(--transition)}.skills__category:hover{transform:translateY(-5px);box-shadow:0 10px 20px #0000001a}.category-title{font-size:clamp(1.2rem,2vw,1.5rem);color:var(--text-primary);margin-bottom:clamp(1rem,1.8vw,1.5rem);text-align:center;font-weight:600;position:relative}.category-title span{position:relative;z-index:1}.category-title:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:3px;background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));border-radius:2px;opacity:.2;z-index:0}.skills__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:clamp(.8rem,1.5vw,1.2rem)}.skills__item{display:flex;flex-direction:column;align-items:center;background:var(--background-secondary);padding:clamp(.8rem,1.2vw,1rem);border-radius:8px;border:1px solid rgba(var(--skill-color),.2);box-shadow:0 2px 8px #0000000d;transition:var(--transition);opacity:0;transform:translateY(20px);animation:fadeIn .8s ease-out forwards;animation-delay:var(--delay);position:relative}.skills__item.animate{opacity:1;transform:translateY(0)}.skills__item:hover{transform:translateY(-5px);box-shadow:0 8px 15px #0000001a;border-color:rgba(var(--skill-color),.4)}.skills__item:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--skill-color);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.skills__item:hover:before{transform:scaleX(1)}.skills__icon{width:50px;height:50px;margin-bottom:.8rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(var(--skill-color),.1);transition:var(--transition);position:relative}.skills__item:hover .skills__icon{transform:scale(1.1);background:rgba(var(--skill-color),.15);box-shadow:0 0 10px rgba(var(--skill-color),.3)}.skills__icon img{width:60%;height:60%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.skills__icon img[src*=python]{filter:invert(31%) sepia(52%) saturate(1188%) hue-rotate(171deg) brightness(91%) contrast(88%)}.skills__icon img[src*=django]{filter:invert(18%) sepia(48%) saturate(1021%) hue-rotate(117deg) brightness(96%) contrast(95%)}.skills__icon img[src*=react]{filter:invert(76%) sepia(47%) saturate(6258%) hue-rotate(159deg) brightness(103%) contrast(94%)}.skills__icon img[src*=javascript]{filter:invert(83%) sepia(47%) saturate(2917%) hue-rotate(359deg) brightness(102%) contrast(99%)}.skills__icon img[src*=typescript]{filter:invert(41%) sepia(51%) saturate(2836%) hue-rotate(191deg) brightness(95%) contrast(86%)}.skills__icon img[src*=docker]{filter:invert(51%) sepia(88%) saturate(2018%) hue-rotate(175deg) brightness(97%) contrast(91%)}.skills__icon img[src*=postgresql]{filter:invert(34%) sepia(80%) saturate(1065%) hue-rotate(193deg) brightness(92%) contrast(88%)}.skills__icon img[src*=redis]{filter:invert(32%) sepia(79%) saturate(1460%) hue-rotate(342deg) brightness(93%) contrast(88%)}.skills__icon img[src*=linux]{filter:invert(91%) sepia(60%) saturate(7040%) hue-rotate(358deg) brightness(102%) contrast(103%)}.skills__icon img[src*=amazonaws]{filter:invert(14%) sepia(13%) saturate(1838%) hue-rotate(173deg) brightness(94%) contrast(87%)}.skills__icon img[src*=html5]{filter:invert(47%) sepia(47%) saturate(2140%) hue-rotate(335deg) brightness(97%) contrast(93%)}.skills__icon img[src*=css3]{filter:invert(35%) sepia(81%) saturate(1231%) hue-rotate(182deg) brightness(90%) contrast(96%)}.skills__icon img[src*=bootstrap]{filter:invert(35%) sepia(16%) saturate(2870%) hue-rotate(231deg) brightness(90%) contrast(87%)}.skills__icon img[src*=webpack]{filter:invert(78%) sepia(42%) saturate(4947%) hue-rotate(171deg) brightness(106%) contrast(94%)}.skills__icon img[src*=jest]{filter:invert(22%) sepia(63%) saturate(2821%) hue-rotate(342deg) brightness(95%) contrast(92%)}.skills__item:hover .skills__icon img{transform:scale(1.1)}.skills__item span{font-size:clamp(.85rem,1.1vw,.95rem);font-weight:600;color:var(--text-primary);text-align:center;max-width:90%}@media (max-width: 992px){.skills__categories{grid-template-columns:1fr;max-width:800px;margin:0 auto}}@media (max-width: 768px){.skills{padding:clamp(3rem,6vw,4rem) clamp(.3rem,.8vw,.5rem)}.section-header h2{font-size:clamp(1.6rem,3vw,2rem)}.skills__grid{grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:clamp(.6rem,1vw,.8rem)}.skills__item{padding:clamp(.7rem,1vw,.9rem)}.skills__icon{width:45px;height:45px}.category-title{font-size:clamp(1.1rem,1.8vw,1.3rem)}}@media (max-width: 576px){.section-header h2{font-size:clamp(1.4rem,2.5vw,1.8rem)}.skills__grid{grid-template-columns:repeat(3,1fr)}.skills__item{padding:clamp(.6rem,.8vw,.8rem)}.skills__item span{font-size:clamp(.8rem,1vw,.9rem)}.skills__icon{width:40px;height:40px}}.contact{color:var(--text-primary);width:100%;display:flex;justify-content:center;align-items:center;padding:clamp(1.5rem,4vw,2rem) clamp(.5rem,1.5vw,.75rem);position:relative;overflow:hidden;font-family:var(--font-family);background:var(--background-primary)}.contact:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 90% 10%,rgba(var(--accent-primary-rgb),.05) 0%,transparent 20%),radial-gradient(circle at 10% 90%,rgba(var(--accent-primary-rgb),.05) 0%,transparent 20%);pointer-events:none}.contact__content{max-width:1200px;width:100%;z-index:1}.contact__header{text-align:center;margin-bottom:clamp(1.5rem,3vw,2rem)}.contact__header h2{font-size:clamp(2rem,4vw,2.5rem);font-weight:700;color:var(--text-primary);margin-bottom:.8rem}.divider{height:4px;background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));border-radius:2px;width:80px;margin:0 auto;transition:width .3s ease}.contact__header:hover .divider{width:100px}.contact__header p{font-size:clamp(1rem,1.3vw,1.1rem);color:var(--text-secondary);max-width:600px;margin:.5rem auto 0;line-height:1.6}.contact__header h2:after{content:none}.contact__container{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1rem,2vw,1.5rem);margin-bottom:clamp(1.5rem,3vw,2rem)}.contact__info{display:flex;flex-direction:column;gap:1rem}.info-card{background:var(--background-secondary);border-radius:12px;padding:clamp(1rem,1.5vw,1.2rem);display:flex;align-items:flex-start;gap:1rem;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;box-shadow:0 4px 12px #0000001a;position:relative;cursor:pointer;border:1px solid rgba(var(--accent-primary-rgb),.2)}.info-card:hover,.info-card:focus-within{transform:translateY(-4px);box-shadow:0 8px 20px #00000026;border-color:rgba(var(--accent-primary-rgb),.5)}.info-card:focus-within{outline:2px solid var(--accent-primary);outline-offset:2px}.info-icon{width:40px;height:40px;background:rgba(var(--accent-primary-rgb),.1);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s ease,background .3s ease}.info-card:hover .info-icon,.info-card:focus-within .info-icon{transform:scale(1.1);background:rgba(var(--accent-primary-rgb),.2)}.info-icon svg{width:20px;height:20px}.email-icon svg{color:#007bff}.phone-icon svg{color:#25d366}.location-icon svg{color:#6f42c1}.info-details{flex:1}.info-details h3{font-size:clamp(1rem,1.4vw,1.1rem);font-weight:600;margin-bottom:.4rem;color:var(--text-primary)}.info-value{display:flex;align-items:center;gap:.5rem;position:relative}.info-value a,.info-value p{font-size:clamp(.9rem,1.2vw,1rem);color:var(--text-secondary);transition:color .3s ease;text-decoration:none}.info-value a:hover,.info-value a:focus{color:var(--accent-primary);text-decoration:underline}.info-value a:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.copy-btn{background:none;border:none;padding:.3rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;transition:opacity .3s ease,transform .3s ease,background .3s ease;opacity:0;transform:translate(-10px)}.info-card:hover .copy-btn,.info-card:focus-within .copy-btn{opacity:1;transform:translate(0)}.copy-btn:hover,.copy-btn:focus{background:rgba(var(--accent-primary-rgb),.1)}.copy-btn:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.copy-icon{width:16px;height:16px;color:var(--text-secondary)}.copy-feedback{position:absolute;top:-25px;right:0;background:var(--text-primary);color:var(--background-secondary);padding:.3rem .6rem;border-radius:4px;font-size:clamp(.75rem,1vw,.85rem);white-space:nowrap;animation:fadeOut 2s forwards;z-index:10}@keyframes fadeOut{0%{opacity:1}70%{opacity:1}to{opacity:0}}.contact__form-container{background:var(--background-secondary);border-radius:12px;padding:clamp(1rem,2vw,1.5rem);box-shadow:0 4px 12px #0000001a;border:1px solid rgba(var(--accent-primary-rgb),.2);position:relative}.contact__form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:clamp(.9rem,1.2vw,1rem);font-weight:500;color:var(--text-primary)}.contact__form input,.contact__form textarea{padding:.75rem;border:none;border-radius:8px;font-size:clamp(.9rem,1.2vw,1rem);background:#f5f5f5;color:var(--text-primary);transition:background .3s ease,outline .3s ease;font-family:var(--font-family)}.contact__form input::placeholder,.contact__form textarea::placeholder{color:#aaa}.contact__form input:focus,.contact__form textarea:focus{outline:2px solid var(--accent-primary);background:#fff}.contact__form textarea{height:120px;resize:vertical}.submit-btn{background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));color:var(--background-secondary)!important;border:none;padding:clamp(.75rem,1.5vw,1rem) clamp(1.5rem,2.5vw,2rem);border-radius:8px;font-size:clamp(1rem,1.3vw,1.1rem);font-weight:600;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease;display:flex;align-items:center;justify-content:center;gap:8px;position:relative;overflow:hidden;z-index:1}.submit-btn:hover{transform:scale(1.05);color:var(--background-secondary)!important;box-shadow:0 6px 15px rgba(var(--accent-primary-rgb),.3)}.submit-btn:focus{color:var(--background-secondary)!important;outline:2px solid var(--accent-primary);outline-offset:2px}.submit-btn:visited{color:var(--background-secondary)!important}.submit-btn:active{transform:scale(1);color:var(--background-secondary)!important}.submit-btn.submitting{background:linear-gradient(to right,#0056b3,#00876c);cursor:not-allowed;opacity:.8;color:var(--background-secondary)!important}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:var(--background-secondary);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.success-message,.error-message{padding:.75rem;border-radius:8px;display:flex;align-items:center;gap:8px;font-weight:500;margin-top:.75rem;font-size:clamp(.85rem,1.1vw,.95rem)}.success-message{background:#28a74526;color:var(--success-color)}.error-message{background:#e74c3c26;color:var(--error-color)}.error-text{color:var(--error-color);font-size:clamp(.8rem,1vw,.9rem);margin-top:.2rem}.success-message svg,.error-message svg{width:20px;height:20px;flex-shrink:0;color:inherit}.contact__socials{margin-top:clamp(.75rem,1.5vw,1rem);padding:clamp(.5rem,1vw,.75rem)}.contact__socials h3{font-size:clamp(1rem,1.4vw,1.1rem);font-weight:600;margin-bottom:clamp(.5rem,1vw,.75rem);color:var(--text-primary)}.social-icons{display:flex;justify-content:flex-start;gap:clamp(.75rem,1.5vw,1rem)}.social-icons a{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--background-secondary);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease,background .3s ease;box-shadow:0 4px 12px #0000001a;border:1px solid rgba(var(--accent-primary-rgb),.2)}.social-icons a:hover,.social-icons a:focus{transform:translateY(-4px);box-shadow:0 8px 20px #00000026;border-color:rgba(var(--accent-primary-rgb),.5);background:#25d3661a}.social-icons a:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.social-icons svg{width:28px;height:28px;transition:transform .3s ease}.social-icons a:hover svg,.social-icons a:focus svg{transform:scale(1.1)}.whatsapp-icon svg{color:#25d366}.grecaptcha-badge{visibility:hidden}.animate-info-card{opacity:0;transform:translateY(20px) scale(.95);animation:infoCardFadeIn .6s ease-out forwards}@keyframes infoCardFadeIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-form-group{opacity:0;transform:translateY(10px);animation:formGroupFadeIn .5s ease-out forwards}@keyframes formGroupFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-social-icon{opacity:0;transform:translateY(10px);animation:socialIconFadeIn .5s ease-out forwards}@keyframes socialIconFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.contact{padding:clamp(1rem,3vw,1.5rem) clamp(.5rem,1vw,.75rem)}.contact__container{grid-template-columns:1fr;gap:clamp(.75rem,1.5vw,1rem)}.contact__header h2{font-size:clamp(1.8rem,3.5vw,2.2rem)}.contact__header h2:after{content:none}.contact__header p{font-size:clamp(.9rem,1.2vw,1rem)}.info-card{padding:clamp(.75rem,1.2vw,1rem)}.info-icon{width:36px;height:36px}.info-icon svg{width:18px;height:18px}.contact__form-container{padding:clamp(.75rem,1.5vw,1rem)}.social-icons a{width:44px;height:44px}.social-icons svg{width:24px;height:24px}.copy-feedback{top:-20px;font-size:clamp(.7rem,.9vw,.8rem)}}@media (max-width: 576px){.contact__header h2{font-size:clamp(1.6rem,3vw,2rem)}.info-details h3{font-size:clamp(.9rem,1.3vw,1rem)}.info-value a,.info-value p,.form-group label,.contact__form input,.contact__form textarea,.submit-btn,.success-message,.error-message,.error-text{font-size:clamp(.85rem,1.1vw,.95rem)}.contact__form input,.contact__form textarea{padding:.6rem}.submit-btn{padding:clamp(.6rem,1.2vw,.8rem) clamp(1.2rem,2vw,1.5rem)}.contact__socials h3{font-size:clamp(.9rem,1.3vw,1rem)}.social-icons a{width:40px;height:40px}.social-icons svg{width:22px;height:22px}.copy-btn{padding:.2rem}.copy-icon{width:14px;height:14px}}.footer-modern{background:linear-gradient(145deg,#1f2937,#111827);color:#d1d5db;padding:2.5rem 0 2rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;position:relative;overflow:hidden}.footer-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,#3b82f6,transparent)}.footer-container{max-width:1200px;margin:0 auto;padding:0 1rem}.footer-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2rem}@media (min-width: 768px){.footer-grid{grid-template-columns:repeat(3,1fr);gap:3rem}.footer-container{padding:0 2rem}.footer-modern{padding:3rem 0 2.5rem}}@media (min-width: 1024px){.footer-grid{gap:4rem}}.footer-brand-section{text-align:center;position:relative;z-index:10;isolation:isolate}@media (min-width: 768px){.footer-brand-section{text-align:left}}.footer-brand-link{text-decoration:none;color:#fff;transition:color .3s ease;outline:none;border-radius:.375rem;padding:.25rem;margin:-.25rem;position:relative;z-index:10}.footer-brand-link:hover{color:#60a5fa}.footer-brand-link:focus{box-shadow:0 0 0 2px #3b82f6}.footer-logo-wrapper{display:flex;align-items:center;gap:.5rem;justify-content:center;position:relative;z-index:10}@media (min-width: 768px){.footer-logo-wrapper{justify-content:flex-start}}.footer-logo-icon{width:2.25rem;height:2.25rem;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.125rem;font-weight:700;color:#1f2937;transition:transform .3s ease;position:relative;z-index:10}.footer-brand-link:hover .footer-logo-icon{transform:scale(1.1) rotate(12deg)}.footer-logo-text{display:flex;flex-direction:column;position:relative;z-index:10}.footer-logo-text h3{font-size:1.25rem;font-weight:700;letter-spacing:.025em;margin:0;position:relative;z-index:10;background:#1f2937;padding:2px 0}.footer-logo-text p{font-size:.875rem;color:#9ca3af;font-weight:300;margin:0;position:relative;z-index:10;background:#1f2937;padding:2px 0}.footer-tagline{margin-top:1rem;font-size:.875rem;color:#9ca3af;max-width:20rem;line-height:1.5;position:relative;z-index:10}.footer-navigation{text-align:center}@media (min-width: 768px){.footer-navigation{text-align:left}}.footer-section-title{font-size:1.125rem;font-weight:600;color:#e5e7eb;margin-bottom:1.5rem;position:relative;display:inline-block;padding-bottom:8px}.footer-section-title:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:2rem;height:2px;background:#3b82f6;transition:width .3s ease;z-index:1}@media (min-width: 768px){.footer-section-title:after{left:0;transform:none}}.footer-section-title:hover:after{width:3rem}.footer-nav-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.footer-nav-link{color:#9ca3af;font-size:.875rem;text-decoration:none;position:relative;padding:.25rem 0;transition:color .3s ease;outline:none}.footer-nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:#3b82f6;transition:width .3s ease}.footer-nav-link:hover,.footer-nav-link:focus{color:#fff}.footer-nav-link:hover:after,.footer-nav-link:focus:after{width:100%}.footer-nav-link:focus{box-shadow:0 0 0 2px #3b82f6;border-radius:.25rem}.footer-connect{text-align:center}@media (min-width: 768px){.footer-connect{text-align:left}}.footer-social-icons{display:flex;justify-content:center;gap:.75rem;margin-bottom:1rem}@media (min-width: 768px){.footer-social-icons{justify-content:flex-start}}.footer-social-icon{width:2.5rem;height:2.5rem;background:#374151;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#9ca3af;text-decoration:none;transition:all .2s ease;outline:none}.footer-social-icon:hover{background:#4b5563;color:#fff;transform:scale(1.1) rotate(6deg)}.footer-social-icon:focus{box-shadow:0 0 0 2px #3b82f6}.whatsapp-icon{width:1.25rem;height:1.25rem;color:#10b981}.footer-email{color:#9ca3af;font-size:.875rem;text-decoration:none;position:relative;transition:color .3s ease;outline:none;padding:.25rem;border-radius:.25rem}.footer-email:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:#3b82f6;transition:width .3s ease}.footer-email:hover,.footer-email:focus{color:#fff}.footer-email:hover:after,.footer-email:focus:after{width:100%}.footer-email:focus{box-shadow:0 0 0 2px #3b82f6}.footer-bottom{border-top:1px solid #374151;padding-top:1.5rem;text-align:center}.footer-bottom p{font-size:.875rem;color:#6b7280;margin:0}.back-to-top-modern{position:fixed;bottom:1rem;right:1rem;width:3rem;height:3rem;background:#3b82f6;color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #3b82f64d;cursor:pointer;transition:all .3s ease;z-index:1000;animation:bounce 1s infinite;outline:none}.back-to-top-modern:hover{background:#2563eb;transform:scale(1.1);box-shadow:0 6px 20px #3b82f666}.back-to-top-modern:focus{box-shadow:0 0 0 2px #3b82f6,0 0 0 4px #3b82f633}@media (min-width: 768px){.back-to-top-modern{bottom:1.5rem;right:1.5rem}}.animate-fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease-out,transform .6s ease-out}.animate-fade-in.animate{opacity:1;transform:translateY(0);transition-delay:var(--delay, 0ms)}@keyframes bounce{0%,20%,53%,80%,to{transform:translateZ(0)}40%,43%{transform:translate3d(0,-30px,0)}70%{transform:translate3d(0,-15px,0)}90%{transform:translate3d(0,-4px,0)}}@media (prefers-color-scheme: dark){.footer-modern{background:linear-gradient(145deg,#0f172a,#020617)}}@media (prefers-reduced-motion: reduce){.animate-fade-in,.footer-logo-icon,.footer-social-icon,.back-to-top-modern{transition:none;animation:none}.back-to-top-modern{animation:none}}
