@font-face {
  font-family: 'Manrope';
  src: local('Manrope Regular'), local('Manrope-Regular'),
  url('../fonts/Manrope/Manrope-Regular.woff2') format('woff2'),
  url('../fonts/Manrope/Manrope-Regular.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Manrope';
  src: local('Manrope Medium'), local('Manrope-Medium'),
  url('../fonts/Manrope/Manrope-Medium.woff2') format('woff2'),
  url('../fonts/Manrope/Manrope-Medium.woff') format('woff');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Manrope';
  src: local('Manrope Semibold'), local('Manrope-Semibold'),
  url('../fonts/Manrope/Manrope-Semibold.woff2') format('woff2'),
  url('../fonts/Manrope/Manrope-Semibold.woff') format('woff');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Manrope';
  src: local('Manrope Bold'), local('Manrope-Bold'),
  url('../fonts/Manrope/Manrope-Bold.woff2') format('woff2'),
  url('../fonts/Manrope/Manrope-Bold.woff') format('woff');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

#main_anchor_top {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 0px;
  margin: 0px;
  padding: 0px;
}

#main_anchor {
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 0px;
  margin: 0px;
  padding: 0px;
}
a{
  color: rgb(255,255,255);
  text-decoration: none;
  opacity: 1;
  transition: 0.2s;
}
a:hover{

}
a.theme_link_dorange{
  color: #EF896F;
  border-bottom: 1px solid transparent;
}
a.theme_link_dorange:hover{
  border-bottom: 1px solid #EF896F;
}
a.theme_link_orange{
  color: #A35E4C;
  border-bottom: 1px solid transparent;
}
a.theme_link_orange:hover{
  border-bottom: 1px solid #A35E4C;
}
a.theme_link_orange.reverse{
  color: #A35E4C;
  border-bottom: 1px solid #A35E4C;
}
a.theme_link_orange.reverse:hover{
  border-bottom: 1px solid transparent;
}
a.theme_link{
  color: rgb(255,255,255);
  text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,1);
}
a.theme_link:hover{
  color: rgb(255,255,255);
  text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,0);
}
a.theme_link_dark{
  color: rgb(0,0,0);
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,1);
}
a.theme_link_dark:hover{
  color: rgb(0,0,0);
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,0);
}
a.def{
  border-bottom: none;
  text-decoration: none;
  color: inherit;
}
body {
  font-family: 'Manrope' !important;
  min-height: 680px;
  font-size: 14px;
  color: rgb(255,255,255);
  background-color: #ffc2b2;
}
img{
  max-width: 100%;
}
.menu_main_element{
  cursor: pointer;
}

.theme_white{
  color: rgb(255,255,255);
}
.theme_black{
  color: rgb(0,0,0);
}
.theme_dgrey{
  color: #333333;
}
.theme_border{
  border-radius: 5px;
}

.theme_border_24{
  border-radius: 24px;
}
.theme_border_20{
  border-radius: 20px;
}
.theme_border_16{
  border-radius: 16px;
}
.theme_border_12{
  border-radius: 12px;
}
.theme_border_8{
  border-radius: 8px;
}

.theme_overflow{
  overflow: hidden;
}

.theme_back_lorange{
  background-color: #FFAD99;
}
.theme_back_orange{
  background-color: #EF896F;
}
.theme_back_yellow{
  background-color: #FBE390;
}
.theme_back_white{
  background-color: #FFFFFF;
}

.theme_regular{
  font-weight: 400;
}
.theme_medium{
  font-weight: 500;
}
.theme_semibold{
  font-weight: 600;
}
.theme_bold{
  font-weight: 700;
}

.theme_upper{
  text-transform: uppercase;
}

.user_field{
  height: 42px;
  border: 1px solid rgba(153, 153, 153, 1);
  margin-bottom: 10px;
}
.has-error .user_field{
  border: 1px solid #a94442;
}

.pp_block{

}
.pp_block .btn-close{
  position: absolute;
  top: 0px;
  right: 0px;
  transform: none;
  margin: 0px;
  width: 50px;
  height: 50px;
  align-items: center;
  padding: 0px;
  outline: none !important;
  z-index: 1;
  box-shadow: none !important;
  border: none !important;
}
.pp_block .modal-dialog{
  max-width: 560px;
}

#privacy_block{
  display: none;
  position: fixed;
  bottom: 0px;
  left: 0px;
  width: 100%;
  background: rgb(255, 255, 255);
  padding-top: 12px;
  padding-bottom: 12px;
  box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.1);
  z-index: 101;
}
#privacy_block .privacy_wrap{
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#privacy_block .privacy_wrap .privacy_info{
  padding-right: 45px;
}
#privacy_block .privacy_wrap .privacy_info a{
  color: #333333;
  border-bottom: 1px solid rgba(51,51,51,1);
}
#privacy_block .privacy_wrap .privacy_info a:hover{
  border-bottom: 1px solid rgba(51,51,51,0);
}
#privacy_block .privacy_wrap .btn_default{
  font-size: 16px;
  padding: 0px 24px;
  white-space: nowrap;
}
@media (min-width: 768px) and (max-width: 992px) {
  #privacy_block .privacy_wrap .privacy_info{
    font-size: 14px;
  }
  #privacy_block .privacy_wrap .btn_default{
    font-size: 14px;
  }
}

