
#preimushestva {
  position: relative;
  z-index: 1;
  overflow: hidden;
  background-image: url('../img/general/paralax1.avif');
  background-size: 110% auto;
  background-position: center center;
  background-repeat: no-repeat;
  background-attachment: fixed;
}

#preimushestva .preimushestva__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  will-change: auto;
  pointer-events: none;
  display: none;
}

@media (max-width: 767px) {
  #preimushestva {
    background-image: none;
  }
}

#preimushestva .preimushestva__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, #4F80AF 0%, #402d0f 100%);
  z-index: 1;
  opacity: 0.85;
  mix-blend-mode: multiply;
}

#preimushestva .container {
  position: relative;
  z-index: 1;
}

#preimushestva h2 {
  color: #ffffff;
}

@media (max-width: 767px) {
  #preimushestva h2 {
    color: #000000;
  }
}

/* Common card styles */
#preimushestva .preim-card,
.mortgage-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  background-color: #ffffff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 16px 40px rgba(27, 27, 27, 0.08);
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}

#preimushestva .preim-card__image {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background-color: #f3f3f3;
}

#preimushestva .preim-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}

#preimushestva .preim-card__body {
  padding: 24px 28px 30px;
}

#preimushestva .preim-card__text {
  margin: 0;
  font-size: 18px;
  line-height: 1.4;
  font-weight: 500;
  color: #1b1b1b;
}

#preimushestva .preim-card:hover,
.mortgage-card:hover {
  transform: translateY(-12px);
  box-shadow: 0 24px 60px rgba(27, 27, 27, 0.18);
}

#preimushestva .preim-card:hover .preim-card__image img {
  transform: scale(1.08);
}
.ratio {
  position: relative;
  display: block;
  overflow: hidden;
}

.ratio::before {
  display: block;
  width: 100%;
  content: "";
}

.ratio-1\:1::before {
  padding-bottom: 100%;
}

.ratio-2\:1::before {
  padding-bottom: 50%;
}

.ratio-3\:2::before {
  padding-bottom: 66.66667%;
}

.ratio-3\:4::before {
  padding-bottom: 133.33333%;
}

.ratio-4\:3::before {
  padding-bottom: 75%;
}

.ratio-4\:1::before {
  padding-bottom: 25%;
}

.ratio-5\:4::before {
  padding-bottom: 80%;
}

.ratio-8\:5::before {
  padding-bottom: 62.5%;
}

.ratio-15\:9::before {
  padding-bottom: 60%;
}

.ratio-16\:9::before {
  padding-bottom: 56.25%;
}

.ratio-33\:35::before {
  padding-bottom: 106.06061%;
}

.ratio-45\:40::before {
  padding-bottom: 88.88889%;
}

.ratio-45\:50::before {
  padding-bottom: 111.11111%;
}

.ratio-45\:55::before {
  padding-bottom: 122.22222%;
}

.ratio-69\:50::before {
  padding-bottom: 72.46377%;
}

.ratio-69\:65::before {
  padding-bottom: 94.2029%;
}

.ratio-69\:70::before {
  padding-bottom: 101.44928%;
}

.ratio-69\:80::before {
  padding-bottom: 115.94203%;
}

.ratio-57\:60::before {
  padding-bottom: 105.26316%;
}

.ratio-57\:45::before {
  padding-bottom: 78.94737%;
}

.ratio-93\:60::before {
  padding-bottom: 64.51613%;
}

:root {
  --font-primary: "Jost", sans-serif;
  --text-14: 14px;
  --text-15: 15px;
  --text-16: 16px;
  --text-18: 18px;
  --text-20: 20px;
  --text-24: 24px;
  --text-30: 30px;
  --text-36: 36px;
  --text-38: 38px;
  --text-40: 40px;
  --text-44: 44px;
  --text-55: 55px;
  --text-62: 62px;
  --text-72: 72px;
  --text-82: 82px;
  --color-white: #FFFFFF;
  --color-black: #000000;
  --color-border: #DDDDDD;
  --color-accent-1: #b89d6f;
  --color-accent-2: #F7F0EC;
  --color-dark-1: #181D24;
  --color-dark-2: #191D23;
  --color-dark-3: #121418;
  --color-dark-4: #71677A;
  --color-dark-5: #2F3337;
  --color-dark: #1a1a1a;
  --color-light: #ffffff;
  --color-gray-light: #f8f9fa;
  --color-gray: #6c757d;
  --color-gold: #b89d6f;
  --color-gold-dark: #f9f2da;
  --shadow: 0 8px 30px rgba(0,0,0,0.08);
  --shadow-hover: 0 15px 35px rgba(0,0,0,0.15);
  --radius: 16px;
  --transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

[data-anim-wrap] {
  pointer-events: none;
}

[data-anim-wrap].animated {
  pointer-events: auto;
}

@keyframes reveal {
  100% {
    opacity: 1;
  }
}

[data-anim^='slide-'],
[data-anim-child^='slide-'] {
  opacity: 0;
  transition-property: opacity, transform;
  pointer-events: none;
  transition-duration: 1s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}

[data-anim^='slide-'].is-in-view,
[data-anim-child^='slide-'].is-in-view {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  pointer-events: auto;
}

[data-anim^='slide-up'],
[data-anim-child^='slide-up'] {
  transform: translate3d(0, 40px, 0);
}

[data-anim^='slide-down'],
[data-anim-child^='slide-down'] {
  transform: translate3d(0, -40px, 0);
}

[data-anim^='slide-right'],
[data-anim-child^='slide-right'] {
  transform: translate3d(-40px, 0, 0);
}

[data-anim^='slide-left'],
[data-anim-child^='slide-left'] {
  transform: translate3d(40px, 0, 0);
}

[data-anim^='fade'],
[data-anim-child^='fade'] {
  opacity: 0;
  transition-property: opacity;
  pointer-events: none;
  transition-duration: 0.5s;
  transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1);
}

.construction-timeline__item[data-anim^='fade'] {
  transition-duration: 0.4s;
}

[data-anim^='fade'].is-in-view,
[data-anim-child^='fade'].is-in-view {
  opacity: 1;
  pointer-events: auto;
}

[data-anim*="delay-1"],
[data-anim-child*="delay-1"] {
  transition-delay: 0.05s;
  animation-delay: 0.05s;
}

[data-anim*="delay-1"]::after,
[data-anim-child*="delay-1"]::after {
  animation-delay: 0.05s;
}

[data-anim*="delay-1"] > *,
[data-anim-child*="delay-1"] > * {
  animation-delay: 0.05s;
}

[data-anim*="delay-2"],
[data-anim-child*="delay-2"] {
  transition-delay: 0.1s;
  animation-delay: 0.1s;
}

[data-anim*="delay-2"]::after,
[data-anim-child*="delay-2"]::after {
  animation-delay: 0.1s;
}

[data-anim*="delay-2"] > *,
[data-anim-child*="delay-2"] > * {
  animation-delay: 0.1s;
}

[data-anim*="delay-3"],
[data-anim-child*="delay-3"] {
  transition-delay: 0.15s;
  animation-delay: 0.15s;
}

[data-anim*="delay-3"]::after,
[data-anim-child*="delay-3"]::after {
  animation-delay: 0.15s;
}

[data-anim*="delay-3"] > *,
[data-anim-child*="delay-3"] > * {
  animation-delay: 0.15s;
}

[data-anim*="delay-4"],
[data-anim-child*="delay-4"] {
  transition-delay: 0.2s;
  animation-delay: 0.2s;
}

[data-anim*="delay-4"]::after,
[data-anim-child*="delay-4"]::after {
  animation-delay: 0.2s;
}

[data-anim*="delay-4"] > *,
[data-anim-child*="delay-4"] > * {
  animation-delay: 0.2s;
}

[data-anim*="delay-5"],
[data-anim-child*="delay-5"] {
  transition-delay: 0.25s;
  animation-delay: 0.25s;
}

[data-anim*="delay-5"]::after,
[data-anim-child*="delay-5"]::after {
  animation-delay: 0.25s;
}

[data-anim*="delay-5"] > *,
[data-anim-child*="delay-5"] > * {
  animation-delay: 0.25s;
}

[data-anim*="delay-6"],
[data-anim-child*="delay-6"] {
  transition-delay: 0.3s;
  animation-delay: 0.3s;
}

[data-anim*="delay-6"]::after,
[data-anim-child*="delay-6"]::after {
  animation-delay: 0.3s;
}

[data-anim*="delay-6"] > *,
[data-anim-child*="delay-6"] > * {
  animation-delay: 0.3s;
}

[data-anim*="delay-7"],
[data-anim-child*="delay-7"] {
  transition-delay: 0.7s;
  animation-delay: 0.7s;
}

[data-anim*="delay-7"]::after,
[data-anim-child*="delay-7"]::after {
  animation-delay: 0.7s;
}

[data-anim*="delay-7"] > *,
[data-anim-child*="delay-7"] > * {
  animation-delay: 0.7s;
}

[data-anim*="delay-8"],
[data-anim-child*="delay-8"] {
  transition-delay: 0.8s;
  animation-delay: 0.8s;
}

[data-anim*="delay-8"]::after,
[data-anim-child*="delay-8"]::after {
  animation-delay: 0.8s;
}

[data-anim*="delay-8"] > *,
[data-anim-child*="delay-8"] > * {
  animation-delay: 0.8s;
}

[data-anim*="delay-9"],
[data-anim-child*="delay-9"] {
  transition-delay: 0.9s;
  animation-delay: 0.9s;
}

[data-anim*="delay-9"]::after,
[data-anim-child*="delay-9"]::after {
  animation-delay: 0.9s;
}

[data-anim*="delay-9"] > *,
[data-anim-child*="delay-9"] > * {
  animation-delay: 0.9s;
}

[data-anim*="delay-10"],
[data-anim-child*="delay-10"] {
  transition-delay: 1s;
  animation-delay: 1s;
}

[data-anim*="delay-10"]::after,
[data-anim-child*="delay-10"]::after {
  animation-delay: 1s;
}

[data-anim*="delay-10"] > *,
[data-anim-child*="delay-10"] > * {
  animation-delay: 1s;
}

[data-anim*="delay-11"],
[data-anim-child*="delay-11"] {
  transition-delay: 1.1s;
  animation-delay: 1.1s;
}

[data-anim*="delay-11"]::after,
[data-anim-child*="delay-11"]::after {
  animation-delay: 1.1s;
}

[data-anim*="delay-11"] > *,
[data-anim-child*="delay-11"] > * {
  animation-delay: 1.1s;
}

[data-anim*="delay-12"],
[data-anim-child*="delay-12"] {
  transition-delay: 1.2s;
  animation-delay: 1.2s;
}

[data-anim*="delay-12"]::after,
[data-anim-child*="delay-12"]::after {
  animation-delay: 1.2s;
}

[data-anim*="delay-12"] > *,
[data-anim-child*="delay-12"] > * {
  animation-delay: 1.2s;
}

[data-anim*="delay-13"],
[data-anim-child*="delay-13"] {
  transition-delay: 1.3s;
  animation-delay: 1.3s;
}

[data-anim*="delay-13"]::after,
[data-anim-child*="delay-13"]::after {
  animation-delay: 1.3s;
}

[data-anim*="delay-13"] > *,
[data-anim-child*="delay-13"] > * {
  animation-delay: 1.3s;
}

[data-anim*="delay-14"],
[data-anim-child*="delay-14"] {
  transition-delay: 1.4s;
  animation-delay: 1.4s;
}

[data-anim*="delay-14"]::after,
[data-anim-child*="delay-14"]::after {
  animation-delay: 1.4s;
}

[data-anim*="delay-14"] > *,
[data-anim-child*="delay-14"] > * {
  animation-delay: 1.4s;
}

[data-anim*="delay-15"],
[data-anim-child*="delay-15"] {
  transition-delay: 1.5s;
  animation-delay: 1.5s;
}

[data-anim*="delay-15"]::after,
[data-anim-child*="delay-15"]::after {
  animation-delay: 1.5s;
}

[data-anim*="delay-15"] > *,
[data-anim-child*="delay-15"] > * {
  animation-delay: 1.5s;
}

[data-anim*="delay-16"],
[data-anim-child*="delay-16"] {
  transition-delay: 1.6s;
  animation-delay: 1.6s;
}

[data-anim*="delay-16"]::after,
[data-anim-child*="delay-16"]::after {
  animation-delay: 1.6s;
}

[data-anim*="delay-16"] > *,
[data-anim-child*="delay-16"] > * {
  animation-delay: 1.6s;
}

[data-anim*="delay-17"],
[data-anim-child*="delay-17"] {
  transition-delay: 1.7s;
  animation-delay: 1.7s;
}

[data-anim*="delay-17"]::after,
[data-anim-child*="delay-17"]::after {
  animation-delay: 1.7s;
}

[data-anim*="delay-17"] > *,
[data-anim-child*="delay-17"] > * {
  animation-delay: 1.7s;
}

[data-anim*="delay-18"],
[data-anim-child*="delay-18"] {
  transition-delay: 1.8s;
  animation-delay: 1.8s;
}

[data-anim*="delay-18"]::after,
[data-anim-child*="delay-18"]::after {
  animation-delay: 1.8s;
}

[data-anim*="delay-18"] > *,
[data-anim-child*="delay-18"] > * {
  animation-delay: 1.8s;
}

[data-anim*="delay-19"],
[data-anim-child*="delay-19"] {
  transition-delay: 1.9s;
  animation-delay: 1.9s;
}

[data-anim*="delay-19"]::after,
[data-anim-child*="delay-19"]::after {
  animation-delay: 1.9s;
}

[data-anim*="delay-19"] > *,
[data-anim-child*="delay-19"] > * {
  animation-delay: 1.9s;
}

[data-anim*="delay-20"],
[data-anim-child*="delay-20"] {
  transition-delay: 2s;
  animation-delay: 2s;
}

[data-anim*="delay-20"]::after,
[data-anim-child*="delay-20"]::after {
  animation-delay: 2s;
}

[data-anim*="delay-20"] > *,
[data-anim-child*="delay-20"] > * {
  animation-delay: 2s;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100%;
}

body {
  padding: 0;
  font-family: var(--font-primary);
  width: 100%;
  background-color: white;
  color: var(--color-dark-1);
  font-size: 16px;
  line-height: 1.875;
}

select,
input:not([type="range"]),
textarea {
  border: 0;
  outline: none;
  width: 100%;
  background-color: transparent;
}

main {
  overflow: hidden;
}

img {
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  transition: color 0.2s ease-in-out;
  text-decoration: none;
  position: relative;
}

a:hover {
  text-decoration: none;
}

/* Эффект подчёркивания для всех ссылок (кроме специальных случаев) */
a:not(.button):not(.footer__nav-link):not(.booking-modal__close):not(.contact-modal__close):not(.floorplan-modal__close):not(.documents-modal__close):not(.documents-modal__download):not(.js-menu-link):not(.headerMenu__item a):not(.header__logo):not(.footer__logo a):not(:has(img))::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--color-accent-1);
  transition: width 0.3s ease;
}

a:not(.button):not(.footer__nav-link):not(.booking-modal__close):not(.contact-modal__close):not(.floorplan-modal__close):not(.documents-modal__close):not(.documents-modal__download):not(.js-menu-link):not(.headerMenu__item a):not(.header__logo):not(.footer__logo a):not(:has(img)):hover::after {
  width: 100%;
}

/* Исключаем эффект для ссылок с изображениями (логотипы и т.д.) */
a:has(img)::after {
  display: none;
}

/* Эффект подчёркивания для ссылок в меню шапки */
.headerMenu__item a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--color-accent-1);
  transition: width 0.3s ease;
}

.headerMenu__item a:hover::after {
  width: 100%;
}

ul, li {
  list-style: none;
  margin: 0;
  padding: 0;
}

p {
  margin: 0;
  font-size: 16px;
  color: var(--color-light-1);
}

.-mobileScroll > * {
  flex-shrink: 0;
}

@media (max-width: 575px) {
  .-mobileScroll {
    overflow-x: scroll;
  }
}

.video.-type-1 {
  position: relative;
  padding: 380px 0;
  z-index: 0;
}

@media (max-width: 1199px) {
  .video.-type-1 {
    padding: 300px 0;
  }
}

@media (max-width: 991px) {
  .video.-type-1 {
    padding: 180px 0;
  }
}

@media (max-width: 767px) {
  .video.-type-1 {
    padding: 120px 0;
  }
}

@media (max-width: 575px) {
  .video.-type-1 {
    padding: 60px 0;
    text-align: center;
  }
}

.video.-type-1 .video__bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
}

.video.-type-1 .video__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
}

.video.-type-1 .video__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.video.-type-1 .video__title {
  font-size: 82px;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: white;
}

@media (max-width: 1199px) {
  .video.-type-1 .video__title {
    font-size: 62px;
  }
}

@media (max-width: 767px) {
  .video.-type-1 .video__title {
    font-size: 48px;
  }
}

@media (max-width: 575px) {
  .video.-type-1 .video__title {
    font-size: 34px;
  }
}

.video.-type-1 .video__button {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 100%;
  border: 1px solid white;
  border-radius: 100%;
  font-size: 24px;
  width: 140px;
  height: 140px;
  color: white;
}

@media (max-width: 767px) {
  .video.-type-1 .video__button {
    width: 100px;
    height: 100px;
  }
}

@media (max-width: 575px) {
  .video.-type-1 .video__button {
    width: 80px;
    height: 80px;
  }
}

.propSingleHero {
  position: relative;
  display: flex;
  align-items: center;
  height: 100vh;
  z-index: 0;
}

.propSingleHero__bg {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: -1;
}

.propSingleHero__bg::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: rgba(0, 0, 0, 0.5);
}

.propSingleHero__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.propSingleHero__button {
  position: absolute;
  bottom: 60px;
  left: 50%;
  transform: translateX(-50%);
}

@media (max-width: 767px) {
  .propSingleHero__button {
    bottom: 30px;
  }
}

button {
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 0;
  background-color: transparent;
  text-decoration: none;
}

button:focus {
  outline: 0;
}

.button {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 16px;
  font-weight: 400;
  line-height: 30px;
  text-transform: uppercase;
  border: 1px solid transparent;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.button.-md {
  padding: 15px 30px;
}

.button.-min-260 {
  min-width: 260px;
}

.button.-underline:hover {
  text-decoration: underline;
}

.button.-white:hover {
  border-color: var(--color-white);
  background-color: var(--color-white) !important;
  color: white !important;
}

.button.-outline-white {
  border-color: var(--color-white);
}

.button.-outline-white:hover {
  background-color: var(--color-white);
  border-color: transparent;
  color: white !important;
}

.button.-black:hover {
  border-color: var(--color-black);
  background-color: var(--color-black) !important;
  color: white !important;
}

.button.-outline-black {
  border-color: var(--color-black);
}

.button.-outline-black:hover {
  background-color: var(--color-black);
  border-color: transparent;
  color: white !important;
}

.button.-border:hover {
  border-color: var(--color-border);
  background-color: var(--color-border) !important;
  color: white !important;
}

.button.-outline-border {
  border-color: var(--color-border);
}

.button.-outline-border:hover {
  background-color: var(--color-border);
  border-color: transparent;
  color: white !important;
}

.button.-accent-1:hover {
  border-color: var(--color-accent-1);
  background-color: var(--color-accent-1) !important;
  color: white !important;
}

.button.-outline-accent-1 {
  border-color: var(--color-accent-1);
}

.button.-outline-accent-1:hover {
  background-color: var(--color-accent-1);
  border-color: transparent;
  color: white !important;
}

.button.-accent-2:hover {
  border-color: var(--color-accent-2);
  background-color: var(--color-accent-2) !important;
  color: white !important;
}

.button.-outline-accent-2 {
  border-color: var(--color-accent-2);
}

.button.-outline-accent-2:hover {
  background-color: var(--color-accent-2);
  border-color: transparent;
  color: white !important;
}

.button.-dark-1:hover {
  border-color: var(--color-dark-1);
  background-color: var(--color-dark-1) !important;
  color: white !important;
}

.button.-outline-dark-1 {
  border-color: var(--color-dark-1);
}

.button.-outline-dark-1:hover {
  background-color: var(--color-dark-1);
  border-color: transparent;
  color: white !important;
}

.button.-dark-2:hover {
  border-color: var(--color-dark-2);
  background-color: var(--color-dark-2) !important;
  color: white !important;
}

.button.-outline-dark-2 {
  border-color: var(--color-dark-2);
}

.button.-outline-dark-2:hover {
  background-color: var(--color-dark-2);
  border-color: transparent;
  color: white !important;
}

.button.-dark-3:hover {
  border-color: var(--color-dark-3);
  background-color: var(--color-dark-3) !important;
  color: white !important;
}

.button.-outline-dark-3 {
  border-color: var(--color-dark-3);
}

.button.-outline-dark-3:hover {
  background-color: var(--color-dark-3);
  border-color: transparent;
  color: white !important;
}

.button.-dark-4:hover {
  border-color: var(--color-dark-4);
  background-color: var(--color-dark-4) !important;
  color: white !important;
}

.button.-outline-dark-4 {
  border-color: var(--color-dark-4);
}

.button.-outline-dark-4:hover {
  background-color: var(--color-dark-4);
  border-color: transparent;
  color: white !important;
}

.button.-dark-5:hover {
  border-color: var(--color-dark-5);
  background-color: var(--color-dark-5) !important;
  color: white !important;
}

.button.-outline-dark-5 {
  border-color: var(--color-dark-5);
}

.button.-outline-dark-5:hover {
  background-color: var(--color-dark-5);
  border-color: transparent;
  color: white !important;
}

.button.-outline-white:hover {
  background-color: white !important;
  color: var(--color-dark-1) !important;
}

.play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 100%;
  width: 160px;
  height: 160px;
}

.play-button.-sm {
  width: 90px;
  height: 90px;
}

@media (max-width: 767px) {
  .play-button {
    width: 100px;
    height: 100px;
  }
  .play-button > i {
    font-size: 18px !important;
  }
}

.play-button:hover {
  color: var(--color-accent-1);
}

.arrowButton.-type-1 {
  display: flex;
  align-items: center;
}

.arrowButton.-type-1 > span {
  width: 50px;
  height: 50px;
  margin-right: 15px;
}

.arrowButton.-type-1 > span i {
  transform: rotate(-90deg);
}

.contactForm select,
.contactForm input:not([type="range"]),
.contactForm textarea {
  font-size: 16px;
  line-height: 30px;
  border-bottom: 1px solid var(--color-accent-1);
  padding-bottom: 10px;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.contactForm select:focus,
.contactForm input:not([type="range"]):focus,
.contactForm textarea:focus {
  outline: none;
  border-color: var(--color-dark-1);
}

.contactForm ::-moz-placeholder {
  font-weight: 400;
}

.contactForm ::placeholder {
  font-weight: 400;
}

.contactForm__caption {
  font-size: 16px;
  font-weight: 500;
  line-height: 30px;
  text-transform: uppercase;
}

input.text-white::-moz-placeholder {
  color: white;
}

input.text-white::placeholder {
  color: white;
}

.form-checkbox {
  cursor: pointer;
  position: relative;
  display: flex;
}

.form-checkbox label {
  margin: 0;
  margin-left: 9px;
  font-size: 14px;
}

.form-checkbox__mark {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 18px;
  height: 18px;
  border: 1px solid var(--color-accent-1);
  border-radius: 4px;
}

.form-checkbox__icon {
  display: none;
  position: absolute;
  font-size: 8px;
  color: var(--color-dark-1);
}

.form-checkbox input {
  cursor: pointer;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 5;
  opacity: 0;
}

.form-checkbox input:checked ~ .form-checkbox__mark {
  background-color: var(--color-accent-2);
  border-color: var(--color-dark-1);
}

.form-checkbox input:checked ~ .form-checkbox__mark .form-checkbox__icon {
  display: block;
}

.form-checkbox:hover input ~ .form-checkbox__mark {
  background-color: var(--color-accent-2);
}

.form-checkbox:hover input:checked ~ .form-checkbox__mark {
  background-color: var(--color-accent-2);
}

.form-radio {
  display: flex;
  align-items: center;
}

.form-radio .radio {
  cursor: pointer;
  position: relative;
  display: block;
}

.form-radio .radio__mark {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 18px;
  width: 18px;
  border-radius: 100%;
  border: 1px solid var(--color-accent-1);
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.form-radio .radio__icon {
  position: absolute;
  width: 10px;
  height: 10px;
  border-radius: 100%;
  transform-origin: center;
  opacity: 1;
  transform: scale(0.2);
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.form-radio .radio input {
  cursor: pointer;
  position: absolute;
  z-index: 5;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  opacity: 0;
}

.form-radio .radio input:checked ~ .radio__mark {
  border-color: var(--color-dark-1);
  background-color: var(--color-dark-1);
}

.form-radio .radio input:checked ~ .radio__mark .radio__icon {
  background-color: var(--color-white);
  opacity: 1;
  transform: scale(1);
}

.form-switch .switch {
  cursor: pointer;
  position: relative;
  width: 55px;
  height: 30px;
}

.form-switch .switch__slider {
  cursor: pointer;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color-accent-2);
  transition: .3s;
  border-radius: 30px;
}

.form-switch .switch__slider::before {
  content: "";
  position: absolute;
  height: 24px;
  width: 24px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  border-radius: 100%;
  box-shadow: 0px 10px 40px 0px #0000000D;
  transition: .3s;
}

.form-switch .switch input {
  z-index: 5;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
}

.form-switch .switch input:checked + .switch__slider {
  background-color: var(--color-dark-1);
}

.form-switch .switch input:checked + .switch__slider::before {
  transform: translateX(25px);
  background-color: white;
}

.select {
  position: relative;
}

.select__button {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 10px 0;
  border-bottom: 1px solid var(--color-accent-1);
  background-color: white;
  text-align: left;
}

.select__icon {
  width: 20px;
  height: 20px;
}

.select__dropdown {
  position: absolute;
  top: calc(100% - 1px);
  left: 50%;
  transform: translateX(-50%);
  z-index: 30;
  display: flex;
  flex-direction: column;
  background-color: white;
  width: 100%;
  min-height: 240px;
  max-height: 340px;
  border: 1px solid var(--color-dark-1);
  transition: all 0.2s ease;
  pointer-events: none;
  opacity: 0;
}

.select__dropdown.-is-visible {
  opacity: 1;
  pointer-events: auto;
}

.select__options {
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
  overflow-y: scroll;
}

.select__options::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}

.select__options::-webkit-scrollbar-thumb {
  background-color: rgba(0, 0, 0, 0.2);
  border-radius: 12px;
}

.select__options__button {
  display: flex;
  align-items: center;
  font-size: 16px;
  text-align: left;
  padding: 6px 20px;
  transition: all 0.15s ease;
}

.select__options__button:hover {
  cursor: pointer;
  background-color: var(--color-accent-2) !important;
  color: var(--color-accent-1) !important;
}

.select__options__button:focus {
  color: var(--color-accent-1) !important;
}

.select__search {
  flex-shrink: 0;
  height: 50px !important;
  border: 1px solid #F7F0EC !important;
  color: black;
  padding: 0 20px !important;
  margin: 0 20px;
  margin-top: 20px;
  margin-bottom: 15px;
}

.select.-multiple .select__dropdown {
  padding: 15px 0;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  line-height: 1.3;
  font-weight: 500;
}

.text-14 {
  font-size: var(--text-14) !important;
}

.text-15 {
  font-size: var(--text-15) !important;
}

.text-16 {
  font-size: var(--text-16) !important;
}

.text-18 {
  font-size: var(--text-18) !important;
}

.text-20 {
  font-size: var(--text-20) !important;
}

.text-24 {
  font-size: var(--text-24) !important;
}

.text-30 {
  font-size: var(--text-30) !important;
}

.text-36 {
  font-size: var(--text-36) !important;
}

.text-38 {
  font-size: var(--text-38) !important;
}

.text-40 {
  font-size: var(--text-40) !important;
}

.text-44 {
  font-size: var(--text-44) !important;
}

.text-55 {
  font-size: var(--text-55) !important;
}

.text-62 {
  font-size: var(--text-62) !important;
}

.text-72 {
  font-size: var(--text-72) !important;
}

.text-82 {
  font-size: var(--text-82) !important;
}

@media (max-width: 1199px) {
  .xl\:text-14 {
    font-size: var(--text-14) !important;
  }
  .xl\:text-15 {
    font-size: var(--text-15) !important;
  }
  .xl\:text-16 {
    font-size: var(--text-16) !important;
  }
  .xl\:text-18 {
    font-size: var(--text-18) !important;
  }
  .xl\:text-20 {
    font-size: var(--text-20) !important;
  }
  .xl\:text-24 {
    font-size: var(--text-24) !important;
  }
  .xl\:text-30 {
    font-size: var(--text-30) !important;
  }
  .xl\:text-36 {
    font-size: var(--text-36) !important;
  }
  .xl\:text-38 {
    font-size: var(--text-38) !important;
  }
  .xl\:text-40 {
    font-size: var(--text-40) !important;
  }
  .xl\:text-44 {
    font-size: var(--text-44) !important;
  }
  .xl\:text-55 {
    font-size: var(--text-55) !important;
  }
  .xl\:text-62 {
    font-size: var(--text-62) !important;
  }
  .xl\:text-72 {
    font-size: var(--text-72) !important;
  }
  .xl\:text-82 {
    font-size: var(--text-82) !important;
  }
}

@media (max-width: 991px) {
  .lg\:text-14 {
    font-size: var(--text-14) !important;
  }
  .lg\:text-15 {
    font-size: var(--text-15) !important;
  }
  .lg\:text-16 {
    font-size: var(--text-16) !important;
  }
  .lg\:text-18 {
    font-size: var(--text-18) !important;
  }
  .lg\:text-20 {
    font-size: var(--text-20) !important;
  }
  .lg\:text-24 {
    font-size: var(--text-24) !important;
  }
  .lg\:text-30 {
    font-size: var(--text-30) !important;
  }
  .lg\:text-36 {
    font-size: var(--text-36) !important;
  }
  .lg\:text-38 {
    font-size: var(--text-38) !important;
  }
  .lg\:text-40 {
    font-size: var(--text-40) !important;
  }
  .lg\:text-44 {
    font-size: var(--text-44) !important;
  }
  .lg\:text-55 {
    font-size: var(--text-55) !important;
  }
  .lg\:text-62 {
    font-size: var(--text-62) !important;
  }
  .lg\:text-72 {
    font-size: var(--text-72) !important;
  }
  .lg\:text-82 {
    font-size: var(--text-82) !important;
  }
}

@media (max-width: 767px) {
  .md\:text-14 {
    font-size: var(--text-14) !important;
  }
  .md\:text-15 {
    font-size: var(--text-15) !important;
  }
  .md\:text-16 {
    font-size: var(--text-16) !important;
  }
  .md\:text-18 {
    font-size: var(--text-18) !important;
  }
  .md\:text-20 {
    font-size: var(--text-20) !important;
  }
  .md\:text-24 {
    font-size: var(--text-24) !important;
  }
  .md\:text-30 {
    font-size: var(--text-30) !important;
  }
  .md\:text-36 {
    font-size: var(--text-36) !important;
  }
  .md\:text-38 {
    font-size: var(--text-38) !important;
  }
  .md\:text-40 {
    font-size: var(--text-40) !important;
  }
  .md\:text-44 {
    font-size: var(--text-44) !important;
  }
  .md\:text-55 {
    font-size: var(--text-55) !important;
  }
  .md\:text-62 {
    font-size: var(--text-62) !important;
  }
  .md\:text-72 {
    font-size: var(--text-72) !important;
  }
  .md\:text-82 {
    font-size: var(--text-82) !important;
  }
}

@media (max-width: 575px) {
  .sm\:text-14 {
    font-size: var(--text-14) !important;
  }
  .sm\:text-15 {
    font-size: var(--text-15) !important;
  }
  .sm\:text-16 {
    font-size: var(--text-16) !important;
  }
  .sm\:text-18 {
    font-size: var(--text-18) !important;
  }
  .sm\:text-20 {
    font-size: var(--text-20) !important;
  }
  .sm\:text-24 {
    font-size: var(--text-24) !important;
  }
  .sm\:text-30 {
    font-size: var(--text-30) !important;
  }
  .sm\:text-36 {
    font-size: var(--text-36) !important;
  }
  .sm\:text-38 {
    font-size: var(--text-38) !important;
  }
  .sm\:text-40 {
    font-size: var(--text-40) !important;
  }
  .sm\:text-44 {
    font-size: var(--text-44) !important;
  }
  .sm\:text-55 {
    font-size: var(--text-55) !important;
  }
  .sm\:text-62 {
    font-size: var(--text-62) !important;
  }
  .sm\:text-72 {
    font-size: var(--text-72) !important;
  }
  .sm\:text-82 {
    font-size: var(--text-82) !important;
  }
}

@media (max-width: 479px) {
  .xs\:text-14 {
    font-size: var(--text-14) !important;
  }
  .xs\:text-15 {
    font-size: var(--text-15) !important;
  }
  .xs\:text-16 {
    font-size: var(--text-16) !important;
  }
  .xs\:text-18 {
    font-size: var(--text-18) !important;
  }
  .xs\:text-20 {
    font-size: var(--text-20) !important;
  }
  .xs\:text-24 {
    font-size: var(--text-24) !important;
  }
  .xs\:text-30 {
    font-size: var(--text-30) !important;
  }
  .xs\:text-36 {
    font-size: var(--text-36) !important;
  }
  .xs\:text-38 {
    font-size: var(--text-38) !important;
  }
  .xs\:text-40 {
    font-size: var(--text-40) !important;
  }
  .xs\:text-44 {
    font-size: var(--text-44) !important;
  }
  .xs\:text-55 {
    font-size: var(--text-55) !important;
  }
  .xs\:text-62 {
    font-size: var(--text-62) !important;
  }
  .xs\:text-72 {
    font-size: var(--text-72) !important;
  }
  .xs\:text-82 {
    font-size: var(--text-82) !important;
  }
}

.lh-1 {
  line-height: 1 !important;
}

.lh-11 {
  line-height: 1.1 !important;
}

.lh-12 {
  line-height: 1.2 !important;
}

.lh-13 {
  line-height: 1.3 !important;
}

.lh-14 {
  line-height: 1.4 !important;
}

.lh-15 {
  line-height: 1.5 !important;
}

.lh-16 {
  line-height: 1.6 !important;
}

.lh-17 {
  line-height: 1.7 !important;
}

.lh-18 {
  line-height: 1.8 !important;
}

.lh-19 {
  line-height: 1.9 !important;
}

.lh-2 {
  line-height: 2 !important;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

.text-left {
  text-align: left;
}

@media (max-width: 1199px) {
  .xl\:text-center {
    text-align: center !important;
  }
  .xl\:text-right {
    text-align: right !important;
  }
  .xl\:text-left {
    text-align: left !important;
  }
}

@media (max-width: 991px) {
  .lg\:text-center {
    text-align: center !important;
  }
  .lg\:text-right {
    text-align: right !important;
  }
  .lg\:text-left {
    text-align: left !important;
  }
}

@media (max-width: 767px) {
  .md\:text-center {
    text-align: center !important;
  }
  .md\:text-right {
    text-align: right !important;
  }
  .md\:text-left {
    text-align: left !important;
  }
}

@media (max-width: 575px) {
  .sm\:text-center {
    text-align: center !important;
  }
  .sm\:text-right {
    text-align: right !important;
  }
  .sm\:text-left {
    text-align: left !important;
  }
}

.fw-300 {
  font-weight: 300;
}

.fw-400 {
  font-weight: 400;
}

.fw-500 {
  font-weight: 500;
}

.fw-600 {
  font-weight: 600;
}

.fw-700 {
  font-weight: 700;
}


.header.-type-5 {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  height: 91px;
  color: white;
  z-index: 700;
  background-color: rgba(0, 0 ,0, 0.5);
  backdrop-filter: blur(5px);
  transition: all 0.2s cubic-bezier(0.165, 0.84, 0.44, 1);
}

@media (max-width: 767px) {
  .header.-type-5 {
    height: auto;
    min-height: 60px;
  }
}

.header.-type-5 .header__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0 60px;
}

@media (max-width: 991px) {
  .header.-type-5 .header__container {
    padding: 0 40px;
  }
}

@media (max-width: 767px) {
  .header.-type-5 .header__container {
    padding: 12px 20px;
  }
}

.header.-type-5 .header__left {
  display: flex;
  align-items: center;
  gap: 40px;
}

@media (max-width: 1366px) {
  .header.-type-5 .header__left {
    gap: 20px;
  }
  
  .header.-type-5 .header__left .headerMenu {
    display: none;
  }
  
  .header.-type-5 .js-toggle-requestForm {
    display: none !important;
  }
}

.header.-type-5 .header__menuBtn {
  display: none;
  align-items: center;
  color: white;
}

@media (max-width: 1366px) {
  .header.-type-5 .header__menuBtn {
    display: flex;
  }
}

.header.-type-5 .header__menuBtn i {
  position: relative;
  height: 11px;
  width: 25px;
}

.header.-type-5 .header__menuBtn i::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: white;
}

