html {
	box-sizing: border-box;
	height: 100%;
}

*, *:before, *:after {
	box-sizing: inherit
}

body {
	height: 100%;
	line-height: 1.8;
	font-family: 'Raleway', sans-serif;
	font-size: 15px;
    margin: 0;
}

.topnav {
	top: 0;
	position: fixed;
	width: 100%;
	z-index: 1;
	color: #000;
	background-color: #fff;
	box-shadow: 0 2px 5px 0 rgba(0,0,0,0.16),0 2px 10px 0 rgba(0,0,0,0.12);
	width: 100%;
	overflow: hidden;
}

.topnav::before, .topnav::after, #productos::before {
	content: "";
	display: table;
	clear: both;
}

.topnav .logo, .topnav .links a {
    padding: 16px;
	white-space: normal;
	float: left;
	width: auto;
	border: none;
	outline: none;
	display: block;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	vertical-align: middle;
	overflow: hidden;
    text-decoration: none;
	color: inherit;
	background-color: inherit;
    text-align: center;
}

.topnav .logo {
	padding: 0;
	cursor: pointer;
}

.topnav .logo img {
	padding: 8px 11px;
	display: block;
	width: 123px;
	height: 59px;
}

.topnav .links {
	float: right;
	cursor: pointer;
}

.topnav .links a:hover {
    background-color: #ddd;
    color: black;
}

.topnav .links .icon {
    display: none;
}

.topnav .filler {
	float: left;
    padding-top: 45px;
}

#top {
	height: 60px;
}

.header {
	background-image: url("img/infinity.jpg");
	background-position: center;
	background-size: cover;
	min-height: 100%;
}

.content {
	text-align: justify;
	padding-left: 14px;
	padding-right: 14px;
}

.content h2 {
	text-align: center;
	font-weight: normal;
}

.content h3 {
	text-align: center;
	font-weight: normal;
}

#inicio, #productos, #contacto {
	padding-top: 60px;
}

#contacto {
	width: 33.3%;
	margin: auto;
}

#inicio {
	overflow: auto;
	width: 100%;
}

#quienes-somos {
	text-align: center;
	width: 67%;
	margin: auto;
	padding-bottom: 20px;
}

#implementacion {
	width: 67%;
	margin: auto;
}

#implementacion li {
	list-style-image:url("img/check.png");
}

.half-mainSections {
	width: 50%;
	float: left;
}

.mainSections {
	width: 50%;
	float: left;
	padding: 40px 15px 0 15px;
}

.section-image {
	height: 100px;
	width: auto;
	display: block;
	margin: auto;
}

.footer {
    background-color: #000;
    overflow: hidden;
	line-height: 1;
	margin-top: 5px;
    color: #f2f2f2;
    text-align: left;
    font-size: 14px;
	padding-top: 5px;
	padding-bottom: 20px;
}

.footer .footerLeft {
    float: left;
}

.footer .footerRight {
    float: right;
}

.footer a {
    display: block;
    padding: 10px 16px;
    text-decoration: none;
	cursor: pointer;
}

.footer p {
    display: block;
    padding: 10px 16px;
	margin: 0;
}

.footer a:hover {
    text-decoration: underline;
}

@media screen and (max-width: 1200px) {
	.half-mainSections {
		width: 100%;
	}
}

@media screen and (max-width: 1000px) {
	#contacto {
		width: 50%;
		margin: auto;
	}
}

@media screen and (max-width: 750px) {
	.header {
		min-height: 60%;
	}

	#contacto {
		width: 80%;
		margin: auto;
	}
}

@media screen and (max-width: 700px) {
	.mainSections {
		width: 100%;
	}
}

@media screen and (max-width: 550px) {
	.topnav .links a {display: none;}
	.topnav .links a.icon {
		float: right;
		display: block;
	}

	.topnav.responsive {position: fixed;}
	.topnav.responsive .links a.icon {
		position: absolute;
		right: 0;
		top: 0;
	}
	.topnav.responsive .links a {
		float: none;
		display: block;
		text-align: left;
	}
}

@media screen and (max-width: 450px) {
	.header {
		min-height: 40%;
	}
}

@media screen and (max-width: 290px) {
	.header {
		min-height: 30%;
	}
}
