html {
  scrollbar-gutter: stable;
}

.popup-active {
  overflow: hidden;
}

h3,
.h3 {
  font-family: "Cormorant Garamond", serif;
  font-size: 1.6875rem;
  margin: 1rem 0;
}

a:hover {
  transition: 0.3s;
}

strong {
  font-weight: 700;
}

.btn:hover {
  cursor: pointer;
  background: #3D5C3A;
  border-color: #3D5C3A;
  transition: 0.3s;
}
.btn-secondary {
  background: #3D5C3A;
  border-color: #3D5C3A;
}
.btn-secondary:hover {
  color: #3D5C3A;
  background: transparent;
}

button:hover {
  cursor: pointer;
}

.header.is-sticky .header-top {
  width: 100%;
  position: fixed;
  left: 0;
  top: 0;
  background: #fff;
  z-index: 10;
}
.header.is-sticky .header-top .header-phone {
  margin-right: 70px;
  margin-left: -70px;
}
.header.is-sticky .header-menu {
  width: 20vw;
  position: fixed;
  right: 0;
  transform: translateY(-500px);
  height: 500px;
  min-width: 300px;
  display: none;
}
.header.is-sticky .header-menu.is-active {
  top: 81px;
  display: block;
  opacity: 0;
  transform: translateY(80px);
  animation: slideDown 0.5s ease forwards;
  z-index: 10;
}
.header.is-sticky .header-menu.is-active .header-menu-close {
  display: block;
  position: absolute;
  top: 24px;
  right: 24px;
  width: 30px;
  height: 30px;
  background: transparent;
  font-size: 26px;
  padding: 0;
  line-height: 1;
  border: none;
}
.header.is-sticky .header-menu.is-active .header-menu-close:hover {
  cursor: pointer;
}
.header.is-sticky .header-menu.is-active .lang-item {
  position: absolute;
  bottom: 20px;
  right: 20px;
}
.header.is-sticky .header-menu.is-active .lang-item-first {
  position: absolute;
  right: 65px;
}
.header.is-sticky .header-menu .menu {
  flex-direction: column;
  align-items: center;
  padding: 48px 0;
}
.header.is-sticky .header-menu-open {
  display: block;
  position: absolute;
  background: none;
  border: none;
  right: 0;
}
.header.is-sticky .header-menu-open:hover {
  cursor: pointer;
}

.block {
  padding: 75px 0;
}
.block-title {
  position: relative;
  text-align: center;
  display: inline-block;
  padding: 0 35px;
  margin: 0 0 55px;
}
.block-title-wrap {
  width: 100%;
  text-align: center;
}
.block-title:before, .block-title:after {
  content: "";
  position: absolute;
  top: 50%;
  margin-top: -5px;
  width: 8px;
  height: 8px;
  border: 2px solid #8B1A1A;
  transform: rotate(45deg);
}
.block-title:before {
  left: 0;
}
.block-title:after {
  right: 0;
}
.block-slider {
  padding: 0 0 100px;
}
.block-slider .swiper-pagination-bullet:not(.swiper-pagination-bullet-active) {
  background: #ddd8cc;
  opacity: 1;
}
.block-slider-pagination {
  width: 100% !important;
}
.block-slider-pagination.swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: 40px;
}
.block-slider-pagination-wrap {
  position: absolute;
  width: 260px;
  left: 50%;
  margin-left: -130px;
  bottom: 0;
}
.block-slider-button-prev, .block-slider-button-next {
  top: auto;
  bottom: 20px;
  z-index: 11;
}
.block-slider-button-prev {
  left: 0;
}
.block-slider-button-next {
  right: 0;
}
.block-text-formatted {
  font-size: 1.375rem;
}
.block-text-formatted p {
  margin: 15px 0;
}
.block-text-formatted em {
  color: #fff;
  background: #2C3B2D;
  border-radius: 6px;
  padding: 2px 5px;
}
.block-text-formatted li {
  position: relative;
  padding-left: 20px;
  line-height: 1.5;
}
.block-text-formatted li:before {
  content: "";
  background: transparent;
  width: 6px;
  height: 6px;
  border: 2px solid #8B1A1A;
  transform: rotate(45deg);
  position: absolute;
  left: 0;
  top: 12px;
}
.block-text-formatted blockquote {
  font-style: italic;
}
.block-text-formatted a {
  font-style: normal;
  text-decoration: underline;
  color: #7A6A5A;
}
.block-text-formatted a:hover {
  color: #8B1A1A;
}