.header.-type-5 .header__menuBtn i::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 20px;
  height: 2px;
  background-color: white;
}

.header.-type-5 .header__menuBtn span {
  margin-left: 15px;
}

.header.-type-5 .header__center {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
}

.header.-type-5 .header__company-text {
  font-size: 1.1rem;
  line-height: 1.4;
  color: white;
  font-weight: 400;
  letter-spacing: 0.05em;
}

.header.-type-5 .header__company-text br {
  display: block;
  content: "";
  margin-top: 2px;
}

@media (min-width: 992px) and (max-width: 1700px) {
  .header.-type-5 .header__company-text {
    font-size: 0.9rem;
    line-height: 1.3;
  }
}

@media (max-width: 991px) {
  .header.-type-5 .header__center {
    position: relative;
    left: unset;
    transform: none;
    flex: 1;
  }
  
  .header.-type-5 .header__company-text {
    font-size: 11px;
  }
}

@media (max-width: 767px) {
  .header.-type-5 .header__company-text {
    font-size: 9px;
    line-height: 1.2;
  }
  
  .header.-type-5 .header__menuBtn span {
    font-size: 12px;
    margin-left: 10px;
  }
  
  .header.-type-5 .header__left {
    gap: 12px;
  }
}

.header.-type-5 .header__logo {
  position: relative;
  z-index: 0;
  flex-shrink: 0;
}

.header.-type-5 .header__left .header__logo {
  margin-right: 0;
}

@media (max-width: 767px) {
  .header.-type-5 .header__logo {
    max-width: 80px;
  }
  
  .header.-type-5 .header__logo .svg-logo {
    height: 4rem !important;
  }
}

.header.-type-5 .header__logo > *:nth-child(2) {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  opacity: 0;
}

.header.-type-5 .header__right {
  display: flex;
  align-items: center;
}

.header.-type-5 .header__number {
  margin-right: 60px;
}

@media (max-width: 991px) {
  .header.-type-5 .header__number {
    margin-right: 40px;
  }
}

.header.-type-5 .header__number a {
  font-size: 18px;
  font-weight: 500;
  color: var(--color-accent-1);
  text-decoration: none;
  transition: color 0.3s ease;
  display: inline-block;
  position: relative;
  width: fit-content;
}

.header.-type-5 .header__number a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--color-accent-1);
  transition: width 0.3s ease;
}

.header.-type-5 .header__number a:hover {
  color: #d1c28c;
}

.header.-type-5 .header__number a:hover::after {
  width: 100%;
}

.header.-type-5 .header__socials {
  margin-right: 60px;
}

@media (max-width: 991px) {
  .header.-type-5 .header__socials {
    margin-right: 40px;
  }
}

.header.-type-5 .header__socials > a {
  font-size: 15px;
}

.header.-type-5 .header__socials > a + a {
  margin-left: 20px;
}

.header.-type-5 .header__language {
  display: flex;
  align-items: center;
  margin-right: 60px;
}

@media (max-width: 991px) {
  .header.-type-5 .header__language {
    margin-right: 40px;
  }
}

.header.-type-5 .header__language span {
  display: inline-block;
  width: 1px;
  height: 18px;
  background-color: white;
  margin: 0 15px;
}

.header.-type-5.-dark-always, .header.-type-5.-dark {
  color: black;
  background-color: white !important;
}

.header.-type-5.-dark-always .header__menuBtn, .header.-type-5.-dark .header__menuBtn {
  color: var(--color-dark-1) !important;
}

.header.-type-5.-dark-always .header__menuBtn i::before,
.header.-type-5.-dark-always .header__menuBtn i::after, .header.-type-5.-dark .header__menuBtn i::before,
.header.-type-5.-dark .header__menuBtn i::after {
  background-color: var(--color-dark-1) !important;
}

.header.-type-5.-dark-always .header__logo > *:nth-child(1), .header.-type-5.-dark .header__logo > *:nth-child(1) {
  opacity: 0;
}

.header.-type-5.-dark-always .header__logo > *:nth-child(2), .header.-type-5.-dark .header__logo > *:nth-child(2) {
  opacity: 1;
}

.header.-type-5.-is-sticky {
  background-color: var(--color-dark-1);
}

.headerMenu {
  display: flex;
}

.headerMenu__item {
  position: relative;
  display: flex;
  align-items: center;
  height: 60px;
  color: white;
  font-size: 16px;
  line-height: 1;
}

.headerMenu__item + * {
  margin-left: 30px;
}

@media (min-width: 992px) and (max-width: 1700px) {
  .headerMenu__item + * {
    margin-left: 15px;
  }
}

.headerMenu__item a {
  transition: .1s;
  position: relative;
}

.headerMenu__item a:hover {
  color: currentColor;
  text-decoration: none;
}

.headerMenu__item .headerMenuSubnav a:hover {
  color: var(--color-accent-1);
  text-decoration: none;
}

.headerMenu__item:hover > .headerMenuSubnav {
  pointer-events: auto;
  opacity: 1;
}

.headerMenuSubnav {
  position: absolute;
  top: 100%;
  left: -20px;
  background-color: white;
  padding: 20px 0;
  min-width: 250px;
  max-width: 100%;
  transition: 0.3s;
  opacity: 0;
  pointer-events: none;
}

.headerMenuSubnav__item {
  position: relative;
}

.headerMenuSubnav__item a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: black;
  text-transform: uppercase;
  font-size: 16px;
  line-height: 1.2;
  padding: 12px 30px;
}

.headerMenuSubnav__item a i {
  font-size: 10px;
}

.headerMenuSubnav__item > .headerMenuSubnav {
  top: unset;
  left: unset;
  left: 100%;
  top: 0;
}

.headerMenuSubnav__item:hover > .headerMenuSubnav {
  pointer-events: auto;
  opacity: 1;
}


svg path[fill="#ffffff"] {
  fill: transparent;
  display: none;
}
svg rect.background {
  fill: transparent;
  stroke: transparent;
  
}
.svg-logo{
  height: 6rem;
  fill: transparent;
  stroke: transparent;
}
.hero.-type-1 {
  position: relative;
  width: 100%;
  height: 100vh;
  z-index: 1;
}

@media (max-width: 767px) {
  .hero.-type-1 {
    height: 700px;
  }
}

.hero.-type-1 .hero__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, #4F80AF 0%, #fda00a 100%);
  z-index: -1;
}

.hero.-type-1 .hero__content {
  padding-top: 12rem;
}

@media (max-width: 479px) {
  .hero.-type-1 .hero__content {
    padding-top: 12rem;
  }
}

.hero.-type-1 .hero__ipoteca {
  position: absolute;
  bottom: 5rem;
  left: 35rem;
  margin-right: 5rem;
  color:white;
  width: 10rem;
  font-size: 2rem;
  height: 7rem;
  align-items: center;
  justify-content: center;
  border: 1px solid #000;
  text-align: center;
  background: rgba(255, 255, 255, 0.25);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 16px;
  box-shadow: 0 8px 32px 0 rgba(226, 227, 231, 0.37);
}

.hero.-type-1 .hero__payment {
  position: absolute;
  bottom: 15rem;
  left: 15rem;
  margin-right: 18rem;
  color:white;
  width: 20rem;
  font-size: 1.6rem;
  height: 7rem;
  text-align: center;
  background: rgba(255, 255, 255, 0.25);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 16px;
  box-shadow: 0 8px 32px 0 rgba(226, 227, 231, 0.37);
  line-height: 1.2;
  padding-top: 0.5rem;
}
.hero.-type-1 .hero__ipoteca .hero__ipoteca-text {
  font-size: 3rem;
  font-weight: 700;
  text-shadow: 1px 1px 2px #C29F7B;
}
.hero.-type-1 .hero__payment .hero__payment-text {
  font-size: 3rem;
  font-weight: 700;
  text-shadow: 1px 1px 2px #C29F7B;
}

@media (max-width: 479px) {
  .hero.-type-1 .hero__ipoteca {
    bottom: 14rem;
    left: 2rem;
  }
  
  .hero.-type-1 .hero__payment {
    bottom: 5rem;
    left: 5rem;
    margin-right: 0;
  }
}

.hero.-type-1 .hero__title {
  position: relative;
  overflow: hidden;
  font-size: 4.4vw;
  font-weight: 500;
  text-transform: uppercase;
  line-height: 1.4;
  line-height: 1;
  color: white;
  text-align: left;
  padding-left: 2rem;
}

@media (max-width: 1199px) {
  .hero.-type-1 .hero__title {
    font-size: 4rem;
  }
}

@media (max-width: 767px) {
  .hero.-type-1 .hero__title {
    font-size: 60px;
  }
}

@media (max-width: 575px) {
  .hero.-type-1 .hero__title span {
    display: block;
  }
}

@media (max-width: 479px) {
  .hero.-type-1 .hero__title {
    padding: 0 20px;
    font-size: 2.7rem;
  }
}
.hero.-type-1 .hero__bg{
  z-index: -3;
}
.hero.-type-1 .hero__clouds {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -2;
  pointer-events: none;
  overflow: hidden;
  opacity: 0.7;
}

@media (max-width: 991px) {
  .hero.-type-1 .hero__clouds {
    display: none;
  }
}

.hero.-type-1 .hero__front {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  overflow: hidden;
}

@media (max-width: 767px) {
  .hero.-type-1 .hero__front {
    left: -30%;
    width: 200%;
  }
}

@media (max-width: 479px) {
  .hero.-type-1 .hero__front {
    left: -60%;
    width: 290%;
  }
}

.hero.-type-1 .hero__front img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

/* CSS Clouds */
.cloud {
  position: absolute;
  background: rgba(255, 255, 255, 0.8);
  border-radius: 50px;
  z-index: 1;
}

.cloud:before,
.cloud:after {
  content: '';
  position: absolute;
  background: rgba(255, 255, 255, 0.8);
  border-radius: 50px;
}

.cloud:before {
  width: 50px;
  height: 50px;
  top: -25px;
  left: 10px;
}

.cloud:after {
  width: 60px;
  height: 60px;
  top: -35px;
  right: 10px;
}

/* Cloud sizes */
.cloud-small {
  width: 100px;
  height: 40px;
}

.cloud-medium {
  width: 150px;
  height: 50px;
}

.cloud-large {
  width: 200px;
  height: 60px;
}

.cloud-small:before {
  width: 40px;
  height: 40px;
  top: -20px;
  left: 8px;
}

.cloud-small:after {
  width: 50px;
  height: 50px;
  top: -25px;
  right: 8px;
}

.cloud-medium:before {
  width: 50px;
  height: 50px;
  top: -25px;
  left: 10px;
}

.cloud-medium:after {
  width: 60px;
  height: 60px;
  top: -30px;
  right: 10px;
}

.cloud-large:before {
  width: 60px;
  height: 60px;
  top: -30px;
  left: 15px;
}

.cloud-large:after {
  width: 70px;
  height: 70px;
  top: -35px;
  right: 15px;
}

/* Cloud animations */
@keyframes float {
  0%, 100% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-20px);
  }
}

.cloud-animated {
  animation: float 6s ease-in-out infinite;
}

.cloud-animated-slow {
  animation: float 10s ease-in-out infinite;
}

.cloud-animated-fast {
  animation: float 4s ease-in-out infinite;
}

.hero.-type-2 {
  position: relative;
  width: 100%;
  height: 860px;
  z-index: 1;
}

@media (max-width: 1199px) {
  .hero.-type-2 {
    height: 80vh;
  }
}

@media (max-width: 767px) {
  .hero.-type-2 {
    height: 60vh;
  }
}

.hero.-type-2 .container {
  position: relative;
  height: 100%;
}

.hero.-type-2 .hero__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.hero.-type-2 .hero__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.1);
  z-index: 1;
}

.hero.-type-2 .hero__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.hero.-type-2 .hero__title {
  position: absolute;
  bottom: -70px;
  left: 0;
  text-transform: uppercase;
  color: white;
  font-size: 150px;
  font-weight: 500;
  line-height: 1;
  z-index: 2;
}

@media (max-width: 1199px) {
  .hero.-type-2 .hero__title {
    bottom: -1em;
    font-size: 120px;
  }
}

@media (max-width: 991px) {
  .hero.-type-2 .hero__title {
    font-size: 85px;
  }
}

@media (max-width: 767px) {
  .hero.-type-2 .hero__title {
    bottom: -0.5em;
    font-size: 72px;
  }
}

@media (max-width: 575px) {
  .hero.-type-2 .hero__title {
    font-size: 12.8vw;
    padding: 0 15px;
  }
}

.hero.-type-2 .hero__buttonDown {
  position: absolute;
  bottom: -50px;
  right: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100px;
  height: 100px;
  border-radius: 100%;
  background-color: var(--color-dark-1);
  border: 1px solid var(--color-accent-1);
  color: white;
  font-size: 20px;
  z-index: 10;
  transform: rotate(90deg);
}

@media (max-width: 767px) {
  .hero.-type-2 .hero__buttonDown {
    width: 80px;
    height: 80px;
  }
}

@media (max-width: 575px) {
  .hero.-type-2 .hero__buttonDown {
    display: none;
  }
}

.hero.-type-3 {
  position: relative;
  width: 100%;
  z-index: 1;
}

.hero.-type-3 .hero__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.hero.-type-3 .hero__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
}

.hero.-type-3 .hero__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.hero.-type-3 .hero__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  color: white;
  padding-top: 300px;
  padding-bottom: 180px;
}

@media (max-width: 767px) {
  .hero.-type-3 .hero__content {
    padding-top: 200px;
    padding-bottom: 120px;
  }
}

@media (max-width: 575px) {
  .hero.-type-3 .hero__content {
    padding-top: 160px;
    padding-bottom: 80px;
  }
}

.hero.-type-3 .hero__subtitle {
  font-size: 18px;
  line-height: 32px;
  margin-bottom: 20px;
}

@media (max-width: 767px) {
  .hero.-type-3 .hero__subtitle {
    font-size: 16px;
    line-height: 1.4;
  }
}

.hero.-type-3 .hero__title {
  font-size: 82px;
  line-height: 1.2;
  font-weight: 500;
  text-transform: uppercase;
}

@media (max-width: 991px) {
  .hero.-type-3 .hero__title {
    font-size: 64px;
  }
}

@media (max-width: 767px) {
  .hero.-type-3 .hero__title {
    font-size: 52px;
  }
}

@media (max-width: 575px) {
  .hero.-type-3 .hero__title {
    font-size: 42px;
  }
}

.hero.-type-3 .hero__button {
  margin-top: 20px;
}

.hero.-type-4 {
  position: relative;
  width: 100%;
  z-index: 1;
}

.hero.-type-4 .hero__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.hero.-type-4 .hero__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2);
}

.hero.-type-4 .hero__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.hero.-type-4 .hero__content {
  display: flex;
  flex-direction: column;
  color: white;
  padding-top: 370px;
  padding-bottom: 300px;
}

@media (max-width: 991px) {
  .hero.-type-4 .hero__content {
    padding-top: 300px;
    padding-bottom: 200px;
  }
}

@media (max-width: 767px) {
  .hero.-type-4 .hero__content {
    padding-top: 220px;
    padding-bottom: 120px;
  }
}

@media (max-width: 575px) {
  .hero.-type-4 .hero__content {
    padding-top: 200px;
    padding-bottom: 120px;
  }
}

.hero.-type-4 .hero__subtitle {
  font-size: 18px;
  line-height: 32px;
  margin-bottom: 5px;
}

@media (max-width: 767px) {
  .hero.-type-4 .hero__subtitle {
    font-size: 16px;
    line-height: 1.4;
  }
}

.hero.-type-4 .hero__title {
  font-size: 82px;
  line-height: 1.2;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 2.5px;
}

@media (max-width: 991px) {
  .hero.-type-4 .hero__title {
    font-size: 64px;
  }
}

@media (max-width: 767px) {
  .hero.-type-4 .hero__title {
    font-size: 52px;
  }
}

@media (max-width: 575px) {
  .hero.-type-4 .hero__title {
    font-size: 42px;
  }
}

.hero.-type-4 .hero__button {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 100%;
  border: 1px solid white;
  width: 120px;
  height: 120px;
  margin-top: 35px;
}

@media (max-width: 767px) {
  .hero.-type-4 .hero__button {
    width: 100px;
    height: 100px;
    margin-top: 24px;
  }
}

.hero.-type-5 {
  overflow: hidden;
  position: relative;
  width: 100%;
  z-index: 1;
}

.hero.-type-5 .hero__lines > * {
  position: absolute;
  top: 144px;
  left: 50%;
  max-width: unset;
  transform: translateX(-50%);
  z-index: -1;
}

.hero.-type-5 .hero__bg {
  position: absolute;
  top: 0;
  right: 0;
  width: 43%;
  height: 100%;
  z-index: -1;
}

@media (max-width: 575px) {
  .hero.-type-5 .hero__bg {
    display: none;
  }
}

.hero.-type-5 .hero__bg > *:nth-child(1) {
  height: 100%;
  width: 100%;
}

.hero.-type-5 .hero__bg > *:nth-child(2) {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 64vw;
  max-width: unset;
}

@media (max-width: 991px) {
  .hero.-type-5 .hero__bg > *:nth-child(2) {
    width: 80vw;
  }
}

@media (max-width: 575px) {
  .hero.-type-5 .hero__bg > *:nth-child(2) {
    display: none;
  }
}

.hero.-type-5 .hero__icon {
  position: absolute;
  top: 160px;
  left: -80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 160px;
  height: 160px;
  border-radius: 100%;
  background-color: var(--color-accent-1);
  color: white;
  text-align: center;
  z-index: 10;
}

@media (max-width: 767px) {
  .hero.-type-5 .hero__icon {
    display: none;
  }
}

.hero.-type-5 .hero__icon::before {
  content: "";
  position: absolute;
  width: 190px;
  height: 190px;
  border-radius: 100%;
  border: 1px solid var(--color-accent-1);
  z-index: -1;
}

.hero.-type-5 .hero__icon > *:nth-child(1) {
  font-size: 44px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 1.5px;
}

.hero.-type-5 .hero__icon > *:nth-child(2) {
  font-size: 16px;
  font-weight: 500;
  line-height: 1;
  margin-top: 10px;
}

.hero.-type-5 .hero__content {
  display: flex;
  flex-direction: column;
  color: white;
  padding: 0 60px;
  padding-top: 290px;
  padding-bottom: 260px;
}

@media (max-width: 991px) {
  .hero.-type-5 .hero__content {
    padding: 0 30px;
    padding-top: 180px;
    padding-bottom: 280px;
  }
}

@media (max-width: 575px) {
  .hero.-type-5 .hero__content {
    padding: 0 15px;
    padding-top: 180px;
    padding-bottom: 120px;
  }
}

.hero.-type-5 .hero__badges {
  display: flex;
  margin-bottom: 25px;
}

.hero.-type-5 .hero__badges > * {
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  padding: 10px 20px;
  background-color: rgba(255, 255, 255, 0.1);
  border-radius: 200px;
}

.hero.-type-5 .hero__badges > * + * {
  margin-left: 15px;
}

.hero.-type-5 .hero__title {
  font-size: 82px;
  line-height: 1.2;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 2.5px;
}

@media (max-width: 1199px) {
  .hero.-type-5 .hero__title {
    font-size: 72px;
  }
}

@media (max-width: 991px) {
  .hero.-type-5 .hero__title {
    font-size: 64px;
  }
  .hero.-type-5 .hero__title br {
    display: none;
  }
}

@media (max-width: 767px) {
  .hero.-type-5 .hero__title {
    font-size: 52px;
  }
}

@media (max-width: 575px) {
  .hero.-type-5 .hero__title {
    font-size: 38px;
    margin-bottom: 15px;
  }
}

.hero.-type-5 .hero__text {
  font-size: 18px;
  line-height: 1.7;
}

.hero.-type-6 {
  position: relative;
  padding-top: 150px;
  padding-bottom: 50px;
  z-index: 2;
}

@media (max-width: 767px) {
  .hero.-type-6 {
    padding-top: 110px;
    padding-bottom: 60px;
  }
}

@media (max-width: 575px) {
  .hero.-type-6 {
    padding-bottom: 40px;
  }
}

.hero.-type-6 .hero__image {
  position: absolute;
  bottom: -150px;
  right: 0;
  width: 55%;
  height: 800px;
  z-index: -1;
}

@media (max-width: 767px) {
  .hero.-type-6 .hero__image {
    position: relative;
    bottom: unset;
    width: 100%;
    height: 350px;
    margin-bottom: 30px;
  }
}

@media (max-width: 575px) {
  .hero.-type-6 .hero__image {
    height: 300px;
  }
}

.hero.-type-6 .hero__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.hero.-type-6 .hero__title {
  text-transform: uppercase;
  font-size: 82px;
  font-weight: 500;
  line-height: 1.3;
}

@media (max-width: 767px) {
  .hero.-type-6 .hero__title {
    font-size: 55px;
  }
}

@media (max-width: 575px) {
  .hero.-type-6 .hero__title {
    font-size: 40px;
  }
}

.hero.-type-6 .hero__text {
  margin-top: 6px;
}

.hero.-type-6 .hero__button {
  margin-top: 32px;
}

@media (max-width: 575px) {
  .hero.-type-6 .hero__button {
    margin-top: 20px;
  }
}

.hero.-type-6 .hero__arrow {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100px;
  height: 100px;
  font-size: 20px;
  border-radius: 100%;
  border: 1px solid var(--color-accent-1);
  margin-top: 120px;
}

@media (max-width: 767px) {
  .hero.-type-6 .hero__arrow {
    display: none;
  }
}

.hero.-type-7 {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 100vh;
  z-index: 0;
}

.hero.-type-7 .hero__nav {
  position: absolute;
  bottom: 0;
  right: 0;
  display: flex;
  z-index: 1;
}

.hero.-type-7 .hero__nav > * {
  background-color: white;
  color: black;
  width: 100px;
  height: 100px;
}

.hero.-type-7 .hero__nav > *:hover {
  background-color: var(--color-accent-2);
}

.hero.-type-7 .hero__bg {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  z-index: -1;
}

.hero.-type-7 .hero__bg::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
}

.hero.-type-7 .hero__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.hero.-type-7 .hero__content {
  display: flex;
  flex-direction: column;
  color: white;
  padding-top: 290px;
  padding-bottom: 260px;
}

.hero.-type-7 .hero__subtitle {
  margin-bottom: 20px;
}

.hero.-type-7 .hero__title {
  font-size: 82px;
  line-height: 1.2;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 2.5px;
}

@media (max-width: 991px) {
  .hero.-type-7 .hero__title {
    font-size: 64px;
  }
}

@media (max-width: 767px) {
  .hero.-type-7 .hero__title {
    font-size: 52px;
  }
}

@media (max-width: 575px) {
  .hero.-type-7 .hero__title {
    font-size: 42px;
  }
}

.hero.-type-8 {
  position: relative;
  margin: 20px;
  margin-bottom: 0;
  z-index: 1;
}

@media (max-width: 991px) {
  .hero.-type-8 {
    padding-bottom: 40px;
  }
}

@media (max-width: 575px) {
  .hero.-type-8 {
    margin: 0;
  }
}

.hero.-type-8 .hero__content {
  color: white;
  padding: 280px 0;
}

@media (max-width: 1199px) {
  .hero.-type-8 .hero__content {
    padding-top: 200px;
    padding-bottom: 360px;
  }
}

@media (max-width: 991px) {
  .hero.-type-8 .hero__content {
    padding-top: 180px;
    padding-bottom: 60px;
  }
}

@media (max-width: 767px) {
  .hero.-type-8 .hero__content {
    padding-top: 120px;
    padding-bottom: 60px;
  }
}

.hero.-type-8 .hero__bg {
  overflow: hidden;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: 12px;
  z-index: -1;
}

@media (max-width: 575px) {
  .hero.-type-8 .hero__bg {
    border-radius: 0;
  }
}

.hero.-type-8 .hero__bg::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: rgba(0, 0, 0, 0.2);
}

.hero.-type-8 .hero__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.hero.-type-8 .hero__subtitle {
  display: flex;
  margin-bottom: 30px;
}

.hero.-type-8 .hero__title {
  font-size: 82px;
  font-weight: 500;
  text-transform: uppercase;
  line-height: 1.2;
}

@media (max-width: 1199px) {
  .hero.-type-8 .hero__title {
    font-size: 72px;
  }
}

@media (max-width: 767px) {
  .hero.-type-8 .hero__title {
    font-size: 60px;
  }
}

@media (max-width: 575px) {
  .hero.-type-8 .hero__title {
    font-size: 44px;
  }
}

.hero.-type-8 .hero__text {
  font-size: 18px;
  line-height: 1.7;
  margin-top: 10px;
}

.hero.-type-8 .heroForm {
  position: absolute;
  right: 0;
  bottom: -50px;
  width: 450px;
  max-width: 100%;
  padding: 50px;
  background-color: white;
  border-radius: 12px;
  box-shadow: 0px 24px 128px 0px #00000024;
}

@media (max-width: 991px) {
  .hero.-type-8 .heroForm {
    position: relative;
    bottom: unset;
    width: 100%;
  }
}

@media (max-width: 575px) {
  .hero.-type-8 .heroForm {
    padding: 30px;
  }
}

.hero.-type-8 .heroForm__title {
  margin-bottom: 30px;
}

.hero.-type-9 {
  position: relative;
  width: 100%;
  height: 100vh;
  z-index: 1;
}

@media (max-width: 767px) {
  .hero.-type-9 {
    height: 80vh;
  }
}

.hero.-type-9 .hero__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: -1;
}

@media (max-width: 767px) {
  .hero.-type-9 .hero__bg {
    height: 80vh;
  }
}

.hero.-type-9 .hero__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
}

.hero.-type-9 .hero__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.hero.-type-9 .hero__nav {
  position: absolute;
  top: 50%;
  left: 60px;
  display: flex;
  flex-direction: column;
  color: white;
  transform: translateY(-50%);
  z-index: 5;
}

@media (max-width: 991px) {
  .hero.-type-9 .hero__nav {
    left: 40px;
  }
}

@media (max-width: 767px) {
  .hero.-type-9 .hero__nav {
    left: 20px;
  }
}

@media (max-width: 575px) {
  .hero.-type-9 .hero__nav {
    position: absolute;
    flex-direction: row;
    top: unset;
    left: 50%;
    bottom: 20px;
    transform: translateX(-50%);
  }
}

.hero.-type-9 .hero__nav > * {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  padding: 0 32px;
  background-color: transparent;
  transition: all 0.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  opacity: 0.5;
}

@media (max-width: 767px) {
  .hero.-type-9 .hero__nav > * {
    height: 50px;
    padding: 0 16px;
  }
}

@media (max-width: 575px) {
  .hero.-type-9 .hero__nav > * {
    height: 40px;
    padding: 0 12px;
  }
}

.hero.-type-9 .hero__nav > *::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 1px;
  background-color: white;
  transition: all 0.2 cubic-bezier(0.165, 0.84, 0.44, 1);
  opacity: 0;
}

@media (max-width: 575px) {
  .hero.-type-9 .hero__nav > *::before {
    top: unset;
    width: 100%;
    height: 1px;
  }
}

.hero.-type-9 .hero__nav > *.swiper-pagination-bullet-active {
  opacity: 1;
}

.hero.-type-9 .hero__nav > *.swiper-pagination-bullet-active::before {
  opacity: 1;
}

.hero.-type-9 .hero__lines > * {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 1px;
  background-color: rgba(255, 255, 255, 0.1);
  z-index: 2;
}

.hero.-type-9 .hero__lines > *:nth-child(1) {
  left: 60px;
}

.hero.-type-9 .hero__lines > *:nth-child(2) {
  right: 60px;
}

@media (max-width: 991px) {
  .hero.-type-9 .hero__lines > *:nth-child(1) {
    left: 40px;
  }
  .hero.-type-9 .hero__lines > *:nth-child(2) {
    right: 40px;
  }
}

@media (max-width: 767px) {
  .hero.-type-9 .hero__lines > *:nth-child(1) {
    left: 20px;
  }
  .hero.-type-9 .hero__lines > *:nth-child(2) {
    right: 20px;
  }
}

@media (max-width: 575px) {
  .hero.-type-9 .hero__lines > *:nth-child(1) {
    left: 15px;
  }
  .hero.-type-9 .hero__lines > *:nth-child(2) {
    right: 15px;
  }
}

.hero.-type-9 .hero__content {
  display: flex;
  flex-direction: column;
  color: white;
  padding-top: 265px;
  padding-bottom: 265px;
}

@media (max-width: 1199px) {
  .hero.-type-9 .hero__content {
    padding-top: 240px;
    padding-bottom: 180px;
  }
}

@media (max-width: 575px) {
  .hero.-type-9 .hero__content {
    padding-top: 180px;
    padding-bottom: 150px;
  }
}

.hero.-type-9 .hero__subtitle {
  font-size: 18px;
  line-height: 32px;
  margin-bottom: 20px;
}

@media (max-width: 767px) {
  .hero.-type-9 .hero__subtitle {
    font-size: 16px;
    line-height: 1.4;
  }
}

.hero.-type-9 .hero__title {
  font-size: 82px;
  line-height: 1.2;
  font-weight: 500;
  text-transform: uppercase;
}

@media (max-width: 991px) {
  .hero.-type-9 .hero__title {
    font-size: 64px;
  }
}

@media (max-width: 767px) {
  .hero.-type-9 .hero__title {
    font-size: 52px;
  }
}

@media (max-width: 575px) {
  .hero.-type-9 .hero__title {
    font-size: 38px;
  }
}

.hero.-type-9 .hero__button {
  margin-top: 20px;
}

.hero.-type-10 {
  position: relative;
  height: 100vh;
  z-index: 0;
  padding-top: 120px;
}

@media (max-width: 575px) {
  .hero.-type-10 {
    padding-top: 18vh;
  }
}

.hero.-type-10 .container {
  height: 100%;
}

.hero.-type-10 .row {
  height: 100%;
}

.hero.-type-10 .hero__lines {
  pointer-events: none;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 180px;
  right: 180px;
  display: flex;
  justify-content: space-between;
  z-index: -1;
}

@media (max-width: 991px) {
  .hero.-type-10 .hero__lines {
    left: 100px;
    right: 100px;
  }
}

@media (max-width: 767px) {
  .hero.-type-10 .hero__lines {
    left: 20px;
    right: 20px;
  }
}

.hero.-type-10 .hero__lines > * {
  width: 1px;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.1);
}

.hero.-type-10 .hero__slider {
  height: 100%;
}

.hero.-type-10 .hero__title {
  position: relative;
  width: calc(100% + 100px);
  letter-spacing: 2.5px;
}

@media (max-width: 1399px) {
  .hero.-type-10 .hero__title {
    width: calc(100% + 200px);
  }
}

@media (max-width: 991px) {
  .hero.-type-10 .hero__title {
    width: 100%;
  }
}

.hero.-type-10 .hero__list {
  -moz-column-count: 2;
       column-count: 2;
  -moz-column-gap: 20px;
       column-gap: 20px;
}

.hero.-type-10 .hero__list li {
  list-style: disc inside;
  margin-bottom: 30px;
}

@media (max-width: 991px) {
  .hero.-type-10 .hero__list li {
    margin-bottom: 15px;
  }
}

@media (max-width: 575px) {
  .hero.-type-10 .hero__list li {
    margin-bottom: 10px;
  }
}

.hero.-type-10 .hero__image {
  height: 100%;
}

.hero.-type-10 .hero__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

@media (max-width: 991px) {
  .hero.-type-10 .hero__image img {
    height: 340px;
  }
}

@media (max-width: 575px) {
  .hero.-type-10 .hero__image img {
    height: 40vh;
  }
}

