:root {
    --primary-font: 'IBM Plex Sans';
}

html { height: 100%; scroll-behavior: smooth; }

body {
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	background: var(--s-25);
	color: var(--s-900);
	font-size: 16px;
	font-family: var(--primary-font), sans-serif;
	font-weight: 400;
	overflow-y: scroll;
}

* { margin: 0; padding: 0; outline: 0; }

a { color: var(--b-100); text-decoration: none; }
a img { border: 0; }

strong { font-weight: 700; }
input, textarea, button { font-family: var(--primary-font), sans-serif; }

h1, h2, h3, h4, h5 { font-family: var(--primary-font), sans-serif; font-weight: 700; }

::selection { background: var(--b-100); color: var(--s-25); }

#email,
#cta-email,
#footer-email { position: absolute; z-index: -100; width: 1px; height: 1px; opacity: 0; }

.wrap { display: flex; flex-direction: column; position: relative; width: 100%; min-height: 100%; }

.content { display: flex; flex-direction: column; box-sizing: border-box; width: 1200px; max-width: 100%; padding: 0 10px; }
.content.width-700 { width: 700px; }
.content.width-800 { width: 800px; }

.header { display: flex; flex-direction: column; align-items: center; width: 100%; padding: 10px 0; border-bottom: 1px solid var(--s-75); }
.header .content { flex-direction: row; flex-wrap: nowrap; justify-content: space-between; align-items: center; gap: 40px; }
.header .logo { display: flex; }
.header .logo a { display: flex; }
.header .logo img { height: 80px; margin-left: -13px; }
.header .menu { display: flex; }
.header .menu nav { display: flex; }
.header .menu nav ul { display: flex; justify-content: flex-end; align-items: center; gap: 40px; list-style: none; }
.header .menu nav ul li { display: flex; }
.header .menu nav ul li a:not(.button) { transition: color 0.2s ease-in-out; display: flex; color: var(--s-900); font-size: 15px; font-weight: 500; line-height: 18px; text-transform: uppercase; text-align: center; }
.header .menu nav ul li a:not(.button):hover { color: var(--s-900-t60); }

.header.transparent { position: absolute; z-index: 200; top: 0; left: 0; padding: 0; border-bottom: 0; }
.header.transparent .content { align-items: flex-start; }
.header.transparent .logo img { height: 120px; }
.header.transparent .logo a { padding: 24px; background: var(--b-100); }
.header.transparent .menu { padding: 26px 0; }
.header.transparent .menu nav ul li a:not(.button) { color: var(--s-25); }
.header.transparent .menu nav ul li a:not(.button):hover { color: var(--s-25-t80); }

.header .mobile-menu { display: none; margin-right: 15px; background: transparent; border: 0; font-size: 24px; }
.header .menu nav .mobile-menu { position: absolute; top: 30px; right: 10px; color: var(--s-900); }
.header.transparent .mobile-menu { color: var(--s-25); }
.header.transparent .menu nav .mobile-menu { top: 25px; }

.page-container,
.section-container { flex-grow: 1; display: flex; flex-direction: column; align-items: center; width: 100%; }

.hero { display: flex; flex-direction: column; align-items: center; position: relative; z-index: 100; box-sizing: border-box; width: 100%; min-height: 810px; padding: 168px 0 60px 0; background: var(--s-900); }
.hero:after { content: ""; position: absolute; top: 0; left: 0; z-index: 20; width: 100%; height: 100%; background: linear-gradient(180deg, var(--s-900-t60) 0%, var(--s-900-t30) 20%); }
.hero .bg { position: absolute; top: 0; left: 0; z-index: 10; width: 100%; height: 100%; object-fit: cover; }
.hero .content { flex-grow: 1; gap: 30px; position: relative; z-index: 30; }
.hero .title { flex-grow: 1; display: flex; flex-direction: column; justify-content: center; width: 100%; padding: 60px 0; }
.hero .title h1 { color: var(--s-25); font-size: 72px; font-weight: 400; line-height: 86px; letter-spacing: -1.44px; }
.hero .title h1 strong { display: block; }
.hero .search-container { display: flex; flex-direction: column; gap: 30px; width: 100%; }

.page { flex-grow: 1; display: flex; flex-direction: column; align-items: center; width: 100%; padding: 90px 0; }
.page.grey { background: var(--s-50); }
.page-image + .page:not(.grey),
.page:not(.grey) + .page:not(.grey) { padding-top: 0; }
.gallery-container + .page { padding-top: 40px; }

.page .title { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 20px; width: 100%; padding: 10px 0 40px 0; }
.page .title .column { display: flex; flex-direction: column; gap: 10px; }
.page .title .column:nth-child(2) { flex-shrink: 0; }
.page .title h1,
.page .title h2 { font-size: 36px; line-height: 44px; letter-spacing: -0.72px; }
.page .title h1.small { font-size: 30px; line-height: 36px; letter-spacing: -0.6px; }
.page .title .field-item { display: flex; width: 200px; }

.page .title.centered { flex-direction: column; }
.page .title.centered .column { align-items: center; }
.page .title.centered h1,
.page .title.centered h2,
.page .title.centered .tagline { text-align: center; }
.page .title.centered .text-container { align-items: center; text-align: center; }

.filters { display: flex; flex-direction: column; align-items: center; width: 100%; padding: 40px 0; background: var(--s-50); }
.filters .form-bar { padding: 0; background: transparent; }
.filters .content { position: relative; }

.filters-advanced { display: flex; flex-direction: column; align-items: center; position: absolute; z-index: 500; top: 100%; left: 0; width: 100%; margin-top: 10px; }
.filters-advanced:not(.visible) { display: none; }
.filters-advanced .form-container { padding: 20px; background: var(--s-50); border: 1px solid var(--s-75); }
.filters-advanced .form-container .form-item { flex-basis: auto; width: calc(25% - 7.5px); }

.page-head { display: flex; flex-direction: column; align-items: center; width: 100%; padding: 74px 0; background: var(--b-200); }
.page-head h1 { margin-top: 6px; color: var(--s-25); font-size: 48px; line-height: 58px; letter-spacing: -0.96px; }
.page-head .tagline { color: var(--b-75); }

