@import url(https://fonts.googleapis.com/css2?family=Barlow:wght@200;400;500;600;800&display=swap);
@charset "UTF-8";
/* = COLOURS = */
/* = FONTS = */
/*
* === MIXINS ===
*/
/*
* === TYPOGRAPHY ===
*/
* {
  font-family: "Barlow", sans-serif;
}

*:not(.material-icons) {
  font-family: "Barlow", sans-serif;
}
html {
  background: #ffffff;
}
body {
  font-family: "Barlow", sans-serif;
  color: #0a0a0a;
  background: #ffffff;
}
.off-canvas-content {
  background: #ffffff;
}
.page-wrap,
.page-wrap-home {
  background: #ffffff;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Barlow", sans-serif;
  color: #0a0a0a;
  font-weight: 600;
}

a {
  font-weight: 400;
  font-size: 18px;
}

p {
  font-weight: 400;
}

h1 {
  font-size: 60px;
}
@media (max-width: 1200px) {
  h1 {
    font-size: 50px;
  }
}
@media (max-width: 950px) {
  h1 {
    font-size: 45px;
  }
}
@media (max-width: 650px) {
  h1 {
    font-size: 35px;
  }
}

h2 {
  font-size: 24px;
  font-weight: 600;
}
@media (max-width: 400px) {
  h2 {
    font-size: 20px;
  }
}

/* Ensure all page main headings use font-weight 600 */
.page-header h1,
.page-header h2,
.banner-overlay h1,
.banner-overlay h2,
.banner .banner-overlay h1,
.banner .banner-overlay h2,
.content h1:first-of-type,
.content h2:first-of-type {
  font-weight: 600 !important;
}

h3 {
  font-size: 18px;
}

i {
  color: #e5347e;
  font-size: 24px;
}

.material-icons,
i.material-icons {
  font-family: "Material Icons" !important;
  font-weight: normal !important;
  font-style: normal !important;
  font-size: 24px !important;
  line-height: 1 !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  display: inline-block !important;
  white-space: nowrap !important;
  word-wrap: normal !important;
  direction: ltr !important;
  -webkit-font-feature-settings: "liga" !important;
  -webkit-font-smoothing: antialiased !important;
  speak: none !important;
  font-variant: normal !important;
  text-rendering: optimizeLegibility !important;
  color: #e5347e;
  vertical-align: middle;
}

.where__wrapper .material-icons,
.property__wrapper .material-icons,
.date__wrapper .material-icons,
.nights__wrapper .material-icons,
.people__wrapper .material-icons,
.flexibility__wrapper .material-icons {
  font-family: "Material Icons" !important;
  font-size: 24px;
  flex-shrink: 0;
  vertical-align: middle;
}

/* = Header Specific Styles = */
header {
  position: -webkit-sticky;
  position: sticky;
  left: 0;
  right: 0;
  top: 0;
  z-index: 25;
  padding: 10px 30px;
  background: #fff;
}
@media (max-width: 749px) {
  header {
    padding: 10px 15px;
  }
}
header .header-logo img {
  max-width: 50px;
}
header .header-menu ul {
  justify-content: center;
}
header .header-menu ul li {
  padding: 0 10px;
}
header .header-menu ul li a {
  color: black;
  font-weight: 600;
  font-size: 15px;
}
header .header-menu ul li a:hover {
  color: #e5347e;
}
/* Current/Active menu item - pink color */
header .header-menu ul li.current-menu-item > a,
header .header-menu ul li.current_page_item > a,
header .header-menu ul li.active > a {
  color: #e5347e !important;
}
header .header-menu ul li ul li {
  padding: 0;
  background: #fff;
}
header .header-menu ul li ul li a {
  text-transform: none;
  color: black;
}
header .header-menu ul li.active ul li a {
  color: black;
}
header .header-menu ul li.active ul li a:hover {
  color: #e5347e !important;
}
/* Dropdown menu styling */
header .header-menu ul li .is-dropdown-submenu {
  background: #fff;
  border: 1px solid #ddd;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  padding: 0.5rem 0;
  min-width: 200px;
  list-style: none;
}
header .header-menu ul li .is-dropdown-submenu li {
  padding: 0;
  list-style: none;
}
header .header-menu ul li .is-dropdown-submenu li::before {
  display: none;
  content: none;
}
header .header-menu ul li .is-dropdown-submenu li a {
  padding: 0.75rem 1.5rem;
  display: block;
  color: black;
  font-weight: 400;
  font-size: 14px;
  list-style: none;
}
header .header-menu ul li .is-dropdown-submenu li a::before {
  display: none;
  content: none;
}
header .header-menu ul li .is-dropdown-submenu li a:hover {
  color: #e5347e;
  background: #f5f5f5;
}
/* Pink dropdown triangle indicator */
header .header-menu ul li.is-dropdown-submenu-parent > a::after {
  border-top-color: #e5347e !important;
}
header .header-menu ul li.is-dropdown-submenu-parent:hover > a::after {
  border-top-color: #e5347e !important;
}
header .header-social {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 1.5rem;
}
header .header-social .phone,
header .header-social .header-menu-btn {
  display: inline-flex;
  align-items: center;
  vertical-align: middle;
}
header .header-social .phone i,
header .header-social .phone .material-icons {
  color: #e5347e;
  font-size: 20px;
  margin-right: 0.5rem;
}
header .header-social .header-menu-btn i,
header .header-social .header-menu-btn .material-icons {
  color: #e5347e;
  font-size: 25px;
}
@media (max-width: 500px) {
  header .header-social .phone {
    display: none;
  }
}
header .header-social .phone a {
  font-weight: 600;
  font-size: 15px;
  color: black;
  display: flex;
  align-items: center;
  text-decoration: none;
  line-height: 1;
}
header .header-social .phone a span {
  color: black;
}
header .header-social .header-menu-btn button {
  border: none;
  background: transparent;
  padding: 0;
  cursor: pointer;
  outline: none;
  display: flex;
  align-items: center;
  line-height: 1;
}
header .header-social .header-search-btn {
  display: inline-flex;
  align-items: center;
  vertical-align: middle;
}
header .header-social .header-search-btn button {
  border: none;
  background: transparent;
  padding: 0;
  cursor: pointer;
  outline: none;
  display: flex;
  align-items: center;
  line-height: 1;
}
header .header-social .header-search-btn i,
header .header-social .header-search-btn .material-icons {
  color: #e5347e;
  font-size: 25px;
  transition: transform 0.2s ease;
}
header .header-social .header-search-btn button:hover i {
  transform: scale(1.1);
}
.search-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.9);
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.search-overlay.active {
  display: flex;
  opacity: 1;
}
.search-overlay-content {
  width: 90%;
  max-width: 700px;
  position: relative;
  animation: searchSlideDown 0.3s ease;
}
@keyframes searchSlideDown {
  from {
    transform: translateY(-30px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}
.search-close {
  position: absolute;
  top: -50px;
  right: 0;
  background: transparent;
  border: none;
  color: #fff;
  cursor: pointer;
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  transition: transform 0.2s ease;
}
.search-close:hover {
  transform: rotate(90deg);
}
.search-close .material-icons {
  font-size: 32px;
  color: #fff;
}
.search-form {
  width: 100%;
  position: relative;
}
.search-input-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  background: #fff;
  border-radius: 50px;
  padding: 15px 20px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}
.search-input-wrapper .search-icon {
  color: #e5347e;
  font-size: 28px;
  margin-right: 15px;
  flex-shrink: 0;
}
.search-input-wrapper .search-field {
  flex: 1;
  border: none !important;
  outline: none !important;
  font-size: 18px;
  color: #333;
  background: transparent;
  padding: 0;
  font-family: inherit;
  box-shadow: none !important;
}
.search-input-wrapper .search-field:focus,
.search-input-wrapper .search-field:focus-visible,
.search-input-wrapper .search-field:active,
.search-input-wrapper .search-field:hover {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
}
.search-input-wrapper .search-field::placeholder {
  color: #999;
}
.search-input-wrapper .search-submit {
  background: #e5347e;
  border: none;
  border-radius: 50%;
  width: 45px;
  height: 45px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  margin-left: 15px;
  flex-shrink: 0;
  transition: background 0.2s ease, transform 0.2s ease;
}
.search-input-wrapper .search-submit:hover {
  background: #c42a6a;
  transform: scale(1.05);
}
.search-input-wrapper .search-submit .material-icons {
  color: #fff;
  font-size: 24px;
}
@media (max-width: 768px) {
  .search-overlay-content {
    width: 95%;
  }
  .search-input-wrapper {
    padding: 12px 15px;
  }
  .search-input-wrapper .search-field {
    font-size: 16px;
  }
  .search-input-wrapper .search-icon {
    font-size: 24px;
    margin-right: 10px;
  }
  .search-input-wrapper .search-submit {
    width: 40px;
    height: 40px;
    margin-left: 10px;
  }
  .search-close {
    top: -40px;
  }
}
.search-suggestions {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  right: 0;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
  max-height: 400px;
  overflow-y: auto;
  z-index: 10000;
  display: none;
}
.search-suggestions .suggestions-list {
  list-style: none;
  margin: 0;
  padding: 8px 0;
}
.search-suggestions .suggestion-item {
  margin: 0;
  padding: 0;
}
.search-suggestions .suggestion-link {
  display: flex;
  align-items: center;
  padding: 12px 20px;
  text-decoration: none;
  color: #333;
  transition: background 0.2s ease;
  gap: 15px;
}
.search-suggestions .suggestion-link:hover,
.search-suggestions .suggestion-item.active .suggestion-link {
  background: #f5f5f5;
}
.search-suggestions .suggestion-link .material-icons {
  font-size: 24px;
  color: #e5347e;
  flex-shrink: 0;
}
.search-suggestions .suggestion-content {
  flex: 1;
  min-width: 0;
}
.search-suggestions .suggestion-title {
  font-size: 16px;
  font-weight: 600;
  color: #333;
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.search-suggestions .suggestion-subtitle {
  font-size: 14px;
  color: #666;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.search-suggestions::-webkit-scrollbar {
  width: 8px;
}
.search-suggestions::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 12px;
}
.search-suggestions::-webkit-scrollbar-thumb {
  background: #888;
  border-radius: 12px;
}
.search-suggestions::-webkit-scrollbar-thumb:hover {
  background: #555;
}
@media (max-width: 768px) {
  .search-suggestions {
    max-height: 300px;
  }
  .search-suggestions .suggestion-link {
    padding: 10px 15px;
    gap: 12px;
  }
  .search-suggestions .suggestion-link .material-icons {
    font-size: 20px;
  }
  .search-suggestions .suggestion-title {
    font-size: 15px;
  }
  .search-suggestions .suggestion-subtitle {
    font-size: 13px;
  }
}
.menu-left .contact {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin: 2rem 0;
  align-items: flex-start;
}
.menu-left .contact .phone {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #fff;
  text-decoration: none;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.2;
}
.menu-left .contact .phone i.material-icons {
  color: #fff;
  font-size: 20px;
  display: inline-flex;
  align-items: center;
  vertical-align: middle;
}
.menu-left .contact .phone span {
  color: #fff;
  display: inline-block;
  vertical-align: middle;
}
.menu-left .contact .email {
  color: #fff;
  text-decoration: none;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.2;
  display: inline-block;
}
.menu-left .contact .phone:hover,
.menu-left .contact .email:hover {
  color: #e5347e;
}
.menu-left .contact .phone:hover i.material-icons,
.menu-left .contact .phone:hover span {
  color: #e5347e;
}
.menu-left .menu-social-links {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  margin-top: 2rem;
  padding-top: 2rem;
}
.menu-left .menu-social-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-decoration: none;
  transition: all 0.3s ease;
}
.menu-left .menu-social-links a i {
  color: #fff;
  font-size: 18px;
  transition: all 0.3s ease;
}
.menu-left .menu-social-links a:hover i {
  color: #e5347e;
  transform: scale(1.1);
}
@media (min-width: 750px) {
  .menu-left .menu-social-links {
    position: absolute;
    bottom: 3%;
    left: 0;
    right: 0;
    margin-top: 0;
    padding-top: 0;
    z-index: 5;
    margin-bottom: 0.5rem;
  }
}
@media (max-width: 749px) {
  .menu-left .contact,
  .menu-left .menu-social-links {
    display: none !important;
  }
  .menu-left .menu-social-links {
    gap: 1rem;
    margin-top: 1.5rem;
    padding-top: 1.5rem;
  }
  .menu-left .menu-social-links a i {
    font-size: 16px;
  }
}

/* = HAMBURGER */
.accordion-menu
  .is-accordion-submenu-parent:not(.has-submenu-toggle)
  > a::after {
  margin-top: -1px;
  right: 1rem;
}

#off-canvas .accordion-menu .is-accordion-submenu-parent > a,
#off-canvas .accordion-menu .menu-item-has-children > a {
  position: relative;
}

#off-canvas .accordion-menu .is-accordion-submenu-parent > a::after,
#off-canvas .accordion-menu .menu-item-has-children > a::after {
  display: block !important;
  width: 0;
  height: 0;
  border: inset 6px;
  content: "";
  border-bottom-width: 0;
  border-top-style: solid;
  border-color: #e5347e transparent transparent !important;
  position: absolute;
  top: 50%;
  margin-top: -3px;
  right: 1rem;
  pointer-events: none;
  transform-origin: 50% 50%;
  transition: transform 0.3s ease;
}

#off-canvas
  .accordion-menu
  .is-accordion-submenu-parent[aria-expanded="true"]
  > a::after,
#off-canvas
  .accordion-menu
  .menu-item-has-children[aria-expanded="true"]
  > a::after {
  transform: rotate(180deg);
}

.off-canvas.is-transition-overlap.is-open {
  z-index: 999;
}

.off-canvas {
  background: #009fe3;
}

.off-canvas.is-transition-overlap.is-open {
  background: #009fe3;
}

ul.menu-two {
  height: 100%;
  justify-content: center;
  transition: 0.2s;
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  margin: 0 auto;
}
@media (max-width: 1049px) {
  ul.menu-two {
    margin-top: 1em !important;
  }
}
ul.menu-two li {
  text-align: center;
  list-style: none;
}
ul.menu-two li a {
  color: #fff;
  font-size: 25px;
  padding: 10px 0;
}
ul.menu-two li a:hover {
  color: #e5347e;
}
@media (max-width: 1049px) {
  ul.menu-two li a {
    font-size: 18px !important;
  }
}

@media (max-width: 749px) {
  .mobile-menu {
    height: 100%;
  }
}

@media (min-width: 1050px) {
  .mobile-menu-size,
  .menu-two {
    display: none;
  }
}

@media (max-width: 1049px) {
  .mobile-menu-size {
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }
}

@media (max-width: 1049px) {
  .mobile-menu-size ul#menu-main-menu,
  .mobile-menu-size ul.menu-two {
    height: 100%;
    justify-content: center;
    transition: 0.2s;
    max-width: -webkit-fit-content;
    max-width: -moz-fit-content;
    max-width: fit-content;
    margin: 0 auto;
  }
  .mobile-menu-size ul#menu-main-menu li,
  .mobile-menu-size ul.menu-two li {
    text-align: center;
    list-style: none;
  }
  .mobile-menu-size ul#menu-main-menu li a,
  .mobile-menu-size ul.menu-two li a {
    color: #fff;
    font-size: 25px;
    padding: 10px 0;
  }
}
@media (max-width: 1049px) and (max-width: 750px) {
  .mobile-menu-size ul#menu-main-menu li a,
  .mobile-menu-size ul.menu-two li a {
    padding: 5px 0;
  }
}

@media (max-width: 1049px) {
  .mobile-menu-size ul#menu-main-menu li a:hover,
  .mobile-menu-size ul.menu-two li a:hover {
    color: #e5347e;
  }
}

.mobile-menu-size #menu-main-menu li a {
  color: #fff !important;
  font-weight: 600;
}

#off-canvas .accordion-menu .is-accordion-submenu,
#off-canvas .accordion-menu .vertical.menu {
  margin-left: 1rem;
  margin-top: 0.5rem;
}

#off-canvas .accordion-menu .is-accordion-submenu li a,
#off-canvas .accordion-menu .vertical.menu li a {
  color: #fff !important;
  font-size: 20px;
  padding: 8px 0;
  font-weight: 400;
}

#off-canvas .accordion-menu .is-accordion-submenu li a:hover,
#off-canvas .accordion-menu .vertical.menu li a:hover {
  color: #e5347e !important;
}

.off-canvas.is-transition-overlap {
  max-width: 100%;
}

.js-off-canvas-overlay.is-overlay-fixed.is-visible.is-closable {
  opacity: 1;
  visibility: visible;
  cursor: pointer;
  background: rgba(10, 10, 10, 0.2);
}

/* Custom menu overlay */
.custom-menu-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(10, 10, 10, 0.2);
  z-index: 998;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  cursor: pointer;
}

.custom-menu-overlay.is-visible {
  opacity: 1;
  visibility: visible;
}

/* Custom menu open state */
body.is-off-canvas-open {
  overflow: hidden;
}

/* Custom menu - ensure it's hidden by default */
#off-canvas {
  transition: transform 0.3s ease, visibility 0.3s ease, opacity 0.3s ease;
}

#off-canvas:not(.is-open) {
  transform: translateX(100%) !important;
  visibility: hidden !important;
}

#off-canvas.is-open {
  transform: translateX(0) !important;
  visibility: visible !important;
  opacity: 1 !important;
  z-index: 999 !important;
}

.off-canvas.is-transition-overlap.is-open {
  box-shadow: none;
}

.off-canvas-wrapper {
  overflow: inherit;
}

.off-canvas-wrapper .off-canvas {
  overflow: hidden;
}

.ysm-search-widget .search-submit {
  color: #fff;
}

.position-right {
  top: 0;
  right: 0;
  height: 100%;
  width: 100%;
  transform: translateX(100%);
}

a.menu-close {
  position: absolute;
  right: 30px;
  top: 20px;
  font-size: 30px;
  z-index: 2;
}

.off-canvas.is-closed {
  visibility: hidden;
}

a.menu-close span {
  font-size: 15px;
  vertical-align: middle;
}

a.menu-close i {
  vertical-align: middle;
  margin-left: 4px;
}

.off-canvas.is-transition-overlap {
  z-index: 13;
}

a.navbar-btn.sidebar-toggle.navbar-close,
a.custom-menu-close {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 18px;
  z-index: 1000 !important;
  padding: 20px 30px;
  background: #009fe361;
  pointer-events: auto !important;
  cursor: pointer !important;
}
a.navbar-btn.sidebar-toggle.navbar-close:hover,
a.custom-menu-close:hover {
  background: #009fe3;
}
a.navbar-btn.sidebar-toggle.navbar-close i,
a.custom-menu-close i {
  color: #fff;
  vertical-align: middle;
  font-size: 30px;
  pointer-events: none;
}

.dropdown .is-dropdown-submenu a {
  padding: 10px 15px;
  text-align: left;
  line-height: 1.5;
  font-weight: 600;
}

.dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {
  top: 120%;
  border: none;
  background: #fff;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  padding: 0.5rem 0;
  min-width: 200px;
}
/* Pink dropdown triangle indicator for all dropdown menus */
.dropdown.menu > li.is-dropdown-submenu-parent > a::after,
header .header-menu .dropdown.menu > li.is-dropdown-submenu-parent > a::after,
header .header-menu ul li.is-dropdown-submenu-parent > a::after,
.medium-horizontal.menu > li.is-dropdown-submenu-parent > a::after {
  border-top-color: #e5347e !important;
  border-top-style: solid !important;
}
.dropdown.menu > li.is-dropdown-submenu-parent:hover > a::after,
header
  .header-menu
  .dropdown.menu
  > li.is-dropdown-submenu-parent:hover
  > a::after,
header .header-menu ul li.is-dropdown-submenu-parent:hover > a::after,
.medium-horizontal.menu > li.is-dropdown-submenu-parent:hover > a::after {
  border-top-color: #e5347e !important;
}
/* Dropdown menu items styling */
.dropdown.menu .is-dropdown-submenu {
  background: #fff;
  border: 1px solid #ddd;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  padding: 0.5rem 0;
  list-style: none;
}
.dropdown.menu .is-dropdown-submenu li {
  list-style: none;
}
.dropdown.menu .is-dropdown-submenu li::before {
  display: none;
}
.dropdown.menu .is-dropdown-submenu li a {
  padding: 0.75rem 1.5rem;
  display: block;
  color: black;
  font-weight: 400;
  font-size: 14px;
  list-style: none;
}
.dropdown.menu .is-dropdown-submenu li a::before {
  display: none;
}
.dropdown.menu .is-dropdown-submenu li a:hover {
  color: #e5347e;
  background: #f5f5f5;
}
.dropdown.menu.medium-horizontal
  > li.opens-right
  > .is-dropdown-submenu
  a:hover {
  color: #009fe3;
  transition: 0.2s;
}

.menu-left {
  position: relative;
}
@media (min-width: 750px) {
  .menu-left .contact {
    position: absolute;
    bottom: 8%;
    left: 0;
    right: 0;
    text-align: center;
    z-index: 5;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
  }
  .menu-left .contact .phone {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: #fff;
    text-decoration: none;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.2;
  }
  .menu-left .contact .phone i.material-icons {
    color: #fff;
    font-size: 20px;
    display: inline-flex;
    align-items: center;
    vertical-align: middle;
  }
  .menu-left .contact .phone span {
    color: #fff;
    display: inline-block;
    vertical-align: middle;
  }
  .menu-left .contact .email {
    color: #fff;
    text-decoration: none;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.2;
    display: inline-block;
  }
}
@media (max-width: 749px) {
  .menu-left .contact {
    position: static;
    text-align: left;
  }
}
.menu-left .contact p {
  color: #fff;
  margin: 0;
}
.menu-left .contact a {
  padding: 0;
}
.menu-left .contact a i {
  color: #fff;
  font-size: 16px;
}
.menu-left .contact a i:hover {
  color: #e5347e;
}
.menu-left .login-links {
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
@media (max-width: 1049px) {
  .menu-left .login-links {
    display: none;
  }
}
.menu-left .login-links ul.menu-desktop {
  height: 100%;
  justify-content: center;
  transition: 0.2s;
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  margin: 0 auto;
}
.menu-left .login-links ul.menu-desktop li {
  text-align: center;
  list-style: none;
}
.menu-left .login-links ul.menu-desktop li a {
  color: #fff;
  font-size: 25px;
  padding: 10px 0;
}
.menu-left .login-links ul.menu-desktop li a:hover {
  color: #e5347e;
}

.menu-photo {
  position: relative;
  height: 100vh;
  overflow: hidden;
}
.menu-photo .menu-slider {
  height: 100vh !important;
  width: 100% !important;
  position: relative;
}
.menu-photo .menu-slider.slick-slider,
.menu-photo .menu-slider .slick-list,
.menu-photo .menu-slider .slick-track {
  height: 100vh !important;
  width: 100% !important;
}
.menu-photo .menu-slider .slick-slide {
  height: 100vh !important;
  width: 100% !important;
  position: relative;
}
.menu-photo .menu-slider .slick-slide > div,
.menu-photo .menu-slider .slick-slide > picture {
  height: 100vh !important;
  width: 100% !important;
  display: block;
}
.menu-photo .menu-slider picture {
  height: 100vh !important;
  width: 100% !important;
  display: block;
}
.menu-photo .menu-slider img {
  height: 100vh !important;
  width: 100% !important;
  display: block !important;
  -o-object-fit: cover !important;
  object-fit: cover !important;
}
.menu-photo .slick-slider img {
  height: 100vh !important;
  width: 100% !important;
  -o-object-fit: cover !important;
  object-fit: cover !important;
  display: block !important;
}

/* = Footer Specific Styles = */
footer {
  background: #242424;
}
footer h3 {
  font-size: 18px !important;
  color: #fff;
}
footer p,
footer a,
footer i,
footer span {
  color: #fff;
}
footer .footer-top {
  padding: 7em 0;
}
@media (max-width: 749px) {
  footer .footer-top {
    padding-top: 0;
    padding-bottom: 3em;
  }
}
footer .footer-top ul {
  margin: 0;
}
footer .footer-top ul li {
  list-style: none;
}
footer .footer-top ul li a {
  font-size: 16px;
}
footer .footer-top i {
  font-size: 16px;
}
footer .footer-top .social-links {
  display: flex;
  flex-direction: row;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 0.5rem;
}
footer .footer-top .social-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: #e5347e;
  border-radius: 50%;
  text-decoration: none;
  transition: all 0.3s ease;
  border: none;
  padding: 0;
}
footer .footer-top .social-links a:hover {
  background: #e5347e;
  transform: translateY(-2px);
  opacity: 0.9;
  box-shadow: 0 4px 8px rgba(229, 52, 126, 0.3);
}
footer .footer-top .social-links a i {
  color: #ffffff;
  font-size: 16px;
  padding: 0;
  transition: all 0.3s ease;
}
footer .footer-top .social-links a:hover i {
  color: #ffffff;
}
@media (max-width: 749px) {
  footer .small-12 {
    padding-top: 10px;
  }
  footer .footer-top .social-links {
    justify-content: flex-start;
    gap: 0.75rem;
  }
  footer .footer-top .social-links a {
    width: 32px;
    height: 32px;
  }
  footer .footer-top .social-links a i {
    font-size: 14px;
  }
}
footer .small-12 span.gs-link {
  font-size: 13px;
}
footer .small-12 span.gs-link a {
  font-size: 13px;
}
footer .bg {
  background: #1a1a1a;
  padding: 25px 0;
}
footer .bg a {
  padding-left: 3px;
}
footer .bg ul {
  margin: 0;
}
footer .bg ul li {
  list-style: none;
  display: inline-block;
  padding: 0 3px;
}
footer .bg ul li a {
  font-size: 16px;
}
@media (max-width: 749px) {
  footer .bg .small-12 {
    text-align: center;
  }
}

.grid-x {
  width: 90%;
  max-width: 1500px;
  margin-left: auto;
  margin-right: auto;
}
.grid-x.full {
  width: 100%;
  max-width: 100%;
}

.cookie-notice-container {
  background: #383838;
}
.cookie-notice-container a#cn-accept-cookie {
  background-color: #e5347e;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
}
.cookie-notice-container a#cn-accept-cookie:hover {
  background-color: #e84b8c;
}

slick-slider {
  outline: none;
}
slick-slider:hover,
slick-slider:active,
slick-slider:focus {
  outline: none;
}

.single-post .banner,
.page-template-list-children .banner,
.blog .banner,
.page-template-simpleflex .banner {
  position: relative;
  height: 55vh;
}
@media (max-width: 970px) {
  .single-post .banner,
  .page-template-list-children .banner,
  .blog .banner,
  .page-template-simpleflex .banner {
    height: 45vh;
  }
}
.single-post .banner img,
.page-template-list-children .banner img,
.blog .banner img,
.page-template-simpleflex .banner img {
  width: 100%;
  height: 55vh;
  -o-object-fit: cover;
  object-fit: cover;
}
@media (max-width: 970px) {
  .single-post .banner img,
  .page-template-list-children .banner img,
  .blog .banner img,
  .page-template-simpleflex .banner img {
    height: 45vh;
  }
}
.single-post .banner .banner-overlay,
.page-template-list-children .banner .banner-overlay,
.blog .banner .banner-overlay,
.page-template-simpleflex .banner .banner-overlay {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
  z-index: 3;
}

div#sb_instagram {
  padding: 0 !important;
}

div#sbi_images {
  padding: 0 !important;
}

#sb_instagram.sbi_col_4 #sbi_images .sbi_item {
  width: 20%;
}
@media (max-width: 950px) {
  #sb_instagram.sbi_col_4 #sbi_images .sbi_item {
    width: 25%;
  }
}
@media (max-width: 750px) {
  #sb_instagram.sbi_col_4 #sbi_images .sbi_item {
    width: 50%;
  }
}
@media (max-width: 350px) {
  #sb_instagram.sbi_col_4 #sbi_images .sbi_item {
    width: 100%;
  }
}

@media (max-width: 950px) {
  #sb_instagram.sbi_col_4 #sbi_images .sbi_item:nth-child(5) {
    display: none;
  }
}

@media (max-width: 750px) {
  #sb_instagram.sbi_col_4 #sbi_images .sbi_item:nth-child(4) {
    display: none;
  }
}

@media (max-width: 750px) {
  #sb_instagram.sbi_col_4 #sbi_images .sbi_item:nth-child(3) {
    display: none;
  }
}

a.anchor {
  display: block;
  position: relative;
  top: -100px;
  visibility: hidden;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus {
  -webkit-text-fill-color: black;
  -webkit-transition: background-color 5000s ease-in-out 0s;
  transition: background-color 5000s ease-in-out 0s;
}

.nf-field-element input,
.nf-field-element select,
.nf-field-element textarea {
  height: 45px !important;
}

html {
  scroll-behavior: smooth;
  font-family: "Barlow", sans-serif;
}

.video-btn {
  background-color: #009fe3;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  transition: 0.35s;
  border-radius: 3px;
  display: block;
  width: 100%;
  text-align: center;
  margin-top: 1em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.video-btn:hover {
  background-color: #e5347e;
  color: #fff;
}
@media (min-width: 750px) {
  .video-btn {
    display: inline-block !important;
  }
}

/* = Banner Specific Styles = */
@-webkit-keyframes bannerSlide {
  0% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes bannerSlide {
  0% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}

.banner {
  position: relative;
  height: 90vh;
}
@media (max-width: 970px) {
  .banner {
    height: 80vh;
  }
}
@media (max-width: 380px) {
  .banner {
    height: 100vh;
  }
}
.banner img {
  width: 100%;
  height: 90vh;
  -o-object-fit: cover;
  object-fit: cover;
}
@media (max-width: 970px) {
  .banner img {
    height: 80vh;
  }
}
@media (max-width: 380px) {
  .banner img {
    height: 100vh;
  }
}

.banner-item {
  position: relative;
  background: #000;
  overflow: hidden;
}
.banner-item::before {
  content: "";
  position: absolute;
  display: block;
  height: 35%;
  top: 0;
  left: 0;
  right: 0;
  z-index: 2;
  background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.5), transparent);
}
.banner-item img.banner-image {
  height: 100vh;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  opacity: 0.78;
  transition: 2s cubic-bezier(0, 0.1, 0, 0.99);
  -webkit-animation-name: bannerSlide;
  animation-name: bannerSlide;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
}
.banner-item .banner-overlay {
  position: absolute;
  top: 45%;
  transform: translateY(-50%);
  width: 100%;
  z-index: 3;
}
@media (max-width: 749px) {
  .banner-item .banner-overlay {
    top: 20%;
  }
}
.banner-item .banner-overlay .cell {
  padding: 0 3vw;
}
.banner-item .banner-overlay .overlay-content h1,
.banner-item .banner-overlay .overlay-content h2,
.banner-item .banner-overlay .overlay-content h3,
.banner-item .banner-overlay .overlay-content h4 {
  color: #fff;
}
.banner-item .banner-overlay .overlay-content p {
  color: #fff;
}
.banner-item .banner-overlay .overlay-content h1,
.banner-item .banner-overlay .overlay-content h2 {
  font-size: 40px;
  font-weight: 600;
}
@media (max-width: 750px) {
  .banner-item .banner-overlay .overlay-content h1,
  .banner-item .banner-overlay .overlay-content h2 {
    font-size: 35px;
  }
}

@media (max-width: 400px) {
  .home-banner__overlay {
    top: 62% !important;
  }
}

#off-canvas.full-screen {
  left: 0;
  width: 100%;
}

@-webkit-keyframes spin {
  100% {
    transform: rotate(360deg);
  }
}

@keyframes spin {
  100% {
    transform: rotate(360deg);
  }
}

@font-face {
  font-family: star;
  src: url(/wp-content/themes/gs-theme/assets/build/fonts/star.eot);
  src: url(/wp-content/themes/gs-theme/assets/build/fonts/star.eot?#iefix)
      format("embedded-opentype"),
    url(/wp-content/themes/gs-theme/assets/build/fonts/star.woff) format("woff"),
    url(/wp-content/themes/gs-theme/assets/build/fonts/star.ttf)
      format("truetype"),
    url(/wp-content/themes/gs-theme/assets/build/images/star.svg#star)
      format("svg");
  font-weight: 400;
  font-style: normal;
}

@font-face {
  font-family: WooCommerce;
  src: url(/wp-content/themes/gs-theme/assets/build/fonts/WooCommerce.eot);
  src: url(/wp-content/themes/gs-theme/assets/build/fonts/WooCommerce.eot?#iefix)
      format("embedded-opentype"),
    url(/wp-content/themes/gs-theme/assets/build/fonts/WooCommerce.woff)
      format("woff"),
    url(/wp-content/themes/gs-theme/assets/build/fonts/WooCommerce.ttf)
      format("truetype"),
    url(/wp-content/themes/gs-theme/assets/build/images/WooCommerce.svg#WooCommerce)
      format("svg");
  font-weight: 400;
  font-style: normal;
}

.woocommerce-store-notice,
p.demo_store {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: 0;
  width: 100%;
  font-size: 1em;
  padding: 1em 0;
  text-align: center;
  background-color: #e5347e;
  color: #fff;
  z-index: 99998;
  box-shadow: 0 1px 1em rgba(0, 0, 0, 0.2);
  display: none;
}

.woocommerce-store-notice a,
p.demo_store a {
  color: #fff;
  text-decoration: underline;
}

.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  overflow: hidden;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
}

.admin-bar p.demo_store {
  top: 32px;
}

.clear {
  clear: both;
}

.woocommerce .blockUI.blockOverlay {
  position: relative;
}

.woocommerce .blockUI.blockOverlay::before {
  height: 1em;
  width: 1em;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-left: -0.5em;
  margin-top: -0.5em;
  content: "";
  -webkit-animation: spin 1s ease-in-out infinite;
  animation: spin 1s ease-in-out infinite;
  background: url(/wp-content/themes/gs-theme/assets/build/images/loader.svg)
    center center;
  background-size: cover;
  line-height: 1;
  text-align: center;
  font-size: 2em;
  color: rgba(0, 0, 0, 0.75);
}

.woocommerce .loader::before {
  height: 1em;
  width: 1em;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-left: -0.5em;
  margin-top: -0.5em;
  content: "";
  -webkit-animation: spin 1s ease-in-out infinite;
  animation: spin 1s ease-in-out infinite;
  background: url(/wp-content/themes/gs-theme/assets/build/images/loader.svg)
    center center;
  background-size: cover;
  line-height: 1;
  text-align: center;
  font-size: 2em;
  color: rgba(0, 0, 0, 0.75);
}

.woocommerce a.remove {
  display: block;
  font-size: 15px;
  height: 20px;
  width: 20px;
  text-align: center;
  line-height: 20px;
  border-radius: 100%;
  color: red !important;
  text-decoration: none;
  font-weight: 600;
  border: 0;
}

.woocommerce a.remove:hover {
  color: #fff !important;
  background: red;
}

.woocommerce small.note {
  display: block;
  color: #767676;
  font-size: 0.857em;
  margin-top: 10px;
}

.woocommerce .woocommerce-breadcrumb {
  margin: 0 0 1em;
  padding: 0;
  font-size: 0.92em;
  color: #767676;
}

.woocommerce .woocommerce-breadcrumb::after,
.woocommerce .woocommerce-breadcrumb::before {
  content: " ";
  display: table;
}

.woocommerce .woocommerce-breadcrumb::after {
  clear: both;
}

.woocommerce .woocommerce-breadcrumb a {
  color: #767676;
}

.woocommerce .quantity .qty {
  width: 65px;
  text-align: center;
  height: 50px;
  line-height: 50px;
  border-color: #e5347e;
  transform: skewX(-8deg);
  font-weight: 700;
  font-size: 20px;
  margin: 0;
  margin-right: 5px;
}

.woocommerce div.product {
  margin-bottom: 0;
  position: relative;
}

.woocommerce div.product .product_title {
  clear: none;
  margin-top: 0;
  padding: 0;
  font-size: 30px;
  font-weight: 500;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-size: 20px;
  font-weight: 700;
}

.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
  background: inherit;
  font-weight: 700;
  display: inline-block;
}

.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
  opacity: 0.5;
  display: inline-block;
}

.woocommerce div.product p.stock {
  font-size: 0.92em;
}

.woocommerce div.product .stock {
  color: #009fe3;
}

.woocommerce div.product .out-of-stock {
  color: red;
}

.woocommerce div.product .woocommerce-product-rating {
  margin-bottom: 1.618em;
}

.woocommerce div.product div.images {
  margin-bottom: 2em;
}

.woocommerce div.product div.images img {
  display: block;
  width: 100%;
  height: auto;
  box-shadow: none;
}

.woocommerce div.product div.images div.thumbnails {
  padding-top: 1em;
}

.woocommerce div.product div.images.woocommerce-product-gallery {
  position: relative;
}

.woocommerce div.product div.images .woocommerce-product-gallery__wrapper {
  transition: all cubic-bezier(0.795, -0.035, 0, 1) 0.5s;
  margin: 0;
  padding: 0;
}

.woocommerce
  div.product
  div.images
  .woocommerce-product-gallery__wrapper
  .zoomImg {
  background-color: #fff;
  opacity: 0;
}

.woocommerce
  div.product
  div.images
  .woocommerce-product-gallery__image--placeholder {
  border: 1px solid #f2f2f2;
}

.woocommerce
  div.product
  div.images
  .woocommerce-product-gallery__image:nth-child(n + 2) {
  width: 25%;
  display: inline-block;
}

.woocommerce div.product div.images .woocommerce-product-gallery__trigger {
  position: absolute;
  top: 0.5em;
  right: 0.5em;
  font-size: 2em;
  z-index: 9;
  width: 36px;
  height: 36px;
  background: #fff;
  text-indent: -9999px;
  border-radius: 100%;
  box-sizing: content-box;
}

.woocommerce
  div.product
  div.images
  .woocommerce-product-gallery__trigger::before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  border: 2px solid #000;
  border-radius: 100%;
  position: absolute;
  top: 9px;
  left: 9px;
  box-sizing: content-box;
}

.woocommerce
  div.product
  div.images
  .woocommerce-product-gallery__trigger::after {
  content: "";
  display: block;
  width: 2px;
  height: 8px;
  background: #000;
  border-radius: 6px;
  position: absolute;
  top: 19px;
  left: 22px;
  transform: rotate(-45deg);
  box-sizing: content-box;
}

.woocommerce div.product div.images .flex-control-thumbs {
  overflow: hidden;
  zoom: 1;
  margin: 0;
  padding: 0;
}

.woocommerce div.product div.images .flex-control-thumbs li {
  width: 25%;
  float: left;
  margin: 0;
  list-style: none;
}

