* { margin: 0; padding: 0;}
p { margin: 5px 0 10px 0; }
a, a:hover, a:active, a:focus{
	color: inherit;
	text-decoration: none;
	outline: none;
}
html {
	min-height: 100vh;
}

body {
	font-family: "stolzl", sans-serif;
	font-weight: 400;
	color: #fff;
	line-height: 1.5;
	margin: auto;
	background: #222222;
}

.wrapper {
	max-width: 1400px;
	padding: 0 20px;
	margin: 0 auto;
	position: relative;
	z-index: 2;
}

header {
	position: relative;
	background: #292929;
	overflow: hidden;
}

section {
	padding: 70px 0;
	overflow: hidden;
}

section:nth-child(2n) {
	background: #222;
}

section:nth-child(2n+1) {
	background: #292929;
}

.main_bg {
	position: absolute;
	z-index: 1;
	width: 100%;
	height: 100%;
	background-position: center;
	background-size: cover;
	animation: main_scale 20s ease;
}

.main_block {
	position: relative;
	z-index: 2;
	background: rgba(0,0,0,0.3);
	padding-top: 25px;
	padding-bottom: 0.1px;
}

@keyframes main_scale {
  from {
    transform: scale(1.2);
  }
  to {
    transform: scale(1)
  }
}

.vn_block {
	position: relative;
	overflow:hidden;
	z-index: 2;
	padding-top: 25px;
	padding-bottom: 50px;
}

.head_line {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	justify-content: space-between;
	-ms-align-items: center;
	align-items: center;
	padding-bottom: 10px;
}

.logo {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: center;
	align-items: center;
	width: 200px;
}

.logo img {
	width: 200px;
}

.logo p {
	font-size: 21px;
	font-weight: 500;
	line-height: 1.2;
	margin-top: 0;
	margin-bottom: 0;
	margin-left: 20px;
}

.menu_block {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: center;
	align-items: center;
}


.desk_menu {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: center;
	align-items: center;
	list-style-type: none;
	margin: 0;
}

.desk_menu li {
	margin: 0 25px;
	padding: 5px 0;
	position: relative;
}

.desk_menu li::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 0;
	height: 1px;
	transition: 0.2s ease all;
}

.desk_menu li:hover::after {
	width: 100%;
	left: 0;
}

.desk_menu li a {
	margin: 0;
	line-height: 1;
	font-size: 15px;
}

.mob_menu {
	display: none;
}

.mob_menu img {
	width: 25px;
}

.menu_mob {
	margin-top: 15px;
	margin-bottom: 0;
	list-style-type: none;
}

.mob_vnutr .logo {
	margin-left: auto;
	margin-right: auto;
}

.menu_mob li {
	width: 100%;
	text-align: center;
	border-bottom-width: 1px;
	border-bottom-style: solid;
}

.menu_mob li:last-child {
	border: none;
}

.menu_mob li a {
	display: table;
	width: 100%;
	padding: 15px 0;
	font-weight: 500;
	font-size: 15px;
}

.phone_head {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: center;
	align-items: center;
	background: #292929;
	overflow: hidden;
	border-radius: 10px;
	margin-left: 25px;
	transition: 0.3s ease all;
}

.phone_head:hover {
	color: #222;
}

.tel {
	display: block;
	font-weight: 500;
	font-size: 21px;
	padding: 10px 20px;
}

.callback {
	display: block;
	border-radius: 10px;
	padding: 9px;
}

.callback img {
	width: 24px;
	display: block;
}

.utp_row {
	margin: 200px 0 250px;
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: center;
	align-items: center;
	justify-content: space-between;
}

.utp_block {
	width: 60%;
	padding-top: 50px;
	position: relative;
	filter: drop-shadow(0 0 10px black);
}

.utp_block:after {
	content: "";
	position: absolute;
	top:0;
	left: 0;
	width: 100px;
	height: 2px;
}

.utp_block h1 {
	font-size: 36px;
	font-weight: 500;
	line-height: 1.2;
	margin: 0;
}

.slogan {
	font-size: 15px;
	margin: 50px 0;
}

.buts-row {
	display: flex;
	align-items: center;
}

.main_butt {
	display: table;
	position: relative;
	padding: 25px 110px 25px 40px;
	background: #292929;
	border-radius: 10px;
	overflow: hidden;
	text-transform: uppercase;
	font-size: 14px;
	line-height: 1;
}

.main_butt:before {
	content: "";
	position: absolute;
	width: 70px;
	height: 100%;
	top: 0;
	right: 0;
	background-image: url(../img/arr_y_down.svg);
	background-repeat: no-repeat;
	background-position: center;
	background-color: #222;
}


.main_butt::after {
	content: "";
	position: absolute;
	width: 70px;
	height: 100%;
	top: 0;
	right: 0;
	background-image: url(../img/arr_b_down.svg);
	background-repeat: no-repeat;
	background-position: center;
	opacity: 0;
	transition: 0.2s ease all;
}

