@charset "utf-8";

/* CSS Document */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

html,
body {
	width: 100%;
	height: auto;
	/*  overflow-x: hidden;*/
	background-color: #181818;
	color: #fff
}

/*
.c-scrollbar {
  z-index: 9999999999;
}
*/
.content {
	padding-top: 8%;
	padding-bottom: 8%;
}

@media(max-width:991px) {
	.content {
		padding-top: 18%;
		padding-bottom: 18%;
	}
}

.padding {
	padding-left: 5vw;
	padding-right: 5vw;
}

@media(max-width:1080px) {
	.padding {
		padding-left: 4%;
		padding-right: 4%
	}
}

.no-padding-left {
	padding-left: 0%;
	padding-right: 10%
}

@media(max-width:1024px) {
	.no-padding-left {
		padding-left: 0%;
		padding-right: 5%
	}
}

@media(max-width:991px) {
	.no-padding-left {
		padding-left: 2%;
		padding-right: 2%
	}
}

.no-padding-right {
	padding-left: 10%;
	padding-right: 0%
}

@media(max-width:1024px) {
	.no-padding-right {
		padding-left: 5%;
		padding-right: 0%
	}
}

@media(max-width:991px) {
	.no-padding-right {
		padding-left: 2%;
		padding-right: 2%
	}
}

body,
td,
th,
#submitButton,
textarea,
input,
select {
	color: #fff;
	font-size: calc(17px + (19 - 17) * ((100vw - 640px) / (1920 - 640)));
	line-height: 1.4;
	font-family: 'Rubik', sans-serif;
}

.main-preloader {
	position: fixed;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 1000000001;
	background-color: #232323;
	text-align: center;
}

.main-preloader .main-preloader-inner {
	position: absolute;
	top: 48vh;
	width: 100%;
}

.main-preloader .preloader-percentage {
	color: #fff;
	margin: 0;
}

.main-preloader .preloader-percentage span {
	display: inline-block;
	float: none;
	font-size: 20px;
}

.loader {
	width: 100px;
	height: 100px;
	position: absolute;
	left: 50%;
	transform: translate(-50%, -50%);

}

.title {
	font-weight: 400
}

.loco-scroll {
	overflow: hidden !important;
}

h1 {
	font-size: calc(50px + (100 - 50) * ((100vw - 640px) / (1920 - 640)));
	font-weight: 700;

	line-height: 1.5;
}

h2 {
	font-size: calc(40px + (80 - 40) * ((100vw - 640px) / (1920 - 640)));
	font-weight: 700;

	line-height: 1.5;
}

h3 {
	font-size: calc(35px + (70 - 35) * ((100vw - 640px) / (1920 - 640)));
	font-weight: 700;

	line-height: 1.3;
}

h4 {
	font-size: calc(35px + (50 - 35) * ((100vw - 640px) / (1920 - 640)));
	font-weight: 700;

	line-height: 1.3;
}

h5 {
	font-size: calc(22px + (30 - 22) * ((100vw - 640px) / (1920 - 640)));
	font-weight: 700;

	line-height: 1.5;
}

h6 {
	font-size: calc(20px + (22 - 20) * ((100vw - 640px) / (1920 - 640)));

	line-height: 1.5;
}

.description,
.title {
	padding-top: 0%;
	padding-bottom: 0%;
}

a {
	color: #434343;
	text-decoration: none;
}

a:hover,
a:focus {
	text-decoration: none;
	color: #434343;
}


.mask {
	z-index: -1;
	/*  height: 100%;*/
	width: 100%;
	overflow: hidden;
	transition: all 0.8s ease-in-out;
	-webkit-transition: all 0.8s ease-in-out;
	-moz-transition: all 0.8s ease-in-out;
	-ms-transition: all 0.8s ease-in-out;
	-o-transition: all 0.8s ease-in-out;
}

.mask img {
	display: block;
	height: 100%;
	width: 100%;
	-o-object-fit: cover;
	object-fit: cover;
	-o-object-position: center;
	object-position: center;
	transform-origin: left;
}

.img-wrapper img {
	width: 100%;
	opacity: 1;
	transform: scale(1.8) !important;
	transition: all 2.52s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform-origin: center;
}

.img-wrapper.is-inview img {
	opacity: 1;
	transform: scale(1) !important;
	transition-delay: .5s;
	transform-origin: center;
}

