/*   
Theme Name: Plasma 4 Vitapherese
Author: Anton Grichenko
Version: 1.0
*/
/* Eric Meyer's CSS Reset */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
/* End of Eric Meyer's CSS Reset */

html {
	height: 100%;
}
article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary {
	display: block;
}
body {
	font-family: "Google Sans", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-variation-settings: "GRAD" 0;
	font-size: 24px;
	line-height:30px;
	width: 100%;
	height: 100%;
	color:#2D3037;
}
body.fixed{
overflow:hidden
}
a{
	transition:0.2s;
}
.wrapper {
	width: 100%;
	min-height: 100%;
	height: auto !important;
	height: 100%;
	background: url(images/promo.jpg) 50% 0/1440px no-repeat;
	position:relative;
	z-index:2;
}
.widfix{
	box-sizing:border-box;
	margin: 0 auto;
	width: 1300px;
	padding:0;
}

/* Header
-----------------------------------------------------------------------------*/
.header {
	color:#fff;
	z-index: 100;
	position: relative;
	padding-top: 28px;
}
.header .widfix{
}
.logo{
	background:url(images/logo.svg) 0 50%/100% no-repeat;
	width: 329px;
	text-indent: -999px;
	overflow: hidden;
	height: 109px;
	display: block;
}

