/* GENERALES */
@font-face {font-family: "Geogrotesque Regular";src: url("../fonts/GeogrotesqueCyr-Regular.ttf");}
@font-face {font-family: "Geogrotesque Italic";src: url("../fonts/GeogrotesqueCyr-Italic.ttf");}
@font-face {font-family: "Geogrotesque Light";src: url("../fonts/GeogrotesqueCyr-Light.ttf");}
@font-face {font-family: "Geogrotesque Bold";src: url("../fonts/GeogrotesqueCyr-Bold.ttf");}
@font-face {font-family: "Geogrotesque Bold Italic";src: url("../fonts/GeogrotesqueCyr-BoldItalic.ttf");}
body {margin:0;/* padding-top: 167px; */}
* {
	font-family: "Geogrotesque Regular";
	--azul: #0d1d3f;
	--azulClaro: #3163af;
	--blanco: #ECECEC;
	--naranja: #fc5e28;
}
a,a:hover,a:active,a:focus {text-decoration: none;}
.space {height:200px;}
h2 {
    font-family: "Geogrotesque Bold";
    text-transform: uppercase;
    letter-spacing: 0.2em;
    text-align:center;
    font-size: 30px;
    margin-bottom:30px;
}
.container {position: relative;}
.container.sinSlider {
	padding: 180px 0 0;
}
.miti {
	display: block;
	width: 100%;
	/* text-align: center; */
	margin: 0 auto;
	vertical-align: top;
	margin: 0 auto 50px;
}
.tercio {
	display: inline-block;
	width: 32%;
	vertical-align: top;	
}

/* HEADER */

#header {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	/* padding: 20px 0; */
	z-index: 10;
}
#headerTop {
	background-color: var(--azul);
	color: white;
	padding: 10px 0 9px;
	font-size: 14px;
}
#headerTop > .container {height: 100%;line-height: 1;}
#headerTop > .container * {vertical-align:middle;}
#headerTop > .container span {
	display:inline-block;
	margin-right:23px;
	line-height: 1;
}
#headerTop > .container svg {
	position:relative;
	top:-1px;
	margin-right:3px;
}
#headerTop #redes {
	position: absolute;
	top: 50%;
	right: 0;
	/* height: 100%; */
	transform: translateY(-50%);
}
#headerTop #redes a {
	font-size: 22px;
	color: white;
	padding: 2px;
	margin-left: 5px;
	background-color: var(--azulClaro);
	width: 26px;
	height: 26px;
	vertical-align: middle;
	display: inline-block;
	position:relative;
	line-height: 1;
	border-radius:50%;
}
#headerTop #redes a svg {
	/* max-width:60%; */
	/* max-height:60%; */
	/* width:auto; */
	/* height:auto; */
	position:absolute;
	left: 50%;
	top: 50%;
	line-height: 1;
	font-size: 16px;
	transform: translate(-50%,-50%);
}
#headerMiddle {
	padding: 18px 0 70px;
	/* background-color: white; */
	/* background: rgb(255,255,255); */
	background: linear-gradient(0deg, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 100%);
}
#datosHeader {
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
}
#datosHeader svg {
	position: absolute;
	right: 107%;
	top: 50%;
	transform: translateY(-50%);
	padding: 9px;
	font-size: 36px;
	border: 1px solid #ddd;
	border-radius: 5px;
	color: var(--azulClaro);
}
#logo img {
	height: 90px;
}
#headerBottom {

}
#menu {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	text-align: center;
	white-space: nowrap;
	z-index: 3;
}
#menu a {
	/* background-color: var(--azul); */
	color: var(--azul);
	padding: 10px 12px;
	text-transform: uppercase;
	letter-spacing: 2px;
	font-weight: bold;
}
#menu a:hover {
	background-color: var(--azulClaro);
}


/* SLIDESHOW */

