@charset "UTF-8";
html {
  scroll-behavior: smooth;
}

body {
  -webkit-font-smoothing: antialiased;
  font-family: "Work Sans", sans-serif;
  font-weight: 400;
  font-size: 18px;
  color: #09131D;
}
@media (max-width: 767px) {
  body {
    font-size: 15px;
  }
}

@media (max-width: 767.98px) {
  :root :where(p) {
    font-size: 15px;
    line-height: 24px;
  }
}
@media (min-width: 1400px) {
  .container {
    max-width: 1340px;
  }
  .container-xxl {
    max-width: 1800px !important;
  }
}
.btn.btn-primary {
  padding: 12px 20px;
  background: #695EFF;
  color: #fff;
  border: none;
  border-radius: 100px;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 14px;
  transition: 250ms;
}
.btn.btn-primary:hover {
  background: #736FFA;
}
.btn.btn-secondary {
  padding: 6px 20px;
  background: #379A9A;
  border: none;
  border-radius: 100px;
  font-size: 18px;
  line-height: 28px;
  transition: 250ms;
}
.btn.btn-secondary:hover {
  background: #49adad;
}
.btn i {
  vertical-align: middle;
}

.form-control,
.form-select {
  padding: 10px 12px;
  border: none;
  font-size: 14px;
  line-height: 20px;
  color: #09131D;
  border-radius: 8px;
}
.form-control:focus,
.form-select:focus {
  box-shadow: 0 0 0 0.1rem #695EFF;
}
.form-control::placeholder,
.form-select::placeholder {
  color: #09131D;
}

.invalid-feedback {
  font-size: 14px;
}

.input-group .input-group-text {
  border: none;
  background: #fff;
  color: #379A9A;
  font-size: 14px;
  padding: 10px 12px;
}
.input-group:focus-within {
  box-shadow: 0 0 0 0.1rem #695EFF;
}
.input-group .form-control:focus,
.input-group .form-select:focus {
  box-shadow: none;
}
.input-group[data-label] {
  position: relative;
  background: #fff;
  border-radius: 8px;
}
.input-group[data-label] input {
  opacity: 0;
}
.input-group[data-label]:hover input, .input-group[data-label]:focus-within input, .input-group[data-label]:has(input:not(:placeholder-shown)) input {
  opacity: 1;
}
.input-group[data-label]::after {
  content: attr(data-label);
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  font-size: 14px;
  opacity: 1;
}
.input-group[data-label]:hover::after, .input-group[data-label]:focus-within::after, .input-group[data-label]:has(input:not(:placeholder-shown))::after {
  opacity: 0;
}