.page-image { display: flex; flex-direction: column; align-items: center; position: relative; width: 100%; padding: 60px 0 50px 0; }
.page-image:before { content: ""; position: absolute; z-index: -10; top: 0; left: 0; width: 100%; height: 226px; background: var(--b-200); }
.page-image img { width: 100%; height: 480px; object-fit: cover; }

.property-head { display: flex; flex-direction: column; align-items: center; width: 100%; padding: 28px 0; }
.property-head .content { gap: 36px; }
.property-head .actions { display: flex; flex-wrap: nowrap; justify-content: space-between; align-items: flex-start; gap: 20px; width: 100%; }
.property-head .actions .column { display: flex; flex-wrap: wrap; gap: 10px 30px; }
.property-head .actions .column:nth-child(2) { justify-content: flex-end; }
.property-head .details { display: flex; flex-direction: column; gap: 8px; width: 100%; }
.property-head .details ul { display: flex; flex-wrap: wrap; gap: 10px 20px; list-style: none; }
.property-head .columns { display: flex; flex-wrap: nowrap; justify-content: space-between; align-items: flex-start; gap: 20px; width: 100%; }
.property-head .columns .column { display: flex; flex-direction: column; gap: 8px; }
.property-head .columns .column:nth-child(2) { flex-shrink: 0; align-items: flex-end; }
.property-head .headline { color: var(--b-100); font-size: 13px; font-weight: 700; line-height: 14px; letter-spacing: 0.48px; text-transform: uppercase; }
.property-head .reference { color: var(--s-600); font-size: 13px; font-weight: 500; line-height: 14px; letter-spacing: 0.96px; text-transform: uppercase; }
.property-head .title { display: flex; flex-direction: column; }
.property-head .title h1 { font-size: 36px; line-height: 44px; letter-spacing: -0.72px; }
.property-head .location { display: flex; flex-wrap: nowrap; align-items: flex-start; gap: 10px; font-weight: 500; line-height: 20px; }
.property-head .location .icon { display: flex; align-items: center; min-height: 20px; color: var(--b-100); }
.property-head .price { display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px; font-size: 36px; font-weight: 700; line-height: 44px; }
.property-head .price .text { font-size: 16px; font-weight: 600; line-height: 20px; }

.gallery-container { display: flex; flex-direction: column; align-items: center; position: relative; width: 100%; height: 480px; margin: 10px 0; overflow: hidden; }
.gallery-container .slider { position: absolute; z-index: 10; top: 0; left: 0; width: 100%; height: 100%; }
.gallery-container .slider .slick-list,
.gallery-container .slider .slick-track { height: 100%; }
.gallery-container .slider .item { display: flex; width: 790px; height: 100%; }
.gallery-container .slider .item .img { display: flex; box-sizing: border-box; width: 100%; height: 100%; padding: 0 5px; }
.gallery-container .slider .item .img img { width: 100%; height: 100%; object-fit: cover; }
.gallery-container .slider-arrows { display: flex; flex-wrap: nowrap; gap: 10px; position: absolute; z-index: 20; bottom: 40px; left: 50%; transform: translateX(-50%); }
.gallery-container .slider-arrows .button { background: var(--s-25-t20); }
.gallery-container .overlay-details { display: flex; flex-wrap: wrap; justify-content: flex-end; align-items: center; gap: 10px; position: absolute; z-index: 20; top: 0; left: 50%; transform: translateX(-50%); box-sizing: border-box; width: 780px; max-width: 100%; padding: 10px; pointer-events: none; }

.form-bar { display: flex; flex-wrap: nowrap; align-items: stretch; gap: 10px; box-sizing: border-box; width: 100%; padding: 10px; background: var(--s-25); }
.form-bar .form-container { flex-grow: 1; align-items: center; width: 0; }
.form-bar .form-container .form-item { flex-basis: auto; width: calc(20% - 8px); }

.form-container { display: flex; flex-wrap: wrap; align-items: stretch; gap: 10px; box-sizing: border-box; width: 100%; }
.form-container .form-item { flex-grow: 1; flex-basis: 300px; display: flex; flex-direction: column; gap: 4px; }
.form-container .form-item.width-full { flex-basis: auto; width: 100%; }
.form-container .form-item .button-item { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 20px; width: 100%; padding-top: 10px; }
.form-container .form-item .checkbox-container { padding: 10px 0; }
.form-container .form-item:has( + .form-item.hidden) .checkbox-container.dynamic-spacing { padding-bottom: 0; }
.form-container .form-item .item-heading { color: var(--s-600); font-size: 14px; line-height: 22px; }
.form-container .form-item .multi-items { display: flex; flex-wrap: wrap; gap: 10px; width: 100%; }
.form-container .form-item .multi-items .multi-item { flex-basis: 100px; flex-grow: 1; }

.text-container { display: flex; flex-direction: column; align-items: flex-start; width: 100%; }
.text-container.justified { text-align: justify; }
.text-container .logo-exclusive { max-width: 100%; height: 28px; margin: 20px 0 32px 0; object-position: center left;  object-fit: contain; }
.text-container h1 { margin: 6px 0 20px 0; font-size: 48px; line-height: 58px; letter-spacing: -0.96px; }
.text-container h1.small { font-size: 30px; line-height: 36px; }
.text-container h2 { margin: 6px 0 20px 0; font-size: 36px; line-height: 44px; letter-spacing: -0.72px; }
.text-container h3 { margin: 6px 0 10px 0; font-size: 24px; line-height: 28px; }
.text-container p { margin-bottom: 15px; line-height: 26px; }
.text-container p:last-child { margin-bottom: 0; }
.text-container .disclaimer { color: var(--s-500); font-size: 14px; line-height: 22px; }
.text-container .button:not(.link) { margin-top: 18px; }
.text-container .buttons { margin-top: 14px; }
.text-container .buttons .button:not(.link) { margin-top: 0; }
.text-container hr { width: 100%; height: 1px; margin: 15px 0 26px 0; background: var(--s-100); border: 0; outline: none; }
.text-container img { width: 100%; }
.text-container figure { width: 100%; margin-bottom: 15px; }
.text-container figure:last-child { margin-bottom: 0; }
.text-container ul,
.text-container ol { margin: 0 0 15px 26px; }
.text-container ol:last-child,
.text-container ul:last-child { margin-bottom: 0; }
.text-container ul li,
.text-container ol li { margin-bottom: 10px; line-height: 22px; }
.text-container ul li:last-child,
.text-container ol li:last-child { margin-bottom: 0; }
.text-container table { width: 100%; margin-bottom: 15px; border-spacing: 0; }
.text-container table:last-child { margin-bottom: 0; }
.text-container table tr th { font-weight: 700; text-align: left; }
.text-container table tr th,
.text-container table tr td { padding: 10px; border-top: 1px solid var(--s-100); border-right: 1px solid var(--s-100); }
.text-container table tr th:first-child,
.text-container table tr td:first-child { border-left: 1px solid var(--s-100); }
.text-container table tr:last-child td { border-bottom: 1px solid var(--s-100); }

