@charset "UTF-8";
/* CSS Document */

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

/* Comunes */
body{
	font-family: 'Jost', sans-serif;
	letter-spacing:0.05em;
	overflow-x: hidden;	
}

html{
	overflow-x: hidden;
}

a{
	text-decoration: none;
	transition: all 0.3s;
	color: #cf002b;
}

a:hover{
	text-decoration: none;
	transition: all 0.3s;
	color: #000;
}



p{
	font-size: 17px;
	font-weight: 300;
}

.ocultar{
	opacity: 0;
	transition: all 0.3s;
}

.mostrar{
	opacity: 1;
	transition: all 0.3s;
}

/* Apartados */
.intro{
	background-attachment: fixed !important;
	background-position: center !important;
	background-repeat: no-repeat !important;
	background-size: cover !important;
	height: 100vh;
	/*background-image: url('../images/slider01.jpg');*/
	position: relative !important;
	z-index: 1 !important;

}

.intro3{
	background-attachment: fixed !important;
	background-position: center !important;
	background-repeat: no-repeat !important;
	background-size: cover !important;
	height: 70vh;
	/*background-image: url('../images/slider01.jpg');*/
	position: relative !important;
	z-index: 1 !important;

}

.back{
	background: rgba(255,255,255,0.50);
	z-index: 2;
	background-attachment: fixed;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	height: 100vh;
	transition: all 0.5s;
}



.transition1{
	height: auto;
	background-color:#e8e6e6;
	background-repeat: no-repeat;
	position: relative;
	
}

.transition2{
	background-attachment: fixed;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	height: auto;
	background-color:#fff;
	position: relative;
}

.transition3{
	background-attachment: fixed;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	height: auto;
	background-color:#fff;
	position: relative;
}


.logointro{
	position: absolute;
	top: 35%;
	bottom:0;
	right:0;
	left:0;
	text-align: center;
	cursor: pointer;
	width: 275px;
	height: 275px;
	margin: 0 auto;
	transition: all 0.5s;
}

.logointro a{
	text-decoration: none;
}

.intro span{
	display: block;
	margin-top: 20px;
	font-size: 20px;
	letter-spacing:0.3em;
	font-weight: 500;
	color:#000;
}

.logointro img{
	width: 150px;
}


.imagen-logo{
	transition: all 0.5s;
	display: inline-block;
	
}
.imagen-logo2{
	display: none;
	transition: all 0.5s;
	text-align: center;
}

.logointro:hover ~ .back {
    background: rgba(255,255,255,0) !important;
	transition: all 0.5s;
}
.logointro:hover > .imagen-logo {
	display: none;
	transition: all 0.5s;
}

.logointro:hover > .imagen-logo2 {
 	display: inline-block;
	transition: all 0.5s;
}

.logointro:hover >  span {
	color:#fff !important;
	
}


/* Menú */
.bg-light {
	background-color: rgba(255,255,255,0.90) !important;
}

.navbar-light .navbar-nav .nav-link.active{
	color: #cf002b;
}

.navbar-light .navbar-nav .nav-link{
	color:rgba(0,0,0,0.9)
}

.dropdown-menu{
	border-radius: 0;
	border:none;
}


@media (min-width: 992px){
	.navbar-expand-lg .navbar-nav .nav-link {
		padding-right: 1rem;
		padding-left: 1rem;
	}
}

.navbar-light .navbar-toggler {
    color: rgba(0,0,0,.1);
    border-color: rgba(0,0,0,.1);
}

.navbar-toggler:focus{
	box-shadow: 0 0 0 0rem;
}


/* Contenido */

.contenido{
	padding:150px 0 80px 0;
}

.contenido h4{
	font-size:42px;
	font-weight: 300;
	line-height: 0.8;
}

.contenido span{
	font-size: 15px;
	font-weight: 400;
}


.contenido2{
	padding:80px 0 50px 0 !important;
}


.contenido3{
	padding:40px 0 !important;
}

.ficha-equipo li{
	list-style-type: circle;
}

.ficha-equipo h3{
	font-size:28px;
	font-weight: 400;
	
	margin-top: 10px;
}