.hero.-type-10 .hero__pagination {
  position: absolute;
  top: 50%;
  right: 70px;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  z-index: 1;
}

.hero.-type-10 .hero__pagination > * {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 6px;
  height: 6px;
  border-radius: 100%;
  background-color: white;
}

.hero.-type-10 .hero__pagination > *::after {
  content: "";
  position: absolute;
  border: 1px solid white;
  width: 26px;
  height: 26px;
  border-radius: 100%;
  transition: all 0.3s ease;
  opacity: 0;
}

.hero.-type-10 .hero__pagination > * + * {
  margin-top: 20px;
}

.hero.-type-10 .hero__pagination > *.is-active::after {
  opacity: 1;
}

@media (max-width: 991px) {
  .hero.-type-10 .hero__pagination {
    right: unset;
    top: unset;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    flex-direction: row;
  }
  .hero.-type-10 .hero__pagination > * + * {
    margin-top: 0;
    margin-left: 20px;
  }
}

@media (max-width: 767px) {
  .hero.-type-10 .hero__pagination > *::after {
    width: 20px;
    height: 20px;
  }
  .hero.-type-10 .hero__pagination > * + * {
    margin-left: 15px;
  }
}

.imageCard.-type-1 {
  position: relative;
  z-index: 0;
}

.imageCard.-type-1 .imageCard__image::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.3);
}

.imageCard.-type-1 .imageCard__title {
  position: absolute;
  bottom: 100px;
  left: 100px;
  font-size: 24px;
  line-height: 1.4;
  text-transform: uppercase;
  font-weight: 500;
}

@media (max-width: 991px) {
  .imageCard.-type-1 .imageCard__title {
    bottom: 50px;
    left: 50px;
    font-size: 20px;
  }
}

@media (max-width: 575px) {
  .imageCard.-type-1 .imageCard__title {
    bottom: 30px;
    left: 30px;
  }
}

.imageCard.-type-2 .imageCard__image {
  margin-bottom: 30px;
}

.imageCard.-type-2 .imageCard__title {
  font-size: 20px;
  font-weight: 500;
  line-height: 36px;
}

.imageCard.-type-2 .imageCard__text {
  line-height: 30px;
}

.imageCard.-type-3 {
  position: relative;
}

.imageCard.-type-3 .imageCard__image {
  position: relative;
  z-index: 0;
}

.imageCard.-type-3 .imageCard__image::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, rgba(24, 29, 36, 0) 0%, #181D24 100%);
  z-index: -1;
}

.imageCard.-type-3 .imageCard__content {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  width: 100%;
  height: 100%;
  padding: 30px;
  color: white;
}

.imageCard.-type-3 .imageCard__title {
  font-size: 20px;
  font-weight: 500;
  line-height: 36px;
}

.imageCard.-type-3 .imageCard__text {
  line-height: 30px;
}

.imageCard.-type-4 {
  position: relative;
}

.imageCard.-type-4 .imageCard__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 20px;
  margin: 20px;
  background-color: white;
  transform: translateY(16px);
  opacity: 0;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.imageCard.-type-4 .imageCard__title {
  font-size: 20px;
  font-weight: 500;
  line-height: 36px;
  color: var(--color-dark-1);
}

.imageCard.-type-4 .imageCard__text {
  line-height: 30px;
  color: var(--color-dark-1);
}

.imageCard.-type-4:hover .imageCard__content {
  transform: none;
  opacity: 1;
}

.imageCard.-type-5 {
  position: relative;
  z-index: 0;
}

.imageCard.-type-5 .imageCard__image::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.3);
}

.imageCard.-type-5 .imageCard__content {
  position: absolute;
  bottom: 100px;
  left: 100px;
}

@media (max-width: 991px) {
  .imageCard.-type-5 .imageCard__content {
    bottom: 50px;
    left: 50px;
  }
}

@media (max-width: 575px) {
  .imageCard.-type-5 .imageCard__content {
    bottom: 30px;
    left: 30px;
  }
}

.imageCard.-type-5 .imageCard__title {
  font-size: 24px;
  line-height: 1.4;
  text-transform: uppercase;
  font-weight: 500;
}

@media (max-width: 991px) {
  .imageCard.-type-5 .imageCard__title {
    font-size: 20px;
  }
}

.imageCard.-type-5 .imageCard__text {
  text-transform: uppercase;
}

.iconCard.-type-1 {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  border: 1px solid #FFFFFF33;
}

.iconCard.-type-1 .iconCard__content {
  position: absolute;
  display: flex;
  align-items: center;
  flex-direction: column;
  z-index: 1;
}

.iconCard.-type-1 .iconCard__icon {
  font-size: 50px;
}

.iconCard.-type-1 .iconCard__title {
  font-size: 20px;
  font-weight: 500;
  line-height: 36px;
  margin-top: 14px;
}

.iconCard.-type-2 {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.iconCard.-type-2 .iconCard__icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100px;
  height: 100px;
  font-size: 40px;
  border-radius: 100%;
  border: 1px solid var(--color-accent-1);
  margin: 0 auto;
  margin-bottom: 30px;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

@media (max-width: 767px) {
  .iconCard.-type-2 .iconCard__icon {
    margin-bottom: 20px;
  }
}

.iconCard.-type-2 .iconCard__title {
  font-size: 20px;
  font-weight: 500;
  line-height: 36px;
}

.iconCard.-type-2 .iconCard__text {
  margin-top: 6px;
}

.iconCard.-type-2:hover .iconCard__icon {
  color: white;
  background-color: var(--color-accent-1);
}

.iconCard.-type-2:hover .iconCard__title {
  color: white;
}

.iconCard.-type-2:hover .iconCard__text {
  color: white;
}

.iconCard.-type-2.-hover-2:hover .iconCard__icon {
  color: white;
  background-color: var(--color-accent-1);
}

.iconCard.-type-2.-hover-2:hover .iconCard__title {
  color: black;
}

.iconCard.-type-2.-hover-2:hover .iconCard__text {
  color: black;
}

.iconCard.-type-2.-dark:hover .iconCard__icon {
  color: white;
  background-color: var(--color-accent-1);
}

.iconCard.-type-2.-dark:hover .iconCard__title {
  color: black;
}

.iconCard.-type-2.-dark:hover .iconCard__text {
  color: black;
}

.iconCard.-type-2.-light .iconCard__icon {
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.iconCard.-type-2.-light:hover .iconCard__icon {
  background-color: rgba(255, 255, 255, 0.1);
}

.iconCard.-type-3 {
  display: flex;
}

@media (max-width: 575px) {
  .iconCard.-type-3 {
    flex-direction: column;
  }
}

.iconCard.-type-3 .iconCard__icon {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  width: 100px;
  height: 100px;
  font-size: 40px;
  border-radius: 100%;
  border: 1px solid var(--color-accent-1);
  margin-right: 20px;
}

@media (max-width: 575px) {
  .iconCard.-type-3 .iconCard__icon {
    width: 80px;
    height: 80px;
    margin-right: 0;
    margin-bottom: 12px;
  }
}

.iconCard.-type-3 .iconCard__title {
  font-size: 20px;
  font-weight: 500;
  line-height: 36px;
  text-transform: uppercase;
}

.iconCard.-type-3 .iconCard__text {
  margin-top: 6px;
}

.iconCard.-type-4 .iconCard__content {
  position: relative;
}

.iconCard.-type-4 .iconCard__icon {
  position: absolute;
  bottom: 30px;
  right: 30px;
  display: flex;
  color: var(--color-accent-1);
  font-size: 126px;
  z-index: 1;
  opacity: 0.2;
}

.iconCard.-type-4 .iconCard__title {
  font-size: 24px;
  font-weight: 500;
  line-height: 1.4;
  text-transform: uppercase;
}

.iconCard.-type-4 .iconCard__text {
  margin-top: 14px;
}

.iconCard.-type-4 .iconCard__button {
  display: flex;
  align-items: center;
  font-size: 18px;
  line-height: 32px;
  text-transform: uppercase;
  margin-top: 30px;
}

.iconCard.-type-4 .iconCard__button span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 100%;
  border: 1px solid var(--color-accent-1);
  margin-right: 15px;
}

.iconCard.-type-4 .iconCard__button span i {
  font-size: 16px;
}

.numberCard.-type-1 {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

.numberCard.-type-1 .numberCard__number {
  font-size: 150px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 2.5px;
  text-align: center;
  color: #F7F0EC;
}

@media (max-width: 991px) {
  .numberCard.-type-1 .numberCard__number {
    font-size: 100px;
  }
}

@media (max-width: 575px) {
  .numberCard.-type-1 .numberCard__number {
    font-size: 90px;
  }
}

.numberCard.-type-1 .numberCard__title {
  position: absolute;
  z-index: 1;
  font-size: 18px;
  font-weight: 500;
  line-height: 32px;
  text-align: center;
  text-transform: uppercase;
}

.blogCard.-type-1 .blogCard__content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 500px;
  border: 1px solid var(--color-accent-1);
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

@media (max-width: 767px) {
  .blogCard.-type-1 .blogCard__content {
    min-height: 410px;
  }
}

.blogCard.-type-1 .blogCard__tag {
  font-size: 16px;
  font-weight: 400;
  line-height: 30px;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.blogCard.-type-1 .blogCard__title {
  font-size: 18px;
  font-weight: 500;
  line-height: 36px;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.blogCard.-type-1 .blogCard__date {
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.blogCard.-type-1 .blogCard__date > *:nth-child(1) {
  font-size: 62px;
  font-weight: 500;
  line-height: 76px;
  letter-spacing: 2.5px;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.blogCard.-type-1 .blogCard__date > *:nth-child(2) {
  font-size: 18px;
  font-weight: 500;
  line-height: 32px;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.blogCard.-type-1:hover .blogCard__content {
  background-color: var(--color-dark-1);
  border-color: transparent;
}

.blogCard.-type-1:hover .blogCard__tag {
  color: white;
}

.blogCard.-type-1:hover .blogCard__title {
  color: white;
}

.blogCard.-type-1:hover .blogCard__date > * {
  color: white;
}

.blogCard.-type-1.-hover-accent:hover .blogCard__content {
  background-color: var(--color-accent-1);
  border-color: transparent;
}

.blogCard.-type-2 .blogCard__image {
  position: relative;
  z-index: 0;
}

.blogCard.-type-2 .blogCard__date {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 30px 40px;
  z-index: 1;
}

.blogCard.-type-2 .blogCard__date > *:nth-child(1) {
  font-size: 62px;
  font-weight: 500;
  line-height: 76px;
  letter-spacing: 2.5px;
}

.blogCard.-type-2 .blogCard__date > *:nth-child(2) {
  font-size: 18px;
  font-weight: 500;
  line-height: 32px;
}

.blogCard.-type-3 .blogCard__date {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 30px 40px;
  color: white;
}

@media (max-width: 767px) {
  .blogCard.-type-3 .blogCard__date {
    padding: 20px 20px;
  }
}

.blogCard.-type-3 .blogCard__date > *:nth-child(1) {
  font-size: 62px;
  font-weight: 500;
  line-height: 76px;
  letter-spacing: 2.5px;
}

.blogCard.-type-3 .blogCard__date > *:nth-child(2) {
  font-size: 18px;
  font-weight: 500;
  line-height: 32px;
}

.blogCard.-type-3 .blogCard__tag {
  font-size: 16px;
  font-weight: 400;
  line-height: 30px;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.blogCard.-type-3 .blogCard__title {
  font-size: 18px;
  font-weight: 500;
  line-height: 36px;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.blogCard.-type-3:hover .blogCard__content {
  background-color: var(--color-dark-1);
  border-color: transparent;
}

.blogCard.-type-3:hover .blogCard__tag {
  color: white;
}

.blogCard.-type-3:hover .blogCard__title {
  color: white;
}

.blogCard.-type-3:hover .blogCard__date > * {
  color: white;
}

.blogCard.-type-3.-hover-accent:hover .blogCard__content {
  background-color: var(--color-accent-1);
  border-color: transparent;
}

.blogCard.-type-3.-hover-light:hover .blogCard__content {
  background-color: transparent;
}

.blogCard.-type-3.-hover-light:hover .blogCard__tag {
  color: var(--color-accent-1);
}

.blogCard.-type-3.-hover-light:hover .blogCard__title {
  color: var(--color-accent-1);
}

.blogCard.-type-3.-hover-light:hover .blogCard__date > * {
  color: white;
}

.testimonials.-type-1 .testimonials__image {
  flex-shrink: 0;
  width: 210px;
  height: 210px;
}

@media (max-width: 767px) {
  .testimonials.-type-1 .testimonials__image {
    width: 150px;
    height: 150px;
    margin-bottom: 30px;
  }
}

.testimonials.-type-1 .testimonials__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 100%;
}

.testimonials.-type-1 .testimonials__icon {
  margin-bottom: 35px;
}

.testimonials.-type-1 .testimonials__text {
  font-size: 24px;
  font-weight: 400;
  line-height: 40px;
  margin-bottom: 25px;
}

@media (max-width: 767px) {
  .testimonials.-type-1 .testimonials__text {
    font-size: 18px;
    margin-bottom: 15px;
  }
}

.testimonials.-type-1 .testimonials__name {
  font-size: 20px;
  font-weight: 500;
  line-height: 36px;
  text-transform: uppercase;
}

.testimonials.-type-1 .testimonials__position {
  font-size: 16px;
  font-weight: 400;
  line-height: 30px;
  text-transform: uppercase;
}

.mapPlaces .mapPlaces__map {
  position: relative;
  right: -100px;
}

@media (max-width: 767px) {
  .mapPlaces .mapPlaces__map {
    right: 0;
  }
}

.mapPlaces .mapPlacesCard {
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: all 0.3s ease;
  opacity: 0.3;
}

.mapPlaces .mapPlacesCard__title {
  font-size: 20px;
  font-weight: 500;
  line-height: 36px;
}

.mapPlaces .mapPlacesCard__caption {
  font-size: 16px;
  line-height: 30px;
}

.mapPlaces .mapPlacesCard__image {
  width: 150px;
  height: 150px;
}

@media (max-width: 767px) {
  .mapPlaces .mapPlacesCard__image {
    width: 120px;
    height: 120px;
  }
}

.mapPlaces .mapPlacesCard__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.mapPlaces .mapPlacesCard.isCardActive {
  opacity: 1;
}

.mapPlaces .mapPlacesPlace {
  position: absolute;
}

.mapPlaces .mapPlacesPlace:nth-child(2) {
  top: 50%;
  left: 47%;
}

.mapPlaces .mapPlacesPlace:nth-child(3) {
  top: 30%;
  left: 47%;
}

.mapPlaces .mapPlacesPlace:nth-child(4) {
  top: 50%;
  left: 27%;
}

.mapPlaces .mapPlacesPlace:nth-child(5) {
  top: 20%;
  left: 17%;
}

.mapPlaces .mapPlacesPlace__marker {
  position: relative;
  width: 20px;
  height: 20px;
  background-color: var(--color-accent-1);
  border-radius: 100%;
}

.mapPlaces .mapPlacesPlace__marker::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  width: 40px;
  height: 40px;
  background-color: var(--color-accent-1);
  opacity: 0.4;
  border-radius: 100%;
}

.mapPlaces .mapPlacesPlace__content {
  position: absolute;
  bottom: calc(100% + 25px);
  left: 50%;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.8;
  color: white;
  text-transform: uppercase;
  padding: 8px 22px;
  background-color: var(--color-accent-1);
  border-radius: 200px;
  white-space: nowrap;
  transition: all 0.3s ease;
  transform: translateY(12px) translateX(-50%);
  opacity: 0;
}

.mapPlaces .mapPlacesPlace.isActive .mapPlacesPlace__content {
  transform: translateX(-50%);
  opacity: 1;
}

.-apartments .tabs__controls .is-tab-el-active {
  background-color: var(--color-accent-2);
}

.tabs__content {
  position: relative;
}

.tabs__pane {
  position: absolute;
  top: 0;
  visibility: hidden;
  transition: none;
  opacity: 0;
}

.tabs__pane.is-tab-el-active {
  transition: opacity 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0.1s;
  position: relative;
  opacity: 1;
  visibility: visible;
}

.tabs.-type-1 {
  position: relative;
  padding-top: 120px;
  padding-bottom: 150px;
  z-index: 0;
}

@media (max-width: 767px) {
  .tabs.-type-1 {
    padding-top: 100px;
  }
}

@media (max-width: 575px) {
  .tabs.-type-1 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

.tabs.-type-1 .tabs__controls {
  display: flex;
  padding: 20px 0;
  margin-top: 40px;
}

@media (max-width: 767px) {
  .tabs.-type-1 .tabs__controls {
    margin-top: 10px;
  }
}

.tabs.-type-1 .tabs__button {
  position: relative;
  font-size: 18px;
  text-transform: uppercase;
  flex-shrink: 0;
}

@media (max-width: 767px) {
  .tabs.-type-1 .tabs__button {
    font-size: 16px;
  }
}

.tabs.-type-1 .tabs__button + * {
  margin-left: 80px;
}

@media (max-width: 991px) {
  .tabs.-type-1 .tabs__button + * {
    margin-left: 32px;
  }
}

.tabs.-type-1 .tabs__button::after {
  content: "";
  background-color: currentColor;
  width: 100%;
  height: 1px;
  position: absolute;
  left: 0;
  bottom: -5px;
  opacity: 0;
}

.tabs.-type-1 .tabs__button.is-tab-el-active::after {
  opacity: 1;
}

.tabs.-type-1 .tabs__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.tabs.-type-1 .tabs__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
}

.tabs.-type-1 .tabs__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.tabs.-type-2 {
  position: relative;
  z-index: 0;
}

.tabs.-type-2 .slider {
  position: unset !important;
}

.tabs.-type-2 .swiper-wrapper {
  position: unset !important;
}

.tabs.-type-2 .tabs__content {
  position: unset;
  padding-top: 340px;
  padding-bottom: 140px;
}

@media (max-width: 991px) {
  .tabs.-type-2 .tabs__content {
    padding-top: 420px;
    padding-bottom: 160px;
  }
}

@media (max-width: 767px) {
  .tabs.-type-2 .tabs__content {
    padding-bottom: 120px;
  }
}

@media (max-width: 575px) {
  .tabs.-type-2 .tabs__content {
    padding-top: 380px;
    padding-bottom: 70px;
  }
}

.tabs.-type-2 .tabs__nav {
  margin-bottom: 40px;
}

@media (max-width: 991px) {
  .tabs.-type-2 .tabs__nav {
    margin-bottom: 0;
    margin-top: 10px;
  }
}

@media (max-width: 575px) {
  .tabs.-type-2 .tabs__nav {
    margin-top: 20px;
  }
}

.tabs.-type-2 .tabs__pagination {
  display: flex;
  flex-wrap: wrap;
  margin: -4px -15px;
  padding-top: 30px;
}

.tabs.-type-2 .tabs__pagination > * {
  width: auto;
  height: auto;
  color: white;
  background-color: transparent;
  padding: 4px 15px;
}

.tabs.-type-2 .tabs__test {
  position: absolute;
  left: 0;
  width: 100%;
  top: 120px;
  z-index: 10;
}

@media (max-width: 575px) {
  .tabs.-type-2 .tabs__test {
    top: 60px;
  }
}

.tabs.-type-2 .tabs__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.tabs.-type-2 .tabs__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
}

.tabs.-type-2 .tabs__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.tabs.-type-3 .tabs__controls {
  display: flex;
  flex-wrap: nowrap;
  padding-bottom: 10px;
}

.tabs.-type-3 .tabs__content {
  margin-top: 20px;
}

@media (max-width: 767px) {
  .tabs.-type-3 .tabs__content {
    margin-top: 10px;
  }
}

.tabs.-type-3 .tabs__button {
  padding: 20px 30px;
  border: 1px solid var(--color-accent-2);
  text-transform: uppercase;
  line-height: 1;
  transition: all 0.2s ease;
}

.tabs.-type-3 .tabs__button.is-tab-el-active {
  background-color: var(--color-accent-2);
}

.tabs.-type-4 .tabs__controls {
  border-bottom: 1px solid var(--color-accent-2);
}

.tabs.-type-4 .tabs__content {
  margin-top: 30px;
}

@media (max-width: 767px) {
  .tabs.-type-4 .tabs__content {
    margin-top: 20px;
  }
}

.tabs.-type-4 .tabs__button {
  position: relative;
  z-index: 0;
  padding-bottom: 18px;
  transition: all 0.2s ease;
}

.tabs.-type-4 .tabs__button::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background-color: var(--color-accent-1);
  transition: all 0.2s ease;
  opacity: 0;
}

.tabs.-type-4 .tabs__button.is-tab-el-active {
  color: var(--color-accent-1);
}

.tabs.-type-4 .tabs__button.is-tab-el-active::after {
  opacity: 1;
}

.shapeBg.-type-1 {
  position: absolute;
  top: 0;
}

.footer.-type-1 {
  position: relative;
  padding: 80px 0 40px;
  overflow: hidden;
}

@media (max-width: 767px) {
  .footer.-type-1 {
    padding: 60px 0 30px;
  }
}

.footer.-type-1 .footer__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  /* Современные браузеры с поддержкой image-set - автоматический выбор размера */
  background-image: 
    image-set(
      url('../img/general/footer-400.webp') 1x,
      url('../img/general/footer-800.webp') 2x
    ),
    /* Fallback для старых браузеров */
    url('../img/general/footer-800.webp');
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0.15;
  z-index: 0;
}

@media (min-width: 1920px) {
  .footer.-type-1 .footer__bg {
    background-image: 
      image-set(
        url('../img/general/footer-1920.webp') 1x,
        url('../img/general/footer-1920.webp') 2x
      ),
      url('../img/general/footer-1920.webp');
  }
}

@media (min-width: 1200px) and (max-width: 1919px) {
  .footer.-type-1 .footer__bg {
    background-image: 
      image-set(
        url('../img/general/footer-1200.webp') 1x,
        url('../img/general/footer-1920.webp') 2x
      ),
      url('../img/general/footer-1200.webp');
  }
}

@media (min-width: 800px) and (max-width: 1199px) {
  .footer.-type-1 .footer__bg {
    background-image: 
      image-set(
        url('../img/general/footer-800.webp') 1x,
        url('../img/general/footer-1200.webp') 2x
      ),
      url('../img/general/footer-800.webp');
  }
}

@media (max-width: 799px) {
  .footer.-type-1 .footer__bg {
    background-image: 
      image-set(
        url('../img/general/footer-400.webp') 1x,
        url('../img/general/footer-800.webp') 2x
      ),
      url('../img/general/footer-400.webp');
  }
}

.footer.-type-1 .footer__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.9) 100%);
  z-index: 1;
}

.footer.-type-1 .container {
  position: relative;
  z-index: 1;
}

.footer.-type-1 .footer__title {
  width: 100vw;
  max-width: 100%;
  text-align: center;
  font-size: 108px;
  font-weight: 300;
  font-family: "Century Gothic", Arial, sans-serif;
  line-height: 1.2;
  background: linear-gradient(to right, #ffeba5, #b77521);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  padding: 40px 0 20px;
  text-transform: uppercase;
  letter-spacing: 40px;
  font-stretch:ultra-condensed;
}

@media (max-width: 991px) {
  .footer.-type-1 .footer__title {
    font-size: 48px;
    padding: 30px 0 15px;
    letter-spacing: 24px;
  }
}

@media (max-width: 575px) {
  .footer.-type-1 .footer__title {
    font-size: 36px;
    padding: 20px 0 10px;
    letter-spacing: 12px;
  }
}

.footer.-type-1 .footer__content {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 80px;
  align-items: start;
  padding: 60px 0 40px;
  max-width: 1200px;
  margin: 0 auto;
}

@media (max-width: 991px) {
  .footer.-type-1 .footer__content {
    grid-template-columns: 1fr;
    gap: 50px;
    padding: 40px 0;
  }
}

.footer.-type-1 .footer__info {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

@media (max-width: 991px) {
  .footer.-type-1 .footer__info {
    text-align: center;
    align-items: center;
  }
}

.footer.-type-1 .footer__logo {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

@media (max-width: 991px) {
  .footer.-type-1 .footer__logo {
    justify-content: center;
  }
}

.footer.-type-1 .footer__logo img {
  max-width: 150px;
  height: auto;
}

@media (max-width: 767px) {
  .footer.-type-1 .footer__logo img {
    max-width: 120px;
  }
}

.footer.-type-1 .footer__contacts {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.footer.-type-1 .footer__contact-item {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

@media (max-width: 991px) {
  .footer.-type-1 .footer__contact-item {
    align-items: center;
    text-align: center;
  }
}

.footer.-type-1 .footer__contact-label {
  font-size: 14px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.6);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.footer.-type-1 .footer__company-name {
  font-size: 16px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.9);
  margin: 0;
  line-height: 1.5;
}

.footer.-type-1 .footer__address-text {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.8);
  margin: 0;
  line-height: 1.6;
}

.footer.-type-1 .footer__phone-link {
  font-size: 18px;
  font-weight: 500;
  color: var(--color-accent-1);
  text-decoration: none;
  transition: color 0.3s ease;
  display: inline-block;
  position: relative;
  width: fit-content;
  align-self: flex-start;
}

@media (max-width: 991px) {
  .footer.-type-1 .footer__phone-link {
    align-self: center;
  }
}

.footer.-type-1 .footer__phone-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--color-accent-1);
  transition: width 0.3s ease;
}

.footer.-type-1 .footer__phone-link:hover {
  color: #d1c28c;
}

.footer.-type-1 .footer__phone-link:hover::after {
  width: 100%;
}

.footer.-type-1 .footer__form-wrapper {
  width: 100%;
}

@media (max-width: 991px) {
  .footer.-type-1 .footer__form-wrapper {
    max-width: 100%;
    margin: 0;
  }
}

.footer.-type-1 .footer__form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}

@media (max-width: 575px) {
  .footer.-type-1 .footer__form-row {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

.footer.-type-1 .footer__form-title {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 24px;
  color: #ffffff;
  line-height: 1.3;
}

@media (max-width: 767px) {
  .footer.-type-1 .footer__form-title {
    font-size: 20px;
    margin-bottom: 20px;
  }
}

.footer.-type-1 .footer__form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.footer.-type-1 .footer__form-field {
  display: flex;
  flex-direction: column;
}

.footer.-type-1 .footer__form-input {
  width: 100%;
  padding: 14px 18px;
  border: 2px solid rgba(255, 255, 255, 0.2);
  border-radius: 12px;
  font-size: 15px;
  font-family: inherit;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.1);
  transition: all 0.3s ease;
  box-sizing: border-box;
  -webkit-appearance: none;
  appearance: none;
}

.footer.-type-1 .footer__form-input::placeholder {
  color: rgba(255, 255, 255, 0.6);
  opacity: 1;
}

.footer.-type-1 .footer__form-input:focus {
  outline: none;
  border-color: rgba(255, 255, 255, 0.3);
  background: rgba(255, 255, 255, 0.12);
}

.footer.-type-1 .footer__form-input:hover {
  border-color: rgba(255, 255, 255, 0.3);
  background: rgba(255, 255, 255, 0.12);
}

.footer.-type-1 .footer__form-radio-group {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.footer.-type-1 .footer__form-radio {
  display: flex;
  align-items: center;
  gap: 0;
  cursor: pointer;
  padding: 12px 20px;
  border: 2px solid rgba(255, 255, 255, 0.2);
  border-radius: 12px;
  transition: all 0.3s ease;
  flex: 1;
  min-width: 0;
  justify-content: center;
  background: rgba(255, 255, 255, 0.1);
}

.footer.-type-1 .footer__form-radio input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  margin: 0;
  cursor: pointer;
  pointer-events: none;
}

.footer.-type-1 .footer__form-radio input[type="radio"]:checked + span {
  font-weight: 600;
}

.footer.-type-1 .footer__form-radio:has(input[type="radio"]:checked) {
  border-color: var(--color-accent-1);
  background: rgba(194, 159, 123, 0.2);
}

.footer.-type-1 .footer__form-radio span {
  font-size: 15px;
  color: #ffffff;
  user-select: none;
}

@media (max-width: 575px) {
  .footer.-type-1 .footer__form-radio-group {
    flex-wrap: nowrap;
    gap: 8px;
  }

  .footer.-type-1 .footer__form-radio {
    flex: 1;
    min-width: 0;
    padding: 10px 12px;
    font-size: 14px;
  }
}

.footer.-type-1 .footer__form-submit {
  font-size: 16px;
  padding: 16px 40px;
  border-width: 2px;
  transition: all 0.3s ease;
  margin-top: 8px;
  width: 100%;
}

.footer.-type-1 .footer__form-submit:hover {
  background: var(--color-accent-1);
  border-color: var(--color-accent-1);
}

.footer.-type-1 .footer__form-agreement {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.5);
  margin: 12px 0 0;
  line-height: 1.4;
  text-align: center;
}

.footer.-type-1 .footer__nav {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 30px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

@media (max-width: 991px) {
  .footer.-type-1 .footer__nav {
    padding: 20px 0;
  }
}

.footer.-type-1 .footer__nav-menu {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 40px;
  list-style: none;
  margin: 0;
  padding: 0;
}

@media (max-width: 991px) {
  .footer.-type-1 .footer__nav-menu {
    gap: 24px;
    flex-wrap: nowrap;
  }
}

@media (max-width: 575px) {
  .footer.-type-1 .footer__nav-menu {
    gap: 12px;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding-bottom: 4px;
  }
  
  .footer.-type-1 .footer__nav-menu::-webkit-scrollbar {
    display: none;
  }
}

.footer.-type-1 .footer__nav-link {
  font-size: 16px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  transition: color 0.3s ease;
  position: relative;
  padding: 8px 0;
}

.footer.-type-1 .footer__nav-link:hover {
  color: var(--color-accent-1);
}

.footer.-type-1 .footer__nav-link::after {
  content: '';
  position: absolute;
  bottom: 4px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--color-accent-1);
  transition: width 0.3s ease;
}

.footer.-type-1 .footer__nav-link:hover::after {
  width: 100%;
}

@media (max-width: 991px) {
  .footer.-type-1 .footer__nav-link::after {
    bottom: 0;
  }
}

.footer.-type-1 .footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 40px;
}

@media (max-width: 767px) {
  .footer.-type-1 .footer__bottom {
    flex-direction: column;
    gap: 20px;
    text-align: center;
    margin-top: 30px;
    padding-top: 20px;
  }
}

.footer.-type-1 .footer__bottom > * {
  font-size: 14px;
  line-height: 24px;
  color: rgba(255, 255, 255, 0.7);
}

.footer.-type-1 .footer__bottom a {
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  transition: color 0.3s ease;
}

.footer.-type-1 .footer__bottom a:hover {
  color: var(--color-accent-1);
}

.footer.-type-1 .footer__bottom > *:last-child {
  display: flex;
  gap: 20px;
}

@media (max-width: 767px) {
  .footer.-type-1 .footer__bottom > *:last-child {
    flex-direction: column;
    gap: 10px;
  }
}

.footer.-type-1.-container .footer__top {
  margin: 0;
}

@media (max-width: 767px) {
  .footer.-type-1.-container .footer__top {
    margin: 0;
  }
}

.footer.-type-1.-light .footer__top {
  border-bottom: 1px solid #F7F0EC;
}

.footer.-type-1.-accent-2 .footer__top {
  border-bottom: 1px solid rgba(25, 29, 35, 0.1);
}

.footer.-type-2 {
  position: relative;
  padding-top: 120px;
  z-index: 0;
}

@media (max-width: 991px) {
  .footer.-type-2 {
    padding-top: 80px;
  }
}

.footer.-type-2 .footer__logo img {
  width: 200px;
}

@media (max-width: 991px) {
  .footer.-type-2 .footer__logo img {
    width: 140px;
  }
}

.footer.-type-2 .footer__mainTitle {
  font-size: 44px;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 1.5px;
  margin-bottom: 120px;
}

@media (max-width: 991px) {
  .footer.-type-2 .footer__mainTitle {
    font-size: 42px;
    margin-bottom: 40px;
  }
}

@media (max-width: 575px) {
  .footer.-type-2 .footer__mainTitle {
    font-size: 32px;
  }
}

.footer.-type-2 .footer__list {
  margin-top: 20px;
}

.footer.-type-2 .footer__list > * {
  display: block;
  font-size: 15px;
}

.footer.-type-2 .footer__list > * + * {
  margin-top: 6px;
}

.footer.-type-2 .footer__bottom {
  padding-top: 120px;
  padding-bottom: 60px;
}