.paging { display: flex; justify-content: center; gap: 6px; width: 100%; margin-top: 36px; padding: 10px 0; }
.paging a { display: flex; justify-content: center; align-items: center; box-sizing: border-box; min-width: 48px; min-height: 48px; padding: 6px 10px; background: var(--s-75); color: var(--s-600); font-weight: 600; line-height: 20px; text-align: center; }
.paging a:hover { transition: background 0.2s ease-in-out, color 0.2s ease-in-out; background: var(--s-100); color: var(--s-900); }
.paging a.active { background: var(--b-100); color: var(--s-25); }

.properties-overview { flex-direction: row; flex-wrap: wrap; align-items: stretch; gap: 16px 0; padding: 0; }
.properties-overview .item { display: flex; box-sizing: border-box; width: 33.33%; padding: 10px; }
.properties-overview .box { display: flex; flex-direction: column; position: relative; width: 100%; height: 100%; }
.properties-overview .box a.whole { position: absolute; z-index: 10; top: 0; left: 0; width: 100%; height: 100%; }
.properties-overview .box .image { display: flex; position: relative; width: 100%; height: 240px; overflow: hidden; }
.properties-overview .box .image .img { transition: transform 0.2s ease-in-out; width: 100%; height: 100%; object-fit: cover; }
.properties-overview .box:hover .image .img { transform: scale(1.05); }
.properties-overview .box .image .estatebud-infowindow-close { transition: opacity 0.2s ease-in-out; position: relative; z-index: 20; background: transparent; border: 0; font-size: 20px; color: var(--s-25); cursor: pointer; }
.properties-overview .box .image .estatebud-infowindow-close:hover { opacity: 0.6; }
.properties-overview .box .image .labels { position: relative; z-index: 20; }
.properties-overview .box .image .overlay-details { display: flex; flex-wrap: wrap; justify-content: flex-end; align-items: center; gap: 10px; position: absolute; top: 0; right: 0; box-sizing: border-box; max-width: 100%; padding: 10px; }
.properties-overview .box .image .tag { position: absolute; bottom: 0; left: 0; padding: 3px 10px 3px 0; background: var(--s-25); }
.properties-overview .box .image .tag img { height: 12px; }
.properties-overview .box .details { flex-grow: 1; display: flex; flex-wrap: nowrap; justify-content: space-between; align-items: flex-start; gap: 10px; width: 100%; padding-top: 16px; }
.properties-overview .box .details .column { display: flex; flex-direction: column; gap: 12px; }
.properties-overview .box .details .column:nth-child(2) { align-items: flex-end; gap: 18px; }
.properties-overview .box .details .reference { color: var(--s-300); font-size: 12px; font-weight: 500; line-height: 14px; letter-spacing: 0.96px; text-transform: uppercase; }
.properties-overview .box .details .favorite { position: relative; z-index: 20; }
.properties-overview .box .details .headline { display: flex; flex-direction: column; }
.properties-overview .box .details .headline h3 { color: var(--b-100); font-size: 12px; line-height: 14px; letter-spacing: 0.48px; text-transform: uppercase; }
.properties-overview .box .details .price { display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px; font-size: 24px; font-weight: 700; line-height: 28px; }
.properties-overview .box .details .price .text { font-size: 16px; font-weight: 600; line-height: 20px; }
.properties-overview .box .details .location { display: flex; flex-wrap: nowrap; align-items: flex-start; gap: 10px; font-weight: 500; line-height: 20px; }
.properties-overview .box .details .location .icon { display: flex; align-items: center; min-height: 20px; color: var(--b-100); }
.properties-overview .box .details .specifications { display: flex; width: 100%; }
.properties-overview .box .details .specifications ul { display: flex; flex-wrap: wrap; gap: 10px 20px; width: 100%; list-style: none; }
.properties-overview .box .details .specifications ul li { color: var(--s-600); line-height: 20px; }

.properties-map { display: flex; flex-direction: row; flex-wrap: nowrap; align-items: stretch; width: 100%; height: calc(100vh - 228px); min-height: 600px; padding: 0; }
.properties-map .map { display: flex; position: relative; width: 50%; background: var(--s-200); }
.properties-map .map #map { width: 100%; height: 100%; }
.properties-map .properties-result { display: flex; flex-direction: column; box-sizing: border-box; width: 50%; padding: 50px; overflow-y: auto; }

.estatebud-marker-label { position: absolute; z-index: 150; top: -40px; left: 0; width: 17px; height: 17px; background: var(--s-25); border: 3px solid var(--b-100); border-radius: 50%; color: var(--b-100); font-size: 10px; font-weight: 500; text-align: center; line-height: 16px; overflow: hidden; opacity: 1; cursor: pointer; }

