/*
Theme Name: GeneratePress Child
Template: generatepress
Version: 1.0.0
Text Domain: generatepress-child
*/

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&display=swap');


body {
  background-color: #f9f9fa !important;
  min-height: 100vh !important;
  display: flex !important;
  flex-direction: column !important;
  min-width: 370px !important;
}

h2 {
  font-size: 30px !important;
}

hr {
  margin-top: 10px;
  margin-bottom: 30px;
}

hr:last-child {
  display: none;
}

p {
  font-family: 'Montserrat', sans-serif;
  color: #8b8b8b;
  font-weight: 400;
  line-height: 26px;
  margin: 0 0 1em 0;
}

a {
  text-decoration: none !important;
  color: #04316e !important;
}

.site-header {
  display: flex;
  height: 85px !important;
  box-shadow: 0px 3px 12px rgb(0 0 0 / 15%);
}

.page-logo {
  align-items: flex-start;
  align-self: center;
  height: 50px;
}

.img-logo {
  width: auto;
  height: 50px;
  margin-top: auto;
  margin-left: 10vw;
  margin-bottom: auto;
  align-self: center;
}

.main-container {
  text-align: center !important;
  justify-content: center;
  align-items: center;
  margin: auto;
  max-width: 90vw !important;
}

.title-container {
  text-align: center !important;
  padding-top: 80px;
  padding-left: 50px;
  padding-right: 50px;
  padding-bottom: 20px;
}
.form-container {
  padding-left: 150px;
  padding-right: 150px;
  padding-bottom: 20px;
}

.main-title {
  font-family: 'Montserrat', sans-serif !important;
  text-decoration: none;
  font-weight: 800;
  /* color: #255dc4 !important; */
  color: #245dc1 !important;
  padding-top: 20px;
  padding-bottom: 10px;
  font-size: 30px;
}

.secondary-title {
  font-size: 16px;
}

/* .form-container {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-evenly;
} */

/* Inicio contenedor boton buscar */
/* ul:last-child li:last-child {
  width: auto !important;
} */
/* Fin contenedor boton buscar */

input:focus,
select:focus {
  border-color: #000 !important;
}

option:checked {
  background-color: #245dc1 !important;
  color: #fff !important;
}

/* Inicio contenedor de inputs plugin Search and Filter */
.searchandfilter > div > ul {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-evenly !important;
  margin: 0 !important;
  margin-bottom: 20px !important;
}
/* Fin contenedor de inputs plugin Search and Filter */

/* Inicio Input Buscar por nombre */
.searchandfilter > div > ul:first-child > li:first-child > input {
  font-size: 16px !important;
  border-radius: 6px !important;
  background-color: #fff !important;
  /* min-width: 360px !important;
  width: 100% !important;
  margin: 5px !important; */
}
/* Fin Input Buscar por nombre */

/* Inicio Select Area */
.searchandfilter select {
  font-size: 16px !important;
  border-radius: 6px !important;
  background-color: #fff !important;
  /* width: 100% !important;
  margin: 5px !important; */
}
/* Fin Select Area */

/* Inicio Boton Buscar */
.searchandfilter div ul li:last-child input:last-child {
  display: inline-block !important;
  color: #245dc1 !important;
  border: 2px solid #245dc1 !important;
  border-radius: 100px !important;
  background-color: transparent !important;
  font-family: 'nunito' !important;
  font-weight: 700 !important;
  transition: all 0.25s linear !important;
  text-align: center !important;
  margin: auto !important;
  width: 120px !important;
}

.searchandfilter div ul li:last-child input:last-child:hover {
  background: #245dc1 !important;
  color: #fff !important;
}
/* Fin Boton Buscar */
.cards-container {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  margin: 40px 20px 20px 20px;
  align-items: center;
  justify-content: space-evenly;
}

.card {
  width: 365px;
  height: 255px;
  border-radius: 8px;
  background-color: #fff;
  margin: 5px 10px 20px 10px;
  box-shadow: 2px 4px 6px rgb(0 0 0 / 15%);
  transition: 0.3s;
  display: flex;
  flex-wrap: wrap;
  font-family: 'nunito';
}

.card:hover {
  transition: all 0.3s ease-out;
  transform: scale(1.05);
}

.card-contact-container {
  width: 100%;
  text-align: left;
  /*padding-left: 10px;
  padding-right: 10px;*/
  display: flex;
  flex-wrap: wrap;
  padding: 15px 25px;
}