.ficha-equipo span{
	font-size: 20px;
	font-weight: 300;
	display: block;
}

.contenido-equipo {
	margin-top: 20px;
}


.foto-equipo{
	 width: 150px;
     height: 150px;
     -moz-border-radius: 50%;
     -webkit-border-radius: 50%;
     border-radius: 50%;
	overflow: hidden;
	margin:20px auto;
}



@media (max-width: 992px){
	.foto-equipo{
		 width: 90px;
     height: 90px;
	}
	
	.ficha-equipo h3{
	font-size:24px;
	
	}
	.ficha-equipo li{
	font-size: 14px;
}
	
	.ficha-equipo ul{
		padding-left: 0rem;
	}

	
}

.categoria-equipo h4{
	font-size:28px;
	font-weight: 400;
	line-height: 0.8;
	
	
	
}

.equipo-lista{
	margin-bottom: 50px;
	font-size:20px;
	position: relative;
}



.link-ficha{
	display: inline-block;
	
}


.titulo{
	text-align: center;
}

.titulo h5{
	font-weight: 300;
	font-size: 24px !important;
}

.titulo h6{
	font-weight: 300;
	font-size: 18px !important;
}

.titulo2{
	padding: 80px 0 80px 80px;
}

@media (max-width: 992px){
	.titulo2{
	padding: 0px 0 50px 20px;
}
}


.servicio-imagen{
	position: relative;
 	height: 430px;
	overflow-y: hidden;
}

@media (max-width: 992px){
	.servicio-imagen{
	
 	height: auto;
	
}
}

.categoria-imagen{
	position: relative;
 	height: 660px;
	overflow-y: hidden;
	
}

.back2 {
    background-color: rgba(0, 0, 0, 1);
    position: absolute;
    top: 0;
	opacity: 0.4;
    left: 0;
    width: 100%;
    height: 100%;
	transition: all 0.3s !important;
	z-index: 3;
}
.back2:hover{
    background-color:rgba(0,0,0,1) !important;
	opacity: 0.8;
	transition: all 0.3s !important;
}


.back3 {
    background-color: rgba(0, 0, 0, 1);
    position: absolute;
    top: 0;
	opacity: 0.4;
    left: 0;
    width: 100%;
    height: 100%;
	transition: all 0.3s !important;
	z-index: 3;
}


.servicio-icono{
	opacity: 0;
	position: absolute;
	color:#fff;
	z-index: 3;
	transition: all 0.5s;
	left: 13%;
	bottom: 10%;
}


.mouse-icono{
	opacity: 0;
	position: absolute;
	color:#fff;
	z-index: 3;
	transition: all 0.5s;
	right: 10%;
	bottom: 5%;
}


 .servicio-imagen:hover > a > .servicio-icono {
    opacity: 1;
	bottom: 50%; 
	transition: all 0.3s;
}

 .servicio-imagen:hover > a > .mouse-icono {
    opacity: 1;
	bottom:12%; 
	transition: all 0.3s;
}

.servicio-titulo{
	position: absolute;
	bottom:10%;
	left: 10%;
	color:#fff;
	z-index:3;
}

.servicio-titulo h3{
	font-weight: 400;
	margin-bottom: 0;
	
}



.servicio-titulo span{
	font-size: 16px;
}


.categoria-titulo{
	position: absolute;
	top:40%;
	left: 0;
	right:0;
	text-align: center;
	border:4px solid #fff;
	z-index: 5;
	width: 70%;
    margin: 0 auto;
	padding: 40px;
	transition: all 0.3s;
}

.categoria-titulo:hover{
	background: rgba(0,0,0,0.50);
	transition: all 0.3s;
}

.categoria-imagen a{
	color:#fff!important;
}

.miga-pan{
	font-size:14px;
	font-style: italic;
	margin-bottom: 40px;
}

.miga-pan a{
	color:#cf002b;
}

.miga-pan a:hover{
	color:#000;
}

.miga-pan i{
	font-size: 8px;
}

.volver{
	font-size:14px;
	
	margin-top: 40px;
}

.volver a{
	color:#cf002b;
}
.volver a:hover{
	color:#000;
}

.volver i{
	font-size: 8px;
}