#estatebud-infowindow { position: absolute; z-index: 300; top: 20px; left: 20px; box-sizing: border-box; width: 380px; max-width: calc(100% - 40px); box-shadow: 0 0 10px rgba(0,0,0,0.1); }
#estatebud-infowindow .slick-track { display: flex; align-items: stretch; }
#estatebud-infowindow .properties-overview { width: 100%; height: auto; }
#estatebud-infowindow .properties-overview .item { width: 100%; height: 100%; background: var(--s-25); }
#estatebud-infowindow .estatebud-loader { display: flex; justify-content: center; align-items: center; box-sizing: border-box; width: 100%; height: 394px; background: var(--s-25); color: var(--s-900); font-size: 50px; text-align: center; }
#estatebud-infowindow .estatebud-loader svg { animation: loading-spin 1s infinite; }

#estatebud-infowindow .estatebud-infowindow-footer { box-sizing: border-box; display: flex; flex-wrap: nowrap; justify-content: space-between; align-items: center; width: 100%; padding: 20px; background: var(--s-50); }
#estatebud-infowindow .estatebud-infowindow-footer .estatebud-right-arrow,
#estatebud-infowindow .estatebud-infowindow-footer .estatebud-left-arrow { transition: color 0.3s ease-in-out; cursor: pointer; }
#estatebud-infowindow .estatebud-infowindow-footer .estatebud-right-arrow:hover,
#estatebud-infowindow .estatebud-infowindow-footer .estatebud-left-arrow:hover { color: var(--s-900); }

.image-box { display: flex; flex-wrap: nowrap; align-items: stretch; width: 100%; padding: 10px 0; }
.image-box .details { display: flex; flex-direction: column; box-sizing: border-box; width: 500px; max-width: 100%; padding: 60px; background: var(--s-50); }
.image-box .image { flex-grow: 1; display: flex; width: 0; }
.image-box .image img { width: 100%; height: 100%; object-fit: cover; }

.image-panel { display: flex; flex-wrap: nowrap; justify-content: space-between; align-items: center; gap: 60px; width: 100%; padding: 10px 0; }
.title + .image-panel { padding-top: 40px; }
.image-panel .panel-content { display: flex; flex-direction: column; width: 580px; max-width: 100%; }
.image-panel .panel-image { width: 100%; }
.image-panel aside { display: flex; flex-direction: column; width: 480px; }

.panel-container { display: flex; flex-wrap: nowrap; justify-content: space-between; align-items: stretch; gap: 40px; width: 100%; }
.panel-container .panel-content { flex-grow: 1; display: flex; flex-direction: column; width: 0; }
.panel-container .panel-content.width-680 { max-width: 680px; }
.panel-container aside { flex-shrink: 0; display: flex; flex-direction: column; width: 380px; max-width: 100%; }
.panel-container aside.sticky .content-item { position: sticky; top: 40px; }
.panel-container aside .content-item .text-container:last-child { flex-grow: 1; justify-content: flex-end; padding-top: 20px; }
.panel-container:not(:has(aside.sticky)) .content-item,
.panel-container:not(:has(aside.sticky)) .content-box { flex-grow: 1; }
.panel-container .content-item { display: flex; flex-direction: column; width: 100%; margin-bottom: 50px; }
.panel-container .content-item:last-child { margin-bottom: 0; }
.panel-container .content-headline { display: flex; flex-direction: column; width: 100%; margin-bottom: 14px; }
.panel-container .content-headline h1 { font-size: 48px; line-height: 58px; letter-spacing: -0.96px; }
.panel-container .content-headline h2 { font-size: 30px; line-height: 36px; letter-spacing: -0.6px; }

.content-box { display: flex; flex-direction: column; box-sizing: border-box; width: 100%; padding: 30px; margin: 10px 0; border: 1px solid var(--s-100); }
.content-box + .content-box { margin-top: 0; }
.content-box.grey { background: var(--s-50); border-color: var(--s-50); }

.specifications-container { display: flex; flex-direction: column; width: 100%; }
.specifications-container ul { display: flex; flex-wrap: wrap; gap: 20px; width: 100%; list-style: none; }
.specifications-container ul li { display: flex; flex-direction: column; gap: 6px; width: calc(25% - 15px); }
.specifications-container ul li .headline { color: var(--s-600); line-height: 26px; }
.specifications-container ul li .details { display: flex; flex-wrap: nowrap; align-items: flex-start; gap: 16px; font-size: 24px; }
.specifications-container ul li .details .icon { display: flex; align-items: center; min-height: 28px; color: var(--b-100); }
.specifications-container ul li .details .value { font-weight: 700; line-height: 28px; }

.simple-specifications-container { display: flex; flex-direction: column; width: 100%; }
.simple-specifications-container ul { column-count: 3; gap: 0 20px; width: 100%; list-style: none; }
.simple-specifications-container ul li { break-inside: avoid; display: flex; flex-wrap: nowrap; align-items: flex-start; gap: 6px; width: 100%; padding: 6px 0; }
.simple-specifications-container ul li .headline { flex-shrink: 0; color: var(--s-600); line-height: 20px; }
.simple-specifications-container ul li .value { font-weight: 500; line-height: 20px; }

.list-container { display: flex; flex-direction: column; width: 100%; }
.list-container ul { column-count: 2; gap: 0 20px; width: 100%; list-style: none; }
.list-container ul li { break-inside: avoid; display: flex; flex-wrap: nowrap; align-items: flex-start; gap: 6px; width: 100%; padding: 6px 0; font-weight: 500; line-height: 20px; }

.video-container { display: flex; width: 100%; height: 420px; margin: 10px 0; background: var(--s-200); }
.video-container iframe { width: 100%; height: 100%; }

.map-container { display: flex; flex-direction: column; gap: 15px; position: relative; width: 100%; margin: 50px 0 10px 0; }
.map-container .map { width: 100%; height: 420px; background: var(--s-200); border-top: 1px solid var(--s-100); }
.map-container .details { display: flex; flex-direction: column; gap: 10px; position: absolute; z-index: 10; top: 30px; right: 30px; box-sizing: border-box; width: 240px; max-width: calc(100% - 60px); padding: 20px; background: var(--s-25); }
.map-container .details ul { display: flex; flex-direction: column; gap: 10px; list-style: none; }
.map-container .details ul li { color: var(--s-600); font-weight: 500; line-height: 22px; }