.card-titles-container {
  display: flex;
  flex-wrap: wrap; /*Usado con width 100% obliga a que el contenido ocupe todo el ancho*/
  width: 65%;
  padding: 10px 0 8px 0px;
  text-align: left;
  line-height: 1.3;
  align-content: center;
  padding-left: 15px;
}

.card-name {
  font-size: 18px;
  font-weight: 700;
  color: #255DC4;
  width: 100%;
}
.card-position {
  font-size: 14px;
  font-weight: 500;
  color: #255DC4;
  width: 100%;
}

.card-info-container {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  padding-left: 10px;
  text-align: left;
  align-content: center;
}

.card-info {
  color: #222;
  width: 100%;
  font-size: 14px;
  font-weight: 400;
  font-family: 'Montserrat' !important;
}

.card-icon {
  padding-right: 4px;
  width: 25px;
  height: 20px;
  color: #255DC4;
}

.card-interno {
  font-size: 14px;
  color: #222;
  font-weight: 400;
}

.link-container {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  align-items: center;
}

.card-hr {
  display: block;
  height: 1px;
  width: 100%;
  /* border: 0; */
  border-top: 1px solid #ccc;
  /* margin: 10px auto; */
  margin: 6px 0px 1px 0px;
}

.card-link {
  display: flex;
  margin: 0 auto;
  text-align: center;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  transition: all 0.25s linear !important;
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
  /* box-shadow: 2px 4px 6px rgb(0 0 0 / 0%); */
  padding: 8px 25px;
  border: 1.9px solid #255dc4;
  border-radius: 25px;
  font-family: 'nunito';
  font-weight: 600;
  color: #255dc4 !important;
}

.card-link:hover {
  background: #245dc1 !important;
  color: #fff !important;
}

/* Dispositivos extra pequeños (600px o menos) */
@media only screen and (max-width: 680px) {
  .main-container {
    min-width: 370px;
  }

  .cards-container {
    margin-top: 10px;
  }

  h2 {
    margin-bottom: 0;
  }

  .site-header {
    justify-content: center;
  }

  .img-logo {
    margin: 0;
  }

  .searchandfilter > div > ul {
    display: flex !important;
    flex-direction: column !important;
    margin: 0 !important;
    margin-bottom: 30px !important;
  }

  /* Inicio Input Buscar por nombre */
  .searchandfilter > div > ul:first-child > li:first-child > input {
    min-width: 360px !important;
    width: 100% !important;
    margin: 5px !important;
  }
  /* Fin Input Buscar por nombre */

  /* Inicio Select Area */
  .searchandfilter select {
    min-width: 360px !important;
    width: 100% !important;
    margin: 5px !important;
  }
  /* Fin Select Area */

  /* Inicio ultimo li de ul */
  .searchandfilter div ul li:last-child {
    padding-left: 10px !important;
  }
  /* Fin ultimo li de ul */

  /* Inicio Boton Buscar */
  .searchandfilter div ul li:last-child input:last-child {
    min-width: 360px !important;
    width: 40% !important;
    margin: 5px !important;
  }

  .vc-main-container {
    max-width: 100%;
  }

}

/* Dispositivos pequeños (entre 600px y <768px) */
@media only screen and (min-width: 680px) {
  .main-container {
    min-width: 500px !important;
  }

  .img-logo {
    margin: 0;
  }
  .site-header {
    justify-content: center;
  }
  .searchandfilter > div > ul {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-evenly !important;
    margin: 0 !important;
    margin-bottom: 30px !important;
  }

  .searchandfilter > div > ul:first-child > li:first-child > input {
    min-width: 260px !important;
    margin: auto !important;
  }
  .searchandfilter select {
    width: 170px !important;
    margin: auto !important;
  }

  .vc-main-container {
    max-width: 100%;
  }

}

/* Dispositivos medianos (entre 768px y <992px) */
@media only screen and (min-width: 768px) {
  .main-container {
    min-width: 600px !important;
  }
  .site-header {
    justify-content: initial;
  }
  .img-logo {
    margin-top: auto;
    margin-left: 10vw;
    margin-bottom: auto;
  }
  .searchandfilter > div > ul:first-child > li:first-child > input {
    width: 320px !important;
    /* margin-right: 10px !important;
    margin-bottom: 10px !important;
    margin-left: 20px !important; */
  }

 
}

.invisibleC1-1,
.invisibleC2-1,
.invisibleC3-1,
.invisibleC4-1,
.invisibleC4-2,
.invisibleC5-1,
.invisibleC5-2 {
  visibility: hidden;
}