@media (max-width: 767px) {
  #privacy_block .privacy_wrap{
    flex-direction: column;
    text-align: center;
    font-size: 12px;
  }
  #privacy_block .privacy_wrap .privacy_info {
    padding-right: 0px;
    padding-bottom: 6px;
  }
  #privacy_block .privacy_wrap .btn_default{
    height: 42px;
  }
}

#popup_promo_utm .modal-dialog{
  max-width: 380px;
  text-align: center;
}
#popup_promo_utm .modal-dialog .form_cat{
  background-color: #f7f7f9;
}
#popup_discount {
  font-size: 36px;
  line-height: 1.2;
  margin-top: 25px;
  font-weight: 600;
}
#popup_promo_utm .input_promo {
  margin-bottom: 24px;
}
#popup_promo_utm .btn_default_pop {
  display: flex;
}
.popup_title_utm {
  padding: 51px 0px 25px 0px;
}
.popup_title_utm .title_utm {
  font-size: 36px;
  color: rgb(0, 0, 0);
  margin-top: 20px;
}
.popup_title_utm p {
  font-size: 18px;
  color: #333333;
  line-height: 1.2;
}
#popup_desc_mini {
  font-size: 18px;
  color: rgb(0, 0, 0);
  margin-top: 5px;
}
.input_promo {
  padding-left: 140px;
  height: 48px;
  position: relative;
  margin-bottom: 15px;
  border: none;
}
.input_promo label {
  position: absolute;
  left: 0px;
  top: 0px;
  width: 140px;
  border-radius: 7px 0px 0px 7px;
  background-color: #EF896F;
  color: rgb(255, 255, 255);
  text-align: center;
  padding: 0px 10px 0px 10px;
  margin-bottom: 0px;
  display: flex;
  justify-content: center;
  flex-direction: row;
  align-items: center;
  font-size: 16px;
  font-weight: normal;
  height: 48px;
}
.input_promo .popup_promo {
  display: inline-flex;
  width: 100%;
  height: 48px;
  padding: 0px 15px;
  float: left;
  text-align: center;
  text-transform: uppercase;
  font-size: 24px;
  color: rgb(33, 33, 33);
  justify-content: center;
  align-items: center;
  border-radius: 0px 7px 7px 0px;
  border-left: none !important;
  background: rgb(255, 255, 255);
}
.popup_title_utm svg{

}
.pp_block .modal-header{
  border: none;
  padding-bottom: 0px;
}
.pp_block .dop{
  font-size: 12px;
}
.form_cosmo .dop{
  font-size: 12px;
}
.main_group .dop{
  font-size: 12px;
}

.main_stars .main_title h2 br{
  display: none;
}

.main_block{
  margin-bottom: 52px;
}

.head_title_wrap{
  position: relative;
}
.head_title_wrap:before{
  content: "";
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background-position: 100% 0px;
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-image: url("../images/cat/main/tiny/b_paws.png");
}
.head_title_wrap>div{
  position: relative;
  z-index: 1;
}
.head_title h1{
  font-size: 62px;
  text-transform: uppercase;
  line-height: 1;
}
.head_title h1 br{

}
.main_title h2{
  font-weight: 600;
  font-size: 36px;
  margin-bottom: 18px;
}

.main_title.flex_title{
  display: flex;
  justify-content: flex-start;
  align-items: center;
  column-gap: 32px;
}

.btn_default{
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  padding: 0px 40px;
  cursor: pointer;
  background-color: #FBE390;
  color: #333333;
  transition: 0.2s;
  border-radius: 16px;
  opacity: 1;
  font-weight: 500;
  min-width: auto;
  position: relative;
}
.btn_default:hover{
  color: #ffffff !important;
  background-color: #333333 !important;
  opacity: 1 !important;
}

.btn_default.btn_medium{
  height: 56px;
  font-size: 18px;
}

.btn_default.btn_big{
  height: 72px;
  font-size: 21px;
}

.btn_default.btn_default_icon>span{
  position: relative;
  padding-left: 34px;
  min-height: 25px;
  display: flex;
  align-items: center;
}
.btn_default.btn_default_icon>span:before{
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  width: 24px;
  height: 100%;
  background-size: 24px auto;
  background-repeat: no-repeat;
  background-position: 0px 50%;
  filter: grayscale(0) brightness(1);
}
.btn_default.btn_default_icon:hover>span:before{
  filter: grayscale(1) brightness(10);
}
.btn_default.btn_default_icon.btn_default_icon_cat>span:before{
  background-image: url("../images/cat/icons/btn_icon_cat.png");
}

.btn_default.def{
  color: #333333;
}
.btn_default.def:hover{
  background-color: #333333;
  color: #ffffff;
}