.woocommerce div.product div.images .flex-control-thumbs li img {
  cursor: pointer;
  opacity: 0.5;
  margin: 0;
}

.woocommerce div.product div.images .flex-control-thumbs li img.flex-active,
.woocommerce div.product div.images .flex-control-thumbs li img:hover {
  opacity: 1;
}

.woocommerce
  div.product
  .woocommerce-product-gallery--columns-3
  .flex-control-thumbs
  li:nth-child(3n + 1) {
  clear: left;
}

.woocommerce
  div.product
  .woocommerce-product-gallery--columns-4
  .flex-control-thumbs
  li:nth-child(4n + 1) {
  clear: left;
}

.woocommerce
  div.product
  .woocommerce-product-gallery--columns-5
  .flex-control-thumbs
  li:nth-child(5n + 1) {
  clear: left;
}

.woocommerce div.product div.summary {
  margin-bottom: 2em;
}

.woocommerce div.product div.social {
  text-align: right;
  margin: 0 0 1em;
}

.woocommerce div.product div.social span {
  margin: 0 0 0 2px;
}

.woocommerce div.product div.social span span {
  margin: 0;
}

.woocommerce div.product div.social span .stButton .chicklets {
  padding-left: 16px;
  width: 0;
}

.woocommerce div.product div.social iframe {
  float: left;
  margin-top: 3px;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
  list-style: none;
  padding: 0 5px;
  margin: 0;
  overflow: hidden;
  position: relative;
  border: none;
  background: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  border: 1px solid #d3ced2;
  background-color: #ebe9eb;
  display: inline-block;
  position: relative;
  z-index: 0;
  margin: 0 -5px;
  padding: 10px 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  display: inline-block;
  padding: 0 20px;
  color: #0a0a0a;
  text-decoration: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  text-decoration: none;
  color: black;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
  background: #fff;
  z-index: 2;
  border-bottom-color: #fff;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: inherit;
  text-shadow: inherit;
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before {
  position: absolute;
  content: " ";
  width: 100%;
  bottom: 0;
  left: 0;
  border-bottom: 1px solid #d3ced2;
  z-index: 1;
}

.woocommerce div.product .woocommerce-tabs .panel {
  margin: 0 0 2em;
  padding: 20px;
  border: 1px solid #d3ced2;
  border-top: none;
}

.woocommerce div.product p.cart {
  margin-bottom: 2em;
}

.woocommerce div.product p.cart::after,
.woocommerce div.product p.cart::before {
  content: " ";
  display: table;
}

.woocommerce div.product p.cart::after {
  clear: both;
}

.woocommerce div.product form.cart {
  margin-bottom: 2em;
}

.woocommerce div.product form.cart::after,
.woocommerce div.product form.cart::before {
  content: " ";
  display: table;
}

.woocommerce div.product form.cart::after {
  clear: both;
}

.woocommerce div.product form.cart div.quantity {
  float: left;
  margin: 0 4px 0 0;
}

.woocommerce div.product form.cart table {
  border-width: 0 0 1px;
}

.woocommerce div.product form.cart table td {
  padding-left: 0;
}

.woocommerce div.product form.cart table div.quantity {
  float: none;
  margin: 0;
}

.woocommerce div.product form.cart table small.stock {
  display: block;
  float: none;
}

.woocommerce div.product form.cart .variations {
  margin-bottom: 1em;
  border: 0;
  width: 100%;
}

.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th {
  border: 0;
  vertical-align: top;
  line-height: 2em;
}

.woocommerce div.product form.cart .variations label {
  font-weight: 700;
}

.woocommerce div.product form.cart .variations select {
  max-width: 100%;
  min-width: 75%;
  display: inline-block;
  margin-right: 1em;
}

.woocommerce div.product form.cart .variations td.label {
  padding-right: 1em;
}

.woocommerce div.product form.cart .woocommerce-variation-description p {
  margin-bottom: 1em;
}

.woocommerce div.product form.cart .reset_variations {
  visibility: hidden;
  font-size: 0.83em;
}

.woocommerce div.product form.cart .wc-no-matching-variations {
  display: none;
}

.woocommerce div.product form.cart .button {
  vertical-align: middle;
  float: left;
}

.woocommerce
  div.product
  form.cart
  .group_table
  td.woocommerce-grouped-product-list-item__label {
  padding-right: 1em;
  padding-left: 1em;
}

.woocommerce div.product form.cart .group_table td {
  vertical-align: top;
  padding-bottom: 0.5em;
  border: 0;
}

.woocommerce div.product form.cart .group_table td:first-child {
  width: 4em;
  text-align: center;
}

.woocommerce
  div.product
  form.cart
  .group_table
  .wc-grouped-product-add-to-cart-checkbox {
  display: inline-block;
  width: auto;
  margin: 0 auto;
  transform: scale(1.5, 1.5);
}

.woocommerce span.onsale {
  position: absolute;
  top: 35px;
  right: 38px;
  margin: 0;
  color: #ffffff;
  font-size: 14px;
  line-height: 1;
  padding: 10px 20px;
  z-index: 2;
  transform: skew(-8deg);
  background: #555;
}

.woocommerce .products ul,
.woocommerce ul.products {
  margin: 0 0 1em;
  padding: 0;
  list-style: none outside;
  clear: both;
}

.woocommerce .products ul::after,
.woocommerce .products ul::before,
.woocommerce ul.products::after,
.woocommerce ul.products::before {
  content: " ";
  display: table;
}

.woocommerce .products ul::after,
.woocommerce ul.products::after {
  clear: both;
}

.woocommerce .products ul li,
.woocommerce ul.products li {
  list-style: none outside;
}

.woocommerce ul.products li.product .woocommerce-loop-category__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h3 {
  padding: 0.5em 0;
  margin: 0;
  font-size: 1em;
}

.woocommerce ul.products li.product a {
  text-decoration: none;
  display: block;
  text-align: center;
}

.woocommerce ul.products li.product a img {
  width: 100%;
  height: auto;
  display: block;
  margin: 0 0 1em;
  box-shadow: none;
}

.woocommerce ul.products li.product strong {
  display: block;
}

.woocommerce ul.products li.product .woocommerce-placeholder {
  border: 1px solid #f2f2f2;
}

.woocommerce ul.products li.product .star-rating {
  font-size: 0.857em;
}

.woocommerce ul.products li.product .button {
  margin: 0;
}

.woocommerce ul.products li.product .price {
  color: #009fe3;
  display: block;
  font-weight: 400;
  margin-bottom: 0.5em;
  font-size: 0.857em;
}

.woocommerce ul.products li.product .price del {
  color: inherit;
  opacity: 0.5;
  display: inline-block;
}

.woocommerce ul.products li.product .price ins {
  background: 0 0;
  font-weight: 700;
  display: inline-block;
}

.woocommerce ul.products li.product .price .from {
  font-size: 0.67em;
  margin: -2px 0 0 0;
  text-transform: uppercase;
  color: rgba(132, 132, 132, 0.5);
}

.woocommerce .woocommerce-result-count {
  margin: 0 0 1em;
  font-size: 14px;
}

.woocommerce .woocommerce-ordering {
  margin: 0 0 1em;
}
.woocommerce .woocommerce-ordering select {
  font-size: 14px;
}

.woocommerce .woocommerce-ordering select {
  vertical-align: top;
}

.woocommerce nav.woocommerce-pagination {
  text-align: center;
}

.woocommerce nav.woocommerce-pagination ul {
  display: inline-block;
  white-space: nowrap;
  padding: 0;
  clear: both;
  border: 1px solid #d3ced2;
  border-right: 0;
  margin: 1px;
}

.woocommerce nav.woocommerce-pagination ul li {
  border-right: 1px solid #d3ced2;
  padding: 0;
  margin: 0;
  float: left;
  display: inline;
  overflow: hidden;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  margin: 0;
  text-decoration: none;
  padding: 0;
  line-height: 1;
  font-size: 1em;
  font-weight: 400;
  padding: 0.5em;
  min-width: 1em;
  display: block;
}

.woocommerce nav.woocommerce-pagination ul li a:focus,
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: #ebe9eb;
  color: #8a7e88;
}

.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background-color: #e5347e;
  color: #fff;
  padding: 15px 50px;
  display: inline-block;
  transition: 0.35s;
  font-size: 15px;
  text-transform: uppercase;
  margin-top: 15px;
  position: relative;
  z-index: 2;
  transition: 0.4s;
}
@media only screen and (max-width: 1000px) {
  .woocommerce #respond input#submit,
  .woocommerce a.button,
  .woocommerce button.button,
  .woocommerce input.button {
    margin-top: 10px;
    padding: 12px 24px;
  }
}
.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background-color: #cc1a64;
  color: #fff;
}
.woocommerce #respond input#submit:hover:before,
.woocommerce a.button:hover:before,
.woocommerce button.button:hover:before,
.woocommerce input.button:hover:before {
  background-color: #cc1a64;
}

.woocommerce #respond input#submit.loading,
.woocommerce a.button.loading,
.woocommerce button.button.loading,
.woocommerce input.button.loading {
  opacity: 0.25;
  padding-right: 2.618em;
}

.woocommerce #respond input#submit.loading::after,
.woocommerce a.button.loading::after,
.woocommerce button.button.loading::after,
.woocommerce input.button.loading::after {
  font-family: WooCommerce;
  content: "\e01c";
  vertical-align: top;
  font-weight: 400;
  position: absolute;
  top: 0.618em;
  right: 1em;
  -webkit-animation: spin 2s linear infinite;
  animation: spin 2s linear infinite;
}

.woocommerce #respond input#submit.added::after,
.woocommerce a.button.added::after,
.woocommerce button.button.added::after,
.woocommerce input.button.added::after {
  font-family: WooCommerce;
  content: "\e017";
  margin-left: 0.53em;
  vertical-align: bottom;
}

.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
  background-color: #e5347e;
  color: #fff;
  -webkit-font-smoothing: antialiased;
}

.woocommerce #respond input#submit.alt.disabled,
.woocommerce #respond input#submit.alt.disabled:hover,
.woocommerce #respond input#submit.alt:disabled,
.woocommerce #respond input#submit.alt:disabled:hover,
.woocommerce #respond input#submit.alt:disabled[disabled],
.woocommerce #respond input#submit.alt:disabled[disabled]:hover,
.woocommerce a.button.alt.disabled,
.woocommerce a.button.alt.disabled:hover,
.woocommerce a.button.alt:disabled,
.woocommerce a.button.alt:disabled:hover,
.woocommerce a.button.alt:disabled[disabled],
.woocommerce a.button.alt:disabled[disabled]:hover,
.woocommerce button.button.alt.disabled,
.woocommerce button.button.alt.disabled:hover,
.woocommerce button.button.alt:disabled,
.woocommerce button.button.alt:disabled:hover,
.woocommerce button.button.alt:disabled[disabled],
.woocommerce button.button.alt:disabled[disabled]:hover,
.woocommerce input.button.alt.disabled,
.woocommerce input.button.alt.disabled:hover,
.woocommerce input.button.alt:disabled,
.woocommerce input.button.alt:disabled:hover,
.woocommerce input.button.alt:disabled[disabled],
.woocommerce input.button.alt:disabled[disabled]:hover {
  background-color: #e5347e;
  color: #fff;
}

.woocommerce #respond input#submit.disabled,
.woocommerce #respond input#submit:disabled,
.woocommerce #respond input#submit:disabled[disabled],
.woocommerce a.button.disabled,
.woocommerce a.button:disabled,
.woocommerce a.button:disabled[disabled],
.woocommerce button.button.disabled,
.woocommerce button.button:disabled,
.woocommerce button.button:disabled[disabled],
.woocommerce input.button.disabled,
.woocommerce input.button:disabled,
.woocommerce input.button:disabled[disabled] {
  color: inherit;
  cursor: not-allowed;
  opacity: 0.5;
}

.woocommerce #respond input#submit.disabled:hover,
.woocommerce #respond input#submit:disabled:hover,
.woocommerce #respond input#submit:disabled[disabled]:hover,
.woocommerce a.button.disabled:hover,
.woocommerce a.button:disabled:hover,
.woocommerce a.button:disabled[disabled]:hover,
.woocommerce button.button.disabled:hover,
.woocommerce button.button:disabled:hover,
.woocommerce button.button:disabled[disabled]:hover,
.woocommerce input.button.disabled:hover,
.woocommerce input.button:disabled:hover,
.woocommerce input.button:disabled[disabled]:hover {
  color: inherit;
  background-color: #ebe9eb;
}

.woocommerce .cart .button,
.woocommerce .cart input.button {
  float: none;
}

.woocommerce a.added_to_cart {
  padding-top: 0.5em;
  display: inline-block;
}

.woocommerce #reviews h2 small {
  float: right;
  color: #767676;
  font-size: 15px;
  margin: 10px 0 0;
}

.woocommerce #reviews h2 small a {
  text-decoration: none;
  color: #767676;
}

.woocommerce #reviews h3 {
  margin: 0;
}

.woocommerce #reviews #respond {
  margin: 0;
  border: 0;
  padding: 0;
}

.woocommerce #reviews #comment {
  height: 75px;
}

.woocommerce #reviews #comments .add_review::after,
.woocommerce #reviews #comments .add_review::before {
  content: " ";
  display: table;
}

.woocommerce #reviews #comments .add_review::after {
  clear: both;
}

.woocommerce #reviews #comments h2 {
  clear: none;
}

.woocommerce #reviews #comments ol.commentlist {
  margin: 0;
  width: 100%;
  background: 0 0;
  list-style: none;
}

.woocommerce #reviews #comments ol.commentlist::after,
.woocommerce #reviews #comments ol.commentlist::before {
  content: " ";
  display: table;
}

.woocommerce #reviews #comments ol.commentlist::after {
  clear: both;
}

.woocommerce #reviews #comments ol.commentlist li {
  padding: 0;
  margin: 0 0 20px;
  border: 0;
  position: relative;
  background: 0;
  border: 0;
}

.woocommerce #reviews #comments ol.commentlist li .meta {
  color: #767676;
  font-size: 0.75em;
}

.woocommerce #reviews #comments ol.commentlist li img.avatar {
  float: left;
  position: absolute;
  top: 0;
  left: 0;
  padding: 3px;
  width: 32px;
  height: auto;
  background: #ebe9eb;
  border: 1px solid #e4e1e3;
  margin: 0;
  box-shadow: none;
}

.woocommerce #reviews #comments ol.commentlist li .comment-text {
  margin: 0 0 0 50px;
  border: 1px solid #e4e1e3;
  border-radius: 4px;
  padding: 1em 1em 0;
}

.woocommerce #reviews #comments ol.commentlist li .comment-text::after,
.woocommerce #reviews #comments ol.commentlist li .comment-text::before {
  content: " ";
  display: table;
}

.woocommerce #reviews #comments ol.commentlist li .comment-text::after {
  clear: both;
}

.woocommerce #reviews #comments ol.commentlist li .comment-text p {
  margin: 0 0 1em;
}

.woocommerce #reviews #comments ol.commentlist li .comment-text p.meta {
  font-size: 0.83em;
}

.woocommerce #reviews #comments ol.commentlist ul.children {
  list-style: none outside;
  margin: 20px 0 0 50px;
}

.woocommerce #reviews #comments ol.commentlist ul.children .star-rating {
  display: none;
}

.woocommerce #reviews #comments ol.commentlist #respond {
  border: 1px solid #e4e1e3;
  border-radius: 4px;
  padding: 1em 1em 0;
  margin: 20px 0 0 50px;
}

.woocommerce #reviews #comments .commentlist > li::before {
  content: "";
}

.woocommerce .star-rating {
  float: right;
  overflow: hidden;
  position: relative;
  height: 1em;
  line-height: 1;
  font-size: 1em;
  width: 5.4em;
  font-family: star;
}

.woocommerce .star-rating::before {
  content: "\73\73\73\73\73";
  color: #d3ced2;
  float: left;
  top: 0;
  left: 0;
  position: absolute;
}

.woocommerce .star-rating span {
  overflow: hidden;
  float: left;
  top: 0;
  left: 0;
  position: absolute;
  padding-top: 1.5em;
}

.woocommerce .star-rating span::before {
  content: "\53\53\53\53\53";
  top: 0;
  position: absolute;
  left: 0;
}

.woocommerce .woocommerce-product-rating {
  line-height: 2;
  display: block;
}

.woocommerce .woocommerce-product-rating::after,
.woocommerce .woocommerce-product-rating::before {
  content: " ";
  display: table;
}

.woocommerce .woocommerce-product-rating::after {
  clear: both;
}

.woocommerce .woocommerce-product-rating .star-rating {
  margin: 0.5em 4px 0 0;
  float: left;
}

.woocommerce .products .star-rating {
  display: block;
  margin: 0 0 0.5em;
  float: none;
}

.woocommerce .hreview-aggregate .star-rating {
  margin: 10px 0 0;
}

.woocommerce #review_form #respond {
  position: static;
  margin: 0;
  width: auto;
  padding: 0;
  background: transparent none;
  border: 0;
}

.woocommerce #review_form #respond::after,
.woocommerce #review_form #respond::before {
  content: " ";
  display: table;
}

.woocommerce #review_form #respond::after {
  clear: both;
}

.woocommerce #review_form #respond p {
  margin: 0 0 10px;
}

.woocommerce #review_form #respond .form-submit input {
  left: auto;
}

.woocommerce #review_form #respond textarea {
  box-sizing: border-box;
  width: 100%;
}

.woocommerce p.stars a {
  position: relative;
  height: 1em;
  width: 1em;
  text-indent: -999em;
  display: inline-block;
  text-decoration: none;
}

.woocommerce p.stars a::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 1em;
  height: 1em;
  line-height: 1;
  font-family: WooCommerce;
  content: "\e021";
  text-indent: 0;
}

.woocommerce p.stars a:hover ~ a::before {
  content: "\e021";
}

.woocommerce p.stars:hover a::before {
  content: "\e020";
}

.woocommerce p.stars.selected a.active::before {
  content: "\e020";
}

.woocommerce p.stars.selected a.active ~ a::before {
  content: "\e021";
}

.woocommerce p.stars.selected a:not(.active)::before {
  content: "\e020";
}

.woocommerce table.shop_attributes {
  border: 0;
  border-top: 1px dotted rgba(0, 0, 0, 0.1);
  margin-bottom: 1.618em;
  width: 100%;
}

.woocommerce table.shop_attributes th {
  width: 150px;
  font-weight: 700;
  padding: 8px;
  border-top: 0;
  border-bottom: 1px dotted rgba(0, 0, 0, 0.1);
  margin: 0;
  line-height: 1.5;
}

.woocommerce table.shop_attributes td {
  font-style: italic;
  padding: 0;
  border-top: 0;
  border-bottom: 1px dotted rgba(0, 0, 0, 0.1);
  margin: 0;
  line-height: 1.5;
}

.woocommerce table.shop_attributes td p {
  margin: 0;
  padding: 8px 0;
}

.woocommerce table.shop_attributes tr:nth-child(even) td,
.woocommerce table.shop_attributes tr:nth-child(even) th {
  background: rgba(0, 0, 0, 0.025);
}

.woocommerce table.shop_table {
  border: 1px solid rgba(0, 0, 0, 0.1);
  margin: 0 0 50px;
  text-align: left;
  width: 100%;
  border-collapse: separate;
}

.woocommerce table.shop_table th {
  font-weight: 700;
  padding: 25px 15px;
  line-height: 1.8;
}

.woocommerce table.shop_table td {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  padding: 20px 15px;
  vertical-align: middle;
  line-height: 1.8;
}

.woocommerce table.shop_table td.product-name a {
  color: #000;
}
.woocommerce table.shop_table td.product-name a:hover {
  color: #e5347e;
}

.woocommerce table.shop_table td small {
  font-weight: 400;
}

.woocommerce table.shop_table td del {
  font-weight: 400;
}

.woocommerce table.shop_table tbody:first-child tr:first-child td,
.woocommerce table.shop_table tbody:first-child tr:first-child th {
  border-top: 0;
}

.woocommerce table.shop_table tbody th,
.woocommerce table.shop_table tfoot td,
.woocommerce table.shop_table tfoot th {
  font-weight: 700;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.woocommerce table.my_account_orders {
  font-size: 0.85em;
}

.woocommerce table.my_account_orders td,
.woocommerce table.my_account_orders th {
  padding: 4px 8px;
  vertical-align: middle;
}

.woocommerce table.my_account_orders .button {
  white-space: nowrap;
}

.woocommerce table.my_account_orders .order-actions {
  text-align: right;
}

.woocommerce table.my_account_orders .order-actions .button {
  margin: 0.125em 0 0.125em 0.25em;
}

.woocommerce table.woocommerce-MyAccount-downloads td,
.woocommerce table.woocommerce-MyAccount-downloads th {
  vertical-align: top;
  text-align: center;
}

.woocommerce table.woocommerce-MyAccount-downloads td:first-child,
.woocommerce table.woocommerce-MyAccount-downloads th:first-child {
  text-align: left;
}

.woocommerce table.woocommerce-MyAccount-downloads td:last-child,
.woocommerce table.woocommerce-MyAccount-downloads th:last-child {
  text-align: left;
}

.woocommerce
  table.woocommerce-MyAccount-downloads
  td
  .woocommerce-MyAccount-downloads-file::before,
.woocommerce
  table.woocommerce-MyAccount-downloads
  th
  .woocommerce-MyAccount-downloads-file::before {
  content: "\2193";
  display: inline-block;
}

.woocommerce td.product-name .wc-item-meta,
.woocommerce td.product-name dl.variation {
  list-style: none outside;
}

.woocommerce td.product-name .wc-item-meta .wc-item-meta-label,
.woocommerce td.product-name .wc-item-meta dt,
.woocommerce td.product-name dl.variation .wc-item-meta-label,
.woocommerce td.product-name dl.variation dt {
  float: left;
  clear: both;
  margin-right: 0.25em;
  display: inline-block;
  list-style: none outside;
}

.woocommerce td.product-name .wc-item-meta dd,
.woocommerce td.product-name dl.variation dd {
  margin: 0;
}

.woocommerce td.product-name .wc-item-meta p,
.woocommerce td.product-name .wc-item-meta:last-child,
.woocommerce td.product-name dl.variation p,
.woocommerce td.product-name dl.variation:last-child {
  margin-bottom: 0;
}

.woocommerce td.product-name p.backorder_notification {
  font-size: 0.83em;
}

.woocommerce td.product-quantity {
  min-width: 80px;
}

.woocommerce ul.cart_list,
.woocommerce ul.product_list_widget {
  list-style: none outside;
  padding: 0;
  margin: 0;
}

.woocommerce ul.cart_list li,
.woocommerce ul.product_list_widget li {
  padding: 4px 0;
  margin: 0;
  list-style: none;
}

.woocommerce ul.cart_list li::after,
.woocommerce ul.cart_list li::before,
.woocommerce ul.product_list_widget li::after,
.woocommerce ul.product_list_widget li::before {
  content: " ";
  display: table;
}

.woocommerce ul.cart_list li::after,
.woocommerce ul.product_list_widget li::after {
  clear: both;
}

.woocommerce ul.cart_list li a,
.woocommerce ul.product_list_widget li a {
  display: block;
  font-weight: 700;
}

.woocommerce ul.cart_list li img,
.woocommerce ul.product_list_widget li img {
  float: right;
  margin-left: 4px;
  width: 32px;
  height: auto;
  box-shadow: none;
}

.woocommerce ul.cart_list li dl,
.woocommerce ul.product_list_widget li dl {
  margin: 0;
  padding-left: 1em;
  border-left: 2px solid rgba(0, 0, 0, 0.1);
}

.woocommerce ul.cart_list li dl::after,
.woocommerce ul.cart_list li dl::before,
.woocommerce ul.product_list_widget li dl::after,
.woocommerce ul.product_list_widget li dl::before {
  content: " ";
  display: table;
}

.woocommerce ul.cart_list li dl::after,
.woocommerce ul.product_list_widget li dl::after {
  clear: both;
}

.woocommerce ul.cart_list li dl dd,
.woocommerce ul.cart_list li dl dt,
.woocommerce ul.product_list_widget li dl dd,
.woocommerce ul.product_list_widget li dl dt {
  display: inline-block;
  float: left;
  margin-bottom: 1em;
}

.woocommerce ul.cart_list li dl dt,
.woocommerce ul.product_list_widget li dl dt {
  font-weight: 700;
  padding: 0 0 0.25em;
  margin: 0 4px 0 0;
  clear: left;
}

.woocommerce ul.cart_list li dl dd,
.woocommerce ul.product_list_widget li dl dd {
  padding: 0 0 0.25em;
}

.woocommerce ul.cart_list li dl dd p:last-child,
.woocommerce ul.product_list_widget li dl dd p:last-child {
  margin-bottom: 0;
}

.woocommerce ul.cart_list li .star-rating,
.woocommerce ul.product_list_widget li .star-rating {
  float: none;
}

.woocommerce .widget_shopping_cart .total,
.woocommerce.widget_shopping_cart .total {
  border-top: 3px double #ebe9eb;
  padding: 4px 0 0;
}

.woocommerce .widget_shopping_cart .total strong,
.woocommerce.widget_shopping_cart .total strong {
  min-width: 40px;
  display: inline-block;
}

.woocommerce .widget_shopping_cart .cart_list li,
.woocommerce.widget_shopping_cart .cart_list li {
  padding-left: 2em;
  position: relative;
  padding-top: 0;
}

.woocommerce .widget_shopping_cart .cart_list li a.remove,
.woocommerce.widget_shopping_cart .cart_list li a.remove {
  position: absolute;
  top: 0;
  left: 0;
}

.woocommerce .widget_shopping_cart .buttons::after,
.woocommerce .widget_shopping_cart .buttons::before,
.woocommerce.widget_shopping_cart .buttons::after,
.woocommerce.widget_shopping_cart .buttons::before {
  content: " ";
  display: table;
}

.woocommerce .widget_shopping_cart .buttons::after,
.woocommerce.widget_shopping_cart .buttons::after {
  clear: both;
}

.woocommerce .widget_shopping_cart .buttons a,
.woocommerce.widget_shopping_cart .buttons a {
  margin-right: 5px;
  margin-bottom: 5px;
}

.woocommerce form .form-row {
  padding: 3px;
  margin: 0 0 6px;
}

.woocommerce form .form-row [placeholder]:focus::-webkit-input-placeholder {
  -webkit-transition: opacity 0.5s 0.5s ease;
  transition: opacity 0.5s 0.5s ease;
  opacity: 0;
}

.woocommerce form .form-row label {
  line-height: 2;
}

.woocommerce form .form-row label.hidden {
  visibility: hidden;
}

.woocommerce form .form-row label.inline {
  display: inline;
}

.woocommerce form .form-row .woocommerce-input-wrapper .description {
  background: #1e85be;
  color: #fff;
  border-radius: 3px;
  padding: 1em;
  margin: 0.5em 0 0;
  clear: both;
  display: none;
  position: relative;
}

.woocommerce form .form-row .woocommerce-input-wrapper .description a {
  color: #fff;
  text-decoration: underline;
  border: 0;
  box-shadow: none;
}

.woocommerce form .form-row .woocommerce-input-wrapper .description::before {
  left: 50%;
  top: 0;
  margin-top: -4px;
  transform: translateX(-50%) rotate(180deg);
  content: "";
  position: absolute;
  border-width: 4px 6px 0 6px;
  border-style: solid;
  border-color: #1e85be transparent transparent transparent;
  z-index: 100;
  display: block;
}

.woocommerce form .form-row select {
  cursor: pointer;
  margin: 0;
}

.woocommerce form .form-row .required {
  color: red;
  font-weight: 700;
  border: 0 !important;
  text-decoration: none;
  visibility: hidden;
}

.woocommerce form .form-row .optional {
  visibility: visible;
}

.woocommerce form .form-row .input-checkbox {
  display: inline;
  margin: -2px 8px 0 0;
  text-align: center;
  vertical-align: middle;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  outline: 0;
  line-height: normal;
}

.woocommerce form .form-row textarea {
  height: 4em;
  line-height: 1.5;
  display: block;
  box-shadow: none;
}

.woocommerce form .form-row .select2-container {
  width: 100%;
  line-height: 2em;
}

.woocommerce form .form-row.woocommerce-invalid label {
  color: #a00;
}

.woocommerce form .form-row.woocommerce-invalid .select2-container,
.woocommerce form .form-row.woocommerce-invalid input.input-text,
.woocommerce form .form-row.woocommerce-invalid select {
  border-color: #a00;
}

.woocommerce form .form-row.woocommerce-validated .select2-container,
.woocommerce form .form-row.woocommerce-validated input.input-text,
.woocommerce form .form-row.woocommerce-validated select {
  border-color: #6dc22e;
}

.woocommerce form .form-row ::-webkit-input-placeholder {
  line-height: normal;
}

.woocommerce form .form-row :-moz-placeholder {
  line-height: normal;
}

.woocommerce form .form-row :-ms-input-placeholder {
  line-height: normal;
}

.woocommerce form.checkout_coupon,
.woocommerce form.login,
.woocommerce form.register {
  border: 1px solid #d3ced2;
  padding: 20px;
  margin: 2em 0;
  text-align: left;
  border-radius: 5px;
}

.woocommerce ul#shipping_method {
  list-style: none outside;
  margin: 0;
  padding: 0;
}

.woocommerce ul#shipping_method li {
  margin: 0 0 0.5em;
  line-height: 1.5em;
  list-style: none outside;
}

.woocommerce ul#shipping_method li input {
  margin: 3px 0.4375em 0 0;
  vertical-align: top;
}

.woocommerce ul#shipping_method li label {
  display: inline;
}

.woocommerce ul#shipping_method .amount {
  font-weight: 700;
}

.woocommerce p.woocommerce-shipping-contents {
  margin: 0;
}

.woocommerce ul.order_details {
  margin: 0 0 3em;
  list-style: none;
}

.woocommerce ul.order_details::after,
.woocommerce ul.order_details::before {
  content: " ";
  display: table;
}

.woocommerce ul.order_details::after {
  clear: both;
}

.woocommerce ul.order_details li {
  float: left;
  margin-right: 2em;
  text-transform: uppercase;
  font-size: 0.715em;
  line-height: 1;
  border-right: 1px dashed #d3ced2;
  padding-right: 2em;
  margin-left: 0;
  padding-left: 0;
  list-style-type: none;
}

.woocommerce ul.order_details li strong {
  display: block;
  font-size: 1.4em;
  text-transform: none;
  line-height: 1.5;
}

.woocommerce ul.order_details li:last-of-type {
  border: none;
}

.woocommerce .wc-bacs-bank-details-account-name {
  font-weight: 700;
}

.woocommerce .woocommerce-customer-details,
.woocommerce .woocommerce-order-details,
.woocommerce .woocommerce-order-downloads {
  margin-bottom: 2em;
}

.woocommerce .woocommerce-customer-details :last-child,
.woocommerce .woocommerce-order-details :last-child,
.woocommerce .woocommerce-order-downloads :last-child {
  margin-bottom: 0;
}

.woocommerce .woocommerce-customer-details address {
  font-style: normal;
  margin-bottom: 0;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-bottom-width: 2px;
  border-right-width: 2px;
  text-align: left;
  width: 100%;
  border-radius: 5px;
  padding: 6px 12px;
}

.woocommerce .woocommerce-customer-details .woocommerce-customer-details--email,
.woocommerce
  .woocommerce-customer-details
  .woocommerce-customer-details--phone {
  margin-bottom: 0;
  padding-left: 1.5em;
}

.woocommerce
  .woocommerce-customer-details
  .woocommerce-customer-details--phone::before {
  font-family: WooCommerce;
  speak: none;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  margin-right: 0.618em;
  content: "";
  text-decoration: none;
  margin-left: -1.5em;
  line-height: 1.75;
  position: absolute;
}

.woocommerce
  .woocommerce-customer-details
  .woocommerce-customer-details--email::before {
  font-family: WooCommerce;
  speak: none;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  margin-right: 0.618em;
  content: "";
  text-decoration: none;
  margin-left: -1.5em;
  line-height: 1.75;
  position: absolute;
}

.woocommerce .woocommerce-widget-layered-nav-list {
  margin: 0;
  padding: 0;
  border: 0;
  list-style: none outside;
}

.woocommerce
  .woocommerce-widget-layered-nav-list
  .woocommerce-widget-layered-nav-list__item {
  padding: 0 0 1px;
  list-style: none;
}

.woocommerce
  .woocommerce-widget-layered-nav-list
  .woocommerce-widget-layered-nav-list__item::after,
.woocommerce
  .woocommerce-widget-layered-nav-list
  .woocommerce-widget-layered-nav-list__item::before {
  content: " ";
  display: table;
}

.woocommerce
  .woocommerce-widget-layered-nav-list
  .woocommerce-widget-layered-nav-list__item::after {
  clear: both;
}

.woocommerce
  .woocommerce-widget-layered-nav-list
  .woocommerce-widget-layered-nav-list__item
  a,
.woocommerce
  .woocommerce-widget-layered-nav-list
  .woocommerce-widget-layered-nav-list__item
  span {
  padding: 1px 0;
}

.woocommerce
  .woocommerce-widget-layered-nav-list
  .woocommerce-widget-layered-nav-list__item--chosen
  a::before {
  font-family: WooCommerce;
  speak: none;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  margin-right: 0.618em;
  content: "";
  text-decoration: none;
  color: #a00;
}

.woocommerce .woocommerce-widget-layered-nav-dropdown__submit {
  margin-top: 1em;
}

.woocommerce .widget_layered_nav_filters ul {
  margin: 0;
  padding: 0;
  border: 0;
  list-style: none outside;
  overflow: hidden;
  zoom: 1;
}

.woocommerce .widget_layered_nav_filters ul li {
  float: left;
  padding: 0 1em 1px 1px;
  list-style: none;
}

.woocommerce .widget_layered_nav_filters ul li a {
  text-decoration: none;
}

.woocommerce .widget_layered_nav_filters ul li a::before {
  font-family: WooCommerce;
  speak: none;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  margin-right: 0.618em;
  content: "";
  text-decoration: none;
  color: #a00;
  vertical-align: inherit;
  margin-right: 0.5em;
}

.woocommerce .widget_price_filter .price_slider {
  margin-bottom: 1em;
}

.woocommerce .widget_price_filter .price_slider_amount {
  text-align: right;
  line-height: 2.4;
  font-size: 0.8751em;
}

.woocommerce .widget_price_filter .price_slider_amount .button {
  font-size: 1.15em;
  float: left;
}