/* Middle
-----------------------------------------------------------------------------*/
.content {
	padding: 0 0 90px;
	overflow-x: hidden;
	background: url(images/footer.jpg) 50% 100%/1440px no-repeat;
}
#promo{
	height: 535px;
	margin-bottom:35px;
	position: relative;
	margin-top: -137px;
	padding-top: 145px;
}
#promo h1{
	font: 500 90px/83px "Google Sans";
	width: 60%;
}
#promo h1 b{
	font: italic 400 180px/122px "EB Garamond";
	color:#1B5A77;
	letter-spacing: -0.05em;
	display: block;
}
#promo .description{position: absolute;top: 375px;left: 640px;background: #1B5A77;color: #fff;width: 333px;padding: 14px 20px 14px 55px;box-sizing: border-box;font: 400 16px/20px "Google Sans";border-radius: 30px;}
#promo .description:before{
	content:'';
	background: url(images/arrow.svg) 0 0/contain no-repeat;
	width: 26px;
	height: 20px;
	position: absolute;
	top: 16px;
	left: 18px;
}
#promo .btn{
	position: absolute;
	bottom: 0;
	left: 0;
	background: #D5B276;
	color: #fff;
	width: 309px;
	padding: 16px 70px 16px 24px;
	box-sizing: border-box;
	font: 500 24px / 30px "Google Sans";
	border-radius: 30px;
	height: 140px;
	display: flex;
	align-items: end;
	text-decoration: none;
}
#promo .btn:after{
	content:'';
	background: url(images/arrow.svg) 0 0/contain no-repeat;
	width: 48px;
	height: 40px;
	position: absolute;
	top: 18px;
	right: 13px;
	transform: rotate(-45deg);
	transition:0.5s;
}
#about{
	display: flex;
	flex-wrap: wrap;
}
#about .col{
}
#about h2{
	font: 500 58px/100% "Google Sans";
	padding: 14px 0 23px;
	width: 100%;
}
#about .grey_box{
	width: 640px;
	margin-right: 19px;
	background: #F1F5F9;
	padding: 26px 36px 50px 32px;
	border-radius: 30px;
	box-sizing: border-box;
	font: 400 30px/41px "Google Sans";
	position: relative;
	z-index: 3;
}
#about .connor{
	position: absolute;
	width: 110px;
	height: 110px;
	bottom: 0;
	right: 0;
	background: #fff;
	z-index: 2;
}
#about .connor:before{
	content:'';
	position: absolute;
	width: 30px;
	height: 110px;
	bottom: 0;
	right: 80px;
	background: #F1F5F9;
	z-index: 1;
	border-radius: 0 0 30px 0;
}
#about .connor:after{
	content:'';
	position: absolute;
	width: 80px;
	height: 30px;
	bottom: 80px;
	right: 0;
	background: #F1F5F9;
	z-index: 1;
	border-radius: 0 0 30px 0;
}
#about .connor2{
	position: absolute;
	width: 80px;
	height: 80px;
	bottom: 0;
	right: 0;
	z-index: 3;
}
#about .connor2:before{
	content: '';
	position: absolute;
	width: 30px;
	height: 30px;
	bottom: 50px;
	right: 50px;
	background: #F1F5F9;
	z-index: -2;
}
#about .connor2:after{
	content: '';
	position: absolute;
	width: 80px;
	height: 80px;
	bottom: 0;
	right: 0;
	background: #fff;
	z-index: -1;
	border-radius: 30px 0 0 0;
}
#about .grey_box a{font-weight:500;color:#D5B276;text-decoration:none;}
#about a.video_pop{
	width: 50px;
	height: 50px;
	position: absolute;
	bottom: 15px;
	right: 10px;
	z-index: 10;
	transition: 0.5s;
	background: url(images/video_btn.svg) 50% 50% /100% no-repeat;
}
#about .image{
	width: 640px;
	overflow: hidden;
	margin-top:-95px;
	border-radius:30px;
}
#about .image img{
	width: 100%;
	display: block;
}
#feature{
	margin-top:27px;
}
#feature h2{
	font: 500 80px / 87px "Google Sans";
	width: 70%;
	color:#CED8E2;
}
#feature h2 b{
	color:#2D3037;
}
#feature .text{
	margin: -60px 0 0 770px;
}
#steps{
	display:flex;
	margin:97px 0 47px;
	position: relative;
}
#steps h2{
	font: 500 40px / 42px "Google Sans";
	width: 330px;
	flex: 0 0 auto;
	background: #fff;
	position: relative;
	z-index: 10;
}
#steps h2:before{
	content:'';
	position: absolute;
	background:#fff;
	top:-80px;
	bottom:0px;
	left:-500%;
	right:0;
	z-index:-1;
}
.steps_list{
	width: 860px;
}
.steps_list_item{
	width: 420px;
	background: #CED8E2;
	box-sizing: border-box;
	height: 350px;
	padding: 27px 26px;
	border-radius:30px;
	position:relative;
	transition:0.5s;
}
.steps_list_item .number{
	position: absolute;
	bottom: 19px;
	right: 8px;
	color: #2D3037;
	font: 500 128px / 128px "Google Sans";
	overflow: hidden;
	height: 81px;
	transition: 0.5s;
}
.steps_list_item .number span{
	display:block;
}
.steps_list_item h3{
	font: 500 24px/30px "Google Sans";
	margin-bottom:14px;
}
.steps_list_item .text{
	opacity:0;
	font: 400 18px/22px "Google Sans";
	transition:0.5s;
}
.steps_list_item .text p{
	margin-bottom:8px;
}
.steps_list_item .text ul{
}
.steps_list_item .text ul li{
	padding-left:10px;
	position:relative;
}
.steps_list_item .text ul li:before{
	content:'';
	position:absolute;
	top:10px;
	left:0;
	width:4px;
	height:4px;
	border-radius:50%;
	background:#2D3037;
}
#steps .owl-nav{
	display:none !important;
}
.steps_nav{
	position: absolute;
	display:flex;
	bottom: 0;
	left: 0;
	z-index:20;
}
.steps_nav .prev, .steps_nav .next{
	width: 50px;
	height: 50px;
	border: 2px solid #fff;
	background: url(images/arrow.svg) 50% 50% / 25px no-repeat #000;
	box-sizing: border-box;
	filter: invert(1);
	border-radius: 50%;
	margin-right: 10px;
}
.steps_nav .prev{
	transform:rotate(180deg);
}
.steps_nav .disabled{
	opacity:0.2;
	cursor:default;
}
.consultation_btn{
	display:flex;
	align-items:center;
	background: url(images/link_thing.jpg) 50% 50% / cover no-repeat;
	font: 500 70px/60px "Google Sans";
	color:#fff;
	padding:0 54px;
	height:160px;
	margin-bottom:47px;
	border-radius:19px;
	text-decoration:none;
}
.consultation_btn.type2{
	background: url(images/link_thing2.jpg) 50% 50% / cover no-repeat;
}
.consultation_btn span{
	position:relative;
}
.consultation_btn span:after{
	content: '';
	position: absolute;
	width: 76px;
	height: 70px;
	background: url(images/arrow.svg) 50% 50% / 100% no-repeat;
	top: 50%;
	right: -105px;
	margin-top: -30px;
	transition:0.5s;
}

