body {
    padding: 0;
    margin: 0;
    font-family: "Montserrat";
    color: #171515;
}

ul {
	padding: 0;
	margin: 0;
	list-style: none;
}

a {
	text-decoration: none;
    color: #171515;
}

h1 {
	display: inline-block;
	margin-block-start: 0;
	margin-block-end: 0;
	font-size: inherit;
}

a.button {
	height: 90px;
	line-height: 90px;
	background: #398685;
	border-radius: 45px;
	display: inline-block;
	padding: 0px 60px;
	color: #ffffff;
	font-weight: 600;
}

.clear::after {
	clear: both;
	display: block;
	content: '';
}

/* HEADER */
#header-phantom {
	height: 140px;
}

#header-phantom {
	width: calc(100% - 150px);
	height: 140px;
}

#header-outer {
	position: fixed;
	background: #ffffff;
	width: 100%;
	top: 0;
	z-index: 999;
}

#header-outer.active {
	-webkit-box-shadow: 0px 1px 2px 0px rgba(0,0,0,0.15);
	-moz-box-shadow: 0px 1px 2px 0px rgba(0,0,0,0.15);
	box-shadow: 0px 1px 2px 0px rgba(0,0,0,0.15);
}

#header {
	height: 140px;
	line-height: 140px;
	width: calc(100% - 150px);
	margin: 0 auto;
}

#header-left {
	float: left;
}

#header-logo-url {
	display: inline-block;
	font-size: 30px;
	font-weight: 700;
}

#logo {
	vertical-align: middle;
	margin-right: 15px;
}

#header-right {
	float: right;
}

#mobile-menu-button {
	background-image: url("../images/mobile-menu.png");
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
	width: 40px;
	height: 40px;
	display: block;
	float: right;
	cursor: pointer;
	margin-top: 20px;
	display: none;
}

#mobile-menu-container {
	position: fixed;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 99999;
	display: none;
}

#mobile-menu-content {
	position: absolute;
	right: 0;
	top: 0;
	width: 250px;
	height: 100%;
	background: #ffffff;
}

#mobile-menu-content-blank {
	position: absolute;
	left: 0;
	top: 0;
	width: calc(100% - 250px);
	height: 100%;
	background: rgba(0, 0, 0, 0.2);
}

#mobile-menu-close {
	background-image: url("../images/mobile-menu-close.png");
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
	width: 30px;
	height: 30px;
	position: absolute;
	right: 25px;
	top: 25px;
	cursor: pointer;
}

#mobile-menu {
	margin-top: 80px;
}

#mobile-menu li {
	height: 50px;
	line-height: 50px;
}

#mobile-menu li.active {
	background: #e4f4f2;
}

#mobile-menu li a {
	font-weight: 600;
	display: block;
	padding-left: 40px;
}

#mobile-menu li.active a {
	color: #398685;
}

#mobile-menu-logo {
	background-image: url("../images/logo.png");
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
	width: 36px;
	height: 48px;
	position: absolute;
	bottom: 25px;
	left: 20px;
}

#mobile-menu-dots {
	background-image: url("../images/mobile-menu-dots.png");
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
	width: 90px;
	height: 62px;
	position: absolute;
	bottom: 20px;
	right: 20px;
}

#menu li {
	float: left;
	position: relative;
	margin-left: 45px;
}

#menu li a {
	display: inline-block;
	font-size: 18px;
	font-weight: 600;
}

#menu li span {
	width: 0px;
	height: 3px;
	background: #4db2a7;
	display: block;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: 40px;
	transition: width 0.3s linear;
}

#menu li.active span {
	width: 20px;
}

/* TOP */
#top {
	position: relative;
}

#top-left {
	width: 860px;
	box-sizing: border-box;
	padding-left: 110px;
	padding-right: 80px;
	padding-top: 140px;
	padding-bottom: 170px;
}

