@charset "UTF-8";
/* CSS Document */
body
{
	margin-left: 0px;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	background-color: #000;
}

/*** texto legal ***/
.txtlegal {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    color: #D5D5D5;
    text-align: center;
    padding-left: 6px;
    padding-top: 25px;
    padding-right: 6px;
    padding-bottom: 5px;
    font-weight: normal;
}
/*** texto legal ***/
/*imagen responsiva*/

img {
    max-width:100%;
}
.img2 {
    max-width:60%;
}
.img3 {
    max-width:10%;
}
.img4 {
    max-width:55%;
}
.img5 {
    max-width:80%;
}
.img6 {
    max-width:70%;
}
.img7 {
    max-width:30%;
}
.img8 {
    max-width:20%;
}

.fondo-formu-up{
	height: 100vh;
	height: 40vmax;
	
    background-repeat: no-repeat;
    background-position: center center;
    opacity: 1.0;
    background-size: cover;
    width: 100%;
    text-align: center;
    background-color: #000000;
    background-image: url(../img/fondo-contacto-up.jpg);
}

/*txt titulos*/

.txt-titulos-blanco01 {
    font-family: Montserrat, sans-serif;
    font-size: 45px;
    color: #000;
    text-align: center;
    padding-top: 3px;
    padding-bottom: 3px;
    font-weight: 600;
    text-transform: uppercase;
    line-height: 48px;
    }
.txt-titulos-blanco02 {
    font-family: Montserrat, sans-serif;
    font-size: 35px;
    color: #000;
    text-align: center;
    font-weight: 400;
    text-transform: uppercase;
    line-height: 44px;
    padding-top: 8px;
    padding-bottom: 8px;
    border-top: thin dotted #FFF;
    border-bottom: thin dotted #FFF;
    }


.container {
  position: relative;
  width: 100%;
}

.image {
  opacity: 1;
  display: block;
  width: 100%;
  height: auto;
  transition: .5s ease;
  backface-visibility: hidden;
}

.middle {
  transition: .5s ease;
  opacity: 0;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  text-align: center;
}



/*

/*boton ir arriba*/
.ir-arriba {
	display:none;
	padding:25px;
	background: url(img/subir.png) no-repeat center center;
	cursor:pointer;
	position: fixed;
	bottom:20px;
	right:30px;
}
/* fin Botón para Ir Arriba 
----------------------------------------------- */

/*CSS para tablas planes*/

.tabla {
padding: 5px;
border-right-width: 1px;
border-bottom-width: 1px;
border-right-style: solid;
border-bottom-style: solid;
border-right-color: #D7D7D7;
border-bottom-color: #D7D7D7;
}
/*** boton fono ***/
.btnfonoup:link {
	font-family: 'Montserrat', sans-serif;
	color: #000;
	font-size: 12px;
	text-decoration: none;
	padding-top: 8px;
	padding-bottom: 8px;
	text-align: left;
	padding-left: 8px;
    font-weight: 500;
    
}
.btnfonoup:visited {
	font-family: 'Montserrat', sans-serif;
	color: #000;
	font-size: 12px;
	text-decoration: none;
	padding-top: 8px;
	padding-bottom: 8px;
	text-align: left;
	padding-left: 8px;
    font-weight: 500;
}
.btnfonoup:actived {
	font-family: 'Montserrat', sans-serif;
	color: #000;
	font-size: 12px;
	text-decoration: none;
	padding-top: 8px;
	padding-bottom: 8px;
	text-align: left;
	padding-left: 8px;
    font-weight: 500;
	
}

.btnfonoup:hover {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    text-decoration: none;
    color: #b80d27;
    padding-top: 8px;
    padding-bottom: 8px;
    text-align: left;
    padding-left: 8px;
    font-weight: 500;
}
/*** fin boton fono ***/

.contenedor{
    position: relative;
    display: inline-block;
    text-align: center;
	
}

.centrado{
    position: absolute;
    top: 22%;
    right: 15px;
	font-family: Montserrat, sans-serif;
    font-size: 14px;
	background-color:rgba(34,174,205,0.9); /* rgbA */
    text-align: center;
    padding: 20px 1px;
    color: #FFFFFF;	
}

.slash {
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    color: #078186;
    text-align: left;
    
    font-weight: 600;
    text-transform: uppercase;
    opacity: 0.6;
    padding-left: 5px;
	}

.caja-filete{
    border-width: 1px;
    border-style: solid;
    border-color: #7ab929;
}

    /*** boton MAS INFO ***/
.boton-info:link {
    font-family: 'Montserrat', sans-serif;
    color: #000;
    font-size: 14px;
    text-decoration: none;
    padding: 12px;
    text-align: center;
    font-weight: 500;
    background-color: #B80D27;
    
}
.boton-info:visited {
    font-family: 'Montserrat', sans-serif;
    color: #000;
    font-size: 14px;
    text-decoration: none;
    padding: 12px;
    text-align: center;
    font-weight: 500;
    background-color: #B80D27;
}
.boton-info:actived {
    font-family: 'Montserrat', sans-serif;
    color: #000;
    font-size: 14px;
    text-decoration: none;
    padding: 12px;
    text-align: center;
    font-weight: 500;
    background-color: #B80D27;
}