.main_menu{
  padding: 0px;
  position: absolute;
  left: 0px;
  width: 100%;
  z-index: 4;
  top: 20px;
}
.main_menu.main_menu_foot{
  position: relative;
  top: 0px;
}
#navbarsExample11{

}
.main_menu .logo{
  font-size: 32px;
}
.main_menu .logo img{

}
.main_menu .navbar-nav li{
  margin: 0px 3px;
}
.main_menu .navbar-nav li a,
.main_menu .navbar-nav li span{
  font-size: 16px;
  color: rgb(255,255,255);
  position: relative;
}
.main_menu .navbar-nav li a span,
.main_menu .navbar-nav li span span{
  position: relative;
  padding-bottom: 3px;
}
.main_menu .navbar-nav li a span:before,
.main_menu .navbar-nav li span span:before{
  content: "";
  position: absolute;
  bottom: 0px;
  left: 50%;
  width: 0%;
  height: 1px;
  background-color: rgb(255,255,255);
  transition: 0.2s;
  transform: translate(-50%,0px);
}
.main_menu .navbar-nav li a:hover span:before,
.main_menu .navbar-nav li span:hover span:before{
  width: 100%;
}
.main_menu .navbar-nav li a.active span:before,
.main_menu .navbar-nav li span.active span:before{
  width: 100%;
}

.main_head{
  padding-top: 124px;
  position: relative;
  margin-bottom: 52px;
}
.main_head>div{
  position: relative;
  z-index: 1;
}
.main_head_image{
  height: 100%;
  position: relative;
}
.main_head_image>img{
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 50%;
}

#anchor_video .main_head_image:before{
  content: "";
  display: block;
  padding-top: 58.25%;
}
#anchor_video .main_head_image img{

}
.main_cities_wrap{
  min-height: 650px;
  height: calc(100vh - 80px);
}
.main_cities_wrap .head_title_wrap{
  height: calc(100% - 45px);
  display: flex;
  align-items: center;
  justify-content: center;
}
.navbar_cities{
  position: fixed !important;
  bottom: 10px;
  top: auto !important;
}
.main_head.main_cities{
  display: flex;
  flex-direction: column;
  height: 100%;
}
.main_head.main_cities h1{
  line-height: 1.1;
}
.main_head.main_cities .descr{
  font-size: 18px;
}
.main_head.main_cities .btns_block{
  display: flex;
  align-items: center;
  justify-content: center;
  row-gap: 24px;
  column-gap: 24px;
  flex-wrap: wrap;
}
.main_head.main_cities .btns_block .btn_default{
  min-width: 190px;
}

.tags{
  display: flex;
  align-items: center;
  column-gap: 5px;
  flex-wrap: wrap;
  row-gap: 14px;
}
.tags .tag_item{
  padding: 5px 12px;
}

.tags_icons{
  display: flex;
  align-items: center;
  column-gap: 14px;
  flex-wrap: wrap;
  row-gap: 14px;
}
.tags_icons .tag_item_icon{
  padding: 5px 17px 5px 47px;
  background-color: rgb(255, 255, 255);
  color: #4A11C2;
  background-image: url(../images/svg/icon_li_star.svg);
  background-position: 20px 50%;
  background-repeat: no-repeat;
  background-size: 18px auto;
}
.tags_icons .tag_item_icon.active{
  background-color: #4A11C2;
  color: #ffffff;
  background-image: url(../images/svg/icon_li_star_white.svg);
}

/* Иконка времени в десктопном меню */
#main_menu_top .menu_right_actions {
  display: flex;
  align-items: center;
  gap: 10px; /* вот этот зазор и регулирует расстояние */
  margin-left: auto;
  padding-left: 16px;
}

#main_menu_top .menu_time_desktop,
#main_menu_top .menu_ticket_desktop {
  padding-left: 0;
}

#main_menu_top .menu_time_wrap {
  position: relative;
  display: flex;
  align-items: center;
}

#main_menu_top .menu_time_btn {
  width: 46px;
  height: 46px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  border-radius: 16px;
  background: transparent;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: 0.25s ease;
  padding: 0;
  box-shadow: none;
}

#main_menu_top .menu_time_btn:hover,
#main_menu_top .menu_time_wrap:hover .menu_time_btn,
#main_menu_top .menu_time_wrap:focus-within .menu_time_btn {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.6);
  transform: translateY(-1px);
}

#main_menu_top .menu_time_dropdown {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  min-width: 340px;
  max-width: 420px;
  padding: 16px;
  border-radius: 24px;
  background: #fff;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.14);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: 0.25s ease;
  z-index: 30;
}

#main_menu_top .menu_time_wrap:hover .menu_time_dropdown,
#main_menu_top .menu_time_wrap:focus-within .menu_time_dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

#main_menu_top .menu_time_dropdown .tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

#main_menu_top .menu_time_dropdown .tag_item {
  margin: 0;
}

/* чтобы popup не прилипал к краю на узких desktop-экранах */
@media (max-width: 1199.98px) {
  #main_menu_top .menu_time_dropdown {
    right: -40px;
    min-width: 320px;
  }
}

/*youtube videos*/
.video_block {

}
.containingBlock {
  width: 100%;
  overflow: hidden;
}
.videoWrapper {
  position: relative;
  padding-bottom: 58.25%;
  height: 0;
  overflow: hidden;
}

.videoWrapper div,
.videoWrapper iframe,
.videoWrapper video,
.videoWrapper img{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
  object-fit: cover;
  object-position: 50% 50%;
}

.videoWrapper.active > div:before {
  display: none;
}