#top-right {
	position: absolute;
	right: 0;
	top: 0;
	height: 100%;
	width: calc(100% - 860px);
	background-image: url("../images/top.jpg");
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

#top-left-title {
	font-size: 72px;
	font-weight: 700;
	margin-bottom: 65px;
}

#top-left-description {
	font-size: 24px;
	line-height: 35px;
	margin-bottom: 45px;
}

/* ABOUT */
#about {
	background: #e1eded;
	padding-top: 200px;
	padding-bottom: 200px;
	overflow: hidden;
}

#about-content-block {
	margin: 0 auto;
	width: calc(100% - 460px);
	position: relative;
	box-sizing: border-box;
	-webkit-box-shadow: 0px 2px 2px 0px rgba(39,95,94,0.1);
	-moz-box-shadow: 0px 2px 2px 0px rgba(39,95,94,0.1);
	box-shadow: 0px 2px 2px 0px rgba(39,95,94,0.1);
}

#about-content {
	background: #ffffff;
	border-radius: 10px;
	text-align: center;
	padding: 100px 130px;
	position: relative;
	z-index: 1;
}

#about-title {
	font-weight: 700;
	font-size: 36px;
	margin-bottom: 45px;
}

#about-description {
	font-size: 24px;
	line-height: 35px;
}

#about-dots-bg-1 {
	background: url("../images/dots.png");
	width: 432px;
	height: 432px;
	position: absolute;
    right: -178px;
    top: -118px;
	z-index: 0;
}

#about-dots-bg-2 {
	background: url("../images/dots.png");
	width: 432px;
	height: 432px;
	position: absolute;
    left: -178px;
    bottom: -118px;
	z-index: 0;
}

/* PRODUCTS */
#products {
	width: 1720px;
	margin: 0 auto;
	margin-top: 120px;
	margin-bottom: 150px;
}

#products-top {
	margin-bottom: 85px;
}

#products-top-left {
	float: left;
}

#products-title {
	font-weight: 700;
	font-size: 72px;
}

#products-top-right {
	float: right;
}

.product {
	width: 400px;
	margin-right: 40px;
	box-sizing: border-box;
	border-radius: 10px;
	border: 1px solid #ededed;
	text-align: center;
	padding: 0px 30px;
	height: 400px;
	float: left;
	margin-bottom: 40px;
	padding-top: 50px;
	-webkit-box-shadow: 0px 2px 2px 0px rgba(23,21,21,0.08);
	-moz-box-shadow: 0px 2px 2px 0px rgba(23,21,21,0.08);
	box-shadow: 0px 2px 2px 0px rgba(23,21,21,0.08);
}

.product:nth-child(4n+0) {
	margin-right: 0px;
}

.product-title {
	font-size: 24px;
	font-weight: 600;
	margin-bottom: 23px;
	margin-top: 30px;
}

.product-description {
	font-size: 16px;
	line-height: 22px;
}

#offer {
	position: relative
}

#offer-left {
	width: calc(100% - 860px);	
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	background-image: url("../images/offer.jpg");
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

#offer-right {
	width: 860px;
	box-sizing: border-box;
	float: right;
	padding-left: 60px;
	padding-right: 200px;
	padding-top: 70px;
	padding-bottom: 60px;
}

#offer-title {
	font-weight: 700;
	font-size: 72px;
	margin-bottom: 80px;
}

.offer {
	margin-bottom: 70px;
}

.offer-image {
	float: left;
	width: 90px;
	margin-right: 30px;
}

.offer-image img {
	width: 100%;
}

.offer-data {
	float: left;
	width: calc(100% - 120px);
}

.offer-data-title {
	font-size: 24px;
	font-weight: 600;
	margin-bottom: 25px;
}

.offer-data-description {
	font-size: 16px;
	line-height: 22px;
}

/* CONTACT */
#contact {
	background: #e1eded;
	padding-top: 200px;
	padding-bottom: 200px;
	font-size: 0px;
	text-align: center;
	overflow: hidden;
}