@media (max-width: 767px) {
  .footer.-type-2 .footer__bottom {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}

.footer.-type-2 .footerForm {
  margin-top: 30px;
}

.footer.-type-2 .footerForm__title {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.8;
}

.footer.-type-2 .footerForm__input input {
  font-size: 16px;
  padding: 10px 0;
  border-bottom: 1px solid black;
}

.footer.-type-2 .footerForm__button {
  width: 100%;
  margin-top: 25px;
}

.footer.-type-2.-dark .footer__bg {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  width: 55.4vw;
  background-color: #15191F;
  z-index: -1;
}

@media (max-width: 1199px) {
  .footer.-type-2.-dark .footer__bg {
    width: 60vw;
  }
}

@media (max-width: 991px) {
  .footer.-type-2.-dark .footer__bg {
    display: none;
  }
}

.footer.-type-2.-dark .footerForm__input input {
  border-color: white;
}

.preloader {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 5000;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  background-color: white;

}

.preloader__wrap {
  overflow: hidden;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 144px;
  height: 72px;
  background-color: white;
  animation-name: preloaderWraper;
  animation-iteration-count: infinite;
  animation-duration: 1.8s;
  animation-timing-function: ease;
}

.preloader__icon {
  position: absolute;
  animation-name: preloader;
  animation-iteration-count: infinite;
  animation-duration: 1.8s;
  animation-timing-function: ease;
}

.preloader__title {
  font-size: 42px;
  text-transform: uppercase;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.04em;
  margin-top: 20px;
}

.preloader.-is-hidden {
  opacity: 0;
  pointer-events: none;
}



@keyframes preloader {
  0% {
    transform: translateY(150%);
  }
  50% {
    transform: translateY(0%);
  }
  100% {
    transform: translateY(-150%);
  }
}

body.is-cursor-active {
  cursor: none !important;
}

body.is-cursor-active * {
  cursor: none !important;
}

.cursor {
  position: fixed;
  pointer-events: none;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: transform 0.1s cubic-bezier(0.165, 0.84, 0.44, 1);
  z-index: 10000;
}

.cursor__wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  transition: transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.cursor__follower {
  position: absolute;
  background-color: #888888;
  opacity: 0.25;
  border-radius: 100%;
  width: 24px;
  height: 24px;
  transition: transform 0.3s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.3s cubic-bezier(0.165, 0.84, 0.44, 1), background-color 0.1s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.cursor__arrows {
  position: absolute;
  display: flex;
  opacity: 0;
  transform: scale(0.7) rotate(40deg);
  transition: transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.cursor__arrows > * {
  position: relative;
  color: black;
  stroke-width: 1;
}

.cursor__arrows > *:first-child {
  left: -10px;
}

.cursor__arrows > *:last-child {
  right: -10px;
}

.cursor__label {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  color: white;
  font-size: 16px;
  font-weight: 600;
  transform: scale(0);
  will-change: transform, opacity;
  transition: transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.cursor__icon {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  color: white;
  transform: scale(0);
  will-change: transform, opacity;
  transition: transform 500ms cubic-bezier(0.165, 0.84, 0.44, 1), opacity 500ms cubic-bezier(0.165, 0.84, 0.44, 1);
}

.cursor__icon svg {
  width: 48px;
  height: 48px;
  stroke-width: 0.75;
}

.cursor {
  visibility: hidden;
}

.cursor.is-enabled {
  visibility: visible;
}

.cursor.is-hidden .cursor__wrapper {
  transform: scale(0) !important;
}

.cursor.is-mouse-down .cursor__wrapper {
  transform: scale(0.8);
}

.cursor.is-active .cursor__follower {
  box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.5);
  transform: scale(3.4);
  opacity: 0.25;
}

.cursor.is-active.has-label .cursor__follower {
  background-color: #01213A;
  opacity: 1;
}

.cursor.is-active.has-label .cursor__label {
  transform: scale(1);
}

.cursor.is-active.has-label-light .cursor__follower {
  box-shadow: 0px 5px 70px rgba(1, 33, 58, 0.03);
  background-color: #ffffff;
  opacity: 1;
}

.cursor.is-active.has-label-light .cursor__label {
  color: var(--bg-dark-1) !important;
  transform: scale(1);
}

.cursor.is-active.has-icon .cursor__follower {
  background-color: black;
  opacity: 0.8;
}

.cursor.is-active.has-icon .cursor__icon {
  transform: scale(1);
}

.menu {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  background-color: white;
  color: black;
  z-index: 500;
  opacity: 0;
  pointer-events: none;
}

.menu.-is-active {
  pointer-events: auto;
}

.menu__left {
  width: 50%;
  height: 100%;
}

@media (max-width: 575px) {
  .menu__left {
    width: 100%;
  }
}

.menu .menuNav {
  overflow-y: scroll;
  height: calc(100% - 85px);
  margin: 85px 60px;
  margin-bottom: 0;
  padding-bottom: 85px;
}

@media (max-width: 991px) {
  .menu .menuNav {
    height: calc(100% - 40px);
    margin: 40px 40px;
    margin-bottom: 0;
    padding-bottom: 40px;
  }
}

@media (max-width: 575px) {
  .menu .menuNav {
    height: calc(100% - 30px);
    margin: 30px;
    margin-bottom: 0;
    padding-bottom: 30px;
  }
}

.menu .menuNav::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}

.menu .menuNav::-webkit-scrollbar-thumb {
  background-color: #F7F0EC;
  border-radius: 100px;
}

.menu .menuNav__item > a {
  display: flex;
  align-items: center;
  font-size: 32px;
  line-height: 1;
  font-weight: 500;
  text-transform: uppercase;
}

@media (max-width: 767px) {
  .menu .menuNav__item > a {
    font-size: 20px;
  }
}

.menu .menuNav__item > a i {
  font-size: 20px;
  margin-left: 12px;
}

.menu .menuNav__item > a:hover {
  color: var(--color-accent-1);
}

.menu .menuNav__item + * {
  margin-top: 24px;
}

@media (max-width: 767px) {
  .menu .menuNav__item + * {
    margin-top: 16px;
  }
}

.menu .submenu {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.2s ease-out;
}

.menu .submenu__wrap {
  padding-top: 12px;
}

.menu .submenu__item > a {
  font-size: 18px;
  font-weight: 500;
  line-height: 1;
  color: #71677A;
  text-transform: uppercase;
}

@media (max-width: 767px) {
  .menu .submenu__item > a {
    font-size: 16px;
  }
}

.menu .submenu__item + * {
  margin-top: 4px;
}

.menu__right {
  width: 50%;
  height: 100%;
}

@media (max-width: 575px) {
  .menu__right {
    display: none;
  }
}

.menu .menuImage {
  width: 100%;
  height: 100%;
}

.menu .menuImage img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.menu__close {
  cursor: pointer;
  position: absolute;
  top: 50%;
  left: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: white;
  border: 1px solid #C29F7B;
  width: 100px;
  height: 100px;
  border-radius: 100%;
  transform: translateX(-50%) translateY(-50%);
}

@media (max-width: 575px) {
  .menu__close {
    display: none;
  }
}

.menu__close i {
  transition: all 0.1s ease;
}

.menu__close:hover i {
  color: var(--color-accent-1) !important;
}

.menu.-top-header {
  padding-top: 130px;
}

@media (max-width: 575px) {
  .menu.-top-header {
    padding-top: 108px;
  }
}

.menu.-top-header .menu__close {
  top: calc(50% + 65px);
}

.-sidebar .menu__left {
  padding-left: 80px;
}

@media (max-width: 767px) {
  .-sidebar .menu__left {
    padding-left: 0;
  }
}

.pageHeader.-type-1 {
  position: relative;
  color: white;
  padding-top: 300px;
  padding-bottom: 220px;
  z-index: 0;
}

.pageHeader.-type-1.-pb-sm {
  padding-bottom: 120px;
}

@media (max-width: 991px) {
  .pageHeader.-type-1.-pb-sm {
    padding-bottom: 100px;
  }
}

@media (max-width: 767px) {
  .pageHeader.-type-1.-pb-sm {
    padding-bottom: 80px;
  }
}

@media (max-width: 991px) {
  .pageHeader.-type-1 {
    padding-top: 220px;
    padding-bottom: 140px;
  }
}

@media (max-width: 767px) {
  .pageHeader.-type-1 {
    padding-top: 140px;
    padding-bottom: 80px;
  }
}

.pageHeader.-type-1 .pageHeader__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background-color: black;
}

.pageHeader.-type-1 .pageHeader__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.pageHeader.-type-1 .pageHeader__image::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-dark-2);
  opacity: 0.2;
}

.pageHeader.-type-1 .pageHeader__title {
  font-size: 82px;
  font-weight: 500;
  line-height: 100px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
}

@media (max-width: 991px) {
  .pageHeader.-type-1 .pageHeader__title {
    font-size: 60px;
    line-height: 1.3;
  }
}

@media (max-width: 767px) {
  .pageHeader.-type-1 .pageHeader__title {
    font-size: 40px;
  }
}

.pageHeader.-type-1 .pageHeader-nav {
  display: flex;
  text-transform: uppercase;
  margin-top: 5px;
}

.pageHeader.-type-1 .pageHeader-nav > span {
  margin: 0 5px;
}

.pageHeader.-type-1 .pageHeader-nav__link a, .pageHeader.-type-1 .pageHeader-nav__link span {
  font-size: 18px;
  font-weight: 400;
  line-height: 32px;
}

.marquee {
  position: relative;
}

.marquee > * {
  font-size: 150px;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 2.5px;
  white-space: nowrap;
}

@media (max-width: 991px) {
  .marquee > * {
    font-size: 90px;
    line-height: 1.3;
  }
}

@media (max-width: 767px) {
  .marquee > * {
    font-size: 80px;
  }
}

.marquee > *:nth-child(1) {
  position: relative;
  left: 250px;
}

@media (max-width: 767px) {
  .marquee > *:nth-child(1) {
    left: 20%;
  }
}

.marquee > *:nth-child(2) {
  position: relative;
  right: 70%;
}

@media (max-width: 767px) {
  .marquee > *:nth-child(2) {
    right: 70%;
  }
}

.sliderNav {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  border: 1px solid var(--color-dark-1);
  background-color: var(--color-accent-2);
  border-radius: 100%;
  font-size: 22px;
}

.sliderNav:hover {
  background-color: white;
  border-color: var(--color-accent-1);
}

.sliderNav.-transparent {
  border-color: var(--color-accent-1);
  background-color: transparent;
}

.sliderNav.-transparent:hover {
  background-color: var(--color-accent-1);
  color: white !important;
}

.py-0 {
  padding-top: 0px !important;
  padding-bottom: 0px !important;
}

.px-0 {
  padding-left: 0px !important;
  padding-right: 0px !important;
}

.pt-0 {
  padding-top: 0px !important;
}

.pb-0 {
  padding-bottom: 0px !important;
}

.pl-0 {
  padding-left: 0px !important;
}

.pr-0 {
  padding-right: 0px !important;
}

.mt-0 {
  margin-top: 0px !important;
}

.mb-0 {
  margin-bottom: 0px !important;
}

.ml-0 {
  margin-left: 0px !important;
}

.mr-0 {
  margin-right: 0px !important;
}

.py-5 {
  padding-top: 5px !important;
  padding-bottom: 5px !important;
}

.px-5 {
  padding-left: 5px !important;
  padding-right: 5px !important;
}

.pt-5 {
  padding-top: 5px !important;
}

.pb-5 {
  padding-bottom: 5px !important;
}

.pl-5 {
  padding-left: 5px !important;
}

.pr-5 {
  padding-right: 5px !important;
}

.mt-5 {
  margin-top: 5px !important;
}

.mb-5 {
  margin-bottom: 5px !important;
}

.ml-5 {
  margin-left: 5px !important;
}

.mr-5 {
  margin-right: 5px !important;
}