.floor-plans-container { display: flex; flex-wrap: wrap; align-items: stretch; gap: 20px; width: 100%; padding: 10px 0; }
.floor-plans-container .item { display: flex; box-sizing: border-box; width: calc(50% - 10px); padding: 20px; border: 1px solid var(--s-100); }
.floor-plans-container .item .img { display: flex; width: 100%; height: 100%; }
.floor-plans-container .item .img img { width: 100%; height: 100%; object-fit: contain; }

.table-container { display: flex; flex-direction: column; width: 100%; overflow: auto; }
table.table tr th,
table.table tr td { padding: 12px 10px; border-bottom: 1px solid var(--s-100); line-height: 22px; }
table.table tr:last-child td { border-bottom: 0; }
table.table tr th:first-child,
table.table tr td:first-child { padding-left: 0; }
table.table tr th:last-child,
table.table tr td:last-child { padding-right: 0; }
table.table tr th { color: var(--s-600); font-weight: 400; }

.services-container { display: flex; flex-direction: row; flex-wrap: wrap; align-items: stretch; padding: 0; }
.services-container .item { flex-grow: 1; flex-basis: 340px; display: flex; box-sizing: border-box; padding: 10px; }
.services-container.columns-2 .item { flex-basis: 540px; }
.services-container .box { display: flex; flex-direction: column; gap: 32px; box-sizing: border-box; width: 100%; height: 100%; padding: 40px; background: var(--s-25); }
.services-container .box .box-icon { display: flex; color: var(--b-100); font-size: 36px; }
.services-container .box .details { display: flex; flex-direction: column; gap: 16px; width: 100%; }
.services-container .box .details h3 { font-size: 24px; line-height: 28px; letter-spacing: -0.48px; }
.services-container .box .details p { line-height: 26px; }

.services-container.centered .box { align-items: center; text-align: center; }
.services-container.centered .box .details { gap: 6px; }
.services-container.centered .box .details p { color: var(--s-600); }

.team-overview { display: flex; flex-direction: row; flex-wrap: wrap; gap: 16px 0; padding: 0; }
.team-overview .item { display: flex; flex-direction: column; gap: 12px; box-sizing: border-box; width: 25%; padding: 10px; }
.team-overview .item .image { display: flex; width: 100%; height: 320px; background: var(--s-100); }
.team-overview .item .image img { width: 100%; height: 100%; object-fit: cover; }
.team-overview .item .details { display: flex; flex-direction: column; gap: 10px; width: 100%; }
.team-overview .item .details h3 { font-size: 24px; line-height: 28px; }
.team-overview .item .details p { font-weight: 500; line-height: 20px; }
.team-overview .item .details .button { margin-top: 4px; }

.articles-overview { flex-direction: row; flex-wrap: wrap; align-items: stretch; gap: 16px 0; padding: 0; }
.articles-overview .item { display: flex; box-sizing: border-box; width: 33.33%; padding: 10px; }
.articles-overview .box { display: flex; flex-direction: column; position: relative; width: 100%; height: 100%; }
.articles-overview .box a.whole { position: absolute; z-index: 10; top: 0; left: 0; width: 100%; height: 100%; }
.articles-overview .box .image { display: flex; position: relative; width: 100%; height: 240px; overflow: hidden; }
.articles-overview .box .image img { transition: transform 0.2s ease-in-out; width: 100%; height: 100%; object-fit: cover; }
.articles-overview .box:hover .image img { transform: scale(1.05); }
.articles-overview .box .details { flex-grow: 1; display: flex; flex-wrap: nowrap; justify-content: space-between; align-items: flex-start; gap: 10px; width: 100%; padding-top: 16px; }
.articles-overview .box .details h3 { font-size: 20px; line-height: 24px; }

.share-container { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 20px; width: 100%; margin-top: 34px; padding: 40px 0 10px 0; border-top: 1px solid var(--s-75); }
.share-container span { font-weight: 700; line-height: 20px; }
.share-container a { transition: color 0.2s ease-in-out; display: flex; align-items: center; color: var(--s-300); font-size: 20px; }
.share-container a:hover { color: var(--s-900); }

.loading-container { flex-grow: 1; display: flex; justify-content: center; align-items: center; box-sizing: border-box; width: 100%; padding: 40px 0; color: var(--s-200); font-size: 60px; }
.loading-container svg { animation: loading-spin 1s infinite; }

.cta { display: flex; flex-direction: column; align-items: center; position: relative; width: 100%; padding: 100px 0; background: var(--b-100); overflow: hidden; }
.cta .bg { position: absolute; z-index: 10; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 1180px; max-width: 100%; object-fit: contain; }
.cta .bg.logo { transform: translate(-57.5%, -57.5%); width: 1390px; }
.cta .content { position: relative; z-index: 20; gap: 30px; }
.cta .title { display: flex; flex-direction: column; align-items: center; gap: 10px; text-align: center; }
.cta .title .tagline { color: var(--b-75); }
.cta .title h4 { color: var(--s-25); font-size: 36px; line-height: 44px; letter-spacing: -0.72px; }
.cta .button { align-self: center; }
.cta .success { color: var(--s-25); }

.cta.grey { background: var(--s-75); }
.cta.grey .title .tagline { color: var(--s-400); }
.cta.grey .title h4 { color: var(--s-900); }
.cta.grey .success { color: var(--s-900); }

footer { display: flex; flex-direction: column; width: 100%; }

