

@import url('https://fonts.googleapis.com/css?family=Roboto:300,400,500,600,700&display=swap');



body {
	background-color: #222222;
	margin: 0px;

	-webkit-text-size-adjust:100%;
	-webkit-font-smoothing: antialiased;	
	font-family: "Roboto", sans-serif;		
	overflow-x: hidden;

}




.fondo {
	float: left;
	width: 100%;
	height: auto;
	background: #0C4AD3;
	background-image: url(../images/lineas01-02.svg);
	background-repeat: repeat-x;
	background-size: 100%;
	background-position: 0px 100px;
	overflow-x: hidden;
	transition: all .5s ease-in-out;
	
}

.header {
	float: left;
	width: calc(100% - 120px);
	padding: 60px;
	padding-top: 0px;
	height: 160px;
	padding-bottom: 0px;
	display: block;	
}

.header .logo {
	position: relative;
	float: left;
	width: 54px;
	height: auto;
	top: 100px;
}

.header .logo img {
	float: left;
	width: 54px;
	height: auto;
}

.header .top-menu {
	position: absolute;
	display: block;
	float: right;
	height: auto;
	right: 60px;
	margin-top: -100px;
}

.header .top-menu ul {
	float: left;
	list-style: none;
	margin-left: -40px;
	padding-left: 40px;
}

.header .top-menu ul li {
	float: left;
	text-align: right;
	margin-bottom: 17px;	
	margin-left: 20px;
}

.header .top-menu ul li a:link {
	font-family: "Roboto", sans-serif;
	color: #fff;
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0px;
	text-decoration: none;
	padding-bottom: 5px;
		
}

.header .menu-m-btn {
	display: none;
}


.header .lang {
	position: absolute;
	right: 60px;
	top: 30px;
	font-size: 10px;
	color: #fff;
	font-weight: 600;
	display: block;
}

.header .lang a:link {
	color: #fff;
	text-decoration: none;
	font-size: 9px;
	font-weight: 600;
	text-transform: uppercase;
	padding: 3px;
	padding-left: 5px;
	padding-right: 5px;
	border-radius: 2px;
	margin-left: 3px;	
	transition: all .1s ease-in-out;
	
}

.header .lang a:visited {
	color: #fff;
	text-decoration: none;
	font-size: 9px;
	font-weight: 600;
	text-transform: uppercase;
	padding: 3px;
	padding-left: 5px;
	padding-right: 5px;
	border-radius: 2px;
	margin-left: 3px;	
	transition: all .1s ease-in-out;
	
}

.header .lang a.selected {
	color: #0C4AD3;
	text-decoration: none;
	font-size: 9px;
	background-color: #fff;
	font-weight: 600;
	text-transform: uppercase;
	padding: 3px;
	padding-left: 5px;
	padding-right: 5px;
	border-radius: 2px;
	
}

.header .lang a:hover {
	color: #0C4AD3;
	text-decoration: none;
	font-size: 9px;
	background-color: #fff;
}

.header .menu {
	display: block;
	float: right;
	height: auto;
	position: relative;	
	top: 86px;
	
}

.header .menu ul {
	float: left;
	list-style: none;
	margin-left: -40px;
	padding-left: 40px;
}

.header .menu ul li {
	float: left;
	text-align: right;
	margin-bottom: 17px;	
	margin-left: 30px;
}

/*
.header .menu ul {
	float: left;
	width: 300px;
	list-style: none;
	margin-left: -40px;
	padding-left: 40px;
}

.header .menu ul li {
	float: left;
	width: 100%;
	text-align: right;
	margin-bottom: 17px;	
}
*/
.header .menu ul li a:link {
	font-family: "Roboto", sans-serif;
	color: #fff;
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0px;
	text-decoration: none;
	padding-bottom: 5px;
		
}

.header .menu ul li a:hover {
	color: #fff;
	text-decoration: none;
}

.header .menu ul li a:visited {
	color: #fff;
	text-decoration: none;
		
}

