/* ================================================
   FONT FACE
   ============================================== */

@import url('https://fonts.googleapis.com/css?family=Roboto+Slab:300,400,700');
@import url('https://fonts.googleapis.com/css?family=Montserrat:300,300i,400,400i,500,500i,600,600i,700,700i');

/* =================================================
   GENERAL
   ============================================== */
body, html {
	background-color: #FFF;
	margin: 0px;
	padding:0px;
    font-family: 'Roboto Slab', serif;
	font-size: 13px;
	font-weight: 400;
	line-height:22px;
	color:#666;
	height:100%;
	}
html { -webkit-text-size-adjust: 100%;	}

img { border: 0px; }
a {	text-decoration: none; color:#666;}
strong { font-weight: 700; }
p { padding:0; margin: 0}


/* ==========================================
   SECCIONES
   ========================================== */
.main {
	width:100%;
	padding:0px;
	overflow:auto;
	}
h1 {
	font-family: 'Montserrat', sans-serif;
	font-size:50px;
	font-weight:300;
	line-height:50px;
	color:#999;
	display:block;
	margin:0;
	padding:0 0 40px 0;
	background-image: url(img/line_green.png);
	background-repeat: no-repeat;
	background-position: left bottom;
	}
h2 {
	font-family: 'Montserrat', sans-serif;
	font-size:30px;
	font-weight:700;
	line-height:normal;
	color:#3C9646;
	letter-spacing: 0.02em;
	margin:0;
	padding-bottom:30px;
	text-align:center;
	}
h3 {
	font-family: 'Roboto Slab', serif;
	font-size: 30px;
	font-weight: 300;
	line-height:50px;
	color:#333;
	margin:0;
	padding:0;
	}
h4 {
	font-family: 'Montserrat', sans-serif;
	font-size: 22px;
	line-height:34px;
	font-weight: 400;
	color:#3C9646;
	margin:0;
	padding:0;
	}

/* =================================================
   TOP
   ============================================== */
.header {
	width:100%;
	padding: 30px 30px 20px 30px;
	position: fixed;
	z-index:999;
	background-color:#fff;
	-webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
	}
.logo {
	float:left;
	}
#nav {
	float:right;
	padding:5px 0px;
	
	}
#nav a {
	font-family: 'Montserrat', sans-serif;
	font-weight:500;
	font-size:13px;
	color:#999;
	display: inline-block;
	letter-spacing: 0.02em;
	text-align:center;
	margin:0px 10px;
	}
#nav a:hover {
	color:#3C9646;
	border-bottom:2px solid #3C9646;
	}
#nav .activo {
	color:#3C9646;
	}
#nav .mail {
	margin:0px !important;
	padding-left:45px;
	border-left:1px solid #999;
	background-image: url(img/mail.png);
	background-repeat: no-repeat;
	background-position: 15px center;
	}
#nav .mail:hover {
	color:#3C9646;
	border-bottom: none;
	}
#menucito {
	padding:5px;
	overflow:auto;
	}


/* =================================================
   HOME
   ============================================== */
.frase {
	background: url(img/back_frase.png) repeat-x top;
	padding:70px 0px;
	text-align:center;
	}
.frase .col {
	width:65%;
	margin:0 auto;
	background-image: url(img/line.png);
	background-repeat: no-repeat;
	background-position: center top;
	padding:40px 0px;
	}

.frase .col:after {
	content: '';
	position: absolute;
	padding-bottom:40px;
	left:50%;
	margin-left: -150px;
	width: 300px;
	border-bottom: 1px solid #B3B3B3;
	}

.frase .col span {
	color:#3C9646;
	font-weight:700;
	}

/* Proyectos Home*********************/
.proyectos_home {
	background-color:#E6E6E6;
	padding:70px 0px;
	text-align:center;
	}
.proyectos_home .colum {
	width:100%;
	display: -webkit-flex;
	display: flex;
	-webkit-flex-flow: row wrap;
	flex-flow: row wrap;
	justify-content: center;
	align-items: center;
	}
.proyectos_home .thumb {
	text-align:left;
	width:220px;
	float:left;
	margin:0px 20px 20px 20px;
	border-bottom:1px solid #3C9646;
	font-size:15px;
	color:#333;
	padding-bottom:10px;
	position: relative;
	}
.proyectos_home .thumb:after {
	content: '';
	display: block;
	position: absolute;
	width: 80px;
	bottom:0px;
	left: 0px;
	border: 1px solid #3C9646;
	}
.proyectos_home .thumb img {
	padding-bottom:10px; 
	}
.proyectos_home .ver {
	display:inline-block;
	color:#4D4D4D;
	padding:10px 40px;
	border:1px solid #3C9646;
	margin-top:30px;
	}
.proyectos_home .ver:hover {
	background-color:#3C9646;
	color:#fff;
	}