.footer { display: flex; flex-direction: column; align-items: center; width: 100%; }
.footer .columns { display: flex; flex-wrap: nowrap; justify-content: space-between; gap: 60px; width: 100%; padding: 95px 0 158px 0; }
.footer .columns .column { display: flex; flex-direction: column; gap: 30px; }
.footer .bottom { display: flex; flex-wrap: nowrap; justify-content: space-between; gap: 20px; width: 100%; padding-bottom: 58px; }
.footer .bottom .column { display: flex; flex-direction: column; gap: 26px; }
.footer .bottom .column:nth-child(2) { align-items: flex-end; }
.footer .bottom .column .item { display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px; }
.footer .bottom .headline { display: flex; flex-wrap: nowrap; align-items: flex-start; gap: 8px; color: var(--s-900); font-size: 16px; font-weight: 700; line-height: 20px; }
.footer .bottom .headline .icon { color: var(--b-100); }
.footer .bottom ul { display: flex; flex-wrap: wrap; gap: 20px; list-style: none; }
.footer .bottom .column:nth-child(2) ul { justify-content: flex-end; }
.footer .bottom ul li { display: flex; align-items: center; }
.footer .bottom ul li,
.footer .bottom ul li a { transition: color 0.2s ease-in-out; color: var(--s-600); font-size: 14px; line-height: 16px; }
.footer .bottom ul.socials li a { display: flex; align-items: center; color: var(--s-300); font-size: 18px; }
.footer .bottom ul li a:hover { color: var(--s-900); }
.footer .logo { display: flex; padding-top: 5px; }
.footer .logo a { display: flex; }
.footer .logo img { height: 142px; margin-left: -15px; }
.footer .title { display: flex; flex-direction: column; }
.footer .title h5 { font-size: 24px; line-height: 28px; letter-spacing: -0.48px; }
.footer .list { display: flex; }
.footer .list ul { display: flex; flex-direction: column; gap: 22px; list-style: none; }
.footer .list ul li,
.footer .list ul li a { color: var(--s-900); font-size: 15px; font-weight: 500; line-height: 18px; text-transform: uppercase; }
.footer .list ul li a:hover { text-decoration: underline; }
.footer .success,
.footer .form-container { width: 380px; max-width: 100%; margin-top: 4px; }
.footer .form-container .form-item:not(.width-full) { flex-basis: 180px; }

.original-price { text-decoration: line-through; }

.tagline { color: var(--s-300); font-size: 12px; font-weight: 700; line-height: 14px; letter-spacing: 2.4px; text-transform: uppercase; }

.labels { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 4px; max-width: 100%; }
.label { display: flex; padding: 5px 8px; background: var(--s-900); color: var(--s-25); font-size: 12px; font-weight: 700; line-height: 14px; text-transform: uppercase; }

.favorite { transition: color 0.2s ease-in-out; display: flex; background: transparent; border: 0; color: var(--s-200); font-size: 24px; cursor: pointer; }
.favorite:hover { color: var(--s-300); }
.favorite.active { color: var(--b-300); }
.favorite.active:hover { color: var(--b-400); }
.button.favorite.active .icon { color: var(--b-300); }
.button.favorite.active:hover { text-decoration: line-through; }
.button.favorite.active:hover .icon { color: var(--b-400); }

.dropdown-container { display: flex; position: relative; }
.dropdown-container .dropdown { display: none; position: absolute; z-index: 400; top: 100%; left: 0; min-width: 100%; padding-top: 10px; }
.dropdown-container .button:hover + .dropdown,
.dropdown-container .dropdown:hover { display: flex; }
.dropdown-container .dropdown ul { display: flex; flex-direction: column; box-sizing: border-box; width: 100%; background: var(--s-25); border: 1px solid var(--s-75); }
.dropdown-container .dropdown ul li { display: flex; width: 100%; }
.dropdown-container .dropdown ul li a { transition: color 0.2s ease-in-out; display: flex; flex-wrap: nowrap; box-sizing: border-box; gap: 12px; width: 100%; padding: 12px 16px; color: var(--s-600); font-weight: 600; line-height: 24px; }
.dropdown-container .dropdown ul li a:hover { color: var(--s-900); }
.dropdown-container .dropdown ul li .icon { display: flex; align-items: center; min-height: 24px; }

.tabs { display: flex; flex-wrap: nowrap; align-items: stretch; gap: 30px; width: 100%; }
.tabs .item { display: flex; }
.tabs .item .tab { transition: border-color 0.2s ease-in-out; display: flex; justify-content: center; align-items: center; padding-bottom: 10px; border-bottom: 2px solid transparent; color: var(--s-25); font-size: 18px; font-weight: 600; line-height: 22px; text-align: center; cursor: pointer; user-select: none; }
.tabs .item .tab:hover { border-color: var(--s-300); }
.tabs .item input { display: none; }
.tabs .item input:checked + .tab { border-color: var(--b-100); }

.checkbox-container { display: flex; flex-wrap: nowrap; align-items: flex-start; }
.checkbox-container input { display: none; }
.checkbox-container .checkbox { flex-shrink: 0; display: flex; justify-content: center; align-items: center; box-sizing: border-box; width: 24px; height: 24px; background: var(--s-25); border: 1px solid var(--s-100); cursor: pointer; }
.checkbox-container .checkbox span { display: none; font-size: 14px; }
.checkbox-container .checkbox:hover,
.checkbox-container:has(.checkbox-label:hover) input:not(:checked):not(.error) + .checkbox { border-color: var(--s-200); }
.checkbox-container input.error + .checkbox { border-color: var(--error); }
.checkbox-container .checkbox:hover span,
.checkbox-container:has(.checkbox-label:hover) input:not(:checked) + .checkbox span { display: block; color: var(--s-200); }
.checkbox-container input:checked + .checkbox { background: var(--s-900); border-color: var(--s-900); }
.checkbox-container input:checked + .checkbox span { display: block; color: var(--s-25); }
.checkbox-container .checkbox-label { margin-top: 2px; padding-left: 12px; font-size: 14px; user-select: none; cursor: pointer; }
.checkbox-container .checkbox-label a { color: var(--s-900); text-decoration: underline; }

.buttons { display: flex; flex-wrap: wrap; align-items: center; gap: 20px; }
.buttons.vertical { flex-direction: column; align-items: flex-start; }

.button { transition: background 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.2s ease-in-out; align-self: flex-start; flex-shrink: 0; display: flex; flex-wrap: nowrap; justify-content: center; align-items: center; gap: 12px; box-sizing: border-box; min-height: 48px; padding: 6px 20px; background: var(--b-100); border: 1px solid var(--b-100); color: var(--s-25); font-size: 16px; font-weight: 600; line-height: 20px; text-align: center; cursor: pointer; }
.button:hover { background: var(--b-200); border-color: var(--b-200); }
.button.icon { min-width: 48px; padding: 6px; }
.button.small { gap: 10px; min-height: 36px; padding: 6px 16px; }
.button.width-full { width: 100%; }

