/** 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-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__tagline small {
  font-size: max(1.125vw, 13px);
  line-height: 1.5;
  margin-top: max(0.625vw, 7px);
  display: block;
  color: #fff;
  font-family: var(--font-family-title);
}

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

/** Search */
.search {
  position: relative;
  display: block;
  padding: 0;
  background: var(--primary-background, #fff);
  z-index: 3;
  width: 1332px;
  margin: 0 auto;
  max-width: 100%;
}

.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;
}


/* Quick Search V2 */
.quick-search-holder {
	position: absolute;
	z-index: 2;
	width: 100%;
	top: calc(50% + 15px);
}

.qs-toggle-button {
	max-width: 210px;
	margin: 0 auto 10px;
}

.qs-toggle-button .site-button {}

.qs-toggle-button .site-button::before {
	display: none;
}

.qs-toggle-button .site-button i {
	font-size: 14px;
	color: #fff;
	margin-right: 12px;
}

.qs-toggle-button .site-button:hover i {
	color: var(--secondary-color);
}

.qs-toggle-button .site-button span {
	margin: 0;
}

.qs-form {
	text-align: center;
	opacity: 0;
	transform: translateY(-50px);
	pointer-events: none;
	-webkit-transition: all 0.35s ease-in-out;
	-moz-transition: all 0.35s ease-in-out;
	-o-transition: all 0.35s ease-in-out;
	transition: all 0.35s ease-in-out;
}

.qs-form p {
	color: #000;
	font-size: 13px;
	padding: 15px 0;
	text-align: center;
}

.qs-form.elem-active {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
	font-size: 0;
}

.qs-form form {}

.qs-form .field-input {
	display: inline-block;
	vertical-align: middle;
	margin-right: 0.49%;
	margin-bottom: 0;
}

.qs-form .field-lg {
	width: 19.15%;
}

.qs-form .field-sm {
	width: 10.8%;
}

.qs-form .field-last {
	margin-right: 0;
}

.qs-form .field-input input,
.qs-form .field-input select,
.qs-form .field-input button[type="button"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: 0;
	border-radius: 0;
	background-color: rgba(0, 0, 0, 0);
	width: 100%;
	height: 52px;
	font-size: 12px;
	color: #000;
	text-transform: uppercase;
	padding: 0 20px;
	outline: none;
  border: 1px solid #000;
}

.qs-form .field-input select,
.qs-form .field-input button[type="button"] {
	background-image: url(../images/caret-dark.png);
	background-position: right center;
	background-repeat: no-repeat;
}

.qs-form .field-input button[type="button"].dropdown-toggle {
	box-shadow: none !important;
	text-shadow: none !important;
	outline: none !important;
	color: #000 !important;
	background: rgba(0, 0, 0, 0) url(../images/caret-dark.png) no-repeat !important;
	background-position: right center !important;
	border: 1px solid #000;
}

.qs-form .field-input button[type="button"] span {
	font-size: 12px;
	color: #fff;
}

.qs-form .field-input .bootstrap-select.btn-group .dropdown-menu.inner {
	max-height: 250px !important;
}

.qs-form .field-input .qs-select input {
	height: 34px;
	border: 1px solid #ccc;
	color: #555;
	background: #fff;
}

.qs-form .form-button {
	display: inline-block;
	vertical-align: middle;
	width: 190px;
	/* margin-right: 32px; */
	position: relative;
}

.qs-form .form-button input {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background: none;
	border: 1px solid #000;
	width: 100%;
	height: 54px;
	outline: none;
	transition: var(--default-transition);
	transition-property: color, border, background;
}

.qs-form .form-button:hover input {
	border-color: var(--primary);
	background: var(--primary);
}

.qs-form .form-button div {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	pointer-events: none;

  transition: var(--default-transition);
  transition-property: color, border, background;
}

.qs-form .form-button div::before {
	content: '';
	width: 13px;
	height: 1px;
	background: #000;

  transition: var(--default-transition);
  transition-property: color, border, background;
}

.qs-form .form-button:hover div::before {
	background: var(--secondary);
}

.qs-form .form-button div span {
	font-size: 12px;
  font-weight: 700;
	color: #000;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	margin: 0 26px 0 30px;

  transition: var(--default-transition);
  transition-property: color, border, background;
}

.qs-form .form-button div i {
	font-size: 10px;
	color: #000;

  transition: var(--default-transition);
  transition-property: color, border, background;
}

.qs-form .form-button:hover span,
.qs-form .form-button:hover i {
	color: var(--secondary);
}

.qs-form a.adv-button {
	display: inline-block;
	vertical-align: middle;
	font-size: 12px;
  font-weight: 700;
	color: #000;
	letter-spacing: 0.2em;
	text-transform: uppercase;

  transition: var(--default-transition);
  transition-property: color, border, background;
}

.qs-form a.adv-button:hover {
	color: var(--primary);
}

.qs-form a.adv-button::before {
	content: '+';
	display: inline-block;
	vertical-align: middle;
	font-size: 25px;
	font-weight: 300;
	margin-right: 10px;

  transition: var(--default-transition);
  transition-property: color, border, background;
}

.qs-form a.adv-button span {}

.qs-form .dropup .dropdown-menu {
	top: 100%;
	bottom: auto;
}

.qs-form .form-button {
  width: 14.8%;
}

.search > .container {
  width: 100%;
}

/* Quick Search V2 */

/** Listings */
.listings {
  position: relative;
  display: block;
  padding: 0 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;
  background: var(--primary) url(../images/git-texture.jpg) no-repeat;
  background-position: center center;
  background-size: cover;
  background-blend-mode: luminosity;
}