.boton-info:hover {
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    text-decoration: none;
    color: #000;
    padding: 12px;
    text-align: center;
    font-weight: 500;
    background-color: #000;
}
/*** fin boton BOTON MAS INFO ***/
h1 {
    font-family: 'Montserrat', sans-serif;
	font-size: clamp(1.35rem, 0.875rem + 1.1111vw, 1.5rem);
    color: #fff;
    text-align: LEFT;
    font-weight: 400;
    padding-top: 2px;
    padding-bottom: 3px;
	padding-left: 55px;
    margin: var(--rhythm) 0;
	border-bottom: 2px solid #000
    }
h2 {
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(33px, 3vw, 33px);
    color: #000;
    text-align: center;
    font-weight: 300;
    text-transform: uppercase;
    padding-bottom: 2px;
    padding-top: 2px;
    margin: var(--rhythm) 0;
    }
h3 {
    font-family: 'Montserrat', sans-serif;
	font-size: clamp(33px, 3vw, 35px);
    color: #000;
    text-align: center;
    font-weight: 300;
    text-transform: uppercase;
    padding-bottom: 2px;
    padding-top: 2px;
    margin: var(--rhythm) 0;

    }
h4 {
    font-family: 'Montserrat', sans-serif;
	font-size: clamp(88px, 10vw, 120px);
    color: #000;
    text-align: center;
    font-weight: 600;
    padding-top: 2px;
    padding-bottom: 0px;
    margin: var(--rhythm) 0;
	text-shadow: black 0.07em 0.07em 0.2em
    }
h5 {
    font-family: 'Raleway', sans-serif;
    font-size: clamp(20px, 3vw, 27px);
    color: #000;
    text-align: center;
    font-weight: 400;
	padding-bottom: 4px;
	padding-top: 4px;
	margin: var(--rhythm) 0;
    }

/*grilla para adaptarse a moviles*/
.containerS{
	width: 95%;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(auto-fit,minmax(18rem,1fr));
	grid-gap: 1.0rem;
}
.containerS2{
	width: 100%;
	margin: 0.0rem 0;
	display: grid;
	grid-template-columns: repeat(auto-fit,minmax(16rem,1fr));
	grid-gap: 0.0rem;
	background-color: #fff;
	/*border-bottom: solid #5F5F5F 8px;*/
	
}
.boxS{
	padding: 1.2rem 0.1rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
.boxS2{
	padding: 1.2rem 0.1rem 0.1rem 0.1rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
.boxS3{
	padding: 1.2rem 1.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
.boxS4{
	padding: 1.2rem 0.0rem;
	width: 100%;
	float: right;
	display: flex;
	text-align: right;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
.boxS42{
	padding: 1.2rem 0.0rem 1.2rem 0.0rem;
	margin-right: -5rem;
	margin-left: -5rem;
	width: 100%;
	float: right;
	display: flex;
	text-align: right;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
.boxS5{
	padding: 1.2rem 0.0rem;
	width: 100%;
	float: right;
	display: flex;
	text-align: right;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	
}
.boxS img{ 
	width: 100px;
}
/*boton header*/
  .botproyectos {
    font-family: 'Montserrat', sans-serif;
	  font-size: 1.50vh;
    color: #222;
	  background-color: #FFF;
    display: inline-block;
    text-align: right;
    text-decoration: none;
    margin: 0px 0px;
    -webkit-transition-duration: 0.3s; /* Safari */
    transition-duration: 0.3s;
    cursor: pointer;
    font-weight: 600;
	  border-bottom: 1px solid #fff
}
.botproyectos1 {
	font-family: 'Montserrat', sans-serif;
    font-size: 1.50vh;
  color: #222222;
	background-color: #FFF;
	font-weight: 600;
	text-align: right;
	text-decoration: none;
	border-bottom: 2px solid #fff
}
.botproyectos1:hover {
    font-family: 'Montserrat', sans-serif;
    color: #737373;
	background-color: #FFF;
    font-weight: 600;
    text-align: right;
	text-decoration: none;
	border-bottom: 2px solid #b80d27
}
/*boton header*/

/*grilla para adaptarse a moviles*/
.grid {
  display: grid;
  padding-top: 5.0em;
	padding-bottom: 5.0em;
	padding-left: 0.2em;
	padding-right: 0.2em;
  counter-reset: grid-items;
  position: relative;
	grid-gap: 0.1em;
}
.grid2 {
  display: grid;
  padding-top: 2.0em;
	padding-bottom: 2.0em;
	padding-left: 0.0em;
	padding-right: 0.0em;
  counter-reset: grid-items;
  position: relative;
	grid-gap: 0.0em;
}
.grid--auto-fit {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.grid__item {
  padding: 0.2em;
  color: #fff;
}
.grid__item2 {
  padding: 0.0em;
  color: #fff;
}
/*grilla para adaptarse a moviles*/
.right{
    float: right;
}