.woocommerce .widget_price_filter .ui-slider {
  position: relative;
  text-align: left;
  margin-left: 0.5em;
  margin-right: 0.5em;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-handle {
  position: absolute;
  z-index: 2;
  width: 1em;
  height: 1em;
  background-color: #e5347e;
  border-radius: 1em;
  cursor: ew-resize;
  outline: 0;
  top: -0.3em;
  margin-left: -0.5em;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-range {
  position: absolute;
  z-index: 1;
  font-size: 0.7em;
  display: block;
  border: 0;
  border-radius: 1em;
  background-color: #e5347e;
}

.woocommerce .widget_price_filter .price_slider_wrapper .ui-widget-content {
  border-radius: 1em;
  background-color: #462940;
  border: 0;
}

.woocommerce .widget_price_filter .ui-slider-horizontal {
  height: 0.5em;
}

.woocommerce .widget_price_filter .ui-slider-horizontal .ui-slider-range {
  top: 0;
  height: 100%;
}

.woocommerce .widget_price_filter .ui-slider-horizontal .ui-slider-range-min {
  left: -1px;
}

.woocommerce .widget_price_filter .ui-slider-horizontal .ui-slider-range-max {
  right: -1px;
}

.woocommerce .widget_rating_filter ul {
  margin: 0;
  padding: 0;
  border: 0;
  list-style: none outside;
}

.woocommerce .widget_rating_filter ul li {
  padding: 0 0 1px;
  list-style: none;
}

.woocommerce .widget_rating_filter ul li::after,
.woocommerce .widget_rating_filter ul li::before {
  content: " ";
  display: table;
}

.woocommerce .widget_rating_filter ul li::after {
  clear: both;
}

.woocommerce .widget_rating_filter ul li a {
  padding: 1px 0;
  text-decoration: none;
}

.woocommerce .widget_rating_filter ul li .star-rating {
  float: none;
  display: inline-block;
}

.woocommerce .widget_rating_filter ul li.chosen a::before {
  font-family: WooCommerce;
  speak: none;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  margin-right: 0.618em;
  content: "";
  text-decoration: none;
  color: #a00;
}

.woocommerce .woocommerce-form-login .woocommerce-form-login__submit {
  float: left;
  margin-right: 1em;
}

.woocommerce .woocommerce-form-login .woocommerce-form-login__rememberme {
  margin-top: 10px;
  display: inline-block;
}

.woocommerce-no-js form.woocommerce-form-coupon,
.woocommerce-no-js form.woocommerce-form-login {
  display: block !important;
}

.woocommerce-no-js .showcoupon,
.woocommerce-no-js .woocommerce-form-coupon-toggle,
.woocommerce-no-js .woocommerce-form-login-toggle {
  display: none !important;
}

.woocommerce-error,
.woocommerce-info,
.woocommerce-message {
  padding: 1em 2em 1em 3.5em;
  margin: 0 0 2em;
  position: relative;
  background-color: #f7f6f7;
  color: #0a0a0a;
  border-top: 3px solid #e5347e;
  list-style: none outside;
  width: auto;
  word-wrap: break-word;
  line-height: 45px;
}

.woocommerce-error::after,
.woocommerce-error::before,
.woocommerce-info::after,
.woocommerce-info::before,
.woocommerce-message::after,
.woocommerce-message::before {
  content: " ";
  display: table;
}

.woocommerce-error::after,
.woocommerce-info::after,
.woocommerce-message::after {
  clear: both;
}

.woocommerce-error::before,
.woocommerce-info::before,
.woocommerce-message::before {
  font-family: WooCommerce;
  content: "\e028";
  display: inline-block;
  position: absolute;
  top: 1em;
  left: 1.5em;
}

.woocommerce-error .button,
.woocommerce-info .button,
.woocommerce-message .button {
  float: right;
  margin-bottom: 0;
}

.woocommerce-error li,
.woocommerce-info li,
.woocommerce-message li {
  list-style: none outside !important;
  padding-left: 0 !important;
  margin-left: 0 !important;
}

.rtl.woocommerce .price_label,
.rtl.woocommerce .price_label span {
  direction: ltr;
  unicode-bidi: embed;
}

.woocommerce-message::before {
  content: "\e015";
  color: #e5347e;
}

.woocommerce-error {
  border-top-color: #b81c23;
}

.woocommerce-error::before {
  content: "\e016";
  color: #b81c23;
}

.woocommerce-account .woocommerce::after,
.woocommerce-account .woocommerce::before {
  content: " ";
  display: table;
}

.woocommerce-account .woocommerce::after {
  clear: both;
}

.woocommerce-account .addresses .title::after,
.woocommerce-account .addresses .title::before {
  content: " ";
  display: table;
}

.woocommerce-account .addresses .title::after {
  clear: both;
}

.woocommerce-account .addresses .title h3 {
  float: left;
}

.woocommerce-account .addresses .title .edit {
  float: right;
}

.woocommerce-account ol.commentlist.notes li.note p.meta {
  font-weight: 700;
  margin-bottom: 0;
}

.woocommerce-account ol.commentlist.notes li.note .description p:last-child {
  margin-bottom: 0;
}

.woocommerce-account ul.digital-downloads {
  margin-left: 0;
  padding-left: 0;
}

.woocommerce-account ul.digital-downloads li {
  list-style: none;
  margin-left: 0;
  padding-left: 0;
}

.woocommerce-account ul.digital-downloads li::before {
  font-family: WooCommerce;
  speak: none;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  margin-right: 0.618em;
  content: "";
  text-decoration: none;
}

.woocommerce-account ul.digital-downloads li .count {
  float: right;
}

#add_payment_method table.cart .product-thumbnail,
.woocommerce-cart table.cart .product-thumbnail,
.woocommerce-checkout table.cart .product-thumbnail {
  min-width: 32px;
}

#add_payment_method table.cart img,
.woocommerce-cart table.cart img,
.woocommerce-checkout table.cart img {
  width: 32px;
  box-shadow: none;
}

#add_payment_method table.cart td,
#add_payment_method table.cart th,
.woocommerce-cart table.cart td,
.woocommerce-cart table.cart th,
.woocommerce-checkout table.cart td,
.woocommerce-checkout table.cart th {
  vertical-align: middle;
}

#add_payment_method table.cart td.actions .coupon .input-text,
.woocommerce-cart table.cart td.actions .coupon .input-text,
.woocommerce-checkout table.cart td.actions .coupon .input-text {
  float: left;
  box-sizing: border-box;
  border: 1px solid #d3ced2;
  padding: 0 12px;
  margin: 0 4px 0 0;
  outline: 0;
  height: 50px;
  line-height: 50px;
  font-size: 15px;
  min-width: 200px;
}

#add_payment_method table.cart input,
.woocommerce-cart table.cart input,
.woocommerce-checkout table.cart input {
  margin: 0;
  vertical-align: middle;
}

#add_payment_method .wc-proceed-to-checkout,
.woocommerce-cart .wc-proceed-to-checkout,
.woocommerce-checkout .wc-proceed-to-checkout {
  padding: 1em 0;
}

#add_payment_method .wc-proceed-to-checkout::after,
#add_payment_method .wc-proceed-to-checkout::before,
.woocommerce-cart .wc-proceed-to-checkout::after,
.woocommerce-cart .wc-proceed-to-checkout::before,
.woocommerce-checkout .wc-proceed-to-checkout::after,
.woocommerce-checkout .wc-proceed-to-checkout::before {
  content: " ";
  display: table;
}

#add_payment_method .wc-proceed-to-checkout::after,
.woocommerce-cart .wc-proceed-to-checkout::after,
.woocommerce-checkout .wc-proceed-to-checkout::after {
  clear: both;
}

#add_payment_method .wc-proceed-to-checkout a.checkout-button,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.woocommerce-checkout .wc-proceed-to-checkout a.checkout-button {
  display: block;
  text-align: center;
  margin-bottom: 1em;
  font-size: 1.25em;
  padding: 25px 15px;
  height: auto;
}

#add_payment_method .cart-collaterals .shipping-calculator-button,
.woocommerce-cart .cart-collaterals .shipping-calculator-button,
.woocommerce-checkout .cart-collaterals .shipping-calculator-button {
  float: none;
  margin-top: 0.5em;
  display: inline-block;
}

#add_payment_method .cart-collaterals .shipping-calculator-button::after,
.woocommerce-cart .cart-collaterals .shipping-calculator-button::after,
.woocommerce-checkout .cart-collaterals .shipping-calculator-button::after {
  font-family: WooCommerce;
  speak: none;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  margin-left: 0.618em;
  content: "";
  text-decoration: none;
}

#add_payment_method .cart-collaterals .shipping-calculator-form,
.woocommerce-cart .cart-collaterals .shipping-calculator-form,
.woocommerce-checkout .cart-collaterals .shipping-calculator-form {
  margin: 1em 0 0 0;
}

#add_payment_method .cart-collaterals .cart_totals p small,
.woocommerce-cart .cart-collaterals .cart_totals p small,
.woocommerce-checkout .cart-collaterals .cart_totals p small {
  color: #767676;
  font-size: 0.83em;
}

#add_payment_method .cart-collaterals .cart_totals table,
.woocommerce-cart .cart-collaterals .cart_totals table,
.woocommerce-checkout .cart-collaterals .cart_totals table {
  border-collapse: separate;
  margin: 0 0 6px;
  padding: 0;
}

#add_payment_method .cart-collaterals .cart_totals table tr:first-child td,
#add_payment_method .cart-collaterals .cart_totals table tr:first-child th,
.woocommerce-cart .cart-collaterals .cart_totals table tr:first-child td,
.woocommerce-cart .cart-collaterals .cart_totals table tr:first-child th,
.woocommerce-checkout .cart-collaterals .cart_totals table tr:first-child td,
.woocommerce-checkout .cart-collaterals .cart_totals table tr:first-child th {
  border-top: 0;
}

#add_payment_method .cart-collaterals .cart_totals table th,
.woocommerce-cart .cart-collaterals .cart_totals table th,
.woocommerce-checkout .cart-collaterals .cart_totals table th {
  width: 35%;
}

#add_payment_method .cart-collaterals .cart_totals table td,
#add_payment_method .cart-collaterals .cart_totals table th,
.woocommerce-cart .cart-collaterals .cart_totals table td,
.woocommerce-cart .cart-collaterals .cart_totals table th,
.woocommerce-checkout .cart-collaterals .cart_totals table td,
.woocommerce-checkout .cart-collaterals .cart_totals table th {
  vertical-align: top;
  border-left: 0;
  border-right: 0;
  line-height: 1.5em;
}

#add_payment_method .cart-collaterals .cart_totals table small,
.woocommerce-cart .cart-collaterals .cart_totals table small,
.woocommerce-checkout .cart-collaterals .cart_totals table small {
  color: #767676;
}

#add_payment_method .cart-collaterals .cart_totals table select,
.woocommerce-cart .cart-collaterals .cart_totals table select,
.woocommerce-checkout .cart-collaterals .cart_totals table select {
  width: 100%;
}

#add_payment_method .cart-collaterals .cart_totals .discount td,
.woocommerce-cart .cart-collaterals .cart_totals .discount td,
.woocommerce-checkout .cart-collaterals .cart_totals .discount td {
  color: #009fe3;
}

#add_payment_method .cart-collaterals .cart_totals tr td,
#add_payment_method .cart-collaterals .cart_totals tr th,
.woocommerce-cart .cart-collaterals .cart_totals tr td,
.woocommerce-cart .cart-collaterals .cart_totals tr th,
.woocommerce-checkout .cart-collaterals .cart_totals tr td,
.woocommerce-checkout .cart-collaterals .cart_totals tr th {
  border-top: 1px solid #ebe9eb;
}

#add_payment_method
  .cart-collaterals
  .cart_totals
  .woocommerce-shipping-destination,
.woocommerce-cart
  .cart-collaterals
  .cart_totals
  .woocommerce-shipping-destination,
.woocommerce-checkout
  .cart-collaterals
  .cart_totals
  .woocommerce-shipping-destination {
  margin-bottom: 0;
}

#add_payment_method .cart-collaterals .cross-sells ul.products li.product,
.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product,
.woocommerce-checkout .cart-collaterals .cross-sells ul.products li.product {
  margin-top: 0;
}

#add_payment_method .checkout .col-2 h3#ship-to-different-address,
.woocommerce-cart .checkout .col-2 h3#ship-to-different-address,
.woocommerce-checkout .checkout .col-2 h3#ship-to-different-address {
  float: left;
  clear: none;
}

#add_payment_method .checkout .col-2 .notes,
.woocommerce-cart .checkout .col-2 .notes,
.woocommerce-checkout .checkout .col-2 .notes {
  clear: left;
}

#add_payment_method .checkout .col-2 .form-row-first,
.woocommerce-cart .checkout .col-2 .form-row-first,
.woocommerce-checkout .checkout .col-2 .form-row-first {
  clear: left;
}

#add_payment_method .checkout .create-account small,
.woocommerce-cart .checkout .create-account small,
.woocommerce-checkout .checkout .create-account small {
  font-size: 11px;
  color: #767676;
  font-weight: 400;
}

#add_payment_method .checkout div.shipping-address,
.woocommerce-cart .checkout div.shipping-address,
.woocommerce-checkout .checkout div.shipping-address {
  padding: 0;
  clear: left;
  width: 100%;
}

#add_payment_method .checkout .shipping_address,
.woocommerce-cart .checkout .shipping_address,
.woocommerce-checkout .checkout .shipping_address {
  clear: both;
}

#add_payment_method #payment,
.woocommerce-cart #payment,
.woocommerce-checkout #payment {
  background: #ebe9eb;
  border-radius: 5px;
}

#add_payment_method #payment ul.payment_methods,
.woocommerce-cart #payment ul.payment_methods,
.woocommerce-checkout #payment ul.payment_methods {
  text-align: left;
  padding: 1em;
  border-bottom: 1px solid #d3ced2;
  margin: 0;
  list-style: none outside;
}

#add_payment_method #payment ul.payment_methods::after,
#add_payment_method #payment ul.payment_methods::before,
.woocommerce-cart #payment ul.payment_methods::after,
.woocommerce-cart #payment ul.payment_methods::before,
.woocommerce-checkout #payment ul.payment_methods::after,
.woocommerce-checkout #payment ul.payment_methods::before {
  content: " ";
  display: table;
}

#add_payment_method #payment ul.payment_methods::after,
.woocommerce-cart #payment ul.payment_methods::after,
.woocommerce-checkout #payment ul.payment_methods::after {
  clear: both;
}

#add_payment_method #payment ul.payment_methods li,
.woocommerce-cart #payment ul.payment_methods li,
.woocommerce-checkout #payment ul.payment_methods li {
  line-height: 2;
  text-align: left;
  margin: 0;
  font-weight: 400;
}

#add_payment_method #payment ul.payment_methods li input,
.woocommerce-cart #payment ul.payment_methods li input,
.woocommerce-checkout #payment ul.payment_methods li input {
  margin: 0 1em 0 0;
}

#add_payment_method #payment ul.payment_methods li img,
.woocommerce-cart #payment ul.payment_methods li img,
.woocommerce-checkout #payment ul.payment_methods li img {
  vertical-align: middle;
  margin: -2px 0 0 0.5em;
  padding: 0;
  position: relative;
  box-shadow: none;
}

#add_payment_method #payment ul.payment_methods li img + img,
.woocommerce-cart #payment ul.payment_methods li img + img,
.woocommerce-checkout #payment ul.payment_methods li img + img {
  margin-left: 2px;
}

#add_payment_method
  #payment
  ul.payment_methods
  li:not(.woocommerce-notice)::after,
#add_payment_method
  #payment
  ul.payment_methods
  li:not(.woocommerce-notice)::before,
.woocommerce-cart
  #payment
  ul.payment_methods
  li:not(.woocommerce-notice)::after,
.woocommerce-cart
  #payment
  ul.payment_methods
  li:not(.woocommerce-notice)::before,
.woocommerce-checkout
  #payment
  ul.payment_methods
  li:not(.woocommerce-notice)::after,
.woocommerce-checkout
  #payment
  ul.payment_methods
  li:not(.woocommerce-notice)::before {
  content: " ";
  display: table;
}

#add_payment_method
  #payment
  ul.payment_methods
  li:not(.woocommerce-notice)::after,
.woocommerce-cart
  #payment
  ul.payment_methods
  li:not(.woocommerce-notice)::after,
.woocommerce-checkout
  #payment
  ul.payment_methods
  li:not(.woocommerce-notice)::after {
  clear: both;
}

#add_payment_method #payment div.form-row,
.woocommerce-cart #payment div.form-row,
.woocommerce-checkout #payment div.form-row {
  padding: 1em;
}

#add_payment_method #payment div.payment_box,
.woocommerce-cart #payment div.payment_box,
.woocommerce-checkout #payment div.payment_box {
  position: relative;
  box-sizing: border-box;
  width: 100%;
  padding: 1em;
  margin: 1em 0;
  font-size: 0.92em;
  border-radius: 2px;
  line-height: 1.5;
  background-color: #dfdcde;
  color: #0a0a0a;
}

#add_payment_method #payment div.payment_box input.input-text,
#add_payment_method #payment div.payment_box textarea,
.woocommerce-cart #payment div.payment_box input.input-text,
.woocommerce-cart #payment div.payment_box textarea,
.woocommerce-checkout #payment div.payment_box input.input-text,
.woocommerce-checkout #payment div.payment_box textarea {
  border-color: #c7c1c6;
  border-top-color: #bbb3b9;
}

#add_payment_method #payment div.payment_box ::-webkit-input-placeholder,
.woocommerce-cart #payment div.payment_box ::-webkit-input-placeholder,
.woocommerce-checkout #payment div.payment_box ::-webkit-input-placeholder {
  color: #bbb3b9;
}

#add_payment_method #payment div.payment_box :-moz-placeholder,
.woocommerce-cart #payment div.payment_box :-moz-placeholder,
.woocommerce-checkout #payment div.payment_box :-moz-placeholder {
  color: #bbb3b9;
}

#add_payment_method #payment div.payment_box :-ms-input-placeholder,
.woocommerce-cart #payment div.payment_box :-ms-input-placeholder,
.woocommerce-checkout #payment div.payment_box :-ms-input-placeholder {
  color: #bbb3b9;
}

#add_payment_method #payment div.payment_box .woocommerce-SavedPaymentMethods,
.woocommerce-cart #payment div.payment_box .woocommerce-SavedPaymentMethods,
.woocommerce-checkout
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods {
  list-style: none outside;
  margin: 0;
}

#add_payment_method
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-new,
#add_payment_method
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-token,
.woocommerce-cart
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-new,
.woocommerce-cart
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-token,
.woocommerce-checkout
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-new,
.woocommerce-checkout
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-token {
  margin: 0 0 0.5em;
}

#add_payment_method
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-new
  label,
#add_payment_method
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-token
  label,
.woocommerce-cart
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-new
  label,
.woocommerce-cart
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-token
  label,
.woocommerce-checkout
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-new
  label,
.woocommerce-checkout
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-token
  label {
  cursor: pointer;
}

#add_payment_method
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-tokenInput,
.woocommerce-cart
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-tokenInput,
.woocommerce-checkout
  #payment
  div.payment_box
  .woocommerce-SavedPaymentMethods
  .woocommerce-SavedPaymentMethods-tokenInput {
  vertical-align: middle;
  margin: -3px 1em 0 0;
  position: relative;
}

#add_payment_method #payment div.payment_box .wc-credit-card-form,
.woocommerce-cart #payment div.payment_box .wc-credit-card-form,
.woocommerce-checkout #payment div.payment_box .wc-credit-card-form {
  border: 0;
  padding: 0;
  margin: 1em 0 0;
}

#add_payment_method #payment div.payment_box .wc-credit-card-form-card-cvc,
#add_payment_method #payment div.payment_box .wc-credit-card-form-card-expiry,
#add_payment_method #payment div.payment_box .wc-credit-card-form-card-number,
.woocommerce-cart #payment div.payment_box .wc-credit-card-form-card-cvc,
.woocommerce-cart #payment div.payment_box .wc-credit-card-form-card-expiry,
.woocommerce-cart #payment div.payment_box .wc-credit-card-form-card-number,
.woocommerce-checkout #payment div.payment_box .wc-credit-card-form-card-cvc,
.woocommerce-checkout #payment div.payment_box .wc-credit-card-form-card-expiry,
.woocommerce-checkout
  #payment
  div.payment_box
  .wc-credit-card-form-card-number {
  font-size: 1.5em;
  padding: 8px;
  background-repeat: no-repeat;
  background-position: right 0.618em center;
  background-size: 32px 20px;
}

#add_payment_method #payment div.payment_box span.help,
.woocommerce-cart #payment div.payment_box span.help,
.woocommerce-checkout #payment div.payment_box span.help {
  font-size: 0.857em;
  color: #767676;
  font-weight: 400;
}

#add_payment_method #payment div.payment_box .form-row,
.woocommerce-cart #payment div.payment_box .form-row,
.woocommerce-checkout #payment div.payment_box .form-row {
  margin: 0 0 1em;
}

#add_payment_method #payment div.payment_box p:last-child,
.woocommerce-cart #payment div.payment_box p:last-child,
.woocommerce-checkout #payment div.payment_box p:last-child {
  margin-bottom: 0;
}

#add_payment_method #payment div.payment_box::before,
.woocommerce-cart #payment div.payment_box::before,
.woocommerce-checkout #payment div.payment_box::before {
  content: "";
  display: block;
  border: 1em solid #dfdcde;
  border-right-color: transparent;
  border-left-color: transparent;
  border-top-color: transparent;
  position: absolute;
  top: -0.75em;
  left: 0;
  margin: -1em 0 0 2em;
}

#add_payment_method #payment .payment_method_paypal .about_paypal,
.woocommerce-cart #payment .payment_method_paypal .about_paypal,
.woocommerce-checkout #payment .payment_method_paypal .about_paypal {
  float: right;
  line-height: 52px;
  font-size: 0.83em;
}

#add_payment_method #payment .payment_method_paypal img,
.woocommerce-cart #payment .payment_method_paypal img,
.woocommerce-checkout #payment .payment_method_paypal img {
  max-height: 52px;
  vertical-align: middle;
}

.woocommerce-terms-and-conditions {
  border: 1px solid rgba(0, 0, 0, 0.2);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
  background: rgba(0, 0, 0, 0.05);
}

.woocommerce-invalid #terms {
  outline: 2px solid red;
  outline-offset: 2px;
}

.woocommerce-password-strength {
  text-align: center;
  font-weight: 600;
  padding: 3px 0.5em;
  font-size: 1em;
}

.woocommerce-password-strength.strong {
  background-color: #c1e1b9;
  border-color: #83c373;
}

.woocommerce-password-strength.short {
  background-color: #f1adad;
  border-color: #e35b5b;
}

.woocommerce-password-strength.bad {
  background-color: #fbc5a9;
  border-color: #f78b53;
}

.woocommerce-password-strength.good {
  background-color: #ffe399;
  border-color: #ffc733;
}

.woocommerce-password-hint {
  margin: 0.5em 0 0;
  display: block;
}

.woocommerce-cart-form tbody tr:nth-child(even) {
  border-bottom: 0;
  background-color: transparent;
}

@media screen and (min-width: 1024px) {
  .woocommerce-cart .woocommerce {
    display: flex;
    flex-flow: row wrap;
  }
  .woocommerce-cart .woocommerce .woocommerce-cart-form {
    width: 60%;
  }
  .woocommerce-cart .woocommerce .cart-collaterals {
    width: 40%;
    padding-left: 5%;
  }
  .woocommerce-cart .woocommerce .cart-collaterals .cart_totals {
    float: none;
    width: 100%;
  }
  .woocommerce-cart .woocommerce .cart-collaterals .cart_totals > h2 {
    display: none;
  }
}

.woocommerce-cart .woocommerce .cart-collaterals .cart_totals {
  width: 100%;
}

.woocommerce-form p {
  font-size: 14px;
  padding: 0 4px;
}

h3#order_review_heading {
  font-size: 20px;
  margin-top: 35px;
}

.woocommerce-additional-fields h3,
.woocommerce-billing-fields h3 {
  font-size: 20px;
}

#add_payment_method #payment div.payment_box p:last-child,
.woocommerce-cart #payment div.payment_box p:last-child,
.woocommerce-checkout #payment div.payment_box p:last-child {
  font-size: 14px;
  margin: 0;
}

.woocommerce-notices-wrapper {
  width: 100%;
}

.woocommerce-account .main {
  min-height: 60vh;
}

.woocommerce-account h1 {
  font-size: 28px;
  margin: 0 0 20px;
}

.woocommerce-account h2 {
  font-size: 23px;
  margin: 0 0 15px;
}

.woocommerce-account h3 {
  font-size: 18px;
  margin: 0 0 12px;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
  padding: 0;
  background: #e5347e;
  color: #000;
}
@media screen and (min-width: 768px) {
  .woocommerce-account .woocommerce-MyAccount-navigation {
    width: 25%;
    margin-right: 5%;
  }
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  margin: 0;
  list-style: none;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li {
  margin: 0;
}
.woocommerce-account
  .woocommerce-MyAccount-navigation
  ul
  li.woocommerce-MyAccount-navigation-link {
  position: relative;
}
.woocommerce-account
  .woocommerce-MyAccount-navigation
  ul
  li.woocommerce-MyAccount-navigation-link:after {
  font-family: "Font Awesome 5 Pro";
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  font-weight: 600;
  width: 20px;
  text-align: center;
  color: #fff;
}
.woocommerce-account
  .woocommerce-MyAccount-navigation
  ul
  li.woocommerce-MyAccount-navigation-link--dashboard:after {
  content: "\f0e4";
}
.woocommerce-account
  .woocommerce-MyAccount-navigation
  ul
  li.woocommerce-MyAccount-navigation-link--orders:after {
  content: "\f291";
}
.woocommerce-account
  .woocommerce-MyAccount-navigation
  ul
  li.woocommerce-MyAccount-navigation-link--downloads:after {
  content: "\f019";
}
.woocommerce-account
  .woocommerce-MyAccount-navigation
  ul
  li.woocommerce-MyAccount-navigation-link--edit-address:after {
  content: "\f90d";
}
.woocommerce-account
  .woocommerce-MyAccount-navigation
  ul
  li.woocommerce-MyAccount-navigation-link--edit-account:after {
  content: "\f007";
}
.woocommerce-account
  .woocommerce-MyAccount-navigation
  ul
  li.woocommerce-MyAccount-navigation-link--customer-logout:after {
  content: "\f2f5";
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 10px 20px 10px 55px;
  color: #fff;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  color: #fff;
  background: rgba(0, 0, 0, 0.1);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
  background: rgba(0, 0, 0, 0.1);
}

.woocommerce-EditAccountForm fieldset {
  margin-top: 30px;
}
.woocommerce-EditAccountForm fieldset legend {
  font-weight: 800;
}

.woocommerce .woocommerce-breadcrumb {
  text-align: left;
  font-size: 13px;
  margin: 0 0 25px;
}

.woocommerce ul.products li.product {
  text-align: center;
}
.woocommerce ul.products li.product .woocommerce-loop-category__title {
  padding: 0;
  margin: 25px auto 0;
  font-size: 21px;
  letter-spacing: 3px;
  color: #000;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  padding: 0;
  margin: 30px auto 15px;
  font-size: 21px;
  letter-spacing: 3px;
  color: #000;
}
.woocommerce ul.products li.product .count {
  display: none;
}
.woocommerce ul.products li.product .price {
  margin: 0;
  padding: 0;
  color: #000;
  line-height: 1;
}
.woocommerce ul.products li.product .price .amount {
  font-weight: 700;
  font-size: 25px;
  color: #e5347e;
}
.woocommerce ul.products li.product .price del {
  font-weight: 700;
  font-size: 16px;
  opacity: 0.25;
  color: #000;
  line-height: 1;
  display: block;
  margin-bottom: 7px;
}
.woocommerce ul.products li.product .price del .amount {
  font-size: 16px;
  color: #000;
}
.woocommerce ul.products li.product .price ins {
  font-weight: 700;
  text-decoration: none;
  font-size: 25px;
  color: #e5347e;
  line-height: 1;
  display: block;
}
.woocommerce ul.products li.product a.button {
  display: inline-block;
  margin: 25px auto 0;
}

#woo-main {
  margin-top: 25px;
}

.woocommerce-error.cart-empty,
.woocommerce-info.cart-empty,
.woocommerce-message.cart-empty {
  width: 100%;
}

.woocommerce-page .content {
  padding-top: 5vh;
  padding-bottom: 5vh;
}

.woocommerce-page [type="text"],
.woocommerce-page [type="password"],
.woocommerce-page [type="date"],
.woocommerce-page [type="datetime"],
.woocommerce-page [type="datetime-local"],
.woocommerce-page [type="month"],
.woocommerce-page [type="week"],
.woocommerce-page [type="email"],
.woocommerce-page [type="number"],
.woocommerce-page [type="search"],
.woocommerce-page [type="tel"],
.woocommerce-page [type="time"],
.woocommerce-page [type="url"],
.woocommerce-page [type="color"],
.woocommerce-page select {
  box-shadow: none;
  height: 2.4375rem;
  font-size: 14px;
  padding: 0.5rem;
  border: 1px solid #cacaca;
  border-radius: 0;
  background-color: #fefefe;
  background-image: none;
  -webkit-appearance: auto;
  -moz-appearance: auto;
  appearance: auto;
}

.woocommerce-page textarea {
  box-shadow: none;
  min-height: 150px;
  font-size: 14px;
}

.woocommerce #payment #place_order,
.woocommerce-page #payment #place_order {
  font-size: 16px;
  padding: 25px 50px;
  margin-top: 25px;
}

.woocommerce table.shop_table_responsive tr td::before,
.woocommerce-page table.shop_table_responsive tr td::before {
  margin-right: 10px;
}

.woocommerce table.shop_table_responsive tr td,
.woocommerce-page table.shop_table_responsive tr td {
  text-align: left !important;
}
.woocommerce table.shop_table_responsive tr td.product-quantity,
.woocommerce-page table.shop_table_responsive tr td.product-quantity {
  line-height: 45px;
}

@media screen and (max-width: 600px) {
  .woocommerce-cart table.cart td.actions .coupon .input-text {
    width: 100%;
    display: block;
  }
  .woocommerce table.cart td.actions .coupon .input-text + .button {
    display: block;
    width: 100%;
    font-size: 13px;
    margin-top: 5px;
  }
}

/* Product Page */
.woocommerce div.product .product_title {
  font-weight: 700;
  font-size: 36px;
}

.woocommerce div.product form.cart .variations thead,
.woocommerce div.product form.cart .variations tbody,
.woocommerce div.product form.cart .variations tfoot {
  border: none;
  background: none;
}

.woocommerce div.product form.cart .variations tbody tr:nth-child(even) {
  background: none;
}

.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th {
  margin: 0;
  padding: 5px 0;
  vertical-align: middle;
  line-height: 1;
}

.woocommerce div.product form.cart .variations .label,
.woocommerce div.product form.cart .variations label {
  background: none;
  margin: 0;
}

.woocommerce div.product form.cart .variations .label {
  display: table-cell;
}

.woocommerce div.product form.cart .variations select {
  margin: 0;
  padding: 0 15px;
  border: 1px solid #e5347e;
  font-weight: 700;
}

.woocommerce div.product .woocommerce-variation-price {
  margin-top: 30px;
  margin-bottom: 35px;
}
.woocommerce div.product .woocommerce-variation-price .price {
  font-size: 26px;
}

#wooswipe .thumbnails {
  height: auto;
}

.woocommerce-Tabs-panel h2:first-of-type {
  display: none;
}

p.woocommerce-store-notice.demo_store {
  position: initial;
  padding: 2px 0;
  font-size: 15px;
  z-index: 9999;
}

.paginate {
  text-align: center;
}
.paginate__number {
  border: 1px solid #e5347e;
  color: #e5347e;
  padding: 5px;
  width: 40px;
  display: inline-block;
}
.paginate__number--selected {
  color: #fff;
  background-color: #e5347e;
}
.paginate__number--spacer {
  border: none;
  padding: 2px;
  width: 30px;
}

.home-banner {
  position: relative;
  height: 830px;
  width: 100%;
  overflow: hidden;
}
.home-banner .banner {
  height: 830px !important;
  width: 100%;
  position: relative;
}
.home-banner .banner .slides,
.home-banner .banner .slick-slider {
  height: 830px;
  width: 100%;
}
.home-banner .banner .slick-list,
.home-banner .banner .slick-track {
  height: 830px;
  width: 100%;
}
.home-banner .banner .slick-slide {
  height: 830px;
  width: 100%;
}
.home-banner .banner .slick-slide > div {
  height: 100%;
  width: 100%;
}
.home-banner .banner img,
.home-banner .banner picture img {
  width: 100%;
  height: 830px !important;
  min-height: 830px;
  object-fit: cover;
  object-position: center center;
  -o-object-fit: cover;
  -o-object-position: center center;
  display: block;
}
.home-banner .banner-item {
  height: 830px;
  width: 100%;
  position: relative;
  overflow: hidden;
  background: transparent;
}
.home-banner .banner-item picture {
  width: 100%;
  height: 100%;
  display: block;
}
.home-banner .banner-item img {
  width: 100%;
  height: 830px !important;
  min-height: 830px;
  object-fit: cover;
  object-position: center center;
  -o-object-fit: cover;
  -o-object-position: center center;
  display: block;
}

.home-banner .slides.slick-slider.slick-initialized.slick-dotted {
  height: 830px !important;
  min-height: 830px;
}

.home-banner .slides.slick-slider.slick-initialized.slick-dotted .slick-list,
.home-banner .slides.slick-slider.slick-initialized.slick-dotted .slick-track,
.home-banner .slides.slick-slider.slick-initialized.slick-dotted .slick-slide {
  height: 830px !important;
  min-height: 830px;
}

.home-banner .slides.slick-slider.slick-initialized.slick-dotted .banner-item,
.home-banner
  .slides.slick-slider.slick-initialized.slick-dotted
  .banner-item
  img,
.home-banner .slides.slick-slider.slick-initialized.slick-dotted picture,
.home-banner .slides.slick-slider.slick-initialized.slick-dotted picture img {
  height: 830px !important;
  min-height: 830px;
}

@media (max-width: 768px) {
  .home-banner {
    height: 740px !important;
    min-height: 740px !important;
    max-height: 740px !important;
  }

  .home-banner .banner {
    height: 740px !important;
    min-height: 740px !important;
    max-height: 740px !important;
  }

  .home-banner .banner .slides,
  .home-banner .banner .slick-slider {
    height: 740px !important;
    min-height: 740px !important;
    max-height: 740px !important;
  }

  .home-banner .banner .slick-list,
  .home-banner .banner .slick-track {
    height: 740px !important;
    min-height: 740px !important;
    max-height: 740px !important;
  }

  .home-banner .banner .slick-slide {
    height: 740px !important;
    min-height: 740px !important;
    max-height: 740px !important;
  }

  .home-banner .banner-item {
    height: 740px !important;
    min-height: 740px !important;
    max-height: 740px !important;
  }

  .home-banner .banner-item picture {
    height: 740px !important;
    min-height: 740px !important;
    max-height: 740px !important;
  }

  .home-banner .banner-item img {
    height: 740px !important;
    min-height: 740px !important;
    max-height: 740px !important;
  }

  .home-banner .slides.slick-slider.slick-initialized.slick-dotted {
    height: 740px !important;
    min-height: 740px !important;
    max-height: 740px !important;
  }

  .home-banner .slides.slick-slider.slick-initialized.slick-dotted .slick-list,
  .home-banner .slides.slick-slider.slick-initialized.slick-dotted .slick-track,
  .home-banner
    .slides.slick-slider.slick-initialized.slick-dotted
    .slick-slide {
    height: 740px !important;
    min-height: 740px !important;
    max-height: 740px !important;
  }

  .home-banner .slides.slick-slider.slick-initialized.slick-dotted .banner-item,
  .home-banner
    .slides.slick-slider.slick-initialized.slick-dotted
    .banner-item
    img,
  .home-banner .slides.slick-slider.slick-initialized.slick-dotted picture,
  .home-banner .slides.slick-slider.slick-initialized.slick-dotted picture img {
    height: 740px !important;
    min-height: 740px !important;
    max-height: 740px !important;
  }
}

.home-banner .banner-item .banner-overlay {
  position: absolute !important;
  top: auto !important;
  bottom: 102px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 100% !important;
  z-index: 3;
  text-align: center;
  margin: 0 !important;
  padding: 0 !important;
}
@media (max-width: 749px) {
  .home-banner .banner-item .banner-overlay {
    bottom: 82px !important;
    transform: translateX(-50%) !important;
  }
}
.home-banner .banner-item .banner-overlay .grid-x {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  height: auto !important;
  margin-bottom: 0 !important;
}
.home-banner .banner-item .banner-overlay .overlay-content {
  text-align: center !important;
  margin: 0 auto !important;
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}
.home-banner .banner-item .banner-overlay .overlay-content h1,
.home-banner .banner-item .banner-overlay .overlay-content h2 {
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
  width: 100%;
  font-weight: 600 !important;
  margin-bottom: 0.1rem !important;
  line-height: 1.2 !important;
}
.home-banner .banner-item .banner-overlay .overlay-content p {
  text-align: center !important;
  margin-bottom: 0 !important;
  line-height: 1.3 !important;
}
@media (max-width: 749px) {
  .home-banner .banner-item .banner-overlay .overlay-content {
    margin-bottom: 12rem !important;
  }
}
.home-banner__overlay {
  position: absolute;
  bottom: 100px;
  left: 50%;
  transform: translateX(-50%);
  width: 55vw;
  max-width: 1200px;
  z-index: 10;
}
@media (max-width: 720px) {
  .home-banner__overlay {
    width: 95vw;
    bottom: 20px;
  }
}

.button-list {
  padding: 0 20%;
  width: 100%;
  display: flex;
  flex-direction: row;
  background-color: #f5f5f5;
}
@media (max-width: 1300px) {
  .button-list {
    padding: 0 10%;
  }
}
@media (max-width: 1000px) {
  .button-list {
    padding: 0;
  }
}
@media (max-width: 700px) {
  .button-list {
    flex-direction: column;
  }
}
.button-list__button {
  flex-grow: 1;
  text-align: center;
  padding: 10px 5px;
}
.button-list__button:not(:last-child) {
  border-right: 1px solid #ececec;
}
.button-list__button--active,
.button-list__button:hover,
.button-list__button:focus {
  background-color: #e5347e;
  color: #fff;
}

.map-responsive {
  height: 600px !important;
}

#properties-map {
  min-height: 600px;
}

#properties--listings {
  position: -webkit-sticky;
  position: sticky;
  top: 0px;
}

.infoBox > img {
  z-index: 1000;
}

/*
* === GENERAL STYLES ===
*/
body {
  overflow-x: hidden;
}

.scrollup {
  position: fixed;
  text-align: center;
  width: 40px;
  height: 40px;
  bottom: 30px;
  right: 30px;
  display: none;
  background-color: #fff;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
  color: #0a0a0a;
  line-height: 40px;
  font-size: 20px;
  font-weight: 700;
}

.content {
  padding: 8vh 0;
}

/* 
* === MAIN CONTENT ===
*/
.off-canvas-wrapper {
  overflow-y: hidden;
}

.page-template-home .off-canvas-wrapper {
  overflow: inherit;
}

.home-banner #home-search {
  background: rgba(255, 255, 255, 0.9);
  padding: 25px 0;
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  border-radius: 0;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}
.home-banner__overlay {
  position: absolute;
  bottom: 100px;
  left: 50%;
  transform: translateX(-50%);
  width: 55vw;
  max-width: 1200px;
  z-index: 10;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}
#home-search {
  background: #fff;
  padding: 25px 0;
  border-radius: 0;
}
@media (max-width: 720px) {
  .home-banner__overlay {
    width: calc(100% - 30px) !important;
    bottom: 20px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    margin-bottom: 2rem !important;
  }

  .home-banner #home-search,
  #home-search {
    padding: 20px 15px !important;
    background: #fff !important;
    border-radius: 8px !important;
  }
}

/* Small mobile devices (max-width: 480px) - Homepage filter spacing */
@media (max-width: 480px) {
  .home-banner__overlay.properties-search-overlay,
  .home-banner__overlay {
    margin-bottom: 40px !important;
    padding-bottom: 20px !important;
  }

  .home-banner__overlay #home-search,
  #home-search {
    margin-bottom: 30px !important;
  }

  /* Ensure proper spacing after banner section */
  .home-banner {
    margin-bottom: 30px !important;
    padding-bottom: 20px !important;
  }
}

/* Extra small mobile devices (iPhone SE - 375px and below) */
@media (max-width: 375px) {
  .home-banner__overlay.properties-search-overlay,
  .home-banner__overlay {
    margin-bottom: 50px !important;
    padding-bottom: 25px !important;
  }

  .home-banner__overlay #home-search,
  #home-search {
    margin-bottom: 30px !important;
  }

  /* Ensure proper spacing after banner section */
  .home-banner {
    margin-bottom: 40px !important;
    padding-bottom: 25px !important;
  }
}
#home-search .small-12 {
  padding: 0 25px;
}
@media (max-width: 700px) {
  #home-search .small-12 {
    padding: 0;
  }
}
#home-search .small-12 form {
  display: flex;
  flex-flow: row nowrap;
  justify-content: flex-start;
  align-items: stretch;
  gap: 10px;
}
#home-search .small-12 form > div {
  flex: 1 1 auto;
  min-width: 0;
}
#home-search .small-12 i,
#home-search .small-12 .material-icons {
  font-size: 24px;
  font-weight: normal;
  color: #e5347e;
  display: inline-block;
  vertical-align: middle;
}
#home-search .small-12 select {
  margin: 0;
  border: none;
  box-shadow: none;
  background: #f5f5f5;
}
#home-search .small-12 .where__wrapper,
#home-search .small-12 .date__wrapper,
#home-search .small-12 .property__wrapper,
#home-search .small-12 .code__wrapper,
#home-search .small-12 .nights__wrapper,
#home-search .small-12 .people__wrapper,
#home-search .small-12 .flexibility__wrapper {
  padding: 15px 12px;
  background: #fff;
  border-radius: 3px;
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid #e0e0e0;
  height: 100%;
  min-height: 54px;
  box-sizing: border-box;
  width: 100%;
  flex: 1;
  overflow: visible;
}
.page-template-properties #home-search .small-12 .where__wrapper,
.page-template-properties #home-search .small-12 .date__wrapper,
.page-template-properties #home-search .small-12 .property__wrapper,
.page-template-properties #home-search .small-12 .nights__wrapper,
.page-template-properties #home-search .small-12 .people__wrapper,
.page-template-properties #home-search .small-12 .flexibility__wrapper {
  height: 50px !important;
  min-height: 50px !important;
  max-height: 50px !important;
  width: 245px !important;
  padding: 0 12px !important;
}
#home-search .small-12 .where__wrapper > *:not(.material-icons),
#home-search .small-12 .date__wrapper > *:not(.material-icons),
#home-search .small-12 .property__wrapper > *:not(.material-icons),
#home-search .small-12 .code__wrapper > *:not(.material-icons),
#home-search .small-12 .nights__wrapper > *:not(.material-icons),
#home-search .small-12 .people__wrapper > *:not(.material-icons),
#home-search .small-12 .flexibility__wrapper > *:not(.material-icons) {
  flex: 1;
  min-width: 0;
  overflow: visible;
}
#home-search .small-12 .where,
#home-search .small-12 .date,
#home-search .small-12 .property,
#home-search .small-12 .code,
#home-search .small-12 .nights,
#home-search .small-12 .people {
  display: flex;
  width: 210px;
  padding: 5px;
  flex: 0 0 210px;
  min-width: 210px;
  max-width: 210px;
  box-sizing: border-box;
}

