@media screen and (max-width: 1800px) {
	.slogan_title {
		font-size: 7.5vmin;
		padding-right: 500px;
		padding-left: 50px;
	}
	.slogan_text {
		padding-right: 550px;
		padding-left: 50px;
	}
	.slogan {
		background-position: calc(100% + 150px) center;
	}
}



@media screen and (max-width: 1540px) {
	.our_pred,
	.op_sect {
		text-align: center;
	}
	.our_pred a:nth-child(4n) {
		margin-right: 20px;
	}
	.our_pred a {
		display: inline-block;
		margin: 0 20px 40px;
		float: none;
	}
}



@media screen and (max-width: 1480px) {
	.comments {
		text-align: center;
		display: block;
	}
	.comment_block {
		display: inline-block;
		text-align: center;
		margin: 0 50px 50px;
	}
	.photo_author {
		display: inline-block;
	}
	.top_line {
		margin-bottom: 10px;
	}
	.next_page {
		padding-left: 60px;
		height: 55px;
		padding-top: 10px;
	}
	.nav_line {
		margin-bottom: 10px;
	}
	.slogan {
		min-height: initial;
		height: calc(100vh - 135px);
	}
	.cmap_label {
		width: 15%;
		right: 20px;
		bottom: 20px;
	}
	.next_page {
		display: none;
	}
}



@media screen and (max-width: 1180px) {
	.map_page {
		display: none;
	}
	.custom_map {
		min-height: 95vh;
	}
	.ac_row .ac_inner:after {
		content: '';
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		background: rgba(255,255,255,0.5);
	}
	.ac_title {
		margin-bottom: 20px;
	}
	.ac_title,
	.ac_text {
		width: 100%;
		text-align: center;
		position: relative;
		z-index: 50;
	}
	.ac_row {
		background-size: cover !important;
	}
	#header_section {
		height: initial;
	}
	.prod_content .left_sect,
	.prod_content .right_sect {
		float: none;
		width: 100%;
		max-width: initial;
	}
	.list_block {
		text-align: center;
	}
	.list_block ul {
		width: 100%;
		padding: 0 15px;
	}
}



@media screen and (max-width: 1080px) {
	.custom_map {
		display: none;
	}
	.nav_line nav ul li {
		margin-right: 5px;
	}
	.nav_line nav ul li.book_btn a {
		padding: 5px 15px;
	}
	.slogan_title {
		font-size: 36px;
		padding-right: 300px;
	}
	h1.slogan_title {
	margin-top: 50px;
}
	.slogan_text {
		font-size: 20px;
		padding-right: 350px;
	}
	.slogan {
		display: block;
		padding-top: 100px;
		min-height: 500px;
	}
	.right_image img,
	.left_image img,
	.center_image img {
		float: none;
		width: 100%;
		margin: 0;
		margin-bottom: 30px;
		max-width: initial;
	}
}



@media screen and (max-width: 900px) {
	.menu_btn {
		display: block;
	}
	.nav_line {
		position: relative;
		-webkit-transition: 0.5s;
		-o-transition: 0.5s;
		transition: 0.5s;
	}
	.nav_line nav ul {
		height: 0;
		overflow: hidden;
		position: absolute;
		top: 100%;
		left: 0;
		width: 100%;
		text-align: center;
		-webkit-transition: 0.5s;
		-o-transition: 0.5s;
		transition: 0.5s;
		display: flex;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
justify-content: space-between;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
align-items: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	padding: 0 20px;
	}
	.nav_line.active {
		margin-bottom: 50px;
	}
	.nav_line.active nav ul {
		height: 50px;
	}
	.package {
		padding: 30px 30px;
		width: 48%;
		margin-right: 4%;
	}
	.package:nth-child(2n) {
		margin-right: 0;
	}
	.title_link {
		font-size: 30px;
	}
	.title_pred {
		font-size: 60px;
	}
}