@media only screen and (max-width: 778px) {
  .invisibleC1-1,
  .invisibleC2-1,
  .invisibleC3-1,
  .invisibleC4-1,
  .invisibleC4-2,
  .invisibleC5-1,
  .invisibleC5-2 {
    /* visibility: hidden; */
    display: none;
  }
}

@media only screen and (min-width: 778px) {
  .invisibleC1-1,
  .invisibleC3-1,
  .invisibleC5-1 {
    display: initial;
  }

  .invisibleC2-1,
  .invisibleC4-1,
  .invisibleC4-2,
  .invisibleC5-2 {
    display: none;
  }
}

@media only screen and (min-width: 1145px) {
  .invisibleC2-1,
  .invisibleC3-1,
  .invisibleC4-1,
  .invisibleC4-2,
  .invisibleC5-1,
  .invisibleC5-2 {
    /* visibility: hidden; */
    display: initial;
  }

  .invisibleC1-1 {
    display: none;
  }
}

/* Dispositivos grandes (entre 992px y <1200px) */
@media only screen and (min-width: 992px) {
  .main-container {
    min-width: 800px !important;
  }
  .site-header {
    justify-content: initial;
  }
  .img-logo {
    margin-top: auto;
    margin-left: 10vw;
    margin-bottom: auto;
  }
  .searchandfilter > div > ul:first-child > li:first-child > input {
    min-width: 500px !important;
    width: auto !important;
  }

  .searchandfilter select {
    width: 200px !important;
  }

}

/* Dispositivos extra grandes (1200px o más) */
@media only screen and (min-width: 1200px) {
  .main-container {
    max-width: 1250px !important;
  }
  .site-header {
    justify-content: initial;
  }
  .img-logo {
    margin-top: auto;
    margin-left: 10vw;
    margin-bottom: auto;
  }

  .searchandfilter > div > ul:first-child > li:first-child > input {
    min-width: 600px !important;
    width: auto !important;
  }

  .searchandfilter select {
    width: 200px !important;
  }

}

/* ***************************   INICIO ESTILO TARJETAS INDIVIDUALES   **************************************** */

#vc-body {
  background-color: #f9f9fa !important;
}

.vc-hr {
  display: block;
  height: 5px;
  border: 0;
  margin: 10px auto;
}

.vc-main-container {
  display: block;
  width: 100%;
  justify-content: center;
  margin: auto;
  margin-top: 0 !important;
  font-family: 'nunito';
}

.vc-img-container {
  display: flex;
  width: 100%;
  height: 150px;
  background-color: #245dc1 !important;
  align-items: center;
}

.vc-home-link-container {
  justify-self: center;
  text-align: center;
}

.vc-permalink {
  display: none;
  visibility: hidden;
}

.vc-logo {
  width: 150x;
  height: 90px;
  padding: 10px;
  margin: 10px auto;
}

.vc-card-container {
  width: 400px;
  height: 100%;
  display: flex;
  flex-direction: column;
  margin: auto;
  margin-top: 50px;
  margin-bottom: 50px;
  background-color: #fff;
  box-shadow: 2px 4px 6px rgb(0 0 0 / 15%);
  border-radius: 8px;
}

.round-container {
  display: flex;
  flex-direction: column;
}

.vc-name-position-container {
  width: 100%;
  height: auto;
  text-align: center;
  padding: 25px 35px;
}

.vc-name {
  font-size: 26px;
  font-weight: 800;
  color: #095aa7;
  width: 100%;
  padding: 10px 10px 2px;
}
.vc-position {
  font-size: 20px;
  font-weight: 300;
  color: #006cff;
  width: 100%;
}

.vc-aero-info-container {
  width: 900px;
  height: 100%;
  text-align: center;
  margin: 50px auto;
}

.vc-card-contact-info-container {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  width: 100%;
  height: 100%;
  text-align: left;
  padding: 0 10px 10px;
}

.vc-card-info {
  color: #222;
  width: 100%;
  font-family: 'Montserrat';
  
  font-size: 14px;
  font-weight: 400;
  padding: 6px 10px 6px 10px;
}

.vc-card-misc {
  color: #04316e;
  width: 100%;
  font-size: 22px;
  font-weight: 500;
  padding: 6px 10px 6px 10px;
}

.vc-misc-text {
  font-size: 16px;
}

.vc-misc-locations-container {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  width: 100%;
  padding: 10px 5px;
  justify-content: center;
  align-items: center;
}