.py-10 {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

.px-10 {
  padding-left: 10px !important;
  padding-right: 10px !important;
}

.pt-10 {
  padding-top: 10px !important;
}

.pb-10 {
  padding-bottom: 10px !important;
}

.pl-10 {
  padding-left: 10px !important;
}

.pr-10 {
  padding-right: 10px !important;
}

.mt-10 {
  margin-top: 10px !important;
}

.mb-10 {
  margin-bottom: 10px !important;
}

.ml-10 {
  margin-left: 10px !important;
}

.mr-10 {
  margin-right: 10px !important;
}

.py-15 {
  padding-top: 15px !important;
  padding-bottom: 15px !important;
}

.px-15 {
  padding-left: 15px !important;
  padding-right: 15px !important;
}

.pt-15 {
  padding-top: 15px !important;
}

.pb-15 {
  padding-bottom: 15px !important;
}

.pl-15 {
  padding-left: 15px !important;
}

.pr-15 {
  padding-right: 15px !important;
}

.mt-15 {
  margin-top: 15px !important;
}

.mb-15 {
  margin-bottom: 15px !important;
}

.ml-15 {
  margin-left: 15px !important;
}

.mr-15 {
  margin-right: 15px !important;
}

.py-20 {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
}

.px-20 {
  padding-left: 20px !important;
  padding-right: 20px !important;
}

.pt-20 {
  padding-top: 20px !important;
}

.pb-20 {
  padding-bottom: 20px !important;
}

.pl-20 {
  padding-left: 20px !important;
}

.pr-20 {
  padding-right: 20px !important;
}

.mt-20 {
  margin-top: 20px !important;
}

.mb-20 {
  margin-bottom: 20px !important;
}

.ml-20 {
  margin-left: 20px !important;
}

.mr-20 {
  margin-right: 20px !important;
}

.py-25 {
  padding-top: 25px !important;
  padding-bottom: 25px !important;
}

.px-25 {
  padding-left: 25px !important;
  padding-right: 25px !important;
}

.pt-25 {
  padding-top: 25px !important;
}

.pb-25 {
  padding-bottom: 25px !important;
}

.pl-25 {
  padding-left: 25px !important;
}

.pr-25 {
  padding-right: 25px !important;
}

.mt-25 {
  margin-top: 25px !important;
}

.mb-25 {
  margin-bottom: 25px !important;
}

.ml-25 {
  margin-left: 25px !important;
}

.mr-25 {
  margin-right: 25px !important;
}

.py-30 {
  padding-top: 30px !important;
  padding-bottom: 30px !important;
}

.px-30 {
  padding-left: 30px !important;
  padding-right: 30px !important;
}

.pt-30 {
  padding-top: 30px !important;
}

.pb-30 {
  padding-bottom: 30px !important;
}

.pl-30 {
  padding-left: 30px !important;
}

.pr-30 {
  padding-right: 30px !important;
}

.mt-30 {
  margin-top: 30px !important;
}

.mb-30 {
  margin-bottom: 30px !important;
}

.ml-30 {
  margin-left: 30px !important;
}

.mr-30 {
  margin-right: 30px !important;
}

.py-35 {
  padding-top: 35px !important;
  padding-bottom: 35px !important;
}

.px-35 {
  padding-left: 35px !important;
  padding-right: 35px !important;
}

.pt-35 {
  padding-top: 35px !important;
}

.pb-35 {
  padding-bottom: 35px !important;
}

.pl-35 {
  padding-left: 35px !important;
}

.pr-35 {
  padding-right: 35px !important;
}

.mt-35 {
  margin-top: 35px !important;
}

.mb-35 {
  margin-bottom: 35px !important;
}

.ml-35 {
  margin-left: 35px !important;
}

.mr-35 {
  margin-right: 35px !important;
}

.py-40 {
  padding-top: 40px !important;
  padding-bottom: 40px !important;
}

.px-40 {
  padding-left: 40px !important;
  padding-right: 40px !important;
}

.pt-40 {
  padding-top: 40px !important;
}

.pb-40 {
  padding-bottom: 40px !important;
}

.pl-40 {
  padding-left: 40px !important;
}

.pr-40 {
  padding-right: 40px !important;
}

.mt-40 {
  margin-top: 40px !important;
}

.mb-40 {
  margin-bottom: 40px !important;
}

.ml-40 {
  margin-left: 40px !important;
}

.mr-40 {
  margin-right: 40px !important;
}

.py-50 {
  padding-top: 50px !important;
  padding-bottom: 50px !important;
}

.px-50 {
  padding-left: 50px !important;
  padding-right: 50px !important;
}

.pt-50 {
  padding-top: 50px !important;
}

.pb-50 {
  padding-bottom: 50px !important;
}

.pl-50 {
  padding-left: 50px !important;
}

.pr-50 {
  padding-right: 50px !important;
}

.mt-50 {
  margin-top: 50px !important;
}

.mb-50 {
  margin-bottom: 50px !important;
}

.ml-50 {
  margin-left: 50px !important;
}

.mr-50 {
  margin-right: 50px !important;
}

.py-55 {
  padding-top: 55px !important;
  padding-bottom: 55px !important;
}

.px-55 {
  padding-left: 55px !important;
  padding-right: 55px !important;
}

.pt-55 {
  padding-top: 55px !important;
}

.pb-55 {
  padding-bottom: 55px !important;
}

.pl-55 {
  padding-left: 55px !important;
}

.pr-55 {
  padding-right: 55px !important;
}

.mt-55 {
  margin-top: 55px !important;
}

.mb-55 {
  margin-bottom: 55px !important;
}

.ml-55 {
  margin-left: 55px !important;
}

.mr-55 {
  margin-right: 55px !important;
}

.py-60 {
  padding-top: 60px !important;
  padding-bottom: 60px !important;
}

.px-60 {
  padding-left: 60px !important;
  padding-right: 60px !important;
}

.pt-60 {
  padding-top: 60px !important;
}

.pb-60 {
  padding-bottom: 60px !important;
}

.pl-60 {
  padding-left: 60px !important;
}

.pr-60 {
  padding-right: 60px !important;
}

.mt-60 {
  margin-top: 60px !important;
}

.mb-60 {
  margin-bottom: 60px !important;
}

.ml-60 {
  margin-left: 60px !important;
}

.mr-60 {
  margin-right: 60px !important;
}

.py-100 {
  padding-top: 100px !important;
  padding-bottom: 100px !important;
}

.px-100 {
  padding-left: 100px !important;
  padding-right: 100px !important;
}

.pt-100 {
  padding-top: 100px !important;
}

.pb-100 {
  padding-bottom: 100px !important;
}

.pl-100 {
  padding-left: 100px !important;
}

.pr-100 {
  padding-right: 100px !important;
}

.mt-100 {
  margin-top: 100px !important;
}

.mb-100 {
  margin-bottom: 100px !important;
}

.ml-100 {
  margin-left: 100px !important;
}

.mr-100 {
  margin-right: 100px !important;
}

@media (max-width: 1199px) {
  .xl\:py-0 {
    padding-top: 0px !important;
    padding-bottom: 0px !important;
  }
  .xl\:px-0 {
    padding-left: 0px !important;
    padding-right: 0px !important;
  }
  .xl\:pt-0 {
    padding-top: 0px !important;
  }
  .xl\:pb-0 {
    padding-bottom: 0px !important;
  }
  .xl\:pl-0 {
    padding-left: 0px !important;
  }
  .xl\:pr-0 {
    padding-right: 0px !important;
  }
  .xl\:mt-0 {
    margin-top: 0px !important;
  }
  .xl\:mb-0 {
    margin-bottom: 0px !important;
  }
  .xl\:ml-0 {
    margin-left: 0px !important;
  }
  .xl\:mr-0 {
    margin-right: 0px !important;
  }
  .xl\:py-5 {
    padding-top: 5px !important;
    padding-bottom: 5px !important;
  }
  .xl\:px-5 {
    padding-left: 5px !important;
    padding-right: 5px !important;
  }
  .xl\:pt-5 {
    padding-top: 5px !important;
  }
  .xl\:pb-5 {
    padding-bottom: 5px !important;
  }
  .xl\:pl-5 {
    padding-left: 5px !important;
  }
  .xl\:pr-5 {
    padding-right: 5px !important;
  }
  .xl\:mt-5 {
    margin-top: 5px !important;
  }
  .xl\:mb-5 {
    margin-bottom: 5px !important;
  }
  .xl\:ml-5 {
    margin-left: 5px !important;
  }
  .xl\:mr-5 {
    margin-right: 5px !important;
  }
  .xl\:py-10 {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }
  .xl\:px-10 {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
  .xl\:pt-10 {
    padding-top: 10px !important;
  }
  .xl\:pb-10 {
    padding-bottom: 10px !important;
  }
  .xl\:pl-10 {
    padding-left: 10px !important;
  }
  .xl\:pr-10 {
    padding-right: 10px !important;
  }
  .xl\:mt-10 {
    margin-top: 10px !important;
  }
  .xl\:mb-10 {
    margin-bottom: 10px !important;
  }
  .xl\:ml-10 {
    margin-left: 10px !important;
  }
  .xl\:mr-10 {
    margin-right: 10px !important;
  }
  .xl\:py-15 {
    padding-top: 15px !important;
    padding-bottom: 15px !important;
  }
  .xl\:px-15 {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
  .xl\:pt-15 {
    padding-top: 15px !important;
  }
  .xl\:pb-15 {
    padding-bottom: 15px !important;
  }
  .xl\:pl-15 {
    padding-left: 15px !important;
  }
  .xl\:pr-15 {
    padding-right: 15px !important;
  }
  .xl\:mt-15 {
    margin-top: 15px !important;
  }
  .xl\:mb-15 {
    margin-bottom: 15px !important;
  }
  .xl\:ml-15 {
    margin-left: 15px !important;
  }
  .xl\:mr-15 {
    margin-right: 15px !important;
  }
  .xl\:py-20 {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
  }
  .xl\:px-20 {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
  .xl\:pt-20 {
    padding-top: 20px !important;
  }
  .xl\:pb-20 {
    padding-bottom: 20px !important;
  }
  .xl\:pl-20 {
    padding-left: 20px !important;
  }
  .xl\:pr-20 {
    padding-right: 20px !important;
  }
  .xl\:mt-20 {
    margin-top: 20px !important;
  }
  .xl\:mb-20 {
    margin-bottom: 20px !important;
  }
  .xl\:ml-20 {
    margin-left: 20px !important;
  }
  .xl\:mr-20 {
    margin-right: 20px !important;
  }
  .xl\:py-25 {
    padding-top: 25px !important;
    padding-bottom: 25px !important;
  }
  .xl\:px-25 {
    padding-left: 25px !important;
    padding-right: 25px !important;
  }
  .xl\:pt-25 {
    padding-top: 25px !important;
  }
  .xl\:pb-25 {
    padding-bottom: 25px !important;
  }
  .xl\:pl-25 {
    padding-left: 25px !important;
  }
  .xl\:pr-25 {
    padding-right: 25px !important;
  }
  .xl\:mt-25 {
    margin-top: 25px !important;
  }
  .xl\:mb-25 {
    margin-bottom: 25px !important;
  }
  .xl\:ml-25 {
    margin-left: 25px !important;
  }
  .xl\:mr-25 {
    margin-right: 25px !important;
  }
  .xl\:py-30 {
    padding-top: 30px !important;
    padding-bottom: 30px !important;
  }
  .xl\:px-30 {
    padding-left: 30px !important;
    padding-right: 30px !important;
  }
  .xl\:pt-30 {
    padding-top: 30px !important;
  }
  .xl\:pb-30 {
    padding-bottom: 30px !important;
  }
  .xl\:pl-30 {
    padding-left: 30px !important;
  }
  .xl\:pr-30 {
    padding-right: 30px !important;
  }
  .xl\:mt-30 {
    margin-top: 30px !important;
  }
  .xl\:mb-30 {
    margin-bottom: 30px !important;
  }
  .xl\:ml-30 {
    margin-left: 30px !important;
  }
  .xl\:mr-30 {
    margin-right: 30px !important;
  }
  .xl\:py-35 {
    padding-top: 35px !important;
    padding-bottom: 35px !important;
  }
  .xl\:px-35 {
    padding-left: 35px !important;
    padding-right: 35px !important;
  }
  .xl\:pt-35 {
    padding-top: 35px !important;
  }
  .xl\:pb-35 {
    padding-bottom: 35px !important;
  }
  .xl\:pl-35 {
    padding-left: 35px !important;
  }
  .xl\:pr-35 {
    padding-right: 35px !important;
  }
  .xl\:mt-35 {
    margin-top: 35px !important;
  }
  .xl\:mb-35 {
    margin-bottom: 35px !important;
  }
  .xl\:ml-35 {
    margin-left: 35px !important;
  }
  .xl\:mr-35 {
    margin-right: 35px !important;
  }
  .xl\:py-40 {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }
  .xl\:px-40 {
    padding-left: 40px !important;
    padding-right: 40px !important;
  }
  .xl\:pt-40 {
    padding-top: 40px !important;
  }
  .xl\:pb-40 {
    padding-bottom: 40px !important;
  }
  .xl\:pl-40 {
    padding-left: 40px !important;
  }
  .xl\:pr-40 {
    padding-right: 40px !important;
  }
  .xl\:mt-40 {
    margin-top: 40px !important;
  }
  .xl\:mb-40 {
    margin-bottom: 40px !important;
  }
  .xl\:ml-40 {
    margin-left: 40px !important;
  }
  .xl\:mr-40 {
    margin-right: 40px !important;
  }
  .xl\:py-50 {
    padding-top: 50px !important;
    padding-bottom: 50px !important;
  }
  .xl\:px-50 {
    padding-left: 50px !important;
    padding-right: 50px !important;
  }
  .xl\:pt-50 {
    padding-top: 50px !important;
  }
  .xl\:pb-50 {
    padding-bottom: 50px !important;
  }
  .xl\:pl-50 {
    padding-left: 50px !important;
  }
  .xl\:pr-50 {
    padding-right: 50px !important;
  }
  .xl\:mt-50 {
    margin-top: 50px !important;
  }
  .xl\:mb-50 {
    margin-bottom: 50px !important;
  }
  .xl\:ml-50 {
    margin-left: 50px !important;
  }
  .xl\:mr-50 {
    margin-right: 50px !important;
  }
  .xl\:py-55 {
    padding-top: 55px !important;
    padding-bottom: 55px !important;
  }
  .xl\:px-55 {
    padding-left: 55px !important;
    padding-right: 55px !important;
  }
  .xl\:pt-55 {
    padding-top: 55px !important;
  }
  .xl\:pb-55 {
    padding-bottom: 55px !important;
  }
  .xl\:pl-55 {
    padding-left: 55px !important;
  }
  .xl\:pr-55 {
    padding-right: 55px !important;
  }
  .xl\:mt-55 {
    margin-top: 55px !important;
  }
  .xl\:mb-55 {
    margin-bottom: 55px !important;
  }
  .xl\:ml-55 {
    margin-left: 55px !important;
  }
  .xl\:mr-55 {
    margin-right: 55px !important;
  }
  .xl\:py-60 {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }
  .xl\:px-60 {
    padding-left: 60px !important;
    padding-right: 60px !important;
  }
  .xl\:pt-60 {
    padding-top: 60px !important;
  }
  .xl\:pb-60 {
    padding-bottom: 60px !important;
  }
  .xl\:pl-60 {
    padding-left: 60px !important;
  }
  .xl\:pr-60 {
    padding-right: 60px !important;
  }
  .xl\:mt-60 {
    margin-top: 60px !important;
  }
  .xl\:mb-60 {
    margin-bottom: 60px !important;
  }
  .xl\:ml-60 {
    margin-left: 60px !important;
  }
  .xl\:mr-60 {
    margin-right: 60px !important;
  }
  .xl\:py-100 {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }
  .xl\:px-100 {
    padding-left: 100px !important;
    padding-right: 100px !important;
  }
  .xl\:pt-100 {
    padding-top: 100px !important;
  }
  .xl\:pb-100 {
    padding-bottom: 100px !important;
  }
  .xl\:pl-100 {
    padding-left: 100px !important;
  }
  .xl\:pr-100 {
    padding-right: 100px !important;
  }
  .xl\:mt-100 {
    margin-top: 100px !important;
  }
  .xl\:mb-100 {
    margin-bottom: 100px !important;
  }
  .xl\:ml-100 {
    margin-left: 100px !important;
  }
  .xl\:mr-100 {
    margin-right: 100px !important;
  }
}

@media (max-width: 991px) {
  .lg\:py-0 {
    padding-top: 0px !important;
    padding-bottom: 0px !important;
  }
  .lg\:px-0 {
    padding-left: 0px !important;
    padding-right: 0px !important;
  }
  .lg\:pt-0 {
    padding-top: 0px !important;
  }
  .lg\:pb-0 {
    padding-bottom: 0px !important;
  }
  .lg\:pl-0 {
    padding-left: 0px !important;
  }
  .lg\:pr-0 {
    padding-right: 0px !important;
  }
  .lg\:mt-0 {
    margin-top: 0px !important;
  }
  .lg\:mb-0 {
    margin-bottom: 0px !important;
  }
  .lg\:ml-0 {
    margin-left: 0px !important;
  }
  .lg\:mr-0 {
    margin-right: 0px !important;
  }
  .lg\:py-5 {
    padding-top: 5px !important;
    padding-bottom: 5px !important;
  }
  .lg\:px-5 {
    padding-left: 5px !important;
    padding-right: 5px !important;
  }
  .lg\:pt-5 {
    padding-top: 5px !important;
  }
  .lg\:pb-5 {
    padding-bottom: 5px !important;
  }
  .lg\:pl-5 {
    padding-left: 5px !important;
  }
  .lg\:pr-5 {
    padding-right: 5px !important;
  }
  .lg\:mt-5 {
    margin-top: 5px !important;
  }
  .lg\:mb-5 {
    margin-bottom: 5px !important;
  }
  .lg\:ml-5 {
    margin-left: 5px !important;
  }
  .lg\:mr-5 {
    margin-right: 5px !important;
  }
  .lg\:py-10 {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }
  .lg\:px-10 {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
  .lg\:pt-10 {
    padding-top: 10px !important;
  }
  .lg\:pb-10 {
    padding-bottom: 10px !important;
  }
  .lg\:pl-10 {
    padding-left: 10px !important;
  }
  .lg\:pr-10 {
    padding-right: 10px !important;
  }
  .lg\:mt-10 {
    margin-top: 10px !important;
  }
  .lg\:mb-10 {
    margin-bottom: 10px !important;
  }
  .lg\:ml-10 {
    margin-left: 10px !important;
  }
  .lg\:mr-10 {
    margin-right: 10px !important;
  }
  .lg\:py-15 {
    padding-top: 15px !important;
    padding-bottom: 15px !important;
  }
  .lg\:px-15 {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
  .lg\:pt-15 {
    padding-top: 15px !important;
  }
  .lg\:pb-15 {
    padding-bottom: 15px !important;
  }
  .lg\:pl-15 {
    padding-left: 15px !important;
  }
  .lg\:pr-15 {
    padding-right: 15px !important;
  }
  .lg\:mt-15 {
    margin-top: 15px !important;
  }
  .lg\:mb-15 {
    margin-bottom: 15px !important;
  }
  .lg\:ml-15 {
    margin-left: 15px !important;
  }
  .lg\:mr-15 {
    margin-right: 15px !important;
  }
  .lg\:py-20 {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
  }
  .lg\:px-20 {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
  .lg\:pt-20 {
    padding-top: 20px !important;
  }
  .lg\:pb-20 {
    padding-bottom: 20px !important;
  }
  .lg\:pl-20 {
    padding-left: 20px !important;
  }
  .lg\:pr-20 {
    padding-right: 20px !important;
  }
  .lg\:mt-20 {
    margin-top: 20px !important;
  }
  .lg\:mb-20 {
    margin-bottom: 20px !important;
  }
  .lg\:ml-20 {
    margin-left: 20px !important;
  }
  .lg\:mr-20 {
    margin-right: 20px !important;
  }
  .lg\:py-25 {
    padding-top: 25px !important;
    padding-bottom: 25px !important;
  }
  .lg\:px-25 {
    padding-left: 25px !important;
    padding-right: 25px !important;
  }
  .lg\:pt-25 {
    padding-top: 25px !important;
  }
  .lg\:pb-25 {
    padding-bottom: 25px !important;
  }
  .lg\:pl-25 {
    padding-left: 25px !important;
  }
  .lg\:pr-25 {
    padding-right: 25px !important;
  }
  .lg\:mt-25 {
    margin-top: 25px !important;
  }
  .lg\:mb-25 {
    margin-bottom: 25px !important;
  }
  .lg\:ml-25 {
    margin-left: 25px !important;
  }
  .lg\:mr-25 {
    margin-right: 25px !important;
  }
  .lg\:py-30 {
    padding-top: 30px !important;
    padding-bottom: 30px !important;
  }
  .lg\:px-30 {
    padding-left: 30px !important;
    padding-right: 30px !important;
  }
  .lg\:pt-30 {
    padding-top: 30px !important;
  }
  .lg\:pb-30 {
    padding-bottom: 30px !important;
  }
  .lg\:pl-30 {
    padding-left: 30px !important;
  }
  .lg\:pr-30 {
    padding-right: 30px !important;
  }
  .lg\:mt-30 {
    margin-top: 30px !important;
  }
  .lg\:mb-30 {
    margin-bottom: 30px !important;
  }
  .lg\:ml-30 {
    margin-left: 30px !important;
  }
  .lg\:mr-30 {
    margin-right: 30px !important;
  }
  .lg\:py-35 {
    padding-top: 35px !important;
    padding-bottom: 35px !important;
  }
  .lg\:px-35 {
    padding-left: 35px !important;
    padding-right: 35px !important;
  }
  .lg\:pt-35 {
    padding-top: 35px !important;
  }
  .lg\:pb-35 {
    padding-bottom: 35px !important;
  }
  .lg\:pl-35 {
    padding-left: 35px !important;
  }
  .lg\:pr-35 {
    padding-right: 35px !important;
  }
  .lg\:mt-35 {
    margin-top: 35px !important;
  }
  .lg\:mb-35 {
    margin-bottom: 35px !important;
  }
  .lg\:ml-35 {
    margin-left: 35px !important;
  }
  .lg\:mr-35 {
    margin-right: 35px !important;
  }
  .lg\:py-40 {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }
  .lg\:px-40 {
    padding-left: 40px !important;
    padding-right: 40px !important;
  }
  .lg\:pt-40 {
    padding-top: 40px !important;
  }
  .lg\:pb-40 {
    padding-bottom: 40px !important;
  }
  .lg\:pl-40 {
    padding-left: 40px !important;
  }
  .lg\:pr-40 {
    padding-right: 40px !important;
  }
  .lg\:mt-40 {
    margin-top: 40px !important;
  }
  .lg\:mb-40 {
    margin-bottom: 40px !important;
  }
  .lg\:ml-40 {
    margin-left: 40px !important;
  }
  .lg\:mr-40 {
    margin-right: 40px !important;
  }
  .lg\:py-50 {
    padding-top: 50px !important;
    padding-bottom: 50px !important;
  }
  .lg\:px-50 {
    padding-left: 50px !important;
    padding-right: 50px !important;
  }
  .lg\:pt-50 {
    padding-top: 50px !important;
  }
  .lg\:pb-50 {
    padding-bottom: 50px !important;
  }
  .lg\:pl-50 {
    padding-left: 50px !important;
  }
  .lg\:pr-50 {
    padding-right: 50px !important;
  }
  .lg\:mt-50 {
    margin-top: 50px !important;
  }
  .lg\:mb-50 {
    margin-bottom: 50px !important;
  }
  .lg\:ml-50 {
    margin-left: 50px !important;
  }
  .lg\:mr-50 {
    margin-right: 50px !important;
  }
  .lg\:py-55 {
    padding-top: 55px !important;
    padding-bottom: 55px !important;
  }
  .lg\:px-55 {
    padding-left: 55px !important;
    padding-right: 55px !important;
  }
  .lg\:pt-55 {
    padding-top: 55px !important;
  }
  .lg\:pb-55 {
    padding-bottom: 55px !important;
  }
  .lg\:pl-55 {
    padding-left: 55px !important;
  }
  .lg\:pr-55 {
    padding-right: 55px !important;
  }
  .lg\:mt-55 {
    margin-top: 55px !important;
  }
  .lg\:mb-55 {
    margin-bottom: 55px !important;
  }
  .lg\:ml-55 {
    margin-left: 55px !important;
  }
  .lg\:mr-55 {
    margin-right: 55px !important;
  }
  .lg\:py-60 {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }
  .lg\:px-60 {
    padding-left: 60px !important;
    padding-right: 60px !important;
  }
  .lg\:pt-60 {
    padding-top: 60px !important;
  }
  .lg\:pb-60 {
    padding-bottom: 60px !important;
  }
  .lg\:pl-60 {
    padding-left: 60px !important;
  }
  .lg\:pr-60 {
    padding-right: 60px !important;
  }
  .lg\:mt-60 {
    margin-top: 60px !important;
  }
  .lg\:mb-60 {
    margin-bottom: 60px !important;
  }
  .lg\:ml-60 {
    margin-left: 60px !important;
  }
  .lg\:mr-60 {
    margin-right: 60px !important;
  }
  .lg\:py-100 {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }
  .lg\:px-100 {
    padding-left: 100px !important;
    padding-right: 100px !important;
  }
  .lg\:pt-100 {
    padding-top: 100px !important;
  }
  .lg\:pb-100 {
    padding-bottom: 100px !important;
  }
  .lg\:pl-100 {
    padding-left: 100px !important;
  }
  .lg\:pr-100 {
    padding-right: 100px !important;
  }
  .lg\:mt-100 {
    margin-top: 100px !important;
  }
  .lg\:mb-100 {
    margin-bottom: 100px !important;
  }
  .lg\:ml-100 {
    margin-left: 100px !important;
  }
  .lg\:mr-100 {
    margin-right: 100px !important;
  }
}

@media (max-width: 767px) {
  .md\:py-0 {
    padding-top: 0px !important;
    padding-bottom: 0px !important;
  }
  .md\:px-0 {
    padding-left: 0px !important;
    padding-right: 0px !important;
  }
  .md\:pt-0 {
    padding-top: 0px !important;
  }
  .md\:pb-0 {
    padding-bottom: 0px !important;
  }
  .md\:pl-0 {
    padding-left: 0px !important;
  }
  .md\:pr-0 {
    padding-right: 0px !important;
  }
  .md\:mt-0 {
    margin-top: 0px !important;
  }
  .md\:mb-0 {
    margin-bottom: 0px !important;
  }
  .md\:ml-0 {
    margin-left: 0px !important;
  }
  .md\:mr-0 {
    margin-right: 0px !important;
  }
  .md\:py-5 {
    padding-top: 5px !important;
    padding-bottom: 5px !important;
  }
  .md\:px-5 {
    padding-left: 5px !important;
    padding-right: 5px !important;
  }
  .md\:pt-5 {
    padding-top: 5px !important;
  }
  .md\:pb-5 {
    padding-bottom: 5px !important;
  }
  .md\:pl-5 {
    padding-left: 5px !important;
  }
  .md\:pr-5 {
    padding-right: 5px !important;
  }
  .md\:mt-5 {
    margin-top: 5px !important;
  }
  .md\:mb-5 {
    margin-bottom: 5px !important;
  }
  .md\:ml-5 {
    margin-left: 5px !important;
  }
  .md\:mr-5 {
    margin-right: 5px !important;
  }
  .md\:py-10 {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }
  .md\:px-10 {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
  .md\:pt-10 {
    padding-top: 10px !important;
  }
  .md\:pb-10 {
    padding-bottom: 10px !important;
  }
  .md\:pl-10 {
    padding-left: 10px !important;
  }
  .md\:pr-10 {
    padding-right: 10px !important;
  }
  .md\:mt-10 {
    margin-top: 10px !important;
  }
  .md\:mb-10 {
    margin-bottom: 10px !important;
  }
  .md\:ml-10 {
    margin-left: 10px !important;
  }
  .md\:mr-10 {
    margin-right: 10px !important;
  }
  .md\:py-15 {
    padding-top: 15px !important;
    padding-bottom: 15px !important;
  }
  .md\:px-15 {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
  .md\:pt-15 {
    padding-top: 15px !important;
  }
  .md\:pb-15 {
    padding-bottom: 15px !important;
  }
  .md\:pl-15 {
    padding-left: 15px !important;
  }
  .md\:pr-15 {
    padding-right: 15px !important;
  }
  .md\:mt-15 {
    margin-top: 15px !important;
  }
  .md\:mb-15 {
    margin-bottom: 15px !important;
  }
  .md\:ml-15 {
    margin-left: 15px !important;
  }
  .md\:mr-15 {
    margin-right: 15px !important;
  }
  .md\:py-20 {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
  }
  .md\:px-20 {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
  .md\:pt-20 {
    padding-top: 20px !important;
  }
  .md\:pb-20 {
    padding-bottom: 20px !important;
  }
  .md\:pl-20 {
    padding-left: 20px !important;
  }
  .md\:pr-20 {
    padding-right: 20px !important;
  }
  .md\:mt-20 {
    margin-top: 20px !important;
  }
  .md\:mb-20 {
    margin-bottom: 20px !important;
  }
  .md\:ml-20 {
    margin-left: 20px !important;
  }
  .md\:mr-20 {
    margin-right: 20px !important;
  }
  .md\:py-25 {
    padding-top: 25px !important;
    padding-bottom: 25px !important;
  }
  .md\:px-25 {
    padding-left: 25px !important;
    padding-right: 25px !important;
  }
  .md\:pt-25 {
    padding-top: 25px !important;
  }
  .md\:pb-25 {
    padding-bottom: 25px !important;
  }
  .md\:pl-25 {
    padding-left: 25px !important;
  }
  .md\:pr-25 {
    padding-right: 25px !important;
  }
  .md\:mt-25 {
    margin-top: 25px !important;
  }
  .md\:mb-25 {
    margin-bottom: 25px !important;
  }
  .md\:ml-25 {
    margin-left: 25px !important;
  }
  .md\:mr-25 {
    margin-right: 25px !important;
  }
  .md\:py-30 {
    padding-top: 30px !important;
    padding-bottom: 30px !important;
  }
  .md\:px-30 {
    padding-left: 30px !important;
    padding-right: 30px !important;
  }
  .md\:pt-30 {
    padding-top: 30px !important;
  }
  .md\:pb-30 {
    padding-bottom: 30px !important;
  }
  .md\:pl-30 {
    padding-left: 30px !important;
  }
  .md\:pr-30 {
    padding-right: 30px !important;
  }
  .md\:mt-30 {
    margin-top: 30px !important;
  }
  .md\:mb-30 {
    margin-bottom: 30px !important;
  }
  .md\:ml-30 {
    margin-left: 30px !important;
  }
  .md\:mr-30 {
    margin-right: 30px !important;
  }
  .md\:py-35 {
    padding-top: 35px !important;
    padding-bottom: 35px !important;
  }
  .md\:px-35 {
    padding-left: 35px !important;
    padding-right: 35px !important;
  }
  .md\:pt-35 {
    padding-top: 35px !important;
  }
  .md\:pb-35 {
    padding-bottom: 35px !important;
  }
  .md\:pl-35 {
    padding-left: 35px !important;
  }
  .md\:pr-35 {
    padding-right: 35px !important;
  }
  .md\:mt-35 {
    margin-top: 35px !important;
  }
  .md\:mb-35 {
    margin-bottom: 35px !important;
  }
  .md\:ml-35 {
    margin-left: 35px !important;
  }
  .md\:mr-35 {
    margin-right: 35px !important;
  }
  .md\:py-40 {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }
  .md\:px-40 {
    padding-left: 40px !important;
    padding-right: 40px !important;
  }
  .md\:pt-40 {
    padding-top: 40px !important;
  }
  .md\:pb-40 {
    padding-bottom: 40px !important;
  }
  .md\:pl-40 {
    padding-left: 40px !important;
  }
  .md\:pr-40 {
    padding-right: 40px !important;
  }
  .md\:mt-40 {
    margin-top: 40px !important;
  }
  .md\:mb-40 {
    margin-bottom: 40px !important;
  }
  .md\:ml-40 {
    margin-left: 40px !important;
  }
  .md\:mr-40 {
    margin-right: 40px !important;
  }
  .md\:py-50 {
    padding-top: 50px !important;
    padding-bottom: 50px !important;
  }
  .md\:px-50 {
    padding-left: 50px !important;
    padding-right: 50px !important;
  }
  .md\:pt-50 {
    padding-top: 50px !important;
  }
  .md\:pb-50 {
    padding-bottom: 50px !important;
  }
  .md\:pl-50 {
    padding-left: 50px !important;
  }
  .md\:pr-50 {
    padding-right: 50px !important;
  }
  .md\:mt-50 {
    margin-top: 50px !important;
  }
  .md\:mb-50 {
    margin-bottom: 50px !important;
  }
  .md\:ml-50 {
    margin-left: 50px !important;
  }
  .md\:mr-50 {
    margin-right: 50px !important;
  }
  .md\:py-55 {
    padding-top: 55px !important;
    padding-bottom: 55px !important;
  }
  .md\:px-55 {
    padding-left: 55px !important;
    padding-right: 55px !important;
  }
  .md\:pt-55 {
    padding-top: 55px !important;
  }
  .md\:pb-55 {
    padding-bottom: 55px !important;
  }
  .md\:pl-55 {
    padding-left: 55px !important;
  }
  .md\:pr-55 {
    padding-right: 55px !important;
  }
  .md\:mt-55 {
    margin-top: 55px !important;
  }
  .md\:mb-55 {
    margin-bottom: 55px !important;
  }
  .md\:ml-55 {
    margin-left: 55px !important;
  }
  .md\:mr-55 {
    margin-right: 55px !important;
  }
  .md\:py-60 {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }
  .md\:px-60 {
    padding-left: 60px !important;
    padding-right: 60px !important;
  }
  .md\:pt-60 {
    padding-top: 60px !important;
  }
  .md\:pb-60 {
    padding-bottom: 60px !important;
  }
  .md\:pl-60 {
    padding-left: 60px !important;
  }
  .md\:pr-60 {
    padding-right: 60px !important;
  }
  .md\:mt-60 {
    margin-top: 60px !important;
  }
  .md\:mb-60 {
    margin-bottom: 60px !important;
  }
  .md\:ml-60 {
    margin-left: 60px !important;
  }
  .md\:mr-60 {
    margin-right: 60px !important;
  }
  .md\:py-100 {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }
  .md\:px-100 {
    padding-left: 100px !important;
    padding-right: 100px !important;
  }
  .md\:pt-100 {
    padding-top: 100px !important;
  }
  .md\:pb-100 {
    padding-bottom: 100px !important;
  }
  .md\:pl-100 {
    padding-left: 100px !important;
  }
  .md\:pr-100 {
    padding-right: 100px !important;
  }
  .md\:mt-100 {
    margin-top: 100px !important;
  }
  .md\:mb-100 {
    margin-bottom: 100px !important;
  }
  .md\:ml-100 {
    margin-left: 100px !important;
  }
  .md\:mr-100 {
    margin-right: 100px !important;
  }
}

@media (max-width: 575px) {
  .sm\:py-0 {
    padding-top: 0px !important;
    padding-bottom: 0px !important;
  }
  .sm\:px-0 {
    padding-left: 0px !important;
    padding-right: 0px !important;
  }
  .sm\:pt-0 {
    padding-top: 0px !important;
  }
  .sm\:pb-0 {
    padding-bottom: 0px !important;
  }
  .sm\:pl-0 {
    padding-left: 0px !important;
  }
  .sm\:pr-0 {
    padding-right: 0px !important;
  }
  .sm\:mt-0 {
    margin-top: 0px !important;
  }
  .sm\:mb-0 {
    margin-bottom: 0px !important;
  }
  .sm\:ml-0 {
    margin-left: 0px !important;
  }
  .sm\:mr-0 {
    margin-right: 0px !important;
  }
  .sm\:py-5 {
    padding-top: 5px !important;
    padding-bottom: 5px !important;
  }
  .sm\:px-5 {
    padding-left: 5px !important;
    padding-right: 5px !important;
  }
  .sm\:pt-5 {
    padding-top: 5px !important;
  }
  .sm\:pb-5 {
    padding-bottom: 5px !important;
  }
  .sm\:pl-5 {
    padding-left: 5px !important;
  }
  .sm\:pr-5 {
    padding-right: 5px !important;
  }
  .sm\:mt-5 {
    margin-top: 5px !important;
  }
  .sm\:mb-5 {
    margin-bottom: 5px !important;
  }
  .sm\:ml-5 {
    margin-left: 5px !important;
  }
  .sm\:mr-5 {
    margin-right: 5px !important;
  }
  .sm\:py-10 {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }
  .sm\:px-10 {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
  .sm\:pt-10 {
    padding-top: 10px !important;
  }
  .sm\:pb-10 {
    padding-bottom: 10px !important;
  }
  .sm\:pl-10 {
    padding-left: 10px !important;
  }
  .sm\:pr-10 {
    padding-right: 10px !important;
  }
  .sm\:mt-10 {
    margin-top: 10px !important;
  }
  .sm\:mb-10 {
    margin-bottom: 10px !important;
  }
  .sm\:ml-10 {
    margin-left: 10px !important;
  }
  .sm\:mr-10 {
    margin-right: 10px !important;
  }
  .sm\:py-15 {
    padding-top: 15px !important;
    padding-bottom: 15px !important;
  }
  .sm\:px-15 {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
  .sm\:pt-15 {
    padding-top: 15px !important;
  }
  .sm\:pb-15 {
    padding-bottom: 15px !important;
  }
  .sm\:pl-15 {
    padding-left: 15px !important;
  }
  .sm\:pr-15 {
    padding-right: 15px !important;
  }
  .sm\:mt-15 {
    margin-top: 15px !important;
  }
  .sm\:mb-15 {
    margin-bottom: 15px !important;
  }
  .sm\:ml-15 {
    margin-left: 15px !important;
  }
  .sm\:mr-15 {
    margin-right: 15px !important;
  }
  .sm\:py-20 {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
  }
  .sm\:px-20 {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
  .sm\:pt-20 {
    padding-top: 20px !important;
  }
  .sm\:pb-20 {
    padding-bottom: 20px !important;
  }
  .sm\:pl-20 {
    padding-left: 20px !important;
  }
  .sm\:pr-20 {
    padding-right: 20px !important;
  }
  .sm\:mt-20 {
    margin-top: 20px !important;
  }
  .sm\:mb-20 {
    margin-bottom: 20px !important;
  }
  .sm\:ml-20 {
    margin-left: 20px !important;
  }
  .sm\:mr-20 {
    margin-right: 20px !important;
  }
  .sm\:py-25 {
    padding-top: 25px !important;
    padding-bottom: 25px !important;
  }
  .sm\:px-25 {
    padding-left: 25px !important;
    padding-right: 25px !important;
  }
  .sm\:pt-25 {
    padding-top: 25px !important;
  }
  .sm\:pb-25 {
    padding-bottom: 25px !important;
  }
  .sm\:pl-25 {
    padding-left: 25px !important;
  }
  .sm\:pr-25 {
    padding-right: 25px !important;
  }
  .sm\:mt-25 {
    margin-top: 25px !important;
  }
  .sm\:mb-25 {
    margin-bottom: 25px !important;
  }
  .sm\:ml-25 {
    margin-left: 25px !important;
  }
  .sm\:mr-25 {
    margin-right: 25px !important;
  }
  .sm\:py-30 {
    padding-top: 30px !important;
    padding-bottom: 30px !important;
  }
  .sm\:px-30 {
    padding-left: 30px !important;
    padding-right: 30px !important;
  }
  .sm\:pt-30 {
    padding-top: 30px !important;
  }
  .sm\:pb-30 {
    padding-bottom: 30px !important;
  }
  .sm\:pl-30 {
    padding-left: 30px !important;
  }
  .sm\:pr-30 {
    padding-right: 30px !important;
  }
  .sm\:mt-30 {
    margin-top: 30px !important;
  }
  .sm\:mb-30 {
    margin-bottom: 30px !important;
  }
  .sm\:ml-30 {
    margin-left: 30px !important;
  }
  .sm\:mr-30 {
    margin-right: 30px !important;
  }
  .sm\:py-35 {
    padding-top: 35px !important;
    padding-bottom: 35px !important;
  }
  .sm\:px-35 {
    padding-left: 35px !important;
    padding-right: 35px !important;
  }
  .sm\:pt-35 {
    padding-top: 35px !important;
  }
  .sm\:pb-35 {
    padding-bottom: 35px !important;
  }
  .sm\:pl-35 {
    padding-left: 35px !important;
  }
  .sm\:pr-35 {
    padding-right: 35px !important;
  }
  .sm\:mt-35 {
    margin-top: 35px !important;
  }
  .sm\:mb-35 {
    margin-bottom: 35px !important;
  }
  .sm\:ml-35 {
    margin-left: 35px !important;
  }
  .sm\:mr-35 {
    margin-right: 35px !important;
  }
  .sm\:py-40 {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }
  .sm\:px-40 {
    padding-left: 40px !important;
    padding-right: 40px !important;
  }
  .sm\:pt-40 {
    padding-top: 40px !important;
  }
  .sm\:pb-40 {
    padding-bottom: 40px !important;
  }
  .sm\:pl-40 {
    padding-left: 40px !important;
  }
  .sm\:pr-40 {
    padding-right: 40px !important;
  }
  .sm\:mt-40 {
    margin-top: 40px !important;
  }
  .sm\:mb-40 {
    margin-bottom: 40px !important;
  }
  .sm\:ml-40 {
    margin-left: 40px !important;
  }
  .sm\:mr-40 {
    margin-right: 40px !important;
  }
  .sm\:py-50 {
    padding-top: 50px !important;
    padding-bottom: 50px !important;
  }
  .sm\:px-50 {
    padding-left: 50px !important;
    padding-right: 50px !important;
  }
  .sm\:pt-50 {
    padding-top: 50px !important;
  }
  .sm\:pb-50 {
    padding-bottom: 50px !important;
  }
  .sm\:pl-50 {
    padding-left: 50px !important;
  }
  .sm\:pr-50 {
    padding-right: 50px !important;
  }
  .sm\:mt-50 {
    margin-top: 50px !important;
  }
  .sm\:mb-50 {
    margin-bottom: 50px !important;
  }
  .sm\:ml-50 {
    margin-left: 50px !important;
  }
  .sm\:mr-50 {
    margin-right: 50px !important;
  }
  .sm\:py-55 {
    padding-top: 55px !important;
    padding-bottom: 55px !important;
  }
  .sm\:px-55 {
    padding-left: 55px !important;
    padding-right: 55px !important;
  }
  .sm\:pt-55 {
    padding-top: 55px !important;
  }
  .sm\:pb-55 {
    padding-bottom: 55px !important;
  }
  .sm\:pl-55 {
    padding-left: 55px !important;
  }
  .sm\:pr-55 {
    padding-right: 55px !important;
  }
  .sm\:mt-55 {
    margin-top: 55px !important;
  }
  .sm\:mb-55 {
    margin-bottom: 55px !important;
  }
  .sm\:ml-55 {
    margin-left: 55px !important;
  }
  .sm\:mr-55 {
    margin-right: 55px !important;
  }
  .sm\:py-60 {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }
  .sm\:px-60 {
    padding-left: 60px !important;
    padding-right: 60px !important;
  }
  .sm\:pt-60 {
    padding-top: 60px !important;
  }
  .sm\:pb-60 {
    padding-bottom: 60px !important;
  }
  .sm\:pl-60 {
    padding-left: 60px !important;
  }
  .sm\:pr-60 {
    padding-right: 60px !important;
  }
  .sm\:mt-60 {
    margin-top: 60px !important;
  }
  .sm\:mb-60 {
    margin-bottom: 60px !important;
  }
  .sm\:ml-60 {
    margin-left: 60px !important;
  }
  .sm\:mr-60 {
    margin-right: 60px !important;
  }
  .sm\:py-100 {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }
  .sm\:px-100 {
    padding-left: 100px !important;
    padding-right: 100px !important;
  }
  .sm\:pt-100 {
    padding-top: 100px !important;
  }
  .sm\:pb-100 {
    padding-bottom: 100px !important;
  }
  .sm\:pl-100 {
    padding-left: 100px !important;
  }
  .sm\:pr-100 {
    padding-right: 100px !important;
  }
  .sm\:mt-100 {
    margin-top: 100px !important;
  }
  .sm\:mb-100 {
    margin-bottom: 100px !important;
  }
  .sm\:ml-100 {
    margin-left: 100px !important;
  }
  .sm\:mr-100 {
    margin-right: 100px !important;
  }
}

.mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.xl\:mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.lg\:mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.md\:mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.sm\:mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.x-gap-0 {
  margin-left: -0px;
  margin-right: -0px;
}

.x-gap-0 > * {
  padding-left: 0px;
  padding-right: 0px;
}

.y-gap-0 {
  margin-top: -0px;
  margin-bottom: -0px;
}

.y-gap-0 > * {
  padding-top: 0px;
  padding-bottom: 0px;
}

.x-gap-5 {
  margin-left: -2.5px;
  margin-right: -2.5px;
}

.x-gap-5 > * {
  padding-left: 2.5px;
  padding-right: 2.5px;
}

.y-gap-5 {
  margin-top: -2.5px;
  margin-bottom: -2.5px;
}

.y-gap-5 > * {
  padding-top: 2.5px;
  padding-bottom: 2.5px;
}

.x-gap-10 {
  margin-left: -5px;
  margin-right: -5px;
}

.x-gap-10 > * {
  padding-left: 5px;
  padding-right: 5px;
}

.y-gap-10 {
  margin-top: -5px;
  margin-bottom: -5px;
}

.y-gap-10 > * {
  padding-top: 5px;
  padding-bottom: 5px;
}

.x-gap-15 {
  margin-left: -7.5px;
  margin-right: -7.5px;
}

.x-gap-15 > * {
  padding-left: 7.5px;
  padding-right: 7.5px;
}

.y-gap-15 {
  margin-top: -7.5px;
  margin-bottom: -7.5px;
}

.y-gap-15 > * {
  padding-top: 7.5px;
  padding-bottom: 7.5px;
}

.x-gap-20 {
  margin-left: -10px;
  margin-right: -10px;
}

.x-gap-20 > * {
  padding-left: 10px;
  padding-right: 10px;
}

.y-gap-20 {
  margin-top: -10px;
  margin-bottom: -10px;
}

.y-gap-20 > * {
  padding-top: 10px;
  padding-bottom: 10px;
}

.x-gap-30 {
  margin-left: -15px;
  margin-right: -15px;
}

.x-gap-30 > * {
  padding-left: 15px;
  padding-right: 15px;
}

.y-gap-30 {
  margin-top: -15px;
  margin-bottom: -15px;
}

.y-gap-30 > * {
  padding-top: 15px;
  padding-bottom: 15px;
}

.x-gap-60 {
  margin-left: -30px;
  margin-right: -30px;
}

.x-gap-60 > * {
  padding-left: 30px;
  padding-right: 30px;
}

.y-gap-60 {
  margin-top: -30px;
  margin-bottom: -30px;
}

.y-gap-60 > * {
  padding-top: 30px;
  padding-bottom: 30px;
}

@media (max-width: 767px) {
  .md\:x-gap-0 {
    margin-left: -0px;
    margin-right: -0px;
  }
  .md\:x-gap-0 > * {
    padding-left: 0px;
    padding-right: 0px;
  }
  .md\:y-gap-0 {
    margin-top: -0px;
    margin-bottom: -0px;
  }
  .md\:y-gap-0 > * {
    padding-top: 0px;
    padding-bottom: 0px;
  }
  .md\:x-gap-5 {
    margin-left: -2.5px;
    margin-right: -2.5px;
  }
  .md\:x-gap-5 > * {
    padding-left: 2.5px;
    padding-right: 2.5px;
  }
  .md\:y-gap-5 {
    margin-top: -2.5px;
    margin-bottom: -2.5px;
  }
  .md\:y-gap-5 > * {
    padding-top: 2.5px;
    padding-bottom: 2.5px;
  }
  .md\:x-gap-10 {
    margin-left: -5px;
    margin-right: -5px;
  }
  .md\:x-gap-10 > * {
    padding-left: 5px;
    padding-right: 5px;
  }
  .md\:y-gap-10 {
    margin-top: -5px;
    margin-bottom: -5px;
  }
  .md\:y-gap-10 > * {
    padding-top: 5px;
    padding-bottom: 5px;
  }
  .md\:x-gap-15 {
    margin-left: -7.5px;
    margin-right: -7.5px;
  }
  .md\:x-gap-15 > * {
    padding-left: 7.5px;
    padding-right: 7.5px;
  }
  .md\:y-gap-15 {
    margin-top: -7.5px;
    margin-bottom: -7.5px;
  }
  .md\:y-gap-15 > * {
    padding-top: 7.5px;
    padding-bottom: 7.5px;
  }
  .md\:x-gap-20 {
    margin-left: -10px;
    margin-right: -10px;
  }
  .md\:x-gap-20 > * {
    padding-left: 10px;
    padding-right: 10px;
  }
  .md\:y-gap-20 {
    margin-top: -10px;
    margin-bottom: -10px;
  }
  .md\:y-gap-20 > * {
    padding-top: 10px;
    padding-bottom: 10px;
  }
  .md\:x-gap-30 {
    margin-left: -15px;
    margin-right: -15px;
  }
  .md\:x-gap-30 > * {
    padding-left: 15px;
    padding-right: 15px;
  }
  .md\:y-gap-30 {
    margin-top: -15px;
    margin-bottom: -15px;
  }
  .md\:y-gap-30 > * {
    padding-top: 15px;
    padding-bottom: 15px;
  }
  .md\:x-gap-60 {
    margin-left: -30px;
    margin-right: -30px;
  }
  .md\:x-gap-60 > * {
    padding-left: 30px;
    padding-right: 30px;
  }
  .md\:y-gap-60 {
    margin-top: -30px;
    margin-bottom: -30px;
  }
  .md\:y-gap-60 > * {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}

@media (max-width: 767px) {
  .sm\:x-gap-0 {
    margin-left: -0px;
    margin-right: -0px;
  }
  .sm\:x-gap-0 > * {
    padding-left: 0px;
    padding-right: 0px;
  }
  .sm\:y-gap-0 {
    margin-top: -0px;
    margin-bottom: -0px;
  }
  .sm\:y-gap-0 > * {
    padding-top: 0px;
    padding-bottom: 0px;
  }
  .sm\:x-gap-5 {
    margin-left: -2.5px;
    margin-right: -2.5px;
  }
  .sm\:x-gap-5 > * {
    padding-left: 2.5px;
    padding-right: 2.5px;
  }
  .sm\:y-gap-5 {
    margin-top: -2.5px;
    margin-bottom: -2.5px;
  }
  .sm\:y-gap-5 > * {
    padding-top: 2.5px;
    padding-bottom: 2.5px;
  }
  .sm\:x-gap-10 {
    margin-left: -5px;
    margin-right: -5px;
  }
  .sm\:x-gap-10 > * {
    padding-left: 5px;
    padding-right: 5px;
  }
  .sm\:y-gap-10 {
    margin-top: -5px;
    margin-bottom: -5px;
  }
  .sm\:y-gap-10 > * {
    padding-top: 5px;
    padding-bottom: 5px;
  }
  .sm\:x-gap-15 {
    margin-left: -7.5px;
    margin-right: -7.5px;
  }
  .sm\:x-gap-15 > * {
    padding-left: 7.5px;
    padding-right: 7.5px;
  }
  .sm\:y-gap-15 {
    margin-top: -7.5px;
    margin-bottom: -7.5px;
  }
  .sm\:y-gap-15 > * {
    padding-top: 7.5px;
    padding-bottom: 7.5px;
  }
  .sm\:x-gap-20 {
    margin-left: -10px;
    margin-right: -10px;
  }
  .sm\:x-gap-20 > * {
    padding-left: 10px;
    padding-right: 10px;
  }
  .sm\:y-gap-20 {
    margin-top: -10px;
    margin-bottom: -10px;
  }
  .sm\:y-gap-20 > * {
    padding-top: 10px;
    padding-bottom: 10px;
  }
  .sm\:x-gap-30 {
    margin-left: -15px;
    margin-right: -15px;
  }
  .sm\:x-gap-30 > * {
    padding-left: 15px;
    padding-right: 15px;
  }
  .sm\:y-gap-30 {
    margin-top: -15px;
    margin-bottom: -15px;
  }
  .sm\:y-gap-30 > * {
    padding-top: 15px;
    padding-bottom: 15px;
  }
  .sm\:x-gap-60 {
    margin-left: -30px;
    margin-right: -30px;
  }
  .sm\:x-gap-60 > * {
    padding-left: 30px;
    padding-right: 30px;
  }
  .sm\:y-gap-60 {
    margin-top: -30px;
    margin-bottom: -30px;
  }
  .sm\:y-gap-60 > * {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}

.layout-pt-sm {
  padding-top: 30px;
}

.layout-pb-sm {
  padding-bottom: 30px;
}

.layout-pt-md {
  padding-top: 60px;
}

.layout-pb-md {
  padding-bottom: 60px;
}

.layout-pt-lg {
  padding-top: 120px;
}

.layout-pb-lg {
  padding-bottom: 120px;
}

.layout-pt-xl {
  padding-top: 140px;
}

.layout-pb-xl {
  padding-bottom: 140px;
}

@media (max-width: 767px) {
  .layout-pt-sm {
    padding-top: 30px;
  }
  .layout-pb-sm {
    padding-bottom: 30px;
  }
}

@media (max-width: 767px) {
  .layout-pt-md {
    padding-top: 60px;
  }
  .layout-pb-md {
    padding-bottom: 60px;
  }
}

@media (max-width: 767px) {
  .layout-pt-lg {
    padding-top: 100px;
  }
  .layout-pb-lg {
    padding-bottom: 100px;
  }
}

@media (max-width: 767px) {
  .layout-pt-xl {
    padding-top: 120px;
  }
  .layout-pb-xl {
    padding-bottom: 120px;
  }
}

@media (max-width: 575px) {
  .layout-pt-sm {
    padding-top: 30px;
  }
  .layout-pb-sm {
    padding-bottom: 30px;
  }
}

@media (max-width: 575px) {
  .layout-pt-md {
    padding-top: 30px;
  }
  .layout-pb-md {
    padding-bottom: 30px;
  }
}

@media (max-width: 575px) {
  .layout-pt-lg {
    padding-top: 30px;
  }
  .layout-pb-lg {
    padding-bottom: 30px;
  }
}

@media (max-width: 575px) {
  .layout-pt-xl {
    padding-top: 50px;
  }
  .layout-pb-xl {
    padding-bottom: 50px;
  }
}

.w-1\/7 {
  width: 14.285714% !important;
}

.w-1\/5 {
  width: 20% !important;
}

.w-1\/4 {
  width: 25% !important;
}

.w-1\/3 {
  width: 33.333333% !important;
}

.w-1\/2 {
  width: 50% !important;
}

.w-1\/1 {
  width: 100% !important;
}

@media (max-width: 1199px) {
  .xl\:w-1\/5 {
    width: 20% !important;
  }
  .xl\:w-1\/4 {
    width: 25% !important;
  }
  .xl\:w-1\/3 {
    width: 33.333333% !important;
  }
  .xl\:w-1\/2 {
    width: 50% !important;
  }
  .xl\:w-1\/1 {
    width: 100% !important;
  }
}

@media (max-width: 991px) {
  .lg\:w-1\/5 {
    width: 20% !important;
  }
  .lg\:w-1\/4 {
    width: 25% !important;
  }
  .lg\:w-1\/3 {
    width: 33.333333% !important;
  }
  .lg\:w-1\/2 {
    width: 50% !important;
  }
  .lg\:w-1\/1 {
    width: 100% !important;
  }
}

@media (max-width: 767px) {
  .md\:w-1\/5 {
    width: 20% !important;
  }
  .md\:w-1\/4 {
    width: 25% !important;
  }
  .md\:w-1\/3 {
    width: 33.333333% !important;
  }
  .md\:w-1\/2 {
    width: 50% !important;
  }
  .md\:w-1\/1 {
    width: 100% !important;
  }
}

@media (max-width: 575px) {
  .sm\:w-1\/5 {
    width: 20% !important;
  }
  .sm\:w-1\/4 {
    width: 25% !important;
  }
  .sm\:w-1\/3 {
    width: 33.333333% !important;
  }
  .sm\:w-1\/2 {
    width: 50% !important;
  }
  .sm\:w-1\/1 {
    width: 100% !important;
  }
}

.flex-column {
  flex-direction: column;
}

@media (max-width: 1199px) {
  .xl\:flex-column {
    flex-direction: column !important;
  }
}

@media (max-width: 991px) {
  .lg\:flex-column {
    flex-direction: column !important;
  }
}

@media (max-width: 767px) {
  .md\:flex-column {
    flex-direction: column !important;
  }
}

@media (max-width: 575px) {
  .sm\:flex-column {
    flex-direction: column !important;
  }
}

.justify-start {
  justify-content: flex-start !important;
}

.justify-end {
  justify-content: flex-end !important;
}

.justify-center {
  justify-content: center !important;
}

.justify-between {
  justify-content: space-between !important;
}

.items-start {
  align-items: flex-start !important;
}

.items-end {
  align-items: flex-end !important;
}

.items-center {
  align-items: center !important;
}

@media (max-width: 1199px) {
  .xl\:justify-start {
    justify-content: flex-start !important;
  }
  .xl\:justify-end {
    justify-content: flex-end !important;
  }
  .xl\:justify-center {
    justify-content: center !important;
  }
  .xl\:justify-between {
    justify-content: space-between !important;
  }
  .xl\:items-start {
    align-items: flex-start !important;
  }
  .xl\:items-end {
    align-items: flex-end !important;
  }
  .xl\:items-center {
    align-items: center !important;
  }
}

@media (max-width: 991px) {
  .lg\:justify-start {
    justify-content: flex-start !important;
  }
  .lg\:justify-end {
    justify-content: flex-end !important;
  }
  .lg\:justify-center {
    justify-content: center !important;
  }
  .lg\:justify-between {
    justify-content: space-between !important;
  }
  .lg\:items-start {
    align-items: flex-start !important;
  }
  .lg\:items-end {
    align-items: flex-end !important;
  }
  .lg\:items-center {
    align-items: center !important;
  }
}

@media (max-width: 767px) {
  .md\:justify-start {
    justify-content: flex-start !important;
  }
  .md\:justify-end {
    justify-content: flex-end !important;
  }
  .md\:justify-center {
    justify-content: center !important;
  }
  .md\:justify-between {
    justify-content: space-between !important;
  }
  .md\:items-start {
    align-items: flex-start !important;
  }
  .md\:items-end {
    align-items: flex-end !important;
  }
  .md\:items-center {
    align-items: center !important;
  }
}

@media (max-width: 575px) {
  .sm\:justify-start {
    justify-content: flex-start !important;
  }
  .sm\:justify-end {
    justify-content: flex-end !important;
  }
  .sm\:justify-center {
    justify-content: center !important;
  }
  .sm\:justify-between {
    justify-content: space-between !important;
  }
  .sm\:items-start {
    align-items: flex-start !important;
  }
  .sm\:items-end {
    align-items: flex-end !important;
  }
  .sm\:items-center {
    align-items: center !important;
  }
}

.order-1 {
  order: 1;
}

.order-2 {
  order: 2;
}

.order-3 {
  order: 3;
}

@media (max-width: 1199px) {
  .xl\:order-1 {
    order: 1;
  }
  .xl\:order-2 {
    order: 2;
  }
  .xl\:order-3 {
    order: 3;
  }
}

@media (max-width: 991px) {
  .lg\:order-1 {
    order: 1;
  }
  .lg\:order-2 {
    order: 2;
  }
  .lg\:order-3 {
    order: 3;
  }
}

@media (max-width: 767px) {
  .md\:order-1 {
    order: 1;
  }
  .md\:order-2 {
    order: 2;
  }
  .md\:order-3 {
    order: 3;
  }
}

@media (max-width: 575px) {
  .sm\:order-1 {
    order: 1;
  }
  .sm\:order-2 {
    order: 2;
  }
  .sm\:order-3 {
    order: 3;
  }
}

.bg-white {
  background-color: var(--color-white) !important;
}

.bg-black {
  background-color: var(--color-black) !important;
}

.bg-border {
  background-color: var(--color-border) !important;
}

.bg-accent-1 {
  background-color: var(--color-accent-1) !important;
}

.bg-accent-2 {
  background-color: var(--color-accent-2) !important;
}

.bg-dark-1 {
  background-color: var(--color-dark-1) !important;
}

.bg-dark-2 {
  background-color: var(--color-dark-2) !important;
}

.bg-dark-3 {
  background-color: var(--color-dark-3) !important;
}

.bg-dark-4 {
  background-color: var(--color-dark-4) !important;
}

.bg-dark-5 {
  background-color: var(--color-dark-5) !important;
}

.bg-white-10 {
  background-color: rgba(255, 255, 255, 0.1);
}

.text-white {
  color: var(--color-white);
}

.text-black {
  color: var(--color-black);
}

.text-border {
  color: var(--color-border);
}

.text-accent-1 {
  color: var(--color-accent-1);
}

.text-accent-2 {
  color: var(--color-accent-2);
}

.text-dark-1 {
  color: var(--color-dark-1);
}

.text-dark-2 {
  color: var(--color-dark-2);
}

.text-dark-3 {
  color: var(--color-dark-3);
}

.text-dark-4 {
  color: var(--color-dark-4);
}

.text-dark-5 {
  color: var(--color-dark-5);
}

.text-white-50 {
  color: rgba(255, 255, 255, 0.5);
}

.d-none {
  display: none !important;
}

.d-flex {
  display: flex !important;
}

.d-block {
  display: block !important;
}

.d-inline-block {
  display: inline-block !important;
}

@media (max-width: 1199px) {
  .xl\:d-none {
    display: none !important;
  }
  .xl\:d-inline-block {
    display: inline-block !important;
  }
  .xl\:d-block {
    display: block !important;
  }
  .xl\:d-flex {
    display: flex !important;
  }
}

@media (max-width: 991px) {
  .lg\:d-none {
    display: none !important;
  }
  .lg\:d-inline-block {
    display: inline-block !important;
  }
  .lg\:d-block {
    display: block !important;
  }
  .lg\:d-flex {
    display: flex !important;
  }
}

@media (max-width: 767px) {
  .md\:d-none {
    display: none !important;
  }
  .md\:d-inline-block {
    display: inline-block !important;
  }
  .md\:d-block {
    display: block !important;
  }
  .md\:d-flex {
    display: flex !important;
  }
}

@media (max-width: 575px) {
  .sm\:d-none {
    display: none !important;
  }
  .sm\:d-inline-block {
    display: inline-block !important;
  }
  .sm\:d-block {
    display: block !important;
  }
  .sm\:d-flex {
    display: flex !important;
  }
}

.html-overflow-hidden {
  overflow: hidden !important;
}

.html-overflow-hidden body {
  overflow-y: scroll;
}

.origin-top {
  transform-origin: top !important;
}

.origin-left {
  transform-origin: left !important;
}

.overflow-scroll {
  overflow: scroll !important;
}

.overflow-hidden {
  overflow: hidden !important;
}

.overflow-normal {
  overflow: initial !important;
}

.overflow-visible {
  overflow: visible !important;
}

.pointer-events-auto {
  pointer-events: auto !important;
}

.pointer-events-none {
  pointer-events: none !important;
}

.bg-image {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  width: 100%;
  height: 100%;
}

.img-ratio {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.line-through {
  text-decoration: line-through;
}

.underline {
  text-decoration: underline;
}

.italic {
  font-style: italic;
}

.uppercase {
  text-transform: uppercase;
}

.capitalize {
  text-transform: capitalize;
}

.normal {
  text-transform: none;
}

.rounded-0 {
  border-radius: 0;
}

.rounded-4 {
  border-radius: 4px;
}

.rounded-12 {
  border-radius: 12px;
}

.rounded-full {
  border-radius: 100%;
}

.border-dark-1 {
  border: 1px solid var(--color-dark-1);
}

.border-accent-1 {
  border: 1px solid var(--color-accent-1);
}

.border-top-dark-5 {
  border-top: 1px solid var(--color-dark-5);
}

.border-white {
  border: 1px solid var(--color-white);
}

.border-bottom-accent-2 {
  border-bottom: 1px solid var(--color-accent-2);
}

.size-18 {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
}

.size-40 {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
}

.size-50 {
  flex-shrink: 0;
  width: 50px;
  height: 50px;
}

.size-80 {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
}

.size-100 {
  flex-shrink: 0;
  width: 100px;
  height: 100px;
}

.size-120 {
  flex-shrink: 0;
  width: 120px;
  height: 120px;
}

.shadow-1 {
  box-shadow: 0px 20px 40px 0px #05103612;
}

.shadow-2 {
  box-shadow: 0px 10px 35px 0px #0510361A;
}

.shadow-3 {
  box-shadow: 0px 10px 30px 0px #05103608;
}

.shadow-4 {
  box-shadow: 0px 10px 60px 0px #0510360D;
}

.flex-center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.flex-wrap {
  flex-wrap: wrap;
}

.h-full {
  height: 100% !important;
}

.relative {
  position: relative;
}

.absolute {
  position: absolute;
}

.z--1 {
  z-index: -1 !important;
}

.z-0 {
  z-index: 0 !important;
}

.z-1 {
  z-index: 1 !important;
}

.z-2 {
  z-index: 2 !important;
}

.z-3 {
  z-index: 3 !important;
}

.z-4 {
  z-index: 4 !important;
}

.z-5 {
  z-index: 5 !important;
}

.sectionBg {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 0;
}

.sectionBg.-left {
  right: unset;
}

@media (max-width: 991px) {
  .sectionBg.-left {
    position: relative;
    width: 100% !important;
    height: 100%;
  }
}

.sectionBg.-left img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.sectionBg.-mx-60 {
  margin: 0 60px;
}

@media (max-width: 1600px) {
  .sectionBg.-mx-60 {
    margin: 0;
  }
}

@media (max-width: 1199px) {
  .sectionBg.-mx-60 {
    margin: 0;
  }
}

.sectionBg.-overlay-1::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 0;
  background-color: rgba(0, 0, 0, 0.5);
}

.table.-type-1 {
  overflow-x: scroll;
  width: 100%;
}

.table.-type-1::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}

.table.-type-1::-webkit-scrollbar-thumb {
  background-color: #F7F0EC;
  border-radius: 100px;
}

.table.-type-1 table {
  width: 100%;
}

.table.-type-1 table thead {
  color: white;
  background-color: var(--color-accent-1);
}

.table.-type-1 table thead tr {
  border: none;
}

.table.-type-1 table tr {
  border-bottom: 1px solid #F7F0EC;
}

.table.-type-1 table td {
  font-weight: 500;
  padding: 25px 60px;
}

@media (max-width: 1199px) {
  .table.-type-1 table td {
    padding: 20px 40px;
  }
}

.table.-type-2 {
  overflow-x: scroll;
  width: 100%;
}

.table.-type-2::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}

.table.-type-2::-webkit-scrollbar-thumb {
  background-color: #F7F0EC;
  border-radius: 100px;
}

.table.-type-2 table {
  width: 100%;
}

.table.-type-2 table thead {
  color: white;
  background-color: var(--color-accent-1);
}

.table.-type-2 table thead tr {
  border: none;
}

.table.-type-2 table tr {
  border-bottom: 1px solid #F7F0EC;
}

.table.-type-2 table td {
  font-weight: 500;
  padding: 18px 25px;
}

.searchInput input {
  padding: 15px 20px;
  border: 1px solid #F7F0EC;
}

.searchInput input::-moz-placeholder {
  font-size: 16px;
  font-weight: 500;
  line-height: 30px;
  text-transform: uppercase;
  color: black;
}

.searchInput input::placeholder {
  font-size: 16px;
  font-weight: 500;
  line-height: 30px;
  text-transform: uppercase;
  color: black;
}

.imageSlider.-type-1 {
  overflow: hidden;
  position: relative;
  margin: 0 20px;
  height: 960px;
  color: white;
  z-index: 0;
}

@media (max-width: 1199px) {
  .imageSlider.-type-1 {
    height: 800px;
  }
}

@media (max-width: 991px) {
  .imageSlider.-type-1 {
    height: 600px;
  }
}

@media (max-width: 767px) {
  .imageSlider.-type-1 {
    height: 500px;
  }
}

@media (max-width: 575px) {
  .imageSlider.-type-1 {
    height: 480px;
  }
}

.imageSlider.-type-1 .imageSlider__slider {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  height: 100%;
  border-radius: 12px;
  z-index: -1;
}

.imageSlider.-type-1 .imageSlider__image {
  position: relative;
  height: 100%;
}

.imageSlider.-type-1 .imageSlider__image::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, rgba(25, 29, 35, 0) 23.13%, rgba(25, 29, 35, 0.7) 100%);
}

.imageSlider.-type-1 .imageSlider__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.imageSlider.-type-1 .imageSlider__title {
  position: absolute;
  bottom: 50px;
  left: 50%;
  transform: translateX(-50%);
  font-weight: 400;
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.imageSlider.-type-1 .imageSlider__content {
  padding-top: 120px;
}

@media (max-width: 767px) {
  .imageSlider.-type-1 .imageSlider__content {
    padding-top: 60px;
  }
}

.imageSlider.-type-1 .imageSlider__nav {
  display: flex;
}

.imageSlider.-type-1.-center .imageSlider__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
  z-index: 5;
}

.imageSlider.-type-1.-center .imageSlider__nav > * {
  display: flex;
  justify-content: space-between;
}

.testimonialsSection {
  position: relative;
  height: 960px;
  z-index: 0;
}

@media (max-width: 1199px) {
  .testimonialsSection {
    height: 720px;
  }
}

@media (max-width: 991px) {
  .testimonialsSection {
    height: 640px;
  }
}

@media (max-width: 767px) {
  .testimonialsSection {
    height: auto;
  }
}

.testimonialsSection .container {
  height: 100%;
}

.testimonialsSection .row {
  height: 100%;
}

.testimonialsSection__bg {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.testimonialsSection__bg > *:nth-child(2) {
  width: 50%;
  height: 100%;
}

@media (max-width: 1199px) {
  .testimonialsSection__bg > *:nth-child(2) {
    width: 60%;
  }
}

@media (max-width: 991px) {
  .testimonialsSection__bg > *:nth-child(2) {
    width: 65%;
  }
}

@media (max-width: 767px) {
  .testimonialsSection__bg > *:nth-child(2) {
    width: 100%;
  }
}

.testimonialsSection__images {
  position: relative;
  display: flex;
  width: 50%;
  height: 100%;
  z-index: -1;
  transition: .5s;
}

@media (max-width: 1199px) {
  .testimonialsSection__images {
    width: 40%;
  }
}

@media (max-width: 991px) {
  .testimonialsSection__images {
    width: 35%;
  }
}

@media (max-width: 767px) {
  .testimonialsSection__images {
    display: none;
  }
}

.testimonialsSection__images img {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.testimonialsSection__content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
}

.mapSection {
  position: relative;
}

.mapSection img {
  width: 100%;
  height: 100%;
  height: auto;
}

.mapSection__markers > *:nth-child(1) {
  top: 31.94%;
  left: 28.04%;
}

.mapSection__markers > *:nth-child(2) {
  top: 25.72%;
  left: 43.77%;
}

.mapSection__markers > *:nth-child(3) {
  top: 76.14%;
  left: 32.05%;
}

.mapSection__markers > *:nth-child(4) {
  top: 61.12%;
  left: 67.44%;
}

.mapSection .mapSectionMarker {
  position: absolute;
  color: white;
  display: flex;
  justify-content: center;
  text-align: center;
  z-index: 10;
  transform: translateX(-20px) translateY(-20px);
}

.mapSection .mapSectionMarker__dot {
  cursor: pointer;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 100%;
  width: 40px;
  height: 40px;
  background-color: rgba(194, 159, 123, 0.15);
  z-index: 0;
}

.mapSection .mapSectionMarker__dot::before {
  content: "";
  position: absolute;
  width: 20px;
  height: 20px;
  background-color: var(--color-accent-1);
  border-radius: 100%;
  z-index: -1;
}

.mapSection .mapSectionMarker__dot::after {
  content: "";
  position: absolute;
  width: 40px;
  height: 40px;
  box-shadow: 0 0 20px white;
  border-radius: 100%;
  z-index: -2;
  animation: Ani 2s infinite;
}

.mapSection .mapSectionMarker__dot:hover + .mapSectionMarker__hover {
  opacity: 1;
  transform: none;
}

.mapSection .mapSectionMarker__content {
  position: absolute;
  top: calc(100% + 20px);
}

@media (max-width: 767px) {
  .mapSection .mapSectionMarker__content {
    display: none;
  }
}

.mapSection .mapSectionMarker__title {
  font-size: 16px;
  font-weight: 500;
  text-transform: uppercase;
  white-space: nowrap;
}

.mapSection .mapSectionMarker__text {
  text-transform: uppercase;
  font-size: 16px;
  white-space: nowrap;
  margin-top: 4px;
}

.mapSection .mapSectionMarker__hover {
  position: absolute;
  bottom: calc(100% + 12px);
  background-color: var(--color-accent-1);
  border-radius: 100px;
  padding: 6px 20px;
  transition: .2s;
  transform: translateY(8px);
  opacity: 0;
}

.mapSection .mapSectionMarker__hover::after {
  content: "";
  position: absolute;
  top: 98%;
  left: 48%;
  background-color: var(--color-accent-1);
  transform-origin: center;
  transform: rotate(45deg) translateX(-50%);
  width: 8px;
  height: 8px;
}

.mapSection .mapSectionMarker__hover > * {
  font-size: 15px;
  font-weight: 500;
  text-transform: uppercase;
  white-space: nowrap;
}

.mapSection.-half {
  height: 100%;
}

@media (max-width: 991px) {
  .mapSection.-half img {
    height: 400px;
  }
}

@keyframes Ani {
  0% {
    box-shadow: 0 0 0 rgba(255, 255, 255, 0);
    transform: scale(0);
  }
  70% {
    box-shadow: 0 0 50px #fff;
    transform: scale(1);
  }
  100% {
    box-shadow: 0 0 50px rgba(255, 255, 255, 0);
    transform: scale(1.5);
  }
}

.videoSection {
  position: relative;
  height: 860px;
}

.videoSection img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

@media (max-width: 1199px) {
  .videoSection {
    height: 720px;
  }
}

@media (max-width: 991px) {
  .videoSection {
    height: 640px;
  }
}

@media (max-width: 767px) {
  .videoSection {
    height: 400px;
  }
}

.h-auto {
  height: auto !important;
}

.noPageSection {
  position: relative;
  width: 100%;
  height: 100vh;
  z-index: 0;
}

.noPageSection__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.noPageSection__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.noPageSection__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: white;
  text-align: center;
  padding-top: 30px;
}

.noPageSection__num {
  font-size: 160px;
  font-weight: 500;
  line-height: 1.35;
}

@media (max-width: 767px) {
  .noPageSection__num {
    font-size: 90px;
  }
}

.noPageSection__title {
  font-size: 44px;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 1.5px;
}

@media (max-width: 767px) {
  .noPageSection__title {
    font-size: 28px;
  }
}

.noPageSection__text {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.6;
  margin-top: 10px;
}

@media (max-width: 767px) {
  .noPageSection__text {
    font-size: 16px;
  }
}

.noPageSection__button {
  margin-top: 48px;
}

@media (max-width: 767px) {
  .noPageSection__button {
    margin-top: 40px;
  }
}

.noPageSection__button > * {
  max-width: 100%;
  min-width: 280px;
}

.accordion__icon {
  position: relative;
}

.accordion__icon .icon {
  transition: all 0.2s ease-out;
}

.accordion__icon .icon:nth-child(1) {
  position: absolute;
  top: 0;
  left: 0;
}

.accordion__icon .icon:nth-child(2) {
  position: relative;
  transform: rotate(-90deg);
  opacity: 0;
}

.accordion__item.is-active .accordion__icon > *:nth-child(1) {
  transform: rotate(90deg);
  opacity: 0;
}

.accordion__item.is-active .accordion__icon > *:nth-child(2) {
  transform: none;
  opacity: 1;
}

.accordion__content {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.2s ease-out;
}

.accordion__button {
  cursor: pointer;
}

.accordion.-simple .accordion__button {
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--color-accent-2);
  transition: 0.4s;
}

.accordion.-simple .accordion__button button {
  color: var(--text-dark-1);
}

.accordion.-simple .accordion__icon {
  width: 28px;
  height: 28px;
  font-size: 12px;
  border: 1px solid var(--color-accent-1);
  color: var(--color-accent-1);
  transition: all 0.2s ease-out;
}

.accordion.-simple .accordion__icon > *:nth-child(1) {
  position: absolute;
  transition: all 0.2s ease-out;
}

.accordion.-simple .accordion__icon > *:nth-child(2) {
  position: relative;
  transform: rotate(-90deg);
  opacity: 0;
  transition: all 0.2s ease-out;
}

.accordion.-simple .accordion__item.is-active .accordion__icon > *:nth-child(1) {
  transform: rotate(90deg);
  opacity: 0;
}

.accordion.-simple .accordion__item.is-active .accordion__icon > *:nth-child(2) {
  transform: none;
  opacity: 1;
}

.imageSliderNav {
  position: absolute;
  top: 50%;
  left: -70px;
  right: -70px;
  width: calc(100% + 140px);
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  z-index: 10;
  pointer-events: none;
  padding: 0;
}

.imageSliderNav > * {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100px;
  height: 100px;
  color: white;
  font-size: 27px;
  background-color: var(--color-dark-1);
  pointer-events: auto;
  cursor: pointer;
}

.imageSliderNav > *:hover {
  background-color: var(--color-dark-3);
}

.testimonialsNav {
  display: flex;
  justify-content: center;
  align-items: center;
}

.testimonialsNav > button {
  display: flex;
  align-items: center;
  font-size: 22px;
}

.testimonialsNav > * + * {
  margin-left: 15px;
}

.testimonialsPag {
  font-size: 14px;
}

.testimonialsPag > * {
  color: var(--color-dark-4);
  opacity: 0.4;
}

.testimonialsPag .is-active {
  color: white !important;
  opacity: 1;
}

.testimonialsPag > * + * {
  margin-left: 15px;
}

.testimonialsPag.-dark .is-active {
  color: var(--color-dark-1) !important;
}

.-hover-link:hover {
  color: var(--color-accent-1);
}

.-hover-link-2:hover {
  color: var(--color-white);
}

.aboutImages.-type-1 {
  position: relative;
}

@media (max-width: 991px) {
  .aboutImages.-type-1 {
    display: grid;
    gap: 30px;
    grid-template-columns: 1fr 1fr;
    align-items: center;
  }
}

@media (max-width: 575px) {
  .aboutImages.-type-1 {
    grid-template-columns: 1fr;
  }
}

.aboutImages.-type-1 > *:nth-child(2) {
  position: absolute;
  bottom: -90px;
  right: -120px;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media (max-width: 1199px) {
  .aboutImages.-type-1 > *:nth-child(2) {
    right: 50px;
  }
}

@media (max-width: 991px) {
  .aboutImages.-type-1 > *:nth-child(2) {
    position: relative;
    bottom: unset;
    right: unset;
  }
}

.items-center-imp {
  align-items: center !important;
}

.test {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 50%;
}

@media (max-width: 1199px) {
  .test {
    position: relative;
    width: 100%;
  }
}

.test img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.icon-minus-1 {
  width: 10px;
  height: 1px;
  background-color: var(--color-accent-1);
}

@media (max-width: 1600px) {
  .absoluteNavSlider {
    margin: 0 80px;
  }
}

@media (max-width: 991px) {
  .absoluteNavSlider {
    margin: 0;
  }
}

.absoluteNav {
  position: absolute;
  top: 50%;
  left: -110px;
  right: -110px;
  display: flex;
  justify-content: space-between;
  transform: translateY(-50%);
  z-index: 5;
}

@media (max-width: 1600px) {
  .absoluteNav {
    left: -30px;
    right: -30px;
  }
}

@media (max-width: 991px) {
  .absoluteNav {
    position: relative;
    top: unset;
    left: unset;
    right: unset;
    transform: none;
    margin-top: 30px;
    justify-content: center;
  }
}

.imageGrid.-type-1 {
  position: relative;
  height: 700px;
}

@media (max-width: 991px) {
  .imageGrid.-type-1 {
    height: 400px;
  }
}

@media (max-width: 767px) {
  .imageGrid.-type-1 {
    height: auto;
  }
}

.imageGrid.-type-1 .imageGrid__images {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  display: grid;
  gap: 30px;
  grid-template-columns: repeat(2, 570px);
  height: 100%;
}

@media (max-width: 991px) {
  .imageGrid.-type-1 .imageGrid__images {
    position: relative;
    grid-template-columns: repeat(2, 1fr);
    height: 100%;
  }
}

@media (max-width: 767px) {
  .imageGrid.-type-1 .imageGrid__images {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}

.imageGrid.-type-1 .imageGrid__images img {
  width: 100%;
  height: 700px;
  -o-object-fit: cover;
     object-fit: cover;
}

@media (max-width: 991px) {
  .imageGrid.-type-1 .imageGrid__images img {
    height: 400px;
  }
}

@media (max-width: 767px) {
  .imageGrid.-type-1 .imageGrid__images img {
    height: auto;
    max-height: 400px;
  }
}

@media (max-width: 575px) {
  .imageGrid.-type-1 .imageGrid__images img {
    max-height: 300px;
  }
}

@media (max-width: 767px) {
  .singleImage.-type-1 {
    height: 400px;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

@media (max-width: 575px) {
  .singleImage.-type-1 {
    height: 300px;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.blockquote {
  position: relative;
  background-color: var(--color-accent-2);
  padding: 35px 220px 25px 60px;
  z-index: 0;
}

@media (max-width: 767px) {
  .blockquote {
    padding: 20px 40px;
  }
}

@media (max-width: 575px) {
  .blockquote {
    padding: 20px 20px;
  }
}

.blockquote > *:nth-child(1) {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  background-color: var(--color-accent-1);
  width: 3px;
  z-index: 1;
}

.blockquote > *:nth-child(2) {
  font-size: 18px;
}

@media (max-width: 767px) {
  .blockquote > *:nth-child(2) {
    font-size: 16px;
  }
}

.blockquote > *:nth-child(3) {
  font-size: 16px;
  font-weight: 500;
  line-height: 36px;
  margin-top: 10px;
  text-transform: uppercase;
}

.blogContent .list {
  font-size: 18px;
  padding-left: 1rem;
}

@media (max-width: 767px) {
  .blogContent .list {
    font-size: 16px;
  }
}

.blogContent .list li {
  list-style: disc;
}

.blogContent .list li + li {
  margin-top: 6px;
}

.blogDivider {
  width: 100%;
  height: 1px;
  background-color: var(--color-accent-2);
}

.blogSocial {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 100%;
  border: 1px solid transparent;
  transition: all 0.3s ease;
}

.blogSocial:hover {
  color: var(--color-dark-1);
  border-color: var(--color-accent-1);
}

.blogTag {
  cursor: pointer;
  padding: 10px 15px;
  border: 1px solid var(--color-accent-1);
  font-weight: 500;
  text-transform: uppercase;
  font-size: 14px;
  transition: all 0.3s ease;
}

.blogTag:hover {
  border-color: var(--color-dark-1);
  background-color: var(--color-accent-2);
}

.blogOtherPosts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 150px;
  padding: 60px;
}

@media (max-width: 767px) {
  .blogOtherPosts {
    gap: 60px;
    padding: 40px;
  }
}

@media (max-width: 575px) {
  .blogOtherPosts {
    grid-template-columns: 1fr;
    gap: 30px;
    padding: 30px;
  }
  .blogOtherPosts > * {
    text-align: center !important;
  }
}

.blogOtherPosts > * h5 {
  font-size: 18px;
  font-weight: 500;
  text-transform: uppercase;
}

.blogOtherPosts > * div {
  font-size: 18px;
}

@media (max-width: 767px) {
  .blogOtherPosts > * div {
    font-size: 16px;
  }
}

.blogOtherPosts > *:nth-child(2) {
  text-align: right;
}

.blogForm {
  width: 690px;
  max-width: 100%;
}

.blogForm textarea,
.blogForm input {
  border-bottom: 1px solid black;
  padding-bottom: 10px;
}

.blogForm textarea:focus,
.blogForm input:focus {
  border-color: var(--color-accent-1);
}

.alertMsg.-info {
  color: #4780AA;
  background-color: rgba(205, 233, 246, 0.5);
}

.alertMsg.-warning {
  color: #927238;
  background-color: rgba(247, 243, 215, 0.5);
}

.alertMsg.-error {
  color: #AB3331;
  background-color: rgba(236, 200, 197, 0.5);
}

.alertMsg.-success {
  color: #5B7052;
  background-color: rgba(222, 242, 215, 0.5);
}

.tooltip {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: 500;
}

.tooltip__content {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 7px 11px;
  font-size: 14px;
  line-height: 1.2;
  background-color: var(--color-dark-1);
  color: white;
  border-radius: 8px;
  transition: all 0.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  opacity: 0;
}

.tooltip__content::after {
  content: '';
  position: absolute;
  width: 8px;
  height: 8px;
  background-color: black;
  transform: rotate(45deg);
}

.tooltip.-top .tooltip__content {
  bottom: calc(100% + 6px);
  transform: translateY(8px);
}

.tooltip.-top .tooltip__content::after {
  bottom: -4px;
}

.tooltip.-bottom .tooltip__content {
  top: calc(100% + 6px);
  transform: translateY(-8px);
}

.tooltip.-bottom .tooltip__content::after {
  top: -4px;
}

.tooltip.-left .tooltip__content {
  right: calc(100% + 6px);
  transform: translateX(8px);
}

.tooltip.-left .tooltip__content::after {
  right: -4px;
}

.tooltip.-right .tooltip__content {
  left: calc(100% + 6px);
  transform: translateX(-8px);
}

.tooltip.-right .tooltip__content::after {
  left: -4px;
}

.tooltip:hover .tooltip__content {
  transform: none;
  opacity: 1;
}

.progressBar {
  position: relative;
}

.progressBar__bg {
  width: 100%;
  height: 10px;
  border-radius: 50px;
}

.progressBar__bar {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 5;
  height: 100%;
  border-radius: 50px;
}

.progressBar__bar span {
  position: absolute;
  right: -15px;
  bottom: 100%;
}

.noUi-target {
  height: 4px !important;
  border: none;
  outline: 1px solid rgba(0, 0, 0, 0.08);
}

.noUi-connect {
  background-color: #5BBB7B !important;
  box-shadow: 0 !important;
}

.noUi-handle {
  border-radius: 100%;
  width: 20px !important;
  height: 20px !important;
  top: 50% !important;
  transform: translateY(-50%);
  border: 2px solid #5BBB7B;
  box-shadow: 0 !important;
}

.noUi-handle::before {
  display: none;
}

.noUi-handle::after {
  display: none;
}

.requestForm {
  position: relative;
  transition: 0.2s;
  pointer-events: none;
  opacity: 0;
  z-index: 5000;
}

.requestForm__overlay {
  position: fixed;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  background-color: rgba(25, 29, 35, 0.5);
  z-index: 4999;
}

.requestForm__content {
  overflow-y: scroll;
  position: fixed;
  top: 0;
  bottom: 0;
  right: 0;
  width: 720px;
  max-width: 100%;
  background-color: white;
  z-index: 5000;
}

.requestForm__container {
  padding: 30px 60px 80px 60px;
}

@media (max-width: 575px) {
  .requestForm__container {
    padding: 20px 20px;
  }
}

.requestForm__close {
  position: absolute;
  top: 30px;
  right: 60px;
}

@media (max-width: 575px) {
  .requestForm__close {
    top: 20px;
    right: 20px;
  }
}

.requestForm__close button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 70px;
  height: 70px;
  border-radius: 100%;
  border: 1px solid var(--color-accent-1);
  transition: 0.15s;
}

@media (max-width: 575px) {
  .requestForm__close button {
    width: 64px;
    height: 64px;
  }
}

.requestForm__close button:hover {
  background-color: var(--color-dark-1);
  border-color: var(--color-dark-2);
  color: white;
}

.requestForm__close i {
  font-size: 13px;
}

.requestForm__title {
  font-size: 62px;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 2.5px;
  text-transform: uppercase;
}

@media (max-width: 991px) {
  .requestForm__title {
    font-size: 44px;
  }
}

@media (max-width: 575px) {
  .requestForm__title {
    font-size: 36px;
  }
}

.requestForm__form {
  margin-top: 30px;
}

@media (max-width: 575px) {
  .requestForm__form {
    margin-top: 20px;
  }
}

.requestForm.is-active {
  pointer-events: auto;
  opacity: 1;
}

.hover-btn-explore__item {
  pointer-events: none;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%) scale(0.9);
  transition: .3s;
  opacity: 0;
  z-index: 5;
}

.hover-btn-explore:hover .hover-btn-explore__item {
  opacity: 1;
  transform: translateY(-50%) translateX(-50%) scale(1);
}

.-hover-iconCard-1 {
  transition: 0.2s;
}

.-hover-iconCard-1:hover {
  background-color: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0);
  color: white;
}

.hover-icon-1__item {
  transition: .2s;
}

.hover-icon-1:hover .hover-icon-1__item {
  background-color: var(--color-accent-1) !important;
  color: white !important;
}

.toTopButton {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 100px;
  height: 100px;
  color: var(--color-accent-1);
  border-radius: 100%;
  border: 1px solid var(--color-accent-1);
  transition: .15s;
  z-index: 500;
}

@media (max-width: 767px) {
  .toTopButton {
    bottom: 20px;
    right: 20px;
    width: 60px;
    height: 60px;
  }
}

.toTopButton.is-hidden {
  pointer-events: none;
  opacity: 0;
}

.toTopButton > * {
  display: block;
  transform: rotate(180deg);
  font-size: 20px;
}

.toTopButton:hover {
  background-color: var(--color-accent-1);
  color: white;
}

.-image-slider-1 .swiper-slide {
  transform: scale(0.9);
  transition: 0.3s;
}

.-image-slider-1 .swiper-slide .exploreButton {
  pointer-events: none;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%) scale(0.9);
  transition: .4s;
  opacity: 0;
  z-index: 5;
  transform-origin: center;
}

.-image-slider-1 .swiper-slide.swiper-slide-active {
  transform: scale(1);
}

.-image-slider-1 .swiper-slide.swiper-slide-active .exploreButton {
  opacity: 1;
  transform: translateY(-50%) translateX(-50%) scale(1);
}

.-hover-iconCard-3 {
  transition: 0.2s;
}

.-hover-iconCard-3 .-hoverIcon {
  transition: 0.2s;
}

.-hover-iconCard-3:hover {
  background-color: var(--color-accent-2);
}

.-hover-iconCard-3:hover .-hoverIcon {
  background-color: var(--color-accent-1);
  color: white;
}

.-hover-iconCard-2:hover {
  background-color: var(--color-accent-1) !important;
  color: white !important;
}

.-hover-iconCard-2:hover .-hover-icon {
  color: rgba(255, 255, 255, 0.5);
}

.-hover-iconCard-2:hover .-hover-button {
  color: white;
}

.-hover-iconCard-2:hover .-hover-button span {
  color: var(--color-accent-1) !important;
  border-color: var(--color-accent-1) !important;
  background-color: white;
}

.is-tab-el-active.-base-active {
  background-color: var(--color-accent-2);
}

.card-flex-end {
  display: flex;
}

.card-flex-end > * {
  align-self: flex-end;
}

.mortgage-info-section {
  background: linear-gradient(135deg, rgba(209, 194, 140, 0.05) 0%, rgba(247, 240, 236, 0.3) 100%);
  position: relative;
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
  padding-top: 60px !important;
}

@media (max-width: 767px) {
  .mortgage-info-section {
    padding-top: 40px !important;
  }
}

@media (max-width: 575px) {
  .mortgage-info-section {
    padding-top: 30px !important;
  }
}

.mortgage-info-section .mortgage-info-card {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

/* Блок с призывом */
.mortgage-cta-banner {
  background: 
    radial-gradient(ellipse at top left, rgba(75, 75, 80, 0.98) 0%, transparent 40%),
    radial-gradient(ellipse at bottom right, rgba(15, 15, 20, 0.98) 0%, transparent 40%),
    radial-gradient(ellipse at center, rgba(60, 60, 65, 0.95) 0%, transparent 60%),
    linear-gradient(135deg, #0d0d12 0%, #3a3a42 15%, #141419 30%, #40404a 45%, #101015 60%, #34343d 75%, #16161b 90%, #2e2e37 100%);
  padding: 60px 0;
  position: relative;
  overflow: hidden;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  border-radius: 0;
}

.mortgage-cta-banner::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: 
    radial-gradient(circle at 30% 20%, rgba(209, 194, 140, 0.2) 0%, transparent 30%),
    radial-gradient(circle at 70% 80%, rgba(209, 194, 140, 0.18) 0%, transparent 30%),
    radial-gradient(ellipse at 50% 50%, rgba(255, 255, 255, 0.03) 0%, transparent 50%);
  pointer-events: none;
  z-index: 0;
}


.mortgage-cta-banner__content {
  text-align: center;
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 100%;
  padding: 40px 0;
}

.mortgage-cta-banner .container {
  position: relative;
}

.mortgage-cta-banner .row {
  position: relative;
}


.mortgage-cta-banner__title {
  font-size: 42px;
  font-weight: 700;
  color: #ffffff;
  margin: 0;
  line-height: 1.3;
  text-transform: uppercase;
  letter-spacing: 1px;
  position: relative;
}

.mortgage-cta-banner__content {
  position: relative;
}


.mortgage-cta-banner__content::before,
.mortgage-cta-banner__content::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 2px;
  pointer-events: none;
  z-index: 2;
}

.mortgage-cta-banner__content::before {
  left: 0;
  border-left: 2px solid rgba(66, 66, 66, 0.5);
  border-top-left-radius: 32px;
  border-bottom-left-radius: 32px;
  top: -60px;
  bottom: 0;
  height: calc(100% + 120px);
  box-shadow: 
    -4px 0 8px rgba(0, 0, 0, 0.3),
    -2px 0 4px rgba(0, 0, 0, 0.2);
}

.mortgage-cta-banner__content::after {
  right: 0;
  border-right: 2px solid rgba(66, 66, 66, 0.5);
  border-top-right-radius: 32px;
  border-bottom-right-radius: 32px;
  top: -60px;
  bottom: 0;
  height: calc(100% + 120px);
  box-shadow: 
    4px 0 8px rgba(0, 0, 0, 0.3),
    2px 0 4px rgba(0, 0, 0, 0.2);
}

.mortgage-cta-banner__title .text-accent-1 {
  color: var(--color-accent-1);
}

.mortgage-cta-banner__text {
  font-size: 24px;
  font-weight: 700;
  color: #ffffff;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin: 0;
  white-space: nowrap;
}

.mortgage-cta-banner__text span:not(.mortgage-cta-banner__title-jk) {
  opacity: 0;
  display: inline-block;
}

.mortgage-cta-banner.is-visible .mortgage-cta-banner__text span:not(.mortgage-cta-banner__title-jk) {
  animation: letterReveal 0.05s ease-out forwards;
}

.mortgage-cta-banner__text-1 {
  opacity: 0;
  transform: translateY(20px);
}

.mortgage-cta-banner__text-2 {
  opacity: 0;
  transform: translateY(20px);
  margin-bottom: 1rem;
}

.mortgage-cta-banner__text-3 {
  margin: 20px 0;
  white-space: normal;
  opacity: 0;
  transform: translateY(20px);
}

.mortgage-cta-banner__text-4 {
  opacity: 0;
  transform: translateY(20px);
}

.mortgage-cta-banner.is-visible .mortgage-cta-banner__text-2 {
  animation: textReveal 0.6s ease-out forwards;
  animation-delay: 1.0s;
}

.mortgage-cta-banner.is-visible .mortgage-cta-banner__text-3 {
  animation: textReveal 0.8s ease-out forwards;
  animation-delay: 0.5s;
}

.mortgage-cta-banner.is-visible .mortgage-cta-banner__text-4 {
  animation: textReveal 0.6s ease-out forwards;
  animation-delay: 1.0s;
}

@keyframes textReveal {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes letterReveal {
  0% {
    opacity: 0;
    transform: translateY(10px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.mortgage-cta-banner__title-jk {
  font-weight: 600;
  font-family: "Century Gothic", Arial, sans-serif;
  background: linear-gradient(to right, #ffeba5, #b77521);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-transform: uppercase;
  letter-spacing: 20px;
  font-stretch: ultra-condensed;
  display: inline-block;
  font-size: 6rem;
}

@media (max-width: 991px) {
  .mortgage-cta-banner {
    padding: 60px 0;
  }

  .mortgage-cta-banner__text {
    font-size: 32px;
  }

  .mortgage-cta-banner__title-jk {
    letter-spacing: 12px;
    font-size: 4rem;
  }
}

@media (max-width: 767px) {
  .mortgage-cta-banner {
    padding: 50px 0;
  }

  .mortgage-cta-banner__text {
    font-size: 20px;
    line-height: 1.4;
  }

  .mortgage-cta-banner__text-1,
  .mortgage-cta-banner__text-2,
  .mortgage-cta-banner__text-4 {
    font-size: 16px;
  }

  .mortgage-cta-banner__title-jk {
    letter-spacing: 8px;
    font-size: 2.5rem;
  }
}

.mortgage-info-card {
  background: #ffffff;
  border-radius: 32px;
  padding: 60px 50px;
  box-shadow: 0 20px 60px rgba(27, 27, 27, 0.1);
  position: relative;
  overflow: hidden;
}

.mortgage-info-card::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 300px;
  height: 300px;
  background: linear-gradient(135deg, rgba(209, 194, 140, 0.1) 0%, transparent 100%);
  border-radius: 50%;
  transform: translate(30%, -30%);
  pointer-events: none;
}

.mortgage-info__header {
  margin-bottom: 40px;
}

.mortgage-info__subtitle {
  font-size: 24px;
  font-weight: 600;
  color: var(--color-dark-1);
}

.mortgage-info__description {
  font-size: 18px;
  line-height: 1.7;
  color: rgba(27, 27, 27, 0.8);
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.mortgage-conditions,
.mortgage-benefits {
  background: linear-gradient(135deg, rgba(209, 194, 140, 0.08) 0%, rgba(247, 240, 236, 0.4) 100%);
  border-radius: 24px;
  padding: 32px;
  height: 100%;
  border: 1px solid rgba(209, 194, 140, 0.2);
}

.mortgage-conditions__title,
.mortgage-benefits__title {
  font-size: 22px;
  font-weight: 600;
  color: var(--color-dark-1);
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 2px solid rgba(209, 194, 140, 0.3);
}

.mortgage-conditions__list,
.mortgage-benefits__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.mortgage-conditions__item,
.mortgage-benefits__item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 16px;
  line-height: 1.6;
  color: rgba(27, 27, 27, 0.9);
}

.mortgage-conditions__icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  background: var(--color-accent-1);
  color: #1b1b1b;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  margin-top: 2px;
}

.mortgage-benefits__icon {
  flex-shrink: 0;
  width: 8px;
  height: 8px;
  background: var(--color-accent-1);
  border-radius: 50%;
  margin-top: 8px;
}

.mortgage-calculator-section {
  padding-top: 0 !important;
  margin-top: 0 !important;
  padding-bottom: 60px !important;
}

@media (max-width: 767px) {
  .mortgage-calculator-section {
    padding-bottom: 40px !important;
  }
}

@media (max-width: 575px) {
  .mortgage-calculator-section {
    padding-bottom: 30px !important;
  }
}

.mortgage-calculator-section .mortgage-info-card {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.mortgage-info__cta {
  padding-top: 40px;
  border-top: 1px solid rgba(209, 194, 140, 0.2);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.mortgage-info__cta-text {
  font-size: 18px;
  font-weight: 500;
  color: var(--color-dark-1);
  margin-bottom: 24px;
}

@media (max-width: 991px) {
  .mortgage-info-card {
    padding: 40px 30px;
  }

  .mortgage-info__subtitle {
    font-size: 20px;
  }

  .mortgage-info__description {
    font-size: 16px;
  }

  .mortgage-conditions,
  .mortgage-benefits {
    padding: 24px;
    margin-bottom: 20px;
  }

  .mortgage-conditions__title,
  .mortgage-benefits__title {
    font-size: 20px;
  }
}

@media (max-width: 767px) {
  .mortgage-info-card {
    padding: 30px 20px;
    border-radius: 24px;
  }

  .mortgage-info__subtitle {
    font-size: 18px;
  }

  .mortgage-info__description {
    font-size: 15px;
  }

  .mortgage-conditions__item,
  .mortgage-benefits__item {
    font-size: 15px;
  }

  .mortgage-info__cta-text {
    font-size: 16px;
  }

  .mortgage-calculator-section {
    padding-top: 30px;
    margin-top: 30px;
  }
}

.mortgage-section {
  background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
}

.calculator-card {
  background: #ffffff;
  padding: 2.5rem;
}

.form-group {
  margin-bottom: 0.5rem;
}

.form-label {
  display: block;
  margin-bottom: 0rem;
  font-weight: 600;
  color: var(--color-dark);
}

.form-range {
  width: 100%;
  height: 6px;
  background: var(--color-gray-light);
  border-radius: 3px;
  outline: none;
}

.form-range::-webkit-slider-thumb {
  appearance: none;
  width: 20px;
  height: 20px;
  background: var(--color-gold);
  border-radius: 50%;
  cursor: pointer;
}

.range-values {
  display: flex;
  justify-content: space-between;
  margin-top: 0.5rem;
  font-size: 0.9rem;
  color: var(--color-gray);
}

.result-card {
  background: linear-gradient(135deg, var(--color-gold), var(--color-gold-dark));
  padding: 2.7rem 2rem;
  color: var(--color-dark);
  text-align: center;
}

.result-card-standart {
  background: linear-gradient(135deg, var(--color-gray), var(--color-gray-light));
  padding: 2.7rem 2rem;
  color: var(--color-dark);
  text-align: center;
}
.result-card h2, .result-card-standart h2{
  font-size: 2rem;
}
.monthly-payment {
  font-size: 2rem;
  font-weight: 800;
  margin-bottom: 1rem;
}

.result-details {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 2rem;
}
.result-item {
  background: rgba(255,255,255,0.2);
  padding: 1rem;
  border-radius: var(--radius);
}
@media (max-width: 767px) {
  .result-card, .result-card-standart {
    padding: 1rem 0.8rem;
  }
  .result-card h2, .result-card-standart h2{
    font-size: 1.1rem;
    margin-bottom: 0.4rem;
  }
  .result-card h3, .result-card-standart h3 {
    font-size: 0.85rem;
    margin-bottom: 0.4rem;
  }
  .monthly-payment {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.6rem;
  }
  .result-details {
        display:block;
        margin-bottom: 0rem;
  }
  .result-item{
    margin-bottom: 0.6rem;
    padding: 0.5rem 0.4rem;
  }
  .result-item .text-20 {
    font-size: 0.75rem !important;
    line-height: 1.3;
  }
  .result-item .text-20.fw-500 {
    font-size: 0.8rem !important;
    font-weight: 600;
  }
}


/* Mortgage card styles are now merged with preim-card above */

.about-project-section {
  position: relative;
  background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
}

.about-project-section::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: min(45%, 520px);
  background-image: url("../img/general/bg1.webp");
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 140%;
  opacity: 0.35;
  pointer-events: none;
  mix-blend-mode: multiply;
}

/* Common card container styles */
.about-project__intro,
.cta-request__form,
.construction-timeline__card {
  background: rgba(255, 255, 255, 0.92);
  border-radius: 22px;
  box-shadow: 0 20px 50px rgba(27, 27, 27, 0.08);
  position: relative;
  overflow: hidden;
}

.about-project__intro {
  background: #ffffff;
  padding: 40px 44px;
}

.about-project__intro::after,
.cta-request__form::after,
.construction-timeline__card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  mix-blend-mode: screen;
}

.about-project__intro::after {
  background: radial-gradient(circle at top right, rgba(247, 209, 76, 0.35), transparent 65%);
}

.cta-request__form::after,
.construction-timeline__card::after {
  background: radial-gradient(circle at top right, rgba(209, 194, 140, 0.15), transparent 65%);
}

.about-project__eyebrow {
  letter-spacing: 0.2em;
  font-size: 0.85rem;
}

.about-project__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 22px;
}

.about-project__card {
  background: rgba(255, 255, 255, 0.92);
  border-radius: 20px;
  padding: 30px 32px;
  box-shadow: 0 18px 45px rgba(27, 27, 27, 0.06);
  backdrop-filter: blur(6px);
  transition: transform 0.35s ease, box-shadow 0.35s ease;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.about-project__card:hover {
  transform: translateY(-10px);
  box-shadow: 0 26px 60px rgba(27, 27, 27, 0.12);
}

.about-project__title {
  font-size: 20px;
  font-weight: 600;
  color: var(--color-dark);
  margin: 0;
}

.about-project__text {
  margin: 0;
  font-size: 16px;
  line-height: 1.6;
  color: rgba(27, 27, 27, 0.85);
}

.about-project__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.about-project__list li {
  position: relative;
  padding-left: 26px;
  font-size: 16px;
  line-height: 1.6;
  color: rgba(27, 27, 27, 0.85);
}

.about-project__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-gold);
  box-shadow: 0 0 0 4px rgba(247, 209, 76, 0.35);
}

.about-project-section .row.y-gap-40 {
  align-items: stretch;
}

.about-project__intro-col,
.about-project__grid-col {
  display: flex;
}

.about-project__grid-col .features-cards__grid {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  align-items: start;
}

@media (max-width: 991px) {
  .about-project__grid-col .features-cards__grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 767px) {
  .about-project__intro-col {
        margin-bottom: 15px !important;
  }
}
.about-project__intro {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.about-project__grid {
  height: 100%;
}

.about-project__cta {
  position: relative;
  margin-top: 50px;
  padding: 48px 60px;
  border-radius: 28px;
  background: linear-gradient(120deg, rgba(213, 196, 145, 0.95), rgba(255, 246, 226, 0.95));
  box-shadow: 0 32px 70px rgba(247, 209, 76, 0.28);
  overflow: hidden;
}

.about-project__cta::before,
.about-project__cta::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  mix-blend-mode: soft-light;
  opacity: 0.6;
}

.about-project__cta::before {
  width: 320px;
  height: 320px;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.8), transparent 65%);
  top: -140px;
  right: -120px;
}

.about-project__cta::after {
  width: 220px;
  height: 220px;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.5), transparent 70%);
  bottom: -100px;
  left: -90px;
}

.about-project__cta-title {
  margin: 0;
  font-size: 32px;
  font-weight: 700;
  color: #1b1b1b;
}

.about-project__cta-text {
  margin: 18px 0 28px;
  font-size: 18px;
  line-height: 1.6;
  color: rgba(27, 27, 27, 0.85);
  max-width: 720px;
}

.about-project__cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}

@media (max-width: 991px) {
  .about-project__intro {
    padding: 32px;
  }

  .about-project__grid {
    gap: 18px;
  }

  .about-project__card {
    padding: 26px 28px;
  }

  .about-project__cta {
    padding: 38px 36px;
  }
}

@media (max-width: 575px) {
  .about-project__intro {
    padding: 28px 24px;
  }

  .about-project__grid {
    grid-template-columns: 1fr;
  }

  .about-project__cta {
    padding: 30px 24px;
  }

  .about-project__cta-title {
    font-size: 26px;
  }

  .about-project__cta-text {
    font-size: 16px;
  }

  .about-project__cta-actions {
    flex-direction: column;
  }
}

/* Features Cards Section */
.features-cards-section {
  position: relative;
}

.features-cards__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.features-card {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 18px 45px rgba(27, 27, 27, 0.08);
  transition: transform 0.35s ease, box-shadow 0.35s ease;
  background: #000;
  width: 100%;
  aspect-ratio: 4 / 3;
  min-height: 300px;
}

.features-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 26px 60px rgba(27, 27, 27, 0.12);
}

.features-card__title {
  position: absolute;
  top: 1rem;
  right: 0;
  margin: 0;
  padding: 12px;
  font-size: 16px;
  font-weight: 600;
  color: #ffffff;
  z-index: 3;
  text-align: right;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
}

.features-card__image-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.features-card__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.features-card__gradient {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 40%;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.7) 40%, rgba(0, 0, 0, 0.6) 50%, rgba(0, 0, 0, 0.6) 100%);
  z-index: 1;
  pointer-events: none;
}

.features-card__content {
  position: absolute;
  top: 70%;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 0 12px 32px 12px;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  align-content: flex-start;
}

.features-card__text {
  margin: 0;
  padding: 0;
  font-size: 16px;
  line-height: 1.2;
  color: #ffffff;
  font-weight: 300;
  text-align: left;
}

@media (max-width: 991px) {
  .features-cards__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }

  .features-card__title {
    padding: 20px 24px;
    font-size: 22px;
  }

  .features-card__content {
    padding: 0 24px 28px 24px;
  }

  .features-card__text {
    font-size: 16px;
  }
}

@media (max-width: 767px) {
  .features-cards__grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .features-card__title {
    padding: 18px 20px;
    font-size: 20px;
  }

  .features-card__content {
    padding: 0 20px 24px 20px;
  }

  .features-card__text {
    font-size: 15px;
  }
}

.floorplans-section {
  position: relative;
  overflow: hidden;
  padding-bottom: 60px !important;
}

@media (max-width: 767px) {
  .floorplans-section {
    padding-bottom: 40px !important;
  }
}

@media (max-width: 575px) {
  .floorplans-section {
    padding-bottom: 30px !important;
  }
}


.floorplan-section-filters {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 20px;
}

.floorplan-section-btn {
  border: 2px solid rgba(27, 27, 27, 0.15);
  background: #ffffff;
  color: var(--color-dark-1);
  font-weight: 700;
  font-size: 16px;
  padding: 14px 32px;
  border-radius: 30px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  position: relative;
  overflow: hidden;
  cursor: pointer;
}

.floorplan-section-btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(209, 194, 140, 0.15) 0%, rgba(209, 194, 140, 0.08) 100%);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.floorplan-section-btn:hover {
  border-color: rgba(209, 194, 140, 0.5);
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(209, 194, 140, 0.25);
}

.floorplan-section-btn:hover::before {
  opacity: 1;
}

.floorplan-section-btn.is-active {
  border-color: transparent;
  background: linear-gradient(135deg, var(--color-accent-1) 0%, rgba(209, 194, 140, 0.95) 100%);
  color: #1b1b1b;
  box-shadow: 0 8px 24px rgba(209, 194, 140, 0.4), 0 2px 8px rgba(209, 194, 140, 0.25);
  transform: translateY(-2px);
  font-weight: 700;
}

.floorplan-section-btn.is-active::before {
  opacity: 0;
}

@media (max-width: 575px) {
  .floorplan-section-filters {
    gap: 10px;
  }
  
  .floorplan-section-btn {
    flex: 1 1 calc(33.333% - 7px);
    min-width: calc(33.333% - 7px);
    padding: 12px 16px;
    font-size: 14px;
  }
}

.floorplan-filters {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

@media (max-width: 575px) {
  .floorplan-filters {
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
  }
  
  .floorplan-filter-btn {
    flex: 0 0 calc(50% - 4px);
    min-width: calc(50% - 4px);
    max-width: calc(50% - 4px);
  }
}

.floorplan-filter-btn {
  border: 2px solid rgba(27, 27, 27, 0.12);
  background: #ffffff;
  color: var(--color-dark-1);
  font-weight: 600;
  font-size: 14px;
  padding: 12px 28px;
  border-radius: 30px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  position: relative;
  overflow: hidden;
}

.floorplan-filter-btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(209, 194, 140, 0.1) 0%, rgba(209, 194, 140, 0.05) 100%);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.floorplan-filter-btn:hover {
  border-color: rgba(209, 194, 140, 0.4);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(209, 194, 140, 0.2);
}

.floorplan-filter-btn:hover::before {
  opacity: 1;
}

.floorplan-filter-btn.is-active {
  border-color: transparent;
  background: linear-gradient(135deg, var(--color-accent-1) 0%, rgba(209, 194, 140, 0.9) 100%);
  color: #1b1b1b;
  box-shadow: 0 8px 20px rgba(209, 194, 140, 0.35), 0 2px 8px rgba(209, 194, 140, 0.2);
  transform: translateY(-2px);
  font-weight: 700;
}

.floorplan-filter-btn.is-active::before {
  opacity: 0;
}

.floorplans-slider {
  position: relative;
  overflow: visible;
  width: 100%;
  max-width: 100%;
}

.floorplans-section,
.floorplans-section .container,
.floorplans-section .row,
.floorplans-section .col-12 {
  overflow: visible !important;
}

.floorplans-slider .swiper-slide {
  height: auto;
  padding: 10px;
  box-sizing: border-box;
  width: auto;
}
.js-section-slider{
  overflow: hidden;
  width: 100%;
  max-width: 100%;
  position: relative;
}

.js-section-slider:has(.imageSliderNav),
.relative:has(.imageSliderNav),
[id*="carusel"]:has(.imageSliderNav),
[id*="carousel"]:has(.imageSliderNav),
.col-lg-7:has(.imageSliderNav),
.col-xl-5:has(.imageSliderNav) {
  overflow: visible;
}

.js-section-slider .swiper-wrapper {
  width: 100%;
  max-width: 100%;
}
.floorplans-slider .swiper-slide.is-hidden {
  display: none !important;
}

.floorplan-card {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  background: #ffffff;
  border-radius: 24px;
  overflow: hidden;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08), 0 1px 3px rgba(0, 0, 0, 0.05);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  border: 1px solid rgba(255, 255, 255, 0.8);
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.floorplan-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(209, 194, 140, 0.03) 0%, rgba(209, 194, 140, 0.08) 100%);
  opacity: 0;
  transition: opacity 0.4s ease;
  z-index: 1;
}