.button.white { background: var(--s-25); border-color: var(--s-25); color: var(--s-900); }
.button.white:hover { background: var(--s-75); border-color: var(--s-75); }

.button.white-outlined { background: var(--s-25); border-color: var(--s-100); color: var(--s-900); }
.button.white-outlined:hover { background: var(--s-75); border-color: var(--s-200); }

.button.grey-light { background: var(--s-75); border-color: var(--s-75); color: var(--s-600); }
.button.grey-light:hover { background: var(--s-200); border-color: var(--s-200); color: var(--s-900); }

.button.brand-whatsapp { background: transparent; border-color: var(--b-whatsapp-100); color: var(--b-whatsapp-100); font-weight: 500; }
.button.brand-whatsapp:hover { background: var(--b-whatsapp-100); border-color: var(--b-whatsapp-100); color: var(--s-25); }
.button.brand-whatsapp .icon { font-size: 20px; }

.button.link { justify-content: flex-start; min-height: 0; padding: 0; text-align: left; background: transparent; border: 0; color: var(--b-100); }
.button.link:hover { background: transparent; color: var(--b-200); }

.button.link.white { color: var(--s-25); }
.button.link.white:hover { color: var(--s-75); }

.button.link.grey-light { color: var(--s-600); }
.button.link.grey-light:hover { color: var(--s-900); }

.button .icon { transition: color 0.2s ease-in-out; display: flex; }
.button .icon.primary { color: var(--b-100); }
.button:hover .icon.primary { color: var(--b-200); }
.button .icon.secondary { color: var(--b-300); }
.button:hover .icon.secondary { color: var(--b-400); }

.input { box-sizing: border-box; width: 100%; height: 48px; padding: 0 16px; background: var(--s-25); border: 1px solid var(--s-100); color: var(--s-900); font-size: 16px; }
.input:hover { border-color: var(--s-200); }
.input.error { border-color: var(--error); }
.input:focus { border-color: transparent; outline: 2px solid var(--s-900); }
.input::placeholder { color: var(--s-400); opacity: 1; }
.input::-webkit-calendar-picker-indicator { cursor: pointer; }

.textarea { box-sizing: border-box; width: 100%; height: 105px; padding: 12px 16px; background: var(--s-25); border: 1px solid var(--s-100); color: var(--s-900); font-size: 16px; resize: none; }
.textarea:hover { border-color: var(--s-200); }
.textarea.error { border-color: var(--error); }
.textarea:focus { border-color: transparent; outline: 2px solid var(--s-900); }
.textarea::placeholder { color: var(--s-400); opacity: 1; }
.textarea.height-124 { height: 124px; }
.textarea.height-144 { height: 144px; }

.select { height: 48px; }

.success { display: none; width: 100%; height: 100%; }
.success .success-inner { display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 20px; width: 100%; height: 100%; font-weight: 600; line-height: 24px; text-align: center; }
.success .success-inner .icon { font-size: 40px; }

[data-collapsed] { max-height: 312px; overflow: hidden; column-count: 1; }

.fancybox-show-thumbs .fancybox-inner { right: 0; bottom: 104px; }
.fancybox-thumbs.fancybox-thumbs-x { top: auto; width: 100%; background: transparent; text-align: center; }
.fancybox-thumbs.fancybox-thumbs-x .fancybox-thumbs__list { display: inline-block; }
.fancybox-thumbs.fancybox-thumbs-x .fancybox-thumbs__list a::before { border: 2px solid var(--b-100); }

.hidden { display: none !important; }
.preload { display: none; }

@keyframes loading-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@media (max-height: 810px) {
    .hero { min-height: 90vh; }
}

@media (max-width: 1920px) {
    .properties-map .properties-overview .item { width: 50%; }
}

@media (max-width: 1400px) {
    .properties-map { flex-direction: column; height: auto; min-height: none; }
    .properties-map .map { width: 100%; height: 40vw; min-height: 300px; }
    .properties-map .properties-result { align-items: center; width: 100%; padding: 50px 0; }
    .properties-map .properties-overview .item { width: 33.33%; }
    
    .dropdown-container .dropdown { left: auto; right: 0; }
}