#advantages{
	display: flex;
	align-items: flex-start;
	margin-bottom:8px;
}
#advantages h2{
	font: 500 68px/78px "Google Sans";
}
#advantages .grey_box{
	width: 640px;
	margin-right: 19px;
	background: #F1F5F9;
	padding: 26px 36px 38px 44px;
	border-radius: 30px;
	box-sizing: border-box;
	font: 400 30px/41px "Google Sans";
	position: relative;
	z-index: 3;
	flex: 0 0 auto;
}
#advantages .connor{
	position: absolute;
	width: 110px;
	height: 110px;
	bottom: 0;
	right: 0;
	background: #fff;
	z-index: 2;
}
#advantages .connor:before{
	content:'';
	position: absolute;
	width: 30px;
	height: 110px;
	bottom: 0;
	right: 80px;
	background: #F1F5F9;
	z-index: 1;
	border-radius: 0 0 30px 0;
}
#advantages .connor:after{
	content:'';
	position: absolute;
	width: 80px;
	height: 30px;
	bottom: 80px;
	right: 0;
	background: #F1F5F9;
	z-index: 1;
	border-radius: 0 0 30px 0;
}
#advantages .connor2{
	position: absolute;
	width: 80px;
	height: 80px;
	bottom: 0;
	right: 0;
	z-index: 3;
}
#advantages .connor2:before{
	content: '';
	position: absolute;
	width: 30px;
	height: 30px;
	bottom: 50px;
	right: 50px;
	background: #F1F5F9;
	z-index: -2;
}
#advantages .connor2:after{
	content: '';
	position: absolute;
	width: 80px;
	height: 80px;
	bottom: 0;
	right: 0;
	background: #fff;
	z-index: -1;
	border-radius: 30px 0 0 0;
}


.advantages_list{}
.advantages_list li{
	border-top:2px solid #1B5A77;
	padding:23px 0 23px 41px;
	position:relative;
}
.advantages_list li:before{
	content: '';
	width: 28px;
	background: url(images/arrow.svg) 50% 50% / 100% no-repeat;
	filter: invert(1);
	position: absolute;
	top: 24px;
	left: 0;
	height: 28px;
}

#video{
	display:flex;
	justify-content:center;
	margin-bottom:46px;
}
.video_box{
	width:906px;
	height:510px;
	background:url(images/video.jpg) 50% 50%/cover no-repeat;
	position:relative;
	border-radius:30px;
	overflow:hidden;
}
.video_box:before{
	content:'';
	width:100%;
	height:100%;
	top:0;
	left:0;
	background:rgba(0,0,0,0.5);
	position:absolute;
	z-index:1;
}
.video_box:after{
	content:'';
	width:140px;
	height:140px;
	background:url(images/video.svg) 50% 50%/cover no-repeat;
	position:absolute;
	top:50%;
	left:50%;
	margin:-70px 0 0 -70px;
	z-index:2;
	transition:0.5s;
}