/* Slider Home*********************/
#slider {
	width:auto;
	padding-top:85px;
	margin:0px 30px 30px 30px;
	}
.slides {
	cursor:default;position:relative;top:0px;left:0px;width:1300px;height:500px;overflow:hidden;
	}
#jssor_1 { position:relative;margin:0 auto;top:0px;left:0px;width:1300px;height:500px;overflow:hidden;visibility:hidden;}
.jssorl-009-spin { position:absolute;top:0px;left:0px;width:100%;height:100%;text-align:center;background-color:rgba(0,0,0,0.7); }
.jssorl-009-spin img {
	animation-name: jssorl-009-spin;
	animation-duration: 1.6s;
	animation-iteration-count: infinite;
	animation-timing-function: linear;
	}

@keyframes jssorl-009-spin {
from {
	transform: rotate(0deg);
	}
to {
	transform: rotate(360deg);
	}
}

.jssorb032 {position:absolute;}
.jssorb032 .i {position:absolute;cursor:pointer;}
.jssorb032 .i .b {fill:#fff;fill-opacity:0.7;stroke:#000;stroke-width:1200;stroke-miterlimit:10;stroke-opacity:0.25;}
.jssorb032 .i:hover .b {fill:#000;fill-opacity:.6;stroke:#fff;stroke-opacity:.35;}
.jssorb032 .iav .b {fill:#000;fill-opacity:1;stroke:#fff;stroke-opacity:.35;}
.jssorb032 .i.idn {opacity:.3;}

.jssora051 {display:block;position:absolute;cursor:pointer;}
.jssora051 .a {fill:none;stroke:#fff;stroke-width:360;stroke-miterlimit:10;}
.jssora051:hover {opacity:.8;}
.jssora051.jssora051dn {opacity:.5;}
.jssora051.jssora051ds {opacity:.3;pointer-events:none;}

.slider1,
.slider2 {
	position:absolute;
	z-index:0;
	background-color:rgba(0,0,0,0.65);
	font-family: 'Montserrat', sans-serif;
	font-size:28px;
	line-height:45px;
	font-weight:500;
	color:#fff;
	padding:50px 100px;
	box-sizing:border-box;
	}
.slider1 span,
.slider2 span {
	color:#55D764;
	}
.slider1 {
	top:100px;
	left:0px;
	}
.slider2 {
	top:100px;
	right:0px;
	}

/* =================================================
   SECCIONES
   ============================================== */
#top {
	width:auto;
	padding-top:85px;
	margin:0px 30px 30px 30px;
	}
#top img {
	width:100%;
	height:auto;
	}
.content {
	margin:0 auto;
	padding:70px 0px;
	width:1100px;
	overflow:auto;
	}

/* EMPRESA ***********************************/
.empresa {
	width:100%;
	text-align:justify;
	overflow:auto;
	height: 100%; 
    min-height: 100%;
    position: relative;
	}
.colum_emp1 {
	width:60%;
	float:left;
	}
.colum_emp2 {
	float:right;
	background-color:#E6E6E6;
	width:35%;
	padding:40px;
	-webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
	font-family: 'Montserrat', sans-serif;
	font-size:14px;
	color:#000;
	text-align:left;
	/* Importante! */
	height: 100%; 
    min-height: 100%; 
    position: absolute; 
    top: 0; 
    right: 0; 
    bottom: 0;
	}
.colum_emp2 span {
	font-family: 'Montserrat', sans-serif;
	font-weight:600;
	font-size:28px;
	color:#3C9646;
	line-height:normal;
	background-image: url(img/vineta.png);
	background-repeat: no-repeat;
	background-position: left 13px;
	display: inline-block;
	padding:0px 0px 10px 30px;
	}
.colum_emp2 .txt {
	display: inline-block;
	padding:0px 0px 70px 30px;
	}
	
/* PROYECTOS *************************/
/* Provisorio */
.projects_listado ul {
	margin:0px;
	padding:0px;
	font-size:20px;
	line-height:200%;
	}
.projects_listado .ul li {
	color: #333; 
	list-style: none;
	}
.projects_listado ul li::before {
	content: url(img/bullet.png); 
	font-size:1em;  
	padding-right: 1em; 
	position: relative;
	top: 0em;
	}
/************************/

.projects {
	float:left;
	width:33%;
	}
.projects .thumb {
	width:90%;
	text-align:left;
	border-bottom:1px solid #3C9646;
	/*font-size:15px;*/
	font-weight:700;
	color:#333;
	padding-bottom:10px;
	position: relative;
	margin-bottom:50px;
	}
.projects .thumb:after {
	content: '';
	display: block;
	position: absolute;
	width: 80px;
	bottom:0px;
	left: 0px;
	border: 1px solid #3C9646;
	}
.projects .thumb img {
	width:100%;
	height:auto;
	padding-bottom:10px; 
	}
.projects .thumb span {
	color:#808080;
	font-weight:400;
	}
.projects_otros {
	background-color:#E6E6E6;
	}
.projects_otros .colum1 {
	width:75%;
	border: 2px solid #3C9646;
	font-family: 'Montserrat', sans-serif;
	font-size:25px;
	line-height:normal;
	font-weight:300;
	color:#3C9646;
	height:200px;
	padding:100px 0px 0px 10%;
	}
.projects_otros .colum2 {
	width:85%;
	font-family: 'Montserrat', sans-serif;
	font-size:15px;
	line-height:28px;
	color:#333;
	}
.projects_otros .colum3 {
	font-size:15px;
	line-height:28px;
	color:#333;
	}
.projects_otros .colum3 ul {
	margin:0px;
	padding:0px;
	}
.projects_otros .colum3 ul li {
	color: #333; 
	list-style: none;
	}
.projects_otros .colum3 ul li::before {
	content: url(img/bullet.png); 
	font-size: 1em;  
	padding-right: 1.1em; 
	position: relative;
	top: 0em;
	}

/* Rollover */
span.rollover {
	opacity: 1;
	-o-transition-duration: 0.3s;
	-moz-transition-duration: 0.3s;
	-webkit-transition: -webkit-transform 0.3s;
	cursor: pointer;
	position: absolute;
	z-index: 10;
	opacity: 0;
	background-image: url(img/img_over.svg);
	background-position: center;
	}

span.rollover { width: 100%; height:100%;}

span.rollover:hover {
	opacity: 1;
	-o-transition-duration: 0.3s;
	-moz-transition-duration: 0.3s;
	-webkit-transition: -webkit-transform 0.3s;
	}
	
/* SERVICIOS ***********************/
.servicios {
	width:100%;
	text-align:justify;
	overflow:auto;
	}
.colum_serv1 {
	width:38%;
	float:left;
	}
.colum_serv1 h4 { line-height:40px;}
.colum_serv2 {
	float:right;
	width:55%;
	}

button.accordion {
	width: 100%;
	background-color:#F2F2F2;
	border-top: solid 1px #B3B3B3;
	border-bottom:none;
	border-left:none;
	border-right:none;
	text-align: left;
	padding: 12px 15px;
	font-family: 'Montserrat', sans-serif;
	font-size: 24px;
	font-weight:700;
	color: #3C9646;
	cursor: pointer;
	transition: background-color 0.2s linear;
	}
button.accordion:after {
	content: url(img/ver_mas.png);
	float: left;
	}
button.accordion.is-open:after {
	content:url(img/ver_menos.png);
	}
.accordion-content {
	padding: 0px;
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.2s ease-in-out;
	color:#000;
	}


/* CONTACTO *************************/
.contacto {
	width:100%;
	text-align:justify;
	overflow:auto;
	}
.colum_contact1 {
	width:38%;
	float:left;
	}
.colum_contact2 {
	width:55%;
	float:right;
	text-align:left;
	background-color:#F2F2F2;
	padding:40px;
	-webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
	}
.contacto .direccion,
.contacto .tel,
.contacto .mail {
	font-family: 'Montserrat', sans-serif;
	font-size: 18px;
	line-height:35px;
	font-weight:500;
	display:block;
	padding-left:35px;
	margin-bottom:10px;
	background-repeat: no-repeat;
	}
.contacto .direccion {
	background-image: url(img/icon_location.png);
	background-position: left 5px;
	}
.contacto .tel {
	background-image: url(img/icon_call.png);
	background-position: left center;
	}
.contacto .mail {
	background-image: url(img/icon_mail.png);
	background-position: left center;
	}
	
#map {
	width: 100%;
	height: 400px;
	-webkit-filter: grayscale(100%); /* Safari 6.0 - 9.0 */
	filter: grayscale(100%);
	}

/* FORMULARIO ============================= */
input, textarea, select, button {
	font-family: 'Roboto Slab', serif;
	font-size: 13px;
	font-weight: 400;
	-webkit-appearance: none;
    -webkit-border-radius: 0;
	color:#666;
	}

::placeholder,
:-moz-placeholder,
:-ms-input-placeholder,
::-webkit-input-placeholder {
	color:#000;
	opacity:1;
	}

.contacto_campos {
	width:100%;
	display:block;
	padding:15px;
	border:1px solid #B3B3B3;
	background-color:#fff;
	margin-bottom:20px;
	-webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
	}
.enviar {
	font-family: 'Montserrat', sans-serif;
	font-size: 24px;
	font-weight:600;
	border:none;
	color:#3C9646;
	padding:10px;
	cursor:pointer;
	float:right;
	-webkit-appearance: none;
	}

/* ==========================================
   FOOT
   ========================================== */
.foot {
	width:auto;
	margin:40px 30px 0px 30px;
	padding:25px 0px;
	color:#999;
	border-top:1px solid #ccc;
	text-align:center;
	}
.foot a {color:#999; }
.foot a:hover {color:#000; }