.btn-1 {
	background-color: #cc0000;
	color: #fff;
	outline: none;
	padding: 15px 20px;
	transition: all 0.4s ease-in-out;
	-webkit-transition: all 0.4s ease-in-out;
	-moz-transition: all 0.4s ease-in-out;
	-ms-transition: all 0.4s ease-in-out;
	-o-transition: all 0.4s ease-in-out;
	border-radius: 4px;
	font-weight: 500;
	letter-spacing: 0px;
	border: none;
	font-size: 17px;

}

.btn-1:hover,
.btn-1:focus {
	background: #990000;
	color: #fff;
	transition: all 0.4s ease-in-out;
	-webkit-transition: all 0.4s ease-in-out;
	-moz-transition: all 0.4s ease-in-out;
	-ms-transition: all 0.4s ease-in-out;
	-o-transition: all 0.4s ease-in-out;
	text-decoration: none;
}

.btn-white {
	background-color: transparent;
	border: 1px solid #FFFFFF;
}

.btn-white:hover,
.btn-white:focus {
	background-color: transparent;
	border: 1px solid #FFFFFF;
}

.btn-1-xs {
	padding: 10px 30px;
	border-radius: 5px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 1px;
	font-size: 15px;
}

.btn-submit {
	background-color: #333;
	color: #fff;
	outline: none;
	padding: 12px 30px;
	transition: all 0.4s ease-in-out;
	-webkit-transition: all 0.4s ease-in-out;
	-moz-transition: all 0.4s ease-in-out;
	-ms-transition: all 0.4s ease-in-out;
	-o-transition: all 0.4s ease-in-out;
	border-radius: 25px;
	font-weight: 300;
	letter-spacing: 0px;
	border: none;
	font-size: 17px;
	font-style: italic
}

.btn-submit:hover,
.btn-submit:focus {
	background: #000;
	color: #fff;
	transition: all 0.4s ease-in-out;
	-webkit-transition: all 0.4s ease-in-out;
	-moz-transition: all 0.4s ease-in-out;
	-ms-transition: all 0.4s ease-in-out;
	-o-transition: all 0.4s ease-in-out;
	text-decoration: none;
}


.hero {
	background-color: #232323;
	color: #fff;
	height: 100vh;
	position: relative
}

@media(max-width:991px) {
	.hero {

		height: 97vh;

	}
}

.hero .arrows {
	width: 60px;
	height: 72px;
	position: absolute;
	left: 50%;
	margin-left: -30px;
	bottom: 20px;
	z-index: 1;
}

.hero .arrows path {
	stroke: #fff;
	fill: transparent;
	stroke-width: 1px;
	animation: arrow 1s infinite;
	-webkit-animation: arrow 2s infinite;
}

@keyframes arrow {
	0% {
		opacity: 0
	}

	40% {
		opacity: 1
	}

	80% {
		opacity: 0
	}

	100% {
		opacity: 0
	}
}

@-webkit-keyframes arrow

/*Safari and Chrome*/
	{
	0% {
		opacity: 0
	}

	40% {
		opacity: 1
	}

	80% {
		opacity: 0
	}

	100% {
		opacity: 0
	}
}

.hero .arrows path.a1 {
	animation-delay: -1s;
	-webkit-animation-delay: -1s;
	/* Safari Chrome */
}

.hero .arrows path.a2 {
	animation-delay: -0.5s;
	-webkit-animation-delay: -0.5s;
	/* Safari Chrome */
}

.hero .arrows path.a3 {
	animation-delay: 0s;
	-webkit-animation-delay: 0s;
	/* Safari Chrome */
}


.home-assembly {
	position: relative;
	overflow: hidden;
	padding-bottom: 15vmax;
	padding-top: 15vmax;
	background-color: #000000;
	color: #fff
}

@media(max-width:991px) {
	.home-assembly {
		padding-bottom: 18vmax;
		padding-top: 18vmax;

	}
}

@media(min-width:991px) {
	.home-assembly .box {
		padding-right: 6vw;
		padding-left: 6vw
	}
}

.caption {
	position: relative;
	z-index: 1;
}

.banner {
	position: absolute;
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: cover;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;

}

.home-assembly h5 {
	color: #fff;
	font-weight: 400;
	line-height: 1.4;
	text-transform: uppercase;
}


.home-service {
	color: #fff
}