.pill-select {
  position: relative;
  width: 100%;
}
.pill-select .pill-select-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  min-height: calc(1.5em + 0.75rem + 2px);
  border: none;
  border-radius: 8px;
  background: var(--bs-body-bg, #fff);
  color: #09131D;
  cursor: pointer;
  user-select: none;
  font-size: 14px;
  line-height: 20px;
}
.pill-select .pill-select-trigger:hover {
  border-color: var(--bs-border-color, #cfd4da);
}
.pill-select .pill-select-trigger:focus {
  outline: none;
  box-shadow: 0 0 0 0.1rem #695EFF;
}
.pill-select .pill-select-value {
  flex: 1 1 auto;
  text-align: left;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pill-select .pill-select-chev {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.15s ease;
  font-size: 12px;
}
.pill-select .pill-select-panel {
  display: none;
  position: absolute;
  left: 0;
  top: calc(100% + 6px);
  width: 100%;
  z-index: 30;
  padding: 10px;
  border: 1px solid var(--bs-border-color, #dee2e6);
  border-radius: 0.5rem;
  background: var(--bs-body-bg, #fff);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.12);
  gap: 8px;
  flex-wrap: wrap;
  max-height: 260px;
  overflow: auto;
}
.pill-select .pill-option {
  border: 1px solid var(--bs-border-color, #dee2e6);
  background: transparent;
  color: var(--bs-body-color, #212529);
  border-radius: 999px;
  padding: 6px 10px;
  line-height: 1.2;
  font-size: 0.875rem;
  cursor: pointer;
  white-space: nowrap;
}
.pill-select .pill-option:hover {
  border-color: rgba(13, 110, 253, 0.6);
  background: rgba(13, 110, 253, 0.06);
}
.pill-select .pill-option:focus {
  outline: none;
  border-color: rgba(13, 110, 253, 0.9);
  box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.2);
}
.pill-select.is-open .pill-select-panel {
  display: flex;
}
.pill-select.is-open .pill-select-chev {
  transform: rotate(180deg);
}
.pill-select.is-open .pill-select-trigger {
  box-shadow: 0 0 0 0.1rem #695EFF;
}
.pill-select.is-disabled {
  opacity: 0.6;
  pointer-events: none;
}

a {
  color: #695EFF;
}

.overflow-x-auto {
  cursor: grab;
  user-select: none;
  scrollbar-width: none;
}
.overflow-x-auto.dragging {
  cursor: grabbing;
}
.overflow-x-auto::-webkit-scrollbar {
  display: none;
}

.modal {
  z-index: 99999;
}

.alert {
  border: 0;
  border-radius: 8px;
  padding: 14px 16px;
  font-size: 16px;
  line-height: 24px;
  margin: 0 0 16px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(9, 19, 29, 0.08);
}
.alert a {
  color: inherit;
  text-decoration: underline;
}
.alert.alert-success {
  border-left: 4px solid #379A9A;
  background: rgba(55, 154, 154, 0.08);
  color: #09131D;
}
.alert.alert-success::before {
  content: "✓";
  display: inline-block;
  margin-right: 10px;
  font-weight: 700;
  color: #379A9A;
}
.alert.alert-danger {
  border-left: 4px solid #C33C54;
  background: rgba(195, 60, 84, 0.1);
  color: #09131D;
}
.alert.alert-danger::before {
  content: "!";
  display: inline-block;
  width: 18px;
  height: 18px;
  margin-right: 10px;
  border-radius: 50%;
  text-align: center;
  line-height: 18px;
  font-weight: 800;
  color: #fff;
  background: #C33C54;
}

.site-header .navbar {
  font-size: 18px;
  background: #fff;
  padding: 20px 0;
}
@media (max-width: 767px) {
  .site-header .navbar {
    padding: 10px 0;
  }
  .site-header .navbar .navbar-collapse {
    padding: 0 20px;
  }
  .site-header .navbar .navbar-collapse .navbar-nav:first-child {
    margin-top: 20px !important;
  }
}
.site-header .navbar .navbar-toggler {
  border: none;
}
.site-header .navbar .navbar-nav {
  gap: 24px;
}
@media (max-width: 767px) {
  .site-header .navbar .navbar-nav {
    gap: 0;
    text-align: center;
  }
}
.site-header .navbar .nav-link {
  color: #09131D;
  position: relative;
}
.site-header .navbar .nav-link.active {
  color: #695EFF;
}
.site-header .navbar .nav-link:not(.nav-link-button):hover:after, .site-header .navbar .nav-link:not(.nav-link-button).active:after {
  content: "";
  height: 1px;
  width: 100%;
  background: #695EFF;
  position: absolute;
  left: 0;
  bottom: 0;
}
.site-header .navbar .nav-link.dropdown-toggle::after {
  display: none;
}
.site-header .navbar .nav-link i {
  font-size: 15px;
}
.site-header .navbar .nav-link i.fa-chevron-down {
  font-size: 12px;
  position: relative;
  top: -3px;
}
.site-header .navbar .nav-link-button {
  background: #379A9A;
  color: #fff;
  border-radius: 30px;
  padding-left: 20px;
  padding-right: 20px;
  transition: 250ms;
}
.site-header .navbar .nav-link-button:hover {
  background: #49adad;
}
.site-header .navbar .dropdown-menu {
  padding: 0;
  border: none;
  border-radius: 0;
  min-width: 0;
}
.site-header .navbar .dropdown-menu .dropdown-item.active, .site-header .navbar .dropdown-menu .dropdown-item:active {
  background: #695EFF;
}
@media (min-width: 600px) {
  .admin-bar .site-header.sticky-top {
    top: 32px;
  }
}

.site-main .wp-block-heading,
.site-main h1, .site-main h2, .site-main h3 {
  font-family: "Playfair", serif;
  font-size: 64px;
  line-height: 64px;
}
@media (max-width: 767px) {
  .site-main .wp-block-heading,
  .site-main h1, .site-main h2, .site-main h3 {
    font-size: 34px;
    line-height: 34px;
  }
}
.site-main section[id],
.site-main article[id] {
  scroll-margin-top: 92px;
}
@media (max-width: 767.98px) {
  .site-main section[id],
  .site-main article[id] {
    scroll-margin-top: 72px;
  }
}
.site-main section.page-title {
  color: #fff;
  padding: 80px;
  background: url("../images/page-title-bg.jpg") -12px -421.52px/168.681% 476.585% no-repeat, linear-gradient(0deg, #379A9A, #379A9A);
  background-blend-mode: multiply, normal;
  background-attachment: fixed;
  background-size: cover;
  background-position: center;
}
@media (max-width: 767px) {
  .site-main section.page-title {
    padding: 28px 16px;
    background-attachment: initial;
    min-height: 140px;
    display: flex;
    align-items: center;
  }
}
.site-main section.contact {
  background: #F5F0E6;
  padding: 80px 0;
  position: relative;
}
.site-main section.contact:before {
  content: "";
  width: 206px;
  height: 150px;
  position: absolute;
  left: 0;
  top: 70px;
  background-image: url("../images/icons/contact.svg");
}
@media (max-width: 1760px) {
  .site-main section.contact:before {
    display: none;
  }
}
.site-main section.contact .favorites {
  font-size: 16px;
  line-height: 24px;
}
.site-main section.contact .favorites .favorites-selected {
  font-weight: 700;
}
.site-main section.contact .favorites .favorites-selected span {
  color: #695EFF;
}
.site-main section.contact .favorites .favorites-selected .btn {
  color: #09131D;
  padding: 4px;
  font-size: 20px;
  line-height: 10px;
  display: inline-block;
  margin: 0;
  border: none;
  box-shadow: none;
  margin-top: -3px;
}
.site-main section.contact .form-check {
  font-size: 16px;
}
.site-main section.contact .contact-card {
  padding: 40px;
  border-radius: 8px;
  background: #fff;
  gap: 24px;
}
@media (max-width: 767px) {
  .site-main section.contact .contact-card {
    flex-wrap: wrap;
  }
}
.site-main section.contact .contact-card .contact-card-photo {
  flex: 0 0 187px;
}
@media (max-width: 767px) {
  .site-main section.contact .contact-card .contact-card-photo {
    flex: 0 0 100%;
  }
  .site-main section.contact .contact-card .contact-card-photo img {
    margin: 0 auto;
    display: block;
  }
}
@media (max-width: 767px) {
  .site-main section.contact .contact-card .contact-card-body {
    flex: 0 0 100%;
    text-align: center;
  }
}
.site-main section.contact .contact-card .contact-card-body .contact-card-name {
  font-size: 20px;
  line-height: 32px;
  font-weight: 700;
}
.site-main section.contact .contact-card .contact-card-body .contact-card-title {
  font-size: 16px;
  color: #379A9A;
  margin-bottom: 20px;
}
.site-main section.contact .contact-card .contact-card-body .contact-card-phone,
.site-main section.contact .contact-card .contact-card-body .contact-card-email {
  padding: 8px 0;
}
.site-main section.contact .contact-card .contact-card-body .contact-card-phone a,
.site-main section.contact .contact-card .contact-card-body .contact-card-email a {
  text-decoration: none;
  color: #09131D;
}
.site-main section.hero .grid {
  display: flex;
  min-height: 375px;
}
@media (max-width: 767px) {
  .site-main section.hero .grid {
    flex-wrap: wrap;
  }
}
.site-main section.hero .grid .left {
  background: #09131D;
  color: #fff;
  padding: 36px 124px;
  display: flex;
  flex-direction: column;
  gap: 17px;
  justify-content: center;
}
@media (max-width: 767px) {
  .site-main section.hero .grid .left {
    padding: 45px 16px;
    flex: 0 0 100%;
  }
}
.site-main section.hero .grid .left h1, .site-main section.hero .grid .left p {
  margin: 0;
}
.site-main section.hero .grid .right {
  background-size: cover;
  background-position: center;
  position: relative;
}
@media (max-width: 767px) {
  .site-main section.hero .grid .right {
    flex: 0 0 100%;
    min-height: 250px;
  }
}
.site-main section.hero .grid .right .btn {
  position: absolute;
  right: 53px;
  bottom: 17px;
}
.site-main section.hero .grid > div {
  flex: 0 0 50%;
}
.site-main section.stats {
  padding: 80px 0;
  background: #F5F0E6;
}
@media (max-width: 767px) {
  .site-main section.stats {
    padding: 30px 0;
  }
}
.site-main section.stats .stat {
  text-align: center;
}
.site-main section.stats .stat .value {
  font-weight: 700;
  font-size: 100px;
  line-height: 100px;
  font-family: "Playfair", serif;
  color: #379A9A;
  margin: -20px 0 16px;
}
@media (max-width: 767px) {
  .site-main section.stats .stat .value {
    font-size: 62px;
    line-height: 62px;
  }
}
.site-main section.stats .stat .label {
  color: #09131D;
  font-size: 16px;
  text-transform: uppercase;
}
.site-main section.hero-slider {
  padding-bottom: 30px;
}
.site-main section.hero-slider .carousel-bg {
  height: calc(100vh - 92px);
  background-position: center;
  background-size: cover;
  position: relative;
}
.site-main section.hero-slider .carousel-bg:before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.3) 100%);
  pointer-events: none;
  z-index: 1;
}
.site-main section.hero-slider .carousel-caption {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  width: 800px;
  max-width: 100%;
}
.site-main section.hero-slider .carousel-caption .carousel-title {
  font-size: 100px;
  line-height: 100px;
  margin-bottom: 12px;
}
@media (max-width: 767px) {
  .site-main section.hero-slider .carousel-caption .carousel-title {
    font-size: 42px;
    line-height: 42px;
  }
}
.site-main section.hero-slider .carousel-caption .carousel-text {
  font-size: 20px;
  line-height: 32px;
}
.site-main section.hero-slider .carousel-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 30px;
  gap: 10px;
}
.site-main section.hero-slider .carousel-controls .carousel-prev,
.site-main section.hero-slider .carousel-controls .carousel-next {
  border: none;
  background: transparent;
  color: #09131D;
  padding: 0;
  line-height: 1;
}
.site-main section.hero-slider .carousel-controls .carousel-indicators {
  position: relative;
  margin: 0;
  gap: 12px;
}
.site-main section.hero-slider .carousel-controls .carousel-indicators button {
  width: 8px;
  height: 8px;
  background: #9DA0A3;
  border: none;
  opacity: 1;
  border-radius: 8px;
  margin: 0;
}
.site-main section.hero-slider .carousel-controls .carousel-indicators button.active {
  background: #379A9A;
}
.site-main section.locations {
  padding: 80px 0;
}
.site-main section.locations .location-card {
  min-height: 362px;
  position: relative;
  background-size: cover;
  background-position: center;
}
.site-main section.locations .location-card:before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.4) 0%, rgba(0, 0, 0, 0.4) 100%);
  pointer-events: none;
  z-index: 1;
}
.site-main section.locations .location-card .location-card-overlay {
  position: absolute;
  z-index: 2;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  color: #fff;
  padding: 24px;
  width: 100%;
}
.site-main section.locations .location-card .location-card-overlay .location-card-title {
  margin: 0;
}
.site-main section.locations .location-card .location-card-overlay .location-card-subtitle {
  font-size: 20px;
  line-height: 32px;
}
.site-main section.locations .location-card .location-card-overlay .location-card-badge {
  margin-bottom: 24px;
}
.site-main section.locations .location-card .location-card-overlay .location-card-badge span {
  padding: 4px 8px;
  background: #fff;
  color: #09131D;
  font-weight: 700;
  display: inline-block;
}
.site-main section.locations .location-card .location-card-overlay .location-card-badge span:before {
  content: "";
  width: 15px;
  height: 15px;
  background-image: url("../images/icons/houses.svg");
  display: inline-block;
  margin: 0 3px;
  vertical-align: middle;
}
.site-main section.articles {
  padding: 80px 0 20px;
}
.site-main section.articles .articles-scroller {
  gap: 24px;
  padding-bottom: 20px;
}
.site-main section.articles article {
  width: 646px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
@media (max-width: 767px) {
  .site-main section.articles article {
    width: 100%;
  }
}
.site-main section.articles article .article-badge {
  font-size: 16px;
  line-height: 24px;
  color: #379A9A;
  text-transform: uppercase;
  min-height: 24px;
}
.site-main section.articles article .article-title {
  font-size: 36px;
  line-height: 36px;
  margin: 0;
}
.site-main section.articles article .article-text {
  margin: 0;
}
.site-main section.media-feature {
  padding: 40px 0;
}
.site-main section.media-feature .row {
  gap: 48px;
}
.site-main section.media-feature .btn {
  margin-top: 50px;
}
.site-main section.offers {
  padding: 80px 0;
}
.site-main section.offers .offer:not(:last-child) {
  margin-bottom: 80px;
}
.site-main section.apartment-filter {
  padding: 60px 0;
  background: #F5F0E6;
}
@media (max-width: 767px) {
  .site-main section.apartment-filter {
    padding: 40px 0;
  }
}
.site-main section.apartment-filter .form-control,
.site-main section.apartment-filter .form-select,
.site-main section.apartment-filter .pill-select-trigger {
  padding: 12px 12px;
  border: 1px solid #09131D;
  border-radius: 100px;
}
.site-main section.apartment-filter .pill-select .pill-select-panel {
  width: auto;
  padding: 15px;
  border: none;
  box-shadow: 1px 1px 24px rgba(25, 26, 38, 0.11);
  border-radius: 24px;
}
.site-main section.apartment-filter .pill-select .pill-select-panel .pill-option {
  padding: 12px 20px;
  border: 1px solid #09131D;
  border-radius: 100px;
  text-align: center;
  font-size: 18px;
  min-width: 60px;
  box-shadow: none;
}
.site-main section.apartment-filter .pill-select .pill-select-panel .pill-option:hover {
  background: transparent;
}
.site-main section.apartment-filter .pill-select .pill-select-panel .pill-option.is-selected {
  background: #379A9A;
  color: #fff;
  border-color: #379A9A;
}
.site-main section.apartment-filter .input-group {
  overflow: hidden;
  border: 1px solid #09131D;
  border-radius: 100px;
}
.site-main section.apartment-filter .input-group .form-control {
  border: none;
  border-radius: 0;
}
.site-main section.apartment-filter .btn-secondary {
  padding: 8px 20px;
}
.site-main section.apartment-filter .btn-secondary i {
  font-size: 12px;
  margin-left: 5px;
}
.site-main section.apartments {
  padding: 80px 0 60px;
}
@media (max-width: 767px) {
  .site-main section.apartments {
    padding: 40px 0;
  }
}
.site-main section.faq {
  padding: 80px 0;
}
@media (max-width: 767px) {
  .site-main section.faq {
    padding: 40px 0;
  }
}
.site-main section.faq h3.pre-header {
  font-size: 16px;
  line-height: 24px;
  color: #379A9A;
  text-transform: uppercase;
  font-family: "Work Sans", sans-serif;
  margin-bottom: 12px;
}
.site-main section.faq h1 {
  font-size: 36px;
  line-height: 36px;
  margin-bottom: 25px;
}
.site-main section.faq .accordion {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.site-main section.faq .accordion .accordion-item {
  border-radius: 8px;
  border: 1px solid #F3F3F5;
  overflow: hidden;
}
.site-main section.faq .accordion .accordion-item .accordion-button {
  padding: 16px;
  font-size: 18px;
  line-height: 28px;
  font-family: "Work Sans", sans-serif;
  background: transparent;
  box-shadow: none;
}
@media (max-width: 767px) {
  .site-main section.faq .accordion .accordion-item .accordion-button {
    font-size: 16px;
    line-height: 24px;
  }
}
.site-main section.faq .accordion .accordion-item .accordion-button:not(.collapsed) {
  background-color: #379A9A;
  color: #fff;
}
.site-main section.faq .accordion .accordion-item .accordion-button:not(.collapsed):after {
  filter: brightness(0) invert(1);
}
.site-main section.faq .accordion .accordion-item .accordion-body {
  font-size: 16px;
}
.site-main section.apartment-back {
  padding: 24px 0;
  background: #F5F0E6;
}
.site-main section.apartment-back a {
  color: #09131D;
  text-decoration: none;
}
.site-main section.apartment-back a i {
  font-size: 14px;
  margin-right: 5px;
}
.site-main section.apartment-details {
  padding: 80px 0 0;
  font-size: 16px;
  line-height: 24px;
}
@media (max-width: 767px) {
  .site-main section.apartment-details {
    padding: 40px 0 0;
  }
}
.site-main section.apartment-details h2 {
  font-size: 36px;
  line-height: 36px;
  font-weight: 700;
}
.site-main section.apartment-details .apartment-sidebar {
  text-align: center;
  background: #09131D;
  color: #fff;
  position: sticky;
  top: 150px;
  padding: 24px 20px;
}
.site-main section.apartment-details .apartment-sidebar hr {
  border-top: 1px solid #FFF;
  margin: 24px -10px;
  opacity: 1;
}
.site-main section.apartment-details .apartment-sidebar .price {
  font-size: 36px;
  line-height: 36px;
  font-family: "Playfair", serif;
  font-weight: 700;
}
.site-main section.apartment-details .apartment-sidebar .address {
  font-size: 16px;
  line-height: 24px;
}
.site-main section.apartment-details .apartment-sidebar .controls {
  gap: 16px;
}
.site-main section.apartment-details .apartment-sidebar .controls a:not(.btn-primary), .site-main section.apartment-details .apartment-sidebar .controls .btn-link {
  color: #fff;
  text-decoration: none;
  font-size: 18px;
  line-height: 28px;
}
.site-main section.apartment-details .carousel .carousel-item {
  height: 458px;
}
@media (max-width: 767px) {
  .site-main section.apartment-details .carousel .carousel-item {
    height: 250px;
  }
}
.site-main section.apartment-details .carousel .carousel-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.site-main section.apartment-details .carousel .carousel-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 30px;
  gap: 10px;
}
.site-main section.apartment-details .carousel .carousel-controls .carousel-prev,
.site-main section.apartment-details .carousel .carousel-controls .carousel-next {
  border: none;
  background: transparent;
  color: #09131D;
  padding: 0;
  line-height: 1;
}
.site-main section.apartment-details .carousel .carousel-controls .carousel-indicators {
  position: relative;
  margin: 0;
  gap: 12px;
}
.site-main section.apartment-details .carousel .carousel-controls .carousel-indicators button {
  width: 8px;
  height: 8px;
  background: #9DA0A3;
  border: none;
  opacity: 1;
  border-radius: 8px;
  margin: 0;
}
.site-main section.apartment-details .carousel .carousel-controls .carousel-indicators button.active {
  background: #379A9A;
}
.site-main section.apartment-details .parameters {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
}
.site-main section.apartment-details .parameters .parameter {
  flex: 0 0 calc(25% - 18px);
  box-sizing: border-box;
}
@media (max-width: 767px) {
  .site-main section.apartment-details .parameters .parameter {
    flex: 0 0 calc(50% - 18px);
    text-align: center;
  }
  .site-main section.apartment-details .parameters .parameter img {
    margin: 0 auto 10px;
    display: block;
  }
}
.site-main section.apartment-details .extras {
  display: flex;
  gap: 24px;
}
@media (max-width: 767px) {
  .site-main section.apartment-details .extras {
    flex-wrap: wrap;
  }
}
@media (max-width: 767px) {
  .site-main section.apartment-details .extras .extra {
    flex: 0 0 100%;
  }
}
.site-main section.apartment-details .extras .extra img {
  margin-bottom: 16px;
}
.site-main section.apartment-details .extras .extra h4 {
  font-family: "Playfair", serif;
  margin-bottom: 16px;
  font-size: 24px;
  line-height: 24px;
  font-weight: 700;
}
.site-main section.estate {
  font-size: 16px;
  line-height: 24px;
}
.site-main section.estate h2 {
  font-size: 36px;
  line-height: 36px;
  font-weight: 700;
}
.site-main section.estate .apartments-scroller {
  gap: 24px;
  padding-bottom: 20px;
}
.site-main section.estate .apartments-scroller .apartment-item {
  width: 422px;
}
@media (max-width: 767px) {
  .site-main section.estate .apartments-scroller .apartment-item {
    width: 100%;
  }
}
.site-main section.estate .apartments-scroller .apartment-item:last-child {
  width: 446px;
  padding-right: 24px;
}
.site-main .apartment-card {
  padding: 16px;
  border: 1px solid #F3F3F5;
  position: relative;
}
.site-main .apartment-card .badges {
  position: absolute;
  left: 16px;
  top: 16px;
  z-index: 2;
  display: flex;
  gap: 4px;
  flex-direction: column;
  align-items: flex-start;
}
.site-main .apartment-card .badges .badge {
  padding: 8px;
  color: #fff;
  background: #379A9A;
  border-radius: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
}
.site-main .apartment-card .badges .badge strong {
  font-weight: 600;
}
.site-main .apartment-card .badges .badge-secondary {
  background: #695EFF;
}
.site-main .apartment-card .carousel .carousel-item {
  height: 218px;
  overflow: hidden;
}
.site-main .apartment-card .carousel .carousel-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.site-main .apartment-card .carousel .carousel-indicators {
  justify-content: flex-end;
  margin: 0;
  right: 4px;
  bottom: 0;
}
.site-main .apartment-card .carousel .carousel-indicators button {
  width: 8px;
  height: 8px;
  background: #9DA0A3;
  border: none;
  border-radius: 8px;
  opacity: 1;
  margin: 8px 4px;
}
.site-main .apartment-card .carousel .carousel-indicators button.active {
  background: #379A9A;
}
.site-main .apartment-card .card-body {
  position: relative;
  margin-top: 16px;
}
.site-main .apartment-card .card-body .btn-save {
  position: absolute;
  right: 0;
  top: 0;
  padding: 0;
  font-size: 24px;
  color: #09131D;
  line-height: 1;
}
.site-main .apartment-card .card-body a {
  text-decoration: none;
  color: #09131D;
}
.site-main .apartment-card .card-body .price {
  font-size: 36px;
  line-height: 36px;
  font-family: "Playfair", serif;
  font-weight: 700;
  margin-bottom: 24px;
}
.site-main .apartment-card .card-body .identifier {
  font-size: 14px;
  line-height: 20px;
  margin-bottom: 8px;
}
.site-main .apartment-card .card-body .address {
  font-size: 18px;
  line-height: 28px;
  margin-bottom: 24px;
}
.site-main .apartment-card .card-body .parameters {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 24px;
  align-self: stretch;
}
.site-main .apartment-card .card-body .parameters .parameter {
  flex: 0 0 60px;
  text-align: center;
  font-size: 16px;
  line-height: 24px;
}
.site-main .offer-card .left {
  height: 100%;
}
.site-main .offer-card .left img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.site-main .offer-card .right {
  height: 100%;
  padding: 24px;
  background: #379A9A;
  color: #fff;
  font-size: 16px;
  line-height: 24px;
}
.site-main .offer-card .right h2 {
  font-size: 36px;
  line-height: 36px;
  font-weight: 700;
}
.site-main .map-embed.leaflet-container {
  background: #ddd;
}
.site-main .map-embed.leaflet-container img.leaflet-tile {
  mix-blend-mode: normal !important;
}
.site-main .map-embed.leaflet-container .leaflet-control-attribution {
  display: none;
}

.site-footer {
  color: #fff;
  background: #09131D;
  padding: 60px 0;
}
.site-footer .footer-top {
  padding-bottom: 24px;
}
.site-footer .footer-top .logo img {
  filter: brightness(0) invert(1);
  max-width: 100%;
}
.site-footer .footer-top .footer-menu {
  list-style-type: none;
  padding: 0;
  margin: 0;
}
@media (min-width: 768px) {
  .site-footer .footer-top .footer-menu {
    columns: 2;
  }
}
.site-footer .footer-top .footer-menu li {
  margin-bottom: 24px;
}
.site-footer .footer-top .footer-menu li a {
  color: #fff;
  text-decoration: none;
  padding: 10px;
}
@media (max-width: 767px) {
  .site-footer .footer-top .footer-menu li a {
    padding: 10px 0;
  }
}
.site-footer .footer-bottom {
  border-top: 1px solid #9DA0A3;
  padding-top: 24px;
  color: #9DA0A3;
  font-size: 16px;
}

@media (min-width: 900px) {
  .apartment-filter-modal .modal-dialog {
    --bs-modal-width: 816px;
  }
}
.apartment-filter-modal .modal-dialog .modal-content {
  border-radius: 0;
  border: none;
  padding: 0 24px;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-header {
  padding: 24px;
  border-bottom: 1px solid #9DA0A3;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-header .modal-title {
  color: #379A9A;
  font-size: 64px;
  line-height: 64px;
  font-weight: 700;
  font-family: "Playfair", serif;
}
@media (max-width: 767px) {
  .apartment-filter-modal .modal-dialog .modal-content .modal-header .modal-title {
    font-size: 32px;
    line-height: 32px;
  }
}
.apartment-filter-modal .modal-dialog .modal-content .modal-header .btn-close {
  opacity: 1;
  box-shadow: none;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body {
  padding: 40px 16px;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .form-label {
  font-family: "Playfair", serif;
  font-weight: 700;
  font-size: 24px;
  line-height: 24px;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .form-control,
.apartment-filter-modal .modal-dialog .modal-content .modal-body .form-select,
.apartment-filter-modal .modal-dialog .modal-content .modal-body .pill-select-trigger {
  padding: 12px 12px;
  border: 1px solid #09131D;
  border-radius: 100px;
  text-align: center;
  font-size: 18px;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .pill-select .pill-select-trigger .pill-select-value {
  text-align: center;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .pill-select.has-value .pill-select-trigger {
  background: #379A9A;
  color: #fff;
  border-color: #379A9A;
  box-shadow: none !important;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .pill-select .pill-select-panel {
  width: auto;
  padding: 15px;
  border: none;
  box-shadow: 1px 1px 24px rgba(25, 26, 38, 0.11);
  border-radius: 24px;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .pill-select .pill-select-panel .pill-option {
  padding: 12px 20px;
  border: 1px solid #09131D;
  border-radius: 100px;
  text-align: center;
  font-size: 18px;
  min-width: 60px;
  box-shadow: none;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .pill-select .pill-select-panel .pill-option:hover {
  background: transparent;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .pill-select .pill-select-panel .pill-option.is-selected {
  background: #379A9A;
  color: #fff;
  border-color: #379A9A;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .form-select:has(option:checked:not([value=""])) {
  background: #379A9A;
  color: #fff;
  border-color: #379A9A;
  box-shadow: none !important;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .input-group {
  overflow: hidden;
  border: 1px solid #09131D;
  border-radius: 100px;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .input-group .form-control {
  border: none;
  border-radius: 0;
  font-size: 14px;
  text-align: left;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .btn-check + .btn {
  border: 1px solid #09131D;
  border-radius: 100px;
  font-size: 18px;
  line-height: 28px;
  padding: 8px;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-body .btn-check:checked + .btn {
  background: #379A9A;
  color: #fff;
  border-color: #379A9A;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-footer {
  padding: 24px 16px;
  justify-content: flex-start;
  border-top: 1px solid #9DA0A3;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-footer .btn-primary {
  width: 200px;
}
.apartment-filter-modal .modal-dialog .modal-content .modal-footer .btn-link {
  color: #09131D;
  font-size: 18px;
}

@media (min-width: 900px) {
  .favorites-modal .modal-dialog {
    --bs-modal-width: 544px;
  }
}
.favorites-modal .modal-dialog .modal-content {
  border-radius: 0;
  border: none;
}
.favorites-modal .modal-dialog .modal-content .modal-header {
  padding: 24px;
  border: none;
}
.favorites-modal .modal-dialog .modal-content .modal-header .modal-title {
  color: #000;
  font-size: 36px;
  line-height: 36px;
  font-weight: 700;
  font-family: "Playfair", serif;
}
.favorites-modal .modal-dialog .modal-content .modal-header .btn-close {
  opacity: 1;
  box-shadow: none;
}
.favorites-modal .modal-dialog .modal-content .modal-body {
  padding: 0 24px 48px;
}
.favorites-modal .modal-dialog .modal-content .modal-body .favorites-list .favorite-item {
  padding-bottom: 24px;
  margin-bottom: 20px;
  border-bottom: 1px solid #9DA0A3;
}
.favorites-modal .modal-dialog .modal-content .modal-body .favorites-list .favorite-item .favorite-item-content {
  font-size: 18px;
  line-height: 24px;
}
.favorites-modal .modal-dialog .modal-content .modal-body .favorites-list .favorite-item .favorite-item-content .favorite-meta,
.favorites-modal .modal-dialog .modal-content .modal-body .favorites-list .favorite-item .favorite-item-content .favorite-address {
  font-size: 16px;
  line-height: 20px;
}
.favorites-modal .modal-dialog .modal-content .modal-body .favorites-list .favorite-item .favorite-remove {
  color: #695EFF;
  font-size: 20px;
}
.favorites-modal .modal-dialog .modal-content .modal-body .favorites-actions a:not(.btn) {
  font-size: 16px;
  line-height: 20px;
  color: #000;
  text-decoration: none;
}
.favorites-modal .modal-dialog .modal-content .modal-body .favorites-actions .favorites-plus {
  color: #379A9A;
  border: 2px solid #379A9A;
  border-radius: 20px;
  text-align: center;
  padding: 8px 9px;
  font-size: 20px;
  line-height: 16px;
}
.favorites-modal .modal-dialog .modal-content .modal-body .favorites-actions .favorites-plus:hover {
  background: #379A9A;
  color: #fff;
}

/*# sourceMappingURL=site.css.map */