#home-search .small-12 .nights-people-wrapper {
  display: flex;
  gap: 10px;
  width: 430px;
  padding: 5px;
  flex: 0 0 430px;
  min-width: 430px;
  max-width: 430px;
  box-sizing: border-box;
}

#home-search .small-12 .nights-people-wrapper .nights,
#home-search .small-12 .nights-people-wrapper .people {
  width: 50%;
  flex: 1 1 auto;
  min-width: 0;
  max-width: none;
  padding: 5px;
}
.page-template-properties #home-search .small-12 .where,
.page-template-properties #home-search .small-12 .date,
.page-template-properties #home-search .small-12 .property,
.page-template-properties #home-search .small-12 .nights,
.page-template-properties #home-search .small-12 .people,
.page-template-properties #home-search .small-12 .flexibility {
  width: 245px !important;
  height: 50px !important;
  min-width: 245px !important;
  max-width: 245px !important;
  min-height: 50px !important;
  max-height: 50px !important;
  flex: 0 0 245px !important;
  padding: 0 !important;
}
#home-search .small-12 .where > *,
#home-search .small-12 .date > *,
#home-search .small-12 .property > *,
#home-search .small-12 .nights > *,
#home-search .small-12 .people > * {
  width: 100%;
  flex: 1;
}
@media (max-width: 720px) {
  #home-search .small-12 form {
    flex-direction: column;
    gap: 12px;
  }

  #home-search .small-12 .date,
  #home-search .small-12 .people {
    width: 100%;
    flex: 1 1 auto;
    min-width: 0;
    max-width: none;
    margin-right: 0;
    margin-top: 0;
    padding: 0;
  }
}
#home-search .small-12 .where select,
#home-search .small-12 .date select,
#home-search .small-12 .property select,
#home-search .small-12 .code input,
#home-search .small-12 .nights select,
#home-search .small-12 .people select {
  width: 100%;
  padding: 0;
  padding-left: 0;
  border: none;
  background: transparent;
  font-size: 15px;
  color: #333;
  flex: 1;
  min-width: 0;
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
}
@media (max-width: 1617px) {
  #home-search .small-12 .where select,
  #home-search .small-12 .date select,
  #home-search .small-12 .property select,
  #home-search .small-12 .nights select,
  #home-search .small-12 .people select {
    font-size: 14px;
  }
}
#home-search .small-12 .where input,
#home-search .small-12 .date input,
#home-search .small-12 .property input,
#home-search .small-12 .code input,
#home-search .small-12 .nights input,
#home-search .small-12 .people input {
  padding: 0;
  padding-left: 0;
  margin: 0;
  border: none;
  box-shadow: none;
  background: transparent;
  width: 100%;
  display: inline-block;
  font-size: 15px;
  color: #333;
  flex: 1;
  min-width: 0;
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
}
@media (max-width: 1617px) {
  #home-search .small-12 .where input,
  #home-search .small-12 .date input,
  #home-search .small-12 .property input,
  #home-search .small-12 .nights input,
  #home-search .small-12 .people input {
    font-size: 14px;
  }
}
@media (max-width: 700px) {
  #home-search .small-12 .where {
    margin-top: 0;
  }
}


#home-search .date-error-message {
  display: none;
  color: #dc3545;
  font-size: 12px;
  margin-top: 5px;
  padding: 5px 0;
  font-weight: 500;
  line-height: 1.4;
}

#home-search .date__wrapper {
  position: relative;
}

#home-search .search__wrapepr.disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
}

#home-search .search input[type="submit"]:disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

#home-search .search {
  display: flex;
  width: 210px;
  padding: 5px;
  flex: 0 0 210px;
  min-width: 210px;
  max-width: 210px;
  box-sizing: border-box;
}
@media (max-width: 720px) {
  #home-search .search {
    width: 100%;
    flex: 1 1 auto;
    min-width: 0;
    max-width: none;
    margin-top: 0;
    margin-right: 0;
    padding: 0;
  }

  #home-search .search .search__wrapepr {
    background: #009fe3 !important;
    border-radius: 4px !important;
    height: 54px !important;
    min-height: 54px !important;
    width: 100% !important;
  }

  #home-search .small-12 .date__wrapper,
  #home-search .small-12 .people__wrapper {
    border-radius: 4px;
    border: 1px solid #e0e0e0;
    background: #fff;
  }
}
#home-search .search input[type="submit"] {
  background: transparent;
  outline: none;
  border: none;
  color: #fff;
  font-weight: 500;
  cursor: pointer;
  height: 100%;
  display: inline-block;
  width: auto;
  flex: 1;
  font-size: 15px;
}
#home-search .search .search__wrapepr {
  height: 100%;
  min-height: 54px;
  background: #009fe3;
  cursor: pointer;
  position: relative;
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 15px 20px;
  border: none;
  box-sizing: border-box;
  width: 100%;
  flex: 1;
}
#home-search .search .search__wrapepr .material-icons {
  color: #fff;
  font-size: 24px;
  pointer-events: none;
  flex-shrink: 0;
}
@media (max-width: 720px) {
  #home-search .search .search__wrapepr {
    height: 4rem;
  }
}

#icons {
  background: #f5f5f5;
  padding-top: 2em;
  padding-bottom: 3em;
}
#icons .icon-svg {
  width: 3rem;
  height: 3rem;
  color: #e5347e;
  margin-bottom: 1rem;
  display: inline-block;
}
#icons .icon-desktop {
  padding: 1.5rem 1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
#icons .icon-desktop .material-icons {
  font-size: 24px;
  color: #e5347e;
  display: inline-block;
  line-height: 1;
  margin: 0;
  margin-right: 10px;
  vertical-align: middle;
}
#icons .icon-desktop i {
  font-size: 24px;
  color: #e5347e;
  display: inline-block;
  margin: 0;
  margin-right: 10px;
  vertical-align: middle;
}
#icons .icon-desktop .icon-number-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.5rem;
  width: 100%;
}
#icons .icon-desktop h3 {
  font-size: 18px;
  font-weight: 800;
  color: #2c3e50;
  margin: 0;
  display: inline-block;
  padding: 0;
  line-height: 1.2;
  vertical-align: middle;
}
#icons .icon-desktop p {
  margin: 0;
  font-size: 1rem;
  font-weight: 400;
  color: #2c3e50;
  line-height: 1.4;
  text-align: center;
}
#icons .material-icons {
  font-size: 48px;
  color: #e5347e;
  margin-bottom: 1rem;
  display: inline-block;
  line-height: 1;
}
#icons i {
  font-size: 48px;
  color: #e5347e;
  margin-bottom: 1rem;
  display: inline-block;
}
#icons h3 {
  font-size: 18px;
  font-weight: 800;
  color: #2c3e50;
  margin: 0.5rem 0;
  display: block;
  padding: 0;
  line-height: 1.2;
}
#icons p {
  margin: 0.5rem 0 0 0;
  font-size: 1rem;
  font-weight: 400;
  color: #2c3e50;
  line-height: 1.4;
}
@media (max-width: 1049px) {
  #icons .text-center {
    padding: 10px 0;
  }
}
@media (max-width: 1049px) {
  #icons .icon-desktop {
    display: none;
  }
}
#icons .icons-mobile {
  width: 100%;
}

#icons .icons-mobile .icon-slider .icon {
  padding: 1.5rem 1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

#icons .icons-mobile .icon-slider .icon .material-icons {
  font-size: 24px;
  color: #e5347e;
  display: inline-block;
  line-height: 1;
  margin: 0;
  margin-bottom: 0.5rem;
}

#icons .icons-mobile .icon-slider .icon h3 {
  font-size: 18px;
  font-weight: 800;
  color: #2c3e50;
  margin: 0;
  display: inline-block;
  padding: 0;
  line-height: 1.2;
}

#icons .icons-mobile .icon-slider .icon p {
  margin: 0;
  font-size: 1rem;
  font-weight: 400;
  color: #2c3e50;
  line-height: 1.4;
  text-align: center;
}

#icons .icons-mobile .icon-slider .slick-slide {
  padding: 0 10px;
  box-sizing: border-box;
}

#icons .icons-mobile .icon-slider .slick-slide > div {
  height: 100%;
}

@media (max-width: 768px) {
  #icons .icons-mobile .icon-slider .icon {
    padding: 1.5rem 0.5rem;
  }

  #icons .icons-mobile .icon-slider .slick-slide {
    padding: 0 5px;
  }
}

@media (min-width: 1050px) {
  #icons .icons-mobile {
    display: none;
  }
}

#inspiration {
  margin-top: 5em;
  font-family: "Barlow", sans-serif;
}
#inspiration * {
  font-family: "Barlow", sans-serif !important;
}
#inspiration .grid-x {
  width: 90% !important;
  max-width: 1500px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
#inspiration .title {
  margin-bottom: 2em;
  padding-left: 10px;
}
#inspiration .title i,
#inspiration .title h2 {
  display: inline-block;
}
#inspiration .title h2 {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
}
#inspiration .title i {
  padding-right: 5px;
}
#inspiration .holidays {
  position: relative;
  padding: 10px;
}
#inspiration .holidays .hol-title {
  position: absolute;
  left: 0;
  top: 50%;
  right: 0;
  z-index: 1;
  text-align: center;
  transform: translateY(-25%);
  pointer-events: none;
  padding: 0 10px;
  font-family: "Barlow", sans-serif !important;
}
#inspiration .holidays .hol-title h2 {
  color: #fff;
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
}
#inspiration .holidays .hol-title .view {
  color: #efe057;
}
#inspiration .holidays .img-zoom {
  position: relative;
  margin: auto;
  overflow: hidden;
  width: 100%;
  cursor: pointer;
  height: 350px;
}
#inspiration .holidays .img-zoom img {
  max-width: 100%;
  display: block;
  width: 100%;
  transform: scale(1);
  transition: 0.5s ease;
  height: 350px !important;
  min-height: 350px !important;
  -o-object-fit: cover;
  object-fit: cover;
}
#inspiration .holidays .img-zoom:hover img {
  transform: scale(1.1);
}

#properties {
  margin-top: 5em;
  padding: 5em 0;
  background: #f5f5f5;
  font-family: "Barlow", sans-serif;
}
#properties * {
  font-family: "Barlow", sans-serif !important;
}
#properties .grid-x {
  width: 90% !important;
  max-width: 1500px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
@media (max-width: 749px) {
  #properties {
    margin: 0;
  }
}
#properties .title {
  margin-bottom: 1em;
  padding-left: 10px;
  font-size: 24px;
  font-family: "Barlow", sans-serif;
  font-weight: 600;
}
#properties .title h2 {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
}
#properties .title p {
  color: #009fe3;
}
#properties .slick-dots {
  text-align: left;
}
#properties .slick-dots li button:before {
  font-size: 12px;
}
#properties .slick-dots li.slick-active button:before {
  background: #e5347e;
  opacity: 0.75;
  border-radius: 10px;
  color: #e5347e;
}
#properties .slick-dots li button:before {
  line-height: 14px;
  height: 12px;
  width: 35px;
}
#properties .property {
  padding: 10px;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
#properties .property:hover {
  transform: translateY(-5px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
#properties .property .slick-slider {
  pointer-events: none;
}
#properties .property .slick-slider .slick-prev,
#properties .property .slick-slider .slick-next,
#properties .property .slick-slider .slick-dots {
  pointer-events: auto;
  z-index: 10;
}
#properties .property .slick-prev {
  left: 10px;
  z-index: 10;
}
#properties .property .slick-next {
  right: 10px;
  z-index: 10;
}
#properties .property .slick-dots {
  bottom: 10px;
  z-index: 10;
}
#properties .property .slick-slide img {
  height: 30vh;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
}
#properties .property .details {
  background: #fff;
  padding: 20px;
}
#properties .property .details .stars {
  display: inline-block;
}
#properties .property .details .stars i {
  font-size: 16px;
  color: #efe057;
  font-weight: bolder;
}
#properties .property .details h3 {
  padding-top: 10px;
  min-height: 60px;
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
}
#properties .property .details .sleeps {
  float: right;
  display: inline-block;
}
#properties .property .details .sleeps i,
#properties .property .details .sleeps p {
  font-size: 16px;
  display: inline-block;
}
#properties .property .details .location {
  padding-top: 5px;
}
#properties .property .details .location i,
#properties .property .details .location p {
  display: inline-block;
  font-size: 16px;
  padding-right: 5px;
}
#properties .property .details .location i {
  color: #e5347e;
}
#properties .property .details .price {
  color: #009fe3;
  font-size: 20px;
  display: block;
  font-weight: 600;
}
#properties .property .details a {
  background-color: #009fe3;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  display: block;
  width: 100%;
  text-align: center;
}
#properties .property .details a:hover {
  background-color: #00b1fd;
}

#things {
  margin-top: 5em;
  font-family: "Barlow", sans-serif;
}
#things * {
  font-family: "Barlow", sans-serif !important;
}
#things .grid-x {
  width: 90% !important;
  max-width: 1500px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
#things .title {
  margin-bottom: 1em;
  padding-left: 10px;
}
#things .title i,
#things .title h2 {
  display: inline-block;
}
#things .title h2 {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
}
#things .title i {
  padding-right: 5px;
}
#things .main-img {
  padding: 10px;
}
#things .medium-3 {
  padding: 10px;
}
#things .img-zoom {
  position: relative;
  margin: auto;
  overflow: hidden;
  width: 100%;
  cursor: pointer;
}
#things .img-zoom .title-overlay {
  position: absolute;
  bottom: 0;
  left: 15px;
  z-index: 5;
}
#things .img-zoom .title-overlay h2 {
  color: #fff;
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
}
#things .img-zoom .title-overlay p {
  color: #efe057;
}
#things .main-img .img-zoom {
  height: 425px;
}
#things .main-img .img-zoom img {
  max-width: 100%;
  display: block;
  width: 100%;
  transform: scale(1);
  transition: 0.5s ease;
  height: 425px !important;
  min-height: 425px !important;
  -o-object-fit: cover;
  object-fit: cover;
}
#things .cell.small-6.medium-3 .img-zoom {
  height: 425px;
}
#things .cell.small-6.medium-3 .img-zoom img {
  max-width: 100%;
  display: block;
  width: 100%;
  transform: scale(1);
  transition: 0.5s ease;
  height: 425px !important;
  min-height: 425px !important;
  -o-object-fit: cover;
  object-fit: cover;
}
@media (max-width: 749px) {
  #things .main-img .img-zoom,
  #things .main-img .img-zoom img,
  #things .cell.small-6.medium-3 .img-zoom,
  #things .cell.small-6.medium-3 .img-zoom img {
    height: 300px !important;
    min-height: 300px !important;
  }
  #things {
    margin-bottom: 3em !important;
  }
}
#things .img-zoom:hover img {
  transform: scale(1.1);
}

#blog,
#blog-4 {
  margin-top: 5em;
  padding: 5em 0;
  background: #f5f5f5;
  font-family: "Barlow", sans-serif;
}
#blog *,
#blog-4 * {
  font-family: "Barlow", sans-serif !important;
}
#blog .grid-x {
  width: 90% !important;
  max-width: 1500px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
#blog .title,
#blog-4 .title {
  margin-bottom: 1em;
  padding-left: 10px;
}
#blog .title h2,
#blog-4 .title h2 {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
}

/* Override for travel guide page */
body.page-template-travel-guide #blog-4 .title h2,
.page-template-travel-guide #blog-4 .title h2,
.travel-guide-banner-wrapper ~ .content #blog-4 .title h2 {
  font-weight: 600 !important;
}
#blog .title p,
#blog-4 .title p {
  color: #009fe3;
}

/* Override for travel guide page */
body.page-template-travel-guide #blog-4 .title p,
.page-template-travel-guide #blog-4 .title p,
.travel-guide-banner-wrapper ~ .content #blog-4 .title p {
  color: #000 !important;
}

.page-template-travel-guide #blog-4 .title p {
  color: #000 !important;
}
#blog .blog-slider {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 auto;
}
#blog .blog-section,
#blog .medium-6,
#blog-4 .blog-section,
#blog-4 .medium-6,
#blog-4 .large-3 {
  padding: 10px;
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  margin: 0 1rem;
}
#blog .blog-section img,
#blog .medium-6 img,
#blog-4 .blog-section img,
#blog-4 .medium-6 img,
#blog-4 .large-3 img {
  width: 100%;
  height: 300px;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
}
#blog .blog-section .blog-text,
#blog .medium-6 .blog-text,
#blog-4 .blog-section .blog-text,
#blog-4 .medium-6 .blog-text,
#blog-4 .large-3 .blog-text {
  background: #fff;
  padding: 20px;
}
#blog .blog-section .blog-text h3,
#blog .medium-6 .blog-text h3,
#blog-4 .blog-section .blog-text h3,
#blog-4 .medium-6 .blog-text h3 {
  color: #009fe3;
}
#blog .blog-section .blog-text h2,
#blog .medium-6 .blog-text h2,
#blog-4 .blog-section .blog-text h2,
#blog-4 .medium-6 .blog-text h2,
#blog-4 .large-3 .blog-text h2 {
  margin: 0;
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
}
#blog .blog-section .blog-text .dates,
#blog .medium-6 .blog-text .dates,
#blog-4 .blog-section .blog-text .dates,
#blog-4 .medium-6 .blog-text .dates {
  margin-top: 1em;
}
#blog .blog-section .blog-text .dates i,
#blog .blog-section .blog-text .dates p,
#blog .medium-6 .blog-text .dates i,
#blog .medium-6 .blog-text .dates p,
#blog-4 .blog-section .blog-text .dates i,
#blog-4 .blog-section .blog-text .dates p,
#blog-4 .medium-6 .blog-text .dates i,
#blog-4 .medium-6 .blog-text .dates p {
  display: inline-block;
}
#blog .blog-section .blog-text .dates p,
#blog .medium-6 .blog-text .dates p,
#blog-4 .blog-section .blog-text .dates p,
#blog-4 .medium-6 .blog-text .dates p {
  padding: 0 5px;
}
#blog .blog-section .blog-text .dates i,
#blog .medium-6 .blog-text .dates i,
#blog-4 .blog-section .blog-text .dates i,
#blog-4 .medium-6 .blog-text .dates i {
  font-size: 16px;
}
#blog .blog-section .blog-text a,
#blog .medium-6 .blog-text a,
#blog-4 .blog-section .blog-text a,
#blog-4 .medium-6 .blog-text a {
  background-color: #009fe3;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  display: block;
  width: 100%;
  text-align: center;
}
#blog .blog-section .blog-text a:hover,
#blog .medium-6 .blog-text a:hover,
#blog-4 .blog-section .blog-text a:hover,
#blog-4 .medium-6 .blog-text a:hover {
  background-color: #00b1fd;
}
@media (max-width: 1000px) {
  #blog .medium-3,
  #blog-4 .medium-3 {
    width: 50%;
  }
}
@media (max-width: 550px) {
  #blog .medium-3,
  #blog-4 .medium-3 {
    width: 100%;
  }
}
#blog .blog-slider .medium-4,
#blog-4 .blog-slider .medium-4 {
  padding: 10px;
}
#blog .blog-slider .medium-4 .blog-text,
#blog-4 .blog-slider .medium-4 .blog-text {
  background: #fff;
  padding: 20px;
}
#blog .blog-slider .medium-4 .blog-text p,
#blog-4 .blog-slider .medium-4 .blog-text p {
  margin: 0;
}
#blog .blog-slider .medium-4 .blog-text a,
#blog-4 .blog-slider .medium-4 .blog-text a {
  background-color: #009fe3;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  display: block;
  width: 100%;
  text-align: center;
  margin-top: 1em;
}
#blog .blog-slider .medium-4 .blog-text a:hover,
#blog-4 .blog-slider .medium-4 .blog-text a:hover {
  background-color: #00b1fd;
}
#blog .slick-dots,
#blog-4 .slick-dots {
  text-align: left;
}
#blog .slick-dots li button:before,
#blog-4 .slick-dots li button:before {
  font-size: 12px;
}
#blog .slick-dots li.slick-active button:before,
#blog-4 .slick-dots li.slick-active button:before {
  background: #e5347e;
  opacity: 0.75;
  border-radius: 10px;
  color: #e5347e;
}
#blog .slick-dots li button:before,
#blog-4 .slick-dots li button:before {
  line-height: 14px;
  height: 12px;
  width: 35px;
}

#blog-4 {
  margin-top: 0;
}

.blog {
  background: #f5f5f5;
}
.blog__items {
  padding: 10px;
}
.blog__image {
  width: 100%;
  height: 30vh;
  -o-object-fit: cover;
  object-fit: cover;
}
.blog__text {
  background: #fff;
  padding: 20px;
}
.blog__text a {
  background-color: #009fe3;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  display: block;
  width: 100%;
  text-align: center;
}
.blog__text a:hover {
  background-color: #00b1fd;
}
.blog__text--heading {
  color: #009fe3;
}

#testimonials {
  margin-top: 5em;
  margin-bottom: 5em;
  font-family: "Barlow", sans-serif;
  padding: 0 1rem;
}
#testimonials * {
  font-family: "Barlow", sans-serif !important;
}
#testimonials .grid-x {
  width: 90% !important;
  max-width: 1400px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
#testimonials .title {
  margin-bottom: 2em;
  padding-left: 10px;
  text-align: left;
}
#testimonials .title i,
#testimonials .title h2 {
  display: inline-block;
  vertical-align: middle;
}
#testimonials .title h2 {
  font-family: "Barlow", sans-serif !important;
  font-size: 32px !important;
  font-weight: 600;
  color: #333;
  margin: 0;
}
#testimonials .title i {
  padding-right: 10px;
  font-size: 36px;
  color: #009fe3;
  vertical-align: middle;
}
#testimonials .slick-slide img,
#testimonials .reviews .bg img,
#testimonials .reviews .bg picture img {
  display: block;
  height: 75px;
  width: 75px;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 50%;
  float: left;
  margin-right: 15px;
  flex-shrink: 0;
}
#testimonials .slick-dots {
  text-align: left;
}
#testimonials .slick-dots li button:before {
  font-size: 12px;
}
#testimonials .slick-dots li.slick-active button:before {
  background: #e5347e;
  opacity: 0.75;
  border-radius: 10px;
  color: #e5347e;
}
#testimonials .slick-dots li button:before {
  line-height: 14px;
  height: 12px;
  width: 35px;
}
#testimonials .reviews {
  padding: 10px;
}
#testimonials .reviews .bg {
  background: #f5f5f5 !important;
  padding: 2em;
  height: 100%;
  display: flex;
  flex-direction: column;
  border-radius: 4px;
}
#testimonials .reviews .bg > picture,
#testimonials .reviews .bg > img {
  float: left;
  margin-right: 15px;
  margin-bottom: 15px;
  flex-shrink: 0;
}
#testimonials .reviews .bg .property {
  overflow: hidden;
  margin-bottom: 1em;
}
#testimonials .reviews .bg .review {
  clear: both;
  margin-top: 1.5em;
  flex: 1;
  display: flex;
  flex-direction: column;
}
@media (max-width: 1050px) {
  #testimonials .reviews .bg {
    background: #f5f5f5 !important;
    padding: 1.5em;
  }
  #testimonials .reviews .bg > picture,
  #testimonials .reviews .bg > img {
    float: none;
    display: block;
    margin: 0 auto 15px;
  }
  #testimonials .reviews .bg .property {
    text-align: center;
  }
  #testimonials .reviews .bg .property .location {
    justify-content: center;
  }
}
#testimonials .review-slider .slick-slide {
  display: flex;
}
#testimonials .review-slider .slick-slide > div {
  width: 100%;
  display: flex;
}
#testimonials .review-slider .slick-list {
  margin: 0 -10px;
}
#testimonials .review-slider .slick-slide {
  padding: 0 10px;
  height: auto;
}
#testimonials .review-slider .slick-arrow {
  display: none !important;
}
@media (max-width: 768px) {
  #testimonials {
    margin-bottom: 3em;
  }
  #testimonials .title h2 {
    font-size: 26px !important;
  }
  #testimonials .title i {
    font-size: 30px;
  }
}
#testimonials .reviews .property {
  display: inline-block;
  vertical-align: top;
  padding-left: 0;
  overflow: hidden;
}
#testimonials .reviews .property h2 {
  font-family: "Barlow", sans-serif !important;
  font-size: 20px !important;
  margin: 0 0 0.5em 0;
  color: #333;
  font-weight: 600;
}
#testimonials .reviews .property .location {
  display: flex;
  align-items: center;
  margin: 0;
  color: #666;
}
#testimonials .reviews .property .location i,
#testimonials .reviews .property .location p {
  display: inline-block;
  margin: 0;
}
#testimonials .reviews .property .location i {
  padding-right: 5px;
  font-size: 18px;
  color: #e5347e;
}
#testimonials .reviews .property .location p {
  font-size: 14px;
}
#testimonials .reviews .review {
  padding-top: 1em;
  margin: 0;
  clear: both;
  width: 100%;
  display: block;
  line-height: 1.6;
  color: #333;
}
#testimonials .reviews .review .review-text {
  margin: 0.5em 0;
  display: block;
  font-size: 15px;
  line-height: 1.6;
  color: #333;
}
#testimonials .reviews .review .review-text:first-child {
  margin-top: 0;
}
#testimonials .reviews .review .review-author {
  margin-top: 1em;
  font-weight: 500;
  color: #333;
  font-size: 14px;
}

/*
* — Content Block 1 —
*/
#content-block-1 {
  padding: 50px 0;
}

/*
* — Testimonial Block —
*/
#testimonial-block {
  background: #e5347e;
  padding: 75px;
  text-align: center;
}
#testimonial-block p {
  color: #fff;
}

/*
* — Property Page —
*/
.page-wrap-properties ~ .banner,
.off-canvas-content:has(.page-wrap-properties) .banner,
.page-wrap-properties + .banner,
.page-template-properties .banner {
  position: relative;
  height: 480px !important;
  max-height: 480px !important;
}
@media (max-width: 970px) {
  .page-wrap-properties ~ .banner,
  .off-canvas-content:has(.page-wrap-properties) .banner,
  .page-wrap-properties + .banner,
  .page-template-properties .banner {
    height: 480px !important;
    max-height: 480px !important;
  }
}
.page-wrap-properties ~ .banner picture,
.page-wrap-properties ~ .banner picture img,
.page-wrap-properties ~ .banner img,
.off-canvas-content:has(.page-wrap-properties) .banner picture,
.off-canvas-content:has(.page-wrap-properties) .banner picture img,
.off-canvas-content:has(.page-wrap-properties) .banner img,
.page-wrap-properties ~ .banner .banner-item img,
.page-wrap-properties ~ .banner .banner-item picture,
.page-wrap-properties ~ .banner .banner-item picture img,
.off-canvas-content:has(.page-wrap-properties) .banner .banner-item img,
.off-canvas-content:has(.page-wrap-properties) .banner .banner-item picture,
.off-canvas-content:has(.page-wrap-properties) .banner .banner-item picture img,
.page-template-properties .banner picture,
.page-template-properties .banner picture img,
.page-template-properties .banner img,
.page-template-properties .banner .banner-item img,
.page-template-properties .banner .banner-item picture,
.page-template-properties .banner .banner-item picture img {
  width: 100%;
  height: 480px !important;
  min-height: 480px !important;
  max-height: 480px !important;
  -o-object-fit: cover;
  object-fit: cover;
}
@media (max-width: 970px) {
  .page-wrap-properties ~ .banner picture,
  .page-wrap-properties ~ .banner picture img,
  .page-wrap-properties ~ .banner img,
  .off-canvas-content:has(.page-wrap-properties) .banner picture,
  .off-canvas-content:has(.page-wrap-properties) .banner picture img,
  .off-canvas-content:has(.page-wrap-properties) .banner img,
  .page-wrap-properties ~ .banner .banner-item img,
  .page-wrap-properties ~ .banner .banner-item picture,
  .page-wrap-properties ~ .banner .banner-item picture img,
  .off-canvas-content:has(.page-wrap-properties) .banner .banner-item img,
  .off-canvas-content:has(.page-wrap-properties) .banner .banner-item picture,
  .off-canvas-content:has(.page-wrap-properties)
    .banner
    .banner-item
    picture
    img,
  .page-template-properties .banner picture,
  .page-template-properties .banner picture img,
  .page-template-properties .banner img,
  .page-template-properties .banner .banner-item img,
  .page-template-properties .banner .banner-item picture,
  .page-template-properties .banner .banner-item picture img {
    height: 480px !important;
    min-height: 480px !important;
    max-height: 480px !important;
  }
}
.page-wrap-properties ~ .banner .banner-item,
.off-canvas-content:has(.page-wrap-properties) .banner .banner-item,
.page-template-properties .banner .banner-item {
  height: 480px !important;
  max-height: 480px !important;
}
.page-wrap-properties ~ .banner .slides,
.page-wrap-properties ~ .banner .slick-slider,
.page-wrap-properties ~ .banner .slick-list,
.page-wrap-properties ~ .banner .slick-track,
.page-wrap-properties ~ .banner .slick-slide,
.off-canvas-content:has(.page-wrap-properties) .banner .slides,
.off-canvas-content:has(.page-wrap-properties) .banner .slick-slider,
.off-canvas-content:has(.page-wrap-properties) .banner .slick-list,
.off-canvas-content:has(.page-wrap-properties) .banner .slick-track,
.off-canvas-content:has(.page-wrap-properties) .banner .slick-slide,
.page-template-properties .banner .slides,
.page-template-properties .banner .slick-slider,
.page-template-properties .banner .slick-list,
.page-template-properties .banner .slick-track,
.page-template-properties .banner .slick-slide {
  height: 480px !important;
  max-height: 480px !important;
}
.page-wrap-properties ~ .banner .slick-slide > div,
.off-canvas-content:has(.page-wrap-properties) .banner .slick-slide > div,
.page-template-properties .banner .slick-slide > div {
  height: 100% !important;
  max-height: 100% !important;
}
.page-wrap-properties ~ .banner .banner-item img.banner-image,
.page-wrap-properties ~ .banner-item img.banner-image,
.off-canvas-content:has(.page-wrap-properties)
  .banner
  .banner-item
  img.banner-image,
.page-template-properties .banner .banner-item img.banner-image,
.page-template-properties .banner-item img.banner-image {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}
body.page-template-properties .banner,
body.page-template-properties .banner .banner-item,
body.page-template-properties .banner .slides,
body.page-template-properties .banner .slick-slider,
body.page-template-properties .banner .slick-list,
body.page-template-properties .banner .slick-track,
body.page-template-properties .banner .slick-slide,
body.page-template-properties .banner img,
body.page-template-properties .banner picture,
body.page-template-properties .banner picture img,
body.page-template-properties .banner .banner-item picture,
body.page-template-properties .banner .banner-item picture img {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}
.page-template-properties .banner .banner-overlay,
.off-canvas-content:has(.page-wrap-properties) > .banner .banner-overlay,
.properties-banner-wrapper .banner .banner-overlay {
  position: absolute !important;
  top: 50% !important;
  left: 0 !important;
  right: 0 !important;
  bottom: auto !important;
  transform: translateY(-50%) !important;
  width: 100% !important;
  height: auto !important;
  z-index: 3;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  padding: 0 !important;
}
.page-template-properties .banner .banner-overlay .grid-x,
.off-canvas-content:has(.page-wrap-properties)
  > .banner
  .banner-overlay
  .grid-x,
.properties-banner-wrapper .banner .banner-overlay .grid-x {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.page-template-properties .banner .banner-overlay .overlay-content,
.off-canvas-content:has(.page-wrap-properties)
  > .banner
  .banner-overlay
  .overlay-content,
.properties-banner-wrapper .banner .banner-overlay .overlay-content {
  text-align: center !important;
  width: 100%;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.page-template-properties .banner .banner-overlay .overlay-content h1,
.off-canvas-content:has(.page-wrap-properties)
  > .banner
  .banner-overlay
  .overlay-content
  h1,
.properties-banner-wrapper .banner .banner-overlay .overlay-content h1 {
  text-align: center !important;
  margin: 0 auto !important;
  width: 100%;
  color: #fff !important;
  font-size: 40px !important;
  font-weight: 600 !important;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3) !important;
  line-height: 1.2 !important;
  padding: 0 !important;
}
@media (max-width: 750px) {
  .page-template-properties .banner .banner-overlay .overlay-content h1,
  .off-canvas-content:has(.page-wrap-properties)
    > .banner
    .banner-overlay
    .overlay-content
    h1,
  .properties-banner-wrapper .banner .banner-overlay .overlay-content h1 {
    font-size: 35px !important;
  }
}
@media (max-width: 749px) {
  .page-template-properties .banner .banner-overlay,
  .off-canvas-content:has(.page-wrap-properties) > .banner .banner-overlay,
  .properties-banner-wrapper .banner .banner-overlay {
    top: 50% !important;
    transform: translateY(-50%) !important;
  }
}
/* Direct targeting for properties page banner - most specific */
/* Target banner when it's in the same container as .page-wrap-properties */
.off-canvas-content:has(.page-wrap-properties) > .banner {
  height: 480px !important;
  max-height: 480px !important;
}
.off-canvas-content:has(.page-wrap-properties) > .banner .banner-item,
.off-canvas-content:has(.page-wrap-properties) > .banner .slides,
.off-canvas-content:has(.page-wrap-properties) > .banner .slick-slider,
.off-canvas-content:has(.page-wrap-properties) > .banner .slick-list,
.off-canvas-content:has(.page-wrap-properties) > .banner .slick-track,
.off-canvas-content:has(.page-wrap-properties) > .banner .slick-slide {
  height: 480px !important;
  max-height: 480px !important;
}
.off-canvas-content:has(.page-wrap-properties) > .banner img,
.off-canvas-content:has(.page-wrap-properties) > .banner picture,
.off-canvas-content:has(.page-wrap-properties) > .banner picture img,
.off-canvas-content:has(.page-wrap-properties) > .banner .banner-item img {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

.properties-banner-wrapper,
.services-banner-wrapper {
  position: relative;
  margin-top: 0 !important;
  padding-top: 0 !important;
}
.properties-banner-wrapper .properties-search-overlay {
  position: relative !important;
  bottom: auto !important;
  left: auto !important;
  transform: none !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 auto;
  padding: 20px 0;
  background: #f5f5f5;
}
.properties-search-overlay #home-search .small-12 {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  padding: 0 !important;
}
.properties-search-overlay #home-search .small-12 form {
  display: flex !important;
  flex-flow: row wrap !important;
  justify-content: center !important;
  align-items: stretch !important;
  gap: 10px !important;
  width: auto !important;
  max-width: 100% !important;
}
.properties-search-overlay #home-search .where,
.properties-search-overlay #home-search .date,
.properties-search-overlay #home-search .property,
.properties-search-overlay #home-search .code,
.properties-search-overlay #home-search .flexibility,
.properties-search-overlay #home-search .search,
.properties-search-overlay #home-search .small-12 .where,
.properties-search-overlay #home-search .small-12 .date,
.properties-search-overlay #home-search .small-12 .property,
.properties-search-overlay #home-search .small-12 .code,
.properties-search-overlay #home-search .small-12 .flexibility,
.properties-search-overlay #home-search .small-12 .search {
  width: 245px !important;
  height: 50px !important;
  min-width: 245px !important;
  max-width: 245px !important;
  min-height: 50px !important;
  max-height: 50px !important;
  flex: 0 0 245px !important;
  padding: 0 !important;
  box-sizing: border-box;
}

.properties-search-overlay #home-search .nights-people-wrapper {
  width: 500px !important;
  height: 50px !important;
  min-width: 500px !important;
  max-width: 500px !important;
  min-height: 50px !important;
  max-height: 50px !important;
  flex: 0 0 500px !important;
  padding: 0 !important;
  box-sizing: border-box;
  display: flex !important;
  gap: 10px !important;
}

.properties-search-overlay #home-search .nights-people-wrapper .nights,
.properties-search-overlay #home-search .nights-people-wrapper .people {
  width: 50% !important;
  height: 50px !important;
  min-width: 0 !important;
  max-width: none !important;
  min-height: 50px !important;
  max-height: 50px !important;
  flex: 1 1 auto !important;
  padding: 0 !important;
  box-sizing: border-box;
}
.properties-search-overlay #home-search .where__wrapper,
.properties-search-overlay #home-search .date__wrapper,
.properties-search-overlay #home-search .property__wrapper,
.properties-search-overlay #home-search .code__wrapper,
.properties-search-overlay #home-search .nights__wrapper,
.properties-search-overlay #home-search .people__wrapper,
.properties-search-overlay #home-search .flexibility__wrapper,
.properties-search-overlay #home-search .search__wrapepr,
.properties-search-overlay #home-search .small-12 .where__wrapper,
.properties-search-overlay #home-search .small-12 .date__wrapper,
.properties-search-overlay #home-search .small-12 .property__wrapper,
.properties-search-overlay #home-search .small-12 .code__wrapper,
.properties-search-overlay #home-search .small-12 .nights__wrapper,
.properties-search-overlay #home-search .small-12 .people__wrapper,
.properties-search-overlay #home-search .small-12 .flexibility__wrapper,
.properties-search-overlay #home-search .small-12 .search__wrapepr {
  width: 245px !important;
  height: 50px !important;
  min-width: 245px !important;
  max-width: 245px !important;
  min-height: 50px !important;
  max-height: 50px !important;
  padding: 0 !important;
  box-sizing: border-box;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 245px !important;
}