.floorplan-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.02) 50%, rgba(0, 0, 0, 0.08) 100%);
  opacity: 0;
  transition: opacity 0.4s ease;
  z-index: 2;
  pointer-events: none;
}

.floorplan-card__image {
  position: relative;
  overflow: hidden;
  padding: 24px 24px 0;
  background: linear-gradient(180deg, rgba(209, 194, 140, 0.05) 0%, transparent 100%);
  z-index: 1;
}

.floorplan-card__image::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 40%;
  background: linear-gradient(to top, rgba(255, 255, 255, 0.8) 0%, transparent 100%);
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
}

.floorplan-card__image img {
  width: 100%;
  display: block;
  border-radius: 16px;
  transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  filter: brightness(1) contrast(1);
  position: relative;
}

.floorplan-card__body {
  position: relative;
  z-index: 3;
  padding: 24px 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: linear-gradient(to bottom, transparent 0%, rgba(255, 255, 255, 0.95) 20%);
}

.floorplan-card__badge {
  align-self: flex-start;
  background: linear-gradient(135deg, rgba(209, 194, 140, 0.2) 0%, rgba(209, 194, 140, 0.15) 100%);
  color: #86794a;
  font-size: 12px;
  font-weight: 700;
  padding: 8px 16px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  box-shadow: 0 2px 8px rgba(209, 194, 140, 0.2);
  transition: all 0.3s ease;
  border: 1px solid rgba(209, 194, 140, 0.3);
}