.vc-misc-location {
  text-align: center;
  display: flex;
  flex-direction: row;
  padding: 0 6px;
  font-family: 'Montserrat';
}
.vc-misc-location span {
	padding: 0 2px;
}
.vc-misc-location.center {
	border-left: 1px solid #222;
	border-right: 1px solid #222;
}

.vc-misc-city {
  display: flex;
  justify-content: center;

  font-weight: 700;
  font-size: 15px;
  line-height: 21px;
  color: #454848;
}

.vc-misc-phone {
  font-size: 14px;
}
.vc-misc-text.horario {
	font-weight: 700;
}
.p-b-10 {
	padding-left: 5px;
}
.vc-aero-misc-container {
  display: flex;
  flex-direction: row;
  margin: auto;
}

.vc-card-icon {
  margin-right: 4px;
  width: 18px;
  height: 18px;
  color: #255DC4;
}

.vc-card-interno {
  font-size: 14px;
  font-family: 'Montserrat';
  color: #222;
  width: 100%;
  font-weight: 400;
  padding-left: 0px;
}

.btn-compartir {
  display: inline-block;
  color: #245dc1 !important;
  border: 2px solid #245dc1 !important;
  /* color: #129633 !important;
  border: 2px solid #129633 !important; */
  border-radius: 100px;
  background-color: transparent !important;
  font-family: 'nunito';
  font-weight: 700;
  transition: all 0.25s linear;
  text-align: center;
  margin: 20px auto;
  width: 200px;
  align-self: center;
}

.btn-compartir:hover {
  background: #245dc1 !important;
  /* background: #129633 !important; */
  color: #fff !important;
}
.vc-return-icon {
  margin-right: 4px;
}
footer {
  margin-top: auto !important;
}

.footer-link-aero {
  padding-bottom: 10px !important;
}
.contacts-footer {
  padding: 45px 0 !important;
}

.f-inner-section {
  display: flex !important;
  justify-content: center !important;
  margin-left: auto;
  margin-right: auto;
  max-width: 120rem;
}

.footer-credits {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  align-items: flex-end;
  margin-bottom: 0 !important;
  line-height: 0.8 !important;
  text-decoration: none;
}
.footer-logo {
  margin-left: 10px !important;
  max-width: 50px;
}


/*nuevos estilos contacto*/

.card-foto-container {
	width: 35%;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
}
.card-foto-container img {
	width: 90px;
    height: 90px;
    object-fit: contain;
    border-radius: 100px;
    border: 2px solid #255dc4;
}

body#vc-body .card-foto-container {
	width: 40%;
}

body#vc-body .card-foto-container img {
	width: 110px;
    height: 110px;
}


/*nuevos estilos single*/

.card-head-flex {
	display: flex;
	flex-direction: row;
}



/*actualizaciones isma*/



h2 {
	font-size: 25px !important;
    font-family: 'Montserrat';
    font-weight: 600;
}

.searchandfilter li {
	padding-right: 40px;
}

.searchandfilter > div > ul > li:first-child {
    min-width: 550px !important;
}
.searchandfilter > div > ul > li:first-child > input {
    width: 100% !important;
}

.searchandfilter div ul li:last-child input:last-child {
	width: 150px !important;
	background-color: #fff !important;
}
.card-titles-container {
	font-family: 'Montserrat';
}

/*card agrandar tamaño imagen */




@media only screen and (max-width: 1024px) {
	
	.form-container {
		width: 300px;
		margin: 0 auto;
	}
	
	.searchandfilter > div > ul:first-child > li:first-child > input {
		min-width: 300px !important;
	}
	.searchandfilter li {
		padding: 0 !important;
	}
	.searchandfilter select {
		min-width: 270px !important;
	}
	.searchandfilter div ul li:last-child input:last-child {
		min-width: 270px !important;
	}
	
	html,body {
		overflow-x: hidden;
	}
}

@media only screen and (max-width: 945px) {
	
	.vc-aero-info-container {
		
		width: 100%;
		
	}
	.vc-misc-location.center {
		border: none;
	}
	
}

@media only screen and (max-width: 450px) {

	.vc-card-container {
    width: 345px;
	}
	
}


/*filtros subcategorias jscript*/

.filters button {
	background-color: transparent;
    color: #255DC4;
    font-family: 'Nunito';
    font-weight: 600;
    border: 1px solid #255DC4;
    border-radius: 50px;
    padding: 5px 10px;
    width: 140px;
    margin: 0px 20px;
	transition: all 0.25s linear !important;
}

.filters button.is-checked {
	background-color: #255DC4;
	color: #fff;
}