:root {
    --primary-font: 'Jost';
}

html { height: 100%; }

body {
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	background: var(--s-25);
	color: var(--s-500);
	font-size: 17px;
	font-family: var(--primary-font), sans-serif;
	font-weight: 400;
}

* { margin: 0; padding: 0; outline: 0; -webkit-tap-highlight-color: transparent; }

a { color: var(--b-100); text-decoration: none; }
a img { border: 0; }

h1, h2, h3, h4, h5 { font-family: var(--primary-font), sans-serif; font-weight: 600; }

strong, b { font-family: var(--primary-font), sans-serif; font-weight: 600; }
input, textarea, button { font-family: var(--primary-font), sans-serif; font-size: 17px; }
input[type="number"] { appearance: textfield; }

#email,
#newsletter_email { position: absolute; top: 0; left: 0; z-index: -100; width: 1px; height: 1px; opacity: 0; }

.wrap { display: flex; flex-direction: column; 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-1000 { width: 1000px; }
.content.width-800 { width: 800px; }

.header { flex-shrink: 0; display: flex; flex-direction: column; width: 100%; height: 150px; }
.header .inner { display: flex; flex-direction: column; position: fixed; z-index: 900; top: 0; left: 0; width: 100%; }
.header .content { flex-direction: row; flex-wrap: nowrap; justify-content: space-between; align-items: center; gap: 20px; }
.header .bar { display: flex; flex-direction: column; align-items: center; width: 100%; padding: 9px 0; background: var(--b-100); }
.header .main { display: flex; flex-direction: column; align-items: center; width: 100%; padding: 20px 0 30px 0; background: var(--s-25); }
.header .main .content { align-items: flex-end; }
.header .logo,
.header .logo a { display: flex; }
.header .logo img { height: 60px; }
.header .menu { display: flex; flex-wrap: nowrap; align-items: center; position: relative; }
.header .menu nav { display: flex; flex-wrap: nowrap; }
.header .menu nav ul { display: flex; flex-wrap: nowrap; align-items: center; gap: 40px; }
.header .menu nav ul li { position: relative; }
.header .menu nav ul li,
.header .menu nav ul li a:not(.button) { transition: border-color 0.2s ease-in-out; display: flex; flex-wrap: nowrap; justify-content: center; align-items: center; color: var(--b-100); font-size: 17px; font-weight: 500; line-height: 20px; text-align: center; }
.header .menu nav ul li a:not(.button) { padding: 9px 0; border-bottom: 2px solid transparent; }
.header .menu nav ul li:hover a:not(.button) { border-color: var(--s-200); }
.header .menu nav ul li.active a:not(.button) { border-color: var(--b-300); }
.header .menu nav ul li a:not(.button).icon { font-size: 18px; }
.header .menu nav ul li .arrow { flex-shrink: 0; margin-left: 8px; color: var(--s-300); font-size: 12px; }
.header .menu nav .submenu { position: absolute; z-index: 500; top: 100%; left: 0; display: none; padding-top: 20px; }
.header .menu nav ul li a:hover + .submenu,
.header .menu nav .submenu:hover { display: flex; }
.header .menu nav .submenu ul { flex-direction: column; align-items: flex-start; gap: 10px; padding: 18px; background: var(--s-25); border: 1px solid var(--s-100); border-radius: 4px; }
.header .menu nav .submenu ul li,
.header .menu nav .submenu ul li button,
.header .menu nav .submenu ul li a:not(.button) { justify-content: flex-start; width: 100%; padding: 0; text-align: left; white-space: nowrap; }
.header .menu nav .submenu ul li a:not(.button) { border-bottom: 0; }
.header .menu nav .submenu ul li button { background: transparent; border: 0; color: var(--b-100); font-weight: 500; cursor: pointer; }

.header .mobile-menu { display: none; align-items: center; height: 40px; margin-right: 10px; background: transparent; border: 0; font-size: 24px; cursor: pointer; }
.header .menu .mobile-menu { position: absolute; z-index: 10; top: 30px; right: 10px; }

.page-container,
.sections-container { flex-grow: 1; display: flex; flex-direction: column; width: 100%; }

.page-title { display: flex; flex-direction: column; align-items: center; box-sizing: border-box; width: 100%; padding: 40px 0; min-height: 116px; background: var(--b-100); }
.page-title h1 { padding-left: 20px; border-left: 6px solid var(--b-300); color: var(--s-25); font-size: 30px; font-weight: 700; line-height: 36px; text-transform: uppercase; }

.page { flex-grow: 1; display: flex; flex-direction: column; align-items: center; width: 100%; padding: 70px 0; }
.page.grey { background: var(--s-50-t50); }
.projects-map + .page { padding-top: 50px; }
.page-title:empty + .page { padding-top: 0; }
.page-title:empty + .page .content:first-child { margin-top: -56px; }

.page .title { display: flex; flex-direction: column; align-items: center; width: 100%; margin-bottom: 20px; }
.page .content:last-child .title:last-child { margin-bottom: 0; }
.page .title:has(.columns .column) { margin-bottom: 10px; }
.page .title h1,
.page .title h2 { color: var(--b-100); font-size: 30px; line-height: 36px; text-align: center; }
.page .title h3 { color: var(--b-100); font-size: 24px; line-height: 28px; text-align: center; }
.page .title p { margin-top: 14px; line-height: 28px; text-align: justify; }
.page .title .columns { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 0 20px; width: 100%; }
.page .title .columns .column { display: flex; align-items: center; gap: 10px 20px; max-width: 100%; min-height: 48px; }
.page .title .columns h1,
.page .title .columns h2,
.page .title .columns h3 { text-align: left; }
.page .title .button { align-self: center; }

.page .title-detailed { display: flex; flex-wrap: nowrap; justify-content: space-between; align-items: flex-start; gap: 20px; width: 100%; margin-bottom: 36px; }
.page .title-detailed .column { display: flex; flex-direction: column; gap: 10px; }
.page .title-detailed .column:nth-child(2) { align-items: flex-end; }
.page .title-detailed .headline { display: flex; }
.page .title-detailed .headline h1 { color: var(--b-100); font-size: 30px; line-height: 36px; }
.page .title-detailed .location { display: flex; flex-wrap: nowrap; align-items: flex-start; line-height: 24px; }
.page .title-detailed .location .icon { display: flex; align-items: center; min-height: 24px; margin-right: 10px; color: var(--b-300); font-size: 16px; }
.page .title-detailed .price { display: flex; flex-wrap: nowrap; align-items: baseline; gap: 10px; min-height: 32px; margin-top: 6px; }
.page .title-detailed .price .text { line-height: 24px; }
.page .title-detailed .price .amount { color: var(--b-300); font-size: 24px; font-weight: 600; line-height: 28px; }

.page .button-container { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; width: 100%; margin: 30px 0 10px 0; }

.page .text-container { display: flex; flex-direction: column; width: 100%; }
.page .text-container h1 { margin-bottom: 26px; }
.page .text-container h2 { margin-bottom: 14px; }
.page .text-container h3 { margin-bottom: 6px; }
.page .text-container h1,
.page .text-container h2 { margin-top: 6px; color: var(--b-100); font-size: 30px; line-height: 36px; }
.page .text-container h3 { margin-top: 6px; color: var(--b-100); font-size: 20px; line-height: 24px; }
.page .text-container h1:first-child,
.page .text-container h2:first-child,
.page .text-container h3:first-child { margin-top: 0; }
.page .text-container p { margin-bottom: 8px; line-height: 28px; text-align: justify; }
.page .text-container p:last-child { margin-bottom: 0; }
.page .text-container p.small-text { font-size: 15px; }
.page .text-container ul,
.page .text-container ol { margin: 0 0 8px 15px; }
.page .text-container ul:last-child,
.page .text-container ol:last-child { margin-bottom: 0; }
.page .text-container ul li,
.page .text-container ol li { margin-bottom: 6px; line-height: 28px; text-align: justify; }
.page .text-container ul li:last-child,
.page .text-container ol li:last-child { margin-bottom: 0; }
.page .text-container .button { margin-top: 22px; }

.page .image-container { display: flex; position: relative; width: 100%; margin-bottom: 30px; }
.page .content:not(:first-child) .image-container { margin-top: 20px; }
.page .image-container .video-button { transition: opacity 0.2s ease-in-out; display: flex; justify-content: center; align-items: center; z-index: 10; position: absolute; top: 0; left: 0; width: 100%; height: 100%; color: var(--s-25); font-size: 120px; }
.page .image-container .video-button:hover { opacity: 0.8; }
.page .image-container img { width: 100%; border-radius: 8px; }

.page .video-container { display: flex; width: 100%; height: 560px; margin: 20px 0 10px 0; border-radius: 8px; background: var(--s-900); overflow: hidden; }
.page .video-container.small { height: 420px; margin: 0; }
.page .video-container iframe { width: 100%; height: 100%; }
.page .video-container + .video-container { margin-top: 20px; }

.page .form-container { display: flex; flex-direction: row; flex-wrap: wrap; align-items: stretch; padding: 0; }
.page .form-container + .content { margin-top: 54px; }
.page .form-container .form-item { display: flex; flex-direction: column; justify-content: flex-end; box-sizing: border-box; width: 50%; padding: 6px 10px; }
.page .form-container .form-item.width-full { width: 100%; }
.page .form-container .form-item.width-25 { width: 25%; }
.page .form-container .form-item.push-down { padding-top: 24px; }
.page .form-container .form-item .item-heading { margin-bottom: 2px; line-height: 28px; }
.page .form-container .form-item .split-items { display: flex; flex-wrap: nowrap; width: 100%; }
.page .form-container .form-item .split-items .split-item { display: flex; box-sizing: border-box; width: 50%; }
.page .form-container .form-item .split-items .split-item:first-child { padding-right: 5px; }
.page .form-container .form-item .split-items .split-item:last-child { padding-left: 5px; }
.page .form-container .form-item .checkbox-container { padding: 18px 0; }

.slider-container { display: flex; position: relative; width: 100%; background: var(--s-900); overflow: hidden; }
.slider-container .slider { width: 100%; min-height: 720px; }
.slider-container .slider .slide { flex-grow: 1; display: flex; flex-direction: column; justify-content: center; align-items: center; position: relative; box-sizing: border-box; width: 100%; padding: 80px 0; }
.slider-container .slider .slide:after { content: ""; position: absolute; z-index: 15; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(270deg, transparent 0%, var(--b-200-t40) 100%); }
.slider-container .slider .slide .bg { position: absolute; z-index: 10; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }
.slider-container .slider .slide .content { position: relative; z-index: 20; }
.slider-container .slider .slide .details { display: flex; flex-direction: column; width: 480px; max-width: 100%; padding: 48px 0; }
.slider-container .slider .slide .details h1,
.slider-container .slider .slide .details h2 { margin-bottom: 10px; color: var(--s-25); font-size: 48px; line-height: 58px; }
.slider-container .slider .slide .details p { margin-bottom: 32px; color: var(--s-25); line-height: 28px; text-align: justify; }
.slider-container .slider .slick-list,
.slider-container .slider .slick-track { height: 100%; }
.slider-container .slider-nav { position: absolute; z-index: 30; bottom: 80px; left: 0; display: flex; flex-direction: column; align-items: center; width: 100%; }
.slider-container .slider-nav .content { flex-direction: row; flex-wrap: wrap; gap: 10px; justify-content: flex-end; }

.projects-overview { display: flex; flex-direction: row; flex-wrap: wrap; align-items: stretch; padding: 0; }
.projects-overview .item { display: flex; box-sizing: border-box; width: 33.33%; padding: 10px; }
.projects-overview .box { transition: background 0.2s ease-in-out, border-color 0.2s ease-in-out; display: flex; flex-direction: column; position: relative; box-sizing: border-box; width: 100%; height: 100%; background: var(--s-25); border: 1px solid var(--s-100); border-radius: 8px; }
.projects-overview .box:hover { background: var(--s-50); border-color: var(--s-200); }
.projects-overview .box a.whole { position: absolute; top: 0; left: 0; z-index: 10; width: 100%; height: 100%; }
.projects-overview .box .image { flex-shrink: 0; display: flex; position: relative; width: 100%; height: 274px; border-radius: 8px 8px 0 0; overflow: hidden; }
.projects-overview .box .image .img { display: flex; width: 100%; height: 100%; }
.projects-overview .box .image .img img { width: 100%; height: 100%; object-fit: cover; }
.projects-overview .box .image .slider { z-index: 15; width: 100%; height: 100%; }
.projects-overview .box .image .slick-list,
.projects-overview .box .image .slick-track { height: 100%; }
.projects-overview .box .image .slider-nav { transition: opacity 0.2s ease-in-out; opacity: 0; position: absolute; z-index: 20; top: 50%; transform: translateY(-50%); }
.projects-overview .box:hover .image .slider-nav { opacity: 1; }
.projects-overview .box .image .slider-nav.prev { left: 20px; }
.projects-overview .box .image .slider-nav.next { right: 20px; }
.projects-overview .box .details { flex-grow: 1; display: flex; flex-direction: column; box-sizing: border-box; width: 100%; padding: 22px 30px; }
.projects-overview .box .details .headline { display: flex; margin-bottom: 10px; }
.projects-overview .box .details .headline h3 { color: var(--b-100); font-size: 24px; line-height: 28px; }
.projects-overview .box .details .location { display: flex; flex-wrap: nowrap; align-items: flex-start; margin-bottom: 6px; line-height: 24px; }
.projects-overview .box .details .location .icon { display: flex; align-items: center; min-height: 24px; margin-right: 10px; color: var(--b-300); font-size: 16px; }
.projects-overview .box .details .price { line-height: 28px; }

.articles-overview { flex-direction: row; flex-wrap: wrap; align-items: stretch; padding: 0; }
.articles-overview .item { display: flex; box-sizing: border-box; width: 33.33%; padding: 10px; }
.articles-overview .box { transition: background 0.2s ease-in-out, border-color 0.2s ease-in-out; display: flex; flex-direction: column; position: relative; box-sizing: border-box; width: 100%; height: 100%; background: var(--s-25); border: 1px solid var(--s-100); border-radius: 8px; }
.articles-overview .box:hover { background: var(--s-50); border-color: var(--s-200); }
.articles-overview .box a.whole { position: absolute; top: 0; left: 0; z-index: 10; width: 100%; height: 100%; }
.articles-overview .box .image { flex-shrink: 0; display: flex; width: 100%; height: 240px; border-radius: 8px 8px 0 0; overflow: hidden; }
.articles-overview .box .image img { width: 100%; height: 100%; object-fit: cover; }
.articles-overview .box .details { flex-grow: 1; display: flex; flex-direction: column; box-sizing: border-box; width: 100%; padding: 22px 30px; }
.articles-overview .box .details h3 { margin-bottom: 8px; color: var(--b-100); font-size: 24px; line-height: 28px; }
.articles-overview .box .details p { line-height: 28px; }

.pages-overview { flex-direction: row; flex-wrap: wrap; align-items: stretch; width: 1220px; padding: 0; }
.pages-overview .item { display: flex; box-sizing: border-box; width: 50%; padding: 20px; }
.pages-overview .box { transition: background 0.2s ease-in-out, border-color 0.2s ease-in-out; display: flex; flex-direction: column; box-sizing: border-box; width: 100%; height: 100%; }
.pages-overview .box .image { flex-shrink: 0; display: flex; width: 100%; height: 360px; border-radius: 8px; overflow: hidden; }
.pages-overview .box .image img { width: 100%; height: 100%; object-fit: cover; }
.pages-overview .box .details { flex-grow: 1; display: flex; flex-direction: column; box-sizing: border-box; width: 100%; padding: 22px 0; }
.pages-overview .box .details h3 { margin-bottom: 14px; color: var(--b-100); font-size: 30px; line-height: 36px; }
.pages-overview .box .details p { line-height: 28px; text-align: justify; }
.pages-overview .box .details .button { margin-top: 20px; }

.videos-container { flex-direction: row; flex-wrap: wrap; align-items: stretch; padding: 0; }
.videos-container .item { display: flex; box-sizing: border-box; width: 50%; padding: 10px; }
.videos-container .box { display: flex; width: 100%; height: 360px; border-radius: 8px; background: var(--s-900); overflow: hidden; }
.videos-container .box iframe { width: 100%; height: 100%; }

.boxes-container { flex-direction: row; flex-wrap: wrap; align-items: stretch; padding: 0; }
.boxes-container .item { display: flex; box-sizing: border-box; width: 33.33%; padding: 10px; }
.boxes-container .box { transition: background 0.2s ease-in-out; display: flex; flex-direction: column; align-items: center; box-sizing: border-box; width: 100%; height: 100%; padding: 40px 30px; border-radius: 8px; }
.boxes-container .box:hover { background: var(--s-50); }
.boxes-container .box .box-icon { display: flex; margin-bottom: 34px; color: var(--b-300); font-size: 48px; }
.boxes-container .box .details { display: flex; flex-direction: column; align-items: center; width: 100%; text-align: center; }
.boxes-container .box .details h3 { margin-bottom: 10px; color: var(--b-100); font-size: 24px; line-height: 28px; }
.boxes-container .box .details p { line-height: 28px; text-align: justify; }

.columns-image-text { display: flex; flex-wrap: nowrap; align-items: center; gap: 120px; width: 100%; margin: 10px 0; }
.columns-image-text + .columns-image-text { margin-top: 30px; }
.columns-image-text .column-image { display: flex; flex-direction: column; width: 480px; max-width: 100%; }
.columns-image-text .column-image img { width: 100%; border-radius: 8px; }
.columns-image-text .column-text { flex-grow: 1; display: flex; flex-direction: column; width: 0; }

.columns-container { display: flex; flex-wrap: nowrap; align-items: stretch; gap: 40px; width: 100%; }
.columns-container .column-main { flex-grow: 1; display: flex; flex-direction: column; width: 0; }
.columns-container .column-main .content-box { flex-grow: 1; }
.columns-container aside { flex-shrink: 0; display: flex; flex-direction: column; width: 380px; }
.columns-container aside:not(.sticky) .content-box { flex-grow: 1; justify-content: space-between; }
.columns-container aside.sticky .content-box { position: sticky; top: 170px; }
.columns-container aside .content-box .title { margin-bottom: 14px; }
.columns-container aside .content-box .title .columns { min-height: 0; }
.columns-container aside .form-container .form-item { padding-top: 5px; padding-bottom: 5px; }
.columns-container aside .form-container .form-item .checkbox-container { padding: 0; }
.columns-container .form-container { width: 100%; }
.columns-container .form-container .form-item:nth-child(odd) { padding-left: 0; }
.columns-container .form-container .form-item:nth-child(even) { padding-right: 0; }
.columns-container .form-container .form-item.width-full { padding-right: 0; padding-left: 0; }

.content-box { display: flex; flex-direction: column; box-sizing: border-box; width: 100%; margin-bottom: 50px; border-radius: 8px; }
.content-box:last-child { margin-bottom: 0; }
.content-box.grey { padding: 30px; background: var(--s-50-t50); }

.content-title { display: flex; flex-wrap: wrap; box-sizing: border-box; width: 100%; margin-top: 10px; padding: 20px; background: var(--s-25); border-bottom: 1px solid var(--s-100); border-radius: 8px 8px 0 0; }
.content-title h3 { color: var(--b-100); font-size: 20px; line-height: 32px; }

.projects-map { display: flex; position: relative; width: 100%; height: 480px; background: var(--s-75); }
.projects-map #map { width: 100%; height: 100%; }

.projects-result { display: flex; flex-direction: column; align-items: center; width: 100%; }

.estatebud-marker-label { position: absolute; z-index: 150; top: -40px; left: 0; width: 17px; height: 17px; background: var(--s-25); border: 3px solid var(--s-25); border-radius: 50%; color: var(--s-900); font-size: 10px; font-weight: 500; text-align: center; line-height: 16px; overflow: hidden; opacity: 1; cursor: pointer; }
.estatebud-marker-label.estatebud-marker-label-00822e { border-color: #00822e; color: #00822e; }
.estatebud-marker-label.estatebud-marker-label-bf52a0 { border-color: #bf52a0; color: #bf52a0; }
.estatebud-marker-label.estatebud-marker-label-28a5a5 { border-color: #28a5a5; color: #28a5a5; }
.estatebud-marker-label.estatebud-marker-label-d83205 { border-color: #d83205; color: #d83205; }
.estatebud-marker-label.estatebud-marker-label-394675 { border-color: #394675; color: #394675; }

#estatebud-infowindow { display: flex; flex-direction: column; position: absolute; z-index: 20; bottom: 40px; left: 40px; width: 240px; }
#estatebud-infowindow .estatebud-infowindow-slider { width: 100%; }
#estatebud-infowindow .projects-overview { width: 100%; }
#estatebud-infowindow .projects-overview .item { width: 100%; padding: 0; }
#estatebud-infowindow .projects-overview .box { padding: 4px; }
#estatebud-infowindow:has(.estatebud-infowindow-footer) .projects-overview .box { border-bottom-right-radius: 0; border-bottom-left-radius: 0; }
#estatebud-infowindow .projects-overview .box .image { height: 168px; border-radius: 4px; }
#estatebud-infowindow .projects-overview .box .image .slider-nav { display: none !important; }
#estatebud-infowindow .projects-overview .box .details { padding: 8px 10px; }
#estatebud-infowindow .projects-overview .box .details .headline { margin-bottom: 6px; }
#estatebud-infowindow .projects-overview .box .details .headline h3 { font-size: 20px; line-height: 24px; }
#estatebud-infowindow .projects-overview .box .details .location { margin-bottom: 0; font-size: 15px; line-height: 22px; }
#estatebud-infowindow .projects-overview .box .details .location .icon { min-height: 22px; margin-right: 8px; font-size: 14px; }
#estatebud-infowindow .projects-overview .box .details .price { display: none; }

#estatebud-infowindow .estatebud-loader { display: flex; justify-content: center; align-items: center; box-sizing: border-box; width: 100%; height: 268px; background: var(--s-25); border-radius: 8px; color: var(--b-300); font-size: 40px; 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; gap: 6px; box-sizing: border-box; width: 100%; padding: 8px 10px; background: var(--s-50); border: 1px solid var(--s-100); border-top: 0; border-radius: 0 0 8px 8px; font-size: 15px; }
#estatebud-infowindow .estatebud-infowindow-footer .estatebud-right-arrow,
#estatebud-infowindow .estatebud-infowindow-footer .estatebud-left-arrow { transition: color 0.2s 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); }

.map-container { display: flex; position: relative; width: 100%; height: 480px; background: var(--s-75); }
.map-container .map { width: 100%; height: 100%; }

.gallery-container { display: flex; flex-wrap: nowrap; align-items: stretch; gap: 20px; width: 100%; height: 540px; margin-bottom: 30px; }
.gallery-container .image { display: flex; position: relative; box-sizing: border-box; width: 100%; border-radius: 8px; overflow: hidden; }
.gallery-container .image .img { display: flex; position: relative; z-index: 10; width: 100%; height: 100%; }
.gallery-container .image .img img { transition: opacity 0.2s ease-in-out; position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }
.gallery-container .image .img img:nth-child(1) { z-index: 200; }
.gallery-container .image .img img:nth-child(2) { z-index: 100; }
.gallery-container .image-main { flex-grow: 1; display: flex; width: 0; }
.gallery-container .image-main .image { height: 100%; }
.gallery-container .image-thumbs { flex-shrink: 0; display: flex; flex-direction: column; gap: 20px; width: 400px; }
.gallery-container .image-thumbs .image { flex-basis: 0; flex-grow: 1; height: 0; }
.gallery-container .gallery-nav { position: absolute; z-index: 20; top: 50%; transform: translateY(-50%); }
.gallery-container .gallery-nav.prev { left: 20px; }
.gallery-container .gallery-nav.next { right: 20px; }

.table-container { display: flex; width: 100%; max-height: 464px; margin-bottom: 10px; border-radius: 8px; overflow: auto; }
.content-title + .table-container { border-top-left-radius: 0; border-top-right-radius: 0; }
.table thead { position: sticky; top: 0; }
.table tr th,
.table tr td { padding: 16px 20px; background: var(--s-25); }
.table tr th { padding-top: 10px; padding-bottom: 10px; color: var(--s-400); font-size: 15px; font-weight: 400; line-height: 20px; }
.table tr th:first-child { border-top-left-radius: 8px; }
.table tr th:last-child { border-top-right-radius: 8px; }
.content-title + .table-container .table tr th:first-child { border-top-left-radius: 0; }
.content-title + .table-container .table tr th:last-child { border-top-right-radius: 0; }
.table tr td { border-bottom: 1px solid var(--s-50); color: var(--b-100); line-height: 28px; }
.table tr td[width="1px"] { padding-right: 0; }
.table tr:last-child td { border-bottom: 0; }
.table tr:last-child td:first-child { border-bottom-left-radius: 8px; }
.table tr:last-child td:last-child { border-bottom-right-radius: 8px; }

footer { flex-shrink: 0; display: flex; flex-direction: column; width: 100%; }
.footer { display: flex; flex-direction: column; align-items: center; width: 100%; background: var(--b-100); }
.footer .top { display: flex; flex-wrap: nowrap; justify-content: space-between; align-items: flex-end; gap: 20px; width: 100%; padding: 80px 0 74px 0; }
.footer .logo { display: flex; }
.footer .logo a { display: flex; }
.footer .logo img { height: 60px; }
.footer .socials { min-height: 40px; }
.footer .columns { display: flex; flex-wrap: nowrap; justify-content: space-between; gap: 40px; width: 100%; padding-bottom: 156px; }
.footer .columns .column { display: flex; flex-direction: column; max-width: 100%; }
.footer .headline { display: flex; margin-bottom: 16px; }
.footer .headline h5 { color: var(--s-25); font-size: 20px; line-height: 28px; }
.footer .success { width: 280px; }
.footer .form { display: flex; flex-direction: column; width: 280px; max-width: 100%; margin-top: 8px; }
.footer .form .item { display: flex; width: 100%; }
.footer .form .item:last-child { padding-top: 10px; }
.footer .award { width: 80px; max-width: 100%; }
.footer .bottom { display: flex; flex-wrap: nowrap; justify-content: space-between; gap: 20px; padding: 26px 0; border-top: 1px solid var(--s-25-t10); }
.footer .bottom ul { display: flex; flex-wrap: nowrap; gap: 30px; list-style: none; }
.footer .bottom ul li,
.footer .bottom ul li a { transition: color 0.2s ease-in-out; color: var(--s-400); font-size: 15px; line-height: 18px; }
.footer .bottom ul li a:hover { color: var(--s-200); }

.status-icon { display: flex; width: 12px; height: 12px; }
.status-icon.status-available { background: var(--status-available); }
.status-icon.status-reserved { background: var(--status-reserved); }
.status-icon.status-sold { background: var(--status-sold); }

.paging { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px; width: 100%; margin-top: 30px; }
.paging a { transition: background 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.2s ease-in-out; display: flex; justify-content: center; align-items: center; box-sizing: border-box; min-width: 48px; min-height: 48px; padding: 10px 18px; background: var(--s-25); border: 1px solid var(--s-100); border-radius: 24px; color: var(--b-100); font-size: 15px; font-weight: 600; line-height: 24px; text-align: center; }
.paging a:hover { background: var(--s-50); border-color: var(--s-200); }
.paging a.active { background: var(--b-100); border-color: var(--b-100); color: var(--s-25); }

.buttons { display: flex; flex-wrap: wrap; gap: 10px; width: 100%; }

.socials { display: flex; flex-direction: column; justify-content: center; }
.socials ul { display: flex; flex-wrap: nowrap; gap: 20px; list-style: none; }
.socials ul li,
.socials ul li a { transition: color 0.2s ease-in-out; display: flex; color: var(--s-200); font-size: 22px; }
.socials.small ul li,
.socials.small ul li a { font-size: 16px; }
.socials ul li a:hover { color: var(--s-25); }

.list { display: flex; flex-direction: column; gap: 20px; }
.list + .list { margin-top: 20px; }
.list ul { display: flex; flex-direction: column; gap: 10px; list-style: none; }
.list ul li,
.list ul li a { transition: color 0.2s ease-in-out; display: flex; align-items: flex-start; color: var(--s-500); line-height: 24px; }
.list ul li a:hover { color: var(--s-25); }
.list ul li .icon { display: flex; align-items: center; min-height: 22px; margin-right: 10px; color: var(--b-100); font-size: 16px; }
.list ul li .status-icon { margin: 5px 10px 0 0; }

.list.light ul li,
.list.light ul li a { color: var(--s-200); font-weight: 500; }
.list.light ul li a:hover { color: var(--s-25); }
.list.light ul li .icon { color: var(--s-25); }

.list.horizontal ul { flex-direction: row; flex-wrap: nowrap; gap: 30px; }
.list.small ul li,
.list.small ul li a { font-size: 15px; line-height: 22px; }
.list.small ul li .icon { font-size: 14px; }

.list-detailed { display: flex; flex-direction: column; gap: 20px; width: 100%; }
.list-detailed ul { display: flex; flex-wrap: wrap; gap: 16px 0; width: 100%; list-style: none; }
.list-detailed ul li { display: flex; flex-direction: column; box-sizing: border-box; width: 33.33%; padding-right: 20px; }
.list-detailed ul li:nth-child(3n) { padding-right: 0; }
.list-detailed ul li .heading { margin-bottom: 4px; line-height: 28px; }
.list-detailed ul li .value { display: flex; flex-wrap: nowrap; align-items: flex-start; color: var(--b-100); font-weight: 500; line-height: 28px; }
.list-detailed ul li .icon { display: flex; align-items: center; min-width: 24px; min-height: 28px; margin-right: 12px; color: var(--b-100); }

.list-bullet { display: flex; flex-direction: column; gap: 20px; width: 100%; }
.list-bullet ul { columns: 3; gap: 14px; width: 100%; list-style: none; }
.list-bullet ul li { display: flex; flex-wrap: nowrap; align-items: flex-start; margin-bottom: 14px; line-height: 28px; }
.list-bullet ul li:before { content: ""; flex-shrink: 0; display: flex; width: 6px; height: 6px; margin: 11px 10px 0 0; background: var(--b-300); }

.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; display: flex; flex-wrap: nowrap; justify-content: center; align-items: center; box-sizing: border-box; min-height: 48px; padding: 12px 22px; background: var(--b-100); border: 2px solid var(--b-100); border-radius: 24px; color: var(--s-25); font-size: 17px; font-weight: 600; line-height: 20px; text-align: center; cursor: pointer; }
.button:not(.text):hover,
.dropdown-container:has(.dropdown:hover) .button:not(.text) { background: var(--b-200); border-color: var(--b-200); }
.button.text { min-height: 0; padding: 0; background: transparent; border: 0; color: var(--b-100); }
.button.text:hover,
.dropdown-container:has(.dropdown:hover) .button.text { color: var(--b-200); }

.button.secondary:not(.text) { background: var(--b-300); border-color: var(--b-300); }
.button.secondary:not(.text):hover,
.dropdown-container:has(.dropdown:hover) .button.secondary:not(.text) { background: var(--b-400); border-color: var(--b-400); }
.button.secondary.text { color: var(--b-300); }
.button.secondary.text:hover,
.dropdown-container:has(.dropdown:hover) .button.secondary.text { color: var(--b-400); }

.button.grey:not(.text) { background: var(--s-300); border-color: var(--s-300); }
.button.grey:not(.text):hover,
.dropdown-container:has(.dropdown:hover) .button.grey:not(.text) { background: var(--s-400); border-color: var(--s-400); }
.button.grey.text { color: var(--s-300); }
.button.grey.text:hover,
.dropdown-container:has(.dropdown:hover) .button.grey.text { color: var(--s-400); }

.button.white:not(.text) { background: var(--s-25); border-color: var(--s-25); color: var(--b-100); }
.button.white:not(.text):hover,
.dropdown-container:has(.dropdown:hover) .button.white:not(.text) { background: var(--s-50); border-color: var(--s-50); color: var(--b-200); }
.button.white.text { color: var(--s-25); }
.button.white.text:hover,
.dropdown-container:has(.dropdown:hover) .button.white.text { color: var(--s-50); }

.button.whatsapp:not(.text) { padding: 0; background: var(--whatsapp-25); border-color: var(--whatsapp-25); font-size: 24px; }
.button.whatsapp:not(.text):hover { background: var(--whatsapp-50); border-color: var(--whatsapp-50); }
.button.whatsapp.text { color: var(--whatsapp-25); }
.button.whatsapp.text:hover { color: var(--whatsapp-50); }

.button.small { min-height: 40px; padding: 8px 18px; }
.button.icon { min-width: 48px; padding-left: 10px; padding-right: 10px; }

.button .icon { flex-shrink: 0; display: flex; }
.button .icon:not(.before) { margin-left: 10px; }
.button .icon.before { margin-right: 10px; }

.input { box-sizing: border-box; width: 100%; height: 48px; padding: 0 18px; background: var(--s-25); border: 1px solid var(--s-100); border-radius: 4px; color: var(--s-400); font-size: 17px; }
.input::placeholder { opacity: 1; color: var(--s-400); }
.input:hover { border-color: var(--s-200); }
.input:focus { border-color: var(--b-100); outline: 1px solid var(--b-100); color: var(--s-900); }
.input.error { border-color: var(--error); outline: 1px solid var(--error); }

.textarea { box-sizing: border-box; width: 100%; height: 168px; padding: 12px 18px; background: var(--s-25); border: 1px solid var(--s-100); border-radius: 4px; color: var(--s-400); font-size: 17px; resize: none; }
.textarea::placeholder { opacity: 1; color: var(--s-400); }
.textarea:hover { border-color: var(--s-200); }
.textarea:focus { border-color: var(--b-100); outline: 1px solid var(--b-100); color: var(--s-900); }
.textarea.error { border-color: var(--error); outline: 1px solid var(--error); }
.textarea.height-128 { height: 128px; }

.input-toggles { display: flex; flex-wrap: wrap; gap: 10px; width: 100%; }
.input-toggles .toggle-item { flex-basis: 0; flex-grow: 1; display: flex; }
.input-toggles .toggle-item input { display: none; }
.input-toggles .toggle-item .input-toggle { display: flex; justify-content: center; align-items: center; box-sizing: border-box; width: 100%; height: 48px; padding: 10px; background: var(--s-25); border: 1px solid var(--s-100); border-radius: 4px; color: var(--b-100); text-align: center; cursor: pointer; user-select: none; }
.input-toggles .toggle-item .input-toggle:hover { background: var(--s-50); border-color: var(--s-200); }
.input-toggles .toggle-item input:checked + .input-toggle { background: var(--b-100); border-color: var(--b-100); color: var(--s-25); }

.checkbox-container { display: flex; flex-wrap: nowrap; align-items: flex-start; margin: 10px 0; }
.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); border-radius: 4px; color: var(--s-75); font-size: 14px; cursor: pointer; }
.checkbox-container:has(.checkbox-label:hover) input:not(:checked):not(.error) + .checkbox,
.checkbox-container input:not(:checked) + .checkbox:hover { border-color: var(--s-200); }
.checkbox-container .checkbox span { display: none; }
.checkbox-container input:checked + .checkbox { background: var(--b-300); border-color: var(--b-300); color: var(--s-25); }
.checkbox-container:has(.checkbox-label:hover) .checkbox span,
.checkbox-container .checkbox:hover span,
.checkbox-container input:checked + .checkbox span { display: flex; }
.checkbox-container .checkbox-label { padding-left: 10px; color: var(--s-400); font-size: 15px; line-height: 24px; cursor: pointer; user-select: none; }
.checkbox-container .checkbox-label a { color: var(--b-100); font-weight: 500; }
.checkbox-container input.error:not(:checked) + .checkbox { border-color: var(--error); }

.checkbox-container.light .checkbox-label { color: var(--s-200); }
.checkbox-container.light .checkbox-label a { color: var(--s-25); }

.label-input-container { display: flex; flex-wrap: wrap; align-items: center; gap: 10px 20px; max-width: 100%; }
.label-input-container .label-input { display: flex; width: 200px; max-width: 100%; }

.dropdown-container { position: relative; display: flex; }
.dropdown-container .dropdown { position: absolute; z-index: 500; top: 100%; left: 0; display: none; min-width: 100%; padding-top: 20px; }
.dropdown-container .button:hover + .dropdown,
.dropdown-container .dropdown:hover { display: flex; }
.dropdown-container .dropdown ul { display: flex; flex-direction: column; gap: 10px; box-sizing: border-box; width: 100%; padding: 18px; background: var(--s-25); border: 1px solid var(--s-100); border-radius: 4px; }
.dropdown-container .dropdown ul li,
.dropdown-container .dropdown ul li a { transition: color 0.2s ease-in-out; display: flex; flex-wrap: nowrap; align-items: flex-start; color: var(--s-400); font-weight: 500; line-height: 20px; white-space: nowrap; }
.dropdown-container .dropdown ul li a:hover { color: var(--b-100); }
.dropdown-container .dropdown ul li .icon { flex-shrink: 0; display: flex; align-items: center; min-height: 20px; margin-right: 10px; }

[data-expand="item"] { max-height: 114px; column-count: 1; overflow: hidden; }

.sticky-buttons { display: flex; flex-direction: column; gap: 10px; position: fixed; z-index: 800; bottom: 30px; right: 30px; }
.sticky-buttons .button { box-shadow: 0 4px 16px var(--black-t25); }

.no-results { display: flex; flex-direction: column; justify-content: center; align-items: center; box-sizing: border-box; width: 100%; margin: 10px 0; padding: 30px; border: 2px solid var(--s-50-t50); border-radius: 8px; line-height: 28px; text-align: center; }

.amount-container { display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px; box-sizing: border-box; width: 100%; padding: 30px; background: var(--b-100); border-radius: 8px; color: var(--s-25); }
.amount-container .amount { font-size: 24px; font-weight: 600; line-height: 28px; }
.amount-container .text { line-height: 22px; }

.success { display: none; width: 100%; height: 100%; }
.success .success-inner { display: flex; flex-direction: column; justify-content: center; align-items: center; box-sizing: border-box; width: 100%; height: 100%; padding: 30px; border: 2px solid var(--s-50-t50); border-radius: 8px; text-align: center; }
.success .success-inner .message-icon { margin-bottom: 10px; color: var(--b-300); font-size: 48px; }
.success .success-inner .message-text { line-height: 28px; }

.success.light .success-inner { border-color: var(--s-25-t10); }
.success.light .success-inner .message-text { color: var(--s-200); }

.loading-container { display: flex; justify-content: center; align-items: center; box-sizing: border-box; width: 100%; min-height: 40vh; padding: 40px 0; color: var(--b-100); font-size: 60px; text-align: center; }
.loading-container svg { animation: loading-spin 1s infinite; }

.preload { display: none; }

.hidden { display: none !important; }

.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-300); }

@keyframes loading-spin {
    from { transform:rotate(0deg); }
    to { transform:rotate(360deg); }
}

@media (max-width: 1400px) {
    .header .menu nav .submenu { left: auto; right: 0; }
    .dropdown-container .dropdown { left: auto; right: 0; }
}

@media (max-width: 1000px) {
    body { font-size: 16px; }
    
    .header { height: 100px; }
    .header .bar { display: none; }
    .header .logo,
    .header .logo a { max-width: 100%; }
    .header .logo img { max-width: 100%; height: 50px; }
    
    .header .menu { flex-direction: column; align-items: flex-end; position: fixed; z-index: 1200; top: 0; right: 0; width: 100%; height: 100%; background: var(--s-900-t60); }
    .header .menu:not(.open) { display: none; }
    .header .menu nav { box-sizing: border-box; width: 340px; max-width: 80%; height: 100%; padding-top: 80px; background: var(--s-25); overflow: auto; }
    .header .menu nav ul { flex-direction: column; align-items: flex-start; gap: 0; width: 100%; }
    .header .menu nav ul li { flex-direction: column; }
    .header .menu nav ul li:has(.button) { flex-grow: 1; justify-content: flex-end; padding: 0 20px; }
    .header .menu nav ul li,
    .header .menu nav ul li a:not(.button) { justify-content: flex-start; align-items: flex-start; box-sizing: border-box; width: 100%; text-align: left; }
    .header .menu nav ul li a:not(.button) { padding: 20px; border: 0; }
    .header .menu nav ul li .button { width: 100%; }
    .header .menu nav .submenu { position: relative; top: auto; left: auto; right: auto; width: 100%; padding-top: 0; }
    
    .header .mobile-menu { display: flex; }
    
    .slider-container .slider { min-height: 400px; }
    .slider-container .slider .slide .content { align-items: center; }
    .slider-container .slider .slide .details { align-items: center; width: 100%; text-align: center; }
    .slider-container .slider .slide .details h1,
    .slider-container .slider .slide .details h2 { font-size: 30px; line-height: 38px; }
    .slider-container .slider .slide .details .button { align-self: center; }
    .slider-container .slider-nav { bottom: 20px; }
    .slider-container .slider-nav .content { justify-content: space-between; }
    
    .page { padding: 40px 0; }
    
    .page .title h1,
    .page .title h2 { font-size: 24px; line-height: 30px; }
    
    .page .text-container h1,
    .page .text-container h2 { font-size: 22px; line-height: 28px; }
    
    .page .form-container .form-item.width-25 { width: 50%; }
    
    .page .image-container .video-button { font-size: 60px; }
    
    .page .video-container { height: 56vw; }
    .page .video-container.small { height: 54vw; }
    
    .page-title { padding: 30px 0; min-height: 90px; }
    .page-title h1 { padding-left: 15px; border-left: 4px solid var(--b-300); font-size: 24px; line-height: 28px; }
    
    .projects-overview .box .image { height: 23vw; }
    .projects-overview .box .details .headline h3 { font-size: 20px; line-height: 24px; }
    .projects-overview .box .image .slider-nav { display: none !important; }
    
    .articles-overview .item { width: 50%; }
    .articles-overview .box .image { height: 30vw; }
    .articles-overview .box .details h3 { font-size: 18px; line-height: 22px; }
    
    .pages-overview .box .image { height: 30vw; }
    .pages-overview .box .details h3 { font-size: 24px; line-height: 28px; }
    
    .videos-container .box { height: 36vw; }
    
    .boxes-container .item { width: 50%; }
    .boxes-container .box { padding: 30px 20px; }
    .boxes-container .box .details h3 { font-size: 20px; line-height: 24px; }
    
    .columns-image-text { flex-direction: column; gap: 30px; }
    .columns-image-text .column-image { order: 1; width: 100%; }
    .columns-image-text .column-text { order: 2; width: 100%; }
    
    .columns-container { flex-direction: column; }
    .columns-container .column-main { width: 100%; }
    .columns-container aside { width: 100%; }
    
    #estatebud-infowindow { bottom: 10px; left: 10px; max-width: calc(100% - 20px); }
    
    .gallery-container { flex-direction: column; height: 90vw; }
    .gallery-container .image-main { width: 100%; height: 0; }
    .gallery-container .image-thumbs { flex-direction: row; width: 100%; height: 35%; }
    .gallery-container .image-thumbs .image { width: 0; height: 100%; }
    
    .footer .top { flex-wrap: wrap; padding: 40px 0 30px 0; }
    .footer .logo { max-width: 100%; }
    .footer .logo a { max-width: 100%; }
    .footer .logo img { max-width: 100%; height: 50px; }
    .footer .columns { flex-wrap: wrap; padding-bottom: 60px; }
    .footer .bottom { flex-wrap: wrap; }
    
    .checkbox-container:has(.checkbox-label:hover) input:not(:checked) + .checkbox span,
    .checkbox-container input:not(:checked) + .checkbox:hover span { display: none; }
}

@media (max-width: 800px) {
    .projects-overview .item { width: 100%; }
    .projects-overview .box .image { height: 69vw; }
    
    .pages-overview .item { width: 100%; }
    .pages-overview .box .image { height: 59vw; }
    
    .socials ul { flex-wrap: wrap; justify-content: center; }
    
    .footer .top { flex-direction: column; align-items: center; }
    .footer .columns { flex-direction: column; align-items: center; }
    .footer .columns .column { align-items: center; }
    .footer .headline { text-align: center; }
    .footer .list { text-align: center; }
    .footer .list ul { align-items: center; }
    .footer .form .item .button { width: 100%; }
    .footer .bottom { flex-direction: column; align-items: center; gap: 10px; }
    .footer .bottom ul { flex-wrap: wrap; justify-content: center; gap: 10px; }
    .footer .bottom ul li { text-align: center; }
}

@media (max-width: 600px) {
    .page .title-detailed { flex-direction: column; align-items: center; }
    .page .title-detailed .column { width: 100%; align-items: center; text-align: center; }
    .page .title-detailed .column:nth-child(2) { align-items: center; }
    
    .articles-overview .item { width: 100%; }
    .articles-overview .box .image { height: 60vw; }
    
    .videos-container .item { width: 100%; }
    .videos-container .box { height: 64vw; }
    
    .boxes-container .item { width: 100%; }
    
    .columns-container .column-main .content-box .buttons { justify-content: center; }
    
    .list-detailed ul li { width: 50%; }
    .list-bullet ul { columns: 2; }
    
    .dropdown-container .dropdown { left: 50%; right: auto; transform: translateX(-50%); }
}

@media (max-width: 500px) {
    .page .form-container .form-item,
    .page .form-container .form-item.width-25 { width: 100%; }
    .page .form-container .form-item .checkbox-container { padding: 5px 0; }
    .page .form-container .form-item .button { width: 100%; }
    
    .columns-container .form-container .form-item:nth-child(odd) { padding-right: 0; }
    .columns-container .form-container .form-item:nth-child(even) { padding-left: 0; }
}

@media (max-width: 350px) {
    .list-detailed ul li { width: 100%; }
    .list-bullet ul { columns: 1; }
}

@media (max-width: 250px) {
    .page .form-container .form-item .split-items { flex-direction: column; }
    .page .form-container .form-item .split-items .split-item { width: 100%; }
    .page .form-container .form-item .split-items .split-item:first-child { padding-bottom: 5px; padding-right: 0; }
    .page .form-container .form-item .split-items .split-item:last-child { padding-top: 5px; padding-left: 0; }
}