/*
Home CSS
*/

/* General
========================= */
.home .site-inner { padding-bottom: 3em; }

/* Hero Slider
========================= */
.hero-container { display: flex; justify-content: center; width: 100%; padding: 2em; }
.hero { display: block; border-radius: 15px; background-color: #fff; position: relative; width: 100%; max-height: 100%; overflow: hidden; z-index: 999; }
.hero-block { display: block; width: 100%; }

.hero,.hero-block-slide.slick-slide { height: calc(100vw * 0.41667); }

.hero-block-slide.slick-slide .hero-bg { background-repeat: no-repeat; background-position: 50% 50%; background-size: cover; position: absolute; left: 0px; right: 0px; top: 0px; bottom: 0px; width: 100%; height: 100%; overflow: hidden; transition: all 1s cubic-bezier(0.7, 0, 0.3, 1); transform: scale(1.2); }
.hero-block-slide.slick-slide.slick-active .hero-bg { transform: scale(1); }

.slider { visibility: hidden; }
.slider.slick-initialized { visibility: visible; }

/* CTA
========================= */
.home-cta { display: flex; flex-direction: column; align-items: center; padding: 3em 2em 4em; width: 100%; }
.home-cta-inner { display: flex; flex-direction: column; max-width: 1480px; width: 100%; }
.cta-tagline { display: flex; flex-wrap: wrap; justify-content: center; margin: 0 auto; }
.cta-tagline span { color: #232323; font-family: 'Poppins'; font-size: calc(30px + (30 - 18)*((100vw - 420px) /(1920 - 420))); font-weight: 500; line-height: 1.2; }

.cta-tagline span:first-of-type { opacity: 0; padding-right: .2em; }
.cta-tagline span:nth-of-type(2) { opacity: 0; padding-right: .2em; }
.cta-tagline span:nth-of-type(3) { opacity: 0; padding-right: .2em; }
.cta-tagline span:nth-of-type(4) { opacity: 0; padding-right: .2em; }
.cta-tagline span:nth-of-type(5) { opacity: 0; padding-right: .2em; }
.cta-tagline span:nth-of-type(6) { opacity: 0; padding-right: .2em; }

.cta-tagline span:first-of-type.animate__animated.animate__fadeIn { animation-delay: .01s; }
.cta-tagline span:nth-of-type(2).animate__animated.animate__fadeIn { animation-delay: .5s; }
.cta-tagline span:nth-of-type(3).animate__animated.animate__zoomIn { animation-delay: 1.2s; animation-duration: .6s; opacity: 1; }
.cta-tagline span:nth-of-type(4).animate__animated.animate__zoomIn { animation-delay: 1.4s; animation-duration: .6s; opacity: 1; }
.cta-tagline span:nth-of-type(5).animate__animated.animate__fadeIn { animation-delay: 2.3s; }
.cta-tagline span:nth-of-type(6).animate__animated.animate__fadeIn { animation-delay: 2.6s; }

/* About
========================= */
.about { display: flex; flex-direction: column; align-items: center; padding: 1em 2em 2em; width: 100%; }
.about-inner { background: #f0f0f0; border-radius: 15px; display: flex; flex-direction: column; max-width: 1480px; padding: 2em; width: 100%; }

.about-title { display: flex; flex-direction: column; margin: 0; padding: .5em 0 0; position: relative; }
.about-title span { color: #232323; font-family: 'Poppins'; font-size: 2.8rem; font-weight: 500; line-height: 1.4; letter-spacing: .05em; text-transform: uppercase; }

.about-content { margin: .5em 0; }

.about-description { display: block; padding: .5em 0; }
.about-description p { color: #4b4b4b; font-family: 'Poppins'; font-size: 1.8rem; line-height: 1.6; margin: 0; padding: 0 0 1.2em; }
.about-description p:last-of-type { padding: 0; }

/* How It Works
========================= */
.how-it-works { display: flex; flex-direction: column; align-items: center; padding: 3em 2em; width: 100%; }
.how-it-works-inner { display: flex; flex-direction: column; max-width: 1480px; width: 100%; }

.how-it-works-title { display: flex; flex-direction: column; margin: 0; padding: 0; position: relative; }
.how-it-works-title span { color: #232323; font-family: 'Poppins'; font-size: 2.8rem; font-weight: 500; line-height: 1.4; letter-spacing: .05em; text-transform: uppercase; }
.how-it-works-title span:last-of-type { color: #4c4c4c; font-size: 1.8rem; font-weight: 400; text-transform: none; padding-top: .25em; }
.how-it-works-content { display: block; background: #fff; margin: 1em 0; min-height: 300px; position: relative; }
.steps-bg { display: block; background-repeat: no-repeat; background-position: 50% 50%; background-size: cover; position: absolute; width: 100%; height: 100%; }
.steps-bg.tab { display: none; }
.steps-bg.mbl768 { display: none; }
.steps-bg.mbl640 { display: none; }
.steps-bg.mbl480 { display: none; }

/* Feat. Properties
========================= */
.feat-prop { display: flex; flex-direction: column; align-items: center; padding: 2em 2em 3em; width: 100%; }
.feat-prop-inner { display: flex; flex-direction: column; max-width: 1480px; width: 100%; }

.feat-prop-title { display: flex; flex-direction: row; justify-content: space-between; align-items: center; margin: 0; padding: 0; position: relative; }
.feat-prop-title span { color: #232323; font-family: 'Poppins'; font-size: 2.8rem; font-weight: 500; line-height: 1.4; letter-spacing: .05em; text-transform: uppercase; padding: 0 0 .8em; }
.feat-prop-title span a { font-size: 1.5rem; font-weight: 500; text-decoration: underline; text-underline-offset: 5px; }

.feat-properties-list { padding: 1em 2em 4.5em; }
.feat-properties-list-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.feat-properties-list-grid .feat-column { background: #fff; border-radius: .5rem; box-shadow: 0 15px 30px 0 rgba(0, 0, 0, .11), 0 5px 15px 0 rgba(0, 0, 0, .08); display: grid; grid-column: span 1; grid-auto-rows: max-content; margin: 0 0 .5em; padding: 0; }

.feat-properties-list-thumb { border-top-left-radius: .5rem; border-top-right-radius: .5rem; max-width: 100%; width: 100%; height: auto; vertical-align: top; }

.feat-properties-list-details { display: flex; flex-direction: column; padding: 1em 0 .5em; position: relative; }
.feat-properties-list-title { display: flex; flex-direction: column; padding: 0 1em; }
.feat-properties-list-title a { color: #000; font-family: 'Poppins'; font-size: 2.5rem; font-weight: 600; letter-spacing: -.02em; line-height: 1.4; }
.feat-properties-list-title a:hover { color: #b4b4b4; }

.feat-properties-list-subtitle .location-icon { max-width: 24px; }
.feat-properties-list-subtitle { display: flex; padding-top: .25em; margin-left: -5px; }
.feat-properties-list-subtitle span { display: flex; align-items: center; color: #4c4c4c; font-family: 'Poppins'; font-size: 1.5rem; font-weight: 500; letter-spacing: .02em; padding-left: 2px; }

.feat-properties-list-showcase { display: flex; flex-direction: row; flex-wrap: wrap; padding: 1.5em 0 1em; }

.feat-properties-list-showcase .feat { display: flex; flex-direction: column; align-items: center; width: calc(1 / 3 * 100% - (1 - 1 / 3) * 0px); }
.feat-properties-list-showcase .bedrooms.feat { width: calc(1 / 3 * 100% - (1 - 1 / 3) * 15px); }
.feat-properties-list-showcase .bathrooms.feat { border-left: 1px solid #ccc; border-right: 1px solid #ccc; }
.feat-properties-list-showcase .feat .icon { max-width: 30px; margin-right: 5px; }
.feat-properties-list-showcase .feat .number { display: flex; align-items: center; }
.feat-properties-list-showcase .feat .number span { color: #4c4c4c; font-family: 'Poppins'; font-size: 2.4rem; font-weight: 600; letter-spacing: .02em; line-height: 0; margin-top: 2px; }
.feat-properties-list-showcase .feat .feat-title { line-height: 1; }
.feat-properties-list-showcase .feat .feat-title span { color: #4c4c4c; font-family: 'Poppins'; font-size: 1.3rem; font-weight: 400; letter-spacing: .05em; }

/* Nomad
========================= */
.nomad-studios { display: flex; flex-direction: column; align-items: center; padding: 3em 2em; width: 100%;}
.nomad-studios-inner { display: flex; flex-direction: column; max-width: 1480px; width: 100%; }
.nomad-studios-title { display: flex; flex-direction: column; margin: 0; padding: 0; position: relative; }
.nomad-studios-title span { color: #232323; font-family: 'Poppins'; font-size: 2.8rem; font-weight: 500; line-height: 1.4; letter-spacing: .05em; text-transform: uppercase; }
.nomad-studios-content { margin: .5em 0 1.25em; }
.nomad-studios-description { display: block; padding: .5em 0; }
.nomad-studios-description p { color: #4b4b4b; font-family: 'Poppins'; font-size: 1.8rem; line-height: 1.6; }
.nomad-studios-description span { font-weight: 600; }

.nomad-grid { display: grid; gap: 1.5rem; grid-template-rows: 4fr 3fr 3fr; grid-template-columns: repeat(3, 1fr); padding: 0.5rem; max-width: 1480px; width: 100%; max-height: 800px; height: 100%; }
.nomad-grid .tout:nth-of-type(1) { grid-row: 1 / 3; }
.nomad-grid .tout:nth-of-type(2) { background-color: #d9e6f2; border-radius: 1rem; grid-row: 3 / 4; display: flex; flex-direction: column; justify-content: center; align-items: center; padding: 0 1em; }
.nomad-grid .tout:nth-of-type(2) span { color: #1a1a1a; font-family: 'Poppins'; font-size: 1.8rem; font-weight: 600; line-height: 1.4; margin: 0; padding: 0 0 .5em; text-align: center; }
.nomad-grid .tout:nth-of-type(2) a { color: #1a1a1a; font-family: 'Poppins'; font-size: 1.8rem; font-weight: 500; line-height: 1.4; margin: 0; padding: 0; text-decoration: underline; text-underline-offset: 0.25em; }
.nomad-grid .tout:nth-of-type(5) { grid-column: 2 / 4; grid-row: 2 / 4; }
.nomad-grid .tout img { border-radius: 1rem; width: 100%; height: 100%; object-fit: cover; }

/* TRE Touts
========================= */
.tre-tout { display: flex; flex-direction: column; align-items: center; padding: 2em; width: 100%; }
.tre-tout-inner { display: flex; flex-direction: column; max-width: 1480px; width: 100%; }
.tre-tout-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 15px; }
.tre-tout-column { background-position: 50% 50%; background-repeat: no-repeat; border-radius: 15px; display: grid; grid-column: span 1; grid-auto-rows: max-content; margin: 0; padding: 0.8em 0.5em; position: relative; min-height: 300px; }
.tout-overlay { background-color: rgba(44, 46, 61, 0.1); border-radius: 15px; position: absolute; left: 0; right: 0; top: 0; bottom: 0; z-index: 1; }
div:not(.tout-cta-block) + .tout-cta-block { display: flex; flex-direction: column; justify-content: center; align-items: center; position: absolute; top: 50%; transform: translate(0, -50%); width: 100%; z-index: 99; }
.tout-title { display: flex; flex-direction: column; }
.tout-title span { color: #fff; font-family: 'Poppins'; font-size: 3.2rem; font-weight: 400; letter-spacing: .02em; line-height: 1.5; margin: 0; padding: 0; text-align: center; }
.tout-title span:nth-of-type(2) { line-height: 1.4;}
.tout-button { padding: .8em 0 0; }
.tout-button a { border: 1px solid #fff; color: #fff; cursor: pointer; font-family: 'Poppins'; font-size: 1.6rem; font-weight: 500; padding: 8px 20px; display: inline-block; line-height: 1.2; }

/* Responsive
--------------------------------------------- */
@media only screen and (min-width: 1980px) {
.hero { height: 800px; }
.hero-block-slide.slick-slide { height: 800px; }
}

@media only screen and (min-width: 2500px) {
.hero { height: 800px; }
.hero-block-slide.slick-slide { height: 800px; }
}

@media only screen and (max-width: 1480px) {
.home .site-inner { padding-bottom: 3em; }
.home-cta { padding: 2.5em 2em 3.5em; }
.about-inner { padding: 1.5em 2em; }
.how-it-works { padding: 2.5em 2em; }
.feat-prop { padding: 1.5em 2em 2.5em; }
.feat-properties-list-title a { font-size: 2.4rem; }
.feat-properties-list-showcase .feat .number span { font-size: 2.3rem; }
.nomad-studios { padding: 2.5em 2em; }
.tre-tout { padding: 1.5em 2em; }
}

@media only screen and (max-width: 1280px) {
.home .site-inner { padding-bottom: 2.5em; }
.home-cta { padding: 2em 2em 3em; }
.about { padding: 1em 2em 1.5em; }
.about-inner { padding: 1em 2em; }
.about-description { padding: .25em 0; }
.about-description p { padding: 0 0 1em; }
.how-it-works { padding: 2em; }
.feat-prop { padding: 1em 2em 2em; }
.feat-properties-list-grid { gap: 25px; }
.feat-properties-list-title a { font-size: 2.3rem; }
.feat-properties-list-subtitle .location-icon { max-width: 22px; }
.feat-properties-list-subtitle span { font-size: 1.4rem; }
.feat-properties-list-showcase { padding: 1.25em 0 1em; }
.feat-properties-list-showcase .feat .number span { font-size: 2.2rem; }
.nomad-studios { padding: 2em; }
.nomad-studios-description { padding: .25em 0; }
.tre-tout { padding: 1em 2em; }
.tre-tout-column { min-height: 275px; }
.tout-title span { font-size: 3rem; }
}

@media only screen and (max-width: 1180px) {
.how-it-works-content { min-height: 285px; }
}

@media only screen and (max-width: 1140px) {
.hero-container { padding: 1.5em 2em 2em; }
.home-cta { padding: 2em 2em 3em; }
.how-it-works-content { min-height: 275px; }
.feat-properties-list-title a { font-size: 2.2rem; }
.nomad-studios { padding: 2em 2em 1.5em; }
.nomad-grid { grid-template-columns: repeat(2, 1fr); }
.nomad-grid .tout:nth-of-type(1) { grid-row: 1 / 4; }
.nomad-grid .tout:nth-of-type(2) { grid-row: 1 / 2; }
.nomad-grid .tout:nth-of-type(5) { grid-column: auto; grid-row: 2 / 4; }
}

@media only screen and (max-width: 1080px) {
.how-it-works-content { min-height: 260px; }
.feat-properties-list-grid { grid-template-columns: repeat(2, 1fr); }
}

@media only screen and (max-width: 1024px) {
.home .site-inner { padding-bottom: 2em; }
.home-cta { padding: 1.5em 2em 2.5em; }
.about { padding: 1em 2em; }
.about-content { margin: .25em 0; }
.steps-bg { display: none; }
.steps-bg.tab { display: block; }
.how-it-works { padding: 1.8em 2em; }
.feat-prop { padding: .5em 2em 1.8em; }
.feat-prop-title span { padding: 0 0 .5em; }
.nomad-studios { padding: 1.5em 2em; }
.nomad-studios-content { margin: .25em 0 1em; }
.tre-tout { padding: .5em 2em; }
.tre-tout-column { min-height: 250px; }
.tout-title span { font-size: 2.8rem; }
}

@media only screen and (max-width: 880px) {
.how-it-works-content { min-height: 250px; }
.nomad-studios-content { margin: .25em 0 .8em; }
.tout-title span { font-size: 2.6rem; }
}

@media only screen and (max-width: 820px) {
.how-it-works-content { min-height: 240px; }
}

@media only screen and (max-width: 768px) {
.home .site-inner { padding-bottom: 1.5em; }
.hero-container { padding: 1em 1.5em 1.5em; }
.home-cta { padding: 1em 1.5em 2em; }
.about { padding: .5em 1.5em; }
.about-title span { font-size: 2.6rem; }
.about-description p { font-size: 1.7rem; }
.how-it-works { padding: 1.5em; }
.how-it-works-title span { font-size: 2.6rem; }
.how-it-works-title span:last-of-type { font-size: 1.7rem; }
.steps-bg.tab { display: none; }
.steps-bg.mbl768 { display: block; }
.feat-prop { padding: .5em 1.5em 1.5em; }
.feat-prop-title span { font-size: 2.6rem; }
.feat-properties-list-grid { gap: 20px; }
.feat-properties-list-title a { font-size: 2.1rem; }
.feat-properties-list-showcase .bedrooms.feat { width: calc(1 / 3* 100% - (1 - 1 / 3)* 25px); }
.feat-properties-list-showcase .feat .number span { font-size: 2.1rem; }
.feat-properties-list-showcase .feat .icon { max-width: 28px; }
.nomad-studios { padding: 1.5em 1.5em 1em; }
.nomad-studios-title span { font-size: 2.6rem; }
.nomad-studios-description p { font-size: 1.7rem; }
.nomad-grid { max-height: 975px; }
.nomad-grid .tout:nth-of-type(1) { grid-row: 1/ 2; }
.nomad-grid .tout:nth-of-type(2) { grid-row: 1 / 2; }
.nomad-grid .tout:nth-of-type(5) { grid-column: 1 / 3; grid-row: 3 / 4; order: 1; }
.tre-tout { padding: .5em 1.5em; }
.tre-tout-grid { grid-template-columns: repeat(1, 1fr); gap: 20px; }
.tre-tout-column { min-height: 225px; }
}

@media only screen and (max-width: 719px) {
.about-title span { font-size: 2.4rem; }
.how-it-works-title span { font-size: 2.4rem; }
.how-it-works-content { margin: .5em 0; }
.feat-prop-title span { font-size: 2.4rem; }
.feat-properties-list-grid { gap: 20px; }
.feat-properties-list-grid .feat .number span { font-size: 2rem; }
}

@media only screen and (max-width: 640px) {
.hero-container { padding: 1em 1.5em; }
.hero, .hero-block-slide.slick-slide { height: calc(100vw* 0.46875); }
.home-cta { padding: 1em 1.5em 1.5em; }
.cta-tagline span { font-size: calc(24px + (24 - 18)*((100vw - 420px) /(640 - 420))); }
.about-title span { font-size: 2.2rem; }
.about-description p { font-size: 1.6rem; padding: 0 0 .8em; }
.how-it-works-content { min-height: 225px; }
.how-it-works-title span { font-size: 2.2rem; }
.how-it-works-title span:last-of-type { font-size: 1.6rem; }
.steps-bg.mbl768 { display: none; }
.steps-bg.mbl640 { display: block; }
.feat-prop { padding: .25em 1.5em 1.5em; }
.feat-prop-title span { font-size: 2.2rem; padding: 0 0 .25em; }
.feat-properties-list-grid { grid-template-columns: repeat(1, 1fr); gap: 28px; }
.feat-properties-list-showcase { padding: 1em 0 .5em; }
.nomad-studios { padding: 1em 1.5em .5em; }
.nomad-studios-title span { font-size: 2.2rem; }
.nomad-studios-description p { font-size: 1.6rem; }
.nomad-studios-content { margin: .25em 0 .5em; }
.nomad-grid { grid-template-columns: repeat(1, 1fr); max-height: 1500px; }
.nomad-grid .tout:nth-of-type(1) { grid-row: auto; order: 5; max-height: 325px; }
.nomad-grid .tout:nth-of-type(2) { grid-row: auto; order: 2; }
.nomad-grid .tout:nth-of-type(2) a { font-size: 1.7rem; }
.nomad-grid .tout:nth-of-type(3) { order: 3; max-height: 300px; }
.nomad-grid .tout:nth-of-type(4) { order: 4; max-height: 300px; }
.nomad-grid .tout:nth-of-type(5) { grid-column: auto; grid-row: auto; order: 1; }
.tre-tout { padding: .5em 1.5em; }
.tre-tout-column { min-height: 200px; }
.tout-title span { font-size: 2.5rem; }
}

@media only screen and (max-width: 580px) {
.home .site-inner { padding-bottom: 1em; }
.about-inner { padding: 1em 1.5em; }
.how-it-works { padding: 1.25em 1.5em .8em; }
.how-it-works-title span:last-of-type { padding-top: 0; }
.how-it-works-content { min-height: 215px; }
.feat-prop { padding: .25em 1.5em 1.25em; }
.nomad-grid .tout:nth-of-type(1) { max-height: 300px; }
.tre-tout-column { min-height: 175px; }
.tout-title span { font-size: 2.4rem; }
.tout-button a { font-size: 1.5rem; }
}

@media only screen and (max-width: 520px) {
.about-inner { padding: 1em 1.5em; }
.how-it-works-content { margin: .25em 0; min-height: 200px; }
.feat-prop { padding: .25em 1.5em; }
}

@media only screen and (max-width: 480px) {
.hero-container { padding: .8em 1.2em; }
.home-cta { padding: .8em 1.2em 1em; }
.about { padding: .5em 1.2em; }
.about-inner { padding: .5em 1em; }
.about-title span { font-size: 2rem; }
.about-description p { padding: 0 0 .5em; }
.how-it-works { padding: 1em 1.2em .8em; }
.how-it-works-content { margin: 0; min-height: 860px; }
.how-it-works-title span { font-size: 2rem; }
.steps-bg.mbl640 { display: none; }
.steps-bg.mbl480 { display: block; }
.feat-prop { padding: .5em 1.2em .25em; }
.feat-prop-title span { font-size: 2rem; }
.feat-properties-list-grid { gap: 25px; }
.feat-properties-list-title a { font-size: 2rem; }
.feat-properties-list-subtitle .location-icon { max-width: 20px; }
.feat-properties-list-showcase { padding: .8em 0 .5em; }
.nomad-studios { padding: 1.8em 1.2em .5em; }
.nomad-studios-title span { font-size: 2rem; }
.nomad-studios-description p { padding: 0 0 .5em; }
.nomad-grid { max-height: 1200px; }
.tre-tout { padding: .5em 1.2em; }
.nomad-grid .tout:nth-of-type(1) { max-height: 250px; }
.nomad-grid .tout:nth-of-type(3) { max-height: 250px; }
.nomad-grid .tout:nth-of-type(4) { max-height: 250px; }
.tout-title span { font-size: 2.2rem; }
.tout-button a { font-size: 1.4rem; }
}