.properties-search-overlay #home-search .search__wrapepr,
.properties-search-overlay #home-search .small-12 .search__wrapepr {
  background: #009fe3 !important;
  border-radius: 3px !important;
  padding: 0 20px !important;
}
.properties-search-overlay #home-search select,
.properties-search-overlay #home-search input[type="text"] {
  width: 100% !important;
  height: 50px !important;
  min-height: 50px !important;
  max-height: 50px !important;
  line-height: 50px !important;
  box-sizing: border-box;
}
@media (max-width: 720px) {
  .properties-banner-wrapper .properties-search-overlay,
  .page-template-properties .properties-search-overlay {
    width: 100vw !important;
    max-width: 100vw !important;
    padding: 20px 15px;
    background: #fff !important;
    border-radius: 0 !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    box-shadow: none !important;
    position: relative !important;
    left: 0 !important;
    right: 0 !important;
  }

  .properties-search-overlay #home-search .small-12 {
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .properties-search-overlay #home-search .small-12 form {
    flex-direction: column !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .page-template-properties .properties-search-overlay #home-search .small-12 {
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    form {
    flex-direction: column !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .properties-search-overlay #home-search .where,
  .properties-search-overlay #home-search .code,
  .properties-search-overlay #home-search .date,
  .properties-search-overlay #home-search .property,
  .properties-search-overlay #home-search .flexibility,
  .properties-search-overlay #home-search .small-12 .where,
  .properties-search-overlay #home-search .small-12 .code,
  .properties-search-overlay #home-search .small-12 .date,
  .properties-search-overlay #home-search .small-12 .property,
  .properties-search-overlay #home-search .small-12 .flexibility,
  .page-template-properties .properties-search-overlay #home-search .where,
  .page-template-properties .properties-search-overlay #home-search .code,
  .page-template-properties .properties-search-overlay #home-search .date,
  .page-template-properties .properties-search-overlay #home-search .property,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .flexibility,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .where,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .code,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .date,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .property,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .flexibility {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 100% !important;
    flex: 1 1 100% !important;
    height: auto !important;
    min-height: 54px !important;
    max-height: none !important;
    padding: 0 !important;
    box-sizing: border-box !important;
  }

  .properties-search-overlay #home-search .nights-people-wrapper {
    width: 100% !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    max-width: none !important;
    display: flex !important;
    gap: 12px !important;
    padding: 0 !important;
  }

  .properties-search-overlay #home-search .nights,
  .properties-search-overlay #home-search .people,
  .properties-search-overlay #home-search .small-12 .nights,
  .properties-search-overlay #home-search .small-12 .people {
    width: 50% !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    min-height: 54px !important;
    max-height: none !important;
    padding: 0 !important;
  }

  .properties-search-overlay #home-search .where__wrapper,
  .properties-search-overlay #home-search .code__wrapper,
  .properties-search-overlay #home-search .date__wrapper,
  .properties-search-overlay #home-search .property__wrapper,
  .properties-search-overlay #home-search .flexibility__wrapper,
  .properties-search-overlay #home-search .nights__wrapper,
  .properties-search-overlay #home-search .people__wrapper,
  .properties-search-overlay #home-search .small-12 .where__wrapper,
  .properties-search-overlay #home-search .small-12 .code__wrapper,
  .properties-search-overlay #home-search .small-12 .date__wrapper,
  .properties-search-overlay #home-search .small-12 .property__wrapper,
  .properties-search-overlay #home-search .small-12 .flexibility__wrapper,
  .properties-search-overlay #home-search .small-12 .nights__wrapper,
  .properties-search-overlay #home-search .small-12 .people__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .where__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .code__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .date__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .property__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .flexibility__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .nights__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .people__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .where__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .code__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .date__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .property__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .flexibility__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .nights__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .people__wrapper {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 100% !important;
    height: auto !important;
    min-height: 54px !important;
    max-height: none !important;
    flex: 1 1 100% !important;
    padding: 15px 12px !important;
    border-radius: 4px !important;
    border: 1px solid #e0e0e0 !important;
    background: #fff !important;
    box-sizing: border-box !important;
  }

  .properties-search-overlay #home-search .search,
  .properties-search-overlay #home-search .small-12 .search {
    width: 100% !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    min-height: 54px !important;
    max-height: none !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
    order: 999 !important;
  }

  .properties-search-overlay #home-search .search__wrapepr,
  .properties-search-overlay #home-search .small-12 .search__wrapepr {
    width: 100% !important;
    height: 54px !important;
    min-height: 54px !important;
    max-height: 54px !important;
    background: #009fe3 !important;
    border-radius: 4px !important;
  }

  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .where,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .date,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .property,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .nights,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .people,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .flexibility,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .code {
    width: 100% !important;
    height: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    min-height: 54px !important;
    max-height: none !important;
    flex: 1 1 auto !important;
    padding: 0 !important;
  }

  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .where__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .date__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .property__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .nights__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .people__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .flexibility__wrapper,
  .page-template-properties
    .properties-search-overlay
    #home-search
    .small-12
    .code__wrapper {
    width: 100% !important;
    height: auto !important;
    min-height: 54px !important;
    max-height: none !important;
    padding: 15px 12px !important;
  }
}
.page-template-properties #home-search {
  background: #f5f5f5;
}
.page-template-properties #home-search .where,
.page-template-properties #home-search .date,
.page-template-properties #home-search .property,
.page-template-properties #home-search .nights,
.page-template-properties #home-search .people,
.page-template-properties #home-search .flexibility,
.page-template-properties #home-search .search,
.page-template-properties #home-search .small-12 .where,
.page-template-properties #home-search .small-12 .date,
.page-template-properties #home-search .small-12 .property,
.page-template-properties #home-search .small-12 .nights,
.page-template-properties #home-search .small-12 .people,
.page-template-properties #home-search .small-12 .flexibility,
.page-template-properties #home-search .small-12 .search {
  width: 245px !important;
  height: 50px !important;
  min-width: 245px !important;
  max-width: 245px !important;
  min-height: 50px !important;
  max-height: 50px !important;
  flex: 0 0 245px !important;
  padding: 0 !important;
  background: #fff;
  box-sizing: border-box;
}
.page-template-properties #home-search .where__wrapper,
.page-template-properties #home-search .date__wrapper,
.page-template-properties #home-search .property__wrapper,
.page-template-properties #home-search .nights__wrapper,
.page-template-properties #home-search .people__wrapper,
.page-template-properties #home-search .flexibility__wrapper,
.page-template-properties #home-search .small-12 .where__wrapper,
.page-template-properties #home-search .small-12 .date__wrapper,
.page-template-properties #home-search .small-12 .property__wrapper,
.page-template-properties #home-search .small-12 .nights__wrapper,
.page-template-properties #home-search .small-12 .people__wrapper,
.page-template-properties #home-search .small-12 .flexibility__wrapper {
  width: 245px !important;
  height: 50px !important;
  min-width: 245px !important;
  max-width: 245px !important;
  min-height: 50px !important;
  max-height: 50px !important;
  padding: 0 12px !important;
  box-sizing: border-box;
  display: flex !important;
  align-items: center !important;
  flex: 0 0 245px !important;
}
.page-template-properties #home-search .where__wrapper .material-icons,
.page-template-properties #home-search .date__wrapper .material-icons,
.page-template-properties #home-search .property__wrapper .material-icons,
.page-template-properties #home-search .nights__wrapper .material-icons,
.page-template-properties #home-search .people__wrapper .material-icons,
.page-template-properties #home-search .flexibility__wrapper .material-icons {
  position: absolute !important;
  left: 12px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  height: auto !important;
}
@media (max-width: 1100px) {
  .page-template-properties #home-search .where,
  .page-template-properties #home-search .date,
  .page-template-properties #home-search .property,
  .page-template-properties #home-search .nights,
  .page-template-properties #home-search .people,
  .page-template-properties #home-search .flexibility {
    width: 245px !important;
    height: 50px !important;
    min-width: 245px !important;
    max-width: 245px !important;
    min-height: 50px !important;
    max-height: 50px !important;
    margin: 5px;
  }
}
@media (max-width: 720px) {
  .page-template-properties #home-search .where,
  .page-template-properties #home-search .date,
  .page-template-properties #home-search .property,
  .page-template-properties #home-search .nights,
  .page-template-properties #home-search .people,
  .page-template-properties #home-search .flexibility {
    width: 245px !important;
    height: 50px !important;
    min-width: 245px !important;
    max-width: 245px !important;
    min-height: 50px !important;
    max-height: 50px !important;
    margin: 5px 0;
  }
}
.page-template-properties #home-search .where select,
.page-template-properties #home-search .where input,
.page-template-properties #home-search .date select,
.page-template-properties #home-search .date input,
.page-template-properties #home-search .property select,
.page-template-properties #home-search .property input,
.page-template-properties #home-search .nights select,
.page-template-properties #home-search .nights input,
.page-template-properties #home-search .people select,
.page-template-properties #home-search .people input,
.page-template-properties #home-search .flexibility select,
.page-template-properties #home-search .flexibility input {
  width: 100% !important;
  height: 50px !important;
  min-height: 50px !important;
  max-height: 50px !important;
  padding: 0 12px 0 3rem !important;
  background: #fff;
  z-index: 1 !important;
  box-sizing: border-box;
  border: none !important;
  line-height: 50px !important;
}
@media (max-width: 1260px) {
  .page-template-properties #home-search .where select,
  .page-template-properties #home-search .where input,
  .page-template-properties #home-search .date select,
  .page-template-properties #home-search .date input,
  .page-template-properties #home-search .nights select,
  .page-template-properties #home-search .nights input,
  .page-template-properties #home-search .people select,
  .page-template-properties #home-search .people input {
    font-size: 14px;
  }
}
@media (max-width: 720px) {
  .page-template-properties #home-search .where select,
  .page-template-properties #home-search .where input,
  .page-template-properties #home-search .date select,
  .page-template-properties #home-search .date input,
  .page-template-properties #home-search .nights select,
  .page-template-properties #home-search .nights input,
  .page-template-properties #home-search .people select,
  .page-template-properties #home-search .people input {
    width: 95%;
  }
}
@media (max-width: 1100px) {
  .page-template-properties #home-search .people {
    width: 45.5%;
  }
}
@media (max-width: 720px) {
  .page-template-properties #home-search .people {
    width: 100%;
  }
}

.page-template-properties #properties--listings .map-container .modal {
  position: absolute;
  box-sizing: border-box;
  top: 25%;
  left: 30%;
  background-color: white;
  border-radius: 8px;
  padding: 12px;
  max-width: 40vh;
  height: 45vh;
  overflow: auto;
}
@media (max-width: 1200px) {
  .page-template-properties #properties--listings .map-container .modal {
    top: 25%;
    left: 20%;
  }
}
@media (max-width: 950px) {
  .page-template-properties #properties--listings .map-container .modal {
    top: auto;
    left: auto;
    bottom: 0;
    width: 100%;
    max-width: 100%;
    right: auto;
  }
}
.page-template-properties
  #properties--listings
  .map-container
  .modal
  a:first-of-type {
  display: inline;
  float: right;
  font-size: 14px;
}
.page-template-properties #properties--listings .map-container .modal h2 {
  display: inline;
  line-height: 1;
}
.page-template-properties #properties--listings .map-container .modal div {
  position: relative;
  margin: 1em 0;
}
.page-template-properties #properties--listings .map-container .modal div h4 {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  text-align: center;
  transform: translateY(-50%);
  color: #fff;
  font-size: 20px;
}
@media (max-width: 1049px) {
  .page-template-properties #properties--listings .map-container .modal div h4 {
    font-size: 25px;
  }
}
.page-template-properties #properties--listings .map-container .modal div img {
  width: 100%;
  height: 35vh;
  -o-object-fit: cover;
  object-fit: cover;
}
.page-template-properties #properties--listings .map-container .modal div a {
  position: absolute;
  top: 75%;
  left: 0;
  right: 0;
  text-align: center;
  transform: translateY(-50%);
  background-color: #e5347e;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  max-width: 80%;
  margin: 0 auto;
}
.page-template-properties
  #properties--listings
  .map-container
  .modal
  div
  a:hover {
  background-color: #e84b8c;
}

.page-template-properties #properties--listings .map-container .infoBox {
  background: black;
  overflow: hidden !important;
  position: relative !important;
  width: 100% !important;
  max-width: 250px !important;
}
.page-template-properties #properties--listings .map-container .infoBox > img {
  position: absolute !important;
  right: 0;
}
.page-template-properties
  #properties--listings
  .map-container
  .infoBox
  .content {
  padding: 0;
  border: 1px solid #fff;
  position: relative;
}
.page-template-properties
  #properties--listings
  .map-container
  .infoBox
  .content
  img {
  width: 100%;
  opacity: 0.85;
}
.page-template-properties
  #properties--listings
  .map-container
  .infoBox
  .content
  h4 {
  top: 40%;
  position: absolute;
  left: 0;
  right: 0;
  text-align: center;
  padding: 10px;
  transform: translateY(-50%);
  color: #fff;
  z-index: 2;
  font-size: 16px;
}
.page-template-properties
  #properties--listings
  .map-container
  .infoBox
  .content
  a {
  bottom: 0;
  position: absolute;
  left: 0;
  right: 0;
  text-align: center;
  max-width: 50%;
  margin: 0 auto;
  transform: translateY(-50%);
  background-color: #e5347e;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  padding: 10px 5px;
  font-size: 14px;
}

#property .medium-8 {
  position: relative;
}
#property .medium-8 .property-name {
  background: #fff;
  position: absolute;
  bottom: 5%;
  left: 3%;
  padding: 20px;
}
@media (max-width: 749px) {
  #property .medium-8 .property-name {
    position: relative;
    left: 0;
    right: 0;
    margin: 20px;
    padding: 10px;
    top: -10%;
  }
}
#property .medium-8 .property-name .property-location i,
#property .medium-8 .property-name .property-location p {
  display: inline-block;
  margin: 0;
}
#property .medium-8 .property-name .property-location i {
  vertical-align: bottom;
}
#property .material-icons {
  font-size: inherit;
  vertical-align: middle;
  display: inline-flex;
  align-items: center;
}
#property .features .icons .material-icons,
#property .additional-info .icons .material-icons {
  font-size: 16px;
  margin-right: 5px;
}
#property .title .material-icons {
  font-size: 24px;
  vertical-align: middle;
  margin-right: 8px;
}
#property .stars .material-icons {
  color: #efe057;
  font-size: 18px;
}
#property .bedroom-details .material-icons {
  font-size: 18px;
  margin-right: 5px;
}
#properties .property .details .material-icons {
  font-size: 16px;
  vertical-align: middle;
}
#property .medium-8 .property-name a {
  background-color: #e5347e;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  margin-top: 5px;
  padding: 10px 35px;
}
#property .medium-8 .property-name a:hover {
  background-color: #e84b8c;
}
#property .medium-8 img {
  width: 100%;
  padding: 10px 10px 20px 20px;
  height: 76vh;
  -o-object-fit: cover;
  object-fit: cover;
}
@media (max-width: 749px) {
  #property .medium-8 img {
    height: 55vh;
    padding: 10px;
  }
}

#property .main-title {
  margin: 2em 0;
}
#property .main-title i,
#property .main-title h2 {
  display: inline-block;
}

#property .medium-4 #book .gloversure-calendar {
  width: 100%;
  margin: 15px auto 0;
}
#property .medium-4 #book .gloversure-calendar .calendar-key ul li {
  padding-right: 5px;
}
#property .medium-4 #book .gloversure-calendar .calendar-key ul li h4 {
  font-size: 14px;
  margin-bottom: 0;
}
#property .medium-4 #book .gloversure-calendar .calendar-key ul li span {
  width: 10px !important;
  height: 10px !important;
  margin: 0;
}
#property
  .medium-4
  #book
  .gloversure-calendar
  .calendar-key
  li:nth-child(2)
  span {
  background-color: transparent !important;
  border: 1px solid #009fe3;
}
#property
  .medium-4
  #book
  .gloversure-calendar
  .calendar-key
  li:first-of-type
  span {
  background-color: #009fe3 !important;
}
#property .medium-4 #book .gloversure-calendar .calendar-wrapper .day .number {
  font-size: 14px;
}
#property
  .medium-4
  #book
  .gloversure-calendar
  .calendar-wrapper
  .calendar-item
  span.day.selected.selected-first.selected-last.selectable {
  background-color: transparent !important;
}
#property
  .medium-4
  #book
  .gloversure-calendar
  .calendar-wrapper
  .calendar-item
  span.day.selected.selected-first.selected-last.selectable
  span {
  background: #009fe3 !important;
}
#property
  .medium-4
  #book
  .gloversure-calendar
  .calendar-wrapper
  .calendar-item
  span.day.selected.selected-first.selectable,
#property
  .medium-4
  #book
  .gloversure-calendar
  .calendar-wrapper
  .calendar-item
  span.day.selected.selectable {
  background: transparent !important;
}
#property
  .medium-4
  #book
  .gloversure-calendar
  .calendar-wrapper
  .calendar-item
  span.day.selected.selected-first.selectable
  span,
#property
  .medium-4
  #book
  .gloversure-calendar
  .calendar-wrapper
  .calendar-item
  span.day.selected.selectable
  span {
  background: #009fe3 !important;
}
#property .medium-4 #book .gloversure-calendar .price .stay-price {
  font-size: 16px;
  margin: 0;
  display: block;
  letter-spacing: 1px;
}
#property .medium-4 #book .gloversure-calendar .price a {
  background-color: #009fe3;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
}
#property .medium-4 #book .gloversure-calendar .price a:hover {
  background-color: #00b1fd;
}
#property .medium-4 #book .gloversure-calendar select {
  font-size: 16px;
}

#property .medium-4 #book span.number {
  border-color: #009fe3 !important;
}

@media (max-width: 749px) {
  #property .medium-4 .image-top {
    display: none;
  }
}

#property .medium-4 .image-top img {
  padding: 10px 20px 10px 10px;
  height: 38vh;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media (max-width: 749px) {
  #property .medium-4 .image-top img {
    height: 55vh;
    padding: 10px;
  }
}

#property .medium-4 .image-bottom img {
  padding: 10px 20px 20px 10px;
  height: 38vh;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media (max-width: 749px) {
  #property .medium-4 .image-bottom img {
    height: 40vh;
    padding: 10px;
  }
}

#property .medium-4 .image-bottom {
  position: relative;
}
#property .medium-4 .image-bottom .button-overlay {
  position: absolute;
  bottom: 12%;
  right: 5%;
}
@media (max-width: 1250px) {
  #property .medium-4 .image-bottom .button-overlay {
    left: 10%;
    bottom: 15%;
    margin-right: 25px;
  }
}
@media (max-width: 749px) {
  #property .medium-4 .image-bottom .button-overlay {
    text-align: center;
    right: 10%;
    bottom: 0;
    top: 50%;
    transform: translateY(-15%);
    margin-right: 0;
  }
}
#property .medium-4 .image-bottom .button-overlay a {
  background-color: #e5347e;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
}
#property .medium-4 .image-bottom .button-overlay a:hover {
  background-color: #e84b8c;
}
@media (max-width: 750px) {
  #property .medium-4 .image-bottom .button-overlay a {
    font-size: 15px;
    padding: 15px 45px;
  }
}
#property .medium-4 .image-bottom .button-overlay a i {
  color: #fff;
  vertical-align: bottom;
  padding-right: 5px;
}

#property .features {
  background: #f5f5f5 !important;
  padding: 25px 0;
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  max-width: 100%;
}
#property .features .grid-x {
  background: #f5f5f5 !important;
  max-width: 100%;
}
#property .features .cell {
  background: transparent;
}
#property .features .icons {
  padding-right: 25px;
  display: inline-block;
}
@media (max-width: 798px) {
  #property .features .icons {
    padding-bottom: 10px;
  }
}
#property .features .icons i,
#property .features .icons p {
  display: inline-block;
}
#property .features .icons p {
  margin: 0;
  padding-left: 5px;
}
#property .features .icons i {
  font-size: 15px;
}

#property .overview {
  margin-top: 5em;
}
#property .overview .stars i {
  color: #efe057;
}

#property .title i,
#property .title h2,
#property .title p {
  display: inline-block;
}

#property .title i {
  padding-right: 5px;
}

#property p.description {
  padding-top: 1em;
}

#property .main-title i {
  padding-right: 5px;
}

#property .bedroom-details {
  padding-top: 10px;
  padding-right: 10px;
  display: inline-block;
}
#property .bedroom-details .bg {
  border: 1px solid whitesmoke;
  padding: 20px;
}
#property .bedroom-details .bg i {
  font-size: 15px;
}
#property .bedroom-details .bg p {
  margin: 0;
}

#property .additional-info {
  margin-top: 5em;
}
#property .additional-info .title {
  margin-bottom: 2em;
}
#property .additional-info ul.accordion {
  list-style: none;
  margin: 0;
  padding: 0;
}
#property .additional-info ul.accordion li {
  margin-bottom: 10px;
  border: 1px solid #e0e0e0;
  border-radius: 4px;
  overflow: hidden;
}
#property .additional-info ul.accordion a {
  font-size: 16px;
  color: black;
  font-weight: 600;
  text-decoration: none;
  display: block;
  padding: 15px 20px;
  position: relative;
  transition: background-color 0.3s ease;
}
#property .additional-info ul.accordion .accordion-title {
  background: #f5f5f5;
  cursor: pointer;
}
#property .additional-info ul.accordion .accordion-title:hover {
  background: #e8e8e8;
}
#property .additional-info ul.accordion .accordion-title::after {
  content: "+";
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 24px;
  font-weight: 300;
  transition: transform 0.3s ease;
}
#property
  .additional-info
  ul.accordion
  .accordion-item.is-active
  .accordion-title::after {
  content: "−";
  transform: translateY(-50%) rotate(0deg);
}
#property .additional-info ul.accordion .accordion-content {
  display: none !important;
  padding: 20px;
  background: #fff;
}
#property
  .additional-info
  ul.accordion
  .accordion-item.is-active
  .accordion-content {
  display: block !important;
}
#property .additional-info ul.accordion .accordion-title::before {
  display: none !important;
}
#property .additional-info ul.accordion .accordion-title {
  position: relative;
  padding-right: 50px;
}
#property
  .additional-info
  ul.accordion
  .accordion-title[aria-expanded]::before {
  display: none !important;
}
#property
  .additional-info
  ul.accordion
  .accordion-title[aria-expanded="true"]::after {
  content: "−" !important;
}
#property
  .additional-info
  ul.accordion
  .accordion-title[aria-expanded="false"]::after {
  content: "+" !important;
}
#property .additional-info ul.accordion .accordion-content .icons {
  display: inline-block;
  width: 33%;
}
@media (max-width: 1278px) {
  #property .additional-info ul.accordion .accordion-content .icons {
    width: 49%;
  }
}
@media (max-width: 500px) {
  #property .additional-info ul.accordion .accordion-content .icons {
    width: 100%;
  }
}
#property .additional-info ul.accordion .accordion-content .icons i {
  vertical-align: inherit;
  font-size: 16px;
  color: #e5347e;
}
#property .additional-info ul.accordion .accordion-content .amenities .icons i,
#property
  .additional-info
  ul.accordion
  .accordion-content
  .amenities
  .icons
  .material-icons {
  color: #e5347e;
}

#property .tour {
  margin-top: 5em;
}
#property .tour iframe {
  width: 100%;
  height: 55vh;
}

#property .location {
  margin: 5em 0;
}
#property .location .title {
  margin-bottom: 2em;
}
#property .location .map-responsive {
  overflow: hidden;
  padding-bottom: 40%;
  position: relative;
  height: 0;
}
#property .location .map-responsive iframe {
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  position: absolute;
}

#property .prices {
  margin-left: 0;
  margin-top: 5em;
  margin-bottom: 5em;
}
@media (max-width: 749px) {
  #property .prices {
    max-width: 100%;
    width: 100%;
  }
}
#property .prices .small-6:nth-child(1),
#property .prices .small-6:nth-child(2) {
  padding: 10px;
  background: #e5347e;
  color: #fff;
  font-family: "Barlow", sans-serif;
  font-weight: 600;
  font-size: 20px;
}
#property .prices .small-6 {
  padding: 5px;
  border: 1px solid #e2e2e2;
}

@media (max-width: 750px) {
  #property .medium-4 {
    margin-bottom: 5em;
  }
}

#property .medium-4 .title {
  margin-top: 5em;
}
@media (max-width: 750px) {
  #property .medium-4 .title {
    margin-top: 0;
    margin-bottom: 1em;
  }
}

#property .property-contact-form {
  margin: 5em 0;
  padding-left: 0;
  padding-right: 0;
}
#property .property-contact-form input#nf-field-4 {
  background-color: #e5347e;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  border: none;
  cursor: pointer;
}
#property .property-contact-form input#nf-field-4:hover {
  background-color: #e84b8c;
}
#property .property-enquiry-form {
  margin: 0;
  padding: 0;
}
#property .property-enquiry-form .grid-x {
  margin-left: 0;
  margin-right: 0;
}
#property .property-enquiry-form label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 500;
}
#property .property-enquiry-form input[type="text"],
#property .property-enquiry-form input[type="email"],
#property .property-enquiry-form input[type="tel"],
#property .property-enquiry-form textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid #e2e2e2;
  border-radius: 3px;
  margin-bottom: 1rem;
}
#property .property-enquiry-form .button {
  background-color: #e5347e;
  color: #fff;
  padding: 10px 45px;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  border: none;
  cursor: pointer;
  font-weight: 500;
  margin-top: 0.5rem;
}
#property .property-enquiry-form .button:hover {
  background-color: #e84b8c;
}
#property .property-enquiry-form .g-recaptcha {
  margin: 1rem 0;
}
#property .property-enquiry-form #recaptcha-error {
  font-size: 14px;
  font-weight: 500;
}

#property .youtube-video {
  overflow: hidden;
  padding-bottom: 56.25%;
  position: relative;
  height: 0;
}
#property .youtube-video iframe {
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  position: absolute;
}

/*
* — Properties —
*/
.page-template-properties #search {
  background: #f5f5f5;
  padding: 25px 0;
}
.page-template-properties #search .small-12 {
  padding: 0 3em;
}
.page-template-properties #search .small-12 select,
.page-template-properties #search .small-12 input[type="date"] {
  width: 20%;
  display: inline-block;
  border: none;
  box-shadow: none;
  height: 50px;
}
@media (max-width: 639px) {
  .page-template-properties #search .small-12 select,
  .page-template-properties #search .small-12 input[type="date"] {
    width: 49%;
  }
}
@media (max-width: 450px) {
  .page-template-properties #search .small-12 select,
  .page-template-properties #search .small-12 input[type="date"] {
    width: 100%;
  }
}
.page-template-properties #search .small-12 input[type="submit"] {
  background-color: #009fe3;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  outline: none;
  border: none;
}
.page-template-properties #search .small-12 input[type="submit"]:hover {
  background-color: #00b1fd;
}
@media (max-width: 639px) {
  .page-template-properties #search .small-12 input[type="submit"] {
    display: block;
    margin: 0 auto;
    width: 100%;
  }
}

#property-category .variable-items {
  border: 1px solid #d1d1d1;
  width: 100%;
  right: 0 !important;
  left: 0 !important;
}
@media (max-width: 1067px) {
  #property-category .variable-items {
    top: 95px !important;
  }
}
@media (max-width: 749px) {
  #property-category .variable-items {
    top: 110px !important;
  }
}
#property-category .variable-items .variables .additional-filters .baths,
#property-category .variable-items .variables .additional-filters .beds,
#property-category .variable-items .variables .additional-filters .type {
  display: inline-block;
  padding: 0 10px;
  width: 33.33%;
}
#property-category .variable-items .variables .additional-filters .baths select,
#property-category .variable-items .variables .additional-filters .beds select,
#property-category .variable-items .variables .additional-filters .type select {
  width: 100%;
}
@media (max-width: 1411px) {
  #property-category .variable-items .variables .additional-filters .baths,
  #property-category .variable-items .variables .additional-filters .beds,
  #property-category .variable-items .variables .additional-filters .type {
    padding: 10px;
    width: 49%;
  }
}
@media (max-width: 750px) {
  #property-category .variable-items .variables .additional-filters .baths,
  #property-category .variable-items .variables .additional-filters .beds,
  #property-category .variable-items .variables .additional-filters .type {
    width: 100%;
  }
}
@media (max-width: 750px) {
  #property-category .variable-items .variables .variables-checkboxes {
    text-align: left;
  }
}
#property-category .variable-items .variables .variables-checkboxes h4 {
  padding: 10px;
  margin: 0;
}
#property-category .variable-items .variables .variables-checkboxes div {
  display: inline-block;
  padding: 0 10px;
}
#property-category .variable-items .variables .variables-checkboxes div label {
  display: inline-block;
  padding: 0;
}
@media (max-width: 750px) {
  #property-category .variable-items .variables .landing-page-checkboxes {
    text-align: left;
  }
}
#property-category .variable-items .variables .landing-page-checkboxes h4 {
  padding: 10px;
  margin: 0;
}
#property-category .variable-items .variables .landing-page-checkboxes label {
  padding: 0;
  display: inline-block;
  padding: 0 10px;
}

#property-category .cell.small-12.medium-5.medium-offset-1 {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
}
@media (max-width: 750px) {
  #property-category .cell.small-12.medium-5.medium-offset-1 {
    width: 50%;
    margin: 0;
  }
}
@media (max-width: 640px) {
  #property-category .cell.small-12.medium-5.medium-offset-1 {
    width: 100%;
  }
}

#property-category .filter-options {
  margin-top: 3em;
  margin-bottom: 2em;
  position: relative;
  width: 100%;
}
@media (max-width: 749px) {
  #property-category .filter-options {
    margin: 0;
    padding: 25px 10px 30px 20px;
  }
}
#property-category .filter-options .properties-found {
  display: inline-block;
  width: 35%;
}
@media (max-width: 1067px) {
  #property-category .filter-options .properties-found {
    width: 100%;
    text-align: center;
    margin-bottom: 1em;
  }
}
#property-category .filter-options .filters {
  display: inline-block;
  float: right;
  width: 65%;
}
@media (max-width: 1067px) {
  #property-category .filter-options .filters {
    width: 100%;
    text-align: center;
    margin-bottom: 1em;
  }
}
#property-category .filter-options .filters i {
  font-size: 18px;
  border: 1px solid #f5f5f5;
  padding: 10px;
  margin-right: 10px;
  cursor: pointer;
  vertical-align: middle;
}
#property-category .filter-options .filters span {
  border: 1px solid #f5f5f5;
  padding: 10px;
  font-weight: 600;
}
#property-category .filter-options .filters span::after {
  content: "\f078";
  font-family: "Font Awesome 5 Pro";
  padding-left: 5px;
}
#property-category .filter-options .filters select {
  width: auto;
  margin: 0;
  vertical-align: middle;
}
#property-category .filter-options .variable-items {
  position: absolute;
  background: #fff;
  z-index: 999;
  top: 40px;
  padding: 10px;
  right: 66px;
  text-align: left;
  max-height: 300px;
  overflow: auto;
}
@media (max-width: 1045px) {
  #property-category .filter-options .variable-items {
    right: 0;
    left: 0;
    top: 195%;
  }
}
@media (max-width: 749px) {
  #property-category .filter-options .variable-items {
    right: 0;
    left: 0;
    top: 115%;
    text-align: center;
  }
}
#property-category .filter-options .variable-items input[type="submit"] {
  background-color: #e5347e;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  outline: none;
  border: none;
}
#property-category .filter-options .variable-items input[type="submit"]:hover {
  background-color: #e84b8c;
}

#property-category .properties {
  width: 32.5%;
  display: inline-block;
  padding-right: 15px;
  padding-bottom: 25px;
}
@media (max-width: 1350px) {
  #property-category .properties {
    width: 49.5%;
  }
}
@media (max-width: 866px) {
  #property-category .properties {
    width: 100%;
  }
}
@media (max-width: 749px) {
  #property-category .properties {
    padding: 10px 10px 10px 15px;
  }
}
@media (max-width: 640px) {
  #property-category .properties {
    width: 50%;
  }
}
@media (max-width: 400px) {
  #property-category .properties {
    padding: 10px 1em;
    width: 100%;
  }
}
#property-category .properties .slick-prev {
  left: 15px;
  z-index: 5;
}
#property-category .properties .slick-next {
  right: 15px;
  z-index: 5;
}
#property-category .properties .image-slider img {
  height: 25vh;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
#property-category .properties .details {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 10px;
  border: 1px solid #f5f5f5;
}
#property-category .properties .details .discount {
  display: inline-block;
  text-decoration: line-through;
  font-size: 15px;
  padding-right: 10px;
  padding-left: 0;
}
#property-category .properties .details .stars i {
  font-size: 15px;
  color: #efe057;
  margin-bottom: 1em;
}
#property-category .properties .details h3 {
  min-height: 50px;
}
#property-category .properties .details h3 a {
  background-color: unset;
  color: black;
  padding: 0rem !important;
  text-align: left;
  font-weight: 600;
}
#property-category .properties .details h3 a:hover {
  background: unset;
}
@media (max-width: 862px) {
  #property-category .properties .details h3 {
    min-height: 100px;
  }
}
@media (max-width: 749px) {
  #property-category .properties .details h3 {
    min-height: 50px;
  }
}
#property-category .properties .details .location i,
#property-category .properties .details .location p {
  display: inline-block;
  font-size: 15px;
}
#property-category .properties .details .location i {
  padding-right: 5px;
  font-size: 16px;
  color: #e5347e;
}
#property-category .properties .details a {
  background-color: #009fe3;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  display: block;
  width: 100%;
  text-align: center;
}
#property-category .properties .details a:hover {
  background-color: #00b1fd;
}
@media (max-width: 1004px) {
  #property-category .properties .details a {
    padding: 15px;
  }
}
#property-category .properties .details .price {
  color: #009fe3;
  font-size: 20px;
  display: inline-block;
  font-weight: 600;
}

@media (max-width: 749px) {
  #property-category .medium-5 .paginate {
    margin: 20px auto;
  }
}

#property-category .medium-6 {
  padding-left: 6em;
}
@media (max-width: 1045px) {
  #property-category .medium-6 {
    padding-left: 4em;
  }
}
@media (max-width: 749px) {
  #property-category .medium-6 {
    padding-left: 0em;
  }
}
#property-category .medium-6 #properties-map {
  min-height: 100vh;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
}
@media (max-width: 749px) {
  #property-category .medium-6 .paginate {
    margin: 1em 0;
    text-align: center;
  }
}

@media (max-width: 749px) {
  #property-category .gm-style-iw-t {
    bottom: auto !important;
  }
}

@media (max-width: 900px) {
  #property-category .gm-style-iw.gm-style-iw-c {
    max-width: 285px !important;
  }
}

@media (max-width: 900px) {
  #property-category .gm-style-iw.gm-style-iw-c {
    position: relative;
  }
}

#property-category .gm-style-iw.gm-style-iw-c .property {
  position: relative;
  margin: 10px 0;
  background: black;
}
#property-category .gm-style-iw.gm-style-iw-c .property h4 {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  text-align: center;
  transform: translateY(-50%);
  color: #fff;
  z-index: 5;
}
@media (max-width: 900px) {
  #property-category .gm-style-iw.gm-style-iw-c .property h4 {
    padding: 0 10px;
    line-height: 1;
    font-size: 22px;
  }
}
#property-category .gm-style-iw.gm-style-iw-c .property a {
  position: absolute;
  top: 60%;
  left: 0;
  right: 0;
  text-align: center;
  transform: translateY(0%);
  background-color: #e5347e;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  max-width: 50%;
  margin: 0 auto;
  padding: 10px;
}
#property-category .gm-style-iw.gm-style-iw-c .property a:hover {
  background-color: #e84b8c;
}
@media (max-width: 1000px) {
  #property-category .gm-style-iw.gm-style-iw-c .property a {
    max-width: 75%;
  }
}
#property-category .gm-style-iw.gm-style-iw-c .property img {
  height: 35vh;
  opacity: 0.8;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.book-container a {
  background-color: #009fe3;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
}
.book-container a:hover {
  background-color: #00b1fd;
}

.book-container a.choose-another-date {
  background-color: #e5347e;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  background: transparent;
  border: 1px solid #e5347e;
  margin-top: 1em;
  color: #e5347e;
}
.book-container a.choose-another-date:hover {
  background-color: #e84b8c;
}
.book-container a.choose-another-date:hover {
  color: #fff;
}

/*
* — Flex Sections —
*/
.page-template-simpleflex .content,
.single-post .content,
.page-template-list-children .content {
  padding-top: 0;
}

.page-template-simpleflex .gap,
.single-post .gap,
.page-template-list-children .gap {
  margin-top: 5em;
  margin-bottom: 5em;
}

.page-template-simpleflex #text-left,
.page-template-simpleflex #text-right,
.single-post #text-left,
.single-post #text-right,
.page-template-list-children #text-left,
.page-template-list-children #text-right {
  margin: 5em 0;
}
.page-template-simpleflex #text-left img,
.page-template-simpleflex #text-right img,
.single-post #text-left img,
.single-post #text-right img,
.page-template-list-children #text-left img,
.page-template-list-children #text-right img {
  height: 50vh;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.page-template-simpleflex #text-left .text,
.page-template-simpleflex #text-right .text,
.single-post #text-left .text,
.single-post #text-right .text,
.page-template-list-children #text-left .text,
.page-template-list-children #text-right .text {
  padding-right: 5em;
}
@media (max-width: 749px) {
  .page-template-simpleflex #text-left .text,
  .page-template-simpleflex #text-right .text,
  .single-post #text-left .text,
  .single-post #text-right .text,
  .page-template-list-children #text-left .text,
  .page-template-list-children #text-right .text {
    padding: 2em;
    order: 2;
  }
}