.floorplan-card__title {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  color: var(--color-dark-1);
  line-height: 1.3;
  transition: color 0.3s ease;
  letter-spacing: -0.02em;
}

.floorplan-card__meta {
  margin: 0;
  font-size: 15px;
  color: rgba(27, 27, 27, 0.7);
  line-height: 1.5;
  font-weight: 500;
  transition: color 0.3s ease;
}

@media (hover: hover) {
  .floorplan-card:hover {
    transform: translateY(-12px) scale(1.02);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12), 0 8px 16px rgba(209, 194, 140, 0.2);
    border-color: rgba(209, 194, 140, 0.3);
  }

  .floorplan-card:hover::before,
  .floorplan-card:hover::after {
    opacity: 1;
  }

  .floorplan-card:hover .floorplan-card__image::after {
    opacity: 1;
  }

  .floorplan-card:hover .floorplan-card__image img {
    transform: scale(1.05);
    filter: brightness(1.05) contrast(1.05);
  }

  .floorplan-card:hover .floorplan-card__badge {
    background: linear-gradient(135deg, rgba(209, 194, 140, 0.3) 0%, rgba(209, 194, 140, 0.25) 100%);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(209, 194, 140, 0.3);
  }

  .floorplan-card:hover .floorplan-card__title {
    color: #86794a;
  }

  .floorplan-card:hover .floorplan-card__meta {
    color: rgba(27, 27, 27, 0.85);
  }
}

.floorplans-slider-nav .sliderNav {
  border-radius: 50%;
}

.floorplans-nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 0.95) 100%);
  backdrop-filter: blur(10px);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12), 0 2px 8px rgba(209, 194, 140, 0.15);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  border: 1px solid rgba(255, 255, 255, 0.8);
}

.floorplans-nav-btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(209, 194, 140, 0.1) 0%, transparent 100%);
  opacity: 0;
  transition: opacity 0.3s ease;
  border-radius: inherit;
}

.floorplans-nav-btn:hover {
  background: linear-gradient(135deg, #ffffff 0%, rgba(255, 255, 255, 0.98) 100%);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.18), 0 4px 12px rgba(209, 194, 140, 0.25);
  transform: translateY(-50%) scale(1.08);
  border-color: rgba(209, 194, 140, 0.3);
}

.floorplans-nav-btn:hover::before {
  opacity: 1;
}

.floorplans-nav-btn--left {
  left: -40px;
}

.floorplans-nav-btn--right {
  right: -40px;
}

@media (max-width: 991px) {
  .floorplans-nav-btn--left {
    left: 10px;
  }

  .floorplans-nav-btn--right {
    right: 10px;
  }
}

@media (max-width: 767px) {
  .floorplans-nav-btn {
    width: 60px;
    height: 60px;
    font-size: 18px;
  }

  .floorplans-nav-btn--left {
    left: 5px;
  }

  .floorplans-nav-btn--right {
    right: 5px;
  }
}

.floorplan-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 40px 16px;
  z-index: 1200;
}

.floorplan-modal.is-visible {
  display: flex;
}

.floorplan-modal__overlay {
  position: absolute;
  inset: 0;
}

.floorplan-modal__dialog {
  position: relative;
  background: #ffffff;
  border-radius: 28px;
  max-width: 960px;
  width: 100%;
  padding: 32px;
  box-shadow: 0 40px 80px rgba(0, 0, 0, 0.25);
  z-index: 1;
}

.floorplan-modal__close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: none;
  background: rgba(27, 27, 27, 0.08);
  color: var(--color-dark-1);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease, transform 0.2s ease;
  z-index: 100;
  pointer-events: auto;
  touch-action: manipulation;
}

.floorplan-modal__close:hover {
  background: rgba(27, 27, 27, 0.16);
  transform: rotate(90deg);
}

.floorplan-modal__body {
  display: grid;
  gap: 32px;
  grid-template-columns: 1.2fr 1fr;
  align-items: start;
}

.floorplan-modal__gallery {
  position: relative;
  max-width: 100%;
}

.floorplan-modal__slider {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.03);
  width: 100%;
  max-width: 100%;
  height: auto;
  min-height: 200px;
  touch-action: pan-x pan-y pinch-zoom;
  pointer-events: auto;
  transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
}

.floorplan-modal__slider .swiper {
  width: 100%;
  max-width: 100%;
  height: auto;
  touch-action: pan-x pan-y pinch-zoom;
  pointer-events: auto;
  overflow: hidden;
}

.floorplan-modal__slider .swiper-wrapper {
  display: flex;
  width: 100% !important;
  max-width: 100% !important;
  transform: translate3d(0px, 0px, 0px);
  touch-action: pan-x pan-y pinch-zoom;
}

.floorplan-modal__slider .swiper-slide {
  width: 100% !important;
  max-width: 100% !important;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: auto;
  touch-action: pan-x pan-y pinch-zoom;
  pointer-events: auto;
}

.floorplan-modal__slide-image {
  width: 100%;
  max-width: 100%;
  height: auto;
  min-height: 200px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.floorplan-modal__slide-image img {
  max-width: 100%;
  max-height: 70vh;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}

.floorplan-modal__slider-pagination {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  z-index: 10;
  width: auto;
}

.floorplan-modal__pagination-bullet {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.5);
  border: 2px solid rgba(255, 255, 255, 0.8);
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  opacity: 0.6;
  flex-shrink: 0;
}

.floorplan-modal__pagination-bullet:hover {
  background: rgba(255, 255, 255, 0.8);
  opacity: 1;
  transform: scale(1.2);
}

.floorplan-modal__pagination-bullet--active {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 5px;
  background: var(--color-accent-1);
  border-color: var(--color-accent-1);
  opacity: 1;
  box-shadow: 0 2px 8px rgba(209, 194, 140, 0.4);
}

.floorplan-modal__pagination-bullet--active:hover {
  transform: scale(1);
}

.floorplan-modal__content {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.floorplan-modal__title {
  margin: 0;
  font-size: 28px;
  font-weight: 600;
  color: var(--color-dark-1);
  line-height: 1.3;
}

.floorplan-modal__description {
  margin: 0;
  font-size: 16px;
  line-height: 1.7;
  color: rgba(27, 27, 27, 0.8);
}

.floorplan-modal__areas {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  padding: 20px;
  background: rgba(0, 0, 0, 0.02);
  border-radius: 16px;
}

@media (max-width: 767px) {
  .floorplan-modal__areas {
    grid-template-columns: 1fr 1fr;
    gap: 12px 16px;
    padding: 0px;
  }
}

.floorplan-modal__area-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0;
  border-bottom: 1px solid rgba(27, 27, 27, 0.08);
}

@media (max-width: 767px) {
  .floorplan-modal__area-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    border-bottom: none;
    padding-bottom: 8px;
    border-right: 1px solid rgba(27, 27, 27, 0.08);
    padding-right: 12px;
  }
  
  .floorplan-modal__area-item:nth-child(2n) {
    border-right: none;
    padding-right: 0;
  }
  
  .floorplan-modal__area-item:nth-last-child(-n+2) {
    border-bottom: none;
    padding-bottom: 0;
  }
}

.floorplan-modal__area-item:last-child {
  border-bottom: none;
}

.floorplan-modal__area-label {
  font-size: 15px;
  color: rgba(27, 27, 27, 0.7);
}

.floorplan-modal__area-value {
  font-size: 16px;
  font-weight: 600;
  color: var(--color-dark-1);
}

.floorplan-modal__book-btn {
  margin-top: 8px;
  width: 100%;
}

.js-floorplans-slider.is-centered .swiper-wrapper {
  justify-content: center;
  transform: translate3d(0, 0, 0) !important;
}

body.is-modal-open {
  overflow: hidden;
}

@media (max-width: 1199px) {
  .floorplan-modal__dialog {
    max-width: 820px;
  }
}

@media (max-width: 991px) {
  .floorplan-modal__dialog {
    padding: 26px;
  }

  .floorplan-modal__body {
    grid-template-columns: 1fr;
  }

  .floorplan-modal__slider {
    overflow: hidden;
  }

  .floorplan-modal__slider .swiper {
    overflow: hidden;
  }

  .floorplan-modal__slider .swiper-wrapper {
    max-width: 100% !important;
    /* Allow Swiper to control transform */
    transform: translate3d(0px, 0px, 0px);
  }

  .floorplan-modal__slide-image {
    min-height: 200px;
  }

  .floorplan-modal__slide-image img {
    max-height: 50vh;
    width: 100%;
    object-fit: contain;
  }
}

@media (max-width: 575px) {
  .floorplan-filters {
    justify-content: flex-start;
  }

  .floorplan-filter-btn {
    width: 100%;
    text-align: center;
  }

  .floorplan-modal__dialog {
    padding: 22px;
  }

  .floorplan-modal__close {
    z-index: 200;
    top: 12px;
    right: 12px;
    width: 40px;
    height: 40px;
  }

  .floorplan-modal {
    align-items: flex-start;
    overflow-y: auto;
    padding: 20px 12px;
  }
  
  .floorplan-modal__dialog {
    padding: 20px 16px;
    max-height: calc(100vh - 40px);
    overflow-y: auto;
    margin: auto;
  }
  
  .floorplan-modal__body {
    gap: 20px;
  }

  .floorplan-modal__slider {
    overflow: hidden;
  }
  
  .floorplan-modal__slider .swiper {
    overflow: hidden;
  }
  
  .floorplan-modal__slide-image {
    min-height: 150px;
  }
  
  .floorplan-modal__slide-image img {
    max-height: 50vh;
    width: 100%;
    object-fit: contain;
  }
  
  .floorplan-modal__content {
    gap: 14px;
  }
  
  .floorplan-modal__title {
    font-size: 20px;
  }
  
  .floorplan-modal__description {
    font-size: 14px;
    line-height: 1.6;
  }
  
  .floorplan-modal__areas {
    gap: 10px 12px;
    padding: 14px;
  }
  
  .floorplan-modal__area-label {
    font-size: 13px;
  }
  
  .floorplan-modal__area-value {
    font-size: 15px;
  }
  
  .floorplan-modal__book-btn {
    padding: 14px 24px;
    font-size: 15px;
  }

  .floorplan-modal__slider .swiper-wrapper {
    max-width: 100% !important;
    /* Allow Swiper to control transform */
    transform: translate3d(0px, 0px, 0px);
  }

  .floorplan-modal__slide-image img {
    max-height: 300px;
  }

  .floorplan-modal__slide-image {
    max-height: 300px;
    min-height: 150px;
  }
}

/* Common Modal Styles */
.booking-modal,
.contact-modal,
.callback-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 40px 16px;
  z-index: 1300;
}

.booking-modal.is-visible,
.contact-modal.is-visible,
.callback-modal.is-visible {
  display: flex;
}

.callback-modal {
  z-index: 1400;
}

.booking-modal__overlay,
.contact-modal__overlay,
.callback-modal__overlay {
  position: absolute;
  inset: 0;
}

.booking-modal__dialog,
.contact-modal__dialog,
.callback-modal__dialog {
  position: relative;
  background: #000000;
  border-radius: 28px;
  max-width: 1000px;
  width: 100%;
  max-height: 90vh;
  overflow: hidden;
  box-shadow: 0 40px 80px rgba(0, 0, 0, 0.3);
  z-index: 1;
  display: flex;
}

.booking-modal__close,
.contact-modal__close,
.callback-modal__close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.2);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease, transform 0.2s ease;
  cursor: pointer;
  z-index: 100;
  font-size: 20px;
}

.booking-modal__close:hover,
.contact-modal__close:hover,
.callback-modal__close:hover {
  background: rgba(255, 255, 255, 0.3);
  transform: rotate(90deg);
}