.contact-block {
	display: inline-block;
	margin: 0px 20px;
	position: relative;
	-webkit-box-shadow: 0px 2px 2px 0px rgba(39,95,94,0.1);
	-moz-box-shadow: 0px 2px 2px 0px rgba(39,95,94,0.1);
	box-shadow: 0px 2px 2px 0px rgba(39,95,94,0.1);
}

.contact-block-content {
	width: 710px;
	border-radius: 10px;
	background: #ffffff;
	padding: 110px 0px;
	z-index: 1;
	position: relative;
}

.contact-block-dots-1 {
	background: url("../images/dots.png");
	width: 432px;
	height: 432px;
	position: absolute;
    left: -178px;
    bottom: -118px;
	z-index: 0;
}

.contact-block-dots-2 {
	background: url("../images/dots.png");
	width: 432px;
	height: 432px;
	position: absolute;
    right: -178px;
    top: -118px;
	z-index: 0;
}

.contact-block-title {
	font-size: 36px;
	font-weight: 700;
	margin-bottom: 80px;
}

.contact-block-email {
	font-size: 24px;
	color: #3e63ae;
	display: block;
	margin-bottom: 30px;
}

.contact-block-phone {
	font-size: 24px;
	display: block;
}

/* FOOTER */
#footer {
	background: #171515;
	padding-top: 120px;
	padding-bottom: 120px;
}

#footer-content {
	margin: 0 auto;
	width: calc(100% - 150px);
}

#footer-content-left {
	float: left;
	color: #ffffff;
	font-size: 16px;
	line-height: 46px;
}

#footer-content-left img {
	vertical-align: middle;
	margin-right: 22px;
}

#footer-content-left span {
	color: #4db2a7;
}

#footer-content-right {
	float: right;
}

.footer-data {
	font-size: 16px;
	display: block;
	float: left;
	text-align: right;
	margin-left: 40px;
}

.footer-data-title {
	color: #4db2a7;
	margin-bottom: 8px;
}

.footer-data-data {
	color: #ffffff;
}


@media screen and (max-width: 1740px) {
	
	#products {
		width: 1400px;
	}
	
	.product {
		width: 320px;
	}
	
	.contact-block-content {
		width: 500px;
	}
	
}

@media screen and (max-width: 1440px) {
	
	#products {
		width: 1100px;
	}
	
	.product {
		width: 530px;
	}
	
	.product:nth-child(4n+0) {
		margin-right: 0px;
	}
	
	.product:nth-child(2n+0) {
		margin-right: 0px;
	}
	
	#top-left {
		width: 50%;
	}
	
	#top-right {
		width: 50%;
	}
	
	#top-left-title {
		font-size: 52px;
	}
	
}

@media screen and (max-width: 1200px) {
	
	#contact {
		padding-top: 100px;
    	padding-bottom: 30px;
	}
	
	.contact-block-content {
		width: 700px;
	}
	
	.contact-block {
		margin-bottom: 70px;
	}
	
	#header {
		width: auto;
		padding: 0px 15px;
	}
	
	#header-logo-url {
		font-size: 20px;
	}
	
	#menu li {
	    margin-left: 25px;
	}
	
	#menu li a {
	    font-size: 15px;
	}
	
	#about {
		padding-top: 100px;
    	padding-bottom: 100px;
	}
	
	#about-content-block {
		width: calc(100% - 180px);
	}
	
	#about-content {
		padding: 40px;
	}
	
}