#slideshow {margin: 0px;position: relative;width: 100%;height: 350px;padding: 0px;opacity: 1;top:0;min-height: unset;height: calc( 100vh - 167px);height: 100vh;}
#slideshow:after {content:"";background-color: rgba(0,0,0,0.2);position:absolute;top:0;left:0;width:100%;height: 100%;z-index: 2;}
#slideshow h2 {position:absolute;top:50%;font-size: 80px;left: 50%;transform: translate(-50%,-50%);width: 90%;text-align: center;margin: 0;z-index: 3;color: white;padding: 20px 0;text-shadow: 0px 0px 20px #0005;/* background-color: rgba(0,0,0,0.1); */}
#slideshow .slider {position: absolute;opacity: 0;transition: opacity 0.3s;z-index: 1;bottom: 0;width: 100%;height: 100%;background-repeat: no-repeat;background-position: center;background-size: cover;}
#slideshow .slider.on {opacity: 1; z-index: 2; }
#slideshow .slider .texto {position: absolute;bottom: 0;left: 0;width: 100%;text-align: center;height: 150px;background: rgb(0,0,0);background: linear-gradient(0deg, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%);}
#slideshow .btns {position: absolute;z-index: 9;display:  inline-block;text-align: center;left: 50%;transform: translateX(-50%);bottom: 10px;}
#slideshow .btn {width: 12px;height: 10px;display: inline-block;padding: 0;border-radius: 2px;margin: 0 3px;/* box-shadow: 0px 0px 1px .000; */transition: background 0.5s;background: var(--azul);cursor: pointer;}
#slideshow .btn:hover {background-color: #aaa;}
#slideshow .btn.on {background: white;}


/* SERVICIOS */
#servicios {text-align: center;padding: 50px 0;}
#servicios .servicio {
	display: inline-block;
	width: 18.5%;
	margin: 0 0.5% 30px;
	box-shadow: 0 3px 7px #ddd;
	padding: 0 0 40px;
	vertical-align: top;
}
#servicios .servicio .imagen {
	display: block;
	width: 100%;
	height: 140px;
	background-size: cover;
	background-position: center;
}
#servicios .servicio h3 {
	font-family: "Geogrotesque Bold";
	text-transform: uppercase;
	font-size: 20px;
	padding: 10px;
	white-space: pre-line;
	min-height: 64px;
}
#servicios .servicio p {
	width: 94%;
	margin: 0 3% 30px;
	font-size: 15px;
	color: #666;
}
#servicios .servicio a {
	background-color:var(--azulClaro);
	color:white;
	font-size:15px;
	padding:10px 25px;
    border-radius: 5px;
}

/* VIDEO */
#video {margin: 0 0 100px;}
#video video {width: 100%;}

/* DATOS */
#datos {
	margin: 0 0 50px;
	width: 100%;
	/* height: 280px; */
	background-size: cover;
	background-position: center;
	background-attachment: fixed;
	position: relative;
	text-align:center;
}
#datos .dato {
	display: inline-block;
	vertical-align: middle;
	width: 26%;
	color: white;
	position:relative;
	text-align: center;
	padding: 90px 0;
	cursor: pointer;
}
#datos .texto {
	position:absolute;
	left:50%;
	top:50%;
	transform:translate(-50%,-50%);
	font-size: 20px;
	transition:0.6s;
}
#datos .hover {
	position: absolute;
	left:50%;
	top: 50%;
	opacity: 0;
	font-size: 22px;
	transform: translate(-50%,-50%);
	width: auto;
	transition:0.2s;
}
#datos .dato:hover .texto {opacity:0;transition:0.2s;}
#datos .dato:hover .hover {opacity:1;transition:1.3s;}

/* QUIENES SOMOS */
#quienes-somos {}
#quienes-somos video {width: 70%;display: block;margin: 0 auto;}
#quienes-somos #quienes-somos-texto {/* text-align: right; */padding-right: 30px;font-size: 18px;column-count: 2;}

/* PARALLAX */
#parallax {
	margin: 50px 0 0;
	width: 100%;
	height: 280px;
	background-size: cover;
	background-position: center;
	background-attachment: fixed;
	position: relative;
}
#parallax h4 {
	text-align: center;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	color: white;
	width: 100%;
	font-size: 2vw;
	letter-spacing: 0.4em;
	font-family: "Geogrotesque Light";
	transition: 0.5s;
}
#parallax.aos-animate h4 {
	letter-spacing: 1.5vw;
	transition: 1.0s;
	transition-timing-function: ease-out;
}


/* UBICACION */
#ubicacion {
	padding: 0;
	text-align: center;
	filter: grayscale(1);
	margin-bottom: -7px;
}
#ubicacion h2 {
	display:none;
}


