@font-face {
  font-family: 'GeometrySoftPro-BoldN';
  src: url(../fonts/GeometrySoftPro-BoldN.woff2);
}
@font-face {
  font-family: 'HelveticaNeueRegular';
  src: url(../fonts/HelveticaNeue-Medium.woff2);
}
:root {
  --principal: #0033B5;
  --secundario: #FF28CE;
  --terciario: #00DFC9;

  --hover: #0054ff;
  --blanco: #ffffff;
  --texto: #3d3d3d;
  --gray: #00DFC9;

  --fondo: #d1eaff;

  /* --card-color: #f5f5f5; */
  /* --card-color: #06065d06; */
  /* --card-color: rgb(220, 221, 221); */

  --card-color: #f9f9fb;
  --border-gray: #ededed;
  --titulo-size: 1.8rem;
  --border-radius: 1rem;
  --padd-top: 6rem;
  --padd-bottom: 6rem;

  --title: 'GeometrySoftPro-BoldN';
  --text: 'HelveticaNeueRegular';

  --size-heading-1: 3rem;
  --size-heading-2: 2rem;
  --size-heading-2: 2rem;
  --size-text: 16px;
  --size-small: .875rem;
}
* {
  font-family: var(--text), sans-serif;
  scroll-behavior: smooth;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html.sr .load-hidden {
  visibility: hidden;
}
body {
  font-size: 16px;
  color: var(--texto);
  /* background: #f5f5f5; */
}
.bodyPag.scrollnone {
  overflow: hidden;
}
.pl-0{
  padding-left: 0;
}
.pr-1{
  padding-right: 1rem;
}
.pt-0{
  padding-top: 0;
}
.mb-1{
  margin-bottom: 1rem;
}
.text-danger{
  color: red;
}
a {
  text-decoration: none;
}
hr {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.btn-principal{
  display: block;
  width: fit-content;
  border-radius: var(--border-radius);
  background: var(--principal);
  border: 1px solid transparent;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.02rem;
  color: var(--blanco);
  padding: .75rem 2rem;
  transition: all .3s;
}
.btn-principal:hover{
  border: 1px solid var(--hover);
  background: var(--hover);
}
.btn-principal.ml-auto{
  margin-left: auto;
}

/* Outline */
.btn-outline{
  display: block;
  width: fit-content;
  border-radius: var(--border-radius);
  background: transparent;
  border: 1px solid var(--principal);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.02rem;
  color: var(--principal);
  padding: .75rem 2rem;
  transition: all .3s;
}
.btn-outline:hover{
  border: 1px solid var(--hover);
  background: var(--hover);
  color: var(--blanco);
}
.btn-outline.ml-auto{
  margin-left: auto;
}
/* Fin Outline */

.btn-link{
  display: inline-block;
  color: var(--principal);
  margin-top: 1rem;
}

.lozad-fade {
  animation-name: fade-lozad;
  animation-duration: 2s;
}

@keyframes fade-lozad {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.container{
	/* max-width: 1540px; */
  /* max-width: calc(100% - 128px); */
  /* max-width: 1400px; */
  position: relative;
}
.container-fluid{
  width: calc(100% - 50px);
  margin: 0 auto;
}
.breadcrumb{
  margin-bottom: 0;
  padding-left: 0;
}


/* Header */

.header {
  width: 100%;
	position: fixed;
  top: 1rem;
  left: 50%;
  transform: translateX(-50%);
  transition: all .4s;
  z-index: 99;
}
.header.top-position{
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.header .container{
  position: unset;
}
.link-logo{
  display: inline-block;
  width: auto;
  height: auto;
}
.img-logo{
  height: 55px;
	width: auto;
  object-fit: contain;
  position: relative;
  top: -2px;
}

.nav-header {
	width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 1rem;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  column-gap: 1rem;
  background: #ffffffb3;
  -webkit-backdrop-filter: blur(15px);
  backdrop-filter: blur(15px);
  border-radius: var(--border-radius);
  border: 1px solid var(--blanco);
}
.btn-menu{
  background: transparent;
  padding: 0;
  margin: 0;
  border: 0;
  width: 44px;
  height: 44px;
  display: none;
  align-items: center;
  justify-content: center;
}
.btn-menu .img-close{
  display: none;
}
.btn-menu.open .img-menu{
  display: none;
}
.btn-menu.open .img-close{
  display: block;
}
.list-nav-header{
  display: flex;
  align-items: center;
	justify-content: flex-end;
  column-gap: 2rem;
  list-style: none;
  padding-left: 0;
  margin-bottom: 0;
}
.link-list-header{
  color: var(--texto);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.04rem;
  line-height: 1;
  position: relative;
  display: flex;
  align-items: center;
  column-gap: .5rem;
  transition: all .3s;
}
.link-list-header::after{
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 0;
  height: 1px;
  background: var(--principal);
  transition: all .3s;
}

.link-list-header:hover::after{
  width: 100%;
  transition: all .3s;
}
.link-list-header:hover{
  color: var(--principal);
  transition: all .3s;
}
.list-nav-header li .link-list-header.active{
  color: var(--principal);
}
.list-nav-header li .link-list-header.active::after{
  width: 100%;
  transition: all .3s;
}

/* Fin Header */

/* Banner Principal */
.section-hero{
  height: 110vh;
  padding-top: 12rem;
  background: var(--fondo);
  /* background: linear-gradient(45deg, var(--terciario) 0%, var(--principal) 100%); */
  border-bottom-left-radius: var(--border-radius);
  border-bottom-right-radius: var(--border-radius);
  position: relative;
  overflow: hidden;
}
/* 
.section-hero::before{
  content: '';
  position: absolute;
  left: -8rem;
  bottom: -34rem;
  width: 800px;
  height: 100%;
  background: url(../images/forma-1.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  animation: scaleIn 1.5s ease-out forwards 0.5s;
  opacity: 0;
  transform-origin: left;
  z-index: 1;
} */
.section-hero::after{
  content: '';
  position: absolute;
  left: 69%;
  top: -24rem;
  width: 800px;
  height: 100%;
  background: url(../images/iso-2.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  opacity: 0;
  transform-origin: right;
  animation: scaleIn 1.5s ease-out forwards 0.5s;
}
.title-hero{
  font-size: 5rem;
  font-family: var(--title);
  letter-spacing: 0.05rem;
  line-height: 1.1;
  color: var(--principal);
  text-align: left;
  text-align: center;
  text-wrap: balance;
  width: 70%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1rem;
  position: relative;
  z-index: 1;
}
.title-hero span{
  color: var(--secundario);
  font-family: var(--title);
}
.text-hero{
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: 0.05rem;
  line-height: 1.4;
  color: var(--texto);
  text-align: center;
  /* text-wrap: balance; */
  width: 51%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 4rem;
}
.link-enlace{
  display: block;
  width: fit-content;
  font-size: .8rem;
  color: var(--principal);
  background: rgba(140, 128, 101, .2);
  padding: .5rem 1rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1.4rem;
  border-radius: 1.6rem;
  transition: all .3s;
}
.link-enlace:hover{
  color: var(--principal);
}
.img-hero-principal{
  position: relative;
  width: 100%;
  height: 100%;
  object-fit: contain;
  z-index: 3;
  opacity: 0;
  animation: slideTransform 1.5s ease-out forwards 0.5s;
}
.grid-hero-images{
  padding-top: 2rem;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100%;
}
.card-hero-img{
  will-change: transform;
  transition: all .3s;
}

.card-hero-img-1{
  position: absolute;
  /* left: -4%; */
  left: clamp(-4%, -4vw, 0%);
  top: 96px;
  z-index: 2;
}
.wrapper-hero-images-1{
  max-width: 250px;
  aspect-ratio: 250/296;
  perspective: 800px;
  transform: rotateX(15deg) rotateY(15deg) rotateZ(-2deg);
  border-radius: var(--border-radius);
  overflow: hidden;
}
.card-hero-img-2{
  position: absolute;
  left: 13%;
  top: 26px;
  z-index: 2;
}
.wrapper-hero-images-2{
  max-width: 340px;
  aspect-ratio: 340/380;
  perspective: 800px;
  border-radius: var(--border-radius);
  transform: rotateX(8deg) rotateY(-15deg) rotateZ(-2deg);
  overflow: hidden;
}

.card-hero-img-3{
  width: fit-content;
  margin-top: -2%;
  margin-left: auto;
  margin-right: auto;
}
.wrapper-hero-images-3{
  max-width: 412px;
  aspect-ratio: 412/480;
  margin-left: auto;
  margin-right: auto;
  border-radius: var(--border-radius);
  overflow: hidden;
}

.card-hero-img-4{
  position: absolute;
  right: 15%;
  top: 26px;
}
.wrapper-hero-images-4{
  max-width: 313px;
  aspect-ratio: 313/380;
  perspective: 800px;
  border-radius: var(--border-radius);
  transform: rotateX(10deg) rotateY(15deg) rotateZ(3deg);
  overflow: hidden;
  z-index: 1;
}

.card-hero-img-5{
  position: absolute;
  /* right: -4%; */
  right: clamp(-4%, -4vw, 0%);
  top: 96px;
}
.wrapper-hero-images-5{
  max-width: 250px;
  aspect-ratio: 250/296;
  perspective: 800px;
  border-radius: var(--border-radius);
  transform: rotateX(-4deg) rotateY(5deg) rotateZ(-5deg);
  overflow: hidden;
  z-index: 1;
}
.img-forma{
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--border-radius);
  opacity: 0;
  animation: slideTransform 1.5s ease-out forwards 0.5s;
}

@keyframes slideTransform {
  from {
      transform: translateY(100px);
      opacity: 0;
  }
  to {
    transform: translateY(0);
      opacity: 1;
  }
}

@keyframes scaleIn {
  from {
      transform: scale(0);
      opacity: 0;
  }
  to {
      transform: scale(1);
      opacity: 1;
  }
}
/* Fin Seccion Banner */

/* Seccion Clientes */
.section-clientes{
  padding-top: 6rem;
  padding-bottom: 7rem;
  padding-left: 1rem;
  padding-right: 1rem;
  background: var(--blanco);
}
.grid-clientes{
  display: grid;
  grid-template-columns: 100%;
  gap: 2rem;
  align-items: center;
}
.title-clientes{
  font-size: var(--size-heading-1);
  font-family: var(--title);
  color: var(--principal);
  line-height: 1.1;
  text-align: center;
  width: 50%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1rem;
}
.text-clientes{
  font-size: 1.125rem;
  color: var(--texto);
  line-height: 1.5;
  text-align: center;
  margin-bottom: 0;
}
.owl-clientes-1{
  margin-top: 1rem;
}
.card-img-clientes{
  width: 100%;
  height: 100%;
  padding: 1.5rem 1rem;
  background: var(--fondo);
  border-radius: var(--border-radius);
  aspect-ratio: 2/1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.img-clientes{
  width: 100%;
  height: 35px;
  aspect-ratio: 2/1;
  object-fit: contain;
  filter: grayscale(1);
  transition: all .4s;
}
.img-partners{
  width: 100%;
  height: 65px;
  aspect-ratio: 2/1;
  object-fit: contain;
  filter: grayscale(1);
  transition: all .4s;
}


/* Fin Seccion Clientes */


/* Section Expertise */
.section-expertise{
  padding-top: 6rem;
  padding-bottom: 6rem;
  /* background: url(../images/fondo-color.svg); */
  /* background-position: center;
  background-size: cover;
  background-repeat: no-repeat; */
  background: var(--fondo);
  border-radius: var(--border-radius);
  position: relative;
  z-index: 3;
}

.title-expertise{
  font-size: var(--size-heading-1);
  font-family: var(--title);
  color: var(--principal);
  line-height: 1.1;
  text-align: center;
  width: 40%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1rem;
}
.text-expertise{
  font-size: 1.25rem;
  color: var(--texto);
  line-height: 1.5;
  text-align: center;
  width: 50%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 0;
}
.wrapper-expertise{
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  gap: 2rem;
  /* max-width: 1200px; */
  margin-left: auto;
  margin-right: auto;
  margin-top: 3rem;
}
.card-num{
  position: sticky;
  top: 200px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 3rem;
  width: 100%;
  height: 485px;
  padding: 4rem;
  background: var(--blanco);
  border-radius: var(--border-radius);
  margin-bottom: 1rem;
  overflow: hidden;
  transition: all .3s;
  transform-origin: left;
  z-index: 2;
}
.card-num.active{
  transform: translateY(-82.6226px) rotate(-3.96588deg) scale(0.867804);
}

.card-num-text{
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
}
.title-card-expertise{
  font-size: 2.875rem;
  font-family: var(--title);
  line-height: 1.3;
  margin-bottom: 1rem;
}
.list-card-expertise{
  margin-bottom: 0;
  padding-left: 1rem;
}
.text-card-expertise{
  font-size: 1.25rem;
  line-height: 1.5;
  margin-bottom: .5rem;
}

.card-num-img{
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1;
}
.img-expertise{
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1;
  max-height: 465px;
  object-fit: cover;
  border-radius: var(--border-radius);
}
/* Fin Section Expertise */


/* Expertise New */
.wrapper-experiencia {
  max-width: 1200px;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  gap: 1rem;
  position: relative; /* Cambiado de sticky a relative */
  z-index: 1;
  margin-top: 3rem;
  margin-left: auto;
  margin-right: auto;
}

.wrapper-num-experiencia {
  position: sticky;
  top: 300px;
  left: 0;
  width: 400px;
  height: 300px;
  z-index: 2; /* Añadido z-index */
}

.num-experiencia {
  position: absolute;
  left: 100px;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 240px;
  font-weight: bold;
  color: var(--principal);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform-style: preserve-3d; /* Añadido para mejor efecto 3D */
}

.cards-container {
  width: 800px; /* Definir ancho explícito */
}

.card-experiencia {
  position: sticky;
  top: 300px;
  height: 400px;
  width: 100%; /* Cambiado a 100% para usar el ancho del contenedor padre */
    background: url(../images/color-fondo-2.svg);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  border-radius: var(--border-radius);
  padding: 2rem 4rem;
  border: 1px solid var(--blanco);
  display: flex;
  flex-direction: column;
  justify-content: center;
  opacity: 1;
  transition: opacity 0.6s ease, transform 0.6s ease;
  margin-bottom: 6rem;
  transform-style: preserve-3d; /* Añadido para mejor efecto 3D */
  backface-visibility: hidden; /* Mejorar rendimiento */
}
.title-card-experiencia{
  font-size: 2.875rem;
  font-family: var(--title);
  color: var(--terciario);
  line-height: 1.1;
  margin-bottom: 1rem;
}
.list-card-experiencia{
  margin-bottom: 0;
  color: var(--blanco);
  padding-left: 1rem;
}
.text-card-experiencia{
  font-size: 1.25rem;
  color: var(--blanco);
  line-height: 1.5;
  margin-bottom: .5rem;
}


/* Fin Expertise New */


/* Seccion Soluciones */
.section-soluciones{
  padding: 6rem 1rem;
  position: relative;
}
.section-soluciones::after{
  content: '';
  position: absolute;
  right: 0;
  top: -16rem;
  width: 600px;
  height: 600px;
  background: url(../images/iso-3.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  opacity: 0;
  transform-origin: right;
}
.section-soluciones.active::after{
  animation: scaleIn 1.5s ease-out forwards 0.5s;
}
.head-title-soluciones{
  font-size: 1.125rem;
  color: var(--texto);
  margin-bottom: 1rem;
  opacity: .8;
}
.title-soluciones{
  font-size: var(--size-heading-1);
  font-family: var(--title);
  color: var(--principal);
  line-height: 1.1;
  width: 50%;
  margin-bottom: 1rem;
}
.subtitle-card-soluciones{
  font-size: 1.25rem;
  font-weight: 400;
  letter-spacing: 0.02rem;
  line-height: 1.5;
  color: var(--texto);
  width: 60%;
  text-wrap: balance;
  margin-bottom: 0;
}
.grid-soluciones{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 3rem;
}
.bg-principal{
  background: var(--principal);
}
.bg-principal h2,
.bg-principal h3,
.bg-principal p,
.bg-principal li{
  color: var(--blanco);
}
.bg-secundario{
  background: var(--secundario);
}
.bg-terciario{
  background: var(--terciario);
}
.card-soluciones{
  padding: 4rem;
  border: 1px solid var(--blanco);
  border-radius: var(--border-radius);
  height: fit-content;
  position: relative;
  z-index: 9;
  transition: all .3s;
}
.card-soluciones:hover{
  transform: translateY(-10px);
  transition: all .3s;
}

.card-soluciones:nth-child(2){
  margin-top: 4rem;
}

.title-card-soluciones{
  font-size: 1.785rem;
  line-height: 1.4;
  margin-bottom: 1rem;
}
.text-card-soluciones{
  font-size: 1rem;
  line-height: 1.5;
  margin-bottom: 0;
}
/* Fin Seccion Soluciones */

/* Seccion Nosotros */
.section-nosotros{
  padding-top: 6rem;
  padding-bottom: 6rem;
  background: var(--fondo);
  border-radius: var(--border-radius);
}
.card-nosotros{
  width: 700px;
  position: absolute;
  top: 60%;
  right: 0;
  transform: translateY(-50%);
  z-index: 2;
}
.img-nosotros-forma{
  position: absolute;
  top: -50%;
  right: 1.5rem;
  width: 550px;
  height: 550px;
  opacity: 0;
  transform-origin: right;
  z-index: -1;
}
.img-nosotros-forma.active{
  animation: scaleIn 1.5s ease-out forwards 0.5s;
}
.wrapper-text-nosotros{
  padding: 4rem;
  background: var(--blanco);
  border-radius: var(--border-radius);
}

.head-title-nosotros{
  font-size: 1.125rem;
  color: var(--texto);
  margin-bottom: 1rem;
  opacity: .8;
}
.title-nosotros{
  font-size: var(--size-heading-1);
  font-family: var(--title);
  color: var(--principal);
  line-height: 1.1;
  margin-bottom: 1rem;
}
.text-nosotros{
  font-size: 1.25rem;
  font-weight: 400;
  letter-spacing: 0.02rem;
  line-height: 1.5;
  color: var(--texto);
  margin-bottom: 0;
}
.img-nosotros{
  width: 70%;
  height: auto;
  border-radius: var(--border-radius);
}
/* Fin Seccion Nosotros */

/* Seccion Partners */
.section-partners{
  padding-top: 6rem;
  padding-bottom: 6rem;
  margin-top: -1rem;
  position: relative;
  overflow: hidden;
}
.section-partners::after{
  content: '';
  position: absolute;
  left: -1rem;
  top: -40%;
  width: 600px;
  height: 600px;
  transform-origin: left center;
  z-index: -1;
  background: url(../images/iso-3.svg) center center / contain no-repeat;
  background-position: center center;
  opacity: 0;
}
.section-partners.active::after{
  animation: scaleIn 1.5s ease-out forwards 0.5s;
}
.title-partners{
  font-size: var(--size-heading-1);
  font-family: var(--title);
  color: var(--principal);
  line-height: 1.1;
  text-align: center;
  margin-bottom: 1rem;
}
.text-partners{
  font-size: 1.25rem;
  font-weight: 400;
  letter-spacing: 0.02rem;
  line-height: 1.5;
  color: var(--texto);
  text-wrap: balance;
  text-align: center;
  width: 52%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 0;
}
.owl-partners{
  margin-top: 2rem;
  padding-right: 1px;
  position: relative;
  z-index: 9;
}
.owl-partners .owl-stage-outer{
  padding-right: 1px;
}
.card-partners{
  padding: 2rem;
  background: var(--blanco);
  border-radius: var(--border-radius);
  border: 1px solid var(--texto);
  display: flex;
  flex-direction: column;
  transition: all .3s;
}
.card-img-partners{
  padding: 4rem 2rem;
  background: var(--fondo);
  border-radius: .5rem;
  transition: all .3s;
}
.card-partners:hover .card-img-partners{
  background: #bde3ff;
}
.card-partners:hover .img-clientes{
  transform: scale(1.1);
  transition: all .3s;
}
.card-text-partners{
  margin-top: 1.5rem;
}
.title-card-partners{
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--principal);
  line-height: 1.4;
  letter-spacing: 0.04rem;
}
.text-card-partners{
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.02rem;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  color: var(--texto);

  margin-bottom: 0;
}

.owl-carousel.owl-partners .owl-nav .owl-prev,
.owl-carousel.owl-partners .owl-nav .owl-next{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 1.6rem;
  border: 1px solid var(--blanco);
  background: rgba(255, 255, 255, .4);
  backdrop-filter: blur(20px);
  transition: all .3s;
}
.owl-carousel.owl-partners .owl-nav .owl-prev:hover,
.owl-carousel.owl-partners .owl-nav .owl-next:hover{
  background: var(--fondo);
}
.owl-carousel.owl-partners .owl-nav .owl-prev{
  left: 1rem;
}
.owl-carousel.owl-partners .owl-nav .owl-next{
  right: 1rem;
}
/* Fin Seccion Partners */

/* Contacto */
.section-contacto{
  padding-bottom: 4rem;
}
.wrapper-contacto{
  padding: 4rem;
  background: var(--fondo);
  border-radius: var(--border-radius);
  position: relative;
  overflow: hidden;
}
.wrapper-contacto::after{
  content: '';
  position: absolute;
  left: 60%;
  top: -18rem;
  width: 800px;
  height: 100%;
  background: url(../images/forma-6.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  opacity: 0;
  transform-origin: right;
  z-index: 1;
}
.wrapper-contacto.active::after{
  animation: scaleIn 1.5s ease-out forwards 0.5s;
}
.head-title-contacto{
  font-size: 1.125rem;
  color: var(--texto);
  margin-bottom: 1rem;
  opacity: .8;
}
.title-contacto{
  font-size: var(--size-heading-1);
  font-family: var(--title);
  color: var(--principal);
  line-height: 1.1;
  width: 50%;
  position: relative;
  z-index: 2;
  margin-bottom: 1rem;
}
.text-contacto{
  font-size: 1.25rem;
  font-weight: 400;
  letter-spacing: 0.02rem;
  line-height: 1.5;
  color: var(--texto);
  width: 60%;
  text-wrap: balance;
  margin-bottom: 0;
}

.grid-contacto {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 2rem;
}

.card-contacto{
  padding: 2rem;
  border-radius: var(--border-radius);
  border: 1px solid var(--blanco);
  height: fit-content;
  position: relative;
  z-index: 2;
  transition: all .3s;
}
.card-contacto:hover{
  transform: translateY(-10px);
  transition: all .3s;
}
.card-contacto:nth-child(2){
  margin-top: 4rem;
}
.card-contacto-icon{
  width: 80px;
  height: 80px;
  background: var(--blanco);
  border-radius: var(--border-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  transition: all .3s;
}
.card-contacto:hover .card-contacto-icon{
  transform: translateY(-5px);
  transition: all .3s;
}
.title-card-contacto{
  font-size: 1.785rem;
  line-height: 1.4;
  color: var(--texto);
  margin-bottom: 0;
}
.text-card-contacto{
  font-size: 1.125rem;
  line-height: 1.5;
  color: var(--texto);
  text-wrap: balance;
  margin-bottom: 0;
}

.list-redes{
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 2rem;
  list-style: none;
  padding-left: 0;
  margin-top: 3rem;
  margin-bottom: 0;
}
.list-redes li a{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  color: var(--texto);
  transition: all .3s;
}
.list-redes li a:hover{
  color: var(--principal);
}
/* Fin Contacto */

/* /////Footer//////// */
.footer{
  margin-top: 0;
  background: var(--blanco);
}
.container-enlaces{
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  flex-wrap: wrap;
  column-gap: 2rem;
}

.container-porta {
  border-top: 1px solid var(--fondo);
}

.text-footer {
  font-size: .9rem;
  color: var(--texto);
  padding-top: 1.2rem;
  padding-bottom: 1rem;
  letter-spacing: 0.02rem;
  margin-bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: .4rem;
}
.text-footer a {
  color: var(--principal);
  text-decoration: none;
  letter-spacing: 0.02rem;
}
.text-footer svg {
  height: 16px;
  width: auto;
  object-fit: contain;
  margin-top: 2px;
}
.text-footer.pt-0 {
  padding-top: 0;
}


/* Fin footer */

.close.btn-close {
  position: absolute;
  top: 10px;
  right: 10px;
  font-size: unset;
  z-index: 9;
}



.container-btn-contact {
  position: fixed;
  right: 2rem;
  bottom: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  z-index: 10;
}

.btn-whatsapp {
  width: 60px;
  height: 60px;
  background: #47c259;
  padding: 1rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: .5rem;
  transition: all .3s;
}
.btn-whatsapp:hover{
  animation: shake 1s;
  animation-iteration-count: infinite;
  transition: all 1s;
}
.btn-whatsapp img{
  width: 45px;
  aspect-ratio: 1/1;
  object-fit: contain;
}

@keyframes shake{
  0% {
    transform: scale(1);
  }
  35% {
    transform: scale(1.1) rotate(-10deg);
  }
  50% {
    transform: scale(1.1) rotate(10deg);
  }
  75% {
    transform: scale(1.1) rotate(-10deg);
  }
  100% {
    transform: scale(1);
  }
}


.owl-carousel .owl-item img.owl-lazy{
  transition: all 1s;
}

.btn-up {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 50px;
  height: 50px;
  background-color: var(--principal);
  border: none;
  border-radius: 50%;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
}

.btn-up img {
  width: 20px;
  height: 20px;
}

.btn-up.hidden {
  opacity: 0;
  visibility: hidden;
}

.btn-up.visible {
  opacity: 1;
  visibility: visible;
}
@media screen and (max-width: 1440px) {
  .wrapper-text-banner{
    width: 50%;
    bottom: 2rem;
  }
  .title-banner{
    font-size: 2.5rem;
  }
  .card-hero-img-1 {
    left: clamp(-10%, -10vw, 0%);
  }
  .card-hero-img-2{
    left: clamp(10%, 9vw, 0%);
  }
  .card-hero-img-4{
    right: clamp(10%, 9vw, 0%);
  }
  .card-hero-img-5 {
    right: clamp(-10%, -10vw, 0%);
}
}
@media screen and (max-width: 1300px) {
  .title-hero{
    font-size: 3.2rem;
  }
  .title-clientes,
  .title-expertise,
  .title-soluciones,
  .title-nosotros,
  .title-contacto{
    font-size: 2.5rem;
    width: 60%;
  }
  .title-partners{
    font-size: 2.5rem;
  }
  .text-expertise,
  .subtitle-card-soluciones,
  .text-nosotros,
  .text-partners,
  .text-contacto{
    font-size: 1rem;
    text-wrap: balance;
  }
  .card-soluciones{
    padding: 2rem;
  }
  .card-nosotros{
    right: 1rem;
  }
  .card-hero-img-1,
  .card-hero-img-5{
    display: none;
  }
  .card-hero-img-2 {
    left: clamp(-4%, -4vw, 0%);
  }
  .card-hero-img-4 {
    right: clamp(-4%, -4vw, 0%);
  }
  .wrapper-hero-images-2,
  .wrapper-hero-images-4{
    width: 90%;
  }
  .wrapper-hero-images-3{
    width: 85%;
  }

  .grid-soluciones,
  .grid-contacto{
    display: grid;
    grid-template-columns: 50% 50%;
  }
  .wrapper-contacto{
    padding: 2rem;
  }

  /* Expertise New */
  .wrapper-num-experiencia{
    width: 200px;
  }
  .num-experiencia{
    font-size: 160px;
    left: 0;
  }
  .cards-container{
    width: 85%;
    margin: 0 auto;
  }
  /* Fin Expertise New */
}
@media screen and (max-width: 1100px) {
  /* Header */
  .nav-header{
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .header .btn-principal{
    display: none;
  }
  .btn-menu{
    display: flex;
  }
  .list-nav-header{
    display: none;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 2rem;
    padding: 2rem;
    background: var(--blanco);
    border-radius: var(--border-radius);
    position: absolute;
    top: 86px;
    left: 0;
    right: 0;
    z-index: 3;
  }
  .list-nav-header.open{
    display: flex;
  }
  /* Fin Header */
  .section-nosotros{
    padding-top: 2rem;
    padding-bottom: 4rem;
  }
}

@media screen and (max-width: 990px) {
  .text-hero,
  .text-expertise{
    width: 80%;
  }
  .grid-soluciones,
  .grid-contacto{
    display: grid;
    grid-template-columns: 100%;
    gap: 1rem;
  }
  .card-soluciones:nth-child(2),
  .card-contacto:nth-child(2){
    margin-top: 0;
  }
  .card-num {
    grid-template-columns: 100%;
    height: auto;
    padding: 2rem;
    top: 100px;
  }
  .title-card-expertise{
    font-size: 2rem;
  }
  .text-card-expertise{
    font-size: 1rem;
  }
  .img-expertise{
    max-height: unset;
  }
  .section-partners::after{
    width: 300px;
    height: 300px;
    top: -20%;
  }
  .card-partners{
    padding: 1rem;
  }
  .card-contacto{
    padding: 1rem;
  }
  .title-card-contacto{
    margin-bottom: .5rem;
  }
  .card-contacto-icon{
    width: 60px;
    height: 60px;
  }
  .title-card-soluciones,
  .title-card-contacto{
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 768px) {
  .card-hero-img-3{
    display: none;
  }
  .card-hero-img-2 {
    left: -2%;
  }
  .card-hero-img-4{
    right: -2%;
  }
  .wrapper-hero-images-2,
  .wrapper-hero-images-4{
    width: 340px;
  }
  .title-hero{
    width: 100%;
    font-size: 2.5rem;
  }
  .title-clientes, .title-expertise, .title-soluciones, .title-nosotros, .title-contacto {
    width: 100%;
    font-size: 2rem;
  }
  .text-hero{
    width: 80%;
  }

  .section-soluciones::after{
    width: 200px;
    height: 200px;
    top: -100px;
    right: 0;
  }
  .grid-soluciones{
    grid-template-columns: 100%;
    gap: 2rem;
  }
  .card-soluciones:nth-child(2),
  .card-soluciones:nth-child(3){
    margin-top: 0;
  }
  .img-nosotros{
    width: 100%;
  }
  .card-nosotros{
    position: unset;
    transform: translateY(2rem)
  }
  .card-nosotros{
    width: 100%;
  }
  .wrapper-text-nosotros{
    padding: 2rem;
  }
  .title-nosotros{
    width: 100%;
  }
  .section-partners::after{
    width: 200px;
    height: 200px;
    top: -100px;
    left: -30px;
  }
  .wrapper-contacto::after {
    top: -28rem;
    width: 200px;
  }
  .text-contacto{
    width: 100%;
  }
    /* Expertise New */
    .wrapper-num-experiencia{
      width: 200px;
    }
    .num-experiencia{
      font-size: 60px;
      left: 0;
    }
    .card-experiencia{
      height: auto;
      padding: 2rem;
    }
    .cards-container{
      width: 85%;
      margin: 0 auto;
    }
    .title-card-experiencia{
      font-size: 1.6rem;
    }
    .text-card-experiencia{
      font-size: 1rem;
    }
    /* Fin Expertise New */
}
@media screen and (max-width: 500px) {
  .text-hero,
  .text-expertise,
  .subtitle-card-soluciones,
  .text-partners{
    font-size: 1rem;
    width: 100%;
  }
  .wrapper-hero-images-2,
  .wrapper-hero-images-4{
    width: 200px;
  }
  .card-hero-img-2 {
    left: -8%;
  }
  .card-hero-img-4{
    right: -8%;
  }
  .wrapper-num-experiencia {
    width: 80px;
  }
}