@media screen and (max-width: 1080px) {
	
	#products {
		width: auto;
		padding: 0px 15px;
	}
	
	.product {
		width: auto;
		margin-right: 0px;
		height: auto;
		padding-bottom: 80px;
	}
	
	#footer {
	    padding-top: 70px;
	    padding-bottom: 70px;
	}
	
	#footer-content {
		width: auto;
		padding: 0px 15px;
	}
	
	#footer-content-left {
		float: none;
		width: auto;
		text-align: center;
		margin-bottom: 30px;
	}
	
	#footer-content-left a {
		display: block;
	}
	
	#footer-content-right {
		float: none;
		width: auto;
		text-align: center;
	}
	
	.footer-data {
		float: none;
		display: inline-block;
		text-align: center;
	}
	
	#header {
		height: 80px;
		line-height: 80px;
	}
	
	#header-phantom {
		height: 80px;
	}
	
	#header-right {
		display: none;
	}
	
	#mobile-menu-button {
		display: block;
	}
	
	#top-left {
		float: none;
		width: auto;
		padding-left: 15px;
		padding-right: 15px;
	}
	
	#top-right {
		float: none;
		width: auto;
		height: 300px;
		position: relative;
	}
	
	#offer-left {
		float: none;
		width: auto;
		position: relative;
		height: 300px;
	}
	
	#offer-right {
		float: none;
		width: auto;
		padding-left: 15px;
		padding-right: 15px;
	}
	
}

@media screen and (max-width: 800px) {
	
	#top-left {
		padding-top: 40px;
    	padding-bottom: 40px;
	}
	
}

@media screen and (max-width: 650px) {
	
	#top-right {
		height: 200px;
	}
	
	#footer {
	    padding-top: 60px;
	    padding-bottom: 10px;
	}
	
	.footer-data {
		display: block;
		margin-bottom: 30px;
		margin-left: 0px;
	}
	
	#contact {
	    padding-top: 20px;
	    padding-bottom: 1px;
	}
	
	.contact-block {
		width: auto;
		padding: 0px 15px;
		display: block;
		margin: 0px;
		margin-bottom: 20px;
	}
	
	.contact-block-content {
		width: auto;
		padding: 50px 0px;
	}
	
	.contact-block-title {
	    font-size: 28px;
	    margin-bottom: 42px;
	}
	
	.contact-block-email {
		font-size: 18px;
	}
	
	.contact-block-phone {
		font-size: 18px;
	}
	
	#about {
	    padding-top: 20px;
	    padding-bottom: 20px;
	}
	
	#about-content-block {
		width: auto;
		padding: 0px 15px;
	}
	
	#about-content {
		padding: 20px;
	}
	
	#about-title {
		font-size: 26px;
		margin-bottom: 15px;
	}
	
	#about-description {
	    font-size: 14px;
	    line-height: 25px;
	}
	
	#top-left-title {
		font-size: 32px;
		margin-bottom: 30px;
	}
	
	#top-left-description {
	    font-size: 18px;
	    line-height: 28px;
	    margin-bottom: 25px;
	}
	
	a.button {
	    height: 60px;
	    line-height: 60px;
	    border-radius: 30px;
	    padding: 0px 30px;
	    font-size: 15px;
	}
	
	#products {
		margin-top: 30px;
		margin-bottom: 0px;
	}
	
	#products-top {
		margin-bottom: 35px;
	}
	
	#products-top-right {
		display: none;
	}
	
	#products-top-left {
		float: none;
		width: auto;
	}
	
	#products-title {
		font-size: 32px;
		text-align: center;
	}
	
	#offer-left {
		height: 200px;
	}
	
	#offer-right {
		padding-bottom: 0px;
		padding-top: 40px;
	}
	
	#offer-title {
		text-align: center;
		font-size: 32px;
		margin-bottom: 30px;
	}
	
	.offer {
	    margin-bottom: 40px;
	}
	
	.offer-image {
	    width: 60px;
	    margin-right: 20px;
	}
	
	.offer-data {
	    width: calc(100% - 80px);
	}
	
	.offer-data-title {
		font-size: 19px;
		margin-bottom: 10px;
	}
	
	.offer-data-description {
		font-size: 15px;
		line-height: 20px;
	}
		
}