.videoWrapper.videoWrapper_preview > div:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  margin-left: -70px;
  margin-top: -60px;
  background-image: url("../images/cat/svg/icons/icon_play.svg");
  background-position: calc(50% + 4px) 50%;
  background-size: 42px auto;
  background-repeat: no-repeat;
  width: 140px;
  height: 100px;
  background-color: #FBE390;
  border-radius: 28px;
  z-index: 1;
  transition: 0.2s;
}
.videoWrapper.videoWrapper_preview:hover > div:before{
  opacity: 0.85;
}
.videoWrapper.videoWrapper_preview > div:after{
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.1);
  transition: 0.2s;
  opacity: 1;
}
.videoWrapper.videoWrapper_preview:hover > div:after{
  opacity: 0;
}
  /*youtube videos end*/

.main_may{

}
.main_may .may_image{
  position: relative;
}
.main_may .may_image:before{
  content: "";
  display: block;
  padding-top: 164%;
}
.main_may .may_image img{
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 50%;
}

.main_therapy{

}
.main_therapy .therapy_image{
  position: relative;
}
.main_therapy .therapy_image:before{
  content: "";
  display: block;
  padding-top: 64%;
}
.main_therapy .therapy_image img{
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 50%;
}

.main_faq .faq_item .di_up{
  border-top: 1px solid #ffffff;
  min-height: 62px;
  display: flex;
  position: relative;
  padding-right: 62px;
  cursor: pointer;
  align-items: center;
}
.main_faq .faq_item:last-child{
  border-bottom: 1px solid rgb(255,255,255);
}
.main_faq .faq_item .di_up .di_title{
  white-space: normal;
  width: 100%;
}
.main_faq .faq_item .di_up .di_title h3{
  font-size: 21px;
  margin: 0px;
}
.main_faq .faq_item .di_up:hover .di_title h3,
.main_faq .faq_item.active .di_up .di_title h3{
  color: #EF896F;
}
.main_faq .faq_item .di_up .di_plus{
  transition: 0.2s;
  width: 62px;
  height: 62px;
  position: absolute;
  top: 0px;
  right: 0px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.main_faq .faq_item .di_up .di_plus>div{
  position: relative;
  width: 40px;
  height: 40px;
  background-color: rgba(255,255,255,0);
  border-radius: 50vh;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: 0.2s;
}
.main_faq .faq_item .di_up .di_plus svg{
  width: 24px;
  height: 24px;
  transform: rotate(0deg);
  transform-origin: 50% 50%;
  transition: 0.2s;
  position: relative;
}
.main_faq .faq_item .di_up .di_plus svg path{
  transition: 0.2s;
}
.main_faq .faq_item.active .di_up .di_plus>div {
  background-color: rgba(255, 255, 255, 1);
}
.main_faq .faq_item.active .di_up .di_plus svg{
  transform: rotate(-45deg);
}
.main_faq .faq_item.active .di_up .di_plus svg path{
  stroke: #EF896F;
}

.main_faq .faq_item:hover .di_up .di_plus>div {
  background-color: rgba(255, 255, 255, 1);
}
.main_faq .faq_item:hover .di_up .di_plus svg path{
  stroke: #EF896F;
}
.main_faq .faq_item .di_bottom{
  display: none;
  font-weight: 300;
  padding-bottom: 30px;
  background-color: transparent;
  font-size: 14px;
}

.main_photo{
  position: relative;
  overflow: hidden;
  max-width: 1920px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.main_video{

}
.main_video .main_video_in{
  position: relative;
}
.main_video .main_video_in>div{
  position: relative;
  z-index: 1;
}
.main_video .main_video_in:before{
  content: "";
  position: absolute;
  bottom: 0px;
  left: 0px;
  background-image: url(../images/cat/svg/back_shar.svg);
  background-size: 550px auto;
  background-position: 80px calc(100% - 35px);
  background-repeat: no-repeat;
  width: 100%;
  height: 100%;
}

.partner_item_wrap{
  margin-bottom: 24px;
}
@media (min-width:1199.98px) {
  .partner_item_wrap{
    width:20%;
  }
}
.partner_item{
  background: #ffffff;
  min-height: 115px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10%;
  height: 100%;
  border-radius: 12px;
  overflow: hidden;
}
.partner_item img{

}

.main_ticket{

}
.ticket_item{

}
.ticket_item .t_info{

}
.ticket_item .t_info .btn_default{
  min-width: 155px;
  max-width: 155px;
  padding: 0px 12px;
  width: auto;
}
.ticket_item .t_image{
  position: relative;
}
.ticket_item .t_image:before{
  content: "";
  display: block;
  padding-top: 56.25%;
}
.ticket_item .t_image img{
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 50%;
}

.tickets_wrap .add{

}

.def_slider_wrap{
  display: none;
  width: 85%;
}
.def_slider{
  margin: 0px -12px;
}
.def_slider .slick-list{
  overflow: visible;
}
.ds_item{
  margin: 0px 12px;
}
.ds_item .ds_image{
  position: relative;
  overflow: hidden;
  background-color: rgb(220, 220, 220);
}
.ds_image .tags{
  position: absolute;
  z-index: 1;
  top: 7px;
  left: 7px;
}
.ds_image .tags .tag_item {
  padding: 3px 10px;
  font-size: 12px;
  border-radius: 8px;
}

.ds_item .ds_image .containingBlock{
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
}
.ds_item .ds_image .containingBlock .videoWrapper.videoWrapper_preview > div:before{
  width: 52px;
  height: 52px;
  margin-left: -26px;
  margin-top: -26px;
  background-size: 20px auto;
  background-position: calc(50% + 2px) 50%;
}
.ds_item .ds_image:before{
  content: "";
  display: block;
  padding-top: 132%;
}
.ds_item .ds_image img{
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 50%;
  transform: scale(1.01);
  transition: 0.3s;
}
.ds_item .ds_image:hover img{
  transform: scale(1.06);
}
.ds_item .ds_descr{

}
.ds_item .ds_descr h3{
  font-weight: normal;
  text-transform: uppercase;
}
.ds_item .ds_descr p{
  font-size: 12px;
}

.btns_slider{
  display: flex;
  column-gap: 15px;
  align-items: center;
  margin-bottom: 30px;
}
.btns_slider .btn_sl {
  width: 40px;
  height: 40px;
  border-radius: 50vh;
  background-color: #FBE390;
  position: relative;
  cursor: pointer;
}
.btns_slider .btn_sl:before{
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background-image: url("../images/cat/svg/icons/slider_arr.svg");
  background-size: 22px auto;
  background-repeat: no-repeat;
}
.btns_slider .btn_sl_prev:before {
  background-position: calc(50% + 1px) 50%;
}
.btns_slider .btn_sl_next:before{
  background-position: calc(50% + 1px) 50%;
  transform: scale(-1, 1);
}

.btns_slider .btn_sl:hover{
  background-color: #333333;
}
.btns_slider .btn_sl:hover:before{
  filter: grayscale(1) brightness(10);
}

.gallery{ display:grid; gap:16px; }
.tile{ position:relative; overflow:hidden; border-radius:16px; margin:0; }
.tile>img{ width:100%; height:100%; object-fit:cover; display:block; object-position: 50% 45%;}

.tile.t2>img{
  object-position: 50% 70%;
}
.tile.t5>img{
  object-position: 50% 60%;
}
.tile.t8>img{
  object-position: 50% 100%;
}
.tile.t9>img{
  object-position: 50% 65%;
}
.tile.t12>img{
  object-position: 50% 75%;
}
.tile.t14>img{
  object-position: 50% 30%;
}
/* ====== XL и шире — раскладка как на макете ====== */
@media (min-width:1200px){
  /* 4 колонки: левая широкая + три равные правые */
  .gallery{
    grid-template-columns: 6fr 4fr 4fr 4fr;
    grid-auto-rows: 60px; /* в 2 раза меньше, чтобы стало 8 строк */
  }

  /* верхняя полоса */
  .t1{ grid-column:1; grid-row:1 / span 4; }   /* котёнок в кресле (большой слева, 4 ряда) */
  .t2{ grid-column:2; grid-row:1 / span 3; }   /* сиамец лежит (верх справа, 2 ряда) */
  .t3{ grid-column:3; grid-row:1 / span 4; }   /* обнимашки (высокий, 4 ряда) */
  .t4{ grid-column:4; grid-row:1 / span 4; }   /* рыжий крупно (высокий, 4 ряда) */

  /* середина/низ */
  .t5{ grid-column:1; grid-row:5 / span 4; }   /* девушка с котом (большой слева, 4 ряда) */
  .t6{ grid-column:2; grid-row:4 / span 5; }   /* кот с игрушкой (ещё выше — 6 рядов) */
  .t7{ grid-column:3 / span 2; grid-row:5 / span 4; } /* котята (широкий блок внизу, 4 ряда) */

  .t8{ grid-column:1; grid-row:9 / span 4; }   /* котёнок в кресле (большой слева, 4 ряда) */
  .t9{ grid-column:2; grid-row:9 / span 3; }   /* сиамец лежит (верх справа, 2 ряда) */
  .t10{ grid-column:3; grid-row:9 / span 4; }   /* обнимашки (высокий, 4 ряда) */
  .t11{ grid-column:4; grid-row:9 / span 4; }   /* рыжий крупно (высокий, 4 ряда) */

  /* середина/низ */
  .t12{ grid-column:1; grid-row:13 / span 4; }   /* девушка с котом (большой слева, 4 ряда) */
  .t13{ grid-column:2; grid-row:12 / span 5; }   /* кот с игрушкой (ещё выше — 6 рядов) */
  .t14{ grid-column:3 / span 2; grid-row:13 / span 4; } /* котята (широкий блок внизу, 4 ряда) */
}

/* ===== LG 992–1199px ===== */
@media (min-width:992px) and (max-width:1199.98px){
  .gallery{
    grid-template-columns: 5fr 4fr 4fr;
    grid-auto-rows: 60px;
  }

  .t1{ grid-column:1; grid-row:1 / span 4; }
  .t2{ grid-column:2; grid-row:1 / span 3; }
  .t3{ grid-column:3; grid-row:1 / span 4; }

  .t4{ grid-column:2; grid-row:4 / span 3; }
  .t5{ grid-column:1; grid-row:5 / span 6; }
  .t6{ grid-column:2; grid-row:7 / span 4; }
  .t7{ grid-column:3; grid-row:5 / span 6; }

  .t8{ grid-column:1; grid-row:11 / span 4; }
  .t9{ grid-column:2; grid-row:11 / span 3; }
  .t10{ grid-column:3; grid-row:11 / span 4; }

  .t11{ grid-column:2; grid-row:14 / span 3; }
  .t12{ grid-column:1; grid-row:15 / span 6; }
  .t13{ grid-column:2; grid-row:17 / span 4; }
  .t14{ grid-column:3; grid-row:15 / span 6; }
}

/* ===== MD/SM 576–991px ===== */
@media (min-width:576px) and (max-width:991.98px){
  .gallery{
    grid-template-columns: repeat(2,1fr);
    grid-auto-rows: 80px;
  }

  .t1{ grid-column:1 / span 2; grid-row:1 / span 4; }
  .t2{ grid-column:1; grid-row:5 / span 2; }
  .t3{ grid-column:2; grid-row:5 / span 4; }
  .t4{ grid-column:1; grid-row:7 / span 3; }

  .t5{ grid-column:2; grid-row:9 / span 5; }
  .t6{ grid-column:1; grid-row:10 / span 4; }
  .t7{ grid-column:1 / span 2; grid-row:14 / span 3; }

  .t8{ grid-column:1 / span 2; grid-row:17 / span 4; }
  .t9{ grid-column:1; grid-row:21 / span 2; }
  .t10{ grid-column:2; grid-row:21 / span 4; }
  .t11{ grid-column:1; grid-row:23 / span 3; }

  .t12{ grid-column:2; grid-row:25 / span 5; }
  .t13{ grid-column:1; grid-row:26 / span 4; }
  .t14{ grid-column:1 / span 2; grid-row:30 / span 3; }
}

.g-map-m {
  height: 100%;
  min-height: 380px;
}
.g-map-m .gmap {
  height: 100%;
  width: 100%;
  border-radius: 5px;
}

#js-gmap > ymaps {
  border-radius: 24px;
  overflow: hidden;
}

.js-map {
  border-radius: 5px;
}

.soc_wrap{
  display: flex;
  column-gap: 15px;
}
.soc{
  position: relative;
  padding-left: 27px;
  opacity: 1;
  transition: 0.2s;
}
.soc:before{
  content: "";
  position: absolute;
  border-radius: 50vh;
  left: 0px;
  top:50%;
  transform: translate(0px,-50%);
  width: 20px;
  height: 20px;
  /*background-color: #D9D9D9;*/
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
.soc:hover{
  opacity: 0.85;
}
.soc.soc_vk:before{
  background-size: 18px auto;
  background-image: url("../images/svg/icon_vk.svg");
}
.soc.soc_inst:before{
  background-size: 18px auto;
  background-image: url("../images/svg/icon_inst.svg");
}

.soc_dop_wrap{
  display: flex;
  column-gap: 30px;
}
.soc_dop{
  position: relative;
  display: flex;
  align-items: center;
  padding-left: 45px;
  background-repeat: no-repeat;
  background-position: 0px 50%;
  background-size: 35px auto;
  min-height: 35px;
}
.soc_dop.soc_mirey{
  background-image: url("../images/back/foot/ic_mirey.png");
}
.soc_dop.soc_nauka{
  background-image: url("../images/back/foot/ic_nauka.png");
}

@media (min-width:1200px) and (max-width:1399.98px){
  body{
    font-size: 12px;
  }
  .main_title h2 {
    font-size: 32px;
  }
}

@media (min-width:992px) and (max-width:1199.98px) {
  .main_menu .logo {
    font-size: 27px;
  }
  #mobile_tickets{
    display: none !important;
  }
  .main_menu .navbar-nav li a, .main_menu .navbar-nav li span {
    font-size: 12px;
  }
  .main_menu_foot.main_menu .navbar-nav-wrap{
    flex-direction: row;
    align-items: center;
  }
}

@media (min-width:768px) and (max-width:991.98px){
  .main_menu{
    position: fixed;
  }
  .main_menu .main_menu_inner{
    position: relative;
    background-color: #EF896F;
    border-radius: 12px;
    padding: 0.5rem 1rem !important;
    align-items: center;
    flex-direction: column;
    border: 1px solid rgb(255, 255, 255);
  }
  .main_menu .main_menu_inner_block{
    flex-direction: column;
  }
  .main_menu .main_menu_inner_block .navbar-nav{
    width: 100%;
  }

  .popup_title_utm {
    padding: 25px 0px 25px 0px;
  }

  #navbarsExample11 {
    width: 100%;
    padding: 0px !important;
  }
  #usedesk-messenger{
    display: none !important;
  }
  .main_head {
    padding-top: 108px;
    min-height: 380px;
    padding-bottom: 24px;
    overflow: hidden;
  }
  .main_menu .logo {
    font-size: 27px;
  }
  .main_menu .navbar-toggler{
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
  }
  .main_menu .navbar-toggler-icon{
    width: 2em;
    height: 2em;
    filter: grayscale(1) brightness(10);
  }
  .main_may .mob_add .may_image:before {
    padding-top: 56.25%;
  }
  #mobile_tickets{
    display: none !important;
  }
  .main_menu_foot.main_menu .navbar-nav-wrap{
    flex-direction: column;
    align-items: flex-start !important;
  }
}