.booking-modal__container,
.contact-modal__container,
.callback-modal__container {
  display: flex;
  width: 100%;
  min-height: 600px;
}

.booking-modal__image,
.contact-modal__image,
.callback-modal__image {
  flex: 0 0 50%;
  position: relative;
  overflow: hidden;
}

.booking-modal__image img,
.contact-modal__image img,
.callback-modal__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.booking-modal__content,
.contact-modal__content,
.callback-modal__content {
  flex: 0 0 50%;
  background: #181d24;
  color: #ffffff;
  padding: 60px 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow-y: auto;
  max-height: 90vh;
}

.booking-modal__logo,
.contact-modal__logo,
.callback-modal__logo {
  text-align: center;
}

.booking-modal__logo {
  margin-bottom: 10px;
}

.contact-modal__logo {
  margin-bottom: 0px;
}

.callback-modal__logo {
  margin-bottom: 40px;
}

.booking-modal__logo img,
.contact-modal__logo img,
.callback-modal__logo img {
  max-width: 120px;
  height: auto;
}

.booking-modal__title {
  font-size: 36px;
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 10px 0;
  color: #ffffff;
  text-align: center;
}

.booking-modal__subtitle {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.4;
  margin: 0 0 30px 0;
  color: rgba(255, 255, 255, 0.8);
  text-align: center;
}

.booking-modal__form,
.contact-modal__form,
.callback-modal__form {
  display: flex;
  flex-direction: column;
}

.booking-modal__form,
.callback-modal__form {
  gap: 24px;
}

.contact-modal__form {
  gap: 12px;
}

.booking-modal__field,
.contact-modal__field,
.callback-modal__field {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.booking-modal__label,
.contact-modal__label,
.callback-modal__label {
  font-size: 14px;
  font-weight: 500;
  color: #ffffff;
}

.booking-modal__input,
.contact-modal__input,
.contact-modal__textarea,
.callback-modal__input {
  width: 100%;
  padding: 16px 20px;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  border-radius: 8px;
  font-size: 16px;
  font-family: inherit;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.1);
  transition: all 0.3s ease;
  box-sizing: border-box;
}

.contact-modal__textarea {
  resize: vertical;
  min-height: 120px;
  font-family: inherit;
}

.booking-modal__input::placeholder,
.contact-modal__input::placeholder,
.contact-modal__textarea::placeholder,
.callback-modal__input::placeholder {
  color: rgba(255, 255, 255, 0.5);
  opacity: 1;
}

.booking-modal__input:focus,
.contact-modal__input:focus,
.contact-modal__textarea:focus,
.callback-modal__input:focus {
  outline: none;
  border-color: var(--color-accent-1);
  background: rgba(255, 255, 255, 0.15);
}

.booking-modal__radio-group,
.contact-modal__radio-group,
.callback-modal__radio-group {
  display: flex;
  gap: 12px;
}

.booking-modal__radio,
.contact-modal__radio,
.callback-modal__radio {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  transition: all 0.3s ease;
  flex: 1;
  justify-content: center;
  position: relative;
}

.booking-modal__radio,
.callback-modal__radio {
  padding: 12px 20px;
}

.contact-modal__radio {
  padding: 12px 12px;
}

.booking-modal__radio input[type="radio"],
.contact-modal__radio input[type="radio"],
.callback-modal__radio input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  margin: 0;
  cursor: pointer;
}

.booking-modal__radio input[type="radio"]:checked + span,
.contact-modal__radio input[type="radio"]:checked + span,
.callback-modal__radio input[type="radio"]:checked + span {
  font-weight: 600;
}

.booking-modal__radio:has(input[type="radio"]:checked),
.contact-modal__radio:has(input[type="radio"]:checked),
.callback-modal__radio:has(input[type="radio"]:checked) {
  border-color: var(--color-accent-1);
  background: rgba(194, 159, 123, 0.2);
}

.booking-modal__radio span,
.contact-modal__radio span,
.callback-modal__radio span {
  color: #ffffff;
  user-select: none;
}

.booking-modal__radio span,
.contact-modal__radio span {
  font-size: 14px;
}

.callback-modal__radio span {
  font-size: 15px;
}

.booking-modal__submit,
.contact-modal__submit,
.callback-modal__submit {
  width: 100%;
  padding: 18px 24px;
  background: var(--color-accent-1);
  color: #ffffff;
  border: none;
  border-radius: 8px;
  font-size: 18px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 8px;
}

.booking-modal__submit:hover,
.contact-modal__submit:hover,
.callback-modal__submit:hover {
  background: #d1c28c;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(194, 159, 123, 0.3);
}

.booking-modal__submit i,
.contact-modal__submit i,
.callback-modal__submit i {
  font-size: 20px;
}

.booking-modal__consent,
.contact-modal__consent,
.callback-modal__consent {
  margin-top: 8px;
}

.booking-modal__checkbox,
.contact-modal__checkbox,
.callback-modal__checkbox {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  font-size: 12px;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.7);
}

.booking-modal__checkbox input[type="checkbox"],
.contact-modal__checkbox input[type="checkbox"],
.callback-modal__checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin: 0;
  cursor: pointer;
  flex-shrink: 0;
  margin-top: 2px;
  accent-color: var(--color-accent-1);
}

.booking-modal__checkbox span,
.contact-modal__checkbox span,
.callback-modal__checkbox span {
  user-select: none;
}

@media (max-width: 991px) {
  .booking-modal__container,
  .contact-modal__container,
  .callback-modal__container {
    flex-direction: column;
    min-height: auto;
  }
  
  .booking-modal__image,
  .contact-modal__image,
  .callback-modal__image {
    display: none;
  }
  
  .booking-modal__content,
  .contact-modal__content,
  .callback-modal__content {
    flex: 1;
    padding: 40px 30px;
    max-height: none;
  }
}

@media (max-width: 575px) {
  .booking-modal__dialog,
  .contact-modal__dialog,
  .callback-modal__dialog {
    max-width: 100%;
    border-radius: 20px;
  }
  
  .booking-modal__content,
  .contact-modal__content,
  .callback-modal__content {
    padding: 30px 20px;
    max-height: none;
  }
  
  .booking-modal__radio-group,
  .contact-modal__radio-group {
    flex-direction: row;
    flex-wrap: nowrap;
  }
  
  .callback-modal__radio-group {
    flex-direction: column;
  }
}

/* Contact Modal Specific Styles */

.contact-modal__title {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 10px 0;
  color: #ffffff;
  text-align: center;
}

.contact-modal__subtitle {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.4;
  margin: 0 0 30px 0;
  color: rgba(255, 255, 255, 0.8);
  text-align: center;
}

/* Contact Modal Specific Styles */

.cta-request-section {
  padding: 0;
  background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
  position: relative;
  overflow: hidden;
}

.cta-request {
  width: 100%;
}

.cta-request__content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 600px;
}

@media (max-width: 991px) {
  .cta-request__content {
    grid-template-columns: 1fr;
    min-height: auto;
  }
}

.cta-request__form-wrapper {
  padding: 80px 60px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: transparent;
  position: relative;
  z-index: 1;
}

@media (max-width: 1199px) {
  .cta-request__form-wrapper {
    padding: 60px 40px;
  }
}

@media (max-width: 767px) {
  .cta-request__form-wrapper {
    padding: 40px 24px;
  }
}

.cta-request__title {
  font-size: 62px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--color-dark-1);
  margin: 0 0 24px 0;
  text-transform: uppercase;
}

.cta-request__title .text-accent-1 {
  color: var(--color-accent-1);
}

@media (max-width: 767px) {
  .cta-request__title {
    font-size: 38px;
  }
}

.cta-request__subtitle {
  font-size: 18px;
  line-height: 1.7;
  color: rgba(27, 27, 27, 0.7);
  margin: 0 0 40px 0;
}

@media (max-width: 767px) {
  .cta-request__subtitle {
    font-size: 16px;
    margin-bottom: 30px;
  }
}

.cta-request__form {
  padding: 40px 44px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

@media (max-width: 767px) {
  .cta-request__form {
    padding: 30px 24px;
  }
}

.cta-request__field {
  width: 100%;
  position: relative;
  z-index: 1;
}

.cta-request__input {
  width: 100%;
  padding: 16px 20px;
  border: 2px solid rgba(27, 27, 27, 0.1);
  border-radius: 12px;
  font-size: 16px;
  font-family: inherit;
  color: var(--color-dark-1);
  background: #ffffff;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  box-sizing: border-box;
}

.cta-request__input::placeholder {
  color: rgba(27, 27, 27, 0.5);
  opacity: 1;
}

.cta-request__input:focus {
  outline: none;
  border-color: var(--color-accent-1);
  box-shadow: 0 0 0 3px rgba(209, 194, 140, 0.15);
  background: #ffffff;
}

.cta-request__phone-wrapper {
  display: flex;
  align-items: center;
  border: 2px solid rgba(27, 27, 27, 0.1);
  border-radius: 12px;
  background: #ffffff;
  overflow: hidden;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.cta-request__phone-prefix {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 16px 18px;
  background: rgba(247, 240, 236, 0.6);
  border-right: 2px solid rgba(27, 27, 27, 0.1);
  white-space: nowrap;
}

.cta-request__flag {
  font-size: 20px;
  line-height: 1;
}

.cta-request__code {
  font-size: 16px;
  font-weight: 500;
  color: var(--color-dark-1);
}

.cta-request__input--phone {
  border: none;
  border-radius: 0;
  flex: 1;
  padding-left: 16px;
}

.cta-request__input--phone:focus {
  box-shadow: none;
}

.cta-request__phone-wrapper:focus-within {
  border-color: var(--color-accent-1);
  box-shadow: 0 0 0 3px rgba(209, 194, 140, 0.15);
}

.cta-request__contact-methods {
  display: flex;
  gap: 12px;
}

.cta-request__method-btn {
  flex: 1;
  padding: 14px 20px;
  border: 2px solid rgba(27, 27, 27, 0.15);
  border-radius: 12px;
  background: #ffffff;
  color: var(--color-dark-1);
  font-size: 15px;
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  text-align: center;
}

.cta-request__method-btn:hover {
  border-color: var(--color-accent-1);
  background: linear-gradient(135deg, rgba(209, 194, 140, 0.1) 0%, rgba(209, 194, 140, 0.05) 100%);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(209, 194, 140, 0.2);
}

.cta-request__method-btn--active {
  background: linear-gradient(135deg, var(--color-accent-1) 0%, rgba(209, 194, 140, 0.9) 100%);
  color: var(--color-dark-1);
  border-color: var(--color-accent-1);
  box-shadow: 0 2px 8px rgba(209, 194, 140, 0.3);
}

.cta-request__method-btn--active:hover {
  background: linear-gradient(135deg, rgba(209, 194, 140, 0.95) 0%, var(--color-accent-1) 100%);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(209, 194, 140, 0.4);
}

.cta-request__submit {
  width: 100%;
  padding: 18px 32px;
  background: linear-gradient(135deg, var(--color-accent-1) 0%, rgba(209, 194, 140, 0.9) 100%);
  color: var(--color-dark-1);
  border: 2px solid var(--color-accent-1);
  border-radius: 12px;
  font-size: 16px;
  font-weight: 500;
  font-family: inherit;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  margin-top: 8px;
  box-shadow: 0 4px 12px rgba(209, 194, 140, 0.25);
}

.cta-request__submit:hover {
  background: linear-gradient(135deg, rgba(209, 194, 140, 0.95) 0%, var(--color-accent-1) 100%);
  transform: translateY(-4px);
  box-shadow: 0 8px 20px rgba(209, 194, 140, 0.35);
}

.cta-request__privacy {
  font-size: 12px;
  line-height: 1.6;
  color: rgba(27, 27, 27, 0.6);
  margin: 16px 0 0 0;
  text-align: center;
  position: relative;
  z-index: 1;
}

.cta-request__image {
  position: relative;
  overflow: hidden;
  background: var(--color-dark-1);
}

.cta-request__image::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(209, 194, 140, 0.1) 0%, transparent 100%);
  z-index: 1;
  pointer-events: none;
}

.cta-request__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

@media (max-width: 991px) {
  .cta-request__image {
    min-height: 400px;
  }
}

.construction-timeline-section {
  background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
  position: relative;
  padding-top: 60px !important;
}

@media (max-width: 767px) {
  .construction-timeline-section {
    padding-top: 40px !important;
  }
}

@media (max-width: 575px) {
  .construction-timeline-section {
    padding-top: 30px !important;
  }
}

.construction-timeline {
  position: relative;
  max-width: 1200px;
  margin: 80px auto 0;
  padding: 0 20px;
  margin-top: 13rem;
}

@media (max-width: 991px) {
  .construction-timeline {
    margin-top: 60px;
    padding: 0 10px;
  }
}

.construction-timeline__line {
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--color-accent-1) 0%, rgba(209, 194, 140, 0.3) 100%);
  transform: translateX(-50%);
  z-index: 0;
}

@media (max-width: 991px) {
  .construction-timeline__line {
    left: 30px;
    transform: none;
  }
}

.construction-timeline__item {
  position: relative;
  display: flex;
  align-items: center;
  margin-bottom: 3rem;
  z-index: 1;
  margin-top: -10rem;
}

.construction-timeline__item:last-child {
  margin-bottom: 0;
}

@media (max-width: 991px) {
  .construction-timeline__item {
    margin-bottom: 40px;
    padding-left: 60px;
    margin-top: 0rem;
  }
}

.construction-timeline__marker {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
  border-radius: 50%;
}

@media (max-width: 991px) {
  .construction-timeline__marker {
    left: 22px;
    transform: translateX(-50%);
    width: 50px;
    height: 50px;
  }
  
  .construction-timeline__dot {
    width: 18px;
    height: 18px;
    border: 3px solid #ffffff;
  }
  
  .construction-timeline__dot--active {
    width: 20px;
    height: 20px;
  }
}

.construction-timeline__dot {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--color-accent-1);
  border: 4px solid #ffffff;
  box-shadow: 0 0 0 3px var(--color-accent-1), 0 4px 12px rgba(209, 194, 140, 0.3);
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.construction-timeline__dot--active {
  width: 24px;
  height: 24px;
  background: linear-gradient(135deg, var(--color-accent-1) 0%, rgba(209, 194, 140, 0.9) 100%);
  box-shadow: 0 0 0 4px #ffffff, 0 0 0 7px var(--color-accent-1), 0 6px 20px rgba(209, 194, 140, 0.4);
  animation: pulse 2s infinite;
}

@keyframes pulse {
  0%, 100% {
    box-shadow: 0 0 0 4px #ffffff, 0 0 0 7px var(--color-accent-1), 0 6px 20px rgba(209, 194, 140, 0.4);
  }
  50% {
    box-shadow: 0 0 0 4px #ffffff, 0 0 0 10px rgba(209, 194, 140, 0.3), 0 6px 20px rgba(209, 194, 140, 0.4);
  }
}

.construction-timeline__card {
  width: calc(50% - 50px);
  padding: 30px 32px;
  backdrop-filter: blur(6px);
  transition: all 0.35s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.construction-timeline__card:hover {
  transform: translateY(-10px);
  box-shadow: 0 26px 60px rgba(27, 27, 27, 0.12);
}

.construction-timeline__card--left {
  margin-right: auto;
  margin-left: 0;
}

.construction-timeline__card--right {
  margin-left: auto;
  margin-right: 0;
}

@media (max-width: 991px) {
  .construction-timeline__card {
    width: 100%;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}

.construction-timeline__date {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 20px;
  position: relative;
  z-index: 1;
}

.construction-timeline__quarter {
  font-size: 18px;
  font-weight: 600;
  color: var(--color-accent-1);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.construction-timeline__year {
  font-size: 32px;
  font-weight: 500;
  color: var(--color-dark-1);
  line-height: 1;
}

.construction-timeline__image {
  width: 100%;
  height: 200px;
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 20px;
  position: relative;
  z-index: 1;
  background: var(--color-dark-1);
}

.construction-timeline__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.construction-timeline__card:hover .construction-timeline__image img {
  transform: scale(1.05);
}

.construction-timeline__description {
  font-size: 16px;
  line-height: 1.7;
  color: rgba(27, 27, 27, 0.8);
  margin: 0;
  position: relative;
  z-index: 1;
}

@media (max-width: 767px) {
  .construction-timeline__card {
    padding: 24px 20px;
  }
  
  .construction-timeline__quarter {
    font-size: 16px;
  }
  
  .construction-timeline__year {
    font-size: 28px;
  }
  
  .construction-timeline__image {
    height: 180px;
  }
  
  .construction-timeline__description {
    font-size: 15px;
  }
}

.map-container{
  position:relative;
}
.map {
  flex: 1;
  height: 500px;
}

.category {
  padding: 15px 30px;
  margin: 10px 0;
  background: var(--color-accent-1);
  border-radius: 0;
  cursor: pointer;
  transition: all 0.3s ease;
  color: #ffffff;
  border: none;
  font-size: 16px;
  font-weight: 500;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.category:hover {
  background: #d1c28c;
  transform: translateX(5px);
}

.category.active {
  background: var(--color-accent-1);
  box-shadow: 0 4px 12px rgba(194, 159, 123, 0.3);
  color:black
}

.category span {
  margin-left: 8px;
}

@media (max-width: 767px) {
  .category {
    padding: 0;
    width: 48px;
    height: 48px;
    min-width: 48px;
    justify-content: center;
    align-items: center;
    font-size: 24px;
    margin: 5px 0;
    border-radius: 8px;
    position: relative;
    overflow: hidden;
  }
  
  .category span {
    display: none;
  }
  
  .category {
    font-size: 0;
  }
  
  .category::before {
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    font-size: 24px;
    line-height: 48px;
    text-align: center;
  }
  
  .category[data-category="shop"]::before {
    content: '🛒';
  }
  
  .category[data-category="kindergarten"]::before {
    content: '🧸';
  }
  
  .category[data-category="school"]::before {
    content: '📚';
  }
  
  .category[data-category="pharmacy"]::before {
    content: '💊';
  }
  
  .category[data-category="cafe"]::before {
    content: '☕';
  }
}

#sidebar{
  position: absolute;
  top:  8rem;
}

/* Callback Modal Specific Styles */
.callback-modal__title {
  font-size: 48px;
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 10px 0;
  color: #ffffff;
  text-align: center;
}

.callback-modal__subtitle {
  font-size: 32px;
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 30px 0;
  color: #ffffff;
  text-align: center;
}

.callback-modal__description {
  font-size: 16px;
  line-height: 1.6;
  margin: 0 0 40px 0;
  color: rgba(255, 255, 255, 0.8);
  text-align: center;
}

@media (max-width: 991px) {
  .callback-modal__title {
    font-size: 36px;
  }
  
  .callback-modal__subtitle {
    font-size: 24px;
  }
}

@media (max-width: 575px) {
  .callback-modal__title {
    font-size: 28px;
  }
  
  .callback-modal__subtitle {
    font-size: 20px;
  }
}

/* Documents Modal */
.documents-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 40px 16px;
  z-index: 1400;
}

.documents-modal.is-visible {
  display: flex;
}

.documents-modal__overlay {
  position: absolute;
  inset: 0;
}

.documents-modal__dialog {
  position: relative;
  background: #ffffff;
  border-radius: 28px;
  max-width: 900px;
  width: 100%;
  max-height: 90vh;
  overflow: hidden;
  box-shadow: 0 40px 80px rgba(0, 0, 0, 0.3);
  z-index: 1;
  display: flex;
  flex-direction: column;
}

.documents-modal__close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  background: rgba(0, 0, 0, 0.1);
  color: #181d24;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease, transform 0.2s ease;
  cursor: pointer;
  z-index: 100;
  font-size: 20px;
}

.documents-modal__close:hover {
  background: rgba(0, 0, 0, 0.2);
  transform: rotate(90deg);
}

.documents-modal__container {
  padding: 60px 50px;
  overflow-y: auto;
  max-height: calc(90vh - 120px);
}

.documents-modal__title {
  font-size: 36px;
  font-weight: 700;
  color: #181d24;
  margin: 0 0 40px 0;
  text-align: center;
}

.documents-modal__table-wrapper {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.documents-modal__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 16px;
}

.documents-modal__table thead {
  background: #f5f5f5;
}

.documents-modal__table th {
  padding: 16px 20px;
  text-align: left;
  font-weight: 600;
  color: #181d24;
  border-bottom: 2px solid #e0e0e0;
  white-space: nowrap;
}

.documents-modal__table th:first-child {
  width: 50%;
}

.documents-modal__table th:nth-child(2) {
  width: 20%;
  text-align: center;
}

.documents-modal__table th:last-child {
  width: 30%;
  text-align: center;
}

.documents-modal__table tbody tr {
  border-bottom: 1px solid #e0e0e0;
  transition: background 0.2s ease;
}

.documents-modal__table tbody tr:hover {
  background: #f9f9f9;
}

.documents-modal__table td {
  padding: 20px;
  color: #181d24;
  vertical-align: middle;
}

.documents-modal__table td:first-child {
  font-weight: 500;
}

.documents-modal__table td:nth-child(2) {
  text-align: center;
  color: #666666;
}

.documents-modal__table td:last-child {
  text-align: center;
}

.documents-modal__download {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  background: var(--color-accent-1);
  color: #ffffff;
  text-decoration: none;
  border-radius: 8px;
  font-weight: 500;
  transition: background 0.3s ease, transform 0.2s ease;
  font-size: 14px;
}

.documents-modal__download:hover {
  background: #d1c28c;
  transform: translateY(-2px);
  text-decoration: none;
}

.documents-modal__download i {
  font-size: 16px;
}

@media (max-width: 991px) {
  .documents-modal__container {
    padding: 40px 30px;
  }
  
  .documents-modal__title {
    font-size: 28px;
    margin-bottom: 30px;
  }
  
  .documents-modal__table {
    font-size: 14px;
  }
  
  .documents-modal__table th,
  .documents-modal__table td {
    padding: 12px 15px;
  }
}

@media (max-width: 575px) {
  .documents-modal__dialog {
    max-width: 100%;
    border-radius: 20px;
  }
  
  .documents-modal__container {
    padding: 30px 20px;
  }
  
  .documents-modal__title {
    font-size: 24px;
    margin-bottom: 20px;
  }
  
  .documents-modal__table {
    font-size: 12px;
  }
  
  .documents-modal__table th,
  .documents-modal__table td {
    padding: 10px 8px;
  }
  
  .documents-modal__download {
    padding: 8px 16px;
    font-size: 12px;
  }
}

.toast-container {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 10000;
  display: flex;
  flex-direction: column;
  gap: 12px;
  pointer-events: none;
  max-width: 400px;
  width: calc(100% - 40px);
}

.toast {
  position: relative;
  background: #ffffff;
  border-radius: 12px;
  padding: 20px 24px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  display: flex;
  align-items: flex-start;
  gap: 16px;
  pointer-events: auto;
  animation: toastSlideIn 0.3s ease-out;
  border-left: 4px solid var(--color-accent-1);
}

.toast.-success {
  border-left-color: #4caf50;
}

/* Большое заметное уведомление для успешной отправки форм */
.toast.-success.-large {
  padding: 32px 40px;
  max-width: 500px;
  border-left-width: 6px;
  box-shadow: 0 12px 40px rgba(76, 175, 80, 0.25);
  background: linear-gradient(135deg, #ffffff 0%, #f8fff8 100%);
}

.toast.-success.-large .toast__icon {
  width: 48px;
  height: 48px;
  font-size: 24px;
  background: linear-gradient(135deg, #4caf50 0%, #45a049 100%);
  box-shadow: 0 4px 12px rgba(76, 175, 80, 0.3);
}

.toast.-success.-large .toast__title {
  font-size: 24px;
  font-weight: 700;
  color: #2e7d32;
  margin-bottom: 8px;
}

.toast.-success.-large .toast__message {
  font-size: 16px;
  color: #555555;
  line-height: 1.6;
}

.toast.-success.-large .toast__close {
  width: 28px;
  height: 28px;
  font-size: 22px;
  top: 16px;
  right: 16px;
}

.toast.-error {
  border-left-color: #f44336;
}

.toast.-warning {
  border-left-color: #ff9800;
}

.toast.-info {
  border-left-color: #2196f3;
}

@keyframes toastSlideIn {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes toastSlideOut {
  from {
    transform: translateX(0);
    opacity: 1;
  }
  to {
    transform: translateX(100%);
    opacity: 0;
  }
}

.toast.is-hiding {
  animation: toastSlideOut 0.3s ease-in forwards;
}

.toast__icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: 14px;
  color: #ffffff;
}

.toast.-success .toast__icon {
  background: #4caf50;
}

.toast.-error .toast__icon {
  background: #f44336;
}

.toast.-warning .toast__icon {
  background: #ff9800;
}

.toast.-info .toast__icon {
  background: #2196f3;
}

.toast__icon::before {
  content: '✓';
  font-weight: bold;
}

.toast.-error .toast__icon::before {
  content: '✕';
}

.toast.-warning .toast__icon::before {
  content: '!';
}

.toast.-info .toast__icon::before {
  content: 'i';
}

.toast__content {
  flex: 1;
  min-width: 0;
}

.toast__title {
  font-size: 16px;
  font-weight: 600;
  color: #181d24;
  margin: 0 0 4px 0;
  line-height: 1.4;
}

.toast__message {
  font-size: 14px;
  color: #666666;
  margin: 0;
  line-height: 1.5;
}

.toast__close {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border: none;
  background: transparent;
  color: #999999;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: color 0.2s ease;
  font-size: 18px;
  line-height: 1;
}

.toast__close:hover {
  color: #181d24;
}

.toast__close::before {
  content: '×';
  font-weight: 300;
}

@media (max-width: 575px) {
  .toast-container {
    top: 10px;
    right: 10px;
    left: 10px;
    width: calc(100% - 20px);
    max-width: none;
  }
  
  .toast {
    padding: 16px 20px;
  }
  
  .toast__title {
    font-size: 15px;
  }
  
  .toast__message {
    font-size: 13px;
  }
}

.bsod.hidden {
  display: none;
}

.bsod {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: #0078d7; /* классический синий */
  color: #ffffff;
  font-family: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: left;
}

.bsod-content {
  max-width: 720px;
  margin: 0 20px;
}

.bsod-face {
  font-size: 96px;
  line-height: 1;
  margin-bottom: 20px;
}

.bsod-text p {
  font-size: 20px;
  line-height: 1.5;
  margin: 10px 0;
}

.bsod-text strong {
  font-weight: 600;
}

.bsod-hint {
  margin-top: 30px;
  font-size: 16px;
  opacity: 0.8;
}

body.bsod-lock {
  overflow: hidden;
}

/* Success Thank You Modal */
.success-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.8);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 40px 16px;
  z-index: 1500;
  animation: fadeIn 0.3s ease-out;
}

.success-modal.is-visible {
  display: flex;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.success-modal__overlay {
  position: absolute;
  inset: 0;
  cursor: pointer;
}

.success-modal__dialog {
  position: relative;
  background: #ffffff;
  border-radius: 24px;
  max-width: 500px;
  width: 100%;
  box-shadow: 0 40px 80px rgba(0, 0, 0, 0.4);
  z-index: 1;
  animation: slideUp 0.4s ease-out;
  overflow: hidden;
}

@keyframes slideUp {
  from {
    transform: translateY(30px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.success-modal__close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  background: rgba(0, 0, 0, 0.05);
  color: #181d24;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease, transform 0.2s ease;
  cursor: pointer;
  z-index: 100;
  font-size: 20px;
}

.success-modal__close:hover {
  background: rgba(0, 0, 0, 0.1);
  transform: rotate(90deg);
}

.success-modal__container {
  padding: 60px 50px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}

.success-modal__icon {
  animation: scaleIn 0.5s ease-out 0.2s both;
}

@keyframes scaleIn {
  from {
    transform: scale(0);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}

.success-modal__title {
  font-size: 42px;
  font-weight: 700;
  color: #181d24;
  margin: 0;
  line-height: 1.2;
  animation: fadeInUp 0.5s ease-out 0.3s both;
}

@keyframes fadeInUp {
  from {
    transform: translateY(20px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.success-modal__message {
  font-size: 18px;
  color: #666666;
  margin: 0;
  line-height: 1.6;
  animation: fadeInUp 0.5s ease-out 0.4s both;
}

.success-modal__button {
  margin-top: 8px;
  padding: 16px 40px;
  font-size: 16px;
  font-weight: 600;
  border-radius: 12px;
  transition: all 0.3s ease;
  animation: fadeInUp 0.5s ease-out 0.5s both;
  cursor: pointer;
  border: none;
}

.success-modal__button:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(194, 159, 123, 0.3);
}

@media (max-width: 575px) {
  .success-modal__dialog {
    max-width: 100%;
    border-radius: 20px;
  }
  
  .success-modal__container {
    padding: 50px 30px;
    gap: 20px;
  }
  
  .success-modal__title {
    font-size: 32px;
  }
  
  .success-modal__message {
    font-size: 16px;
  }
  
  .success-modal__icon svg {
    width: 60px;
    height: 60px;
  }
}

/* Advantages Section Styles */
.advantages-section {
  background-color: #f5f5f5;
}

.advantages-section__title {
  font-size: 42px;
  font-weight: 600;
  color: #333333;
  line-height: 1.3;
  margin-bottom: 60px;
}

@media (max-width: 991px) {
  .advantages-section__title {
    font-size: 32px;
  }
}

@media (max-width: 767px) {
  .advantages-section__title {
    font-size: 28px;
    margin-bottom: 40px;
  }
}

.advantages-card {
  background-color: #ffffff;
  border-radius: 12px;
  padding: 40px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  height: 100%;
  display: flex;
  flex-direction: column;
}

.advantages-card--large {
  min-height: 600px;
}

.advantages-card--small {
  min-height: 280px;
}

.advantages-card__title {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 20px;
  color: #0052CC;
}

.advantages-card__text {
  font-size: 16px;
  line-height: 1.6;
  color: #333333;
  margin-bottom: 30px;
  flex-grow: 1;
}

.advantages-card__image {
  width: 100%;
  height: auto;
  margin-top: auto;
  border-radius: 8px;
  overflow: hidden;
}

.advantages-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.advantages-card__icon {
  width: 48px;
  height: 48px;
  margin-bottom: 20px;
  color: var(--color-accent-1);
  flex-shrink: 0;
}

.advantages-card__icon svg {
  width: 100%;
  height: 100%;
}

.advantages-card__heading {
  font-size: 18px;
  font-weight: 600;
  line-height: 1.4;
  color: #333333;
  margin-bottom: 15px;
}

.advantages-card__description {
  font-size: 16px;
  line-height: 1.6;
  color: #666666;
  margin: 0;
  margin-bottom: 15px;
}

.advantages-card__list {
  list-style: none;
  padding: 0;
  margin: 0 0 20px 0;
}

.advantages-card__list-item {
  position: relative;
  padding-left: 28px;
  margin-bottom: 12px;
  font-size: 16px;
  line-height: 1.6;
  color: #333333;
}

.advantages-card__list-item::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 0;
  width: 20px;
  height: 20px;
  background-color: var(--color-accent-1);
  color: #ffffff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}

.advantages-card__callout {
  font-size: 18px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--color-accent-1);
  margin: 20px 0 0 0;
  padding-top: 20px;
  border-top: 2px solid #f0f0f0;
}

.advantages-card__steps {
  list-style: none;
  padding: 0;
  margin: 15px 0 0 0;
  counter-reset: step-counter;
}

.advantages-card__steps-item {
  position: relative;
  padding-left: 40px;
  margin-bottom: 12px;
  font-size: 15px;
  line-height: 1.6;
  color: #555555;
  counter-increment: step-counter;
}

.advantages-card__steps-item::before {
  content: counter(step-counter);
  position: absolute;
  left: 0;
  top: 0;
  width: 28px;
  height: 28px;
  background-color: var(--color-accent-1);
  color: #ffffff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  flex-shrink: 0;
}

.text-accent-blue {
  color: var(--color-accent-1) !important;
}

.advantages-banner {
  background-color: var(--color-accent-1);
  border-radius: 12px;
  padding: 24px 32px;
  min-height: 80px;
  display: flex;
  align-items: center;
  box-shadow: 0 2px 8px rgba(184, 157, 111, 0.2);
}

.advantages-banner__content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  gap: 20px;
}

.advantages-banner__text {
  font-size: 20px;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.3;
  flex-grow: 1;
}

.advantages-banner__icon {
  width: 32px;
  height: 32px;
  color: #ffffff;
  flex-shrink: 0;
}

.advantages-banner__icon svg {
  width: 100%;
  height: 100%;
}

@media (max-width: 991px) {
  .advantages-card {
    padding: 30px;
  }
  
  .advantages-card--large {
    min-height: 500px;
  }
  
  .advantages-card--small {
    min-height: 250px;
  }
  
  .advantages-card__title {
    font-size: 20px;
  }
  
  .advantages-banner {
    padding: 20px 24px;
    min-height: 70px;
  }
  
  .advantages-banner__text {
    font-size: 18px;
  }
}

@media (max-width: 767px) {
  .advantages-card {
    padding: 24px;
  }
  
  .advantages-card--large {
    min-height: auto;
  }
  
  .advantages-card--small {
    min-height: auto;
  }
  
  .advantages-card__title {
    font-size: 18px;
    margin-bottom: 15px;
  }
  
  .advantages-card__text {
    font-size: 14px;
    margin-bottom: 20px;
  }
  
  .advantages-card__heading {
    font-size: 16px;
  }
  
  .advantages-card__description {
    font-size: 14px;
  }
  
  .advantages-card__list-item {
    font-size: 14px;
    padding-left: 24px;
    margin-bottom: 10px;
  }
  
  .advantages-card__list-item::before {
    width: 18px;
    height: 18px;
    font-size: 11px;
  }
  
  .advantages-card__callout {
    font-size: 16px;
    padding-top: 15px;
    margin-top: 15px;
  }
  
  .advantages-card__steps-item {
    font-size: 13px;
    padding-left: 36px;
    margin-bottom: 10px;
  }
  
  .advantages-card__steps-item::before {
    width: 24px;
    height: 24px;
    font-size: 12px;
  }
  
  .advantages-banner {
    padding: 16px 20px;
    min-height: 60px;
  }
  
  .advantages-banner__text {
    font-size: 16px;
  }
  
  .advantages-banner__icon {
    width: 24px;
    height: 24px;
  }
}