@media (max-width: 1000px) {
    .header .logo img { height: 64px; margin-left: -10.4px; }
    
    .header .menu nav { justify-content: flex-end; position: fixed; z-index: 900; top: 0; left: 0; width: 100%; height: 100%; background: var(--s-900-t60); }
    .header .menu:not(.visible) nav { display: none; }
    .header .menu nav ul { flex-direction: column; justify-content: flex-start; align-items: flex-start; gap: 0; box-sizing: border-box; width: 400px; max-width: 80%; height: 100%; padding-top: 85px; background: var(--s-25); overflow: auto; }
    .header .menu nav ul li { box-sizing: border-box; width: 100%; }
    .header .menu nav ul li:has(.button) { padding: 12px 16px; }
    .header .menu nav ul li a:not(.button) { box-sizing: border-box; width: 100%; padding: 12px 16px; color: var(--s-900); text-align: left; }
    .header .menu nav ul li a:not(.button):hover { color: var(--s-900); }
    
    .header.transparent .logo img { height: 96px; }
    .header.transparent .logo a { padding: 19.2px; }
    .header.transparent .menu nav ul li a:not(.button),
    .header.transparent .menu nav ul li a:not(.button):hover { color: var(--s-900); }
    
    .header .mobile-menu { display: flex; }
    
    .hero { min-height: 600px; padding: 134px 0 40px 0; }
    .hero .title { padding: 40px 0; }
    .hero .title h1 { font-size: 40px; line-height: 48px; letter-spacing: -0.8px; }
    
    .filters-advanced .form-container .form-item { width: calc(50% - 5px); }
    
    .form-bar { flex-wrap: wrap; }
    .form-bar .form-container { width: 100%; }
    .form-bar .button:not(.icon) { flex-grow: 1; }
    
    .page-head { padding: 30px 0; }
    .page-head h1 { font-size: 26px; line-height: 34px; letter-spacing: -0.3px; }
    
    .page-image { padding: 10px 0 30px 0; }
    .page-image:before { height: 20vw; }
    .page-image img { height: 40vw; }
    
    .page { padding: 40px 0; }
    
    .page .title { padding-bottom: 20px; }
    .page .title .column { gap: 4px; }
    .page .title h1,
    .page .title h2 { font-size: 26px; line-height: 34px; letter-spacing: -0.3px; }
    .page .title h1.small { font-size: 24px; line-height: 32px; letter-spacing: -0.3px; }
    
    .text-container h1 { font-size: 34px; line-height: 44px; letter-spacing: -0.4px; }
    .text-container h1.small { font-size: 26px; line-height: 34px; letter-spacing: -0.3px; }
    .text-container h2 { font-size: 28px; line-height: 36px; letter-spacing: -0.3px; }
    .text-container h3 { font-size: 20px; line-height: 24px; }
    
    .properties-overview .item,
    .properties-map .properties-overview .item { width: 50%; }
    .properties-overview .box .image { height: 30vw; }
    
    .team-overview .item { width: 50%; }
    .team-overview .item .image { height: 110vw; max-height: 320px; }
    .team-overview .item .details h3 { font-size: 22px; line-height: 26px; }
    
    .articles-overview .item { width: 50%; }
    .articles-overview .box .image { height: 30vw; }
    
    .image-box { flex-direction: column; }
    .image-box .details { width: 100%; padding: 40px; }
    .image-box .image { width: 100%; }
    
    .image-panel { flex-direction: column; gap: 30px; }
    .image-panel .panel-content { order: 2; width: 100%; }
    .image-panel aside { order: 1; width: 100%; }
    
    .specifications-container ul li .details { display: flex; flex-wrap: nowrap; align-items: flex-start; gap: 16px; font-size: 20px; }
    .specifications-container ul li .details .icon { min-height: 24px; }
    .specifications-container ul li .details .value { line-height: 24px; }
    
    .panel-container { flex-direction: column; }
    .panel-container .panel-content { width: 100%; }
    .panel-container .panel-content.width-680 { max-width: 100%; }
    .panel-container aside { width: 100%; }
    .panel-container .content-headline h1 { font-size: 34px; line-height: 44px; letter-spacing: -0.4px; }
    .panel-container .content-headline h2 { font-size: 22px; line-height: 30px; letter-spacing: -0.3px; }
    
    .map-container .map { height: 360px; }
    .map-container .details { top: 20px; right: 20px; max-width: calc(100% - 40px); }
    
    .properties-map { padding: 0; }
    
    .property-head .actions { flex-direction: column; }
    .property-head .actions .column { justify-content: center; width: 100%; }
    .property-head .actions .column:nth-child(2) { justify-content: center; }
    .property-head .details ul { justify-content: center; text-align: center; }
    .property-head .columns { flex-direction: column; }
    .property-head .columns .column { align-items: center; width: 100%; }
    .property-head .columns .column:nth-child(2) { align-items: center; }
    .property-head .title h1 { font-size: 28px; line-height: 36px; letter-spacing: -0.3px; text-align: center; }
    .property-head .location { justify-content: center; text-align: center; }
    .property-head .price { justify-content: center; font-size: 28px; line-height: 36px; text-align: center; }
    
    .gallery-container { height: 60vw; }
    .gallery-container .slider-arrows { bottom: 20px; }
    
    .cta { padding: 60px 0; }
    .cta .title { gap: 4px; }
    .cta .title h4 { font-size: 28px; line-height: 30px; letter-spacing: -0.3px; }
    
    .footer .logo img { height: 113.6px; margin-left: -12px; }
    .footer .columns { flex-direction: column; gap: 30px; padding: 40px 0 60px 0; }
    .footer .columns .column { align-items: center; gap: 20px; width: 100%; }
    .footer .title h5 { font-size: 20px; line-height: 24px; letter-spacing: -0.3px; text-align: center; }
    .footer .list ul { align-items: center; }
    .footer .list ul li,
    .footer .list ul li a { text-align: center; }
    .footer .bottom { flex-direction: column; }
    .footer .bottom .headline { justify-content: center; text-align: center; }
    .footer .bottom .column { align-items: center; gap: 10px; width: 100%; }
    .footer .bottom .column:nth-child(2) { align-items: center; }
    .footer .bottom .column:nth-child(2) ul { justify-content: center; }
    .footer .bottom .column .item { justify-content: center; }
    .footer .bottom ul { justify-content: center; gap: 10px 20px; }
    .footer .bottom ul li, 
    .footer .bottom ul li a { text-align: center; }
    
    .dropdown-container .dropdown { right: auto; left: 50%; transform: translateX(-50%); }
}

@media (max-width: 800px) {
    .form-bar .form-container .form-item { width: calc(50% - 5px); }
}

@media (max-width: 700px) {
    .specifications-container ul li { width: calc(33.33% - 13.33px); }
    .simple-specifications-container ul { column-count: 2; }
}

@media (max-width: 600px) {
    .properties-overview .item,
    .properties-map .properties-overview .item { width: 100%; }
    .properties-overview .box .image { height: 60vw; }
    
    .team-overview .item { width: 100%; }
    
    .articles-overview .item { width: 100%; }
    .articles-overview .box .image { height: 60vw; }
    
    .form-container .form-item .button-item { flex-direction: column; align-items: flex-start; }
    .form-container .form-item .button { width: 100%; }
}

@media (max-width: 440px) {
    .specifications-container ul li { width: calc(50% - 10px); }
    .simple-specifications-container ul { column-count: 1; }
    
    .floor-plans-container .item { width: 100%; }
}

@media (max-width: 400px) {
    .filters-advanced .form-container .form-item { width: 100%; }
    
    .form-bar .form-container .form-item { width: 100%; }
}

@media (max-width: 340px) {
    .list-container ul { column-count: 1; }
}

@media (max-width: 300px) {
    .specifications-container ul li { width: 100%; }
}