#recommendation{
	display:flex;
	flex-wrap:wrap;
	justify-content:space-between;
}
#recommendation h2{
	width: 600px;
	margin-top: -13px;
	font: 500 58px / 73px "Google Sans";
}
#recommendation .text{
	width: 620px;
	font: 400 30px / 41px "Google Sans";
}
#recommendation ul{
	display:flex;
	flex-wrap:wrap;
	margin:33px -20px 0 0;
}
#recommendation li{
	display: flex;
	align-items: flex-end;
	font: 400 30px / 41px "Google Sans";
	border-radius:30px;
	padding:25px 30px;
	background:#CED8E2;
	height:225px;
	width:310px;
	margin:0 20px 20px 0;
	box-sizing: border-box;
	position:relative;
	transition:0.5s;
}
#recommendation .rec01{
	width:640px;
}
#recommendation .rec02{}
#recommendation .rec03{
	
}
#recommendation .rec04{
	width:420px;
}
#recommendation .rec05{
	width:860px;
}
#recommendation li:after{
	content:'';
	position:absolute;
	z-index:-1;
	opacity:0;
	animation:recom_blinking 5s infinite linear;
	transition:0.5s;
}
#recommendation .rec01:after{
	width:311px;
	height:328px;
	top: -100px;
	right: -57px;
	background:url(images/rec01.png) 50% 50%/cover no-repeat;
	transform: translate(-440px, 50px);
}
#recommendation .rec02:after{
	width:307px;
	height:328px;
	top: -130px;
	right: -102px;
	background:url(images/rec02.png) 50% 50%/cover no-repeat;
}
#recommendation .rec03:after{
	width:290px;
	height:338px;
	top: -103px;
	right: -75px;
	background:url(images/rec03.png) 50% 50%/cover no-repeat;
}
#recommendation .rec04:after{
	width:323px;
	height:340px;
	top: -143px;
	right: -111px;
	background:url(images/rec04.png) 50% 50%/cover no-repeat;
	transform: translate(-220px, 50px);
}
#recommendation .rec05:after{
	width:298px;
	height:314px;
	top: -109px;
	right: -70px;
	background:url(images/rec05.png) 50% 50%/cover no-repeat;
	transform: translate(-660px, 50px);
}
#price{
	margin: 50px 0;
	font: 500 45px / 52px "Google Sans";
	text-align: center;
	display: flex;
	justify-content: center;
}
#price div{
	background: #F1F5F9;
	border-radius: 30px;
	padding: 50px;
	width: 70%;
}
#price b{
	font-weight: 900;
	color: rgb(27 90 119);
	font-size: 150%;
	display: block;
	margin: 15px 0;
	letter-spacing: -0.02em;
	text-shadow: 0 0 10px rgba(27, 90, 119, 0.5);
}
#consultation_form{
	margin: 18px 0 35px;
	display: flex;
	justify-content: space-between;
	position:relative;
}
#consultation_form h2{
	font: 500 80px / 87px "Google Sans";
	width: 700px;
}
#consultation_form form{
	width: 530px;
	margin-top: 17px;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
}
#consultation_form .field{
	position:relative;
	width: 100%;
	z-index: 5;
}
#consultation_form .field label{
	font: 500 32px / 40px "Google Sans";
	color: #CED8E2;
	position: absolute;
	transition: 0.2s;
	top: 10px;
	left: 0;
	z-index: -1;
}
#consultation_form .field.filled label{
	font-size: 20px;
	top: -12px;
	line-height: 24px;
}
#consultation_form .field.error label{
	color: #f00;
}
#consultation_form .field input{
	border: 0;
	border-bottom: 2px solid #425559;
	margin-bottom: 20px;
	height: 55px;
	width: 100%;
	z-index: 1;
	position: relative;
	background: transparent;
	outline: none;
	font: 500 32px / 40px "Google Sans";
	color: #2D3037;
}
#consultation_form .field.error input{
	border-bottom: 2px solid #f00;
}
#consultation_form .agree{
	position:relative;
	padding-left:30px;
	font: 300 16px/22px "Google Sans";
}
#consultation_form .agree:before{
	content:'';
	position:absolute;
	top:0;
	left:0;
	width:20px;
	height:20px;
	border:2px solid #000;
	box-sizing: border-box;
}
#consultation_form .agree:after{
	content: '';
	position: absolute;
	top: 2px;
	left: 6px;
	border-bottom: 2px solid #000;
	border-right: 2px solid #000;
	width: 5px;
	height: 10px;
	transform: rotate(45deg);
	opacity:0;
	ox-sizing: border-box;
	transition:0.1s;
}
#consultation_form .agree.checked:after{
	opacity:1;
}
#consultation_form .agree a{
	position:relative;
	display:inline-block;
	z-index:15;
	text-decoration:none;
	color:#D5B276
}
#consultation_form .agree input{
	position:absolute;
	top:0;
	left:0;
	right:0;
	bottom:0;
	z-index:10;
	opacity:0;
}
#consultation_form button{
	position: relative;
	background: #D5B276;
	color: #fff;
	width: 309px;
	padding: 16px 70px 16px 24px;
	box-sizing: border-box;
	font: 500 24px / 30px "Google Sans";
	border-radius: 30px;
	height: 140px;
	display: flex;
	align-items: end;
	text-decoration: none;
	border: 0;
	margin-top: 18px;
	cursor:pointer;
	transition:0.2s;
}
#consultation_form button:after{
	content:'';
	background: url(images/arrow.svg) 0 0/contain no-repeat;
	width: 48px;
	height: 40px;
	position: absolute;
	top: 18px;
	right: 13px;
	transform: rotate(-45deg);
	transition:0.5s;
}
#consultation_form button:disabled{
	opacity:0.2;
	cursor:default;
}
.btn_whatsapp{
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 20px 30px 20px 70px;
	color: #fff;
	text-decoration: none;
	z-index: 10;
	background: url(images/wapp.svg) 20px 50% / 45px no-repeat rgb(42, 181, 64);
	border-radius: 30px;
}
/* Footer
-----------------------------------------------------------------------------*/
.footer{
	width: 100%;
	margin: -90px auto 0;
	height: 90px;
	position: relative;
	font-size: 16px;
	z-index:2;
}
.footer a{
	display:inline-block;
	text-decoration:none;
	color:#D5B276
}
.footer .widfix{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.footer .logo{
	width: 176px;
	height: 90px;
}
.pop_modal_video{
	position:fixed;
	top:0;
	bottom:0;
	left:0;
	right:0;
	z-index:100;
	background:rgba(0,0,0,0.9);
	display: none;
}
.pop_modal_video .close{
	font: 300 60px / 20px "Google Sans";
	text-decoration: none;
	color: #999;
	position: absolute;
	top: 20px;
	right: 20px;
	z-index: 10;
}
.pop_modal_video_box{
	position:absolute;
	top:0;
	bottom:0;
	left:0;
	right:0;
	display:flex;
	justify-content:center;
	align-items:center;
}
.pop_modal_video_box video{
	max-width:90%;
	max-height:90%;
}
.pop_modal_success{
	position:fixed;
	top:0;
	bottom:0;
	left:0;
	right:0;
	z-index:100;
	background:rgba(255,255,255,0.9);
	display: none;
}
.pop_modal_success .close{
	font: 300 60px / 20px "Google Sans";
	text-decoration: none;
	color: #999;
	position: absolute;
	top: 20px;
	right: 20px;
	z-index: 10;
}
.pop_modal_success_box{
	position:absolute;
	top:0;
	bottom:0;
	left:0;
	right:0;
	display:flex;
	justify-content:center;
	align-items:center;
}
.pop_modal_success_box div{
	width:400px;
	background:#fff;
	padding:40px;
	text-align:center;
	position:relative;
	box-shadow: 0 0 50px rgba(0, 0, 0, 0.3);
	border-radius:20px;
}
.pop_modal_success_box h3{
	font: 700 30px / 34px "Google Sans";
	margin-bottom:20px;
}
.pop_modal_politik,.pop_modal_impressum{
	position:fixed;
	top:0;
	bottom:0;
	left:0;
	right:0;
	z-index:100;
	background:rgba(255,255,255,0.9);
	display: none;
}
.pop_modal_politik .close,.pop_modal_impressum .close{
	font: 300 60px / 20px "Google Sans";
	text-decoration: none;
	color: #999;
	position: absolute;
	top: 20px;
	right: 20px;
	z-index: 10;
}
.pop_modal_politik_box,.pop_modal_impressum_box{
	position:absolute;
	top:0;
	bottom:0;
	left:0;
	right:0;
	display:flex;
	justify-content:center;
	align-items:center;
}
.pop_modal_politik_box > div,.pop_modal_impressum_box > div{
	width: 700px;
	background: #fff;
	padding: 40px;
	position: relative;
	max-height: 80vh;
	box-shadow: 0 0 50px rgba(0, 0, 0, 0.3);
	border-radius:20px;
}
.pop_modal_politik_box h3,.pop_modal_impressum_box h3{
	font: 700 30px / 34px "Google Sans";
	margin-bottom:20px;
}
.pop_modal_politik_box .scroll_box,.pop_modal_impressum .scroll_box{
	width: 100%;
	overflow-y: auto;
	padding: 0;
	font-size: 18px;
	line-height: 24px;
	max-height: 70vh;
}
.scroll_box p{
	margin-bottom:15px;
}
.scroll_box p:last-child{
	margin-bottom:0;
}
.scroll_box b{
	font-weight:700;
}
.scroll_box h4{
	font-size:120%;
	font-weight:700;
	margin:40px 0 20px;
}
.scroll_box ul{
	margin:15px 0 15px 20px;;
}
.scroll_box li{
	padding-left:20px;
	position:relative;
	list-style:none;
}
.scroll_box li:before{
	content:'';
	position:absolute;
	left:0;
	top:10px;
	width:6px;
	height:6px;
	border-radius:50%;
	background:#CED8E2;
}
.scroll_box a{
	display:inline-block;
	text-decoration:none;
	color:#D5B276
}
@keyframes recom_blinking{
0%{transform: scale(1.05)}
25%{transform: rotate(-5deg)}
50%{transform: scale(1.05)}
75%{transform: rotate(5deg)}
100%{transform: scale(1.05) rotate(0deg)}
}
.for_bots *{
	transition:0s !important;
}