.menu-m	{
	display: none;
	transition: all .5s ease-in-out;	
}

.menu-mob	{
	display: none;
	transition: all .5s ease-in-out;	
}


.content {
	position: absolute;
	height: 300px;
	width: 100%;
	top: 100vh;
}

.home {
	float: left;
	margin-top: 28vh;
	width: 100%;
	height: auto;
	background: none;
	margin-bottom: 40vh;

}

.texto {
	float: left;
	width: calc(100% - 120px);
	margin-left: 56px;
	text-align: left;
}

.texto h3 {
	font-family: "Roboto", sans-serif;	
	font-weight: 400;
	color: #fff;
	font-size: 40px;
	margin: 0px;

	line-height: 1.2;
	letter-spacing: 0px;
   -moz-user-select: none;
   -khtml-user-select: none;
   -webkit-user-select: none;

}

.scroll {
	position: absolute;
	height: auto;
	top: calc(50% - 100px);
	width: auto;
	left: 80%;
}

.cont_a {
	position: absolute;
	height: auto;
	top: calc(50% - 20px);
	width: auto;
	left: 60px;
	width: 100px;
	height: 200px;
	border-color: #fff;
	border-width: 2px;
	border-style: solid;
	display: block;	

	
}

.cont_a h4 {
	font-family: "Roboto", sans-serif;	
	font-weight: 500;
	color: #fff;
	text-align: center;
	padding-top: 16px;
	
}

.cont_b {
	position: absolute;
	height: auto;
	top: calc(50% - 120px);
	width: auto;
	display: block;	
}

.underline{
  position: relative;
}
.underline::before{
  content: '';
  position: absolute;
  bottom: 0;
  top: 32px;
  right: 0;
  width: 0;
  height: 3px;
  background-color: #fff;
  transition: width 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}

.underline-active{
  position: relative;
}
.underline-active::before{
  content: '';
  position: absolute;
  bottom: 0;
  top: 32px;
  left: 0;
  width: 60%;
  height: 3px;
  background-color: #fff;
  transition: width 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}

.nosotros {

	float: left;
	position: relative;
	width: 100%;
	margin-left: 0px;
	height: auto;
	

/*	border-radius: 0px 40px 0px 0px;	*/
	
}

.nosotros .intro {
	float: left;
	width: calc(80% - 120px);		
	background-color: #fff;	
	padding: 60px;	

}

.nosotros .intro h5 {
	float: left;
	color: #0C4AD3;
	font-size: 12px;
	font-weight: 500;
	margin: 0px;
	width: calc(100% - 20px);
}

.nosotros .intro .flecha {
	float: right;
	width: 20px;
	margin-top: -5px;
	margin-right: -20px;
}

.nosotros .intro .titular {
	float: left;
	margin-top: 72px;
	width: 50%;
}

.nosotros .intro .titular p {
	color: #0C4AD3;
	font-size: 25px;
	line-height: 42px;
	font-weight: 400;
	margin: 0px;
}

.nosotros .intro .titular p b {
	font-weight: 400;
	border-bottom-color: #0C4AD3;
	border-bottom-style: solid;
	border-bottom-width: 2px;
	padding-bottom: 5px;
}

.nosotros .detalle {
	float: left;
	width: calc(100% - 120px);		
	background-color: #fff;	
	padding: 60px;	
	padding-bottom: 120px;	
}

.nosotros .detalle .line {
	float: left;
	width: 100%;
	margin-bottom: 46px;
}

.nosotros .detalle .coli {
	float: left;
	width: 50%;
	padding-right: 60px;
	padding-bottom: 0px;	
}

.nosotros .detalle .cold {
	float: left;
	width: calc(50% - 60px);
}

.nosotros .detalle p {
	color: #0C4AD3;
	font-size: 15px;
	line-height: 28px;
	font-weight: 400;
	margin: 0px;
}

.nosotros .detalle p b {
	font-weight: 400;
	border-bottom-color: #0C4AD3;
	border-bottom-style: dotted;
	border-bottom-width: 1px;
	padding-bottom: 4px;
}