.main_butt:hover:after {
	opacity: 1;
}

.main_butt2 {
	margin-left: 50px;
	display: table;
	position: relative;
	padding: 25px 105px 25px 35px;
	background: #231d0a;
	border-radius: 10px;
	overflow: hidden;
	text-transform: uppercase;
	font-size: 16px;
	line-height: 1;
	transition: 0.3s ease all;
}


.main_butt2::after {
	content: "";
	position: absolute;
	width: 70px;
	height: 100%;
	top: 0;
	right: 0;
	background-image: url(../img/arr_black.svg);
	background-repeat: no-repeat;
	background-position: center;
}

.about_cifs {
	width: 40%;
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;
	filter: drop-shadow(0 0 10px black);
}

.ac_one {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: flex-end;
	align-items: flex-end;
	margin-bottom: 30px;
}

.ac_cif {
	font-weight: 300;
	font-size: 75px;
	line-height: 1;
	margin-right: 20px;
}

.ac_one p {
	margin: 0;
	font-weight: 500;
	font-size: 24px;
	line-height: 1.8;
	text-transform: uppercase;
}

.icos_row {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-ms-align-items: center;
	align-items: center;
	justify-content: space-between;
	background: #292929;
	border-top-left-radius: 10px;
	border-top-right-radius: 10px;
	padding: 15px;
}

.ico_col {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: center;
	align-items: center;
	padding: 10px 2%;
	width: 24%;
	border-right-width: 1px;
	border-right-style: solid;
}

.ico_col:last-child {
	border: none;
}

.ico_col img {
	width: 50px;
	margin-right: 25px;
}

.ico_col p {
	font-size: 14px;
	line-height: 1.25;
	margin: 0;
}

.preim_row {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	flex-wrap: wrap;
}

.preim_col {
	width: 31%;
	border-radius: 10px;
	background: #292929;
	padding: 30px;
	margin-bottom: 40px;
}

.preim_zag {
	display: flex;
	align-items: center;
	margin-bottom: 20px;
}

.preim_zag img {
	width: 40px;
	margin-right: 15px;
}

.preim_zag p {
	font-weight: 500;
	font-size: 17px;
	margin: 0;
}

.preim_body {
	font-size: 15px;
	font-weight: 400;
}

section h2 {
	position: relative;
	display: block;
	font-weight: 500;
	font-size: 30px;
	padding-bottom: 30px;
	margin-top: 0;
	margin-bottom: 50px;
	border-bottom: 1px solid #707070;
}

section h2:after {
	content: "";
	position: absolute;
	height: 1px;
	width: 100px;
	bottom: -1px;
	left: 0;
}

.about_row {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: stretch;
	align-items: stretch;
	justify-content: space-between;
	margin-bottom: 80px;
}

.about_img {
	width: 44%;
	border-radius: 10px;
	background-position: center;
	-webkit-background-size: cover;
	background-size: cover;
}

.about_text {
	width: 50%;
}

.about_text h3 {
	font-weight: 500;
	font-size: 30px;
	margin-top: 0;
	margin-bottom: 30px;
}

.about_text p {
	font-size: 15px;
	font-weight: 300;
	line-height: 2;
	margin-bottom: 30px;
}

