.cta-section{background:linear-gradient(135deg,rgba(13,13,26,0.98) 0%,rgba(30,15,80,0.4) 50%,rgba(13,13,26,0.98) 100%);padding:clamp(100px,15vw,140px) clamp(16px,5vw,60px);position:relative;overflow:hidden;} .cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 15% 40%,rgba(123,47,190,0.2) 0%,transparent 50%),radial-gradient(circle at 85% 60%,rgba(200,75,158,0.12) 0%,transparent 50%),radial-gradient(circle at 50% 100%,rgba(123,47,190,0.08) 0%,transparent 40%);pointer-events:none;z-index:0;animation:float 10s ease-in-out infinite;} .cta-section::after{content:'';position:absolute;top:-30%;right:-15%;width:600px;height:600px;background:radial-gradient(circle,rgba(123,47,190,0.12) 0%,transparent 70%);border-radius:50%;filter:blur(100px);pointer-events:none;z-index:0;animation:float 14s ease-in-out infinite reverse;} @keyframes float{0%,100%{transform:translate(0,0);} 50%{transform:translate(20px,20px);}} .cta-section .cta-header{text-align:center;margin:0 auto 56px;max-width:980px;animation:fadeInUp 0.8s ease-out;} .cta-section .cta-container{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:clamp(18px,3vw,32px);align-items:stretch;position:relative;z-index:1;padding:clamp(18px,3vw,34px);border-radius:34px;background:linear-gradient(135deg,rgba(45,27,105,0.4) 0%,rgba(100,47,180,0.14) 52%,rgba(13,13,26,0.7) 100%);border:1px solid rgba(196,181,253,0.2);backdrop-filter:blur(34px);box-shadow:0 26px 90px rgba(123,47,190,0.22),0 0 50px rgba(236,72,153,0.1),inset 0 1px 0 rgba(255,255,255,0.08);} @media (max-width:1024px){.cta-section .cta-container{grid-template-columns:1fr;gap:22px;} .cta-section .cta-header{margin-bottom:36px;}} .cta-section .cta-left{animation:fadeInLeft 0.8s ease-out;display:flex;flex-direction:column;justify-content:flex-start;min-width:0;} .cta-section .cta-title{font-family:'Cormorant Garamond',serif;font-size:clamp(36px,4.4vw,62px);font-weight:500;line-height:1.12;margin-bottom:14px;color:var(--white);letter-spacing:-0.8px;position:relative;z-index:1;text-shadow:0 10px 40px rgba(123,47,190,0.25);} .cta-section .cta-title span{background:linear-gradient(135deg,#c4b5fd 0%,#ec4899 50%,#a78bfa 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:500;display:inline-block;animation:gradientShift 4s ease infinite;} @keyframes gradientShift{0%,100%{background:linear-gradient(135deg,#c4b5fd 0%,#ec4899 50%,#a78bfa 100%);-webkit-background-clip:text;background-clip:text;} 50%{background:linear-gradient(135deg,#a78bfa 0%,#ec4899 50%,#c4b5fd 100%);-webkit-background-clip:text;background-clip:text;}} .cta-section .cta-title::after{content:'';display:block;width:72px;height:3px;background:linear-gradient(90deg,#c4b5fd,#ec4899,#a78bfa);margin:14px auto 0;border-radius:2px;animation:shimmer 2.5s ease infinite;} @keyframes shimmer{0%,100%{opacity:1;} 50%{opacity:0.7;}} .cta-section .cta-subtitle{font-size:17px;color:rgba(255,255,255,0.78);line-height:1.72;margin-bottom:0;max-width:760px;font-weight:500;letter-spacing:0.15px;position:relative;z-index:1;margin-left:auto;margin-right:auto;} .cta-section .contact-info-grid{display:grid;grid-template-columns:1fr;gap:12px;align-items:start;} @media (max-width:1024px){.cta-section .contact-info-grid{grid-template-columns:1fr;}} @media (max-width:768px){.cta-section .contact-info-grid{grid-template-columns:1fr;gap:12px;}} @media (max-width:480px){.cta-section .contact-info-grid{grid-template-columns:1fr;}} .cta-section .contact-card{display:flex;align-items:flex-start;gap:12px;padding:14px 14px;background:linear-gradient(135deg,rgba(196,181,253,0.08) 0%,rgba(236,72,153,0.04) 100%);border:1px solid rgba(196,181,253,0.18);border-radius:18px;transition:transform 0.22s ease,box-shadow 0.22s ease,border-color 0.22s ease,background 0.22s ease;position:relative;overflow:hidden;backdrop-filter:blur(18px);align-self:start;} .cta-section .contact-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(196,181,253,0.2) 0%,transparent 50%,rgba(236,72,153,0.1) 100%);opacity:0;transition:opacity 0.4s ease;pointer-events:none;} .cta-section .contact-card::after{content:'';position:absolute;inset:-1px;background:linear-gradient(135deg,rgba(196,181,253,0.5),transparent);opacity:0;transition:opacity 0.4s ease;border-radius:18px;z-index:-1;pointer-events:none;} .cta-section .contact-card:hover{border-color:rgba(196,181,253,0.36);background:linear-gradient(135deg,rgba(196,181,253,0.12) 0%,rgba(236,72,153,0.06) 100%);box-shadow:0 18px 60px rgba(123,47,190,0.22),0 0 34px rgba(236,72,153,0.12),inset 0 1px 0 rgba(255,255,255,0.08);transform:translateY(-3px);} .cta-section .contact-card:hover::before{opacity:1;} .cta-section .contact-card:hover .contact-icon{transform:translateY(-1px) scale(1.05);} .cta-section .contact-icon{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;flex-shrink:0;margin-top:0;background:linear-gradient(135deg,rgba(196,181,253,0.18) 0%,rgba(236,72,153,0.08) 100%);border:1px solid rgba(196,181,253,0.22);transition:transform 0.25s ease,background 0.25s ease,border-color 0.25s ease;font-size:20px;} .cta-section .contact-details{position:relative;z-index:1;min-width:0;} .cta-section .contact-details h4{font-size:12px;font-weight:700;color:var(--white);margin-bottom:8px;text-transform:uppercase;letter-spacing:1px;background:linear-gradient(135deg,#ffffff 0%,#c4b5fd 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-family:'Syne',sans-serif;} .cta-section .contact-details p{font-size:13px;color:rgba(255,255,255,0.76);line-height:1.55;font-weight:500;margin:0;} .cta-section .contact-details a{display:block;font-size:13px;color:rgba(255,255,255,0.86);text-decoration:none;transition:all 0.3s ease;margin:6px 0;position:relative;font-weight:500;} .cta-section .contact-details a::before{content:'';position:absolute;bottom:-3px;left:0;width:0;height:2px;background:linear-gradient(90deg,#c4b5fd,#ec4899);transition:width 0.3s ease;} .cta-section .contact-details a:hover{color:#c4b5fd;transform:translateX(3px);} .cta-section .contact-details a:hover::before{width:100%;} .cta-section .cta-right{animation:fadeInRight 0.8s ease-out 0.1s both;position:relative;z-index:2;display:flex;flex-direction:column;justify-content:flex-start;min-width:0;} @media (min-width:1025px){.cta-section .cta-left{padding-right:clamp(14px,2vw,22px);} .cta-section .cta-right{padding-left:clamp(14px,2vw,22px);border-left:1px solid rgba(196,181,253,0.16);}} .cta-section .contact-form,.contact-modal .contact-form{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px;background:transparent;padding:0;border-radius:0;border:none;backdrop-filter:none;box-shadow:none;position:relative;z-index:1;width:100%;} @media (max-width:1024px){.cta-section .contact-form,.contact-modal .contact-form{grid-template-columns:1fr;} .cta-section .cta-right{padding-top:22px;border-top:1px solid rgba(196,181,253,0.16);border-left:none;padding-left:0;}} .cta-section .form-group,.contact-modal .form-group{display:flex;flex-direction:column;position:relative;padding:12px 12px 10px;background:linear-gradient(135deg,rgba(255,255,255,0.055) 0%,rgba(255,255,255,0.02) 100%);border:1px solid rgba(196,181,253,0.18);border-radius:18px;box-shadow:inset 0 1px 0 rgba(255,255,255,0.06);transition:transform 0.25s ease,border-color 0.25s ease,box-shadow 0.25s ease,background 0.25s ease;} .cta-section .form-group.full-width,.contact-modal .form-group.full-width{grid-column:1 / -1;} .cta-section .form-group label,.contact-modal .form-group label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:rgba(196,181,253,0.95);margin-bottom:6px;display:block;background:linear-gradient(135deg,#c4b5fd 0%,#ec4899 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-family:'Syne',sans-serif;} @media (max-width:768px){.cta-section .contact-form,.contact-modal .contact-form{grid-template-columns:1fr;padding:0;gap:14px;} .cta-section .form-group.full-width,.contact-modal .form-group.full-width{grid-column:1;} .cta-section .contact-info-grid{grid-template-columns:1fr;gap:12px;} .cta-section .btn-submit,.contact-modal .btn-submit{grid-column:1;} .cta-section .cta-title{font-size:clamp(30px,7vw,44px);}} .cta-section .form-group:has(input:focus),.cta-section .form-group:has(select:focus),.cta-section .form-group:has(textarea:focus),.contact-modal .form-group:has(input:focus),.contact-modal .form-group:has(select:focus),.contact-modal .form-group:has(textarea:focus){border-color:rgba(196,181,253,0.42);background:linear-gradient(135deg,rgba(196,181,253,0.09) 0%,rgba(236,72,153,0.045) 100%);box-shadow:0 18px 60px rgba(123,47,190,0.18),0 0 28px rgba(236,72,153,0.1),inset 0 1px 0 rgba(255,255,255,0.08);transform:translateY(-2px);} .cta-section .contact-form input,.cta-section .contact-form select,.cta-section .contact-form textarea,.contact-modal .contact-form input,.contact-modal .contact-form select,.contact-modal .contact-form textarea{padding:2px 6px 6px;background:transparent;border:none;border-radius:12px;color:var(--white);font-family:'Montserrat',sans-serif;font-size:14px;font-weight:500;line-height:1.4;transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);backdrop-filter:none;letter-spacing:0.2px;position:relative;z-index:1;box-shadow:none;} .cta-section .contact-form input::placeholder,.cta-section .contact-form textarea::placeholder,.contact-modal .contact-form input::placeholder,.contact-modal .contact-form textarea::placeholder{color:rgba(255,255,255,0.5);font-weight:400;} .cta-section .contact-form input:focus,.cta-section .contact-form select:focus,.cta-section .contact-form textarea:focus,.contact-modal .contact-form input:focus,.contact-modal .contact-form select:focus,.contact-modal .contact-form textarea:focus{outline:none;background:transparent;box-shadow:none;transform:none;} .cta-section .contact-form select,.contact-modal .contact-form select{cursor:pointer;color-scheme:dark;appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:40px;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgba(196, 181, 253, 0.7)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:42px;} .cta-section .contact-form select option,.contact-modal .contact-form select option{background:#1a0033;color:var(--white);padding:8px;} .cta-section .contact-form textarea,.contact-modal .contact-form textarea{resize:vertical;min-height:96px;font-family:'Montserrat',sans-serif;} .cta-section .btn-submit,.contact-modal .btn-submit{grid-column:1 / -1;background:linear-gradient(135deg,var(--violet),var(--magenta));border:none;color:white;font-family:'Syne',sans-serif;font-size:12px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:12px 24px;border-radius:18px;cursor:pointer;transition:all 0.3s;box-shadow:0 8px 22px rgba(123,47,190,0.22),0 0 12px rgba(200,75,158,0.14);white-space:nowrap;overflow:hidden;position:relative;width:100%;} .cta-section .btn-submit::before,.contact-modal .btn-submit::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.3),transparent);transition:left 0.6s cubic-bezier(0.34,1.56,0.64,1);pointer-events:none;} .cta-section .btn-submit:hover::before,.contact-modal .btn-submit:hover::before{left:100%;} .cta-section .btn-submit::after,.contact-modal .btn-submit::after{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent,rgba(255,255,255,0.1),transparent);transform:rotate(45deg);transition:opacity 0.3s ease;opacity:0;z-index:-1;} .cta-section .btn-submit:hover::after,.contact-modal .btn-submit:hover::after{opacity:1;left:100%;} .cta-section .btn-submit:hover,.contact-modal .btn-submit:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(123,47,190,0.26),0 0 18px rgba(200,75,158,0.18);letter-spacing:1px;} .cta-section .btn-submit:active,.contact-modal .btn-submit:active{box-shadow:0 6px 16px rgba(123,47,190,0.2),0 0 10px rgba(200,75,158,0.14);transform:scale(0.98) !important;-webkit-transform:scale(0.98) !important;} .cta-section .btn-submit:disabled,.contact-modal .btn-submit:disabled{opacity:0.5;cursor:not-allowed;transform:none;} @media (max-width:768px){.cta-section .contact-form,.contact-modal .contact-form{grid-template-columns:1fr;}} .contact-modal .contact-form{display:grid !important;grid-template-columns:1fr 1fr;gap:10px 12px !important;padding:0;} .contact-modal .form-group{gap:0;padding:8px 11px 7px;border-radius:13px;} .contact-modal .form-group label{font-size:9px;letter-spacing:1px;margin-bottom:2px;} .contact-modal .contact-form input,.contact-modal .contact-form select,.contact-modal .contact-form textarea{box-sizing:border-box;min-height:28px;padding:4px 6px;font-size:13px;line-height:1.3;} .contact-modal .contact-form select{background-position:right 6px center;background-size:18px;padding-right:32px;} .contact-modal .contact-form textarea{resize:none;min-height:72px;max-height:72px;overflow:hidden;} .contact-modal .btn-submit{min-height:42px;padding:10px 24px;border-radius:14px;margin-top:2px;} .contact-modal .quote-wizard-form{display:block !important;} .quote-wizard-progress{display:none !important;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:12px;} .quote-wizard-progress span{display:flex;align-items:center;justify-content:center;min-height:30px;border:1px solid rgba(196,181,253,0.16);border-radius:12px;color:rgba(255,255,255,0.62);font-size:11px;font-weight:800;background:rgba(255,255,255,0.04);} .quote-wizard-progress span.is-active,.quote-wizard-progress span.is-complete{border-color:rgba(236,72,153,0.42);background:linear-gradient(135deg,rgba(123,47,190,0.25),rgba(236,72,153,0.13));color:#ffffff;} .quote-step-counter{width:fit-content;margin:0 0 12px auto;padding:6px 11px;border:1px solid rgba(196,181,253,0.2);border-radius:999px;background:rgba(255,255,255,0.055);color:rgba(255,255,255,0.72);font-family:'Syne',sans-serif;font-size:11px;font-weight:700;line-height:1;letter-spacing:0.6px;text-transform:uppercase;} .quote-step-counter span{color:#ffffff;} .quote-wizard-step{display:grid;grid-template-columns:1fr 1fr;gap:10px 12px;} .quote-wizard-step[hidden]{display:none !important;} .quote-wizard-step .full-width,.quote-choice-group.full-width{grid-column:1 / -1;} .quote-choice-group{margin:0;padding:10px;border:1px solid rgba(196,181,253,0.18);border-radius:13px;background:linear-gradient(135deg,rgba(255,255,255,0.055) 0%,rgba(255,255,255,0.02) 100%);} .quote-choice-group legend{padding:0 4px;color:rgba(196,181,253,0.95);font-family:'Syne',sans-serif;font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;} .quote-option-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:8px;} .quote-option-grid-compact{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));} .quote-option{min-height:40px;display:flex;align-items:center;gap:8px;padding:8px 9px;border:1px solid rgba(196,181,253,0.16);border-radius:11px;background:rgba(8,8,24,0.42);color:rgba(255,255,255,0.78);font-family:'Montserrat',sans-serif;font-size:11px;font-weight:600;line-height:1.3;cursor:pointer;transition:border-color 0.2s ease,background 0.2s ease,transform 0.2s ease;} .quote-option:hover{border-color:rgba(236,72,153,0.42);background:rgba(236,72,153,0.08);transform:translateY(-1px);} .contact-modal .contact-form .quote-option input{width:15px;height:15px;min-height:0;padding:0;border:0;border-radius:0;background:transparent;box-shadow:none;backdrop-filter:none;flex:0 0 auto;accent-color:var(--magenta);} .quote-option:has(input:checked){border-color:rgba(236,72,153,0.72);background:linear-gradient(135deg,rgba(123,47,190,0.2),rgba(236,72,153,0.12));color:#ffffff;} .quote-helper{margin:4px 6px 0;color:rgba(255,255,255,0.56);font-size:11px;line-height:1.45;} .quote-optional{color:rgba(255,255,255,0.52);-webkit-text-fill-color:rgba(255,255,255,0.52);text-transform:lowercase;} .quote-wizard-actions{grid-column:1 / -1;display:grid;grid-template-columns:0.45fr 1fr;gap:10px;} .quote-wizard-actions .quote-next-btn,.quote-wizard-actions .quote-back-btn,.quote-wizard-actions .btn-submit{grid-column:auto;width:100%;} .quote-next-btn,.quote-back-btn{min-height:42px;padding:10px 18px;border-radius:14px;font-family:'Syne',sans-serif;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all 0.25s ease;} .quote-next-btn{grid-column:1 / -1;border:none;color:#ffffff;background:linear-gradient(135deg,var(--violet),var(--magenta));box-shadow:0 0 20px rgba(200,75,158,0.28);} .quote-back-btn{border:1px solid rgba(196,181,253,0.24);color:rgba(255,255,255,0.82);background:rgba(255,255,255,0.05);} .quote-next-btn:hover,.quote-back-btn:hover{transform:translateY(-1px);} .quote-wizard-note{grid-column:1 / -1;margin:0;padding:10px 12px;border:1px solid rgba(34,211,238,0.18);border-radius:12px;background:rgba(34,211,238,0.06);color:rgba(255,255,255,0.78);font-size:12px;font-weight:600;} @media (max-width:768px){.contact-modal .contact-form{grid-template-columns:1fr;gap:8px !important;} .quote-wizard-step{grid-template-columns:1fr;} .quote-wizard-actions{grid-template-columns:minmax(92px,0.42fr) minmax(0,1fr);} .quote-option-grid,.quote-option-grid-compact{grid-template-columns:1fr;} .contact-modal .form-group{padding:7px 10px 6px;} .contact-modal .btn-submit{min-height:38px;padding:8px 18px;}} @media (max-height:660px){.contact-modal .contact-form{gap:7px 9px !important;} .contact-modal .form-group{padding:6px 9px 5px;border-radius:11px;} .contact-modal .form-group label{font-size:8px;margin-bottom:1px;} .contact-modal .contact-form input,.contact-modal .contact-form select,.contact-modal .contact-form textarea{min-height:24px;padding:3px 5px;font-size:11px;line-height:1.2;} .contact-modal .contact-form textarea{min-height:54px;max-height:54px;} .contact-modal .btn-submit{min-height:34px;padding:7px 16px;margin-top:1px;}} @keyframes fadeInLeft{from{opacity:0;transform:translateX(-40px);} to{opacity:1;transform:translateX(0);}} @keyframes fadeInRight{from{opacity:0;transform:translateX(40px);} to{opacity:1;transform:translateX(0);}} .footer{background:linear-gradient(135deg,rgba(13,13,26,0.98) 0%,rgba(25,15,65,0.5) 50%,rgba(13,13,26,0.98) 100%);border-top:2px solid rgba(123,47,190,0.3);color:rgba(255,255,255,0.8);padding:clamp(80px,12vw,100px) clamp(16px,5vw,60px) clamp(40px,8vw,60px);margin-top:clamp(40px,8vw,80px);position:relative;overflow:hidden;} .footer-bg-gradient{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(123,47,190,0.15) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(236,72,153,0.1) 0%,transparent 50%),radial-gradient(circle at 50% 100%,rgba(123,47,190,0.08) 0%,transparent 40%);pointer-events:none;z-index:0;} .footer-glow-1{position:absolute;bottom:10%;left:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(123,47,190,0.08) 0%,transparent 70%);border-radius:50%;filter:blur(80px);pointer-events:none;z-index:0;animation:float 8s ease-in-out infinite;} .footer-glow-2{position:absolute;top:20%;right:-5%;width:350px;height:350px;background:radial-gradient(circle,rgba(236,72,153,0.06) 0%,transparent 70%);border-radius:50%;filter:blur(80px);pointer-events:none;z-index:0;animation:float 10s ease-in-out infinite reverse;} @keyframes float{0%,100%{transform:translate(0,0);} 50%{transform:translate(30px,20px);}} .footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(196,181,253,0.6),transparent);pointer-events:none;z-index:2;} .footer-container{max-width:1400px;margin:0 auto;position:relative;z-index:1;} .footer-top-redesign{display:grid;grid-template-columns:1.8fr 1.2fr 1.2fr 1.2fr;gap:clamp(40px,6vw,60px);margin-bottom:60px;align-items:flex-start;} @media (max-width:1200px){.footer-top-redesign{grid-template-columns:1.5fr 1fr 1fr;gap:50px;}} @media (max-width:992px){.footer-top-redesign{grid-template-columns:1fr 1fr;gap:50px;}} @media (max-width:768px){.footer-top-redesign{grid-template-columns:1fr;gap:40px;}} .footer-section{animation:fadeInUp 0.8s ease-out backwards;position:relative;} .footer-brand{animation-delay:0.1s;padding-right:20px;} .footer-links-section{animation-delay:0.2s;} .footer-contact-section{animation-delay:0.3s;} .footer-social-section{animation-delay:0.4s;} .footer-brand .footer-logo-wrapper{position:relative;margin-bottom:24px;} .footer-brand .footer-logo{position:relative;z-index:1;} .footer-brand .footer-logo h3{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:300;background:linear-gradient(135deg,#a78bfa 0%,var(--magenta) 50%,#ec4899 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:0 0 2px 0;letter-spacing:-0.5px;font-weight:400;} .footer-brand .logo-accent{width:60px;height:4px;background:linear-gradient(90deg,var(--magenta) 0%,#a78bfa 50%,transparent 100%);border-radius:2px;margin-top:12px;} .footer-brand .footer-tagline{font-size:13px;color:rgba(255,255,255,0.75);line-height:1.8;margin:0;max-width:100%;font-weight:300;} .footer-links-section .footer-section-title,.footer-contact-section .footer-section-title{font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;background:linear-gradient(135deg,#c4b5fd 0%,var(--magenta) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:0 0 22px 0;position:relative;display:inline-block;} .footer-links-section .footer-section-title::after,.footer-contact-section .footer-section-title::after{content:'';position:absolute;bottom:-10px;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--magenta) 0%,transparent 100%);border-radius:1px;} .footer-social-section .footer-section-title{font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;background:linear-gradient(135deg,#c4b5fd 0%,var(--magenta) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:0 0 22px 0;position:relative;display:inline-block;} .footer-social-section .footer-section-title::after{content:'';position:absolute;bottom:-10px;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--magenta) 0%,transparent 100%);border-radius:1px;} .footer-address,.footer-contact{font-size:13px;color:rgba(255,255,255,0.75);line-height:1.9;margin:0 0 14px 0;font-weight:300;} .footer-contact:last-of-type{margin-bottom:0;} .address-icon,.contact-icon{margin-right:10px;font-size:16px;display:inline-block;min-width:20px;text-align:center;color:var(--magenta);} .contact-items{display:flex;flex-direction:column;gap:20px;} .contact-item{display:flex;gap:14px;align-items:flex-start;padding:12px;background:linear-gradient(135deg,rgba(123,47,190,0.08) 0%,rgba(123,47,190,0.03) 100%);border:1px solid rgba(196,181,253,0.15);border-radius:12px;transition:all 0.3s ease;} .contact-item:hover{background:linear-gradient(135deg,rgba(123,47,190,0.12) 0%,rgba(236,72,153,0.06) 100%);border-color:rgba(196,181,253,0.3);transform:translateX(4px);} .contact-item-icon{font-size:20px;min-width:24px;display:flex;align-items:center;justify-content:center;color:var(--magenta);flex-shrink:0;} .contact-item-content{flex:1;min-width:0;} .contact-item-label{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(196,181,253,0.8);margin:0 0 4px 0;} .contact-item-text{font-size:13px;color:rgba(255,255,255,0.8);margin:0;font-weight:300;line-height:1.5;word-break:break-word;} .contact-item-link{color:rgba(196,181,253,0.9);text-decoration:none;transition:all 0.3s ease;position:relative;display:inline-block;font-size:13px;font-weight:500;word-break:break-word;} .contact-item-link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--magenta);transition:width 0.3s ease;} .contact-item-link:hover{color:var(--magenta);} .contact-item-link:hover::after{width:100%;} .footer-contact a{color:rgba(196,181,253,0.9);text-decoration:none;transition:all 0.3s ease;position:relative;display:inline;font-weight:500;} .footer-contact a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--magenta);transition:width 0.3s ease;} .footer-contact a:hover{color:var(--magenta);} .footer-contact a:hover::after{width:100%;} .footer-social-section{display:flex;flex-direction:column;} .social-links-footer{list-style:none;padding:0;margin:0 0 20px 0;display:flex;gap:clamp(12px,2.5vw,16px);flex-wrap:wrap;align-items:center;} .social-link-footer{display:inline-flex;align-items:center;justify-content:center;width:clamp(44px,6vw,52px);height:clamp(44px,6vw,52px);background:linear-gradient(135deg,rgba(123,47,190,0.2) 0%,rgba(123,47,190,0.08) 100%);border:1.5px solid rgba(196,181,253,0.4);border-radius:50%;color:rgba(196,181,253,0.9);font-size:clamp(18px,3vw,24px);text-decoration:none;transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);position:relative;overflow:hidden;} .social-link-footer::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(236,72,153,0.3) 0%,transparent 50%);border-radius:50%;opacity:0;transition:opacity 0.4s ease;z-index:-1;} .social-link-footer:hover{background:linear-gradient(135deg,rgba(236,72,153,0.4) 0%,rgba(123,47,190,0.25) 100%);border-color:rgba(236,72,153,0.7);color:white;transform:translateY(-5px) scale(1.1);box-shadow:0 15px 45px rgba(200,75,158,0.35),0 0 30px rgba(123,47,190,0.25),inset 0 1px 0 rgba(255,255,255,0.1);} .footer-social-section .footer-cta{font-size:11px;color:rgba(196,181,253,0.8);letter-spacing:1.2px;text-transform:uppercase;font-weight:600;margin:0;display:inline-block;padding:6px 12px;background:linear-gradient(135deg,rgba(123,47,190,0.15) 0%,rgba(123,47,190,0.08) 100%);border:1px solid rgba(196,181,253,0.25);border-radius:16px;transition:all 0.3s ease;} .footer-title{font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;background:linear-gradient(135deg,var(--white) 0%,#a78bfa 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:16px;} .footer-column{animation:fadeInUp 0.8s ease-out;} .footer-links{list-style:none;display:flex;flex-direction:column;gap:14px;padding:0;margin:0;} .footer-links li{list-style:none;} .footer-links a{color:rgba(255,255,255,0.75);text-decoration:none;font-size:14px;transition:all 0.3s ease;position:relative;display:inline-block;font-weight:300;} .footer-links a::before{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--magenta),#a78bfa);transition:width 0.3s ease;border-radius:1px;} .footer-links a:hover{color:rgba(196,181,253,1);letter-spacing:0.3px;} .footer-links a:hover::before{width:100%;} .footer-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(196,181,253,0.3),transparent);margin:50px 0 40px 0;position:relative;} .footer-divider::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(123,47,190,0.1),transparent);filter:blur(1px);} .footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;font-size:12px;color:rgba(255,255,255,0.5);animation:fadeInUp 0.8s ease-out 0.4s backwards;} @media (max-width:768px){.footer-bottom{flex-direction:column;text-align:center;}} .footer-left,.footer-right{display:flex;gap:4px;align-items:center;} .footer-left p,.footer-right p{margin:0;font-weight:300;} .footer-link-small{color:rgba(255,255,255,0.65);text-decoration:none;transition:all 0.3s ease;position:relative;font-weight:500;} .footer-link-small::after{content:'';position:absolute;bottom:-1px;left:0;width:0;height:1px;background:var(--magenta);transition:width 0.3s ease;} .footer-link-small:hover{color:var(--magenta);} .footer-link-small:hover::after{width:100%;} .heart{display:inline-block;animation:heartbeat 1.5s ease-in-out infinite;margin:0 4px;} @keyframes heartbeat{0%,100%{transform:scale(1);} 25%{transform:scale(1.2);} 50%{transform:scale(1);}} @keyframes fadeInUp{from{opacity:0;transform:translateY(20px);} to{opacity:1;transform:translateY(0);}} @keyframes fadeInLeft{from{opacity:0;transform:translateX(-30px);} to{opacity:1;transform:translateX(0);}} @keyframes fadeInRight{from{opacity:0;transform:translateX(30px);} to{opacity:1;transform:translateX(0);}} .footer{background:linear-gradient(180deg,rgba(7,8,20,0.98) 0%,rgba(17,11,38,0.98) 54%,rgba(7,8,20,1) 100%);border-top:1px solid rgba(196,181,253,0.22);padding-top:clamp(54px,8vw,82px);} .footer-container{max-width:1320px;} .footer-feature-bar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;margin-bottom:clamp(34px,5vw,56px);overflow:hidden;border:1px solid rgba(196,181,253,0.16);border-radius:18px;background:rgba(196,181,253,0.12);box-shadow:0 24px 70px rgba(0,0,0,0.2);} .footer-feature{display:flex;align-items:center;gap:12px;min-height:68px;padding:18px clamp(16px,3vw,24px);background:linear-gradient(135deg,rgba(255,255,255,0.07),rgba(255,255,255,0.025));color:rgba(255,255,255,0.88);font-size:13px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;} .footer-feature i{display:grid;place-items:center;width:36px;height:36px;flex:0 0 36px;border-radius:12px;color:#ffffff;background:linear-gradient(135deg,rgba(236,72,153,0.8),rgba(123,47,190,0.78));box-shadow:0 12px 28px rgba(123,47,190,0.28);} .footer-section,.footer-bottom{animation:none;} .footer-top-redesign{grid-template-columns:minmax(240px,1.25fr) minmax(320px,1.55fr) minmax(160px,0.75fr) minmax(260px,1.05fr);gap:clamp(24px,3.2vw,44px);margin-bottom:46px;} .footer-section-title,.footer-links-section .footer-section-title,.footer-contact-section .footer-section-title{color:#ffffff;background:none;-webkit-text-fill-color:currentColor;letter-spacing:1.8px;margin-bottom:24px;} .footer-section-title::after,.footer-links-section .footer-section-title::after,.footer-contact-section .footer-section-title::after{width:42px;background:linear-gradient(90deg,#ec4899,rgba(167,139,250,0));} .footer-brand .footer-logo h3{font-family:'Syne',sans-serif;font-size:clamp(24px,2.2vw,34px);font-weight:800;line-height:1.08;background:linear-gradient(135deg,#ffffff 0%,#c4b5fd 48%,#ec4899 100%);-webkit-background-clip:text;background-clip:text;} .footer-brand .logo-accent{width:76px;height:3px;margin-top:14px;} .footer-brand .footer-tagline{max-width:330px;color:rgba(255,255,255,0.72);font-size:14px;line-height:1.75;} .footer-primary-link{display:inline-flex;align-items:center;gap:10px;margin-top:24px;padding:12px 16px;border:1px solid rgba(196,181,253,0.26);border-radius:14px;color:#ffffff;background:linear-gradient(135deg,rgba(236,72,153,0.22),rgba(123,47,190,0.18));font-size:12px;font-weight:800;letter-spacing:1px;text-decoration:none;text-transform:uppercase;transition:transform 0.25s ease,border-color 0.25s ease,box-shadow 0.25s ease;} .footer-primary-link:hover{border-color:rgba(236,72,153,0.65);box-shadow:0 16px 44px rgba(123,47,190,0.24);transform:translateY(-2px);} .footer-video-services-section{padding:0 clamp(18px,2.2vw,28px);border-left:1px solid rgba(196,181,253,0.13);border-right:1px solid rgba(196,181,253,0.13);} .footer-service-links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px 18px;} .footer-links a{color:rgba(255,255,255,0.72);font-size:13px;font-weight:500;line-height:1.35;} .footer-service-links a{padding-left:16px;} .footer-service-links a::after{content:'';position:absolute;top:0.55em;left:0;width:6px;height:6px;border-radius:50%;background:rgba(236,72,153,0.9);box-shadow:0 0 14px rgba(236,72,153,0.52);} .footer-links a:hover{color:#ffffff;} .contact-items{gap:12px;} .contact-item{border-color:rgba(196,181,253,0.12);border-radius:14px;background:rgba(255,255,255,0.045);} .contact-item-icon{width:34px;height:34px;min-width:34px;border-radius:11px;color:#ffffff;background:rgba(196,181,253,0.12);font-size:14px;} .contact-item-text,.contact-item-link{font-size:12px;} .footer-divider{margin:36px 0 28px;} .footer-bottom{align-items:flex-start;gap:14px 24px;} .footer-right{flex-direction:column;align-items:flex-end;gap:10px;} .footer-right .social-links-footer{margin:0;gap:8px;justify-content:flex-end;} .footer-right .social-link-footer{width:30px;height:30px;border-radius:9px;font-size:13px;border-width:1px;color:rgba(255,255,255,0.78);background:rgba(255,255,255,0.055);} .footer-right .social-link-footer:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(123,47,190,0.22);} .footer-left p,.footer-right p{line-height:1.7;} @media (max-width:1240px){.footer-top-redesign{grid-template-columns:1.2fr 1.5fr 0.95fr;} .footer-video-services-section{border-right:none;}} @media (max-width:900px){.footer-feature-bar{grid-template-columns:1fr;} .footer-top-redesign{grid-template-columns:1fr 1fr;} .footer-video-services-section{padding-left:0;border-left:none;}} @media (max-width:640px){.footer{padding-bottom:34px;} .footer-feature{min-height:62px;} .footer-top-redesign,.footer-service-links{grid-template-columns:1fr;} .footer-brand .footer-tagline,.footer-social-section .footer-cta{max-width:none;} .footer-bottom{text-align:left;align-items:flex-start;} .footer-right{align-items:flex-start;} .footer-right .social-links-footer{justify-content:flex-start;}} .floating-whatsapp{position:fixed;left:22px;bottom:22px;z-index:9999;display:inline-flex;align-items:center;justify-content:center;gap:9px;min-width:58px;height:58px;padding:0 18px;border-radius:999px;color:#ffffff;background:linear-gradient(135deg,#25d366 0%,#128c7e 100%);border:1px solid rgba(255,255,255,0.24);box-shadow:0 18px 40px rgba(18,140,126,0.34),0 8px 18px rgba(0,0,0,0.22);text-decoration:none;font-family:'Montserrat',sans-serif;font-size:13px;font-weight:800;line-height:1;letter-spacing:0;isolation:isolate;transition:transform 0.25s ease,box-shadow 0.25s ease,filter 0.25s ease;} .floating-whatsapp::before{content:"";position:absolute;inset:5px;z-index:-1;border-radius:inherit;background:rgba(255,255,255,0.14);opacity:0;transition:opacity 0.25s ease;} .floating-whatsapp i{font-size:28px;line-height:1;} .floating-whatsapp__label{max-width:92px;overflow:hidden;white-space:nowrap;} .floating-whatsapp__pulse{position:absolute;inset:-8px;z-index:-2;border-radius:inherit;border:1px solid rgba(37,211,102,0.5);animation:whatsappPulse 1.9s ease-out infinite;} .floating-whatsapp:hover,.floating-whatsapp:focus-visible{color:#ffffff;transform:translateY(-4px);filter:saturate(1.08);box-shadow:0 22px 48px rgba(18,140,126,0.44),0 10px 24px rgba(0,0,0,0.26);} .floating-whatsapp:hover::before,.floating-whatsapp:focus-visible::before{opacity:1;} .floating-whatsapp:focus-visible{outline:3px solid rgba(255,255,255,0.7);outline-offset:4px;} @keyframes whatsappPulse{0%{opacity:0.85;transform:scale(0.92);} 70%,100%{opacity:0;transform:scale(1.22);}} @media (prefers-reduced-motion:reduce){.floating-whatsapp,.floating-whatsapp::before,.floating-whatsapp__pulse{animation:none;transition:none;}} @media (max-width:640px){.floating-whatsapp{left:16px;bottom:16px;width:56px;min-width:56px;height:56px;padding:0;border-radius:18px;} .floating-whatsapp i{font-size:27px;} .floating-whatsapp__label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}} .contact-modal.is-open .contact-modal-dialog{max-height:calc(100dvh - 24px) !important;overflow-y:auto !important;overflow-x:hidden !important;} .contact-modal.is-open .quote-wizard-form{display:block !important;max-height:none !important;overflow:visible !important;} .contact-modal.is-open .quote-wizard-step.is-active{display:grid !important;grid-template-columns:1fr 1fr;gap:10px 12px;visibility:visible !important;opacity:1 !important;} .contact-modal.is-open .quote-wizard-step[hidden]{display:none !important;} .contact-modal.is-open .quote-choice-group,.contact-modal.is-open .quote-wizard-step .full-width{grid-column:1 / -1;} @media (max-width:768px){.contact-modal.is-open .quote-wizard-step.is-active{grid-template-columns:1fr;}} @media (min-width:900px){.contact-modal.is-open .contact-modal-dialog{width:min(920px,calc(100vw - 56px)) !important;padding:0 !important;border-radius:20px;background:linear-gradient(135deg,rgba(255,255,255,0.09),transparent 30%),linear-gradient(180deg,rgba(15,15,32,0.98),rgba(8,8,20,0.98));overflow-y:auto !important;overflow-x:hidden !important;scrollbar-gutter:stable;} .contact-modal-close{top:18px;right:18px;z-index:4;} .quote-modal-header{padding:28px 34px 20px;border-bottom:1px solid rgba(196,181,253,0.14);background:radial-gradient(circle at 16% 16%,rgba(236,72,153,0.16),transparent 34%),linear-gradient(135deg,rgba(123,47,190,0.16),rgba(255,255,255,0.025));} .quote-modal-kicker{margin:0 52px 8px 0;color:rgba(236,72,153,0.95);font-family:'Montserrat',sans-serif;font-size:11px;font-weight:800;letter-spacing:1.8px;line-height:1;text-transform:uppercase;} .quote-modal-header .contact-modal-title{margin:0 58px 8px 0;font-size:31px;line-height:1.08;} .quote-modal-header .contact-modal-subtitle{max-width:690px;margin:0;color:rgba(255,255,255,0.68);font-size:13px;line-height:1.6;} .contact-modal.is-open .quote-wizard-form{padding:24px 34px 32px !important;background:transparent;} .quote-wizard-progress{display:none !important;} .quote-wizard-progress span{min-height:8px;border-radius:999px;font-size:0;border-color:rgba(196,181,253,0.12);background:rgba(255,255,255,0.065);} .quote-wizard-progress span.is-active,.quote-wizard-progress span.is-complete{background:linear-gradient(90deg,rgba(123,47,190,0.95),rgba(236,72,153,0.92));box-shadow:0 0 22px rgba(236,72,153,0.22);} .contact-modal.is-open .quote-wizard-step.is-active{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px;align-items:stretch;} .contact-modal .form-group,.quote-choice-group{border-radius:12px;background:rgba(255,255,255,0.055);border-color:rgba(196,181,253,0.14);box-shadow:none;} .contact-modal .form-group{padding:13px 14px 12px;} .quote-choice-group{padding:16px;} .contact-modal .form-group label,.quote-choice-group legend{font-size:10px;letter-spacing:1.1px;} .contact-modal .contact-form input,.contact-modal .contact-form textarea{font-size:14px;} .quote-option-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;} .quote-option-grid-compact{grid-template-columns:repeat(5,minmax(0,1fr));} .quote-option{min-height:46px;padding:10px 11px;border-radius:10px;font-size:12px;line-height:1.25;} .quote-wizard-actions{grid-template-columns:160px 1fr;gap:12px;margin-top:2px;} .quote-next-btn,.quote-back-btn,.contact-modal .btn-submit{min-height:46px;border-radius:12px;} .quote-helper,.quote-wizard-note{font-size:12px;}} .contact-modal.is-open .contact-modal-dialog::-webkit-scrollbar{width:8px;} .contact-modal.is-open .contact-modal-dialog::-webkit-scrollbar-track{background:rgba(255,255,255,0.04);} .contact-modal.is-open .contact-modal-dialog::-webkit-scrollbar-thumb{background:rgba(196,181,253,0.32);border-radius:999px;} .contact-modal.is-open .contact-modal-dialog::-webkit-scrollbar-thumb:hover{background:rgba(236,72,153,0.42);} .contact-modal .quote-wizard-step[data-quote-step="0"].is-active{grid-template-columns:1fr !important;} .contact-modal .quote-wizard-step[data-quote-step="0"] .form-group{padding:12px 14px;border-radius:12px;background:rgba(255,255,255,0.045);} .contact-modal .quote-wizard-step[data-quote-step="0"] .form-group label{margin-bottom:7px;} .contact-modal .quote-wizard-step[data-quote-step="0"] input{width:100%;min-height:42px;padding:10px 12px;border:1px solid rgba(196,181,253,0.16);border-radius:10px;background:rgba(8,8,24,0.36);} .contact-modal .quote-wizard-step[data-quote-step="0"] input:focus{border-color:rgba(236,72,153,0.5);background:rgba(8,8,24,0.5);}