.home-service a.box {
	position: relative;
	background-color: #2d2d2d;
	text-align: center;
	color: #fff;
	padding: 25px;
	border-radius: 21px;
	border-bottom: 8px solid #D71922;
	margin-bottom: 25px;
	transition: all 0.4s ease-in-out;
	-webkit-transition: all 0.4s ease-in-out;
	-moz-transition: all 0.4s ease-in-out;
	-ms-transition: all 0.4s ease-in-out;
	-o-transition: all 0.4s ease-in-out;
}

.home-service a.box:hover {
	transition: all 0.4s ease-in-out;
	-webkit-transition: all 0.4s ease-in-out;
	-moz-transition: all 0.4s ease-in-out;
	-ms-transition: all 0.4s ease-in-out;
	-o-transition: all 0.4s ease-in-out;
	background-color: #181818;
}

.home-service .box .description {
	margin-bottom: 42px;
	color: #fff
}

.home-service .box .more {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 25px
}

.home-service a .more {
	color: rgba(164, 164, 164, 0.5);
	font-size: 17px;
	letter-spacing: 1px;
	font-weight: 500;
	transition: all 0.4s ease-in-out;
	-webkit-transition: all 0.4s ease-in-out;
	-moz-transition: all 0.4s ease-in-out;
	-ms-transition: all 0.4s ease-in-out;
	-o-transition: all 0.4s ease-in-out;
}

.home-service a:hover .more {
	color: rgba(164, 164, 164, 1);
	transition: all 0.4s ease-in-out;
	-webkit-transition: all 0.4s ease-in-out;
	-moz-transition: all 0.4s ease-in-out;
	-ms-transition: all 0.4s ease-in-out;
	-o-transition: all 0.4s ease-in-out;

}

.home-service-2 {
	background-color: #2D2D2D;
	color: #fff
}

@media(min-width:991px) {
	.home-service-2 .box {
		padding-left: 10vw;
		padding-right: 10vw;
		color: #fff
	}

}


.partners {
	color: #fff
}


.partners img {
	transition: all 0.4s ease-in-out;
	-webkit-transition: all 0.4s ease-in-out;
	-moz-transition: all 0.4s ease-in-out;
	-ms-transition: all 0.4s ease-in-out;
	-o-transition: all 0.4s ease-in-out;
	filter: grayscale(1);
}

.partners img:hover {
	transition: all 0.4s ease-in-out;
	-webkit-transition: all 0.4s ease-in-out;
	-moz-transition: all 0.4s ease-in-out;
	-ms-transition: all 0.4s ease-in-out;
	-o-transition: all 0.4s ease-in-out;
	filter: grayscale(0);
}


.service a {
	color: rgba(255, 255, 255, 0.35);
	text-decoration: underline
}

.service a:hover {
	color: #D71922
}

.service .bi {
	color: #D71922
}

.service h4 {
	font-size: calc(30px + (45 - 30) * ((100vw - 640px) / (1920 - 640)));
	font-weight: 700;

	line-height: 1.3;
}

.contacts .icon-box {
	width: 60px;
	height: 60px;
	background: rgba(35, 35, 35, 1.00);
	text-align: center;
	border-radius: 100px;
	margin-right: auto;
	margin-left: auto;
	font-size: 30px
}

.contacts .name {
	font-size: calc(20px + (22 - 20) * ((100vw - 640px) / (1920 - 640)));
	font-weight: 500
}

.contacts .position {
	font-size: calc(17px + (18 - 17) * ((100vw - 640px) / (1920 - 640)));
	font-style: italic;
	opacity: 0.8
}

.contacts .mail a {
	color: #D71922
}

.contacts .mail a:hover {
	color: #D71922;
	text-decoration: underline
}

.contacts .specification {
	font-size: calc(14px + (15 - 14) * ((100vw - 640px) / (1920 - 640)));
	opacity: 0.6;
	font-weight: 300
}

.footer {
	position: relative;
	height: 95vh;
	width: 100%;
	right: 0;
	transition: right 0.4s ease;
	z-index: 4;
	background-image: url(images/footer.jpg);
	background-repeat: no-repeat;
	background-position: left center;
	background-size: cover;
	color: #fff;
	font-size: calc(18px + (21 - 18) * ((100vw - 640px) / (1920 - 640)));
}

.footer.active {
	right: 50%;
}