@media screen and (max-width: 768px) {
	.package {
		padding: 30px 30px 70px;
		width: 100%;
		margin-right: 0;
		text-align: center;
		margin-bottom: 30px;
		min-height: 500px;
	}
	.package span.br {
		display: none;
	}
	.package ul {
		width: 100%;
	}
	.learn_more {
		left: calc(50% - 70px);
		bottom: 20px;
	}
	.ac_row {
		padding: 100px 0;
		height: initial;
	}
	.ac_row .ac_inner {
		position: static;
	}
	.ac_title {
		padding-top: 0;
	}
	.slider_box .bx-pager {
		display: none;
	}
	.slider_box .bx-controls-direction .bx-prev {
		top: -70px;
		left: calc(50% - 50px);
	}
	.slider_box .bx-controls-direction .bx-next {
		top: -70px;
		left: calc(50% + 20px);
	}
	.rs_title {
		width: 100%;
		font-size: 9vmin;
		text-align: center;
	}
	.slogan {
		padding-top: 50px;
	}
	.slogan_title {
		font-size: 28px;
		padding-right: 220px;
	}
	.slogan_text {
		font-size: 17px;
		padding-right: 250px;
	}
	.top_line .address,
	.top_line .phone {
		float: none;
		margin-bottom: 20px;
	}
	.inner_fixed_row ul li .guests img,
	.inner_fixed_row ul li .days img {
		display: none;
	}
	.inner_fixed_row ul li span,
	.inner_fixed_row ul li span.bp_param select {
		font-size: 20px;
		line-height: 25px;
	}
	.inner_fixed_row ul {
		display: block;
		display: inline-flex;
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
flex-direction: column;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-wrap: wrap;
	}
	.inner_fixed_row ul li {
		display: block;
		line-height: 25px;
		width: 50%;
	}
	.inner_fixed_row ul li .bp_order {
		padding: 0 20px;
	}
	.inner_fixed_row ul li .price span.bp_price_num {
		font-size: 22px;
	}
	.inner_fixed_row ul li .price span.bp_rubl {
		font-size: 17px;
	}
}



@media screen and (max-width: 630px) {
	.nav_line.active {
		margin-bottom: 220px;
	}
	.nav_line nav ul {
		height: 0;
		display: block;
		background: #fff;
	}
	.nav_line.active nav ul {
		height: 220px;
		display: block;
	}
	.nav_line nav ul li {
		display: block;
		text-align: center;
		margin-bottom: 10px;
	}
	.title_link {
		font-size: 20px;
	}
	.title_pred {
		font-size: 40px;
	}
	.bp_title {
		font-size: 30px;
	}
	.param_lists li {
		margin-bottom: 30px;
	}
	.param_lists {
		margin-bottom: 40px;
	}
	.param_lists li span {
		font-size: 20px;
	}
	.bp_price_block {
		display: block;
		margin-bottom: 30px;
	}
	.banner_pred {
		height: auto;
		padding: 90px 15px;
	}
	.prod_content {
		margin: 40px auto;
	}
	.bp_text {
		font-size: 20px;
	}
}



@media screen and (max-width: 580px) {
	.comment_block {
		display: block;
		width: 100%;
		margin: 0 0 40px;
	}
	.comment_text {
		font-size: 5vmin;
		width: 100%;
		min-width: initial;
		max-width: initial;
		text-align: center;
		padding-bottom: 8vmin;
	}
	.cb_head {
		height: initial;
	}
	.ac_title {
		font-size: 35px;
	}
	.ac_text {
		font-size: 25px;
	}
	.ac_row .ac_inner:after {
		content: '';
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		background: rgba(255,255,255,0.8);
	}
	.slogan {
		padding-top: 20px;
		background-position: calc(50% - 35px) bottom;
		min-height: initial;
		padding-bottom: 400px;
		height: initial;
	}
	.slogan_title {
		padding-left: 0;
		font-size: 28px;
		padding-right: 0;
		text-align: center;
		margin-bottom: 10px;
	}
	.slogan_text {
		padding-left: 0;
		font-size: 17px;
		padding-right: 0;
		text-align: center;
	}
	.prod_content .title {
		font-size: 32px;
	}
	.prod_content .text {
		font-size: 15px;
	}
	.prod_content .comments {
		margin-bottom: 50px;
	}
}



@media screen and (max-width: 500px) {
	.slogan {
		padding-bottom: 350px;
	}
}



@media screen and (max-width: 440px) {
	.slogan {
		padding-bottom: 280px;
	}
	.slogan_title {
		font-size: 24px;
	}
	.slogan_text {
		font-size: 15px;
	}
	.nav_line {
		padding: 10px 5px;
	}
	.nav_line.active nav ul {
		padding-top: 20px;
	}
	.title_link,
	.title_pred,
	.bp_title {
		text-align: center;
		display: block;
	}
	.title_link:after {
		display: none;
	}
	.title_link {
		text-decoration: underline;
	}
	.title_link:hover {
		text-decoration: none;
	}
	.param_lists li {
		margin-bottom: 30px;
	}
	.title_pred {
		margin-bottom: 35px;
	}
	.banner_pred {
		padding: 50px 15px;
	}
	.bp_title {
		font-size: 25px;
	}
	.our_pred a:nth-child(4n) {
		margin-right: 0;
	}
	.our_pred a {
		margin: 0 0 30px;
		width: 100%;
	}
}



@media screen and (max-width: 380px) {
	.bp_price_block .bp_price_num {
		font-size: 35px;
	}
	.bp_price_block .bp_rubl,
	.bp_price_block .bp_days {
		font-size: 20px;
	}
	.prod_content .title {
		font-size: 25px;
	}
}



@media screen and (max-width: 340px) {
	.wrapper {
		padding: 0 10px;
	}
	.slogan {
		padding-bottom: 220px;
	}
}