.servicios {

	float: left;
	position: relative;
	width: calc(100% - 120px);
	margin-left: 0px;
	height: auto;
	padding: 60px;
	padding-bottom: 120px;
}

.servicios h5 {
	float: left;
	color: #fff;
	font-size: 12px;
	font-weight: 500;
	margin: 0px;
	width: 100%;
}

.servicios .sep {
	float: left;
	width: 20px;
	height: 3px;
	background-color: #fff;
	margin-top: 24px;
}

.servicios .contenido {
	float: left;
	width: 100%;
	margin-top: 120px;
}

.servicios .contenido .coli {
	float: left;
	width: 50%;
	padding-right: 60px;
}

.servicios .contenido .cold {
	float: left;
	width: calc(50% - 60px);
}

.servicios .contenido .coli p {
	color: #fff;
	font-size: 25px;
	line-height: 42px;
	font-weight: 400;
	margin: 0px;
}

.servicios .contenido .coli .sep-v {
	float: left;
	width: 2px;
	height: 84px;
	background-color: #fff;
	margin-top: 70px;
	margin-bottom: 70px;
}

.servicios .contenido .col {
	float: left;
	width: 100%;
}

.servicios .contenido .col .link {
	float: left;
	width: 40%;
}
	
.servicios .contenido .col .link a:link {
	float: left;
	background-color: #fff;
	padding: 25px;
	color: #0C4AD3;
	font-size: 13px;
	font-weight: 500;
	text-decoration: none;
	border-radius: 0px 0px 20px 0px;
	width: 50%;
	padding-bottom: 66px;
	margin-left: -25px;
	background-image: url(../images/flecha-der-azul.svg);
	background-repeat: no-repeat;
	background-position-x: calc(100% - 22px);
	background-position-y: 26px;
	background-size: 15px;
	transition: all 0.6s cubic-bezier(0.25, 1, 0.5, 1);
	
}

.servicios .contenido .col .link a:visited {
	color: #0C4AD3;
	text-decoration: none;
}

.servicios .contenido .col .link a:hover {
	width: 80%;
}

.servicios .contenido .cold p {
	color: #fff;
	font-size: 15px;
	line-height: 28px;
	font-weight: 400;
	margin: 0px;
	margin-bottom: 40px;
	margin-top: 5px;
}

.servicios .contenido .cold p b {
	font-weight: 400;
	border-bottom-color: #fff;
	border-bottom-style: solid;
	border-bottom-width: 2px;
	padding-bottom: 4px;
}



.tecno {

	float: left;
	position: relative;
	width: calc(100% - 120px);
	margin-left: 0px;
	height: auto;
	padding: 60px;
	padding-bottom: 120px;
	background-color: #0A45C7;
}

.tecno h5 {
	float: left;
	color: #fff;
	font-size: 12px;
	font-weight: 500;
	margin: 0px;
	width: 100%;
}

.tecno .sep {
	float: left;
	width: 20px;
	height: 3px;
	background-color: #fff;
	margin-top: 24px;
}

.tecno .contenido {
	float: left;
	width: 100%;
	margin-top: 120px;
}

.tecno .contenido ul {
	float: left;
	width: 20%;
	margin: 0px;
	list-style: none;
	margin-left: -40px;
	padding-left: 40px;
}

.tecno .contenido ul li {
	float: left;
	width: 100%;
	font-size: 21px;
	color: #fff;
	font-weight: 400;
	line-height: 44px;
}

.tecno-logos {

	float: left;
	position: relative;
	width: calc(100% - 120px);
	margin-left: 0px;
	height: auto;
	padding: 60px;
	padding-top: 90px;
	padding-bottom: 90px;
	background-color: #0742C3;
}

.tecno-logos ul {
	float: left;
	margin: 0px;
	list-style: none;
	margin-left: -40px;
	padding-left: 40px;
	width: 100%;
}

.tecno-logos ul li {
	float: left;
	width: 10%;
	height: 100px;
}