.promo {
  display: flex;
  align-items: center;
  flex-direction: column;
  position: relative;
}
.promo-bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.promo-slider {
  width: 60vw;
  margin-bottom: 15px;
  max-width: 1000px;
}
.promo-slider-slide {
  font-size: 2rem;
  background: #fff;
  border: 20px solid #ddd8cc;
  border-radius: 30px;
  box-sizing: border-box;
  padding: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 20px;
  text-align: center;
}
.promo-slider-slide strong {
  color: #8B1A1A;
}
.promo-slider-slide .has-small-font-size {
  font-size: 1.125rem !important;
}

.perevagi {
  background: #F2EDE3;
  width: 100%;
}
.perevagi-grid {
  display: flex;
  gap: 30px;
}

.perevaga {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 30px;
}
.perevaga-title {
  text-align: center;
  color: #2C3B2D;
}
.perevaga-icon {
  border: 1px solid #ddd8cc;
  background: #FAF8F4;
  border-radius: 50%;
}
.perevaga-text {
  color: #7A6A5A;
}

.nomeri {
  position: relative;
  border-radius: 40px;
  overflow: hidden;
  margin: 75px auto;
  padding: 90px 0 50px 60px;
  display: grid;
  grid-template-columns: 51% 49%;
  align-items: start;
  box-sizing: border-box;
}
.nomeri:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, rgba(44, 59, 45, 0.8) 0%, rgba(44, 59, 45, 0.4) 100%);
  opacity: 0.7;
}
.nomeri-info {
  border-radius: 18px;
  background: rgba(221, 216, 204, 0.2392156863);
  border: 1px solid rgba(255, 255, 255, 0.1490196078);
  backdrop-filter: blur(2.5px);
  z-index: 1;
  position: relative;
  padding: 30px 25px;
  color: #fff;
  width: 50%;
  top: 60px;
}
.nomeri-info-btn {
  margin: 50px 0 0;
}
.nomeri-title {
  font-family: "Cormorant Garamond", serif;
  text-transform: none;
  font-weight: 400;
  font-size: 3.75rem;
  display: inline-block;
  margin: 0 0 20px;
  color: #fff;
}
.nomeri-text {
  font-size: 1.375rem;
}
.nomeri-slider {
  width: 100%;
  display: flex;
  padding: 0 0 100px;
}
.nomeri-slider-wrap {
  height: auto;
  align-items: stretch;
}
.nomeri-slider-pagination-wrap {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 244px;
}
.nomeri-slider-pagination.swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: 20px;
  width: 100% !important;
  left: 25px;
}
.nomeri-slider-button-prev, .nomeri-slider-button-next {
  bottom: 0;
  top: auto;
  background: #fff;
  border: 1px solid #fff;
}
.nomeri-slider-button-prev {
  left: 0;
}
.nomeri-slider-button-next {
  right: 0;
}
.nomeri-bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  z-index: -1;
}

.nomer {
  padding: 20px 20px 80px;
  box-sizing: border-box;
  background: #FAF8F4;
  border-radius: 30px;
  overflow: hidden;
  position: relative;
}
.nomer-image {
  border-radius: 18px;
  width: 100%;
  height: auto;
}
.nomer-image-wrap {
  position: relative;
}
.nomer-title {
  font-size: 1.6875rem;
  color: #2C3B2D;
  margin: 25px 0 10px;
}
.nomer-text {
  color: #7A6A5A;
}
.nomer-spec {
  border: 1px solid rgba(255, 255, 255, 0.1490196078);
  background: rgba(221, 216, 204, 0.2392156863);
  backdrop-filter: blur(2.5px);
  padding: 5px;
  display: flex;
  border-radius: 6px;
  align-items: end;
  font-size: 1.375rem;
  color: #fff;
  height: 28px;
}
.nomer-spec-wrap {
  position: absolute;
  left: 15px;
  right: 15px;
  bottom: 15px;
  display: flex;
  gap: 5px;
}
.nomer-buttons-wrap {
  display: flex;
  gap: 15px;
  margin: 40px 0 20px;
  position: absolute;
  bottom: 0;
  left: 20px;
}
.nomer-btn-video {
  border: none;
  background: transparent;
  position: absolute;
  right: 0;
  top: -1px;
}