.about_butt {
		display: table;
		position: relative;
		padding: 25px 105px 25px 35px;
		background: #292929;
		border-radius: 10px;
		overflow: hidden;
		text-transform: uppercase;
		font-size: 14px;
		line-height: 1;
	}

	.about_butt:before {
		content: "";
		position: absolute;
		width: 70px;
		height: 100%;
		top: 0;
		right: 0;
		background-image: url(../img/arr_right.svg);
		background-repeat: no-repeat;
		background-position: center;
		background-color: #222;
	}

	.about_butt::after {
		content: "";
		position: absolute;
		width: 70px;
		height: 100%;
		top: 0;
		right: 0;
		background-image: url(../img/arr_black.svg);
		background-repeat: no-repeat;
		background-position: center;
		opacity: 0;
		transition: 0.2s ease all;
	}

	.about_butt:hover:after {
		opacity: 1;
	}

	.cifs_row {
		width: 86%;
		border-radius: 10px;
		margin: 0 auto;
		background: #292929;
		padding: 25px 0;
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-ms-align-items: flex-start;
		align-items: flex-start;
		justify-content: center;
	}

	.cif_col {
		width: 33%;
		padding: 15px 4%;
		text-align: center;
		border-right-width: 1px;
		border-right-style: solid;
	}

	.cif_col:last-child {
		border: none;
	}

	.cif {
		font-weight: 500;
		font-size: 80px;
		line-height: 1;
		margin-bottom: 25px;
	}

	.cif_col p {
		text-transform: uppercase;
		font-size: 17px;
		margin: 0;
	}

	.serv_info {
		width: 35%;
		min-height: 400px;
	}

	.serv_info p {
		font-size: 15px;
		font-weight: 300;
		line-height: 2;
		margin-bottom: 50px;
	}

	.services_block {
		position: absolute;
		top:-25px;
		left: 40%;
		width: 90%;
		height: 550px;
		overflow: hidden;
		}

	.services_row {
		position: relative;
	}

	.serv_col {
		width: 90%;
		margin: 25px 5%;
		overflow: hidden;
		border-radius: 10px;
		background: #222;
	}

	.serv_img {
		width: 100%;
		height: 200px;
		background-position: center;
		background-size: cover;
	}

	.serv_body {
		padding: 25px 30px;
	}

	.serv_body h3 {
		margin-top: 0;
		margin-bottom: 25px;
		font-size: 18px;
		line-height: 1.2;
		font-weight: 500;
		display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	}

	.serv_body p {
		font-weight: 300;
		font-size: 12px;
		line-height: 2;
		margin: 0;
	}

	.serv_butt {
		display: table;
		position: relative;
		margin-top: 25px;
		padding: 15px 75px 15px 25px;
		background: #292929;
		border-radius: 10px;
		overflow: hidden;
		text-transform: uppercase;
		font-size: 13px;
		font-weight: 500;
		line-height: 1;
	}


	.serv_butt::after {
		content: "";
		position: absolute;
		width: 45px;
		height: 100%;
		top: 0;
		right: 0;
		border-radius: 10px;
		background-image: url(../img/arr_black.svg);
		background-repeat: no-repeat;
		background-position: center;
		-webkit-background-size: 25px auto;
		background-size: 25px auto;
	}

	.owl-dots {
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-ms-align-items: center;
		align-items: center;
		justify-content: center;
	}

	.owl-dot {
		border: 1px solid transparent;
		border-radius: 100px;
		padding: 10px;
		background: none;
		transition: 0.2s ease all;
	}

	.owl-dot span {
		display: table;
		width: 5px;
		height: 5px;
		border-radius: 100px;
		transition: 0.2s ease all;
	}

	.owl-dot.active {
		border: 1px solid #fff;
	}

	.port {
		overflow: hidden;
	}

	.port_block {
		position: relative;
		width: 100%;
	}

	.port_img {
		position: absolute;
		z-index: 1;
		top:0;
		left: 0;
		width: 65%;
		height: 100%;
		background-repeat: no-repeat;
		background-position: center;
		-webkit-background-size: cover;
		background-size: cover;
	}

	.port_info {
		position: relative;
		z-index: 2;
		margin: 50px 35px 50px auto;
		padding: 25px 50px;
		max-width: 680px;
		width: 100%;
		border-radius: 10px;
		background: #292929;
	}

	.port_name {
		margin-top: 15px;
		padding-bottom: 20px;
		font-weight: 500;
		font-size: 30px;
		line-height: 1.2;
		border-bottom: 1px solid #707070;
		margin-bottom: 20px;
	}

	.port_chars {
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		justify-content: space-between;
		-ms-align-items: flex-start;
		align-items: flex-start;
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	.char_big {
		width: 100%;
		font-size: 22px;
		margin-bottom: 20px;
	}

	.char {
		width: 31%;
		font-size: 16px;
		margin-bottom: 20px;
	}

	.char span {
		display: inline-block;
	}

	.port_info p {
		font-size: 13px;
		line-height: 1.7;
	}

	.port_butt {
			display: table;
			position: relative;
			margin-top: 25px;
			margin-left: auto;
			padding: 15px 75px 15px 25px;
			background: #222222;
			border-radius: 10px;
			overflow: hidden;
			text-transform: uppercase;
			font-size: 13px;
			font-weight: 500;
			line-height: 1;
			transition: 0.2s ease all;
		}

		.port_butt::after {
			content: "";
			position: absolute;
			width: 45px;
			height: 100%;
			top: 0;
			right: 0;
			border-radius: 10px;
			background-image: url(../img/arr_black.svg);
			background-repeat: no-repeat;
			background-position: center;
			-webkit-background-size: 25px auto;
			background-size: 25px auto;
		}

		.port_butt:hover {
			padding-right: 85px;
		}

		.port .owl-dots {
			position: absolute;
			bottom: 0;
			right: 15%;
		}

		.proj_butt {
			display: table;
			position: absolute;
			top:-10px;
			right: 20px;
			padding: 25px 110px 25px 40px;
			background: #292929;
			border-radius: 10px;
			overflow: hidden;
			text-transform: uppercase;
			font-size: 14px;
			line-height: 1;
		}

		.proj_butt:before {
			content: "";
			position: absolute;
			width: 70px;
			height: 100%;
			top: 0;
			right: 0;
			background-image: url(../img/arr_right.svg);
			background-repeat: no-repeat;
			background-position: center;
			background-color: #222;
		}


		.proj_butt::after {
			content: "";
			position: absolute;
			width: 70px;
			height: 100%;
			top: 0;
			right: 0;
			background-image: url(../img/arr_black.svg);
			background-repeat: no-repeat;
			background-position: center;
			opacity: 0;
			transition: 0.2s ease all;
		}

		.proj_butt:hover:after {
			opacity: 1;
		}

		.blog_post {
			margin: 25px 5%;
			overflow: hidden;
			width: 90%;
			border-radius: 10px;
		}

		.post_min {
			width: 100%;
			height: 230px;
			background-repeat: no-repeat;
			background-position: center;
			-webkit-background-size: cover;
			background-size: cover;
			position: relative;
		}

		.post_date {
			position: absolute;
			bottom: 0;
			left: 10px;
			padding: 8px 20px;
			border-top-left-radius: 10px;
			border-top-right-radius: 10px;
			background: #292929c7;
			font-size: 11px;
		}

		.post_zag {
			display: table;
			width: 100%;
			padding: 25px 90px 25px 30px;
			position: relative;
		}

		.post_zag p {
			font-size: 14px;
			font-weight: 300;
			line-height: 1.5;
			display: -webkit-box;
			-webkit-line-clamp: 2;
			-webkit-box-orient: vertical;
			overflow: hidden;
			margin: 0;
		}

		.post_zag:before {
			content: "";
			position: absolute;
			width: 70px;
			height: 100%;
			top: 0;
			right: 0;
			background-image: url(../img/arr_right.svg);
			background-repeat: no-repeat;
			background-position: center;
			background-color: #171717;
		}

		.post_zag::after {
			content: "";
			position: absolute;
			width: 70px;
			height: 100%;
			top: 0;
			right: 0;
			background-image: url(../img/arr_black.svg);
			background-repeat: no-repeat;
			background-position: center;
			opacity: 0;
			transition: 0.2s ease all;
		}

		.post_zag:hover:after {
			opacity: 1;
		}

	.otz_text {
		width: 33%;
		min-height: 300px;
	}

	.otz_text p {
		font-size: 15px;
		line-height: 2;
		font-weight: 300;
	}

	.reviews {
		position: relative;
	}

	.review_bg {
		position: absolute;
		z-index: 1;
		width: 45%;
		height: 100%;
		top:0;
		right: 0;
		background-position: center;
		background-size: cover;
	}

	.reviews_block {
		position: absolute;
		z-index: 5;
		overflow: hidden;
		left: 37%;
		top:-20px;
		width: 100%;
		padding-bottom:30px;
	}

	.review_col {
		margin: 20px;
		background: #292929;
		padding: 30px 35px;
		border-radius: 10px;
	}

	.review_col p {
		font-size: 13px;
		line-height: 2;
		font-weight: 300;
	}

	.review_head {
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-ms-align-items: center;
		align-items: center;
		margin-bottom: 20px;
	}

	.review_head_img {
		width: 80px;
		height:80px;
		border-radius: 100px;
		border-width: 1px;
		border-style: solid;
		margin-right: 50px;
		overflow:hidden;
		position:relative;
	}
	.review_head_img img {
		width:100%;
		position:absolute;
		top:50%;
		left:50%;
		transform: translate(-50%, -50%);
	}

	.review_head p {
		margin: 10px 0;
		font-size: 18px;
		line-height: 1;
		font-weight: 500;
	}

	.review_head p.city {
		font-weight: 300;
	}

	.reviews_block .owl-dots {
		position: absolute;
		left: 4%;
	}

	footer {
		padding-top: 50px;
		background: #292929;
	}

	.foot_row {
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-ms-align-items: flex-start;
		align-items: flex-start;
		justify-content: space-between;
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	.foot_col1 {
		width: 33%;
		position: relative;
	}

	.desc {
		margin-top: 40px;
		font-weight: 200;
		font-size: 12px;
		line-height: 2;
	}

	.fot_col2 {
		width: 25%;
	}

	.foot_zag {
		width: 100%;
		font-weight: 500;
		font-size: 16px;
		padding-bottom: 20px;
		border-bottom: 1px solid #707070;
		margin-bottom: 30px;
		position: relative;
	}

	.foot_zag:after {
		content: "";
		position: absolute;
		height: 1px;
		width: 50px;
		bottom: -1px;
		left: 0;
	}

	.foot_tel {
		display: table;
		padding-left: 35px;
		margin: 20px 0;
		font-weight: 700;
		font-size: 18px;
		background: url(../img/tel.svg) no-repeat;
		background-position: left center;
		background-size: 15px auto;
	}

	.foot_mail {
		display: table;
		padding-left: 35px;
		margin: 20px 0;
		font-size: 15px;
		background: url(../img/mail.svg) no-repeat;
		background-position: left center;
		background-size: 15px auto;
	}

	.foot_adr {
		display: table;
		padding-left: 35px;
		margin: 25px 0;
		font-size: 12px;
		background: url(../img/adr.svg) no-repeat;
		background-position: left center;
		background-size: 15px auto;
	}
	.socs_row {
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-ms-align-items: center;
		align-items: center;
	}
	.foot_soc {
		display: table;
		margin: 0 15px;
	}

	.foot_soc img {
		width: 15px;
	}

	.fot_col3 {
		width: 30%;
	}

	.fot_col3 p {
		font-size: 14px;
	}

	.foot_form {
		 background: #222;
		 border-radius: 10px;
		 width: 100%;
		 margin: 25px 0;
		 display: -webkit-flex;
		 display: -ms-flex;
		 display: flex;
		 -ms-align-items: stretch;
		 align-items: stretch;
	}

	.form_input {
		border:none;
		background: none;
		outline: none;
		color: #fff;
		padding: 15px 25px;
		font-weight: 500;
		font-size: 13px;
		width: 100%;
	}

	.foot_butt {
		margin-top: 30px;
		display: table;
		position: relative;
		width: 100%;
		padding: 25px 105px 25px 35px;
		background: #222;
		border-radius: 10px;
		overflow: hidden;
		text-transform: uppercase;
		font-size: 16px;
		line-height: 1;
		transition: 0.3s ease all;
	}


	.foot_butt::after {
		content: "";
		position: absolute;
		width: 70px;
		height: 100%;
		top: 0;
		right: 0;
		background-image: url(../img/arr_black.svg);
		background-repeat: no-repeat;
		background-position: center;
	}

	footer .policy {
		font-weight: 300;
		font-size: 10px;
	}

	.copyright {
		margin-top: 20px;
		border-top: 1px solid #fff;
		padding: 20px 0;
		position: relative;
	}

	.copyright p {
		font-size: 14px;
			margin: 0;
	}

	.bbs {
		position: absolute;
		background: #fff;
		padding: 7px 25px;
		display: flex;
		-ms-align-items: center;
		align-items: center;
		bottom: 0;
		right: 0;
		border-top-left-radius: 10px;
		border-top-right-radius: 10px;
	}

	.bbs img {
		width: 30px;
		margin-right: 20px;
	}

	.bbs p {
		margin: 0;
		font-weight: 300;
		font-size: 14px;    
		color: #714DE5!important;
	}

	.bbs p a {
		text-decoration: underline;
	}

	.vn_block h1 {
		margin-top: 60px;
		font-weight: 500;
		font-size: 30px;
		text-align: center;
		padding-bottom: 30px;
		margin-bottom: 40px;
		border-bottom: 1px solid #707070;
		position: relative;
	}

	.vn_block h1::after {
		content: "";
		position: absolute;
		bottom: -1px;
		left: 45%;
		width: 10%;
		height: 1px;
	}

	.servs_row {
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-ms-align-items: center;
		align-items: center;
		justify-content: space-between;
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	.servs_col {
		width: 49%;
		height: 385px;
		position: relative;
		-webkit-background-size: cover;
		background-size: cover;
		background-position: center;
		overflow: hidden;
		border-radius: 10px;
		margin-bottom: 40px;
	}

	.serv_block {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: #00000059;
		text-align: center;
		padding-left: 70px;
		padding-right: 70px;
		padding-top: 250px;
		transition: 0.3s ease all;
	}

	.serv_block h2 {
		margin-top: 25px;
		font-weight: 500;
		font-size: 28px;
		padding-bottom: 30px;
		margin-bottom: 30px;
		position: relative;
		text-shadow: 0px 0px 20px #000000;
	}

	.serv_block h2:after {
		content: "";
		position: absolute;
		bottom: 0;
		left: 40%;
		width: 20%;
		height: 1px;
		opacity: 0;
		transition: 0.3s ease all;
	}

	.serv_block p {
		font-size: 15px;
		margin-top: 0;
		margin-bottom: 15px;
		opacity: 0;
		transition: 0.3s ease all;
	}

	.serv_block	.serv_butt {
		margin-right: auto;
		margin-left: auto;
		opacity: 0;
		transition: 0.3s ease all;
	}

	.serv_block:hover {
		background: #000000a8;
		padding-top: 50px;
	}

	.serv_block:hover h2:after, .serv_block:hover p, .serv_block:hover .serv_butt {
		opacity: 1;
	}

	.content_row {
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		justify-content: space-between;
		-ms-align-items: stretch;
		align-items: stretch;
		margin-bottom: 50px;
	}

	.cont_img {
		width: 46%;
		-webkit-background-size: cover;
		background-size: cover;
		background-position: center;
		border-radius: 10px;
	}

	.cont_text {
		width: 50%;
	}

	.cont_text h2 {
		margin-top: 25px;
		margin-bottom: 30px;
		border: 0;
		padding: 0;
	}

	.cont_text h2::after {
		content: none;
	}

	.cont_text p {
		font-weight: 300;
		font-size: 15px;
		line-height: 2;
		margin-bottom: 30px;
	}

	.cont_text li {
		font-weight: 300;
		font-size: 15px;
		line-height: 2;
		margin-bottom: 20px;
	}

	.cont_text ol, .cont_text ul {
		padding-left:25px;
	}

	.content_row:nth-child(2n) {
		-webkit-flex-direction: row-reverse;
		-ms-flex-direction: row-reverse;
		flex-direction: row-reverse;
	}

	.quiz_row {
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-ms-align-items: center;
		align-items: center;
		justify-content: space-between;
	}

.quiz_text {
	width: auto;
}

.quiz_text h2 {
	border: none;
	padding: 0;
	position: static;
	font-weight: 500;
	font-size: 28px;
	line-height: 1.5;
	margin-top: 0;
	margin-bottom: 20px;
}

.quiz_text h2::after {
	content: none;
}

.quiz_text p {
	font-size: 15px;
	margin: 0;
}

.quiz_butt {
	display: table;
	position: relative;
	margin-left: 50px;
	padding: 27px 135px 27px 45px;
	background: #111;
	border-radius: 10px;
	overflow: hidden;
	font-size: 21px;
	font-weight: 500;
	line-height: 1;
	min-width: 450px;
}

.quiz_butt::after {
	content: "";
	position: absolute;
	width: 85px;
	height: 100%;
	top: 0;
	right: 0;
	border-radius: 10px;
	background-image: url(../img/arr_black.svg);
	background-repeat: no-repeat;
	background-position: center;
	-webkit-background-size: 45px auto;
	background-size: 45px auto;
}

.news_row {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: flex-start;
	align-items: flex-start;
	justify-content: flex-start;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.new_post {
	margin: 0 1% 25px;
	overflow: hidden;
	width: 31%;
	border-radius: 10px;
}

.more_butt {
		display: table;
		position: relative;
		margin: 20px auto 0;
		padding: 25px 110px 25px 40px;
		background: #292929;
		border-radius: 10px;
		overflow: hidden;
		text-transform: uppercase;
		font-size: 14px;
		line-height: 1;
	}

	.more_butt:before {
		content: "";
		position: absolute;
		width: 70px;
		height: 100%;
		top: 0;
		right: 0;
		background-image: url(../img/arr_y_down.svg);
		background-repeat: no-repeat;
		background-position: center;
		background-color: #222;
	}


	.more_butt::after {
		content: "";
		position: absolute;
		width: 70px;
		height: 100%;
		top: 0;
		right: 0;
		background-image: url(../img/arr_b_down.svg);
		background-repeat: no-repeat;
		background-position: center;
		opacity: 0;
		transition: 0.2s ease all;
	}

	.more_butt:hover:after {
		opacity: 1;
	}

.post_row {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: flex-start;
	align-items: flex-start;
	justify-content: space-between;
}

.post_body {
	border-radius: 10px;
	overflow: hidden;
	background: #fff;
}

.post_body img {
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
	height: auto;
}

.post_content {
	padding: 40px 50px;
	color: #333;
	font-weight: 300;
	font-size: 15px;
	line-height: 2;
}

.post_content p {
	margin-bottom: 30px;
}

.post_content ul, .post_content ol {
	padding-left: 30px;
		margin-bottom: 30px;
}

.post_content li {
	margin-bottom: 10px;
}

.post_content blockquote {
	padding: 40px;
	background: #222;
	color: #fff;
	border-left-width: 2px;
	border-left-style: solid;
		margin-bottom: 30px;
}

.cont_row {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: center;
	align-items: center;
	justify-content: space-between;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.date {
	font-weight: 700;
	font-size: 15px;;
	opacity: 0.5;
	margin: 10px 0;
}

.back, .back:hover {
	display: table;
	position: relative;
	padding: 15px 70px 15px 20px;
	background: #292929;
	border-radius: 10px;
	overflow: hidden;
	text-transform: uppercase;
	font-size: 13px;
	font-weight: 500;
	line-height: 1;
	color: #fff;
}


.back::after {
	content: "";
	position: absolute;
	width: 45px;
	height: 100%;
	top: 0;
	right: 0;
	transform: rotate(180deg);
	border-radius: 10px;
	background-image: url(../img/arr_black.svg);
	background-repeat: no-repeat;
	background-position: center;
	-webkit-background-size: 25px auto;
	background-size: 25px auto;
}

.sidebar {
	min-width: 355px;
	width:355px;
	margin-left: 40px;
}

.sidebar h2 {
	border: none;
	padding: 0;
}

.sidebar h2:after {
	content: none;
}

.sidebar .serv_col {
	width: 100%;
	margin: 35px 0;
}

.port_one {
	overflow: hidden;
	border-radius: 10px;
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: stretch;
	align-items: stretch;
	background: #292929;
	margin-bottom: 50px;
}

.port_min {
	width: 50%;
	-webkit-background-size: cover;
	background-size: cover;
	background-position: center;
}

.port_con {
	width: 50%;
	padding: 25px 50px;
}

	.port_con p {
		font-size: 13px;
		line-height: 1.7;
	}

	.cont_gallery {
		width: 45%;
		min-height: 450px;
		position: relative;
	}

	.proj_gall {
		position: absolute;
		top:0;
		left: 0;
		width: 250%;
		overflow: hidden;
	}

	.gall_img {
		border-radius: 10px;
		margin: 30px 5% 60px;
		width: 90%;
		height: 420px;
		-webkit-background-size: cover;
		background-size: cover;
		background-position: center;
	}

	.proj_gall .owl-dots {
		position: absolute;
		bottom: 10px;
		left: 10%;
	}

	.proj_chars {
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-ms-align-items: flex-start;
		align-items: flex-start;
		justify-content: space-between;
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		position: relative;
		border-top:1px solid #707070;
		padding-top:40px;
	}

	.proj_chars:after {
		content: "";
		position: absolute;
		left: 0;
		top: -1px;
		height: 1px;
		width: 100px;
	}

	.vn_char {
		width: 31%;
		font-size: 16px;
		padding-left: 20px;
		position: relative;
		margin-bottom: 30px;
	}

	.vn_char span {
		display: inline-block;
	}

	.vn_char:after {
		content: "";
		position: absolute;
		top: 5px;
		left: 5px;
		width: 5px;
		height: 5px;
		border-radius: 100px;
	}

	.vn_char_big {
		width: 100%;
		font-size: 21px;
		font-weight: 500;
	}

	.proj_vid {
		width: 45%;
		height: auto;
		border-radius: 10px;
		position: relative;
		-webkit-background-size: cover;
		background-size: cover;
		background-position: center;
	}

	.vid_vn {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-ms-align-items: center;
		align-items: center;
		justify-content: center;
	}

	.play_vn {
		display: table;
		padding: 10px;
		border-radius: 100px;
		background: #ffffff60;
	}

	.play {
		display: block;
		width: 175px;
		height: 175px;
		border-radius: 100px;
		background-color: #222222;
		background-image: url(../img/play.svg);
		background-repeat: no-repeat;
		background-position: center;
		-webkit-background-size: 30px auto;
		background-size: 30px auto;
	}

	.conts_row {
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-ms-align-items: stretch;
		align-items: stretch;
		justify-content: space-between;
	}

	.conts_block {
		width: 40%;
	}

	.cont_tel {
		display: table;
		padding-left: 35px;
		margin: 30px 0;
		font-weight: 700;
		font-size: 32px;
		background: url(../img/tel.svg) no-repeat;
		background-position: left center;
		background-size: 25px auto;
	}

	.cont_mail {
		display: table;
		padding-left: 35px;
		margin: 25px 0;
		font-size: 24px;
		background: url(../img/mail.svg) no-repeat;
		background-position: left center;
		background-size: 25px auto;
	}

	.cont_adr {
		display: table;
		padding-left: 35px;
		margin: 35px 0;
		font-size: 20px;
		background: url(../img/adr.svg) no-repeat;
		background-position: left center;
		background-size: 25px auto;
	}

	.soc_zag {
		font-weight: 500;
		font-size: 26px;
		margin-top: 70px;
		margin-bottom: 25px;
	}

	.cont_socs {
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-ms-align-items: center;
		align-items: center;
	}
	.cont_soc {
		display: table;
		margin: 0 45px 25px 0;
	}

	.cont_soc img {
		width: 30px;
	}

	.cont_form {
		margin-top: 50px;
		background: #222;
		width: 100%;
		padding: 30px 45px;
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		justify-content: space-between;
		text-align: center;
		border-radius: 10px;

	}

	.cont_form h2 {
			width: 100%;
			margin-top: 10px;
			bottom: 0;
			padding: 0;
			font-weight: 500;
			font-size: 26px;
	}

	.cont_inp {
		width: 46%;
		font-size: 15px;
		outline: none;
		background: none;
		border-top: 0;
		border-right: 0;
		border-left: 0;
		border-bottom:2px solid #fff;
		padding: 15px 0;
		margin: 15px 0;
	}

	.cont_ta {
		width: 100%;
		font-size: 15px;
		outline: none;
		background: none;
		border-top: 0;
		border-right: 0;
		border-left: 0;
		border-bottom:2px solid #fff;
		padding: 15px 0;
		margin: 15px 0;
	}

	.cont_butt {
		display: table;
		padding: 14px 35px;
		border: 0;
		border-radius: 10px;
		margin: 30px auto 0;
		text-transform: uppercase;
		font-weight: 500;
		font-size: 13px;
		color: #333;
	}

	.cont_form .policy {
		font-size: 11px;
	}

	.map {
		width: 50%;
		height: 500px;
		position: relative;
	}

	.map_vn {
		position: absolute;
		top: 0;
		left: 0;
		height: 100%;
		width: 150%;
		border-radius: 10px;
		overflow: hidden;
	}


.popup, .popup_mob {
  position: fixed;
  left: 0px;
  top: 0px;
  right: 0px;
  bottom: 0px;
  display: none;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  opacity: 0;
  z-index:1000;
  overflow:auto;
}
.close_popup {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 3000;
}
.popup_vnutr {
  position: relative;
  z-index: 5000;
  display: block;
  margin: 200px auto 0 auto;
  width: 95%;
	padding: 30px 45px;
  max-width: 500px;
	border-radius: 10px;
	background: #222222;
}
.mob_vnutr {
  position: relative;
  z-index: 5000;
  display: block;
  margin: 30px auto 0 auto;
  width: 95%;
	padding: 30px;
  max-width: 330px;
	border-radius: 10px;
	background: #222222;
}


.close_wind {
	position: absolute;
	right:-10px;
	top:-10px;
}

.pp_form {
	width: 100%;
	text-align: center;
}

.pp_form h2 {
		margin-top: 10px;
		margin-bottom: 20px;
		font-weight: 500;
		font-size: 26px;
}

.pp_form p {
	font-weight: 300;
	font-size: 15px;
	margin-top: 0px;
	margin-bottom: 10px;
}

.pp_inp {
	width: 100%;
	font-size: 15px;
	outline: none;
	background: none;
	border-top: 0;
	border-right: 0;
	border-left: 0;
	border-bottom-style: solid;
	border-bottom-width: 2px;
	padding: 15px 0;
	margin: 10px 0;
}

.pp_butt {
	display: table;
	padding: 14px 35px;
	border: 0;
	border-radius: 10px;
	margin: 30px auto 0;
	text-transform: uppercase;
	font-weight: 500;
	font-size: 13px;
	color: #333;
}

.popup .policy {
	font-size: 12px;
	text-align: center;
	margin: 15px 0;
}

.policy a {
	text-decoration: underline;
}

.menu_fix {
    position: fixed;
    left: 0px;
    top: -1px;
    right: 0px;
    z-index: 500;
    display: none;
    padding: 10px 0;
		background: #222222;
}



.page404 {
	padding:150px 0;
	text-align:center;
}

.err1 {
	margin-top:70px;
	font-weight:700;
	font-size:80px;
}

.err2 {
	font-weight:500;
	font-size:30px;
}


.page404 .port_butt {
	margin-left:auto;
	margin-right:auto;
	margin-top:25px;
}
.it-butik {
	position: absolute;
	z-index: 100;
	bottom: 0;
	right: 50%;
	transform: translatex(50%);
	white-space: nowrap;
	width: max-content;
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-ms-align-items: center;
	align-items: center;
	padding: 7px 22px;
	background: #fff;
	border: 1px solid #714DE5;
	border-radius: 15px 15px 0px 0px;
}

.it-butik svg {
	width:30px;
}

.it-butik p {
	font-style: italic;
	font-size: 14px;
	font-weight: 600;
	margin-left: 15px;
	margin-bottom: 0;
	margin-top: 0;
	color:#714DE5!important;
}

.it-butik p span {
	text-transform: uppercase;
	text-decoration: underline;
}

footer {
	position:relative;
}

.us_row {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	flex-wrap: wrap;
}

.us_col {
	width: 48%;
	position: relative;
	margin-bottom: 40px;
}

.us_img {
	position: absolute;
	z-index: 1;
	height: 100%;
	width: 55%;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	border-radius: 10px;
}

.us_block {
	position: relative;
	z-index: 2;
	width: 55%;
	border-radius: 10px;
	background: #292929;
	padding: 25px 30px;
	margin: 30px 0 30px auto;
}

.us_zag {
	font-weight: 500;
	font-size: 20px;
	margin-bottom: 15px;
}

.us_text {
	font-size: 16px;
	font-weight: 400;
}

.faq_row {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}

.faq_block {
	width: 60%;
}

.faq_line {
	background: #222;
	border-radius: 10px;
	overflow: hidden;
	margin-bottom: 20px;
}

.faq-head {
	padding: 30px 70px 30px 40px;
	font-weight: 500;
	font-size: 20px;
	position: relative;
	cursor: pointer;
	transition: 0.3s ease all;
}

.faq-head::after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	right: 30px;
	width: 30px;
	height: 100%;
	background-image: url(../img/down-arrow-yell.svg);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	transition: 0.3s ease all;
}

.faq-head:hover::after {
	background-image: url(../img/down-arrow.svg);
}

.faq-head.unfolded::after {
	transform: rotate(180deg);
}

.faq-body {
	padding: 40px;
	border-top: 1px solid;
	font-weight: 400;
	font-size: 16px;
}

.faq_img {
	width: 35%;
	height: 400px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	border-radius: 10px;
}