.page-template-simpleflex #full-width-image,
.single-post #full-width-image,
.page-template-list-children #full-width-image {
  margin: 5em 0;
}
.page-template-simpleflex #full-width-image .medium-8,
.single-post #full-width-image .medium-8,
.page-template-list-children #full-width-image .medium-8 {
  position: relative;
}
.page-template-simpleflex #full-width-image .medium-8 .property-name,
.single-post #full-width-image .medium-8 .property-name,
.page-template-list-children #full-width-image .medium-8 .property-name {
  position: absolute;
  bottom: 10%;
  left: 5%;
  background: #fff;
  padding: 20px;
  right: 5%;
}
.page-template-simpleflex #full-width-image .medium-8 img,
.single-post #full-width-image .medium-8 img,
.page-template-list-children #full-width-image .medium-8 img {
  width: 100%;
  padding: 10px 10px 20px 20px;
  height: 76vh;
  -o-object-fit: cover;
  object-fit: cover;
}
@media (max-width: 749px) {
  .page-template-simpleflex #full-width-image .medium-8 img,
  .single-post #full-width-image .medium-8 img,
  .page-template-list-children #full-width-image .medium-8 img {
    height: 55vh;
    padding: 10px;
  }
}
.page-template-simpleflex #full-width-image .medium-4 .image-top img,
.single-post #full-width-image .medium-4 .image-top img,
.page-template-list-children #full-width-image .medium-4 .image-top img {
  padding: 10px 20px 10px 10px;
  height: 38vh;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media (max-width: 749px) {
  .page-template-simpleflex #full-width-image .medium-4 .image-top img,
  .single-post #full-width-image .medium-4 .image-top img,
  .page-template-list-children #full-width-image .medium-4 .image-top img {
    height: 55vh;
    padding: 10px;
  }
}
.page-template-simpleflex #full-width-image .medium-4 .image-bottom img,
.single-post #full-width-image .medium-4 .image-bottom img,
.page-template-list-children #full-width-image .medium-4 .image-bottom img {
  padding: 10px 20px 20px 10px;
  height: 38vh;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media (max-width: 749px) {
  .page-template-simpleflex #full-width-image .medium-4 .image-bottom img,
  .single-post #full-width-image .medium-4 .image-bottom img,
  .page-template-list-children #full-width-image .medium-4 .image-bottom img {
    height: 55vh;
    padding: 10px;
  }
}
.page-template-simpleflex #full-width-image .medium-4 .image-bottom,
.single-post #full-width-image .medium-4 .image-bottom,
.page-template-list-children #full-width-image .medium-4 .image-bottom {
  position: relative;
}
.page-template-simpleflex
  #full-width-image
  .medium-4
  .image-bottom
  .button-overlay,
.single-post #full-width-image .medium-4 .image-bottom .button-overlay,
.page-template-list-children
  #full-width-image
  .medium-4
  .image-bottom
  .button-overlay {
  position: absolute;
  bottom: 12%;
  right: 5%;
}
@media (max-width: 1250px) {
  .page-template-simpleflex
    #full-width-image
    .medium-4
    .image-bottom
    .button-overlay,
  .single-post #full-width-image .medium-4 .image-bottom .button-overlay,
  .page-template-list-children
    #full-width-image
    .medium-4
    .image-bottom
    .button-overlay {
    left: 10%;
    bottom: 15%;
  }
}
@media (max-width: 749px) {
  .page-template-simpleflex
    #full-width-image
    .medium-4
    .image-bottom
    .button-overlay,
  .single-post #full-width-image .medium-4 .image-bottom .button-overlay,
  .page-template-list-children
    #full-width-image
    .medium-4
    .image-bottom
    .button-overlay {
    text-align: center;
    right: 10%;
    bottom: 0;
    top: 50%;
  }
}

.page-template-simpleflex .child-page,
.single-post .child-page,
.page-template-list-children .child-page {
  background: #fff;
}
.page-template-simpleflex .child-page .blog__items,
.single-post .child-page .blog__items,
.page-template-list-children .child-page .blog__items {
  padding: 5em 10px;
}
.page-template-simpleflex .child-page .blog__text,
.single-post .child-page .blog__text,
.page-template-list-children .child-page .blog__text {
  background: #f5f5f5;
}
.page-template-simpleflex .child-page .blog__text a,
.single-post .child-page .blog__text a,
.page-template-list-children .child-page .blog__text a {
  padding: 10px;
}

.page-template-simpleflex .accordion li,
.page-template-simpleflex .tabs li,
.single-post .accordion li,
.single-post .tabs li,
.page-template-list-children .accordion li,
.page-template-list-children .tabs li {
  float: none;
  display: inline-block;
}
@media (max-width: 1049px) {
  .page-template-simpleflex .accordion li,
  .page-template-simpleflex .tabs li,
  .single-post .accordion li,
  .single-post .tabs li,
  .page-template-list-children .accordion li,
  .page-template-list-children .tabs li {
    display: block;
  }
}
.page-template-simpleflex .accordion li a,
.page-template-simpleflex .tabs li a,
.single-post .accordion li a,
.single-post .tabs li a,
.page-template-list-children .accordion li a,
.page-template-list-children .tabs li a {
  font-size: 16px !important;
  padding: 25px 10px;
}
@media (max-width: 1255px) {
  .page-template-simpleflex .accordion li a,
  .page-template-simpleflex .tabs li a,
  .single-post .accordion li a,
  .single-post .tabs li a,
  .page-template-list-children .accordion li a,
  .page-template-list-children .tabs li a {
    padding: 25px 5px;
  }
}
@media (max-width: 1049px) {
  .page-template-simpleflex .accordion li a,
  .page-template-simpleflex .tabs li a,
  .single-post .accordion li a,
  .single-post .tabs li a,
  .page-template-list-children .accordion li a,
  .page-template-list-children .tabs li a {
    padding: 25px;
  }
}

.page-template-simpleflex .accordion li.is-active,
.page-template-simpleflex .tabs li.is-active,
.single-post .accordion li.is-active,
.single-post .tabs li.is-active,
.page-template-list-children .accordion li.is-active,
.page-template-list-children .tabs li.is-active {
  border-bottom: 2px solid #e5347e;
}
.page-template-simpleflex .accordion li.is-active a,
.page-template-simpleflex .tabs li.is-active a,
.single-post .accordion li.is-active a,
.single-post .tabs li.is-active a,
.page-template-list-children .accordion li.is-active a,
.page-template-list-children .tabs li.is-active a {
  background: #fff;
  outline: none;
}

.page-template-simpleflex .accordion-content .uk-margin,
.page-template-simpleflex .tabs-content .uk-margin,
.single-post .accordion-content .uk-margin,
.single-post .tabs-content .uk-margin,
.page-template-list-children .accordion-content .uk-margin,
.page-template-list-children .tabs-content .uk-margin {
  margin-bottom: 3em !important;
}
.page-template-simpleflex .accordion-content .uk-margin img,
.page-template-simpleflex .tabs-content .uk-margin img,
.single-post .accordion-content .uk-margin img,
.single-post .tabs-content .uk-margin img,
.page-template-list-children .accordion-content .uk-margin img,
.page-template-list-children .tabs-content .uk-margin img {
  width: 100%;
  height: 55vh;
  -o-object-fit: cover;
  object-fit: cover;
}

.page-template-simpleflex .accordion-content p a,
.page-template-simpleflex .tabs-content p a,
.single-post .accordion-content p a,
.single-post .tabs-content p a,
.page-template-list-children .accordion-content p a,
.page-template-list-children .tabs-content p a {
  padding: 0;
}

.page-template-simpleflex .accordion-content .book_box,
.page-template-simpleflex .tabs-content .book_box,
.single-post .accordion-content .book_box,
.single-post .tabs-content .book_box,
.page-template-list-children .accordion-content .book_box,
.page-template-list-children .tabs-content .book_box {
  margin: auto;
}

.page-template-simpleflex .accordion-content .book_title,
.page-template-simpleflex .tabs-content .book_title,
.single-post .accordion-content .book_title,
.single-post .tabs-content .book_title,
.page-template-list-children .accordion-content .book_title,
.page-template-list-children .tabs-content .book_title {
  width: 180px;
  height: 45px;
  background-color: #009fe3;
  font-size: 18px;
  color: #ffffff;
  text-align: left;
  font-family: "Lato", sans-serif;
  font-weight: bold;
  padding: 0 15px;
}

.page-template-simpleflex .accordion-content .book_table .book_lbl,
.page-template-simpleflex .tabs-content .book_table .book_lbl,
.single-post .accordion-content .book_table .book_lbl,
.single-post .tabs-content .book_table .book_lbl,
.page-template-list-children .accordion-content .book_table .book_lbl,
.page-template-list-children .tabs-content .book_table .book_lbl {
  font-weight: normal;
  padding: 8px 15px;
  font-size: 16px;
  color: #3d4f69;
}

.page-template-simpleflex .accordion-content tbody tr:nth-child(even),
.page-template-simpleflex .tabs-content tbody tr:nth-child(even),
.single-post .accordion-content tbody tr:nth-child(even),
.single-post .tabs-content tbody tr:nth-child(even),
.page-template-list-children .accordion-content tbody tr:nth-child(even),
.page-template-list-children .tabs-content tbody tr:nth-child(even) {
  background: #fff;
}

.page-template-simpleflex .accordion-content .book_table > tbody > tr > td,
.page-template-simpleflex .tabs-content .book_table > tbody > tr > td,
.single-post .accordion-content .book_table > tbody > tr > td,
.single-post .tabs-content .book_table > tbody > tr > td,
.page-template-list-children .accordion-content .book_table > tbody > tr > td,
.page-template-list-children .tabs-content .book_table > tbody > tr > td {
  padding: 5px 15px;
}

.page-template-simpleflex .accordion-content .book_tbl11,
.page-template-simpleflex .tabs-content .book_tbl11,
.single-post .accordion-content .book_tbl11,
.single-post .tabs-content .book_tbl11,
.page-template-list-children .accordion-content .book_tbl11,
.page-template-list-children .tabs-content .book_tbl11 {
  width: 54px;
  vertical-align: middle;
  padding: 0;
}

.page-template-simpleflex .accordion-content .book_tbl12,
.page-template-simpleflex .tabs-content .book_tbl12,
.single-post .accordion-content .book_tbl12,
.single-post .tabs-content .book_tbl12,
.page-template-list-children .accordion-content .book_tbl12,
.page-template-list-children .tabs-content .book_tbl12 {
  width: 36px;
  vertical-align: middle;
  text-align: center;
  padding: 0;
  padding-left: 10px;
}

.page-template-simpleflex .accordion-content .book_tbl13,
.page-template-simpleflex .tabs-content .book_tbl13,
.single-post .accordion-content .book_tbl13,
.single-post .tabs-content .book_tbl13,
.page-template-list-children .accordion-content .book_tbl13,
.page-template-list-children .tabs-content .book_tbl13 {
  width: 26px;
  vertical-align: middle;
  text-align: center;
  padding: 0;
}
.page-template-simpleflex .accordion-content .book_tbl13 img,
.page-template-simpleflex .tabs-content .book_tbl13 img,
.single-post .accordion-content .book_tbl13 img,
.single-post .tabs-content .book_tbl13 img,
.page-template-list-children .accordion-content .book_tbl13 img,
.page-template-list-children .tabs-content .book_tbl13 img {
  max-width: 100%;
  display: inline-block;
  vertical-align: super;
}

.page-template-simpleflex .accordion-content .book_tbl21,
.page-template-simpleflex .tabs-content .book_tbl21,
.single-post .accordion-content .book_tbl21,
.single-post .tabs-content .book_tbl21,
.page-template-list-children .accordion-content .book_tbl21,
.page-template-list-children .tabs-content .book_tbl21 {
  padding: 0;
}

.page-template-simpleflex .accordion-content .book_tbl14,
.page-template-simpleflex .tabs-content .book_tbl14,
.single-post .accordion-content .book_tbl14,
.single-post .tabs-content .book_tbl14,
.page-template-list-children .accordion-content .book_tbl14,
.page-template-list-children .tabs-content .book_tbl14 {
  padding: 0;
  width: 64px;
  vertical-align: middle;
  text-align: right;
}

.page-template-simpleflex .accordion-content input#book_ok,
.page-template-simpleflex .tabs-content input#book_ok,
.single-post .accordion-content input#book_ok,
.single-post .tabs-content input#book_ok,
.page-template-list-children .accordion-content input#book_ok,
.page-template-list-children .tabs-content input#book_ok {
  background-color: #009fe3;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  border: none;
  cursor: pointer;
  display: block;
  width: 100%;
  padding: 15px 0;
}
.page-template-simpleflex .accordion-content input#book_ok:hover,
.page-template-simpleflex .tabs-content input#book_ok:hover,
.single-post .accordion-content input#book_ok:hover,
.single-post .tabs-content input#book_ok:hover,
.page-template-list-children .accordion-content input#book_ok:hover,
.page-template-list-children .tabs-content input#book_ok:hover {
  background-color: #00b1fd;
}

.page-template-simpleflex .accordion-content thead,
.page-template-simpleflex .accordion-content tbody,
.page-template-simpleflex .accordion-content tfoot,
.page-template-simpleflex .tabs-content thead,
.page-template-simpleflex .tabs-content tbody,
.page-template-simpleflex .tabs-content tfoot,
.single-post .accordion-content thead,
.single-post .accordion-content tbody,
.single-post .accordion-content tfoot,
.single-post .tabs-content thead,
.single-post .tabs-content tbody,
.single-post .tabs-content tfoot,
.page-template-list-children .accordion-content thead,
.page-template-list-children .accordion-content tbody,
.page-template-list-children .accordion-content tfoot,
.page-template-list-children .tabs-content thead,
.page-template-list-children .tabs-content tbody,
.page-template-list-children .tabs-content tfoot {
  border: none;
}

.page-template-simpleflex .accordion-content .book_table select,
.page-template-simpleflex .accordion-content .book_table input[type="text"],
.page-template-simpleflex .tabs-content .book_table select,
.page-template-simpleflex .tabs-content .book_table input[type="text"],
.single-post .accordion-content .book_table select,
.single-post .accordion-content .book_table input[type="text"],
.single-post .tabs-content .book_table select,
.single-post .tabs-content .book_table input[type="text"],
.page-template-list-children .accordion-content .book_table select,
.page-template-list-children .accordion-content .book_table input[type="text"],
.page-template-list-children .tabs-content .book_table select,
.page-template-list-children .tabs-content .book_table input[type="text"] {
  border: solid 1px #dfdfdf;
  height: 37px;
  color: #3d4f69;
  font-weight: 300;
  font-size: 16px;
  padding: 0 10px;
  width: 100%;
  margin: 0;
  padding-right: 20px;
}

.page-template-simpleflex .accordion-content TD.calDaysChar,
.page-template-simpleflex .tabs-content TD.calDaysChar,
.single-post .accordion-content TD.calDaysChar,
.single-post .tabs-content TD.calDaysChar,
.page-template-list-children .accordion-content TD.calDaysChar,
.page-template-list-children .tabs-content TD.calDaysChar {
  background: #e5347e;
}

.page-template-simpleflex .accordion-content TD.calDayCur,
.page-template-simpleflex .tabs-content TD.calDayCur,
.single-post .accordion-content TD.calDayCur,
.single-post .tabs-content TD.calDayCur,
.page-template-list-children .accordion-content TD.calDayCur,
.page-template-list-children .tabs-content TD.calDayCur {
  background: #e5347e;
  border: none;
  border-radius: 30px;
}
.page-template-simpleflex .accordion-content TD.calDayCur a,
.page-template-simpleflex .tabs-content TD.calDayCur a,
.single-post .accordion-content TD.calDayCur a,
.single-post .tabs-content TD.calDayCur a,
.page-template-list-children .accordion-content TD.calDayCur a,
.page-template-list-children .tabs-content TD.calDayCur a {
  color: #fff;
}

.page-template-simpleflex #blog-4 p,
.single-post #blog-4 p,
.page-template-list-children #blog-4 p {
  color: black;
}

.page-template-simpleflex #blog-4 .blog-text,
.single-post #blog-4 .blog-text,
.page-template-list-children #blog-4 .blog-text {
  text-align: center;
}

.page-template-simpleflex .button,
.single-post .button,
.page-template-list-children .button {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
.page-template-simpleflex .button a,
.single-post .button a,
.page-template-list-children .button a {
  background-color: #e5347e;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
}
.page-template-simpleflex .button a:hover,
.single-post .button a:hover,
.page-template-list-children .button a:hover {
  background-color: #e84b8c;
}

#full-width-image-section {
  display: block;
  min-height: 50vh;
  background-position: center;
  background-size: cover;
}

#wpadminbar {
  position: fixed;
  z-index: 10;
}

/*
* — Contact —
*/
#contact .contact-slider img {
  height: 75vh;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
}

#contact .contact-details .details {
  margin-top: 2em;
  padding: 15px 25px;
  border-right: 1px solid #e4e4e4;
  padding-left: 4em;
  padding-right: 4em;
}
@media (max-width: 1250px) {
  #contact .contact-details .details {
    padding-left: 2em;
    padding-right: 2em;
  }
}
@media (max-width: 749px) {
  #contact .contact-details .details {
    max-width: 100%;
    width: 100%;
    text-align: center;
    margin: 0;
  }
}

#contact .form {
  padding-right: 10em;
}
@media (max-width: 1250px) {
  #contact .form {
    padding-right: 5em;
  }
}
@media (max-width: 1050px) {
  #contact .form {
    padding-right: 0;
    margin-left: 3em;
  }
}
@media (max-width: 749px) {
  #contact .form {
    padding: 2em;
    margin: 0;
  }
}
#contact .form h3 {
  font-size: 24px;
}
#contact .form .nf-form-fields-required {
  display: none;
}
#contact .form .nf-field-element input,
#contact .form .nf-field-element textarea#nf-field-3,
#contact .form .nf-field-element select {
  width: 100%;
  border: 1px solid #f5f5f5;
  box-shadow: none;
  height: 45px;
}
#contact .form .nf-field-element input#nf-field-4 {
  background-color: #e5347e;
  color: #fff;
  padding: 10px 45px;
  color: #fff;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  cursor: pointer;
  font-size: 18px;
}
#contact .form .nf-field-element input#nf-field-4:hover {
  background-color: #e84b8c;
}
#contact .form .nf-field-element input#nf-field-4:focus {
  outline: none;
}
#contact .form .nf-field-element input#nf-field-4:hover {
  background-color: #e84b8c;
}

.3d-tour iframe {
  width: 100%;
  height: 600px;
  border: none;
}

.single-post .content {
  padding-top: 0;
}
.single-post .content strong,
.single-post .content b {
  font-weight: 600;
}
.single-post .content .grid-x {
  margin-top: 5em;
  margin-bottom: 5em;
}

body.blog .banner {
  height: 55vh;
}
body.blog .banner img {
  height: 55vh;
}

body.blog #blog {
  margin: 0;
}
body.blog #blog .blog-article {
  position: relative;
}
body.blog #blog .blog-article img {
  height: 40vh;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
body.blog #blog .blog-article-details {
  position: absolute;
  bottom: 10%;
  text-align: left;
  left: 0;
  z-index: 10;
  pointer-events: none;
  padding: 0 10px;
  margin: 0 2em;
  color: #fff;
}
@media (max-width: 1101px) {
  body.blog #blog .blog-article-details {
    top: 50%;
  }
}
@media (max-width: 1049px) {
  body.blog #blog .blog-article-details {
    top: 60%;
  }
}
body.blog #blog .img-zoom {
  position: relative;
  margin: auto;
  overflow: hidden;
  width: 100%;
  cursor: pointer;
  background: black;
}
body.blog #blog .img-zoom img {
  max-width: 100%;
  display: block;
  width: 100%;
  transform: scale(1);
  transition: 0.5s ease;
  height: 350px;
  -o-object-fit: cover;
  object-fit: cover;
  opacity: 0.85;
}
body.blog #blog .img-zoom:hover img {
  transform: scale(1.1);
}
body.blog #blog .nav-links {
  text-align: center;
  font-size: 16px;
}
body.blog #blog .pagination a,
body.blog #blog .pagination button {
  display: inline-block;
}

div.loading {
  border-top: 2px solid #e5347e;
  margin: 50px auto;
}

.property-guest-details {
  margin-top: 6px;
  margin-left: 4px;
}

p.discount {
  margin-bottom: 0;
  color: #e5347e;
  display: inline-block;
  font-size: 15px;
  padding-right: 10px;
  text-decoration: line-through;
}

span.stay-discount {
  background: #83bd83;
  color: white;
  padding: 2px 5px;
  display: inline-block;
  font-size: 15px;
  margin-top: 5px;
}

.book-now-btn.fixed {
  position: fixed;
  bottom: 100px;
  right: 10px;
  z-index: 100;
}

.accordions {
  display: flex;
  flex-direction: column;
}
.accordions ul {
  margin: 0.5rem 0;
  display: flex;
  flex-direction: column;
}
.accordions h3:not(.accordion__mainTitle) {
  margin-top: 1rem;
}

#instagram {
  background: #f5f5f5;
}

#instagram h2 {
  font-size: 24px;
}

#instagram .sbi_item {
  width: 50% !important;
}
@media (min-width: 750px) {
  #instagram .sbi_item {
    width: 33.33% !important;
  }
}
@media (min-width: 1050px) {
  #instagram .sbi_item {
    width: 20% !important;
  }
}

#instagram .sbi_item:nth-child(2n) {
  display: none !important;
}
@media (min-width: 1050px) {
  #instagram .sbi_item:nth-child(2n) {
    display: block !important;
  }
}

#instagram .sbi_item:nth-child(3n) {
  display: none !important;
}
@media (min-width: 750px) {
  #instagram .sbi_item:nth-child(3n) {
    display: block !important;
  }
}

#property {
  font-family: "Barlow", sans-serif !important;
}
#property * {
  font-family: "Barlow", sans-serif !important;
}
#property .material-icons,
#property i.material-icons {
  font-family: "Material Icons" !important;
  font-weight: normal;
  font-style: normal;
  font-size: 24px;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
}
#property h2,
#property .overview .title h2,
#property .sleeping .main-title h2,
#property .additional-info .title h2,
#property .location .title h2,
#property .title h2,
#property h2.title {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
}
#property .property-name h2 {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
  font-weight: 600 !important;
}
#property .material-icons {
  font-family: "Material Icons" !important;
  font-weight: normal;
  font-style: normal;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
  vertical-align: middle;
  font-size: inherit;
}
#property .features .icons .material-icons,
#property .additional-info .icons .material-icons {
  font-family: "Material Icons" !important;
  font-size: 16px;
  margin-right: 5px;
}
#property .title .material-icons {
  font-family: "Material Icons" !important;
  font-size: 24px;
  vertical-align: middle;
  margin-right: 8px;
}