.clientes {

	float: left;
	position: relative;
	width: calc(100% - 120px);
	margin-left: 0px;
	height: auto;
	padding: 60px;
	padding-bottom: 120px;
	padding-top: 90px;
	background-color: #fff;
}

.clientes h5 {
	float: left;
	color: #0C4AD3;
	font-size: 12px;
	font-weight: 500;
	margin: 0px;
	width: 100%;
}

.clientes .sep {
	float: left;
	width: 20px;
	height: 3px;
	background-color: #0C4AD3;
	margin-top: 24px;
}

.clientes .contenido {
	float: left;
	width: 100%;
	margin-top: 120px;
}

.clientes .contenido .coli {
	float: left;
	width: 50%;
	padding-right: 60px;
}


.clientes .contenido .coli p {
	color: #0C4AD3;
	font-size: 25px;
	line-height: 36px;
	font-weight: 400;
	margin: 0px;
}

.clientes .contenido .coli .sep-v {
	float: left;
	width: 2px;
	height: 84px;
	background-color: #0C4AD3;
	margin-top: 70px;
	margin-bottom: 70px;
}

.clientes .contenido .lista {
	float: left;
	width: 100%;
}

.clientes .contenido .lista ul {
	float: left;
	margin: 0px;
	list-style: none;
	margin-left: -40px;
	padding-left: 40px;
	width: 20%;
}

.clientes .contenido .lista ul li {
	float: left;
	width: 100%;
	font-size: 14px;
	line-height: 34px;
	color: #0C4AD3;
}



@media (hover: hover) and (pointer: fine) {
  .underline:hover::before{
    left: 0;
    right: auto;
    width: 50%;
  }
}



