.element_page {
	display: flex;
	-webkit-justify-content: flex-start;
	justify-content: flex-start;
	-webkit-align-items: flex-start;
	align-items: flex-start
}

.element_page * {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	padding: 0;
	margin: 0;
	outline: 0
}

.element_page .photo {
	min-width: 505px;
	height: 370px;
	display: block;
	margin-right: 30px;
	-webkit-background-size: contain !important;
	-o-background-size: contain !important;
	background-size: contain !important
}

.element_page .props .title {
	margin-bottom: 8px
}

.element_page .props .title p {
	padding: 0;
	margin: 0;
	font-weight: 600;
	font-size: 27px;
	line-height: 100%;
	color: #005C8A;
	margin-bottom: 5px
}

.element_page .props .title p:first-of-type {
	font-size: 30px
}

.element_page .props .title .article {
	font-weight: 400;
	font-size: 17px;
	line-height: 21px;
	color: #333
}

.element_page .props .tpi_jpi_nm {
	min-width: 290px;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
	margin-bottom: 20px
}

.element_page .props .tpi_jpi_nm .nm,
.element_page .props .tpi_jpi_nm .tpi_jpi {
	width: 50%;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
	height: 50px;
	padding: 10px 15px
}

.element_page .props .tpi_jpi_nm .tpi_jpi {
	background: #005C8A
}

.element_page .props .tpi_jpi_nm .nm {
	background: #F17420
}

.element_page .props .tpi_jpi_nm span {
	font-weight: 400;
	font-size: 20px;
	color: #FFF;
	white-space: nowrap
}

.element_page .props .tpi_jpi_nm span.val {
	font-weight: 700;
	font-size: 28px
}

.element_page .props .props_table tr {
	width: 100%
}

.element_page .props .props_table tr td {
	vertical-align: middle;
	width: auto;
	position: relative;
	height: 33px
}

.element_page .props .props_table tr td:after {
	position: absolute;
	content: "";
	width: 100%;
	height: 0;
	border-bottom: .5px dashed #FF7AAB;
	bottom: 5px;
	left: 0;
	right: 0;
	z-index: 1
}

.element_page .props .props_table tr td p {
	position: absolute;
	height: 25px;
	z-index: 500;
	padding: 0;
	margin: 0;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	font-size: 20px;
	line-height: 100%;
	color: #000;
	background-color: #FFF;
	width: -moz-fit-content;
	width: -webkit-fit-content;
	width: fit-content;
	bottom: 0
}

.element_page .props .props_table tr td p:first-of-type {
	text-align: left;
	font-weight: 600;
	padding-right: 10px;
	left: 0
}

.element_page .props .props_table tr td p:last-of-type {
	text-align: right;
	right: 0;
	font-weight: 300;
	padding-left: 10px
}

.element_page .buy {
	margin-left: 30px
}

.element_page .buy .btn {
	-webkit-border-radius: 30px;
	border-radius: 30px;
	overflow: hidden;
	background: #FF7AAB;
	color: #FFF;
	text-align: center;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	font-weight: 600;
	font-size: 20px;
	margin-bottom: 20px;
	cursor: pointer;
	width: 180px;
	height: 50px
}

.element_page .buy p {
	font-weight: 400;
	font-size: 20px;
	line-height: 37px;
	color: #333
}

.element_page .buy p a {
	text-decoration: none;
	color: #005C8A
}

.element_page .buy p a:hover {
	text-decoration: underline
}

.section.form-consultation-wrapper {
	-webkit-box-shadow: none !important;
	box-shadow: none !important;
	border: none !important
}

.page-title .__title {
	display: none !important
}

.block_txt {
	margin-top: 30px
}

.document__element {
	padding: 10px;
	background-color: #00559C;
	color: #fff;
	border-radius: 5px;
	transition: background-color 0.2s ease-out;
	display: inline-flex;
	align-items: center;
	gap: 10px;
}

.document__element:hover,
.document__element:active,
.document__element:focus {
	color: #fff;
	background-color: #3571a3;
}

@media screen and (max-width:1100px) {
	.element_page {
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap
	}

	.element_page .photo {
		min-width: 400px;
		height: 285px
	}

	.element_page .buy {
		position: relative;
		width: 100%;
		margin-left: 0;
		margin-top: 30px
	}

	.element_page .buy .btn {
		position: relative;
		left: 50%;
		-webkit-transform: translateX(-50%);
		-moz-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		-o-transform: translateX(-50%);
		transform: translateX(-50%)
	}

	.element_page .buy p {
		text-align: center
	}
}

@media screen and (max-width:900px) {
	.element_page .photo {
		min-width: 300px;
		height: 223px
	}

	.element_page .props .title {
		margin-bottom: 5px
	}

	.element_page .props .title p {
		font-size: 15px
	}

	.element_page .props .title p:first-of-type {
		margin-bottom: 5px;
		font-size: 17px
	}

	.element_page .props .title .article {
		font-size: 13px;
		line-height: 16px
	}

	.element_page .props .tpi_jpi_nm {
		min-width: 215px;
		margin-bottom: 10px
	}

	.element_page .props .tpi_jpi_nm .nm,
	.element_page .props .tpi_jpi_nm .tpi_jpi {
		height: 30px
	}

	.element_page .props .tpi_jpi_nm span {
		font-size: 14px
	}

	.element_page .props .tpi_jpi_nm span.val {
		font-size: 22px;
		line-height: 100%
	}

	.element_page .props .props_table tr td {
		height: 21px
	}

	.element_page .props .props_table tr td p {
		font-size: 15px;
		height: 20px
	}

	.element_page .buy p {
		line-height: 30px
	}
}

@media screen and (max-width:580px) {
	.element_page {
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
		-webkit-flex-wrap: nowrap;
		-ms-flex-wrap: nowrap;
		flex-wrap: nowrap;
		position: relative
	}

	.element_page .photo {
		margin-right: 0;
		width: 100%;
		margin-top: 45px;
		margin-bottom: 15px;
		height: 370px
	}

	.element_page .props {
		width: 100%
	}

	.element_page .title {
		width: 100%;
		position: absolute;
		left: 50%;
		-webkit-transform: translateX(-50%);
		-moz-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		-o-transform: translateX(-50%);
		transform: translateX(-50%);
		top: -20px;
		margin-bottom: 0 !important
	}

	.element_page .title .article,
	.element_page .title p {
		text-align: center
	}

	.element_page .title p {
		font-size: 18px;
		white-space: nowrap
	}

	.element_page .title p:first-of-type {
		font-size: 21px
	}

	.element_page .buy p {
		font-size: 15px;
		line-height: 20px
	}
}

@media screen and (max-width:490px) {
	.element_page .photo {
		height: 310px
	}
}

@media screen and (max-width:420px) {
	.element_page .photo {
		height: 270px
	}
}

@media screen and (max-width:360px) {
	.element_page .photo {
		height: 223px
	}
}