@media (max-width:767.98px) {
  body {
    font-size: 16px;
    min-height: 450px;
  }
  .main_cities_wrap{
    min-height: max(calc(100vh - 170px), 450px);
    height: auto;
  }
  .main_head.main_cities{
    padding-top: 42px;
  }
  .navbar-cities-top{
    position: relative !important;
  }
  .main_head.main_cities .btns_block .btn_default {
    min-width: 120px;
  }
  .main_head.main_cities .btns_block {
    row-gap: 12px;
    column-gap: 12px;
  }
  .main_head.main_cities .descr{
    font-size: 16px;
  }
  .navbar_cities {
    text-align: center;
  }
  .main_menu.main_menu_foot{
    position: relative !important;
  }

  .tickets_wrap .add {
    font-size: 14px;
  }
  .tile.t10>img{
    object-position: 50% 20%;
  }
  .partner_item {
    border-radius: 8px;
    min-height: 76px;
  }
  #popup__content-right {
    display: none;
    position: fixed;
    top: 0;
    right: 0;
    background: #fff;
    width: 100%;
    height: 100%;
    overflow-y: auto;
    z-index: 1000;
  }
  #popup__content-right{
    margin-top: 0px !important;
    padding-bottom: 92px;
  }
  .popup_new_order #popup__content-right .btn{
    height: 58px;
    background-color: #FAC416 !important;
  }
  .popup_new_order #popup__content-right .btn:hover{
    background-color: #FAC416 !important;
  }
  #popup__content-right .close{
    position: absolute;
    top: 10px;
    right: 0px;
    width: 45px;
    height: 45px;
    background-image: url(../images/svg/icon_cross_t.svg);
    background-size: 25px auto;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    filter: grayscale(1) brightness(0);
    opacity: 1;
    transition: 0.2s;
  }
  #popup__content-right .close:hover{
    opacity: 0.8;
  }
  #popup__content-right .btns_block{
    padding: 0px 10px;
    margin-top: 24px;
  }
  #popup__content-right .popup__title_l_block{
    color: #333333;
  }
  body.mobile-scroll-lock {
    overflow: hidden;
    height: 100%;
  }

  #popup__content-right {
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    z-index: 1000;
    background: #fff;
    overflow-y: auto; /* ← Прокрутка внутри */
    -webkit-overflow-scrolling: touch; /* для iOS плавности */
    display: none;
  }

  #popup__content-right.visible-mobile {
    display: block;
  }
  .main_head.main_head_bdb {
    min-height: 340px;
  }
  #popup__content-right {
    display: none;
    position: fixed;
    top: 0;
    right: 0;
    background: #fff;
    width: 100%;
    height: 100%;
    overflow-y: auto;
    z-index: 1000;
  }

  #popup__content-right.visible-mobile {
    display: block;
  }

  .theme_border_24{
    border-radius: 12px;
  }
  .theme_border_20{
    border-radius: 8px;
  }
  .theme_border_16{
    border-radius: 8px;
  }
  .theme_border_12{
    border-radius: 6px;
  }
  .theme_border_8{
    border-radius: 6px;
  }

  .main_menu{
    position: fixed;
  }
  .main_menu .main_menu_inner{
    position: relative;
    background-color: #EF896F;
    border-radius: 12px;
    padding: 0.5rem 1rem !important;
    align-items: center;
    flex-direction: column;
    border: 1px solid rgb(255, 255, 255);
  }
  .main_menu .main_menu_inner_block{
    flex-direction: column;
  }
  .main_menu .main_menu_inner_block .navbar-nav{
    width: 100%;
  }

  .popup_title_utm {
    padding: 25px 0px 25px 0px;
  }

  #navbarsExample11 {
    width: 100%;
    padding: 0px !important;
  }
  #usedesk-messenger{
    display: none !important;
  }
  .main_head {
    padding-top: 108px;
    min-height: 500px;
    padding-bottom: 24px;
    overflow: hidden;
  }
  .main_menu .logo {
    font-size: 27px;
  }
  .main_menu .navbar-toggler{
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
  }
  .main_menu .navbar-toggler-icon{
    width: 2em;
    height: 2em;
    filter: grayscale(1) brightness(10);
  }

  .main_head .tags {
    align-items: flex-start;
  }
  .main_head .descr br{
    display: none;
  }
  .main_head .main_head_image{
    position: relative;
  }
  .main_head .main_head_image:before{
    content: "";
    display: block;
    padding-top: 56.25%;
  }

  .main_head .logo {
    max-width: 140px;
  }

  .head_title h1, .main_title h2 {
    font-size: 34px;
    line-height: 1.2;
  }

  .head_title h1 br {
    display: inline-block;
  }

  .main_head.main_head_def{
    min-height: 0px;
  }
  .main_head.main_head_def:before{
    display: none;
  }

  .videoWrapper.videoWrapper_preview > div:before {
    width: 50px;
    height: 50px;
    margin-left: -25px;
    margin-top: -25px;
    background-position: calc(50% + 2px) 50%;
    background-size: 20px auto;
  }

  .main_video .tags_icons {

  }

  .tags_icons .tag_item_icon {
    padding: 6px 12px 6px 45px;
    background-position: 12px 50%;
    background-size: 24px auto;
  }

  .theme_list li {
    line-height: 1.2;
    margin-bottom: 15px;
  }
  .tags .tag_item{
    font-size: 14px;
  }
  .ticket_item{
    flex-direction: column;
  }
  .ticket_item .t_info .btn_default{
    max-width: 100%;
    width: 100%;
  }

  .main_stars .main_title h2 br{
    display: block;
  }
  .def_slider_wrap {
    width: 90%;
  }
  .main_photo .gallery{
    /*width: calc(90% - 20px);*/
    /*margin: 0px -12px;*/
    width: 100%;
    margin: 0px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    row-gap: 12px;
    column-gap: 12px;
    justify-content: space-between;
  }
  .main_photo .gallery>a{
    width: calc(50% - 6px);
    border-radius: 12px;
  }
  .main_photo .gallery>a:nth-child(n+11){
    display: none !important;
  }
  .main_photo .gallery figure,
  .main_photo .gallery .figure{
    position: relative;
    margin: 0px;
  }
  .main_photo .gallery figure:before,
  .main_photo .gallery .figure:before{
    content: "";
    display: block;
    padding-top: 56.25%;
  }
  .main_photo .gallery figure img,
  .main_photo .gallery .figure img{
    position: absolute;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .main_photo .gallery .slick-list {
    overflow: visible;
  }

  .main_block {
    margin-bottom: 48px;
  }

  .main_title p {
    font-size: 16px;
  }

  .def_slider {
    width: calc(100% - 20px);
  }
  .def_slider .slick-list {
    overflow: visible;
  }
  .ds_item .ds_descr p {
    font-size: 16px;
  }

  .tags {
    align-items: flex-start;
    column-gap: 10px;
    row-gap: 10px;
  }

  .main_may .mob_add .may_image:before {
    padding-top: 56.25%;
  }

  .ms_slider_in {
    padding: 0px 12px;
    width: calc(100% - 20px);
    margin: 0px -20px;
  }
  .ms_slider_in .slick-list {
    overflow: visible;
  }
  .ms_slider_in .ms_in_item {
    margin: 0px 10px;
  }

  .btns_block {
    width: 100%;
  }

  .main_faq .faq_item .di_up .di_title h3 {
    font-size: 18px;
  }
  .main_faq .faq_item .di_bottom {
    padding-bottom: 10px;
    padding-top: 10px;
  }
  .main_faq .faq_item{
    margin-bottom: 12px;
    background-color: #FFFFFF;
    border-radius: 12px;
    padding: 8px 6px 8px 12px;
  }

  .btn_default {
    height: 68px;
    display: flex;
    font-size: 21px;
  }
  .btn_default.btn_orange{
    background-color: #FBE390;
    color: #333333;
  }
  .btn_default.btn_orange:hover{
    background-color: #333333;
    color: rgb(255, 255, 255);
  }

  .main_faq .main_video_in{
    padding: 0px !important;
    background-color: transparent !important;
  }

  .main_menu_foot.main_menu .navbar-nav li{
    margin: 0px;
  }
  .main_menu_foot.main_menu .navbar-nav{
    margin-top: 12px;
  }
  .main_menu_foot.main_menu .navbar-nav li a, .main_menu_foot.main_menu .navbar-nav li span{
    padding: 3px 0px;
  }
  .main_menu_foot.main_menu .navbar-nav-wrap{
    flex-direction: column;
    align-items: flex-start !important;
  }
  .main_menu_foot.main_menu .foot_cont{
    flex-direction: column;
  }
  .main_menu_foot.main_menu .foot_cont .cont{
    margin-bottom: 12px;
  }

  #js-gmap > ymaps {
    border-radius: 16px;
    height: 100% !important;
  }
  .g-map-m{
    min-height: 160px;
    height: 300px !important;
    overflow: hidden;
  }

  .pp_block .modal-header{
    line-height: 1.2;
  }
  .pp_block .btn_default{
    opacity: 1 !important;
    background-color: #FBE390 !important;
    color: #333333 !important;
  }
  .pp_block .btn_default:hover{
    opacity: 1 !important;
    background-color: #333333 !important;
    color: rgb(255,255,255) !important;
  }
  .pp_block .btn_default{
    font-size: 18px;
  }

  #mobile_tickets{
    position: fixed;
    bottom: 10px;
    left: 10px;
    right: 10px;
    background: #FBE390;
    z-index: 101;
    max-width: 520px;
    margin: 0px auto;
  }
  #mobile_tickets:hover{
    color: #ffffff;
    background-color: #333333;
  }

  .soc_dop_wrap {
    flex-direction: column;
    row-gap: 20px;
    margin-bottom: 40px;
  }
  .soc_dop {
    padding-left: 65px;
    background-size: 52px auto;
    min-height: 52px;
  }

  .main_menu.main_menu_foot {
    margin-bottom: 105px !important;
  }
  .main_menu.main_menu_foot.navbar_cities{
    margin-bottom: 0px !important;
  }
}