@media screen and (max-width: 800px) {
	
	body {
		overflow-x: hidden;
	}

	.fondo {
		float: left;
		width: 100%;
		height: auto;
		background: #0C4AD3;
		background-image: url(../images/lineas01-02.svg);
		background-repeat: repeat-x;
		background-size: 140%;
		background-position: 0px 100px;
		overflow: hidden;
	}
	
	.header .menu {
		display: none;
	}

	.header .menu-m-btn {
		position: absolute;
		width: 26px;
		height: 26px;
		right: 20px;
		top: 100px;
		display: block;
	}

	.menu-m	{
		display: none;		
		position: absolute;
		z-index: 5000;
		width: calc(100% - 100px);
		left: calc(100% + 20px);
		top: 0px;
		background-color: #fff;
		height: auto;
		padding-bottom: 60px;
		box-shadow: -5px 1px 7px 1px rgba(0,0,0,0.12);
		-webkit-box-shadow: -5px 1px 7px 1px rgba(0,0,0,0.12);
		-moz-box-shadow: -5px 1px 7px 1px rgba(0,0,0,0.12);		
/*
		border-left-color: #0C4AD3;
		border-left-style: solid;
		border-left-width: 3px;
*/
		border-radius: 0px 0px 0px 50px;
		transition: all .5s ease-in-out;

		
	}
	
	.menu-m	.x {
		float: right;
		width: 26px;
		height: 26px;
		right: 20px;
		margin-right: 20px;
		margin-top: 100px;
	}	

	.menu-m	.top {
		float: left;
		width: calc(100% - 60px);
		padding: 30px;
		margin-top: 20px;
	}	
	
	.menu-m	.top ul {
		float: right;
		width: 100%;
		margin-left: -40px;
		padding-left: 40px;
		list-style: none;
	}	
	
	.menu-m	.top ul li {
		float: left;
		width: 100%;
		text-align: left;
		font-size: 15px;
		height: 40px;
	}	
	
	.menu-m	.top ul li a:link {
		color: #0C4AD3;
		text-decoration: none;
	}	

	.menu-m	.top ul li a:visited {
		color: #0C4AD3;
		text-decoration: none;
	}	

	.menu-m	.top ul li a.active {
		position: relative;	
	}

	.menu-m	.top ul li a.active::before {
		position: relative;	
	  content: '';
	  position: absolute;
	  bottom: 0;
	  top: 10px;
	  left: 120%;
	  width: 100%;
	  height: 2px;
	  background-color: #0C4AD3;
	  transition: width 0.6s cubic-bezier(0.25, 1, 0.5, 1);
	}


	.menu-m	.lang {
		float: left;
		width: 100%;
		padding: 30px;
		
	}	
		
	.menu-m .lang a:link {
		color: #0C4AD3;
		text-decoration: none;
		font-size: 11px;
		font-weight: 600;
		text-transform: uppercase;
		padding: 6px;
		padding-left: 8px;
		padding-right: 8px;
		border-radius: 2px;
		margin-left: 0px;	
	}

	.menu-m .lang a:visited {
		color: #0C4AD3;
		text-decoration: none;
	}
	
	.menu-m .lang a.selected {
		color: #fff;
		text-decoration: none;
		font-size: 11px;
		background-color: #0C4AD3;
		font-weight: 600;
		text-transform: uppercase;
		padding: 6px;
		padding-left: 8px;
		padding-right: 8px;
		border-radius: 2px;
		
	}
	
	.menu-m .lang a:hover {
		color: #0C4AD3;
		text-decoration: none;
		background-color: #fff;
	}
	

	.menu-mob {
		display: block;
		width: 100%;
		position: absolute;
		top: -100%;
		height: 460px;
		background-color: #fff;
		z-index: 6000;
		box-shadow: -5px 1px 7px 1px rgba(0,0,0,0.12);
		-webkit-box-shadow: -5px 1px 7px 1px rgba(0,0,0,0.12);
		-moz-box-shadow: -5px 1px 7px 1px rgba(0,0,0,0.12);	
/*		background-image: url(../images/lineas01-02.svg);
		background-repeat: repeat-x;
		background-size: 200%;
		background-position: 0px 0px;
*/		
		border-bottom-color: #0C4AD3;
		border-bottom-style: solid;
		border-bottom-width: 3px;


	}
	
	.menu-mob	.x {
		float: right;
		width: 26px;
		height: 26px;
		right: 20px;
		margin-right: 20px;
		margin-top: 70px;
	}	

	.menu-mob	.top {
		float: left;
		width: calc(100% - 120px);
		padding: 20px;
		margin-top: 0px;
		padding-bottom: 0px;
	}	
	
	.menu-mob	.top ul {
		float: right;
		width: 100%;
		margin-left: -40px;
		padding-left: 40px;
		list-style: none;
	}	
	
	.menu-mob	.top ul li {
		float: left;
		width: 100%;
		text-align: left;
		font-size: 14px;
		height: 46px;
		font-weight: 400;
	}	
	
	.menu-mob	.top ul li a:link {
		color: #0C4AD3;
		text-decoration: none;
	}	

	.menu-mob	.top ul li a:visited {
		color: #0C4AD3;
		text-decoration: none;
	}	

	.menu-mob	.top ul li a.active {
		position: relative;	
	}

	.menu-mob	.top ul li a.active::before {
		position: relative;	
	  content: '';
	  position: absolute;
	  bottom: 0;
	  top: 26px;
	  left: 0px;
	  width: 60%;
	  height: 2px;
	  background-color: #0C4AD3;
	  transition: width 0.6s cubic-bezier(0.25, 1, 0.5, 1);
	}


	.menu-mob	.lang {
		float: left;
		width: calc(100% - 200px);
		padding: 20px;
		margin-top: 20px;
		margin-bottom: 20px;
	}	
		
	.menu-mob .lang a:link {
		color: #0C4AD3;
		text-decoration: none;
		font-size: 10px;
		font-weight: 600;
		text-transform: uppercase;
		padding: 6px;
		padding-left: 8px;
		padding-right: 8px;
		border-radius: 2px;
		margin-left: 0px;	
	}

	.menu-mob .lang a:visited {
		color: #fff;
		text-decoration: none;
	}
	
	.menu-mob .lang a.selected {
		color: #fff;
		text-decoration: none;
		font-size: 10px;
		background-color: #0C4AD3;
		font-weight: 600;
		text-transform: uppercase;
		padding: 6px;
		padding-left: 8px;
		padding-right: 8px;
		border-radius: 2px;
		
	}
	
	.menu-mob .lang a:hover {
		color: #fff;
		text-decoration: none;
		background-color: #0C4AD3;
	}
	
	
	.header .lang {
		display: none;
	}
	

	.header {
		width: calc(100% - 40px);
		padding: 20px;
		padding-top: 0px;
	}

	.texto {
		float: left;
		width: calc(100% - 120px);
		margin-left: 18px;
		text-align: left;
	}
		
	.nosotros .intro {
		float: left;
		width: calc(100% - 80px);		
		background-color: #fff;	
		padding: 60px;	
		padding-left: 20px;
	
	}

	.nosotros .intro .titular {
		float: left;
		margin-top: 72px;
		width: 100%;
	}

	.nosotros .detalle {
		float: left;
		width: calc(100% - 80px);		
		background-color: #fff;	
		padding: 60px;	
		padding-bottom: 120px;	
		padding-left: 20px;

	}

	.nosotros .detalle .coli {
		float: left;
		width: 100%;
		padding-right: 0px;
		padding-bottom: 40px;
	}
	
	.nosotros .detalle .cold {
		float: left;
		width: 100%;
	}
	
	.servicios {
	
		width: calc(100% - 120px);
		margin-left: 0px;
		height: auto;
		padding: 60px;
		padding-bottom: 120px;
		padding-left: 20px;
	}
	
	.servicios .contenido .coli {
		float: left;
		width: 100%;
		padding-right: 0px;
	}
	
	.servicios .contenido .col .link {
		float: left;
		width: 100%;
		margin-top: 30px;
	}
	
	.servicios .contenido .col .link a:link {
		width: 60%;
		margin-left: 0px;
	}	

	.servicios .contenido .col .link a:hover {
		width: 80%;
		margin-left: 0px;
	}	
	
	.servicios .contenido .cold {
		float: left;
		width: 100%;
	}


	.tecno {
	
		float: left;
		position: relative;
		width: calc(100% - 80px);
		margin-left: 0px;
		height: auto;
		padding: 60px;
		padding-bottom: 120px;
		background-color: #0A45C7;
		padding-left: 20px;
	}

	.tecno .contenido ul {
		float: left;
		width: 50%;
		margin: 0px;
		list-style: none;
		margin-left: -40px;
		padding-left: 40px;
	}
	
	.tecno .contenido ul li {
		float: left;
		width: 100%;
		font-size: 21px;
		color: #fff;
		font-weight: 400;
		line-height: 44px;
	}

	.tecno-logos {
	
		float: left;
		position: relative;
		width: calc(100% - 40px);
		margin-left: 0px;
		height: auto;
		padding: 60px;
		padding-left: 20px;
		padding-right: 20px;
		padding-top: 90px;
		padding-bottom: 90px;
		background-color: #0742C3;
	}

	.tecno-logos ul li {
		float: left;
		width: 50%;
		height: 100px;
		text-align: center;
	}
	
	.clientes {
	
		float: left;
		position: relative;
		width: calc(100% - 80px);
		margin-left: 0px;
		height: auto;
		padding: 60px;
		padding-bottom: 120px;
		padding-top: 90px;
		padding-left: 20px;
		background-color: #fff;
	}

	.clientes .contenido .coli {
		float: left;
		width: 100%;
		padding-right: 0px;
	}

	.clientes .contenido .lista ul {
		float: left;
		margin: 0px;
		list-style: none;
		margin-left: -40px;
		padding-left: 40px;
		width: 50%;
	}
	
}

@media screen and (max-width: 1000px) {

	.tecno-logos ul li {
		float: left;
		width: 20%;
		height: 100px;
	}

}

@media screen and (max-width: 600px) {

	.tecno-logos ul li {
		float: left;
		width: 33%;
		height: 100px;
	}

}