.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 var(--secondary);
}

.welcome__heading strong, .welcome__heading small {
  color: var(--secondary);
}

.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(--secondary);
}

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

.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(--secondary);
  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(1.563vw, 20px);
  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(1.750vw, 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;
  display: none;
}

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

.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;
  display: none;
}

.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.875vw, 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;
  pointer-events: none;
  background: var(--primary) url(../images/git-texture.jpg) no-repeat;
  background-position: center center;
  background-size: cover;
  background-blend-mode: luminosity;
}

.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;
  display: none;
}

.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;
}

.site-button.site-button--white.site-button--hover-primary.site-btn-bg-w {
	background: var(--primary);
	border-color: var(--primary);
	color: var(--secondary-text-color, #fff);
}
#homepage-communities{
  padding-top: 120px;
    padding-top: 7.5vw;
}
#homepage-communities .splide__track{
  /* padding-right: 400px !important; */
  padding-right: 0 !important;
}
#homepage-communities .listings__slider-address strong{
  font-size: 36px;
  font-size: max(1.13vw, 18px);
}
#homepage-communities .listings__slider-info{
  max-width: 100%;
  padding: max(1.25vw, 20px);
  margin: 0 max(1.25vw, 20px);
}
#homepage-communities .listings__slider-info:after{
  height: 100%;
}

section#homepage-communities .listings__heading {
  position: relative;
  left: unset;
  bottom: unset;
  margin: 0 auto max(4.38vw, 50px);
}

section#homepage-communities .listings__slider-img canvas {
  aspect-ratio: 315 / 639;
  height: auto;
}
/*******************************************************
*
* Media Queries
*
*******************************************************/
@media only screen and (max-width: 1199px) {
  .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;
  }
}

@media (min-width: 992px) {
	.quick-search-holder {
		top: calc(50% + 0.9375vw); /* 15px */
	}

	.qs-toggle-button {
		max-width: 13.125vw; /* 210px */
		margin: 0 auto 0.625vw; /* 10px */
	}

	.qs-toggle-button .site-button i {
		font-size: 0.875vw; /* 14px */
		margin-right: 0.75vw; /* 12px */
	}

	.qs-form p {
		font-size: 0.8125vw; /* 13px */
		padding: 0.9375vw 0; /* 15px */
	}

	.qs-form.elem-active {
		font-size: 0;
	}

	.qs-form .field-input {
		/* margin-bottom: 1.5vw; */ /* 24px */
	}

	.qs-form .field-input input,
	.qs-form .field-input select,
	.qs-form .field-input button[type="button"] {
		font-size: 0.75vw; /* 12px */
		height: 3.375vw; /* 52px */
		padding: 0 1.25vw; /* 20px */
	}

	.qs-form .field-input button[type="button"] span {
		font-size: 0.75vw; /* 12px */
	}

	.qs-form .form-button {
		/* width: 11.875vw; */ /* 190px */
	}

	.qs-form .form-button input {
		height: 3.375vw; /* 54px */
		 /* 2px */
	}

	.qs-form .form-button div::before {
		width: 0.8125vw; /* 13px */
	}

	.qs-form .form-button div span {
		font-size: 0.75vw; /* 12px */
		margin: 0 1.625vw 0 1.875vw; /* 26px 30px */
	}

	.qs-form .form-button div i {
		font-size: 0.625vw; /* 10px */
	}

	.qs-form a.adv-button {
		font-size: 0.75vw; /* 12px */
	}

	.qs-form a.adv-button::before {
		font-size: 1.5625vw; /* 25px */
		margin-right: 0.625vw; /* 10px */
	}

  .qs-wrapper {
      position: absolute;
      top: 8.75vw;
      left: 0;
      z-index: 1;
      width: 100%;
  }

  .qs-form .field-input input, .qs-form .field-input select, .qs-form .field-input button[type="button"] {
      border-color: #fff;
      color: #fff;
  }

  .qs-form .field-input select, .qs-form .field-input button[type="button"] {
      background-image: url(../images/caret.png);
  }

  .qs-form .field-input select option{
      color: #000;
  }

  .qs-form .form-button input {
      border-color: #fff;
      color: #fff;
  }

  .qs-form .form-button div::before {
      background: #fff;
  }

  .qs-form .form-button div span {color: #fff;}

  .qs-form .form-button div i {
      color: #fff;
  }

  .search{
    background: transparent;
    width: 83.25vw;
  }


  .hero__info {
      top: 12vw;
  }

  .listings{
      padding: 6.875vw 6.25vw;
  }
}


@media only screen and (max-width: 991px) {
  .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;
  }

  .hero__info {
      padding: 20px 15px;
  }
    #homepage-communities{
        padding-top: 50px;
    }
    #homepage-communities .splide__track{
    padding-right: 0 !important;
  }
    #homepage-communities .listings__slider-info{
    margin-right: 0;
  }

  section#homepage-communities .listings__slider-img canvas {
      max-height: 500px;
  }

  .qs-form {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
    max-width: 360px;
    margin: auto;
  }
    .qs-form .field-input {
      margin: 5px 0;
    }
    .qs-form .field-lg {
      width: 100%;
    }
    .qs-form .field-sm {
      width: 100%;
      margin-right: 0;
    }
    .qs-form .field-nomar {
      margin-right: 0;
    }
    .qs-form .form-button {
      display: block;
      margin: 20px auto;
      width: 100%;
    }
}

@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%;
  }

  .communities__slider-name {
      font-size: 15px;
  }

  .communities__slider-item:after {
      margin: 10px;
  }
}
