/** Hero */
.hero {
  position: relative;
  display: block;
  overflow: hidden;
}

.hero__container {
  position: relative;
  display: block;
}

.hero__slideshow {
  position: relative;
  display: block;
}

.hero__slideshow:after {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.2);
  pointer-events: none;
}

.hero__info {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  padding: 20px;
  pointer-events: none;
}

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

.hero__tagline {
  position: relative;
  display: block;
  text-align: center;
  text-transform: uppercase;
  text-shadow: 0px 2px 5px rgba(0, 0, 0, 0.2);
  color: var(--secondary, #fff);
}

.hero__tagline strong {
  display: block;
  font-family: var(--font-family-title);
  font-size: max(3.75vw, 30px);
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: 0;
}

.hero__link {
  position: relative;
  display: block;
  margin-top: max(1.563vw, 20px);
}

/** Search */
.search {
  position: relative;
  display: block;
  padding: max(4.688vw, 50px) 14.375vw;
  background: var(--primary-background, #fff);
}

.search__container {
  position: relative;
  display: block;
}

.search__heading {
  position: relative;
  display: block;
}

.search__heading h2 {
  display: block;
  font-family: var(--font-family-title);
  font-size: max(1.875vw, 20px);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0;
  text-transform: uppercase;
  text-align: center;
  color: var(--primary-text-color, var(--font-color-default));
}

.search__form {
  position: relative;
  display: flex;
  border-bottom: 1px solid #7f7f7f;
  margin-top: max(2.5vw, 30px);
}

.search__form > * + * {
  margin-left: max(3.125vw, 20px);
}

.search__form-col {
  position: relative;
  display: block;
  margin-top: max(0.313vw, 5px);
  width: max(4.375vw, 60px);
  flex-shrink: 0;
}

.search__form-col--lg {
  flex: 1 0 auto;
}

.search__form-col--md {
  width: max(9.375vw, 80px);
}

.search__form-col--button {
  width: auto;
  flex-shrink: 0;
  margin-top: 0;
  margin-left: max(1.875vw, 20px);
}

.search__form-col--button:after {
  content: "";
  position: absolute;
  top: 100%;
  left: min(-1.875vw, -20px);
  right: 0;
  background: #fff;
  height: 1px;
}

.search__form-input {
  -webkit-appearance: none;
  appearance: none;
  outline: none;
  border: none;
  background: transparent;
  display: block;
  width: 100%;
  padding: 0;
  font-size: max(0.625vw, 10px);
  font-weight: 700;
  line-height: normal;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-overflow: ellipsis;
  color: var(--primary-text-color, #999);
}

.search__form-input--select {
  background-image: url(../images/dropdown-arrow.png);
  background-repeat: no-repeat;
  background-position: center right;
  padding-right: 15px;
}

.search__form-input button {
  -webkit-appearance: none !important;
  appearance: none !important;
  outline: none !important;
  border: none !important;
  background: transparent;
  display: block !important;
  width: 100% !important;
  padding: 0 !important;
  font-size: max(0.625vw, 10px) !important;
  font-weight: 700;
  line-height: normal !important;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-overflow: ellipsis;
  color: var(--primary-text-color, #999) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: inset 0 0px 0px rgba(0, 0, 0, 0.125) !important;
}

.search__form .bootstrap-select .dropdown-toggle:focus {
  outline: none !important;
}

.search__form-submit--desktop {
  -webkit-appearance: none;
  appearance: none;
  outline: none;
  border: none;
  background: transparent;
  display: inline-block;
  vertical-align: middle;
  font-size: max(2.5vw, 30px);
  padding: 0;
  color: var(--primary);
  transition: opacity var(--default-transition);
}

.search__form-submit--desktop:focus, .search__form-submit--desktop:hover {
  opacity: 0.75;
}

.search__form-submit--mobile {
  display: none;
}

.search__poweredby {
  position: relative;
  display: block;
  font-size: max(0.625vw, 10px);
  font-weight: 300;
  line-height: 1;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  text-align: center;
  margin-top: max(0.938vw, 10px);
  color: #666;
}

/** Listings */
.listings {
  position: relative;
  display: block;
  padding: 5vw 6.25vw 6.875vw;
  background: var(--primary-background, #fff);
  overflow: hidden;
  --title-width: max(28.313vw, 225px);
  --title-height: max(14.625vw, 150px);
  --title-position-left: max(2.5vw, 20px);
}

.listings__container {
  position: relative;
  display: block;
}

.listings__heading {
  position: absolute;
  bottom: 0;
  left: var(--title-position-left);
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--title-width);
  height: var(--title-height);
  background: var(--primary);
  padding: 15px;
  text-align: left;
}

.listings__slider {
  position: relative;
  display: block;
}

.listings__slider:before {
  content: "";
  position: absolute;
  bottom: calc(var(--site-button-height) + max(3.75vw, 30px));
  right: min(-6.875vw, -50px);
  width: 18.313vw;
  height: 26.125vw;
  background: transparent url(../images/listings-texture.jpg) no-repeat;
  background-size: cover;
  pointer-events: none;
}

.listings__slider-container {
  position: relative;
  display: block;
}

.listings__slider-img {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.listings__slider-button {
  position: absolute;
  background: var(--primary);
  transform: scale(0);
  transition: transform var(--default-transition);
  color: var(--secondary-text-color, #fff);
}

.listings__slider-info {
  position: relative;
  display: block;
  max-width: calc(100% - (var(--title-width) + var(--title-position-left) * 2));
  margin: 0 var(--title-position-left) 0 auto;
  padding: max(1.875vw, 20px) max(2.5vw, 20px) max(1.563vw, 15px);
  text-align: right;
  color: var(--primary-text-color, var(--font-color-default));
}

.listings__slider-info:after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 1px;
  height: var(--title-height);
  background: rgba(var(--rgb-primary, 0, 0, 0), 0.5);
}

.listings__slider-info > * + * {
  margin-top: max(0.938vw, 10px);
}

.listings__slider-address {
  position: relative;
  display: block;
}

.listings__slider-address strong {
  display: block;
  font-family: var(--font-family-title);
  font-size: max(1.5vw, 20px);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0;
  text-transform: uppercase;
}

.listings__slider-others {
  position: relative;
  display: block;
}

.listings__slider-others ul {
  position: relative;
  display: inline-flex;
}

.listings__slider-others ul > * + * {
  margin-left: max(0.813vw, 8px);
  padding-left: max(0.813vw, 8px);
  border-left: 1px solid #ccc;
}

.listings__slider-others ul li {
  position: relative;
  display: block;
  font-size: max(0.813vw, 10px);
  font-weight: 300;
  line-height: 1;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.listings__slider-price {
  position: relative;
  display: block;
  font-size: max(0.813vw, 10px);
  font-weight: 300;
  line-height: 1;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.listings__slider-item {
  position: relative;
  display: block;
}

.listings__slider-item:focus .listings__slider-img img, .listings__slider-item:hover .listings__slider-img img {
  filter: grayscale(1);
}

.listings__slider-item:focus .listings__slider-button, .listings__slider-item:hover .listings__slider-button {
  transform: none;
}

.listings__slider-control {
  margin-top: max(3.75vw, 30px);
  padding: 0 8.125vw;
}

.listings__slider-viewall {
  margin-right: auto;
  margin-left: 0;
  order: -1;
}

/** Welcome */
.welcome {
  position: relative;
  display: block;
  padding: max(6.25vw, 50px) 6.875vw;
  overflow: hidden;
}

.welcome:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: transparent url(../images/welcome-texture.jpg) no-repeat;
  background-position: center center;
  background-size: cover;
  pointer-events: none;
}

.welcome__container {
  position: relative;
  display: flex;
}

.welcome__main {
  position: relative;
  display: flex;
  flex-direction: column;
  margin-top: max(1.875vw, 20px);
}

.welcome__heading {
  position: relative;
  display: block;
  padding-left: max(2.5vw, 20px);
  border-left: 1px solid #000;
}

.welcome__text {
  position: relative;
  display: block;
  font-size: max(0.875vw, 13px);
  font-weight: 300;
  line-height: 1.9;
  letter-spacing: 0.05em;
  margin-top: max(2.813vw, 30px);
  color: var(--primary-text-color, var(--font-color-default));
}

.welcome__text > * + * {
  margin-top: 1.9em;
}

.welcome__text span {
  display: block;
  margin-bottom: 10px;
}

.welcome__text p strong {
    margin-top: 10px;
}

.welcome__text p strong {
  display: block;
}



.welcome__link {
  position: relative;
  display: block;
  margin-top: auto;
  padding-top: max(2.5vw, 30px);
}

.welcome__link .site-button {
  padding: 10px 15px;
  min-width: max(13.625vw, 200px);
}

.welcome__video {
  position: relative;
  display: flex;
  flex-direction: column;
  width: max(41.063vw, 350px);
  margin-left: 6.25vw;
  flex-shrink: 0;
}

.welcome__video-img {
  position: relative;
  display: block;
  margin: max(1.875vw, 20px) max(1.875vw, 20px) 0 0;
}

.welcome__video-img:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  right: 0;
  width: 89%;
  height: 80%;
  background: var(--primary);
  margin: min(-1.875vw, -20px);
  pointer-events: none;
}

.welcome__video-button {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: max(1.875vw, 20px) max(1.875vw, 20px) 0 0;
}

.welcome__video-button i {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: max(7.25vw, 55px);
  height: max(7.25vw, 55px);
  border-radius: 50%;
  border: 1px solid #fff;
  font-size: max(2.25vw, 20px);
  color: #fff;
  padding-left: 4px;
  transition: var(--default-transition);
  transition-property: background, color, border;
}

.welcome__video-popup {
  position: relative;
  display: block;
}

.welcome__video-popup:focus .welcome__video-button i, .welcome__video-popup:hover .welcome__video-button i {
  color: #fff;
  background: var(--primary);
  border-color: var(--primary);
}

.welcome__video-text {
  position: relative;
  display: block;
  font-family: var(--font-family-title);
  font-size: max(1.125vw, 16px);
  font-weight: 400;
  font-style: italic;
  letter-spacing: 0.05em;
  color: var(--font-color-default);
  margin-top: max(1.875vw, 20px);
}

.welcome__video-link {
  position: relative;
  display: block;
  margin-top: auto;
  padding-top: max(2.5vw, 30px);
}

.welcome__video-link .site-button {
  padding: 10px 15px;
  min-width: max(13.625vw, 200px);
}

/** Featured Communities */
.communities {
  position: relative;
  display: block;
  padding: max(6.25vw, 50px) 0;
  background: var(--primary-background, #fff);
  overflow: hidden;
}

.communities__container {
  position: relative;
  display: block;
}

.communities__main {
  position: relative;
  display: flex;
  padding: 0 14.375vw;
}

.communities__main > * + * {
  margin-left: 7.6vw;
}

.communities__heading {
  position: relative;
  display: block;
  flex-shrink: 0;
}

.communities__text {
  position: relative;
  display: block;
  padding-top: 0.8vw;
  font-size: max(0.875vw, 13px);
  font-weight: 300;
  line-height: 1.9;
  letter-spacing: 0.05em;
  color: var(--primary-text-color, var(--font-color-default));
}

.communities__slider {
  position: relative;
  display: block;
  margin-top: max(3.125vw, 30px);
}

.communities__slider-img {
  position: relative;
  display: block;
}

.communities__slider-info {
  position: absolute;
  z-index: 3;
  top: 100%;
  left: 0;
  right: 0;
  transform: translateY(-100%);
  padding: max(4.063vw, 25px) max(2.5vw, 30px);
  text-align: center;
  transition: var(--default-transition);
  transition-property: top, transform;
}

.communities__slider-name {
  position: relative;
  font-family: var(--font-family-title);
  font-size: max(2.188vw, 18px);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: 0;
  text-transform: uppercase;
  color: var(--secondary-text-color, #fff);
}

.communities__slider-link {
  position: relative;
  display: block;
  height: 0;
  transform: scale(0);
  overflow: hidden;
  transition: var(--default-transition);
  transition-property: height, transform, margin;
}

.communities__slider-link .site-button {
  padding: 10px 15px;
  width: max(13vw, 150px);
  max-width: 100%;
  background: var(--primary);
  color: var(--secondary-text-color, #fff);
}

.communities__slider-item {
  position: relative;
  display: block;
}

.communities__slider-item:before, .communities__slider-item:after {
  content: "";
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  transition: opacity var(--default-transition);
}

.communities__slider-item:before {
  background: rgba(0, 0, 0, 0.2);
}

.communities__slider-item:after {
  margin: max(1.25vw, 15px);
  border: 1px solid rgba(255, 255, 255, 0.5);
}

.communities__slider-item:hover:before {
  opacity: 0;
}

.communities__slider-item:hover .communities__slider-img img {
  filter: grayscale(1);
}

.communities__slider-item:hover .communities__slider-info {
  top: 50%;
  transform: translateY(-50%);
}

.communities__slider-item:hover .communities__slider-link {
  margin-top: max(1.563vw, 15px);
  height: var(--site-button-height);
  transform: none;
}

.communities__slider-control {
  position: relative;
  margin-top: max(3.75vw, 30px);
}

.communities__slider-control > * + * {
  margin-left: max(3.125vw, 15px);
}

/** Testimonials */
.testimonials {
  position: relative;
  display: block;
  padding: max(6.25vw, 50px) 14.375vw;
  overflow: hidden;
}

.testimonials:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: transparent url(../images/testimonials-texture.jpg) no-repeat;
  background-size: cover;
  pointer-events: none;
}

.testimonials__container {
  position: relative;
  display: flex;
}

.testimonials__main {
  position: relative;
  display: block;
  flex-shrink: 0;
  margin-top: max(3.95vw, 20px);
}

.testimonials__slider {
  position: relative;
  display: block;
  margin-left: auto;
  padding-left: 30px;
  max-width: calc(max(38.75vw, 400px) + 50px);
}

.testimonials__slider-item {
  position: relative;
  display: block;
}

.testimonials__slider-icon {
  position: relative;
  display: block;
}

.testimonials__slider-icon img {
  display: block;
  width: max(5.5vw, 50px);
  max-width: 100%;
  height: auto;
}

.testimonials__slider-text {
  position: relative;
  display: block;
  font-size: max(0.875vw, 13px);
  font-weight: 300;
  font-style: italic;
  line-height: 1.9;
  letter-spacing: 0.05em;
  margin-top: max(1.563vw, 20px);
  color: var(--secondary-text-color, #fff);
}

.testimonials__slider-author {
  position: relative;
  display: block;
  font-family: var(--font-family-title);
  font-size: max(1.5vw, 18px);
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  margin-top: max(1.563vw, 20px);
  color: var(--secondary-text-color, #fff);
}

.testimonials__slider-control {
  margin-top: max(2.813vw, 30px);
}

.testimonials__slider-control--desktop {
  margin-top: max(3.75vw, 30px);
  justify-content: flex-start;
}

.testimonials__slider-arrow--desktop-hidden {
  display: none;
}

.testimonials__slider-viewall {
  text-align: left;
  width: 100%;
  margin: 0;
}

/** Call To Action */
.cta {
  position: relative;
  display: block;
  padding-bottom: max(0.188vw, 3px);
  overflow: hidden;
}

.cta__container {
  position: relative;
  display: block;
}

.cta__list {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: max(0.188vw, 3px);
}

.cta__list-img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  opacity: 0;
  transition: opacity var(--default-transition);
}

.cta__list-img:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(var(--rgb-primary, 0, 0, 0), 0.8);
}

.cta__list-img img {
  filter: grayscale(1);
}

.cta__list-info {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding: 20px;
}

.cta__list-heading {
  position: relative;
  display: block;
  font-family: var(--font-family-title);
  font-size: max(1.875vw, 20px);
  font-weight: 400;
  line-height: 1.3;
  letter-spacing: 0;
  color: var(--primary);
  text-transform: uppercase;
  transition: color var(--default-transition);
}

.cta__list-text {
  position: relative;
  display: block;
  font-size: max(0.575vw, 13px);
  font-weight: 300;
  line-height: 1.9;
  letter-spacing: 0.05em;
  color: var(--primary-text-color, var(--font-color-default));
  margin-top: max(1.25vw, 15px);
  transition: color var(--default-transition);
}

.cta__list-link {
  position: relative;
  display: block;
  height: 0;
  transform: scale(0);
  margin-top: 0;
  transition: var(--default-transition);
}

.cta__list-link .site-button {
  background: var(--secondary);
  border-color: var(--secondary);
  color: var(--primary-text-color);
}

.cta__list-item {
  position: relative;
  display: block;
  height: max(30.563vw, 350px);
  text-align: center;
  padding: 20px;
}

.cta__list-item:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: transparent;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  pointer-events: none;
}

.cta__list-item--a:before {
  background-image: url(../images/cta-texture-a.jpg);
}

.cta__list-item--b:before {
  background-image: url(../images/cta-texture-b.jpg);
}

.cta__list-item--c:before {
  background-image: url(../images/cta-texture-c.jpg);
}

.cta__list-item:focus .cta__list-heading, .cta__list-item:focus .cta__list-text, .cta__list-item:hover .cta__list-heading, .cta__list-item:hover .cta__list-text {
  color: var(--secondary-text-color, #fff);
}

.cta__list-item:focus .cta__list-img, .cta__list-item:hover .cta__list-img {
  opacity: 1;
}

.cta__list-item:focus .cta__list-link, .cta__list-item:hover .cta__list-link {
  height: var(--site-button-height);
  transform: none;
  margin-top: max(1.875vw, 20px);
}

/** Latest News */
.blogs {
  position: relative;
  display: block;
  padding: max(7.813vw, 50px) 6.25vw;
  overflow: hidden;
}

.blogs:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: transparent url(../images/blogs-texture.jpg) no-repeat;
  background-size: cover;
  pointer-events: none;
}

.blogs__container {
  position: relative;
  display: flex;
  align-items: center;
}

.blogs__main {
  position: relative;
  display: block;
  width: max(20.313vw, 265px);
  max-width: 100%;
  flex-shrink: 0;
}

.blogs__heading {
  position: relative;
  display: block;
}

.blogs__text {
  position: relative;
  display: block;
  font-size: max(0.875vw, 13px);
  font-weight: 300;
  line-height: 1.9;
  letter-spacing: 0.05em;
  color: var(--secondary-text-color, #fff);
  margin-top: max(2.5vw, 20px);
}

.blogs__link {
  position: relative;
  display: block;
  margin-top: max(2.5vw, 20px);
}

.blogs__link--mobile {
  display: none;
}

.blogs__list {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: max(0.375vw, 6px);
  flex-grow: 1;
  margin-left: 7.5vw;
}

.blogs__list-img {
  position: relative;
  display: block;
  height: 100%;
}

.blogs__list-img:after {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.2);
  transition: background var(--default-transition);
  pointer-events: none;
}

.blogs__list-info {
  position: absolute;
  z-index: 2;
  bottom: 0;
  right: 0;
  left: 0;
  margin: 0 auto max(1.25vw, 15px);
  padding: 0 10px max(2.188vw, 20px);
  width: calc(max(12.5vw, 200px) + 20px);
  max-width: calc(100% - max(1.25vw, 15px) * 2);
  text-transform: uppercase;
  color: var(--secondary-text-color, #fff);
}

.blogs__list-date {
  position: relative;
  display: block;
  font-size: max(0.813vw, 10px);
  font-weight: 300;
  line-height: 1;
  letter-spacing: 0.1em;
}

.blogs__list-heading {
  position: relative;
  display: block;
  font-size: max(0.938vw, 13px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.1em;
  margin-top: max(0.375vw, 5px);
}

.blogs__list-link {
  position: relative;
  display: block;
  height: 0;
  transform: scale(0);
  transition: var(--default-transition);
  transition-property: height, transform, margin;
}

.blogs__list-link .site-button {
  background: var(--secondary);
  border-color: var(--secondary);
  color: var(--primary-text-color, var(--primary));
  padding: 10px;
  min-width: 0;
  width: max(12.375vw, 175px);
  font-size: max(0.875vw, 10px);
  max-width: 100%;
}

.blogs__list-item {
  position: relative;
  display: block;
  padding: max(1.25vw, 15px);
  border: 1px solid rgba(var(--rgb-secondary, 255, 255, 255), 0.5);
}

.blogs__list-item:focus .blogs__list-img:after, .blogs__list-item:hover .blogs__list-img:after {
  background: rgba(0, 0, 0, 0.75);
}

.blogs__list-item:focus .blogs__list-img img, .blogs__list-item:hover .blogs__list-img img {
  filter: grayscale(1);
}

.blogs__list-item:focus .blogs__list-link, .blogs__list-item:hover .blogs__list-link {
  height: var(--site-button-height);
  transform: none;
  margin-top: max(1.25vw, 15px);
}

/** Social Media Wall */
.social {
  position: relative;
  display: block;
  padding: max(7.5vw, 50px) 6.25vw;
  background: var(--primary-background, transparent);
  overflow: hidden;
}

.social__container {
  position: relative;
  display: flex;
}

.social__main {
  position: relative;
  display: block;
  width: max(22.188vw, 300px);
  flex-shrink: 0;
}

.social__main > * {
  padding-left: max(2.5vw, 20px);
}

.social__heading {
  position: relative;
  display: block;
  border-left: 1px solid rgba(0, 0, 0, 0.5);
}

.social__text {
  position: relative;
  display: block;
  font-size: max(0.875vw, 13px);
  font-weight: 300;
  line-height: 1.9;
  letter-spacing: 0.05em;
  margin-top: max(2.188vw, 25px);
  color: var(--primary-text-color, #333);
}

.social__links {
  position: relative;
  display: block;
  margin-top: max(2.5vw, 30px);
}

.social__links ul {
  position: relative;
  display: inline-flex;
  vertical-align: middle;
  flex-flow: row wrap;
}

.social__links ul > * + * {
  margin-left: max(0.938vw, 10px);
}

.social__links ul li {
  position: relative;
  display: block;
}

.social__links ul li a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  width: max(2.375vw, 32px);
  height: max(2.375vw, 32px);
  border: 1px solid var(--primary);
  color: var(--primary-text-color, var(--font-color-default));
  font-size: max(1vw, 13px);
  border-radius: 50%;
}

.social__links ul li a:focus, .social__links ul li a:hover {
  background: var(--primary);
  color: var(--secondary-text-color, #fff);
}

.social__list {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: max(1.563vw, 15px);
  margin-left: 9.375vw;
  flex-grow: 1;
}

.social__list-img {
  position: relative;
  display: block;
}

.social__list-img:after {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.8);
  opacity: 0;
  transition: opacity var(--default-transition);
  pointer-events: none;
}

.social__list-img canvas {
  min-height: 150px;
}

.social__list-icon {
  position: absolute;
  z-index: 3;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: max(6vw, 35px);
  color: var(--secondary-text-color, #fff);
  transform: scale(0);
  transition: transform var(--default-transition);
}

.social__list-icon i {
  display: block;
}

.social__list-item {
  position: relative;
  display: block;
}

.social__list-item:focus .social__list-img:after, .social__list-item:hover .social__list-img:after {
  opacity: 1;
}

.social__list-item:focus .social__list-img img, .social__list-item:hover .social__list-img img {
  filter: grayscale(1);
}

.social__list-item:focus .social__list-icon, .social__list-item:hover .social__list-icon {
  transform: none;
}



/*******************************************************
*
* Media Queries
*
*******************************************************/
@media only screen and (max-width: 1560px) {
  .cta__list-text {
      font-size: 13px;
      line-height: 1.6;
  }
}

@media only screen and (max-width: 1440px) {
  .cta__list-text {
      font-size: 12px;
      line-height: 1.5;
  }
}

@media only screen and (max-width: 1199px) {
  .search {
      padding-left: 10.425vw;
      padding-right: 10.425vw;
  }

  .communities__main {
      padding-left: 10.425vw;
      padding-right: 10.425vw;
  }

  .testimonials {
      padding-left: 10.425vw;
      padding-right: 10.425vw;
  }

  .blogs__list {
      margin-left: 5.04vw;
  }

  .welcome__video {
      margin-left: 24px;
  }

  .cta__list-text {
    font-size: 11px;
    line-height: 1.3;
}

.cta__list-heading {
    font-size: 18px;
}
}

@media only screen and (max-width: 991px) {
  .cta__list-text.is-mobile {
     display: block !important;
  }
  .cta__list-text{
    display: none;
  }
  .search, .listings, .welcome, .testimonials, .cta, .blogs, .social {
      padding: 50px 15px;
  }

  .search__container, .listings__container, .welcome__container, .testimonials__container, .cta__container, .blogs__container, .social__container {
      max-width: 750px;
      margin-left: auto;
      margin-right: auto;
  }

  .hero__slideshow .aios-slider .aios-slider-splide .aios-slider-img canvas, .hero__slideshow .aios-slider .aios-slider-splide .aios-slider-custom-video canvas {
      height: calc(100vh - 200px) !important;
  }

  .search__form {
      flex-flow: row wrap;
      border-bottom: none;
      margin: 30px -10px 0;
  }

  .search__form-col {
      width: 50%;
      margin: 0 !important;
      padding: 10px;
  }

  .search__form-col--lg {
      width: 100%;
  }

  .search__form-col--button {
      width: 100%;
      text-align: center;
  }

  .search__form-input {
      padding-bottom: 10px;
      border-bottom: 1px solid #7f7f7f;
  }

  .search__form-submit--desktop {
      display: none;
  }

  .search__form-submit--mobile {
      display: inline-flex;
  }

  .listings {
      --title-width: auto;
      --title-height: auto;
      --title-position-left: 0;
  }

  .listings__heading {
      position: relative;
      text-align: center;
      background: transparent;
      margin-bottom: 40px;
      padding: 0;
  }

  .listings__heading small, .listings__heading strong {
      color: var(--font-color-default);
  }

  .listings__slider:before {
      display: none;
  }

  .listings__slider-info {
      text-align: center;
      width: auto;
      max-width: 100%;
  }

  .listings__slider-info:after {
      display: none;
  }

  .welcome__container {
      display: block;
      text-align: center;
  }

  .welcome__main {
      margin-top: 0;
  }

  .welcome__video {
      margin: 40px auto 0;
      width: 100%;
  }

  .communities {
      padding: 50px 0;
  }

  .communities__main {
      display: block;
      text-align: center;
  }

  .communities__main > * + * {
      margin: 30px 0 0;
      padding: 0;
  }

  .communities__slider-link {
      display: none;
  }

  .testimonials__container {
      display: block;
      text-align: center;
  }

  .testimonials__slider {
      margin: 40px 0 0;
      padding: 0;
      max-width: 100%;
  }

  .testimonials__slider-icon img {
      margin: 0 auto;
  }

  .testimonials__slider-control--desktop {
      display: none;
  }

  .testimonials__slider-arrow--desktop-hidden {
      display: flex;
  }

  .cta {
      padding-left: 0;
      padding-right: 0;
  }

  .cta__list {
      grid-template-columns: 1fr;
  }

  /*.cta__list-item {
      height: 250px;
  }*/

  .cta__list-heading {
      font-size: 25px;
  }

  .cta__list-link {
      display: none;
  }

  .blogs__container {
      display: block;
  }

  .blogs__main {
      width: 500px;
      margin: 0 auto;
      text-align: center;
  }

  .blogs__list {
      margin: 40px 0 0;
  }

  .blogs__list-link {
      display: none;
  }

  .blogs__link {
      text-align: center;
  }

  .blogs__link--desktop {
      display: none;
  }

  .blogs__link--mobile {
      display: block;
  }

  .social__container {
      display: block;
  }

  .social__main {
      width: auto;
      max-width: 500px;
      margin: 0 auto;
      text-align: center;
  }

  .social__main > * {
      padding-left: 0;
  }

  .social__list {
      margin: 40px 0 0;
  }

    .cta__list-text {
    font-size: 13px;
    line-height: 1.6;
}
}

@media only screen and (max-width: 767px) {
  .cta {
      padding: 15px;
  }
}

@media only screen and (max-width: 567px) {
  .blogs__list {
      grid-template-columns: 1fr;
      max-width: 400px;
      margin-left: auto;
      margin-right: auto;
  }

  /*.blogs__list-img canvas {
      max-height: 250px;
  }*/

  .blogs__list-info {
      width: 100%;
  }

  .social__list {
      grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media only screen and (max-width: 480px) {
  .search__form-col {
      width: 100%;
  }
}