.footer .but-map {
	background-color: rgba(255, 255, 255, 0.00);
	height: 45px;
	width: 45px;
	position: absolute;
	top: 50%;
	right: 45px;
	cusror: pointer;
	z-index: inherit;
	cursor: pointer;
	border-radius: 100%;
	transform: rotate(180deg);
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.47);
}

.footer .seemap {
	position: absolute;
	transform: rotate(-90deg);
	top: 51.5%;
	right: 5px;
	font-size: 10px;
	text-transform: uppercase;
	text-align: center;
	opacity: 1;
	letter-spacing: 4px;
	transform-origin: center;

}

.footer .but-map.active {
	transform: rotate(0deg);
	transition: transform 0.55s ease, padding 0.2s ease, right 0.4s ease;
}

.footer div.map {
	height: 100%;
	width: 50%;
	position: absolute;
	background: #F3F3F3;
	top: 0;
	right: -50%;
	z-index: inherit;
	transition: right 0.4s ease;
}

.footer div.map.show {
	right: -50%;
}

/*
.footer .addres{
    position: static
}
*/
.footer .addres a {
	color: #fff
}

.footer .addres a:hover {
	color: #CC0000
}

.footer .addres .social .wrapper {
	padding-top: 15px;
	padding-right: 15px;
	padding-left: 0px;
	padding-bottom: 15px
}

.footer .addres .social .bi {
	font-size: 28px;

}

.sub-footer {
	position: absolute;
	left: 6%;
	bottom: 25px;
	color: #fff;
	font-size: 14px
}

.sub-footer a {
	color: #fff
}

.map-xs {
	height: 40vh
}

/* ! Animations */

.fade-left {
	opacity: 1;
	transition: all 2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateX(-100%);
	transition-delay: 0.5s;
}

.fade-left.is-inview {
	opacity: 1;
	transform: translateX(0px);
}

.fade-right {
	opacity: 1;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateX(30%);
	transition-delay: 0.5s;
}

.fade-right.is-inview {
	opacity: 1;
	transform: translateX(0px);
}

.fade-up {
	opacity: 1;
	transition: all 2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(30%);
	transition-delay: 0s;
}

.fade-up.is-inview {
	opacity: 1;
	transform: translateY(0px);
}

.fade-down {
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateX(10%);
	transition-delay: 0.5s;
}

.fade-down.is-inview {
	opacity: 1;
	transform: translateX(0px);
}

.fade {
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: 0.5s;
}

.fade.is-inview {
	opacity: 1;
}

.reveal-top {
	height: 0;
	overflow: hidden;
	transition: all 1.52s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: 0.5s;
}

.reveal-top.is-inview {
	height: 100%;
}

.reveal-left {
	width: 0;
	overflow: hidden;
	transition: all 1.52s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: 0.5s;
}

.reveal-left.is-inview {
	width: 100%;
}

.zoom-in {
	opacity: 1;
	transform: scale(1.5);
	transition: all 2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: 0.5s;
}

.zoom-in.is-inview {
	opacity: 1;
	transform: scale(1);
}

.text-reveal {
	overflow: hidden;
	display: block;
}

.text-reveal {
	display: inline-block;
	will-change: transform;
	transform: translate3d(0, 100%, 0);
	transition: all 3s cubic-bezier(.15, .61, .16, .97);
}

.text-reveal.is-inview {
	transform: none;
}

.delay-1 {
	transition-delay: 0.1s !important;
}

.delay-2 {
	transition-delay: 0.2s !important;
}

.delay-3 {
	transition-delay: 0.3s !important;
}

.delay-4 {
	transition-delay: 0.4s !important;
}

.delay-5 {
	transition-delay: 0.5s !important;
}

.delay-6 {
	transition-delay: 0.6s !important;
}

.delay-7 {
	transition-delay: 0.7s !important;
}

.delay-8 {
	transition-delay: 0.8s !important;
}

.delay-9 {
	transition-delay: 0.9s !important;
}

.delay-10 {
	transition-delay: 1s !important;
}

.hover-div {
	margin: 0 auto;
	position: relative;
	overflow: hidden;
}

.hover-div img {
	width: 100%;
	transition: all ease-in-out .5s;
}

.hover-div:hover img {
	transition: all ease-in-out .5s;
	opacity: 1;
	transform: scale(1.2);
}

.clients .hover-div {
	background-color: #666666;
}

/* ! Animations */