/* Force properties page banner height to 480px - highest priority */
body.page-template-properties .off-canvas-content > .banner,
body.page-template-properties .banner,
body.page-template-properties .banner * {
  height: 480px !important;
  max-height: 480px !important;
}
body.page-template-properties .banner img,
body.page-template-properties .banner picture,
body.page-template-properties .banner picture img,
body.page-template-properties .banner .banner-item,
body.page-template-properties .banner .banner-item img,
body.page-template-properties .banner .banner-item picture,
body.page-template-properties .banner .banner-item picture img,
body.page-template-properties .banner .slides,
body.page-template-properties .banner .slick-slider,
body.page-template-properties .banner .slick-list,
body.page-template-properties .banner .slick-track,
body.page-template-properties .banner .slick-slide {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

/* ============================================
   ABOUT US PAGE - INDEPENDENT CSS
   All styles scoped to body.page-template-about-us
   This section ensures complete isolation from global styles
   ============================================ */

/* CRITICAL: Override ALL global banner styles FIRST - prevent 90vh (780px) from affecting this page */
body.page-template-about-us .banner,
body.page-template-about-us .banner.about-us-banner,
body.page-template-about-us .off-canvas-content .banner,
body.page-template-about-us .content .banner,
body.page-template-about-us .flex-content .banner {
  height: 486px !important;
  max-height: 486px !important;
  min-height: 486px !important;
}
body.page-template-about-us .banner *,
body.page-template-about-us .banner.about-us-banner * {
  height: 486px !important;
  max-height: 486px !important;
  min-height: 486px !important;
}

/* Override global content padding - prevent 8vh padding from affecting this page */
body.page-template-about-us .content,
body.page-template-about-us .flex-content,
body.page-template-about-us .off-canvas-content .content {
  padding-top: 0 !important;
  margin-top: 0 !important;
  padding-bottom: inherit !important;
}

/* CRITICAL: Override ALL global banner img heights (90vh, 80vh, 100vh) */
body.page-template-about-us .off-canvas-content .banner img,
body.page-template-about-us .content .banner img,
body.page-template-about-us .flex-content .banner img,
body.page-template-about-us .banner img,
body.page-template-about-us .banner.about-us-banner img,
body.page-template-about-us .off-canvas-content .banner picture,
body.page-template-about-us .content .banner picture,
body.page-template-about-us .flex-content .banner picture,
body.page-template-about-us .banner picture,
body.page-template-about-us .banner.about-us-banner picture,
body.page-template-about-us .banner picture img,
body.page-template-about-us .banner.about-us-banner picture img {
  height: 486px !important;
  max-height: 486px !important;
  min-height: 486px !important;
  object-fit: cover !important;
}

/* Force About Us page banner height to 486px - scoped to page template only */
body.page-template-about-us .about-us-banner,
body.page-template-about-us .about-us-banner *,
body.page-template-about-us .about-us-banner img,
body.page-template-about-us .about-us-banner picture,
body.page-template-about-us .about-us-banner picture img,
body.page-template-about-us .about-us-banner .banner-item,
body.page-template-about-us .about-us-banner .banner-item img,
body.page-template-about-us .about-us-banner .banner-item picture,
body.page-template-about-us .about-us-banner .banner-item picture img,
body.page-template-about-us .about-us-banner .slides,
body.page-template-about-us .about-us-banner .slick-slider,
body.page-template-about-us .about-us-banner .slick-list,
body.page-template-about-us .about-us-banner .slick-track,
body.page-template-about-us .about-us-banner .slick-slide {
  height: 486px !important;
  max-height: 486px !important;
  min-height: 486px !important;
}
body.page-template-about-us
  .off-canvas-content
  .content
  .banner.about-us-banner,
body.page-template-about-us .content .banner.about-us-banner,
body.page-template-about-us .flex-content .banner.about-us-banner,
body.page-template-about-us .banner.about-us-banner,
body.page-template-about-us .banner.about-us-banner * {
  height: 486px !important;
  max-height: 486px !important;
}
body.page-template-about-us .content .banner.about-us-banner img,
body.page-template-about-us .flex-content .banner.about-us-banner img,
body.page-template-about-us .banner.about-us-banner img,
body.page-template-about-us .banner.about-us-banner picture,
body.page-template-about-us .banner.about-us-banner picture img,
body.page-template-about-us .banner.about-us-banner .banner-item,
body.page-template-about-us .banner.about-us-banner .banner-item img,
body.page-template-about-us .banner.about-us-banner .banner-item picture,
body.page-template-about-us .banner.about-us-banner .banner-item picture img,
body.page-template-about-us .banner.about-us-banner .slides,
body.page-template-about-us .banner.about-us-banner .slick-slider,
body.page-template-about-us .banner.about-us-banner .slick-list,
body.page-template-about-us .banner.about-us-banner .slick-track,
body.page-template-about-us .banner.about-us-banner .slick-slide {
  height: 486px !important;
  max-height: 486px !important;
  min-height: 486px !important;
}

/* Reduce space between header and hero section on About Us page only */
body.page-template-about-us .about-us-banner {
  margin-top: -20px !important;
}

/* Ensure About Us banner overlay is vertically centered - scoped to page template */
body.page-template-about-us .about-us-banner .banner-overlay {
  top: 50% !important;
  transform: translateY(-50%) !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}
body.page-template-about-us .about-us-banner .banner-overlay .grid-x {
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 100% !important;
  margin: 0 !important;
}
body.page-template-about-us .about-us-banner .banner-item {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 486px !important;
}
body.page-template-about-us .about-us-banner .banner-overlay .overlay-content {
  margin: 0 auto !important;
}

/* Override all media query banner heights for About Us page */
@media (max-width: 970px) {
  body.page-template-about-us .banner,
  body.page-template-about-us .banner.about-us-banner,
  body.page-template-about-us .banner *,
  body.page-template-about-us .banner.about-us-banner *,
  body.page-template-about-us .banner img,
  body.page-template-about-us .banner.about-us-banner img,
  body.page-template-about-us .banner .banner-item,
  body.page-template-about-us .banner.about-us-banner .banner-item {
    height: 486px !important;
    max-height: 486px !important;
    min-height: 486px !important;
  }
}
@media (max-width: 380px) {
  body.page-template-about-us .banner,
  body.page-template-about-us .banner.about-us-banner,
  body.page-template-about-us .banner *,
  body.page-template-about-us .banner.about-us-banner *,
  body.page-template-about-us .banner img,
  body.page-template-about-us .banner.about-us-banner img,
  body.page-template-about-us .banner .banner-item,
  body.page-template-about-us .banner.about-us-banner .banner-item {
    height: 486px !important;
    max-height: 486px !important;
    min-height: 486px !important;
  }
}

/* Override global banner-item styles */
body.page-template-about-us .about-us-banner .banner-item {
  background: transparent !important;
  overflow: visible !important;
}
body.page-template-about-us .about-us-banner .banner-item::before {
  display: none !important;
}

/* Ensure banner overlay positioning is independent */
body.page-template-about-us .about-us-banner .banner-overlay {
  background: transparent !important;
  z-index: 2 !important;
}

/* Override any global h1 styles in banner overlay */
body.page-template-about-us .about-us-banner .banner-overlay h1 {
  color: #fff !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  margin: 0 !important;
  text-align: center !important;
}

/* ============================================
   TERMS AND CONDITIONS PAGE - INDEPENDENT CSS
   All styles scoped to body.page-template-terms-and-conditions
   This section ensures complete isolation from global styles
   ============================================ */

/* CRITICAL: Override ALL global banner styles FIRST - prevent 90vh (780px) from affecting this page */
/* Target .banner directly to override the global .banner { height: 90vh; } rule */
body.page-template-terms-and-conditions .off-canvas-content .banner,
body.page-template-terms-and-conditions .content .banner,
body.page-template-terms-and-conditions .flex-content .banner,
body.page-template-terms-and-conditions .banner,
body.page-template-terms-and-conditions .banner.terms-conditions-banner {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}
body.page-template-terms-and-conditions .off-canvas-content .banner *,
body.page-template-terms-and-conditions .content .banner *,
body.page-template-terms-and-conditions .flex-content .banner *,
body.page-template-terms-and-conditions .banner *,
body.page-template-terms-and-conditions .banner.terms-conditions-banner * {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

/* Override global content padding - prevent 8vh padding from affecting this page */
body.page-template-terms-and-conditions .content,
body.page-template-terms-and-conditions .flex-content,
body.page-template-terms-and-conditions .off-canvas-content .content {
  padding-top: 0 !important;
  margin-top: 0 !important;
  padding-bottom: inherit !important;
}

/* CRITICAL: Override ALL global banner img heights (90vh, 80vh, 100vh) - must override viewport units */
/* Target all possible banner img selectors to override .banner img { height: 90vh; } */
body.page-template-terms-and-conditions .off-canvas-content .banner img,
body.page-template-terms-and-conditions .content .banner img,
body.page-template-terms-and-conditions .flex-content .banner img,
body.page-template-terms-and-conditions .banner img,
body.page-template-terms-and-conditions .banner.terms-conditions-banner img,
body.page-template-terms-and-conditions .off-canvas-content .banner picture,
body.page-template-terms-and-conditions .content .banner picture,
body.page-template-terms-and-conditions .flex-content .banner picture,
body.page-template-terms-and-conditions .banner picture,
body.page-template-terms-and-conditions .banner.terms-conditions-banner picture,
body.page-template-terms-and-conditions .banner picture img,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  picture
  img {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
  object-fit: cover !important;
}

/* Force Terms and Conditions page banner height to 480px - scoped to page template only */
body.page-template-terms-and-conditions .terms-conditions-banner,
body.page-template-terms-and-conditions .terms-conditions-banner *,
body.page-template-terms-and-conditions .terms-conditions-banner img,
body.page-template-terms-and-conditions .terms-conditions-banner picture,
body.page-template-terms-and-conditions .terms-conditions-banner picture img,
body.page-template-terms-and-conditions .terms-conditions-banner .banner-item,
body.page-template-terms-and-conditions
  .terms-conditions-banner
  .banner-item
  img,
body.page-template-terms-and-conditions
  .terms-conditions-banner
  .banner-item
  picture,
body.page-template-terms-and-conditions
  .terms-conditions-banner
  .banner-item
  picture
  img,
body.page-template-terms-and-conditions .terms-conditions-banner .slides,
body.page-template-terms-and-conditions .terms-conditions-banner .slick-slider,
body.page-template-terms-and-conditions .terms-conditions-banner .slick-list,
body.page-template-terms-and-conditions .terms-conditions-banner .slick-track,
body.page-template-terms-and-conditions .terms-conditions-banner .slick-slide {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}
body.page-template-terms-and-conditions
  .off-canvas-content
  .content
  .banner.terms-conditions-banner,
body.page-template-terms-and-conditions
  .content
  .banner.terms-conditions-banner,
body.page-template-terms-and-conditions
  .flex-content
  .banner.terms-conditions-banner,
body.page-template-terms-and-conditions .banner.terms-conditions-banner,
body.page-template-terms-and-conditions .banner.terms-conditions-banner * {
  height: 480px !important;
  max-height: 480px !important;
}
body.page-template-terms-and-conditions
  .content
  .banner.terms-conditions-banner
  img,
body.page-template-terms-and-conditions
  .flex-content
  .banner.terms-conditions-banner
  img,
body.page-template-terms-and-conditions .banner.terms-conditions-banner img,
body.page-template-terms-and-conditions .banner.terms-conditions-banner picture,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  picture
  img,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .banner-item,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .banner-item
  img,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .banner-item
  picture,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .banner-item
  picture
  img,
body.page-template-terms-and-conditions .banner.terms-conditions-banner .slides,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .slick-slider,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .slick-list,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .slick-track,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .slick-slide {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

/* Reduce space between header and hero section on Terms and Conditions page only */
body.page-template-terms-and-conditions .terms-conditions-banner {
  margin-top: -20px !important;
}
body.page-template-terms-and-conditions .off-canvas-content .content,
body.page-template-terms-and-conditions .off-canvas-content .flex-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}
body.page-template-terms-and-conditions .off-canvas-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* Ensure Terms and Conditions banner overlay is vertically centered - scoped to page template */
body.page-template-terms-and-conditions
  .terms-conditions-banner
  .banner-overlay {
  top: 50% !important;
  transform: translateY(-50%) !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}
body.page-template-terms-and-conditions
  .terms-conditions-banner
  .banner-overlay
  .grid-x {
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 100% !important;
  margin: 0 !important;
}
body.page-template-terms-and-conditions .terms-conditions-banner .banner-item {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 480px !important;
}
body.page-template-terms-and-conditions
  .terms-conditions-banner
  .banner-overlay
  .overlay-content {
  margin: 0 auto !important;
}

/* CRITICAL: Override ALL media query banner heights for Terms and Conditions page - override viewport units */
@media (max-width: 970px) {
  body.page-template-terms-and-conditions .banner,
  body.page-template-terms-and-conditions .banner.terms-conditions-banner,
  body.page-template-terms-and-conditions .banner *,
  body.page-template-terms-and-conditions .banner.terms-conditions-banner *,
  body.page-template-terms-and-conditions .banner img,
  body.page-template-terms-and-conditions .banner.terms-conditions-banner img,
  body.page-template-terms-and-conditions .banner .banner-item,
  body.page-template-terms-and-conditions
    .banner.terms-conditions-banner
    .banner-item {
    height: 480px !important;
    max-height: 480px !important;
    min-height: 480px !important;
  }
}
@media (max-width: 380px) {
  body.page-template-terms-and-conditions .banner,
  body.page-template-terms-and-conditions .banner.terms-conditions-banner,
  body.page-template-terms-and-conditions .banner *,
  body.page-template-terms-and-conditions .banner.terms-conditions-banner *,
  body.page-template-terms-and-conditions .banner img,
  body.page-template-terms-and-conditions .banner.terms-conditions-banner img,
  body.page-template-terms-and-conditions .banner .banner-item,
  body.page-template-terms-and-conditions
    .banner.terms-conditions-banner
    .banner-item {
    height: 480px !important;
    max-height: 480px !important;
    min-height: 480px !important;
  }
}

/* Override global banner-item styles (background, overflow, etc.) */
body.page-template-terms-and-conditions .terms-conditions-banner .banner-item {
  background: transparent !important;
  overflow: visible !important;
}
body.page-template-terms-and-conditions
  .terms-conditions-banner
  .banner-item::before {
  display: none !important;
}

/* Ensure banner overlay positioning is independent */
body.page-template-terms-and-conditions
  .terms-conditions-banner
  .banner-overlay {
  background: transparent !important;
  z-index: 2 !important;
}

/* Override any global h1 styles in banner overlay */
body.page-template-terms-and-conditions
  .terms-conditions-banner
  .banner-overlay
  h1 {
  color: #fff !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  margin: 0 !important;
  text-align: center !important;
}

/* ============================================
   FINAL OVERRIDE - Must be at the END of file
   Overrides default.css and any other late-loading CSS
   ============================================ */
body.page-template-terms-and-conditions .banner,
body.page-template-terms-and-conditions .banner.terms-conditions-banner,
body.page-template-terms-and-conditions .off-canvas-content .banner,
body.page-template-terms-and-conditions .content .banner,
body.page-template-terms-and-conditions .flex-content .banner {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}
body.page-template-terms-and-conditions .banner img,
body.page-template-terms-and-conditions .banner.terms-conditions-banner img,
body.page-template-terms-and-conditions .banner picture,
body.page-template-terms-and-conditions .banner.terms-conditions-banner picture,
body.page-template-terms-and-conditions .banner picture img,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  picture
  img {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}
body.page-template-terms-and-conditions .banner .banner-item,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .banner-item,
body.page-template-terms-and-conditions .banner .slides,
body.page-template-terms-and-conditions .banner.terms-conditions-banner .slides,
body.page-template-terms-and-conditions .banner .slick-slider,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .slick-slider,
body.page-template-terms-and-conditions .banner .slick-list,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .slick-list,
body.page-template-terms-and-conditions .banner .slick-track,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .slick-track,
body.page-template-terms-and-conditions .banner .slick-slide,
body.page-template-terms-and-conditions
  .banner.terms-conditions-banner
  .slick-slide {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

/* ============================================
   PRIVACY POLICY PAGE - INDEPENDENT CSS
   All styles scoped to body.page-template-privacy-policy
   This section ensures complete isolation from global styles
   ============================================ */

/* CRITICAL: Override ALL global banner styles FIRST - prevent 90vh (780px) from affecting this page */
body.page-template-privacy-policy .off-canvas-content .banner,
body.page-template-privacy-policy .content .banner,
body.page-template-privacy-policy .flex-content .banner,
body.page-template-privacy-policy .banner,
body.page-template-privacy-policy .banner.privacy-policy-banner {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

body.page-template-privacy-policy .off-canvas-content .banner *,
body.page-template-privacy-policy .content .banner *,
body.page-template-privacy-policy .flex-content .banner *,
body.page-template-privacy-policy .banner *,
body.page-template-privacy-policy .banner.privacy-policy-banner * {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

/* Override global content padding - prevent 8vh padding from affecting this page */
body.page-template-privacy-policy .content,
body.page-template-privacy-policy .flex-content,
body.page-template-privacy-policy .off-canvas-content .content {
  padding-top: 0 !important;
  margin-top: 0 !important;
  padding-bottom: inherit !important;
}

/* Force banner images and picture elements to 480px */
body.page-template-privacy-policy .off-canvas-content .banner img,
body.page-template-privacy-policy .content .banner img,
body.page-template-privacy-policy .flex-content .banner img,
body.page-template-privacy-policy .banner img,
body.page-template-privacy-policy .banner.privacy-policy-banner img,
body.page-template-privacy-policy .off-canvas-content .banner picture,
body.page-template-privacy-policy .content .banner picture,
body.page-template-privacy-policy .flex-content .banner picture,
body.page-template-privacy-policy .banner picture,
body.page-template-privacy-policy .banner.privacy-policy-banner picture,
body.page-template-privacy-policy .banner picture img,
body.page-template-privacy-policy .banner.privacy-policy-banner picture img {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
  width: 100% !important;
  object-fit: cover !important;
}

/* Force all banner child elements */
body.page-template-privacy-policy .privacy-policy-banner,
body.page-template-privacy-policy .privacy-policy-banner *,
body.page-template-privacy-policy .privacy-policy-banner img,
body.page-template-privacy-policy .privacy-policy-banner picture,
body.page-template-privacy-policy .privacy-policy-banner picture img,
body.page-template-privacy-policy .privacy-policy-banner .banner-item,
body.page-template-privacy-policy .privacy-policy-banner .banner-item img,
body.page-template-privacy-policy .privacy-policy-banner .banner-item picture,
body.page-template-privacy-policy
  .privacy-policy-banner
  .banner-item
  picture
  img,
body.page-template-privacy-policy .privacy-policy-banner .slides,
body.page-template-privacy-policy .privacy-policy-banner .slick-slider,
body.page-template-privacy-policy .privacy-policy-banner .slick-list,
body.page-template-privacy-policy .privacy-policy-banner .slick-track,
body.page-template-privacy-policy .privacy-policy-banner .slick-slide {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

body.page-template-privacy-policy
  .off-canvas-content
  .content
  .banner.privacy-policy-banner,
body.page-template-privacy-policy .content .banner.privacy-policy-banner,
body.page-template-privacy-policy .flex-content .banner.privacy-policy-banner,
body.page-template-privacy-policy .banner.privacy-policy-banner,
body.page-template-privacy-policy .banner.privacy-policy-banner * {
  height: 480px !important;
  max-height: 480px !important;
}

/* Banner margin override */
body.page-template-privacy-policy .privacy-policy-banner {
  margin-top: -20px !important;
}

body.page-template-privacy-policy .off-canvas-content .content,
body.page-template-privacy-policy .off-canvas-content .flex-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

body.page-template-privacy-policy .off-canvas-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* Ensure Privacy Policy banner overlay is vertically centered */
body.page-template-privacy-policy .privacy-policy-banner .banner-overlay {
  top: 50% !important;
  transform: translateY(-50%) !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
}

body.page-template-privacy-policy
  .privacy-policy-banner
  .banner-overlay
  .grid-x {
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

body.page-template-privacy-policy .privacy-policy-banner .banner-item {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 480px !important;
}

body.page-template-privacy-policy
  .privacy-policy-banner
  .banner-overlay
  .overlay-content {
  margin: 0 auto !important;
}

/* Responsive overrides */
@media (max-width: 1023px) {
  body.page-template-privacy-policy .banner,
  body.page-template-privacy-policy .banner.privacy-policy-banner,
  body.page-template-privacy-policy .banner *,
  body.page-template-privacy-policy .banner.privacy-policy-banner *,
  body.page-template-privacy-policy .banner img,
  body.page-template-privacy-policy .banner.privacy-policy-banner img,
  body.page-template-privacy-policy .banner .banner-item,
  body.page-template-privacy-policy .banner.privacy-policy-banner .banner-item {
    height: 480px !important;
    max-height: 480px !important;
    min-height: 480px !important;
  }
}

@media (max-width: 640px) {
  body.page-template-privacy-policy .banner,
  body.page-template-privacy-policy .banner.privacy-policy-banner,
  body.page-template-privacy-policy .banner *,
  body.page-template-privacy-policy .banner.privacy-policy-banner *,
  body.page-template-privacy-policy .banner img,
  body.page-template-privacy-policy .banner.privacy-policy-banner img,
  body.page-template-privacy-policy .banner .banner-item,
  body.page-template-privacy-policy .banner.privacy-policy-banner .banner-item {
    height: 480px !important;
    max-height: 480px !important;
    min-height: 480px !important;
  }
}

body.page-template-privacy-policy .privacy-policy-banner .banner-item {
  background: transparent !important;
  overflow: visible !important;
}

body.page-template-privacy-policy .privacy-policy-banner .banner-item::before {
  display: none !important;
}

/* Ensure banner overlay positioning is independent */
body.page-template-privacy-policy .privacy-policy-banner .banner-overlay {
  background: transparent !important;
  z-index: 2 !important;
}

/* Override any global h1 styles in banner overlay */
body.page-template-privacy-policy .privacy-policy-banner .banner-overlay h1 {
  color: #fff !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  margin: 0 !important;
  text-align: center !important;
}

/* Content styling */
body.page-template-privacy-policy .grid-x.grid-padding-x {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2rem 1rem;
}

body.page-template-privacy-policy .grid-x.grid-padding-x .cell {
  padding-left: 1rem;
  padding-right: 1rem;
}

body.page-template-privacy-policy h2,
body.page-template-privacy-policy .grid-x h2,
body.page-template-privacy-policy .cell h2,
body.page-template-privacy-policy .grid-padding-x h2,
body.page-template-privacy-policy .grid-padding-y h2,
body.page-template-privacy-policy .content h2,
body.page-template-privacy-policy .flex-content h2 {
  font-size: 24px !important;
  font-weight: 600;
  margin-top: 2rem;
  margin-bottom: 1rem;
  color: #0a0a0a;
}

body.page-template-privacy-policy h2:first-of-type {
  margin-top: 0;
}

/* Override any global h2 styles */
body.page-template-privacy-policy h2 strong,
body.page-template-privacy-policy h2 b {
  font-size: 24px !important;
}

body.page-template-privacy-policy h3 {
  font-size: 18px;
  font-weight: 600;
  margin-top: 1.5rem;
  margin-bottom: 0.75rem;
  color: #0a0a0a;
}

body.page-template-privacy-policy p {
  font-size: 16px;
  line-height: 1.6;
  margin-bottom: 1rem;
  color: #0a0a0a;
}

body.page-template-privacy-policy ul,
body.page-template-privacy-policy ol {
  margin-left: 1.5rem;
  margin-bottom: 1rem;
  font-size: 16px;
  line-height: 1.6;
}

body.page-template-privacy-policy ul li,
body.page-template-privacy-policy ol li {
  margin-bottom: 0.5rem;
}

body.page-template-privacy-policy hr {
  border: none;
  border-top: 1px solid #e6e6e6;
  margin: 2rem 0;
}

body.page-template-privacy-policy a {
  color: #e5347e;
  text-decoration: underline;
}

body.page-template-privacy-policy a:hover {
  color: #c02a68;
}

body.page-template-privacy-policy strong {
  font-weight: 600;
}

/* ============================================
   FINAL OVERRIDE - Must be at the END of Privacy Policy section
   Overrides default.css and any other late-loading CSS
   ============================================ */

/* CRITICAL: Force h2 font-size to 24px - override ALL other rules including banner overlay */
body.page-template-privacy-policy h2,
body.page-template-privacy-policy .grid-x h2,
body.page-template-privacy-policy .cell h2,
body.page-template-privacy-policy .grid-padding-x h2,
body.page-template-privacy-policy .grid-padding-y h2,
body.page-template-privacy-policy .content h2,
body.page-template-privacy-policy .flex-content h2,
body.page-template-privacy-policy .off-canvas-content h2,
body.page-template-privacy-policy .grid-x.grid-padding-x h2,
body.page-template-privacy-policy .grid-x.grid-padding-x .cell h2,
body.page-template-privacy-policy .grid-x.grid-padding-x.grid-padding-y h2,
body.page-template-privacy-policy
  .grid-x.grid-padding-x.grid-padding-y
  .cell
  h2,
body.page-template-privacy-policy
  .grid-x.grid-padding-x.grid-padding-y.align-middle
  h2,
body.page-template-privacy-policy
  .grid-x.grid-padding-x.grid-padding-y.align-middle
  .cell
  h2 {
  font-size: 24px !important;
}

/* Exclude banner overlay h2 from the 24px rule - keep banner h2 at default size */
body.page-template-privacy-policy .banner-overlay h2,
body.page-template-privacy-policy .banner .banner-overlay h2,
body.page-template-privacy-policy .privacy-policy-banner .banner-overlay h2 {
  font-size: inherit !important;
}

body.page-template-privacy-policy .banner,
body.page-template-privacy-policy .banner.privacy-policy-banner,
body.page-template-privacy-policy .off-canvas-content .banner,
body.page-template-privacy-policy .content .banner,
body.page-template-privacy-policy .flex-content .banner {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

body.page-template-privacy-policy .banner img,
body.page-template-privacy-policy .banner.privacy-policy-banner img,
body.page-template-privacy-policy .banner picture,
body.page-template-privacy-policy .banner.privacy-policy-banner picture,
body.page-template-privacy-policy .banner picture img,
body.page-template-privacy-policy .banner.privacy-policy-banner picture img {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

body.page-template-privacy-policy .banner .banner-item,
body.page-template-privacy-policy .banner.privacy-policy-banner .banner-item,
body.page-template-privacy-policy .banner .slides,
body.page-template-privacy-policy .banner.privacy-policy-banner .slides,
body.page-template-privacy-policy .banner .slick-slider,
body.page-template-privacy-policy .banner.privacy-policy-banner .slick-slider,
body.page-template-privacy-policy .banner .slick-list,
body.page-template-privacy-policy .banner.privacy-policy-banner .slick-list,
body.page-template-privacy-policy .banner .slick-track,
body.page-template-privacy-policy .banner.privacy-policy-banner .slick-track,
body.page-template-privacy-policy .banner .slick-slide,
body.page-template-privacy-policy .banner.privacy-policy-banner .slick-slide {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

#property .stars .material-icons {
  font-family: "Material Icons" !important;
  color: #efe057;
  font-size: 18px;
}
#property .bedroom-details .material-icons {
  font-family: "Material Icons" !important;
  font-size: 18px;
  margin-right: 5px;
}
#properties .property .details .material-icons {
  font-family: "Material Icons" !important;
  font-size: 16px;
  vertical-align: middle;
}

/* ============================================
   INFO PAGE - INDEPENDENT CSS
   All styles scoped to body.page-template-info
   This section ensures complete isolation from global styles
   ============================================ */

/* CRITICAL: Override ALL global banner styles FIRST - prevent 90vh (780px) from affecting this page */
body.page-template-info .off-canvas-content .banner,
body.page-template-info .content .banner,
body.page-template-info .flex-content .banner,
body.page-template-info .banner,
body.page-template-info .banner.info-banner {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
  margin-top: -20px !important;
}

body.page-template-info .banner .slides,
body.page-template-info .banner.info-banner .slides,
body.page-template-info .banner .slick-slider,
body.page-template-info .banner.info-banner .slick-slider {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
}

body.page-template-info .banner .banner-item,
body.page-template-info .banner.info-banner .banner-item {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
  position: relative !important;
}

body.page-template-info .banner picture,
body.page-template-info .banner.info-banner picture {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
  display: block !important;
}

body.page-template-info .banner picture img,
body.page-template-info .banner.info-banner picture img {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
  width: 100% !important;
  object-fit: cover !important;
}

body.page-template-info .content.flex-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

body.page-template-info .off-canvas-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

body.page-template-info .info-banner .banner-overlay {
  top: 50% !important;
  transform: translateY(-50%) !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  z-index: 2 !important;
}

body.page-template-info .info-banner .banner-overlay .grid-x {
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 100% !important;
  margin: 0 !important;
}

body.page-template-info .info-banner .banner-item {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 500px !important;
}

body.page-template-info .info-banner .banner-overlay .overlay-content {
  margin: 0 auto !important;
}

body.page-template-info .info-banner .banner-overlay h2 {
  color: #fff !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  margin: 0 !important;
  text-align: center !important;
}

/* Override global banner-item styles */
body.page-template-info .info-banner .banner-item {
  background: transparent !important;
  overflow: visible !important;
}

body.page-template-info .info-banner .banner-item::before {
  display: none !important;
}

/* Info page content styling */
body.page-template-info .grid-padding-x,
body.page-template-info .grid-padding-y {
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 2rem;
  padding-bottom: 2rem;
}

body.page-template-info .gap {
  margin-bottom: 2rem;
}

body.page-template-info .cell p {
  text-align: left;
  margin-bottom: 1rem;
  line-height: 1.6;
  font-size: 16px;
}

/* Tabs styling for Info page */
body.page-template-info .tabs {
  margin: 0;
  border: 1px solid #e6e6e6;
  background: #fefefe;
  list-style-type: none;
  display: flex;
  flex-wrap: wrap;
}

body.page-template-info .tabs-title {
  float: left;
  margin: 0;
}

body.page-template-info .tabs .tabs-title > a,
body.page-template-info ul.tabs .tabs-title > a,
body.page-template-info .tabs-title > a,
body.page-template-info .tabs li.tabs-title > a,
body.page-template-info ul.tabs li.tabs-title > a,
body.page-template-info .grid-x .tabs .tabs-title > a,
body.page-template-info .content .tabs .tabs-title > a,
body.page-template-info #info-tabs .tabs-title > a,
body.page-template-info
  [data-tabs-content="info-tabs"]
  ~ .tabs-content
  ~ .tabs
  .tabs-title
  > a {
  font-size: 16px !important;
  display: block;
  padding: 1.25rem 1.5rem;
  line-height: 1;
  color: #e5347e;
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: all 0.3s ease;
}

body.page-template-info .tabs-title > a:hover {
  background: #fefefe;
  color: #e5347e;
}

body.page-template-info .tabs-title > a:focus,
body.page-template-info .tabs-title > a[aria-selected="true"] {
  background: #e6e6e6;
  color: #e5347e;
  border-bottom-color: #e5347e;
}

body.page-template-info .tabs-title.is-active > a,
body.page-template-info .tabs-title > a[aria-selected="true"],
body.page-template-info .tabs-title > a:focus {
  background: #e6e6e6;
  color: #e5347e;
  border-bottom-color: #e5347e;
  font-size: 16px !important;
}

body.page-template-info .tabs-content {
  border: 1px solid #e6e6e6;
  border-top: 0;
  background: #fefefe;
  color: #0a0a0a;
  padding: 0;
}

body.page-template-info .tabs-panel {
  display: none;
  padding: 2rem;
}

body.page-template-info .tabs-panel.is-active {
  display: block;
}

body.page-template-info .tabs-panel img {
  max-width: 100%;
  height: auto;
  margin-bottom: 1.5rem;
}

body.page-template-info .tabs-panel p {
  margin-bottom: 1rem;
  line-height: 1.6;
  font-size: 16px;
}

body.page-template-info .tabs-panel ol {
  margin-left: 1.5rem;
  margin-bottom: 1rem;
}

body.page-template-info .tabs-panel ol li {
  margin-bottom: 0.5rem;
  line-height: 1.6;
  font-size: 16px;
}

body.page-template-info .tabs-panel ul {
  margin-left: 1.5rem;
  margin-bottom: 1rem;
}

body.page-template-info .tabs-panel ul li {
  margin-bottom: 0.5rem;
  line-height: 1.6;
  font-size: 16px;
}

body.page-template-info .tabs-panel strong {
  font-weight: 600;
  color: #0a0a0a;
}

body.page-template-info .tabs-panel a {
  color: #e5347e;
  text-decoration: underline;
}

body.page-template-info .tabs-panel a:hover {
  color: #d61b6a;
}

/* Media queries for Info page */
@media (max-width: 970px) {
  body.page-template-info .banner,
  body.page-template-info .banner.info-banner,
  body.page-template-info .banner *,
  body.page-template-info .banner.info-banner *,
  body.page-template-info .banner img,
  body.page-template-info .banner.info-banner img,
  body.page-template-info .banner .banner-item,
  body.page-template-info .banner.info-banner .banner-item {
    height: 500px !important;
    max-height: 500px !important;
    min-height: 500px !important;
  }
}

@media (max-width: 750px) {
  body.page-template-info .info-banner .banner-overlay h2 {
    font-size: 35px;
  }

  body.page-template-info .tabs-title > a,
  body.page-template-info .tabs .tabs-title > a,
  body.page-template-info ul.tabs .tabs-title > a {
    font-size: 16px !important;
    padding: 1rem 1rem;
  }

  body.page-template-info .tabs-panel {
    padding: 1.5rem;
  }
}

@media (max-width: 640px) {
  body.page-template-info .tabs {
    flex-direction: column;
  }

  body.page-template-info .tabs-title {
    width: 100%;
    border-bottom: 1px solid #e6e6e6;
  }

  body.page-template-info .tabs-title:last-child {
    border-bottom: none;
  }

  body.page-template-info .tabs-title > a,
  body.page-template-info .tabs .tabs-title > a {
    border-bottom: none;
    border-left: 3px solid transparent;
    font-size: 16px !important;
  }

  body.page-template-info .tabs-title.is-active > a {
    border-left-color: #e5347e;
    border-bottom: none;
    font-size: 16px !important;
  }
}

/* FINAL OVERRIDE - Must be at the END of Info page section */
body.page-template-info .banner,
body.page-template-info .banner.info-banner,
body.page-template-info .off-canvas-content .banner,
body.page-template-info .content .banner,
body.page-template-info .flex-content .banner {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
}

/* Universal override for all tabs titles on info page - highest priority */
body.page-template-info .tabs-title > a,
body.page-template-info .tabs .tabs-title > a,
body.page-template-info ul.tabs .tabs-title > a,
body.page-template-info .tabs li.tabs-title > a,
body.page-template-info ul.tabs li.tabs-title > a,
body.page-template-info .grid-x .tabs .tabs-title > a,
body.page-template-info .content .tabs .tabs-title > a,
body.page-template-info .tabs-title.is-active > a,
body.page-template-info .tabs-title > a[aria-selected="true"],
body.page-template-info .tabs-title > a:hover,
body.page-template-info .tabs-title > a:focus {
  font-size: 16px !important;
  color: #e5347e !important;
}

body.page-template-info .banner img,
body.page-template-info .banner.info-banner img,
body.page-template-info .banner picture,
body.page-template-info .banner.info-banner picture,
body.page-template-info .banner picture img,
body.page-template-info .banner.info-banner picture img {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
}

body.page-template-info .banner .banner-item,
body.page-template-info .banner.info-banner .banner-item,
body.page-template-info .banner .slides,
body.page-template-info .banner.info-banner .slides,
body.page-template-info .banner .slick-slider,
body.page-template-info .banner.info-banner .slick-slider,
body.page-template-info .banner .slick-list,
body.page-template-info .banner.info-banner .slick-list,
body.page-template-info .banner .slick-track,
body.page-template-info .banner.info-banner .slick-track,
body.page-template-info .banner .slick-slide,
body.page-template-info .banner.info-banner .slick-slide {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
}

/* ============================================
   FAQ PAGE - INDEPENDENT CSS
   All styles scoped to body.page-template-faq
   This section ensures complete isolation from global styles
   ============================================ */

/* CRITICAL: Override ALL global banner styles FIRST */
body.page-template-faq .off-canvas-content .banner,
body.page-template-faq .content .banner,
body.page-template-faq .flex-content .banner,
body.page-template-faq .banner,
body.page-template-faq .banner.faq-banner {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
  margin-top: -20px !important;
}

body.page-template-faq .banner .slides,
body.page-template-faq .banner.faq-banner .slides,
body.page-template-faq .banner .slick-slider,
body.page-template-faq .banner.faq-banner .slick-slider {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
}

body.page-template-faq .banner .banner-item,
body.page-template-faq .banner.faq-banner .banner-item {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
  position: relative !important;
}

body.page-template-faq .banner picture,
body.page-template-faq .banner.faq-banner picture {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
  display: block !important;
}

body.page-template-faq .banner picture img,
body.page-template-faq .banner.faq-banner picture img {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
  width: 100% !important;
  object-fit: cover !important;
}

body.page-template-faq .content.flex-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

body.page-template-faq .off-canvas-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

body.page-template-faq .faq-banner .banner-overlay {
  top: 50% !important;
  transform: translateY(-50%) !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  z-index: 2 !important;
}

body.page-template-faq .faq-banner .banner-overlay .grid-x {
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 100% !important;
  margin: 0 !important;
}

body.page-template-faq .faq-banner .banner-item {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 500px !important;
}

body.page-template-faq .faq-banner .banner-overlay .overlay-content {
  margin: 0 auto !important;
}

body.page-template-faq .faq-banner .banner-overlay h1 {
  color: #fff !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  margin: 0 !important;
  text-align: center !important;
}

body.page-template-faq .faq-banner .banner-item {
  background: transparent !important;
  overflow: visible !important;
}

body.page-template-faq .faq-banner .banner-item::before {
  display: none !important;
}

/* FAQ page accordions styling */
body.page-template-faq .accordions {
  padding: 2rem 1rem;
  margin: 0 auto;
  max-width: 1200px;
  width: 100%;
}

body.page-template-faq .accordions .cell {
  width: 100%;
  padding: 0;
}

body.page-template-faq .accordion__mainTitle {
  font-size: 18px !important;
  font-weight: 600;
  margin-bottom: 2rem;
  margin-top: 0;
  color: #0a0a0a;
}

body.page-template-faq .accordions h3 {
  font-size: 18px !important;
  font-weight: 600;
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  color: #0a0a0a;
}

body.page-template-faq .accordions h3:first-of-type {
  margin-top: 0;
}

body.page-template-faq .accordions h3,
body.page-template-faq h3,
body.page-template-faq .accordion__mainTitle,
body.page-template-faq .accordions h3:not(.accordion__mainTitle) {
  font-size: 18px !important;
}

body.page-template-faq .accordion {
  margin-left: 0;
  margin-bottom: 2rem;
  background: #fefefe;
  list-style-type: none;
  border: 1px solid #e6e6e6;
}

body.page-template-faq .accordion-item {
  border-bottom: 1px solid #e6e6e6;
  transition: background-color 0.3s ease;
}

body.page-template-faq .accordion-item:last-child {
  border-bottom: none;
}

body.page-template-faq .accordion-item.is-active {
  background-color: #fefefe;
}

body.page-template-faq .accordion-title {
  position: relative;
  display: block;
  padding: 1.25rem 1rem;
  border: none;
  border-bottom: 1px solid #e6e6e6;
  font-size: 16px !important;
  line-height: 1.5;
  color: #e5347e !important;
  background: #fefefe;
  text-decoration: none;
  transition: background-color 0.3s ease;
}

body.page-template-faq .accordion-title,
body.page-template-faq .accordions .accordion-title,
body.page-template-faq .accordion .accordion-title,
body.page-template-faq .accordion-item .accordion-title,
body.page-template-faq .accordion-title:hover,
body.page-template-faq .accordion-title:focus,
body.page-template-faq .accordion-item.is-active > .accordion-title {
  font-size: 16px !important;
  color: #e5347e !important;
}

body.page-template-faq .accordion-item:last-child .accordion-title {
  border-bottom: none;
}

body.page-template-faq .accordion-title:hover,
body.page-template-faq .accordion-title:focus {
  background-color: #e6e6e6;
  color: #e5347e !important;
}

body.page-template-faq .accordion-title::before {
  position: absolute;
  top: 50%;
  right: 1rem;
  margin-top: -0.5rem;
  content: "+";
  font-size: 20px;
  font-weight: 300;
  color: #e5347e;
}

body.page-template-faq .accordion-item.is-active > .accordion-title::before {
  content: "–";
}

body.page-template-faq .accordion-content {
  display: none !important;
  padding: 1.5rem 1rem;
  border: none;
  border-bottom: 1px solid #e6e6e6;
  background-color: #fefefe;
  color: #0a0a0a;
  overflow: hidden;
}

body.page-template-faq .accordion-item.is-active > .accordion-content,
body.page-template-faq .accordion-content[aria-hidden="false"],
body.page-template-faq
  .accordion-item[aria-expanded="true"]
  > .accordion-content,
body.page-template-faq .accordion-item.is-active .accordion-content {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  padding: 1.5rem 1rem !important;
}

body.page-template-faq .accordion-item:last-child > .accordion-content {
  border-bottom: none;
}

body.page-template-faq .accordion-item.is-active {
  background-color: #fefefe;
}

body.page-template-faq .accordion-item.is-active > .accordion-title {
  background-color: #e6e6e6;
  border-bottom-color: #e6e6e6;
  color: #e5347e !important;
}

body.page-template-faq .accordion-content p {
  margin-bottom: 1rem;
  line-height: 1.6;
  font-size: 16px;
  color: #0a0a0a;
}

body.page-template-faq .accordion-content p:last-child {
  margin-bottom: 0;
}

body.page-template-faq .accordion-content ul.list-2 {
  margin-top: 0.5rem;
}

body.page-template-faq .accordion-content ul.list-2 {
  margin-left: 1.5rem;
  margin-bottom: 1rem;
  list-style-type: disc;
}

body.page-template-faq .accordion-content ul.list-2 li {
  margin-bottom: 0.5rem;
  line-height: 1.6;
  font-size: 16px;
}

body.page-template-faq .accordion-content em {
  font-style: italic;
}

body.page-template-faq .accordion-content a {
  color: #e5347e;
  text-decoration: underline;
}

body.page-template-faq .accordion-content a:hover {
  color: #d61b6a;
}

/* Media queries for FAQ page */
@media (max-width: 970px) {
  body.page-template-faq .banner,
  body.page-template-faq .banner.faq-banner,
  body.page-template-faq .banner *,
  body.page-template-faq .banner.faq-banner *,
  body.page-template-faq .banner img,
  body.page-template-faq .banner.faq-banner img,
  body.page-template-faq .banner .banner-item,
  body.page-template-faq .banner.faq-banner .banner-item {
    height: 500px !important;
    max-height: 500px !important;
    min-height: 500px !important;
  }
}

@media (max-width: 750px) {
  body.page-template-faq .faq-banner .banner-overlay h1 {
    font-size: 35px;
  }

  body.page-template-faq .accordion__mainTitle {
    font-size: 18px !important;
  }

  body.page-template-faq .accordions h3 {
    font-size: 18px !important;
  }

  body.page-template-faq h3,
  body.page-template-faq .accordions h3:not(.accordion__mainTitle) {
    font-size: 18px !important;
  }

  body.page-template-faq .accordion-title {
    font-size: 16px !important;
    color: #e5347e !important;
    padding: 1rem;
  }

  body.page-template-faq .accordion-content {
    padding: 0.875rem;
  }
}

@media (max-width: 640px) {
  body.page-template-faq .accordions {
    padding: 1.5rem 0.75rem;
  }

  body.page-template-faq .accordion-title {
    font-size: 16px !important;
    color: #e5347e !important;
    padding: 0.875rem 0.75rem;
  }

  body.page-template-faq .accordion-content {
    padding: 0.75rem;
  }

  body.page-template-faq .accordion-content p,
  body.page-template-faq .accordion-content ul.list-2 li {
    font-size: 15px;
  }
}

/* FINAL OVERRIDE - Must be at the END of FAQ page section */
body.page-template-faq .banner,
body.page-template-faq .banner.faq-banner,
body.page-template-faq .off-canvas-content .banner,
body.page-template-faq .content .banner,
body.page-template-faq .flex-content .banner {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
}

body.page-template-faq .banner img,
body.page-template-faq .banner.faq-banner img,
body.page-template-faq .banner picture,
body.page-template-faq .banner.faq-banner picture,
body.page-template-faq .banner picture img,
body.page-template-faq .banner.faq-banner picture img {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
}

body.page-template-faq .banner .banner-item,
body.page-template-faq .banner.faq-banner .banner-item,
body.page-template-faq .banner .slides,
body.page-template-faq .banner.faq-banner .slides,
body.page-template-faq .banner .slick-slider,
body.page-template-faq .banner.faq-banner .slick-slider,
body.page-template-faq .banner .slick-list,
body.page-template-faq .banner.faq-banner .slick-list,
body.page-template-faq .banner .slick-track,
body.page-template-faq .banner.faq-banner .slick-track,
body.page-template-faq .banner .slick-slide,
body.page-template-faq .banner.faq-banner .slick-slide {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
}

/* ============================================
   COOKIE POLICY PAGE - INDEPENDENT CSS
   All styles scoped to body.page-template-cookie-policy
   This section ensures complete isolation from global styles
   ============================================ */

/* CRITICAL: Override ALL global banner styles FIRST */
body.page-template-cookie-policy .off-canvas-content .banner,
body.page-template-cookie-policy .content .banner,
body.page-template-cookie-policy .flex-content .banner,
body.page-template-cookie-policy .banner,
body.page-template-cookie-policy .banner.cookie-policy-banner {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
  margin-top: -20px !important;
}

body.page-template-cookie-policy .banner .slides,
body.page-template-cookie-policy .banner.cookie-policy-banner .slides,
body.page-template-cookie-policy .banner .slick-slider,
body.page-template-cookie-policy .banner.cookie-policy-banner .slick-slider {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
}

body.page-template-cookie-policy .banner .banner-item,
body.page-template-cookie-policy .banner.cookie-policy-banner .banner-item {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
  position: relative !important;
}

body.page-template-cookie-policy .banner picture,
body.page-template-cookie-policy .banner.cookie-policy-banner picture {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
  display: block !important;
}

body.page-template-cookie-policy .banner picture img,
body.page-template-cookie-policy .banner.cookie-policy-banner picture img {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
  width: 100% !important;
  object-fit: cover !important;
}

body.page-template-cookie-policy .content.flex-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

body.page-template-cookie-policy .off-canvas-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

body.page-template-cookie-policy .cookie-policy-banner .banner-overlay {
  top: 50% !important;
  transform: translateY(-50%) !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  z-index: 2 !important;
}

body.page-template-cookie-policy .cookie-policy-banner .banner-overlay .grid-x {
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 100% !important;
  margin: 0 !important;
}

body.page-template-cookie-policy .cookie-policy-banner .banner-item {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 500px !important;
}

body.page-template-cookie-policy
  .cookie-policy-banner
  .banner-overlay
  .overlay-content {
  margin: 0 auto !important;
}

body.page-template-cookie-policy .cookie-policy-banner .banner-overlay h2 {
  color: #fff !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  margin: 0 !important;
  text-align: center !important;
}

body.page-template-cookie-policy .cookie-policy-banner .banner-item {
  background: transparent !important;
  overflow: visible !important;
}

body.page-template-cookie-policy .cookie-policy-banner .banner-item::before {
  display: none !important;
}

/* Cookie Policy page content styling */
body.page-template-cookie-policy .grid-x.grid-padding-x.grid-padding-y {
  padding-top: 2rem;
  padding-bottom: 2rem;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

body.page-template-cookie-policy .grid-x.grid-padding-x .cell {
  padding-left: 1rem;
  padding-right: 1rem;
}

body.page-template-cookie-policy .grid-x.grid-padding-x.grid-padding-y .cell p {
  font-size: 16px;
  line-height: 1.6;
  margin-bottom: 1rem;
  color: #0a0a0a;
}

body.page-template-cookie-policy
  .grid-x.grid-padding-x.grid-padding-y
  .cell
  p
  strong {
  font-weight: 600;
  font-size: 16px;
}

/* Cookie Policy page accordions styling */
body.page-template-cookie-policy .accordions {
  padding: 2rem 1rem;
  margin: 0 auto;
  max-width: 1200px;
  width: 100%;
}

body.page-template-cookie-policy .accordions .cell {
  width: 100%;
  padding: 0;
}

body.page-template-cookie-policy .accordion__mainTitle {
  font-size: 18px !important;
  font-weight: 600;
  margin-bottom: 2rem;
  margin-top: 0;
  color: #0a0a0a;
}

body.page-template-cookie-policy .accordions h3 {
  font-size: 18px !important;
  font-weight: 600;
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  color: #0a0a0a;
}

body.page-template-cookie-policy .accordions h3:first-of-type {
  margin-top: 0;
}

body.page-template-cookie-policy .accordions h3,
body.page-template-cookie-policy h3,
body.page-template-cookie-policy .accordion__mainTitle,
body.page-template-cookie-policy .accordions h3:not(.accordion__mainTitle) {
  font-size: 18px !important;
}

body.page-template-cookie-policy .accordion {
  margin-left: 0;
  margin-bottom: 2rem;
  background: #fefefe;
  list-style-type: none;
  border: 1px solid #e6e6e6;
}

body.page-template-cookie-policy .accordion-item {
  border-bottom: 1px solid #e6e6e6;
  transition: background-color 0.3s ease;
}

body.page-template-cookie-policy .accordion-item:last-child {
  border-bottom: none;
}

body.page-template-cookie-policy .accordion-item.is-active {
  background-color: #fefefe;
}

body.page-template-cookie-policy .accordion-title {
  position: relative;
  display: block;
  padding: 1.25rem 1rem;
  border: none;
  border-bottom: 1px solid #e6e6e6;
  font-size: 16px !important;
  line-height: 1.5;
  color: #e5347e !important;
  background: #fefefe;
  text-decoration: none;
  transition: background-color 0.3s ease;
}

body.page-template-cookie-policy .accordion-title,
body.page-template-cookie-policy .accordions .accordion-title,
body.page-template-cookie-policy .accordion .accordion-title,
body.page-template-cookie-policy .accordion-item .accordion-title,
body.page-template-cookie-policy .accordion-title:hover,
body.page-template-cookie-policy .accordion-title:focus,
body.page-template-cookie-policy .accordion-item.is-active > .accordion-title {
  font-size: 16px !important;
  color: #e5347e !important;
}

body.page-template-cookie-policy .accordion-item:last-child .accordion-title {
  border-bottom: none;
}

body.page-template-cookie-policy .accordion-title:hover,
body.page-template-cookie-policy .accordion-title:focus {
  background-color: #e6e6e6;
  color: #e5347e !important;
}

body.page-template-cookie-policy .accordion-title::before {
  position: absolute;
  top: 50%;
  right: 1rem;
  margin-top: -0.5rem;
  content: "+";
  font-size: 20px;
  font-weight: 300;
  color: #e5347e;
}

body.page-template-cookie-policy
  .accordion-item.is-active
  > .accordion-title::before {
  content: "–";
}

body.page-template-cookie-policy .accordion-content {
  display: none !important;
  padding: 1.5rem 1rem;
  border: none;
  border-bottom: 1px solid #e6e6e6;
  background-color: #fefefe;
  color: #0a0a0a;
  overflow: hidden;
}

body.page-template-cookie-policy .accordion-item.is-active > .accordion-content,
body.page-template-cookie-policy .accordion-content[aria-hidden="false"],
body.page-template-cookie-policy
  .accordion-item[aria-expanded="true"]
  > .accordion-content,
body.page-template-cookie-policy .accordion-item.is-active .accordion-content {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  padding: 1.5rem 1rem !important;
}

body.page-template-cookie-policy
  .accordion-item:last-child
  > .accordion-content {
  border-bottom: none;
}

body.page-template-cookie-policy .accordion-item.is-active {
  background-color: #fefefe;
}

body.page-template-cookie-policy .accordion-item.is-active > .accordion-title {
  background-color: #e6e6e6;
  border-bottom-color: #e6e6e6;
  color: #e5347e !important;
}

body.page-template-cookie-policy .accordion-content p {
  margin-bottom: 1rem;
  line-height: 1.6;
  font-size: 16px;
  color: #0a0a0a;
}

body.page-template-cookie-policy .accordion-content p:last-child {
  margin-bottom: 0;
}

body.page-template-cookie-policy .accordion-content h3 {
  font-size: 18px !important;
  font-weight: 600;
  margin-top: 1.5rem;
  margin-bottom: 0.75rem;
  color: #0a0a0a;
}

body.page-template-cookie-policy .accordion-content h3:first-of-type {
  margin-top: 0;
}

body.page-template-cookie-policy .accordion-content a {
  color: #e5347e;
  text-decoration: underline;
}

body.page-template-cookie-policy .accordion-content a:hover {
  color: #d61b6a;
}

body.page-template-cookie-policy .accordion-content strong {
  font-weight: 600;
  font-size: 16px;
}

/* Responsive adjustments for Cookie Policy page */
@media (max-width: 1024px) {
  body.page-template-cookie-policy .grid-x.grid-padding-x.grid-padding-y {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  body.page-template-cookie-policy .accordions {
    padding: 2rem 1rem;
  }
}

@media (max-width: 750px) {
  body.page-template-cookie-policy .cookie-policy-banner .banner-overlay h2 {
    font-size: 35px;
  }

  body.page-template-cookie-policy .accordions h3 {
    font-size: 18px !important;
  }

  body.page-template-cookie-policy .accordion-title {
    font-size: 16px !important;
  }

  body.page-template-cookie-policy .accordion-content p {
    font-size: 16px;
  }
}

@media (max-width: 640px) {
  body.page-template-cookie-policy .grid-x.grid-padding-x.grid-padding-y {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  body.page-template-cookie-policy .accordions {
    padding: 1.5rem 0.5rem;
  }

  body.page-template-cookie-policy .accordion-title {
    padding: 1rem 0.75rem;
    font-size: 16px !important;
  }

  body.page-template-cookie-policy .accordion-content {
    padding: 1rem 0.75rem !important;
  }

  body.page-template-cookie-policy .accordion-content p {
    font-size: 16px;
  }
}

/* FINAL OVERRIDE - Must be at the END of Cookie Policy page section */
body.page-template-cookie-policy .banner,
body.page-template-cookie-policy .banner.cookie-policy-banner,
body.page-template-cookie-policy .off-canvas-content .banner,
body.page-template-cookie-policy .content .banner,
body.page-template-cookie-policy .flex-content .banner {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
}

body.page-template-cookie-policy .banner img,
body.page-template-cookie-policy .banner.cookie-policy-banner img,
body.page-template-cookie-policy .banner picture,
body.page-template-cookie-policy .banner.cookie-policy-banner picture,
body.page-template-cookie-policy .banner picture img,
body.page-template-cookie-policy .banner.cookie-policy-banner picture img {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
}

body.page-template-cookie-policy .banner .banner-item,
body.page-template-cookie-policy .banner.cookie-policy-banner .banner-item,
body.page-template-cookie-policy .banner .slides,
body.page-template-cookie-policy .banner.cookie-policy-banner .slides,
body.page-template-cookie-policy .banner .slick-slider,
body.page-template-cookie-policy .banner.cookie-policy-banner .slick-slider,
body.page-template-cookie-policy .banner .slick-list,
body.page-template-cookie-policy .banner.cookie-policy-banner .slick-list,
body.page-template-cookie-policy .banner .slick-track,
body.page-template-cookie-policy .banner.cookie-policy-banner .slick-track,
body.page-template-cookie-policy .banner .slick-slide,
body.page-template-cookie-policy .banner.cookie-policy-banner .slick-slide {
  height: 500px !important;
  max-height: 500px !important;
  min-height: 500px !important;
}

/* Suppress missing font warnings */
@font-face {
  font-family: "Font Awesome 5 Brands";
  src: url("data:font/woff2;base64,") format("woff2");
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: "slick";
  src: url("data:font/woff;base64,") format("woff");
  font-weight: normal;
  font-style: normal;
}

/* Services Page Styling */
.services-banner-wrapper .banner,
.page-template-services .banner,
body.page-template-services .banner {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.services-banner-wrapper .banner img,
.services-banner-wrapper .banner picture,
.services-banner-wrapper .banner .banner-item,
.page-template-services .banner img,
.page-template-services .banner picture,
.page-template-services .banner .banner-item {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
  object-fit: cover;
}

.services-banner-wrapper .banner .banner-overlay,
.page-template-services .banner .banner-overlay {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  width: 100%;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
}

.services-banner-wrapper .banner .banner-overlay h1,
.services-banner-wrapper .banner .banner-overlay h2,
.page-template-services .banner .banner-overlay h1,
.page-template-services .banner .banner-overlay h2 {
  color: #fff;
  font-size: 40px;
  font-weight: 500;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  margin: 0;
  padding: 0;
}

@media (max-width: 750px) {
  .services-banner-wrapper .banner .banner-overlay h1,
  .services-banner-wrapper .banner .banner-overlay h2,
  .page-template-services .banner .banner-overlay h1,
  .page-template-services .banner .banner-overlay h2 {
    font-size: 35px;
  }
}

.page-template-services .grid-padding-x,
.page-template-services .grid-padding-y {
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.page-template-services .gap {
  margin-bottom: 2rem;
}

.page-template-services .tabs {
  margin: 0;
  border: 1px solid #e6e6e6;
  background: #fefefe;
  list-style-type: none;
  display: flex;
  flex-wrap: wrap;
}

.page-template-services .tabs-title {
  float: left;
  margin: 0;
}

.page-template-services .tabs .tabs-title > a,
.page-template-services ul.tabs .tabs-title > a,
.page-template-services .tabs-title > a {
  font-size: 16px !important;
}

.page-template-services .tabs-title > a {
  display: block;
  padding: 1.25rem 1.5rem;
  font-size: 16px !important;
  line-height: 1;
  color: #e5347e;
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: all 0.3s ease;
}

.page-template-services .tabs-title > a:hover {
  background: #fefefe;
  color: #d61b6a;
}

.page-template-services .tabs-title > a:focus,
.page-template-services .tabs-title > a[aria-selected="true"] {
  background: #e6e6e6;
  color: #e5347e;
  border-bottom-color: #e5347e;
}

.page-template-services .tabs-title.is-active > a {
  background: #e6e6e6;
  color: #e5347e;
  border-bottom-color: #e5347e;
}

.page-template-services .tabs-content {
  border: 1px solid #e6e6e6;
  border-top: 0;
  background: #fefefe;
  color: #0a0a0a;
  padding: 0;
}

.page-template-services .tabs-panel {
  display: none;
  padding: 2rem;
}

.page-template-services .tabs-panel.is-active {
  display: block;
}

.page-template-services .tabs-panel img {
  max-width: 100%;
  height: auto;
  margin-bottom: 1.5rem;
}

.page-template-services .tabs-panel p {
  margin-bottom: 1rem;
  line-height: 1.6;
  font-size: 16px;
}

.page-template-services .tabs-panel ul {
  margin-left: 1.5rem;
  margin-bottom: 1rem;
}

.page-template-services .tabs-panel ul li {
  margin-bottom: 0.5rem;
  line-height: 1.6;
}

.page-template-services .tabs-panel a {
  color: #e5347e;
  text-decoration: underline;
}

.page-template-services .tabs-panel a:hover {
  color: #d61b6a;
}

@media (max-width: 1024px) {
  .page-template-services .tabs {
    flex-direction: column;
  }

  .page-template-services .tabs-title {
    float: none;
    width: 100%;
    border-bottom: 1px solid #e6e6e6;
  }

  .page-template-services .tabs-title:last-child {
    border-bottom: none;
  }

  .page-template-services .tabs-title > a {
    padding: 1rem 1.5rem;
    font-size: 16px !important;
  }

  .page-template-services .tabs .tabs-title > a {
    font-size: 16px !important;
  }

  .page-template-services .tabs-content {
    border-top: 1px solid #e6e6e6;
  }

  .page-template-services .tabs .tabs-title > a {
    font-size: 16px !important;
  }
}

/* Force services tabs font size - highest priority at end of file */
body.page-template-services .tabs-title > a,
body.page-template-services ul.tabs .tabs-title > a,
body.page-template-services .tabs .tabs-title > a,
body.page-template-services .tabs-title.is-active > a,
body.page-template-services .tabs-title > a[aria-selected="true"] {
  font-size: 16px !important;
}

/* Travel Guide Page Styling */
.travel-guide-banner-wrapper,
.page-template-travel-guide .banner,
body.page-template-travel-guide .banner {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.travel-guide-banner-wrapper .banner img,
.travel-guide-banner-wrapper .banner picture,
.travel-guide-banner-wrapper .banner .banner-item,
.page-template-travel-guide .banner img,
.page-template-travel-guide .banner picture,
.page-template-travel-guide .banner .banner-item {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
  object-fit: cover;
}

.travel-guide-banner-wrapper .banner .banner-overlay,
.page-template-travel-guide .banner .banner-overlay {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  width: 100%;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
}

.travel-guide-banner-wrapper .banner .banner-overlay h2,
.page-template-travel-guide .banner .banner-overlay h2 {
  color: #fff;
  font-size: 40px;
  font-weight: 500;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  margin: 0;
  padding: 0;
}

@media (max-width: 750px) {
  .travel-guide-banner-wrapper .banner .banner-overlay h2,
  .page-template-travel-guide .banner .banner-overlay h2 {
    font-size: 35px;
  }
}

.travel-guide-banner-wrapper,
.page-template-travel-guide .travel-guide-banner-wrapper {
  position: relative;
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Travel Guide Blog Section Styling */
.page-template-travel-guide #blog-4 {
  margin-top: 0;
  padding: 5em 0;
  background: #f5f5f5;
}

.page-template-travel-guide #blog-4 .title {
  margin-bottom: 1em;
  padding-left: 10px;
}

.page-template-travel-guide #blog-4 .title h2 {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
  font-weight: 600 !important;
  margin-bottom: 0.5em;
}

.page-template-travel-guide #blog-4 .title p {
  color: #000 !important;
  font-size: 16px;
  line-height: 1.6;
}

.page-template-travel-guide #blog-4 .large-3 {
  padding: 10px;
}

.page-template-travel-guide #blog-4 .large-3 img {
  width: 100%;
  height: 30vh;
  object-fit: cover;
}

.page-template-travel-guide #blog-4 .blog-text {
  background: #fff;
  padding: 20px;
}

.page-template-travel-guide #blog-4 .blog-text h2 {
  margin: 0;
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
}

.page-template-travel-guide #blog-4 .blog-text h2 a {
  color: inherit;
  text-decoration: none;
  transition: color 0.3s ease;
}

.page-template-travel-guide #blog-4 .blog-text h2 a:hover {
  color: #009fe3;
}

/* Force travel guide title styles - highest priority */
body.page-template-travel-guide #blog-4 .title h2,
body.page-template-travel-guide section#blog-4 .title h2,
.travel-guide-banner-wrapper ~ .content #blog-4 .title h2,
section#blog-4 .title h2 {
  font-weight: 600 !important;
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
}

body.page-template-travel-guide #blog-4 .title p,
body.page-template-travel-guide section#blog-4 .title p,
.travel-guide-banner-wrapper ~ .content #blog-4 .title p,
section#blog-4 .title p {
  color: #000 !important;
  font-size: 16px !important;
}

/* Additional override for travel guide page - target by URL pattern */
body:has(.travel-guide-banner-wrapper) #blog-4 .title h2 {
  font-weight: 600 !important;
}

body:has(.travel-guide-banner-wrapper) #blog-4 .title p {
  color: #000 !important;
}

