*, *::after, *::before {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

* {
  box-sizing: border-box;
}

html * {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  margin:0;
  padding:0;
}

html,body{margin:0px;height:100%;}

body, div,
h1, h2, h3, h4, h5, h6,
p, blockquote, pre, dl, dt, dd, ol, ul, li, hr,
fieldset, form, label, legend, th, td,
article, aside, figure, footer, header, hgroup, menu, nav, section,
summary, hgroup {
  margin: 0;
  padding: 0;
  border: 0;
}

a:active,
a:hover {
  outline: 0;
}

@-webkit-viewport { width: device-width; }
@-moz-viewport { width: device-width; }
@-ms-viewport { width: device-width; }
@-o-viewport { width: device-width; }
@viewport { width: device-width; }

body {
  background: white;
  color: #8f8f8f;
  font-family: "Open Sans", sans-serif;
  font-weight: 400;
}

a {text-decoration: none;}

h1 {
  color:#7ec0a5;
  font-size: 30px;
  line-height: 1.8;
  text-transform: uppercase;
  font-family: "Montserrat", sans-serif;
  padding:50px 0 10px 0;}
  
h2, h3, h4{font-size: 20px;font-weight:400;letter-spacing:normal;text-transform:inherit;}

p {font-size: 17px;line-height: 2;}

.izq{text-align:left;}
.justificado{text-align:justify;}
.cursiva{font-style:italic;}
.rojo{color:red;}
.blanco{color:white;}
.naranja{color:#f60;}
.sombra-texto{text-shadow: 0px 0px 4px #000;}

.centro-img {margin-left:auto;margin-right:auto;display:block;}

.alerta-1{color:#F60; font-size: 12px;font-style:italic;}

.bg-negro{background:#000;}
.bg-verde{background:#84DFCB;}
.bg-verde-85{background:rgba(126,192,165,0.85);}
.bg-1{background:url(../img/bg-1.jpg) left center fixed no-repeat}
.bg-3{background:url(../img/bg-3.jpg) left top no-repeat}


.boton{background:#599689;border:2px solid #599689;border-radius:10px;color:#fff;display:inline-block;font-size:16px;font-weight:400;margin:10px;padding:15px 20px;text-align:center;transition: all 0.3s linear;}
.boton:hover{background:transparent;border:2px solid #599689;color:#599689;transition: all 0.3s linear;}

/* ------------------------------------------
 MENU
--------------------------------------------- */

.menu ul {
  width: 100%;height:auto;
  background:none;
  display: block;
  list-style: none;
  margin-top:200px;
  padding: 0;
  text-align:center;
}

.menu li {
  display:block;padding:15px 0;
}
.menu a {
  text-decoration: none;
  color: #999;
}

.menu a:hover{color: #599689;}

.menu a:active,
.menu .active a {
  color:#599689;font-weight:bold;
}

.fixed {
  position: fixed;
  width: 100%;
  left: 0;
  top: 0;
}


/* -------------------------------- 

Main Components 

-------------------------------- */
.c-izq{width:88%;display:inline-block;float:left;margin:0;padding:0;text-align:center;}

.c-der {
  width: 12%;
  height: 100%;
  background:#000;
  font-family: "Montserrat", sans-serif;
  overflow: hidden;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  opacity: 0;
  top: -100px;
  padding-bottom: 6px;
  position: fixed;
  top: 0px;right:0;
  z-index: 999;
}

.c-der-bar{width:20px;height:100%;background:#000;float:right;}

.sticky {background:#fff;opacity: 1;top: 0px;}

.logo {width:130px;height:auto;margin:0 auto;position:absolute;margin-top:30px;text-align:center;left:50%; margin-left: -75px;  /* 50% del ancho de la div en px */}

.cover {
  position: relative;
  background: url(../img/background-cdmx.jpg) no-repeat center center fixed;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  text-align: center;
  color: #fff;
  min-height: 100%;
  letter-spacing: 2px;
  font-family: "Montserrat", sans-serif;margin:0;padding:0;
}
.cover-up{ width:60%;height:100%;left:50%;margin-left:-30%;padding-top: 10%;position:absolute;z-index:2;text-align:center;}
.cover-up h1 {width:200px;margin:0 auto;text-align:center;}
.cover-up h2 {color:#fff;margin-top:200px;text-align:center;}
.logo-cover-1{position:absolute;z-index:10;}
.logo-cover-2{position:absolute;z-index:11;}
.logo-cover-3{position:absolute;z-index:12;}
.logo-cover-4{position:absolute;z-index:13;}
.arrow-button{width:50px;height:50px;border:2px solid #fff;border-radius:50%;margin:30px auto 0 auto;text-align:center;}
.arrow-button:hover{border-color:#599689;}
.arrow-button i{color:#fff;font-size:22px;padding:12px;}
.arrow-button:hover i{color:#599689;}


.f100{width:100%;display:inline-block;margin:0;padding:0;}
.f100 h2{font-size:18px;font-weight:300;letter-spacing:0.3em;text-transform:uppercase;}
.f80{width:80%;display:inline-block;margin:0;padding:0;}
.space{height:200px;display:block;}

.cont-1{width:20%; display:inline-block;margin:20px 10px 50px 10px;vertical-align:top;}
.cont-1 h1{font-size:18px;padding:10px 0;}
.cont-1 img{width:100%;height:auto;}

.pic-cont{display:inline-block; margin:0px;overflow:hidden;}
.pic-cont, .pic-cont-mask, .pic-cont-mask-celda{width:335px;height:245px;}
.pic-cont img{width:335px;height:auto;}
.pic-cont img a{text-decoration:none;}
.img-bg{transition: all 0.5s linear;transform:scale(1);-webkit-transform:scale(1);}
.pic-cont:hover .img-bg{transition: all 0.5s linear;transform:scale(1.3);-webkit-transform:scale(1.3);}
.pic-cont-mask{display:table;opacity: 0;position:absolute;transition: all 0.5s linear;z-index:2;}
.pic-cont-mask-celda{display:table-cell;text-align:center;vertical-align:middle;}
.pic-cont-mask-celda h3{color:#fff;font-size:20px;font-weight:700;text-align:center;text-transform:uppercase;text-shadow: 0px 1px 0px #292929;}
.pic-cont-mask-celda i{color:#fff;font-size:45px;text-shadow: 0px 1px 0px #292929;}
.pic-cont:hover .pic-cont-mask{opacity: 1;}


.cont-2{width:100%;height:800px;background: url(../img/bg-2.jpg) center center;overflow:hidden;}
.cont-2t{width:50%;height:800px;background: url(../img/bg-trapecio.svg) no-repeat right center;display:table;padding-right:150px;}
.cont-2c{display:table-cell;vertical-align:middle;}

.cont-3{width:90%;margin:60px auto;padding:0; text-align:center;}
.gal-w{width:22%;display:inline-block;vertical-align:top;margin:0 2px;}
.gal1{width:100%;height:520px;display:inline-block; margin:2px 0;overflow:hidden;position:relative;}
.gal2{width:100%;height:228px;display:inline-block; margin:2px 0;overflow:hidden;position:relative;}
.gal3l{width:48.5%;height:173px;display:inline-block; margin:2px 0;margin-right:2px;overflow:hidden;position:relative;}
.gal3r{width:48.5%;height:173px;display:inline-block; margin:2px 0; margin-left:2px;overflow:hidden;position:relative;}
.gal1 img, .gal2 img, .gal3l img, .gal3r img{width:auto; height:100%;}
.gal-w a{color:#84DFCB;}
.gal-t{width:100%;height:100%;background:#000;display:table;position:absolute;z-index:2;opacity: .65;transition: all 0.5s linear;text-align:center;}
.gal-t i{color:rgba(255,255,255,.25);font-size:30px;}
.gal-c{display:table-cell;vertical-align:middle;}
.gal-t:hover{opacity: 0;}

/*contenedor facebook*/
#container{width:300px;margin-top:20px;}

footer{width:100%;color:#888;text-align:center;margin-top:-5px;}
.footer-row{width:35%; display:inline-block;margin:0;padding:80px 0;vertical-align:top;}
.footer-box{width:30%;display:inline-block;padding:5% 2%;vertical-align:top;}
.footer-box ul{text-align:left;}
.footer-box li{font-size:15px;list-style-image:none;list-style:none;padding:5px 0;}
.footer-box i{color:#599689;position:relative;top:3px; }
.footer-box a{color:#599689;}
.footer-box a:hover{color:#afcfc9;}
.footer-box-social-1{width:100%;display:inline-block;}
.footer-box-social-2{width:25%;display:inline-block;margin:10px;}
.footer-box-social-1 h3 .footer-box-social-2 h3{text-align:center;}
.footer-box-social-1 img{width:35%; height:auto;}
.footer-box-social-2 img{width:50px; height:auto;}
.creditos{width:100%;background:none;font-size:10px; padding:10px;}
.creditos a{color:#599689;font-weight:bold;text-transform:uppercase;}
.creditos a:hover{color:#afcfc9;}

/* form */

input.form-1:focus ~ label.form-1, textarea:focus ~ label.form-1, input.form-1:valid ~ label.form-1, textarea:valid ~ label.form-1 {
  font-size: 1.2em;
  color: #63babe;
  top: -2.75rem;
  -webkit-transition: all 0.125s cubic-bezier(0.2, 0, 0.03, 1);
          transition: all 0.125s cubic-bezier(0.2, 0, 0.03, 1);
}

.styled-input {
  float: left;
  width: 33.3333%;
  margin: 2rem 0 1rem;
  position: relative;
}
.styled-input label.form-1 {
  color: #999;
  padding: 1rem;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transition: all 0.25s cubic-bezier(0.2, 0, 0.03, 1);
          transition: all 0.25s cubic-bezier(0.2, 0, 0.03, 1);
  pointer-events: none;
}
.styled-input.wide {
  width: 100%;
}

.styled-input-submit {
  width: 100%;display:block;
}

input.form-1, textarea {
  padding: 1rem 1rem;
  border: 0;
  width: 100%;
  font-size: 1rem;
  background:transparent;
  border-bottom:1px solid #63babe;color:#63babe;
}
input.form-1 ~ span, textarea ~ span {
  display: block;
  width: 0;
  height: 3px;
  background: #63babe;
  position: absolute;
  bottom: 0;
  left: 0;
  -webkit-transition: all 0.125s cubic-bezier(0.2, 0, 0.03, 1);
          transition: all 0.125s cubic-bezier(0.2, 0, 0.03, 1);
}
input.form-1:focus, textarea:focus {
  outline: 0;
}
input.form-1:focus ~ span, textarea:focus ~ span {
  width: 100%;
  -webkit-transition: all 0.125s cubic-bezier(0.2, 0, 0.03, 1);
          transition: all 0.125s cubic-bezier(0.2, 0, 0.03, 1);
}

textarea{
  width: 100%;
  min-height: 15em;
}

#submit {
 width:100%;
 background:#63babe;
 border:none;
 color:#fff;
 cursor:pointer;
 font-size:20px;
 padding:10px;
 }
 
input#submit:hover{
 background:#59a0a2;
 }

.error-message{color:#F00; font-size: 10px; margin-top:12px;font-style:italic;}

/*---QUOTED ROTATOR---*/
.cbp-qtrotator {
	position: relative;
	margin: 3em auto auto auto;
	max-width: 800px;
	width: 100%;
	min-height: 300px;
}

.cbp-qtrotator .cbp-qtcontent {
	position: absolute;
	/*min-height: 200px;*/
	border-top: 1px solid #B4B3AA;
	border-bottom: 1px solid #B4B3AA;
	padding: 1em 0;
	top: 0;
	z-index: 0;
	opacity: 0;
	width: 100%;
}

.no-js .cbp-qtrotator .cbp-qtcontent {
	border-bottom: none;
}

.cbp-qtrotator .cbp-qtcontent.cbp-qtcurrent,
.no-js .cbp-qtrotator .cbp-qtcontent {
	position: relative; 
	z-index: 100;
	pointer-events: auto;
	opacity: 1;
}

.cbp-qtrotator .cbp-qtcontent:before,
.cbp-qtrotator .cbp-qtcontent:after {
	content: " ";
	display: table;
}

.cbp-qtrotator .cbp-qtcontent:after {
	clear: both;
}

.cbp-qtprogress {
	position: absolute;
	background: #658FA7;
	height: 1px;
	width: 0%;
	top: 0;left:0;
	z-index: 1000;
}

.cbp-qtrotator blockquote {
	margin: 0;
	padding: 0;
}

.cbp-qtrotator blockquote p {
	font-size: 16px;
	color: #7F8289;
	font-style: italic;
	font-weight: Light 300;
	margin: 0.4em 0 1em;
}
footer.slider{
	background-color: none;
}

.cbp-qtrotator blockquote footer {
	font-size: 14px; font-style:italic; color: #658FA7; margin-left:0px; text-align:left;
}

.cbp-qtrotator blockquote footer:before {
	content: '';
}

.cbp-qtrotator .cbp-qtcontent img {
	float: right;
	margin-left: 3em;
}

/* Example for media query */
@media screen and (max-width: 30.6em) { 

	.cbp-qtrotator {
		font-size: 70%;
	}

	.cbp-qtrotator img {
		width: 80px;
	}

}


/* -------------------------------- 

efectos

-------------------------------- */
.fade{
   background-color: rgba(0,0,0,0);
   opacity: 1;
   -webkit-transition: opacity 0.3s;
   transition: opacity 0.3s;
}
.fade:hover {
	opacity: 0.2;
}

.bounce-1 {
  animation: bounce-1 infinite 3.5s;
  transform: scale(1);
}

@keyframes bounce-1 {
	0%{transform: scale(1);opacity:0.5;}
	50%{transform: scale(1.1);opacity:1;}
  100% { transform: scale(1); opacity:0.5;}
}

.bounce-2 {
  animation: bounce-2 infinite 3.5s;
  transform: scale(1);
}

@keyframes bounce-2 {
	0%{transform: scale(1.1);opacity:1;}
	50%{transform: scale(1);opacity:0.5;}
  100% { transform: scale(1.1); opacity:1;}
}

/* Efecto-arriba-abajo */
.up-down {
  animation: up-down infinite 1.0s;
}

@keyframes up-down {
	0%{transform: translate(0,0px);}
	50%{transform: translate(0,-6px);}
  100% { transform: translate(0,0px);}
}

@media only screen and (max-width: 1440px) {
.c-izq{width:84%;}
.c-der{width:16%;}
.cont-1{width:24%;margin:20px 15px 50px 15px;}
.pic-cont, .pic-cont-mask, .pic-cont-mask-celda{width:275px;height:200px;}
.pic-cont img{width:275px;height:auto;}
.cont-3{width:95%;}
.gal-w{width:22%;}
.gal3l, .gal3r{width:47%;}
.footer-row{width:40%;}
.footer-box{width:80%;}
}

@media only screen and (max-width: 1280px) {
.cont-1{width:26%;}
.cont-3{width:100%;}
.gal-w{width:20%;}
.gal3l, .gal3r{width:47%;height:73px;}
.gal1{height:320px;}
.gal2{height:128px;}
}

@media only screen and (max-width: 1024px) {
.c-izq{width:80%;}
.c-der{width:20%;}	
.cont-1 h1{font-size:16px;}
.pic-cont, .pic-cont-mask, .pic-cont-mask-celda{width:200px;height:146px;}
.pic-cont img{width:200px;height:auto;}
}

@media only screen and (max-width: 768px) {
.c-izq{width:76%;}
.c-der{width:24%;}
.cont-1{width:70%;}
.cont-1 h1{font-size:18px;}
.pic-cont, .pic-cont-mask, .pic-cont-mask-celda{width:335px;height:245px;}
.pic-cont img{width:335px;height:auto;}
.cont-3{width:100%;}
.gal-w{width:42%;}
.cont-2t{width:60%;padding:0 100px 0 60px;}
.gal2 img{width:auto; height:100%;}
}

@media only screen and (max-width: 414px) {
.c-izq{width:100%;}
.c-der{display:none;}
.space{display:none;}
.f100{width:100%;}
.f100 p{padding:0 20px;}
.f100 h1{font-size:25px;}
.f100 h2{width:88%; margin:0 auto;text-align:center;}
.f80{width:80%;margin:0 auto;}
.cont-1{width:90%;}
.cont-1 h1{font-size:18px;}
.pic-cont, .pic-cont-mask, .pic-cont-mask-celda{width:300px;height:219px;}
.pic-cont img{width:300px;height:auto;}
.gal-w{width:90%;}
.gal2 img, .gal3l img, .gal3r img{width:100%; height:auto;}
#container{width:240px;}
.footer-row{width:90%;}
}

/* Effect 1: Brackets */
.cl-effect-1 a::before,
.cl-effect-1 a::after {
	display: inline-block;
	opacity: 0;
	-webkit-transition: -webkit-transform 0.3s, opacity 0.2s;
	-moz-transition: -moz-transform 0.3s, opacity 0.2s;
	transition: transform 0.3s, opacity 0.2s;
}

.cl-effect-1 a::before {
	margin-right: 10px;
	content: '[';
	-webkit-transform: translateX(20px);
	-moz-transform: translateX(20px);
	transform: translateX(20px);
}

.cl-effect-1 a::after {
	margin-left: 10px;
	content: ']';
	-webkit-transform: translateX(-20px);
	-moz-transform: translateX(-20px);
	transform: translateX(-20px);
}

.cl-effect-1 a:hover::before,
.cl-effect-1 a:hover::after,
.cl-effect-1 a:focus::before,
.cl-effect-1 a:focus::after {
	color:#599689;
	opacity: 1;
	-webkit-transform: translateX(0px);
	-moz-transform: translateX(0px);
	transform: translateX(0px);
}
/* ==================================================
   Icons rotation
================================================== */
.contact_bar{width: 80px;position:relative;left:50%; margin-left: -55px; }
.icons-rot ul {
	margin: 0;
	padding: 0;
	text-align: center;
	overflow: hidden;
}

.icons-rot ul li {
	display: inline-block;
	margin: 15px;
	list-style: none;
	cursor: pointer;
	float: left;
    width: 20%;
}
.icons-rot li i{font-size: 36px; padding:3px;}

.icons-rot ul li a {
	display: block;
	width: 65px;
	height: 65px;

	
	-webkit-transition: all 400ms ease-out 0s;	
	   -moz-transition: all 400ms ease-out 0s;
		 -o-transition: all 400ms ease-out 0s;
		    transition: all 400ms ease-out 0s;
		  
	-webkit-transform: rotateY(0deg);
	   -moz-transform: rotateY(0deg);
		-ms-transform: rotateY(0deg);
		 -o-transform: rotateY(0deg);
			transform: rotateY(0deg);
			
			border-radius: 100px;
	 -webkit-border-radius: 100px;  
     -moz-border-radius: 100px;
				
}

.icons-rot ul li a span {
	display: inline-block;
	margin: 0;
	color: #808080;
	font-size: 32px;
	line-height: 67px;
	
	opacity: 0.3;
	filter: alpha(opacity=30);
	
	-webkit-transition: all 400ms ease-out 0s;	
	   -moz-transition: all 400ms ease-out 0s;
		 -o-transition: all 400ms ease-out 0s;
		    transition: all 400ms ease-out 0s;
		  
	-webkit-transform: rotateY(0deg);
	   -moz-transform: rotateY(0deg);
		-ms-transform: rotateY(0deg);
		 -o-transform: rotateY(0deg);
			transform: rotateY(0deg);
			
	 border-radius: 100px;
	 -webkit-border-radius: 100px;  
     -moz-border-radius: 100px;    
}

.icons-rot ul li:hover a,
.icons-rot ul li.active a {
	background-color: #7EC0A5;	
	
	-webkit-transform: rotateY(180deg);
	   -moz-transform: rotateY(180deg);
		-ms-transform: rotateY(180deg);
		 -o-transform: rotateY(180deg);
		    transform: rotateY(180deg);
			
			border-radius: 100px;
	 -webkit-border-radius: 100px;  
     -moz-border-radius: 100px;
}

.icons-rot ul li:hover a span,
.icons-rot ul li.active a span {
	color: #FFFFFF;
	opacity: 1;
	filter: alpha(opacity=100);
	
	-webkit-transform: rotateY(180deg);
	   -moz-transform: rotateY(180deg);
		-ms-transform: rotateY(180deg);
		 -o-transform: rotateY(180deg);
			transform: rotateY(180deg);
			
			border-radius: 100px;
	 -webkit-border-radius: 100px;  
     -moz-border-radius: 100px;
}