.nomeri-page-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin: 0 0 70px;
}
.nomeri-page-one {
  width: 100%;
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 30px;
}
.nomeri-page-one-image {
  width: 100%;
  height: auto;
  border-radius: 18px;
}
.nomeri-page-one-text-wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.nomeri-page-one-buttons {
  position: relative;
  left: 0;
}

.gallery-photos {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}
.gallery-link {
  object-fit: cover;
  display: block;
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
  border-radius: 18px;
  margin: 0 0 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.gallery-col-2, .gallery-col-4 {
  margin: 64px 0 0;
}
.gallery-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.reviews {
  background: #F2EDE3;
}
.reviews-grid {
  display: flex;
  gap: 20px;
  margin: 30px 0 90px;
  align-items: start;
}
.reviews-btn {
  margin: 0 auto;
}

.review {
  background: #FAF8F4;
  padding: 25px;
  border-radius: 18px;
  flex: 0 1 25%;
}
.review-user {
  display: flex;
  gap: 16px;
}
.review-name {
  font-weight: bold;
  font-size: 1.375rem;
}
.review-name-wrap {
  display: flex;
  flex-direction: column;
}
.review-date {
  color: #777;
}
.review-rating {
  margin: 10px 0;
}
.review-text {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.review-text.is-expanded {
  display: block;
}
.review-more {
  color: #777;
  border: none;
  background: transparent;
  padding: 0;
  margin: 15px 0 0;
}
.review-more:hover {
  cursor: pointer;
  color: #8B1A1A;
}

.wp-block-media-text {
  color: #7A6A5A;
}

.price {
  background: #F2EDE3;
}
.price-text {
  max-width: 900px;
  text-align: center;
  margin: 0 auto;
}
.price-btn {
  margin: 40px auto 0;
  display: flex;
  gap: 10px;
}
.price.bg-dark {
  background: #7A6A5A;
  color: #F2EDE3;
}
.price.bg-dark .h2 {
  color: #F2EDE3;
}

.faq {
  color: #FAF8F4;
}
.faq .container {
  position: relative;
}
.faq-items {
  width: 57%;
}
.faq-title {
  color: #F2EDE3;
  margin: 0 0 40px;
}
.faq-question {
  font-size: 1.375rem;
  padding: 22px 30px;
  position: relative;
}
.faq-question:hover {
  cursor: pointer;
}
.faq-question-wrap {
  backdrop-filter: blur(2.5px);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 6px;
  background: rgba(221, 216, 204, 0.2392156863);
  margin: 0 0 15px 0;
  position: relative;
  z-index: 1;
}
.faq-question-wrap.is-active .faq-answer {
  display: block;
}
.faq-question-wrap.is-active .faq-question-bracket {
  transform: rotate(90deg);
  transition: 0.3s;
}
.faq-question-bracket {
  position: absolute;
  right: 25px;
  top: 50%;
  margin-top: -11px;
}
.faq-answer {
  border-top: 2px solid rgba(255, 255, 255, 0.1490196078);
  padding: 25px 30px;
  display: none;
}
.faq-answer a {
  color: #FAF8F4;
}
.faq-answer ul {
  list-style: disc;
  margin: 10px 0;
  padding: 0 0 0 20px;
}
.faq-answer p {
  margin: 10px 0;
}
.faq-bg {
  position: absolute;
  top: 50%;
  right: 0;
  z-index: 0;
}

.textimages {
  background: #F2EDE3;
}
.textimages h3 {
  color: #2C3B2D;
  margin-top: 0;
}
.textimages-wrap {
  background: #FAF8F4;
}
.textimages-bg-text {
  background: #FAF8F4;
}
.textimages-bg-text .textimages-wrap {
  background: #7A6A5A;
}
.textimages-bg-text .textimages-text,
.textimages-bg-text .textimages-header {
  color: #F2EDE3;
}
.textimages-wrap {
  border-radius: 30px;
}
.textimages-item {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4%;
  padding: 50px;
  align-items: start;
}
.textimages-item-full {
  grid-template-columns: 1fr;
  text-align: center;
  padding: 0 50px;
}
.textimages-images-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.textimages-images-second {
  justify-content: flex-end;
}
.textimages-images-second .textimages-image-2 {
  right: auto;
  left: 0;
}
.textimages-image {
  display: inline-block;
}
.textimages-image-1 {
  position: relative;
  z-index: 2;
}
.textimages-image-2 {
  position: absolute;
  top: 50%;
  right: 0;
  z-index: 1;
  display: flex;
  border-radius: 18px;
  overflow: hidden;
}
.textimages-image-2:before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: linear-gradient(180deg, rgba(44, 59, 45, 0.8) 0%, rgba(44, 59, 45, 0.4) 100%);
  opacity: 0.8;
}
.textimages-image-img {
  border-radius: 18px;
}
.textimages-text {
  line-height: 1.6;
}
.textimages-text-wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.textimages-text ul {
  font-size: 1.375rem;
  margin: 0 0 1rem;
}
.textimages-text ul li {
  line-height: 30px;
}
.textimages-text thead td {
  font-weight: 700;
  background: #F2EDE3;
}
.textimages-text td {
  border: 1px solid #F2EDE3;
  padding: 5px 10px;
  width: auto !important;
  height: auto !important;
}
.textimages-text tr td:first-child {
  white-space: nowrap;
}

/*! PhotoSwipe main CSS by Dmytro Semenov | photoswipe.com */
.pswp {
  --pswp-bg: #000;
  --pswp-placeholder-bg: #222;
  --pswp-root-z-index: 100000;
  --pswp-preloader-color: rgba(79, 79, 79, 0.4);
  --pswp-preloader-color-secondary: rgba(255, 255, 255, 0.9);
  /* defined via js:
  --pswp-transition-duration: 333ms; */
  --pswp-icon-color: #fff;
  --pswp-icon-color-secondary: #4f4f4f;
  --pswp-icon-stroke-color: #4f4f4f;
  --pswp-icon-stroke-width: 2px;
  --pswp-error-text-color: var(--pswp-icon-color);
}

/*
	Styles for basic PhotoSwipe (pswp) functionality (sliding area, open/close transitions)
*/
.pswp {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: var(--pswp-root-z-index);
  display: none;
  touch-action: none;
  outline: 0;
  opacity: 0.003;
  contain: layout style size;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

/* Prevents focus outline on the root element,
  (it may be focused initially) */
.pswp:focus {
  outline: 0;
}

.pswp * {
  box-sizing: border-box;
}

.pswp img {
  max-width: none;
}

.pswp--open {
  display: block;
}

.pswp,
.pswp__bg {
  transform: translateZ(0);
  will-change: opacity;
}

.pswp__bg {
  opacity: 0.005;
  background: var(--pswp-bg);
}

.pswp,
.pswp__scroll-wrap {
  overflow: hidden;
}

.pswp__scroll-wrap,
.pswp__bg,
.pswp__container,
.pswp__item,
.pswp__content,
.pswp__img,
.pswp__zoom-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.pswp__img,
.pswp__zoom-wrap {
  width: auto;
  height: auto;
}

.pswp--click-to-zoom.pswp--zoom-allowed .pswp__img {
  cursor: -webkit-zoom-in;
  cursor: -moz-zoom-in;
  cursor: zoom-in;
}

.pswp--click-to-zoom.pswp--zoomed-in .pswp__img {
  cursor: move;
  cursor: -webkit-grab;
  cursor: -moz-grab;
  cursor: grab;
}

.pswp--click-to-zoom.pswp--zoomed-in .pswp__img:active {
  cursor: -webkit-grabbing;
  cursor: -moz-grabbing;
  cursor: grabbing;
}

/* :active to override grabbing cursor */
.pswp--no-mouse-drag.pswp--zoomed-in .pswp__img,
.pswp--no-mouse-drag.pswp--zoomed-in .pswp__img:active,
.pswp__img {
  cursor: -webkit-zoom-out;
  cursor: -moz-zoom-out;
  cursor: zoom-out;
}

/* Prevent selection and tap highlights */
.pswp__container,
.pswp__img,
.pswp__button,
.pswp__counter {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.pswp__item {
  /* z-index for fade transition */
  z-index: 1;
  overflow: hidden;
}

.pswp__hidden {
  display: none !important;
}

/* Allow to click through pswp__content element, but not its children */
.pswp__content {
  pointer-events: none;
}

.pswp__content > * {
  pointer-events: auto;
}

/*

  PhotoSwipe UI

*/
/*
	Error message appears when image is not loaded
	(JS option errorMsg controls markup)
*/
.pswp__error-msg-container {
  display: grid;
}

.pswp__error-msg {
  margin: auto;
  font-size: 1em;
  line-height: 1;
  color: var(--pswp-error-text-color);
}

/*
class pswp__hide-on-close is applied to elements that
should hide (for example fade out) when PhotoSwipe is closed
and show (for example fade in) when PhotoSwipe is opened
 */
.pswp .pswp__hide-on-close {
  opacity: 0.005;
  will-change: opacity;
  transition: opacity var(--pswp-transition-duration) cubic-bezier(0.4, 0, 0.22, 1);
  z-index: 10; /* always overlap slide content */
  pointer-events: none; /* hidden elements should not be clickable */
}

/* class pswp--ui-visible is added when opening or closing transition starts */
.pswp--ui-visible .pswp__hide-on-close {
  opacity: 1;
  pointer-events: auto;
}

/* <button> styles, including css reset */
.pswp__button {
  position: relative;
  display: block;
  width: 50px;
  height: 60px;
  padding: 0;
  margin: 0;
  overflow: hidden;
  cursor: pointer;
  background: none;
  border: 0;
  box-shadow: none;
  opacity: 0.85;
  -webkit-appearance: none;
  -webkit-touch-callout: none;
}

.pswp__button:hover,
.pswp__button:active,
.pswp__button:focus {
  transition: none;
  padding: 0;
  background: none;
  border: 0;
  box-shadow: none;
  opacity: 1;
}

.pswp__button:disabled {
  opacity: 0.3;
  cursor: auto;
}

.pswp__icn {
  fill: var(--pswp-icon-color);
  color: var(--pswp-icon-color-secondary);
}

.pswp__icn {
  position: absolute;
  top: 14px;
  left: 9px;
  width: 32px;
  height: 32px;
  overflow: hidden;
  pointer-events: none;
}

.pswp__icn-shadow {
  stroke: var(--pswp-icon-stroke-color);
  stroke-width: var(--pswp-icon-stroke-width);
  fill: none;
}

.pswp__icn:focus {
  outline: 0;
}

/*
	div element that matches size of large image,
	large image loads on top of it,
	used when msrc is not provided
*/
div.pswp__img--placeholder,
.pswp__img--with-bg {
  background: var(--pswp-placeholder-bg);
}

.pswp__top-bar {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 60px;
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  z-index: 10;
  /* allow events to pass through top bar itself */
  pointer-events: none !important;
}

.pswp__top-bar > * {
  pointer-events: auto;
  /* this makes transition significantly more smooth,
     even though inner elements are not animated */
  will-change: opacity;
}

/*

  Close button

*/
.pswp__button--close {
  margin-right: 6px;
}

/*

  Arrow buttons

*/
.pswp__button--arrow {
  position: absolute;
  top: 0;
  width: 75px;
  height: 100px;
  top: 50%;
  margin-top: -50px;
}

.pswp__button--arrow:disabled {
  display: none;
  cursor: default;
}

.pswp__button--arrow .pswp__icn {
  top: 50%;
  margin-top: -30px;
  width: 60px;
  height: 60px;
  background: none;
  border-radius: 0;
}

.pswp--one-slide .pswp__button--arrow {
  display: none;
}

/* hide arrows on touch screens */
.pswp--touch .pswp__button--arrow {
  visibility: hidden;
}

/* show arrows only after mouse was used */
.pswp--has_mouse .pswp__button--arrow {
  visibility: visible;
}

.pswp__button--arrow--prev {
  right: auto;
  left: 0px;
}

.pswp__button--arrow--next {
  right: 0px;
}

.pswp__button--arrow--next .pswp__icn {
  left: auto;
  right: 14px;
  /* flip horizontally */
  transform: scale(-1, 1);
}

/*

  Zoom button

*/
.pswp__button--zoom {
  display: none;
}

.pswp--zoom-allowed .pswp__button--zoom {
  display: block;
}

/* "+" => "-" */
.pswp--zoomed-in .pswp__zoom-icn-bar-v {
  display: none;
}

/*

  Loading indicator

*/
.pswp__preloader {
  position: relative;
  overflow: hidden;
  width: 50px;
  height: 60px;
  margin-right: auto;
}

.pswp__preloader .pswp__icn {
  opacity: 0;
  transition: opacity 0.2s linear;
  animation: pswp-clockwise 600ms linear infinite;
}

.pswp__preloader--active .pswp__icn {
  opacity: 0.85;
}

@keyframes pswp-clockwise {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/*

  "1 of 10" counter

*/
.pswp__counter {
  height: 30px;
  margin-top: 15px;
  margin-inline-start: 20px;
  font-size: 14px;
  line-height: 30px;
  color: var(--pswp-icon-color);
  text-shadow: 1px 1px 3px var(--pswp-icon-color-secondary);
  opacity: 0.85;
}

.pswp--one-slide .pswp__counter {
  display: none;
}

.footer {
  background: #2C3B2D;
  padding: 40px 0;
  color: #F2EDE3;
}
.footer-logo {
  text-align: center;
  margin: 0 0 35px 0;
}
.footer-grid {
  gap: 5%;
  margin: 0 0 60px;
  display: flex;
  justify-content: space-between;
}
.footer-col {
  max-width: 20%;
  min-width: 200px;
}
.footer-col-title {
  color: #7A9E7E;
  margin: 0 0 25px;
}
.footer-link {
  color: #fff;
  display: inline-block;
  text-decoration: none;
}
.footer-link:hover {
  text-decoration: underline;
}
.footer-menu {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer-menu-a {
  color: #F2EDE3;
  text-transform: uppercase;
  font-size: 0.875rem;
  text-decoration: none;
}
.footer-menu-a:hover {
  text-decoration: underline;
}
.footer-social {
  display: inline-block;
}
.footer-social-wrap {
  display: flex;
  gap: 10px;
}
.footer-copy {
  padding: 40px 40px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.5019607843);
  text-align: center;
  color: #7A9E7E;
  font-size: 0.875rem;
}
.footer-contacts {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.booking {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  padding: 50px;
  background: #FAF8F4;
  border-radius: 18px;
}
.booking-widget {
  max-width: 100%;
  width: 340px;
  height: 340px;
}

.popup {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  align-items: center;
  justify-content: center;
  display: flex;
  background: rgba(44, 59, 45, 0.85);
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.popup.is-active {
  opacity: 1 !important;
  visibility: visible !important;
}
.popup-close {
  position: absolute;
  top: 10px;
  right: 0;
  border: none;
  opacity: 0.75;
  z-index: 1;
}
.popup-close:hover {
  background: transparent;
}

.room-post {
  background: #FAF8F4;
  height: 100%;
  box-sizing: border-box;
  padding: 0 0 55px;
}
.room-post-gallery {
  width: calc(100% + 1px);
}
.room-post-title {
  color: #2C3B2D;
  padding: 30px;
  margin: 0;
  text-align: center;
}
.room-post-content {
  padding: 0 10% 55px;
}
.room-post-content ul {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 20px;
}
.room-post-content li {
  position: relative;
  padding-left: 20px;
  align-items: center;
  display: flex;
}
.room-post-content li:before {
  content: "";
  background: transparent;
  width: 6px;
  height: 6px;
  border: 2px solid #8B1A1A;
  transform: rotate(45deg);
  position: absolute;
  left: 0;
  top: 50%;
  margin-top: -5px;
}
.room-post-content p {
  margin: 20px 0;
}
.room-popup-content {
  margin: 30px auto;
  width: 100%;
  max-width: 1200px;
  border-radius: 30px;
  box-shadow: 0 0 30px #2C3B2D;
  max-height: calc(100vh - 60px);
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
  scrollbar-color: #888 #f1f1f1;
  border-radius: 10px;
  position: relative;
}
.room-pagination {
  bottom: 10px !important;
}
.room-close {
  position: absolute;
  top: 10px;
  right: 0;
  border: none;
  opacity: 0.75;
  z-index: 1;
}
.room-close:hover {
  background: transparent;
  opacity: 1;
}

.schedule {
  background: #7A6A5A;
  display: flex;
}
.schedule-wrap {
  border: 15px solid #ddd8cc;
  box-shadow: 10px 10px 8.4px rgba(0, 0, 0, 0.03);
  border-radius: 30px;
  margin: 0 auto;
  background: #FAF8F4;
  padding: 30px 36px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.schedule-title {
  margin: 0 0 16px;
}
.schedule-hours {
  display: flex;
  font-size: 1.375rem;
}
.schedule-hours-label {
  font-weight: 700;
  color: #8B1A1A;
}
.schedule-hour {
  color: #fff;
  background: #2C3B2D;
  border-radius: 6px;
  padding: 2px 5px;
}

.sho-vhodit {
  position: relative;
}
.sho-vhodit-wrap {
  position: relative;
  z-index: 1;
}
.sho-vhodit-title {
  color: #fff;
  margin: 0 0 40px;
}
.sho-vhodit-price {
  color: #fff;
  font-weight: 700;
  font-size: 1.375rem;
  text-align: center;
  margin: 0 0 10px;
}
.sho-vhodit-subtitle {
  color: #fff;
  text-align: center;
}
.sho-vhodit-grid {
  margin: 40px 0 24px;
}
.sho-vhodit-icon {
  border: 1px solid #fff;
  background: rgba(255, 255, 255, 0.3490196078);
  border-radius: 50%;
  width: 68px;
  height: 68px;
}
.sho-vhodit .btn {
  margin: 0 auto;
}
.sho-vhodit-bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  z-index: -1;
  height: 100%;
  object-fit: cover;
}
.sho-vhodit:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, rgb(44, 59, 45) 0%, rgba(44, 59, 45, 0.8) 100%);
  opacity: 0.9;
}

.restoran-buttons {
  display: flex;
  justify-content: space-between;
  gap: 15px;
}

.stravi {
  background: #F2EDE3;
}
.stravi-slider {
  display: flex;
}
.stravi-slider-wrap {
  height: auto;
  align-items: stretch;
  margin: 0 0 105px;
}

.strava {
  padding: 20px 20px 30px;
  background: #FAF8F4;
  border-radius: 30px;
  box-sizing: border-box;
}
.strava-image {
  border-radius: 18px;
  width: 100%;
  object-fit: cover;
}
.strava-title {
  color: #2C3B2D;
}

.text-text {
  max-width: 1200px;
  margin: 0 auto;
}
.text-text p,
.text-text ul {
  margin: 10px 0;
}
.text-text li {
  position: relative;
  padding-left: 20px;
}
.text-text li:before {
  content: "";
  background: transparent;
  width: 6px;
  height: 6px;
  border: 2px solid #8B1A1A;
  transform: rotate(45deg);
  position: absolute;
  left: 0;
  top: 50%;
  margin-top: -6px;
}

.tour {
  position: relative;
}
.tour:after {
  content: "";
  position: absolute;
  top: 10%;
  width: 30%;
  height: 80%;
}
.tour-ltr {
  background: #F2EDE3;
}
.tour-ltr:after {
  right: 0;
  background: #FAF8F4;
  border-radius: 30px 0 0 30px;
}
.tour-rtl {
  background: #FAF8F4;
}
.tour-rtl:after {
  left: 0;
  background: #F2EDE3;
  border-radius: 0 30px 30px 0;
}
.tour-wrap {
  display: flex;
  gap: 95px;
  min-height: 33vw;
  padding: 55px 0;
  align-items: center;
}
.tour-text-wrap {
  width: 47%;
}
.tour-text-wrap-rtl {
  margin: 0 0 0 53%;
}
.tour-slider {
  width: 47%;
  position: absolute;
  margin: 95px 0 0 0;
  padding: 0 0 95px;
}
.tour-slider-left {
  left: 0;
}
.tour-slider-right {
  right: 0;
}
.tour-slide {
  transform: scale(0.75);
}
.tour-slide.swiper-slide-active {
  transform: scale(1);
}
.tour-pagination {
  margin: 0;
}
.tour-pagination-ltr {
  left: 0;
}
.tour-pagination-rtl {
  left: auto;
  right: 0;
}
.tour-image {
  display: block;
}
.tour-image-img {
  width: 100%;
  height: auto;
  border-radius: 18px;
}
.tour .btn {
  margin: 50px 0;
}

.slidertext {
  background: #F2EDE3;
}
.slidertext-wrap {
  background: #FAF8F4;
  border-radius: 30px;
  padding: 35px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 70px;
}
.slidertext-slider {
  width: 100%;
}
.slidertext-slider-wrap {
  padding: 0 0 95px;
}
.slidertext-image-img {
  border-radius: 18px;
}
.slidertext-text-wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.promolist {
  position: relative;
}
.promolist-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}

.form-title {
  text-align: center;
}
.form-content {
  margin: 30px auto;
  width: calc(100% - 30px);
  max-width: 400px;
  border-radius: 30px;
  box-shadow: 0 0 30px #2c3b2d;
  max-height: calc(100vh - 60px);
  border-radius: 10px;
  position: relative;
  background: #FAF8F4;
  padding: 30px;
}

.wpcf7-form-control {
  height: 36px;
  padding: 5px 10px;
  box-sizing: border-box;
  font-size: 1.125rem;
  border-radius: 4px;
  border: 1px solid #7A6A5A;
  width: 100%;
  margin: 5px 0 0;
}
.wpcf7 label {
  margin: 20px 0;
  display: block;
}
.wpcf7-textarea {
  height: auto;
  max-height: 5.625rem;
}
.wpcf7-select {
  background: #fff;
}
.wpcf7-submit {
  font-family: "Ysabeau Infant", sans-serif;
  padding: 0 20px;
  box-sizing: border-box;
  height: 40px;
  border: 1px solid #fff;
  font-size: 0.875rem;
  letter-spacing: 0.5px;
  color: #fff;
  border-radius: 4px;
  background: transparent;
  text-transform: uppercase;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  width: fit-content;
  background: #8B1A1A;
  border-color: #8B1A1A;
  margin: 20px auto 0;
}
.wpcf7-submit:hover {
  cursor: pointer;
  background: #3D5C3A;
  border-color: #3D5C3A;
  transition: 0.3s;
}

@media (min-width: 1601px) {
  .tour-wrap {
    min-height: 648px;
  }
}
@media (max-width: 1600px) {
  .container {
    max-width: calc(100% - 40px);
  }
  .room-popup-content {
    max-width: calc(100% - 100px) !important;
  }
}
@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-500px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.admin-bar .topslider {
  height: calc(100vh - 192px);
}
.admin-bar .topslider-wrap {
  height: calc(100vh - 192px);
}
/*# sourceMappingURL=style.css.map */