/* Holiday Resorts Page Styling */
.holiday-resorts-banner-wrapper {
  margin-top: 0 !important;
  padding-top: 0 !important;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

.page-template-holiday-resorts .content,
.holiday-resorts-banner-wrapper ~ .content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

.page-template-holiday-resorts .button-list,
.holiday-resorts-banner-wrapper ~ .content .button-list {
  margin-top: 0 !important;
  padding-top: 0 !important;
  margin-bottom: 0 !important;
}

.page-template-holiday-resorts .button-list ~ .grid-x,
.holiday-resorts-banner-wrapper ~ .content .button-list ~ .grid-x,
.page-template-holiday-resorts .content .grid-padding-x,
.page-template-holiday-resorts .content .gap {
  margin-top: 3em !important;
}

.page-template-holiday-resorts .page-header ~ div,
.page-template-holiday-resorts .page-header + div {
  margin-top: 1.5em !important;
}

.holiday-resorts-banner-wrapper .banner,
.page-template-holiday-resorts .banner,
body.page-template-holiday-resorts .banner {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

.holiday-resorts-banner-wrapper .banner img,
.holiday-resorts-banner-wrapper .banner picture,
.holiday-resorts-banner-wrapper .banner .banner-item,
.holiday-resorts-banner-wrapper .banner .slides,
.holiday-resorts-banner-wrapper .banner .slick-slider,
.holiday-resorts-banner-wrapper .banner .slick-list,
.holiday-resorts-banner-wrapper .banner .slick-track,
.holiday-resorts-banner-wrapper .banner .slick-slide {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

.page-template-holiday-resorts .banner img,
.page-template-holiday-resorts .banner picture,
.page-template-holiday-resorts .banner .banner-item,
.page-template-holiday-resorts .banner .slides,
.page-template-holiday-resorts .banner .slick-slider,
.page-template-holiday-resorts .banner .slick-list,
.page-template-holiday-resorts .banner .slick-track,
.page-template-holiday-resorts .banner .slick-slide {
  height: 480px !important;
  max-height: 480px !important;
  min-height: 480px !important;
}

.page-template-holiday-resorts .banner .banner-overlay {
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
}

.page-template-holiday-resorts .banner .banner-overlay .overlay-content h1 {
  color: #fff;
  font-size: 24px;
  font-weight: 600;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  text-align: center;
}

@media (max-width: 768px) {
  .page-template-holiday-resorts .banner .banner-overlay .overlay-content h1 {
    font-size: 24px;
  }
}

.page-template-holiday-resorts .page-header h2,
.page-template-holiday-resorts .grid-padding-x .page-header h2,
.page-template-holiday-resorts .grid-padding-y .page-header h2,
.page-template-holiday-resorts .gap .page-header h2,
.page-template-holiday-resorts .content .page-header h2,
.holiday-resorts-banner-wrapper ~ .content .page-header h2,
body.page-template-holiday-resorts .page-header h2,
body.page-template-holiday-resorts .grid-padding-x .page-header h2,
body.page-template-holiday-resorts .grid-padding-y .page-header h2,
body.page-template-holiday-resorts .gap .page-header h2,
body.page-template-holiday-resorts .content .page-header h2 {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
  font-weight: 600 !important;
  margin-bottom: 1em;
}

.page-template-holiday-resorts #blog {
  margin-top: 0;
  padding: 5em 0;
}

.page-template-holiday-resorts #blog .title h2 {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
  font-weight: 600 !important;
}

.page-template-holiday-resorts #blog .blog-slider .medium-4 img {
  width: 100%;
  height: 30vh;
  object-fit: cover;
}

.page-template-holiday-resorts
  #blog
  .blog-slider
  .medium-4
  .blog-text
  .page-header
  h2 {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
  font-weight: 600 !important;
  margin-bottom: 0.5em;
}

.page-template-holiday-resorts #blog .blog-slider .medium-4 .blog-text a {
  background-color: #009fe3;
  color: #fff;
  padding: 10px 45px;
  display: inline-block;
  transition: 0.35s;
  border-radius: 3px;
  text-decoration: none;
  margin-top: 1em;
}

.page-template-holiday-resorts #blog .blog-slider .medium-4 .blog-text a:hover {
  background-color: #00b1fd;
}

/* Holiday Guide Page Styling */
.page-template-holiday-guide .content,
body.page-template-holiday-guide .content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

.page-template-holiday-guide .page-header h1,
.page-template-holiday-guide .grid-padding-x .page-header h1,
.page-template-holiday-guide .grid-padding-y .page-header h1,
.page-template-holiday-guide .gap .page-header h1,
.page-template-holiday-guide .content .page-header h1,
body.page-template-holiday-guide .page-header h1,
body.page-template-holiday-guide .grid-padding-x .page-header h1,
body.page-template-holiday-guide .grid-padding-y .page-header h1,
body.page-template-holiday-guide .gap .page-header h1,
body.page-template-holiday-guide .content .page-header h1,
.page-template-holiday-guide .grid-x .page-header h1,
body.page-template-holiday-guide .grid-x .page-header h1 {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
  font-weight: 600 !important;
  margin-bottom: 1em;
}

/* Override any general h1 rules for holiday guide page */
.page-template-holiday-guide h1,
body.page-template-holiday-guide h1 {
  font-size: 24px !important;
}

.page-template-holiday-guide .page-header h1,
body.page-template-holiday-guide .page-header h1 {
  font-size: 24px !important;
}

.page-template-holiday-guide .page-header ~ div,
.page-template-holiday-guide .page-header + div {
  margin-top: 1.5em !important;
}

.page-template-holiday-guide .page-header ~ h2 img,
.page-template-holiday-guide .page-header + h2 img {
  width: 100%;
  height: auto;
  display: block;
  margin: 2em 0;
}

/* Holiday Guide Tabs - Force 16px font size with maximum specificity */
.page-template-holiday-guide .tabs-title > a,
body.page-template-holiday-guide .tabs-title > a,
.page-template-holiday-guide ul.tabs .tabs-title > a,
.page-template-holiday-guide .tabs .tabs-title > a,
body.page-template-holiday-guide .tabs .tabs-title > a,
body.page-template-holiday-guide ul.tabs .tabs-title > a,
.page-template-holiday-guide .tabs-title.is-active > a,
.page-template-holiday-guide .tabs-title > a[aria-selected="true"],
body.page-template-holiday-guide .tabs-title.is-active > a,
body.page-template-holiday-guide .tabs-title > a[aria-selected="true"],
.page-template-holiday-guide ul.tabs li.tabs-title > a,
body.page-template-holiday-guide ul.tabs li.tabs-title > a,
.page-template-holiday-guide .tabs li.tabs-title > a,
body.page-template-holiday-guide .tabs li.tabs-title > a,
.page-template-holiday-guide .grid-x .tabs .tabs-title > a,
body.page-template-holiday-guide .grid-x .tabs .tabs-title > a,
.page-template-holiday-guide .content .tabs .tabs-title > a,
body.page-template-holiday-guide .content .tabs .tabs-title > a {
  font-size: 16px !important;
  font-family: "Barlow", sans-serif !important;
  color: #e5347e !important;
}

@media (max-width: 1024px) {
  .page-template-holiday-guide .tabs .tabs-title > a,
  body.page-template-holiday-guide .tabs .tabs-title > a {
    font-size: 16px !important;
    color: #e5347e !important;
  }
}

@media (max-width: 768px) {
  .page-template-holiday-guide .tabs .tabs-title > a,
  body.page-template-holiday-guide .tabs .tabs-title > a {
    font-size: 16px !important;
    color: #e5347e !important;
  }
}

/* Universal override for all tabs on holiday-guide page - highest priority */
body.page-template-holiday-guide .tabs-title a,
body.page-template-holiday-guide ul.tabs li.tabs-title a,
body.page-template-holiday-guide .tabs li.tabs-title a {
  font-size: 16px !important;
  font-family: "Barlow", sans-serif !important;
  color: #e5347e !important;
}

/* Even more specific - target by ID if present */
body.page-template-holiday-guide #holiday-guide-tabs .tabs-title > a,
body.page-template-holiday-guide [id*="holiday-guide"] .tabs-title > a {
  font-size: 16px !important;
  font-family: "Barlow", sans-serif !important;
  color: #e5347e !important;
}

.page-template-holiday-guide .tabs-content .tabs-panel h3,
body.page-template-holiday-guide .tabs-content .tabs-panel h3 {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
  font-weight: 600 !important;
  margin-bottom: 1em;
}

.page-template-holiday-guide .tabs-content .tabs-panel p,
body.page-template-holiday-guide .tabs-content .tabs-panel p {
  font-family: "Barlow", sans-serif !important;
  line-height: 1.6;
  margin-bottom: 1em;
}

/* Material Icons styling for homepage sections */
#inspiration .title .material-icons,
#things .title .material-icons,
#testimonials .title .material-icons {
  font-family: "Material Icons" !important;
  font-size: 24px;
  vertical-align: middle;
  margin-right: 5px;
}

#properties .property .details .stars .material-icons {
  font-family: "Material Icons" !important;
  font-size: 16px;
  color: #efe057;
}

#properties .property .details .sleeps .material-icons,
#properties .property .details .location .material-icons {
  font-family: "Material Icons" !important;
  font-size: 16px;
  vertical-align: middle;
  margin-right: 5px;
}
#properties .property .details .location .material-icons {
  color: #e5347e;
}

#blog .blog-section .blog-text .dates .material-icons,
#blog-4 .blog-section .blog-text .dates .material-icons {
  font-family: "Material Icons" !important;
  font-size: 16px;
  vertical-align: middle;
  margin-right: 5px;
}

#testimonials .reviews .location .material-icons {
  font-family: "Material Icons" !important;
  font-size: 16px;
  vertical-align: middle;
  margin-right: 5px;
}

/* Places To Visit Page Styling */
.page-template-places-to-visit .content,
body.page-template-places-to-visit .content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* Places To Visit - Main h2 heading (24px) - Maximum specificity */
.page-template-places-to-visit .page-header h2:nth-of-type(2),
.page-template-places-to-visit .page-header h2:not(:first-of-type),
body.page-template-places-to-visit .page-header h2:nth-of-type(2),
body.page-template-places-to-visit .page-header h2:not(:first-of-type),
.page-template-places-to-visit .grid-padding-x .page-header h2:nth-of-type(2),
.page-template-places-to-visit
  .grid-padding-x
  .page-header
  h2:not(:first-of-type),
.page-template-places-to-visit .grid-padding-y .page-header h2:nth-of-type(2),
.page-template-places-to-visit
  .grid-padding-y
  .page-header
  h2:not(:first-of-type),
.page-template-places-to-visit .gap .page-header h2:nth-of-type(2),
.page-template-places-to-visit .gap .page-header h2:not(:first-of-type),
.page-template-places-to-visit .content .page-header h2:nth-of-type(2),
.page-template-places-to-visit .content .page-header h2:not(:first-of-type),
body.page-template-places-to-visit
  .grid-padding-x
  .page-header
  h2:nth-of-type(2),
body.page-template-places-to-visit
  .grid-padding-x
  .page-header
  h2:not(:first-of-type),
body.page-template-places-to-visit
  .grid-padding-y
  .page-header
  h2:nth-of-type(2),
body.page-template-places-to-visit
  .grid-padding-y
  .page-header
  h2:not(:first-of-type),
body.page-template-places-to-visit .gap .page-header h2:nth-of-type(2),
body.page-template-places-to-visit .gap .page-header h2:not(:first-of-type),
body.page-template-places-to-visit .content .page-header h2:nth-of-type(2),
body.page-template-places-to-visit .content .page-header h2:not(:first-of-type),
.page-template-places-to-visit .grid-x .page-header h2:nth-of-type(2),
.page-template-places-to-visit .grid-x .page-header h2:not(:first-of-type),
body.page-template-places-to-visit .grid-x .page-header h2:nth-of-type(2),
body.page-template-places-to-visit .grid-x .page-header h2:not(:first-of-type) {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
  font-weight: 600 !important;
  margin-bottom: 1em;
}

.page-template-places-to-visit .page-header h2:first-of-type {
  font-size: 0 !important;
  margin: 0;
  padding: 0;
  line-height: 0;
}

.page-template-places-to-visit .page-header h2:first-of-type img {
  width: 100%;
  height: auto;
  display: block;
}

.page-template-places-to-visit .page-header ~ div,
.page-template-places-to-visit .page-header + div {
  margin-top: 1.5em !important;
}

/* Places To Visit Tabs Titles - 16px font size with maximum specificity */
.page-template-places-to-visit .tabs-title > a,
body.page-template-places-to-visit .tabs-title > a,
.page-template-places-to-visit ul.tabs .tabs-title > a,
.page-template-places-to-visit .tabs .tabs-title > a,
body.page-template-places-to-visit .tabs .tabs-title > a,
body.page-template-places-to-visit ul.tabs .tabs-title > a,
.page-template-places-to-visit .tabs-title.is-active > a,
.page-template-places-to-visit .tabs-title > a[aria-selected="true"],
body.page-template-places-to-visit .tabs-title.is-active > a,
body.page-template-places-to-visit .tabs-title > a[aria-selected="true"],
.page-template-places-to-visit ul.tabs li.tabs-title > a,
body.page-template-places-to-visit ul.tabs li.tabs-title > a,
.page-template-places-to-visit .tabs li.tabs-title > a,
body.page-template-places-to-visit .tabs li.tabs-title > a,
.page-template-places-to-visit .grid-x .tabs .tabs-title > a,
body.page-template-places-to-visit .grid-x .tabs .tabs-title > a,
.page-template-places-to-visit .content .tabs .tabs-title > a,
body.page-template-places-to-visit .content .tabs .tabs-title > a,
#places-to-visit-tabs .tabs-title > a,
#places-to-visit-tabs .tabs-title.is-active > a,
#places-to-visit-tabs .tabs-title > a[aria-selected="true"] {
  font-size: 16px !important;
  font-family: "Barlow", sans-serif !important;
}

/* Places To Visit Tabs - h3 headings inside tabs content (18px) - Maximum specificity */
.page-template-places-to-visit .tabs-content .tabs-panel h3,
body.page-template-places-to-visit .tabs-content .tabs-panel h3,
.page-template-places-to-visit .tabs-panel h3,
body.page-template-places-to-visit .tabs-panel h3,
.page-template-places-to-visit .tabs-content .tabs-panel h3.uk-h1,
body.page-template-places-to-visit .tabs-content .tabs-panel h3.uk-h1,
.page-template-places-to-visit
  .tabs-content
  .tabs-panel
  h3.uk-h1.uk-margin-top-remove,
body.page-template-places-to-visit
  .tabs-content
  .tabs-panel
  h3.uk-h1.uk-margin-top-remove,
.page-template-places-to-visit
  #places-to-visit-tabs
  ~ .tabs-content
  .tabs-panel
  h3,
body.page-template-places-to-visit
  #places-to-visit-tabs
  ~ .tabs-content
  .tabs-panel
  h3,
.page-template-places-to-visit
  [data-tabs-content="places-to-visit-tabs"]
  .tabs-panel
  h3,
body.page-template-places-to-visit
  [data-tabs-content="places-to-visit-tabs"]
  .tabs-panel
  h3,
/* Override Foundation and UIKit classes */
.page-template-places-to-visit .tabs-content .tabs-panel h3.h3,
body.page-template-places-to-visit .tabs-content .tabs-panel h3.h3,
.page-template-places-to-visit .tabs-panel h3.h3,
body.page-template-places-to-visit .tabs-panel h3.h3,
.page-template-places-to-visit .tabs-content .tabs-panel h3.uk-h1.h3,
body.page-template-places-to-visit .tabs-content .tabs-panel h3.uk-h1.h3 {
  font-family: "Barlow", sans-serif !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  margin-bottom: 1em;
  margin-top: 0;
  line-height: 1.4 !important;
}

/* Override Foundation media query for h2 (40px -> 24px) */
@media print, screen and (min-width: 46.875em) {
  .page-template-places-to-visit .page-header h2:nth-of-type(2),
  .page-template-places-to-visit .page-header h2:not(:first-of-type),
  body.page-template-places-to-visit .page-header h2:nth-of-type(2),
  body.page-template-places-to-visit .page-header h2:not(:first-of-type),
  .page-template-places-to-visit .page-header h2.h2,
  body.page-template-places-to-visit .page-header h2.h2 {
    font-size: 24px !important;
  }

  .page-template-places-to-visit .tabs-content .tabs-panel h3,
  body.page-template-places-to-visit .tabs-content .tabs-panel h3,
  .page-template-places-to-visit .tabs-panel h3,
  body.page-template-places-to-visit .tabs-panel h3,
  .page-template-places-to-visit .tabs-content .tabs-panel h3.h3,
  body.page-template-places-to-visit .tabs-content .tabs-panel h3.h3,
  .page-template-places-to-visit .tabs-panel h3.h3,
  body.page-template-places-to-visit .tabs-panel h3.h3,
  .page-template-places-to-visit .tabs-content .tabs-panel h3.uk-h1,
  body.page-template-places-to-visit .tabs-content .tabs-panel h3.uk-h1 {
    font-size: 18px !important;
  }
}

.page-template-places-to-visit .tabs-content .tabs-panel p,
body.page-template-places-to-visit .tabs-content .tabs-panel p {
  font-family: "Barlow", sans-serif !important;
  line-height: 1.6;
  margin-bottom: 1em;
}

@media (max-width: 1024px) {
  .page-template-places-to-visit .tabs .tabs-title > a,
  body.page-template-places-to-visit .tabs .tabs-title > a {
    font-size: 16px !important;
  }
}

@media (max-width: 768px) {
  .page-template-places-to-visit .tabs .tabs-title > a,
  body.page-template-places-to-visit .tabs .tabs-title > a {
    font-size: 16px !important;
  }
}

/* Things To Do Page Styling */
.page-template-things-to-do .content,
body.page-template-things-to-do .content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* Things To Do - Main h2 heading (24px) - Maximum specificity */
.page-template-things-to-do .page-header h2:nth-of-type(3),
.page-template-things-to-do
  .page-header
  h2:not(:first-of-type):not(:nth-of-type(2)),
body.page-template-things-to-do .page-header h2:nth-of-type(3),
body.page-template-things-to-do
  .page-header
  h2:not(:first-of-type):not(:nth-of-type(2)),
.page-template-things-to-do .grid-padding-x .page-header h2:nth-of-type(3),
.page-template-things-to-do
  .grid-padding-x
  .page-header
  h2:not(:first-of-type):not(:nth-of-type(2)),
.page-template-things-to-do .grid-padding-y .page-header h2:nth-of-type(3),
.page-template-things-to-do
  .grid-padding-y
  .page-header
  h2:not(:first-of-type):not(:nth-of-type(2)),
.page-template-things-to-do .gap .page-header h2:nth-of-type(3),
.page-template-things-to-do
  .gap
  .page-header
  h2:not(:first-of-type):not(:nth-of-type(2)),
.page-template-things-to-do .content .page-header h2:nth-of-type(3),
.page-template-things-to-do
  .content
  .page-header
  h2:not(:first-of-type):not(:nth-of-type(2)),
body.page-template-things-to-do .grid-padding-x .page-header h2:nth-of-type(3),
body.page-template-things-to-do
  .grid-padding-x
  .page-header
  h2:not(:first-of-type):not(:nth-of-type(2)),
body.page-template-things-to-do .grid-padding-y .page-header h2:nth-of-type(3),
body.page-template-things-to-do
  .grid-padding-y
  .page-header
  h2:not(:first-of-type):not(:nth-of-type(2)),
body.page-template-things-to-do .gap .page-header h2:nth-of-type(3),
body.page-template-things-to-do
  .gap
  .page-header
  h2:not(:first-of-type):not(:nth-of-type(2)),
body.page-template-things-to-do .content .page-header h2:nth-of-type(3),
body.page-template-things-to-do
  .content
  .page-header
  h2:not(:first-of-type):not(:nth-of-type(2)),
.page-template-things-to-do .grid-x .page-header h2:nth-of-type(3),
.page-template-things-to-do
  .grid-x
  .page-header
  h2:not(:first-of-type):not(:nth-of-type(2)),
body.page-template-things-to-do .grid-x .page-header h2:nth-of-type(3),
body.page-template-things-to-do
  .grid-x
  .page-header
  h2:not(:first-of-type):not(:nth-of-type(2)) {
  font-family: "Barlow", sans-serif !important;
  font-size: 24px !important;
  font-weight: 600 !important;
  margin-bottom: 1em;
}

.page-template-things-to-do .page-header h2:first-of-type {
  font-size: 0 !important;
  margin: 0;
  padding: 0;
  line-height: 0;
}

.page-template-things-to-do .page-header h2:first-of-type img {
  width: 100%;
  height: auto;
  display: block;
}

.page-template-things-to-do .page-header h2:nth-of-type(2) {
  display: none;
}

.page-template-things-to-do .page-header ~ div,
.page-template-things-to-do .page-header + div {
  margin-top: 1.5em !important;
}

/* Things To Do Tabs Titles - 16px font size with maximum specificity */
.page-template-things-to-do .tabs-title > a,
body.page-template-things-to-do .tabs-title > a,
.page-template-things-to-do ul.tabs .tabs-title > a,
.page-template-things-to-do .tabs .tabs-title > a,
body.page-template-things-to-do .tabs .tabs-title > a,
body.page-template-things-to-do ul.tabs .tabs-title > a,
.page-template-things-to-do .tabs-title.is-active > a,
.page-template-things-to-do .tabs-title > a[aria-selected="true"],
body.page-template-things-to-do .tabs-title.is-active > a,
body.page-template-things-to-do .tabs-title > a[aria-selected="true"],
.page-template-things-to-do ul.tabs li.tabs-title > a,
body.page-template-things-to-do ul.tabs li.tabs-title > a,
.page-template-things-to-do .tabs li.tabs-title > a,
body.page-template-things-to-do .tabs li.tabs-title > a,
.page-template-things-to-do .grid-x .tabs .tabs-title > a,
body.page-template-things-to-do .grid-x .tabs .tabs-title > a,
.page-template-things-to-do .content .tabs .tabs-title > a,
body.page-template-things-to-do .content .tabs .tabs-title > a,
#things-to-do-tabs .tabs-title > a,
#things-to-do-tabs .tabs-title.is-active > a,
#things-to-do-tabs .tabs-title > a[aria-selected="true"] {
  font-size: 16px !important;
  font-family: "Barlow", sans-serif !important;
}

/* Things To Do Tabs - h3 headings inside tabs content (18px) - Maximum specificity */
.page-template-things-to-do .tabs-content .tabs-panel h3,
body.page-template-things-to-do .tabs-content .tabs-panel h3,
.page-template-things-to-do .tabs-panel h3,
body.page-template-things-to-do .tabs-panel h3,
.page-template-things-to-do .tabs-content .tabs-panel h3.uk-h1,
body.page-template-things-to-do .tabs-content .tabs-panel h3.uk-h1,
.page-template-things-to-do
  .tabs-content
  .tabs-panel
  h3.uk-h1.uk-margin-top-remove,
body.page-template-things-to-do
  .tabs-content
  .tabs-panel
  h3.uk-h1.uk-margin-top-remove,
.page-template-things-to-do
  #things-to-do-tabs
  ~ .tabs-content
  .tabs-panel
  h3,
body.page-template-things-to-do
  #things-to-do-tabs
  ~ .tabs-content
  .tabs-panel
  h3,
.page-template-things-to-do
  [data-tabs-content="things-to-do-tabs"]
  .tabs-panel
  h3,
body.page-template-things-to-do
  [data-tabs-content="things-to-do-tabs"]
  .tabs-panel
  h3,
/* Override Foundation and UIKit classes */
.page-template-things-to-do .tabs-content .tabs-panel h3.h3,
body.page-template-things-to-do .tabs-content .tabs-panel h3.h3,
.page-template-things-to-do .tabs-panel h3.h3,
body.page-template-things-to-do .tabs-panel h3.h3,
.page-template-things-to-do .tabs-content .tabs-panel h3.uk-h1.h3,
body.page-template-things-to-do .tabs-content .tabs-panel h3.uk-h1.h3 {
  font-family: "Barlow", sans-serif !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  margin-bottom: 1em;
  margin-top: 0;
  line-height: 1.4 !important;
}

.page-template-things-to-do .tabs-content .tabs-panel p,
body.page-template-things-to-do .tabs-content .tabs-panel p {
  font-family: "Barlow", sans-serif !important;
  line-height: 1.6;
  margin-bottom: 1em;
}

/* Override Foundation media query for h2 (40px -> 24px) */
@media print, screen and (min-width: 46.875em) {
  .page-template-things-to-do .page-header h2:nth-of-type(3),
  .page-template-things-to-do
    .page-header
    h2:not(:first-of-type):not(:nth-of-type(2)),
  body.page-template-things-to-do .page-header h2:nth-of-type(3),
  body.page-template-things-to-do
    .page-header
    h2:not(:first-of-type):not(:nth-of-type(2)),
  .page-template-things-to-do .page-header h2.h2,
  body.page-template-things-to-do .page-header h2.h2 {
    font-size: 24px !important;
  }

  .page-template-things-to-do .tabs-content .tabs-panel h3,
  body.page-template-things-to-do .tabs-content .tabs-panel h3,
  .page-template-things-to-do .tabs-panel h3,
  body.page-template-things-to-do .tabs-panel h3,
  .page-template-things-to-do .tabs-content .tabs-panel h3.h3,
  body.page-template-things-to-do .tabs-content .tabs-panel h3.h3,
  .page-template-things-to-do .tabs-panel h3.h3,
  body.page-template-things-to-do .tabs-panel h3.h3,
  .page-template-things-to-do .tabs-content .tabs-panel h3.uk-h1,
  body.page-template-things-to-do .tabs-content .tabs-panel h3.uk-h1 {
    font-size: 18px !important;
  }
}

@media (max-width: 1024px) {
  .page-template-things-to-do .tabs .tabs-title > a,
  body.page-template-things-to-do .tabs .tabs-title > a {
    font-size: 16px !important;
  }
}

@media (max-width: 768px) {
  .page-template-things-to-do .tabs .tabs-title > a,
  body.page-template-things-to-do .tabs .tabs-title > a {
    font-size: 16px !important;
  }
}

/* ============================================
   FINAL OVERRIDE - Must be at the END of file
   Overrides default.css and any other late-loading CSS
   ============================================ */

/* About Us Page Final Override */
body.page-template-about-us .banner,
body.page-template-about-us .banner.about-us-banner,
body.page-template-about-us .off-canvas-content .banner,
body.page-template-about-us .content .banner,
body.page-template-about-us .flex-content .banner {
  height: 486px !important;
  max-height: 486px !important;
  min-height: 486px !important;
}
body.page-template-about-us .banner img,
body.page-template-about-us .banner.about-us-banner img,
body.page-template-about-us .banner picture,
body.page-template-about-us .banner.about-us-banner picture,
body.page-template-about-us .banner picture img,
body.page-template-about-us .banner.about-us-banner picture img {
  height: 486px !important;
  max-height: 486px !important;
  min-height: 486px !important;
}
body.page-template-about-us .banner .banner-item,
body.page-template-about-us .banner.about-us-banner .banner-item,
body.page-template-about-us .banner .slides,
body.page-template-about-us .banner.about-us-banner .slides,
body.page-template-about-us .banner .slick-slider,
body.page-template-about-us .banner.about-us-banner .slick-slider,
body.page-template-about-us .banner .slick-list,
body.page-template-about-us .banner.about-us-banner .slick-list,
body.page-template-about-us .banner .slick-track,
body.page-template-about-us .banner.about-us-banner .slick-track,
body.page-template-about-us .banner .slick-slide,
body.page-template-about-us .banner.about-us-banner .slick-slide {
  height: 486px !important;
  max-height: 486px !important;
  min-height: 486px !important;
}

/* ============================================
   HOMEPAGE SEARCH SECTION - INDEPENDENT STYLING
   High specificity to prevent any overrides
   ============================================ */
.page-wrap-home .home-banner__overlay #home-search,
.page-wrap-home .home-banner .home-banner__overlay #home-search,
body.page-template-home .page-wrap-home .home-banner__overlay #home-search,
body.page-template-home .home-banner__overlay #home-search {
  margin: 0 !important;
  margin-top: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding: 0 !important;
  padding-top: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  background: #fff !important;
  border-radius: 0 !important;
  box-sizing: border-box !important;
}

.page-wrap-home .home-banner__overlay #home-search .small-12 {
  padding: 25px !important;
  margin: 0 !important;
}

@media (max-width: 720px) {
  .page-wrap-home .home-banner__overlay #home-search,
  .page-wrap-home .home-banner .home-banner__overlay #home-search,
  body.page-template-home .page-wrap-home .home-banner__overlay #home-search,
  body.page-template-home .home-banner__overlay #home-search {
    padding: 20px 15px !important;
    background: #fff !important;
    border-radius: 8px !important;
    margin-bottom: 0 !important;
  }
}

@media (max-width: 480px) {
  .page-wrap-home .home-banner__overlay {
    padding-bottom: 30px !important;
    margin-bottom: 30px !important;
  }

  .page-wrap-home .home-banner__overlay #home-search,
  .page-wrap-home .home-banner .home-banner__overlay #home-search,
  body.page-template-home .page-wrap-home .home-banner__overlay #home-search,
  body.page-template-home .home-banner__overlay #home-search {
    margin-bottom: 30px !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-bottom: 20px !important;
    display: block !important;
    position: relative !important;
  }

  .page-wrap-home .home-banner__overlay #home-search .small-12 {
    padding: 0 !important;
    margin: 0 !important;
  }
}

@media (max-width: 375px) {
  .page-wrap-home .home-banner__overlay {
    padding-bottom: 30px !important;
    margin-bottom: 30px !important;
  }

  .page-wrap-home .home-banner__overlay #home-search,
  .page-wrap-home .home-banner .home-banner__overlay #home-search,
  body.page-template-home .page-wrap-home .home-banner__overlay #home-search,
  body.page-template-home .home-banner__overlay #home-search {
    margin-bottom: 30px !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-bottom: 25px !important;
    display: block !important;
    position: relative !important;
  }

  .page-wrap-home .home-banner__overlay #home-search .small-12 {
    padding: 0 !important;
    margin: 0 !important;
  }
}


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