html, body {
	margin: 0;
	padding: 0;
}
.wide {
	width: 100%;
	margin: 0;
	padding: 0;
	position: relative;
}
.block {
	margin: 0 auto;
	max-width: 1200px;
	position: relative;
	padding-right: 20px;
	padding-left: 20px;
}
.indent {
	margin-top: 55px!important;
}
.background {
	position: relative;
	background-image: url(../img/bg.jpg);
	background-size: cover;
	background-position: center center;
}
.background .inner {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-pack: space-evenly;
	    -ms-flex-pack: space-evenly;
	        justify-content: space-evenly;
	width: 100%;
	min-height: 150px;
	padding: 25px 0;
}
.overlay {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}
.header {
	display: -ms-grid;
	display: grid;
	-ms-grid-columns: 30% 2vw 1fr;
	grid-template-columns: 30% 1fr;
	grid-gap: 2vw;
}
.menu {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	/*display: grid;
	grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
	grid-gap: 2vw;*/
}
.promo {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}
.breadcrumbs {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: start;
	margin-top: 22px;
	margin-bottom: 44px;
}
.breadcrumbs div {
	margin: 0 10px;
}
.middle {
	display: -ms-grid;
	display: grid;
	-ms-grid-columns: 265px 40px 1fr;
	grid-template-columns: 265px 1fr;
	grid-gap: 40px;
}
.table {
	border-collapse: collapse;
}
.table-scroll-x {
	overflow: auto;
	max-width: 100%;
	white-space: nowrap;
}
.scheme-of-work {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	counter-reset: scheme-counter;
	padding: 0;
	margin: 0;
}
.scheme-of-work li {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	text-align: center;
}
.scheme-of-work li i {
	font-size: 55px;
	z-index: 1;
	position: relative;
	background: -o-linear-gradient(315deg, #6194dd, #195cb8);
	background: linear-gradient(135deg, #dd9f61, #b81919);
	color: transparent;
	-webkit-background-clip: text;
	text-decoration: none;
}
.scheme-of-work li .text {
	z-index: 1;
	position: relative;
	line-height: 20px;
}
.scheme-of-work li:before {
	position: absolute;
	top: 30px;
	left: -20px;
	width: 100%;
	height: 100%;
	content: counter(scheme-counter);
	counter-increment: scheme-counter;
	font-size: 150px;
	z-index: 0;
	color: #f3f3f3;
	line-height: 150px;
}
.our-clients {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}
.our-clients img {
	opacity: 0.6;
	max-width: 120px;
}
.footer {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: start;
	padding-top: 55px;
	padding-bottom: 40px;
}
.footer .menu {
	display: -ms-grid;
	display: grid;
	-ms-grid-rows: 1fr 15px 1fr;
	grid-template-rows: 1fr 1fr;
	-ms-grid-columns: 1fr 30px 1fr;
	grid-template-columns: 1fr 1fr;
	grid-gap: 15px 30px;
}
.footer .menu > *:nth-child(1) {
	-ms-grid-row: 1;
	-ms-grid-column: 1;
}
.footer .menu > *:nth-child(2) {
	-ms-grid-row: 1;
	-ms-grid-column: 3;
}
.footer .menu > *:nth-child(3) {
	-ms-grid-row: 3;
	-ms-grid-column: 1;
}
.footer .menu > *:nth-child(4) {
	-ms-grid-row: 3;
	-ms-grid-column: 3;
}
.footer .contacts {
	display: -ms-grid;
	display: grid;
	-ms-grid-rows: auto 15px auto 15px auto;
	grid-template-rows: auto auto auto;
	-ms-grid-columns: 1fr;
	grid-template-columns: 1fr;
	grid-gap: 15px 0;
}
.footer .contacts > *:nth-child(1) {
	-ms-grid-row: 1;
	-ms-grid-column: 1;
}
.footer .contacts > *:nth-child(2) {
	-ms-grid-row: 3;
	-ms-grid-column: 1;
}
.footer .contacts > *:nth-child(3) {
	-ms-grid-row: 5;
	-ms-grid-column: 1;
}
.modal {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 999;
    display: none;
}
.modal .bg {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: #ffffffc4;
}
.modal .form {
    margin: 10% auto 0;
    width: 40%;
    min-width: 400px;
    background: #fff;
    position: relative;
    padding: 35px;
    box-shadow: 0px 0px 10px #00000038;
}
.modal .form .form-body {
	display: grid;
	grid-gap: 10px;
}
.modal .form .form-footer {
	display: grid;
	grid-template-columns: auto auto;
	grid-gap: 25px;
	margin: 40px;
}
.modal input {
    color: #555;
    border: 1px solid #ccc;
    padding: 15px 15px;
    font-size: 14px;
    background: transparent;
    text-transform: uppercase;
    font-weight: 700;
}
.modal input.empty-required {
	border-color: red;
}
.modal button.submit {
	background: #84bb0a;
	color: #fff;
	border: none;
}
.modal .form .privacy-info {
	font-size: 13px;
	color: #666;
	width: 200px;
}
.modal .form .close {
    position: absolute;
    right: 20px;
    top: 20px;
    font-size: 30px;
    cursor: pointer;
}