.invert {-webkit-filter: invert(100%);}


.dropdown-item.active, .dropdown-item:active {

	background-color: #cf002b;
}


@media screen and (min-width: 992px){
	.dropdown:hover .dropdown-menu{
	display: block;
	margin-top: 0;
}

.dropdown .dropdown-menu{
	display: none;
}
}


/* Proyectos */

.proyecto-imagen-min{
	position: relative;
	
}
.proyecto-imagen-min img{
	object-fit: cover;
    width: 100%;
    height: 40vh;
   
}

@media screen and (max-width: 992px){
	.proyecto-imagen-min img{
    height: 40vh;
   
}
}

@media screen and (max-width: 769px){
	.proyecto-imagen-min img{
    height: 50vh;
   
}
}

.proyecto-titulo-min{
	position: absolute;
	opacity: 0;
	bottom: 0%;
	left: 10%;
	font-size: 14px;
	color:#fff;
	z-index: 4;
	transition: all 0.3s;
	font-weight: 300;
}

.proyecto-titulo-min span{
	font-size: 16;
	font-weight: 500;
}

.proyecto-titulo-min a{
	color:#fff;
}

.back4 {
    position: absolute;
    top: 0;
	opacity: 0;
    left: 0;
    width: 100%;
    height: 100%;
	transition: all 0.3s !important;
	z-index: 3;
}
.back4:hover{
    background-color:rgba(0,0,0,1) !important;
	opacity: 0.6;
	transition: all 0.3s !important;
}

.proyecto-imagen-min:hover > a > .proyecto-titulo-min{
	opacity: 1;
	bottom: 15%;
	transition: all 0.3s;
}

.ficha-proyecto a{
	color: #cf002b;
}

.ficha-proyecto a:hover{
	color: #212529;
}

.mensaje-error{
	text-align: center;
	color:#cf002b;
}

@media screen and (max-width: 769px){
	.back4 {
		opacity: 1 !important;
		background-color:rgba(0,0,0,0.3) !important;
	}
	.back4:hover{
		background-color:rgba(0,0,0,0.3) !important;
	}
	
	.proyecto-titulo-min{
		opacity: 1 !important;
	}
	
	a > .proyecto-titulo-min{
		opacity: 1;
	bottom: 15%;
	}
	
}

/* Carrusel de imágenes */

.owl-prev{
	position: absolute;
	top: 43%;
	left: 3%;
	font-size: 52px !important;
}

.owl-next{
	position: absolute;
	top: 43%;
	right:3%;
	font-size: 52px !important;
}


/* Cajas contacto*/

.box-contact{
	border:1px solid #626262;
	padding: 60px 20px;
	text-align: center;
	color:#626262;
	transition: all 0.3s;
}

.box-contact:hover{
	border:1px solid #cf002b;
	transition: all 0.3s;
	background: #cf002b;
	color: #fff;
}

a .box-contact {
	color:#626262;
}

 a .box-contact:hover{
	color:#fff; 
}


.box-contact-icono2{
	display: none;
	transition: all 0.3s;
}

.box-contact:hover > .box-contact-icono {
	display: none;
	transition: all 0.3s;
}

.box-contact:hover > .box-contact-icono2 {
	display: block;
	transition: all 0.3s;
}

.box-contact h4{
	font-weight: 600;
	text-transform: uppercase;
	font-size:16px;
	margin-top: 25px;
}

.box-contact span{
	
	font-size:14px;
	font-weight: 300;

}

.hr1{
	margin: 1.5rem auto;
	height: 2px !important;
	width: 25%;
	opacity: 1;
	color: #cf002b;
}

.box-contact:hover > .hr1{
	color:#fff;
}

.titulo-modal{
	font-weight: 600 !important;
	text-transform: uppercase !important;
	font-size:16px !important;
	color:#626262;
	text-align: center;
}

.subtitulo-modal{
	font-size:14px;
	font-weight: 300;
	text-align: center;
	margin-bottom: 40px;
}


.tnp-privacy-field a{
	color: #cf002b;
	font-size: 15px;
}

.tnp-privacy-field a:hover{
	color: #626262;
}

.wp-block-tnp-minimal{
	padding-top: 0 !important;
}