/* PARALLAX LOGOS */
#parallax-logos {
	margin: 0;
	width: 100%;
	/* height: 280px; */
	padding: 30px 0;
	background-size: cover;
	background-position: center;
	background-attachment: fixed;
	position: relative;
}
#parallax-logos img {
	width:150px;
	display: inline-block;
	vertical-align: middle;
	float:none;
	background-color: transparent;
	padding:0px;
	margin:0 30px;
}

/* CONTACTO */
#contacto {
	background-image: url('../img/contacto-bg.jpg');
	background-position: center;
	background-size: cover;
	padding: 0;
	padding: 100px 0;
	background-color: #eee;
}
#contacto p {font-size:19px;margin: 0 0 30px;}
#contacto .container {
	background-color: rgba(255,255,255,0.6);
	padding: 70px 100px 60px;
	width: 960px;
}
#contacto h3 {
	text-align: center;
	font-weight: bold;
	margin: 0 0 30px;
	text-transform: uppercase;
	letter-spacing: 0.2em;
}
#contacto form {
	max-height: 1600px;
	overflow: hidden;
}
#contacto form.hidden {
	max-height: 0px;
	transition: 0.2s;
}
#contacto form .miti {
	width:50%;
	display:inline-block;
	padding-right: 30px;
	margin: 0;
}

#contacto form button {
	padding-left: 20px;
	padding-right: 20px;
	background-color: var(--azulClaro);
	color: white;
	width: 100%;
}
.form-control {
	margin: 0 0 20px;
}

#form_enviado {
	visibility: hidden;
	opacity: 0;
}

#form_enviado.on {
	visibility: visible;
	opacity: 1;
	text-align: center;
	margin: 0px 0px 0px 0px;
	transition: 0.2s;
}
#form_enviado h4 {
	font-size:18px;
}


/* CONTENEDOR */
#footer {
    padding: 48px 0 0;
    background: #0d1d3f;
    color: #fff;
}

#footer .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

#footer a {
    color: #fff;
    text-decoration: none
}

/* COLUMNAS ARRIBA */
#footer .footer-top {
    display: inline-flex;
    grid-template-columns: 1.1fr 1fr .8fr;
    gap: clamp(20px, 4vw, 48px);
    align-items: flex-start;
    margin-bottom: 24px;
}

#footer h4 {
    margin: 0 0 12px;
    font-size: 1.12rem;
    font-weight: 600
}

/* LOGO + DESCRIPCIÓN CONTROLADOS */
#footer .brand-head {
    display: flow-root;
    gap: 16px;
    align-items: baseline;
}

#footer .brand-logo {
    width: 80px;
    height: auto;
    flex: 0 0 auto;
    object-fit: contain;
    filter: drop-shadow(0 0 0 transparent);
}

#footer .brand-desc {
    margin: .25rem 0 .75rem;
    opacity: .92;
    max-width: 40ch
}

#footer .brand-contact a {
    text-decoration: underline
}

/* LISTA DE SERVICIOS */
#footer #foot-servicios a {
    margin: 6px 0
}

/* ICONOS REDES UNIFICADOS ABAJO */
#footer .social {
    display: flex;
    gap: 10px
}

#footer .redes {
    font-size: 18px;
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    color: #0d1d3f;
    border-radius: 50%;
    transition: transform .15s ease, opacity .15s ease
}

#footer .redes:hover {
    transform: translateY(-2px);
    opacity: .9
}

/* BARRA INFERIOR STICKY AL PIE DEL FOOTER */
#footer .footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, .15);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 14px 0 22px
}

#footer .copyright {
    margin: 0;
    opacity: .85
}

/* RESETEO DE ESTILOS VIEJOS QUE ROMPÍAN */
#footer .tercio {
    line-height: 1.55
}

#footer .tercio .redes {
    position: static;
    line-height: 1
}

#footer .tercio .redes svg {
    position: static;
    transform: none;
    max-width: 100%;
    max-height: 100%
}

#subir {
	position: fixed;
	left: 50px;
	bottom: 50px;
	cursor: pointer;
	font-size: 40px;
	color: #666;
	visibility:hidden;
	opacity:0;
	z-index: 1;
	line-height: 1;
	transition: 0.2s;
}
#subir.on {
	visibility:visible;
	opacity:1;
	transition: 0.2s;
}