/* Campos Formulario */

.campo-contacto{
	width: 100%;
	background: #fff;
	height: 50px;
	padding: 12px;	
	margin-bottom: 20px;
	color:#626262;
	border:1px solid #626262;
}

.campo-contacto::placeholder {
  color:#AEAEAE;
	font-weight: 300;
}

.campo-contacto:focus{
	outline: none;
	border:2px solid #cf002b;
}

.areatexto-contacto{
	width: 100%;
	background: #fff;
	height: 200px;
	padding: 12px;	
	color:#626262;
	border:1px solid #626262;
}

.areatexto-contacto:focus{
outline: none;
	border:2px solid #cf002b;
}

.areatexto-contacto::placeholder {
 color:#AEAEAE;
	font-weight: 300;
}

span.wpcf7-list-item {
      margin: 0 0 0 0em !important;
}

.wpcf7-list-item-label{
	font-size: 14px;
	color: #cf002b;
}

.wpcf7-list-item-label a{
	color: #cf002b;
	
}

.wpcf7-list-item-label a:hover{
	
	color: #626262;
	
}

.wpcf7-not-valid-tip {
	color: #9f4130;
}

.enviar-contacto{
	background: #cf002b;
	color: #fff;
	padding: 10px 20px;
	border:none;
	transition: all 0.3s;
}

.enviar-contacto:hover{
	background: #626262;
	color:#fff;
	transition: all 0.3s;	
}

.enviar-contacto:disabled{
	background:#bfbfbf;
	color:#E7E7E7;
}


.datos-pie{
	text-align: center;
	margin:40px 0;
	
}

.datos-pie a{
	color: #000;
}

.datos-pie a:hover{
	color: #cf002b;
}


/* Footer */

.footer{
	background: #fff;
	color:#000;
	height: auto;
	font-size: 11px;
	 position: fixed;
	left: 0;
	bottom: 0;
	width: 100%;
	z-index: 9999;
	border-top: 1px solid #efefef;
}

.footer2{
	border-top: 1px solid #efefef;
	background: #fff;
	color:#000;
	height: auto;
	font-size: 11px;

	
}

.items-footer{
	text-align: center;
	padding: 15px 0;
}

.items-footer a{
	color:#000;
	
}

.items-footer a:hover{
	color:#cf002b;
}

.items-footer img{
	height: 28px;
	padding-right: 5px;
	padding-bottom: 5px;
}

.owl-carousel .owl-item img{
 height: 70vh;
	object-fit: cover;
    width: 100%;	
	
}


@media (max-width: 992px){
	 .owl-carousel .owl-item img{
		 height: 40vh;
	}
}

.grecaptcha-badge { 
    visibility: hidden;
}




.opiniones{
	width: 100%;
	position: fixed;
	bottom:90px;
	background: rgba(255,255,255,0.90) !important;
	z-index: 999;
	
}

.item-opiniones{
	
	margin: 0 auto;
 height: auto;

 padding: 15px 0px 5px 0px;
	color: #000;
	overflow: hidden;
}
.item-opiniones img{
	width: 100px !important;
	height: auto !important;
}

.item-opiniones h5{
	font-weight: 400;
	font-size: 1.2rem;
}


.item-opiniones p{
	font-size: 14px;
	font-style: italic;
	margin-bottom: 0;
}

.img-item-opiniones{
	 width: 100px;
     height: 100px;
     -moz-border-radius: 50%;
     -webkit-border-radius: 50%;
     border-radius: 50%;
     background: #fff;
	overflow: hidden;
	margin: 10px auto 10px auto;
}

.item-opiniones-puesto{
	font-size: 12px;
}



@media (max-width: 992px){
	.item-opiniones{
		width: 95%;
	}
	.item-opiniones h5{
		text-align: center;
	}
	
}

#mostrar{display:none;}

@media (max-width: 768px){
	#mostrar{
		display:block;
		text-align:center;
		font-size: 12px;
		padding-bottom:15px;
	}
	.opiniones{
		margin-bottom:20px;
	}
	#target{
		display:none;
	}
	.item-opiniones-puesto{
		text-align:center !important;
	}
	
	
}