#whatsapp {
	position: fixed;
	right: 40px;
	bottom: 35px;
	cursor: pointer;
	font-size:15px;
	color: white;
	border-radius:30px;
	text-align:center;
	padding:10px 15px;
	background-color: rgb(37,211,102);
	z-index: 2;
	transition: 0.2s;
}
#whatsapp svg {
	font-size: 30px;
	margin-left:10px;
	vertical-align:middle;
}

/*
SECCION SERVICIOS AMPLIADO
*/
#servicio-ampliacion {}
#servicio-ampliacion img {width:100%;}
#servicio-ampliacion h2 {margin: 40px 0 30px;}

/*
Desktop Full HD
*/
@media screen and (min-width:1400px){
	#slideshow .slider .texto h3 {
		left: 30%;
		width: 40%;
	}
	#menu {width: 64%;}
	#menu.on {width: 26%;left: 74%;}
	#descripcion .descripcion-miti {
        width: 27%;
    }
    #eventos.home .evento,
    #proyectos.home .proyecto {
    	width:18%;
    }
}



/*
Mobile
*/
@media screen and (max-width: 768px){
	.container {
        width: 100% !important;text-align: center;
        }
	.container.sinSlider {
		padding-top: 70px;
	}
	.space {
        height:100px;
        }
	.miti {
		display: block;
		width: 100%;
	}
	#header {
        position:fixed;
        }
	#subir {
		left: 20px;
		bottom: 20px;
		font-size: 35px;
	}
	#whatsapp {
		bottom:20px;
		right: 10px;
		transform: scale(0.8);
	}
	#headerTop {display:none;}
	#headerMiddle {
		background:var(--azul);
		padding: 0;
		top: 0;
		height: 70px;
		position: relative;
	}
	#headerMiddle .container {
		text-align:left;
		height: 100%;
	}
	#logo {
        height: 60px;
        display: inline-block;
        position: relative;
        margin-top: 5px;
    }
	#logo img {
		height: 100%;
		/* margin-top: 5px; */
	}
	#hamburguesa {
		position:absolute;
		top:50%;
		right:20px;
		transform:translateY(-50%);
		color:white;
		line-height: 1;
		font-size:25px;
	}
	#menu {
		width:100vw;
		background-color:white;
		height: calc(100vh - 70px);
		left:100vw;
		top: 70px;
		z-index: 4;
		transform: unset;
		padding: 30px 0 0;
		transition:0.3s;
	}
	#menu.on {
		left:0;
		transition:0.4s;
	}
	#menu a {
		display:block;
		
	}

	.slideshow {height: 150px;width: 100%;margin: 0 auto;}
	.slideshow.zoom-slide {height: 300px;}
	#slideshow .slider .texto h3 {font-size: 15px;width: 90%;left: 5%;bottom: 20px !important;}
	#slideshow {height: 50vh;margin-top: 70px;}
	#slideshow h2 {font-size: 24px;width: 90%;}
	#slideshow .slider.conLink .texto a {font-size: 15px;padding: 4px 15px;bottom: 30px;}
    #slideshow .btns {bottom: 2px;}
    #slideshow .btn {width: 12px;height: 5px;margin: 0 2px;}
    #servicios .servicio {
    	display:block;
    	width:100%;
    }
    #datos {padding:30px 0;}
    #datos .dato {
    	display:block;
    	width: 76%;
    	margin:0 auto;
    	position:relative;
    	padding: 30px 0;
    }
    #datos .dato .texto {
    	position:relative;
    	left:unset;
    	top:unset;
    	transform:unset;
    	font-weight:bold;
    }
    #datos .dato .hover {
    	opacity:1;
    	position:relative;
    	left:unset;
    	top:unset;
    	transform:unset;
    	margin-top:10px;
    	font-size: 17px;
    }
    #quienes-somos {
    	text-align:center;
    }
    #quienes-somos #quienes-somos-texto {
    	text-align: left;
    	width:100%;
    	padding: 0;
    }
    #parallax h4 {
    	line-height:2;
    }
    #contacto .container {
        padding: 50px 20px;
    }
	 #footer .footer-top {
        flex-direction: column;
        align-items: center;
		}
	
	#footer .footer-bottom {
	  	flex-direction: column;
	   	text-align: center
	}
	
	#footer .brand-desc {
	   	max-width: unset
	}
    #servicio-ampliacion h2 {
    	font-size: 25px;
    }
    #servicio-ampliacion p {
    	padding:10px;
    }
}