/* mulish-200 - latin */
@font-face {
	font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
	font-family: 'Mulish';
	font-style: normal;
	font-weight: 200;
	src: url('https://static.immoserver.ch/fonts/google/mulish-v12-latin-200.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+ */
		 url('https://static.immoserver.ch/fonts/google/mulish-v12-latin-200.woff') format('woff'); /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}

/* mulish-300 - latin */
@font-face {
	font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
	font-family: 'Mulish';
	font-style: normal;
	font-weight: 300;
	src: url('https://static.immoserver.ch/fonts/google/mulish-v12-latin-300.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+ */
		 url('https://static.immoserver.ch/fonts/google/mulish-v12-latin-300.woff') format('woff'); /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}


/* mulish-regular - latin */
@font-face {
	font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
	font-family: 'Mulish';
	font-style: normal;
	font-weight: 400;
	src: url('https://static.immoserver.ch/fonts/google/mulish-v12-latin-regular.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+ */
		 url('https://static.immoserver.ch/fonts/google/mulish-v12-latin-regular.woff') format('woff'); /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}


/* mulish-500 - latin */
@font-face {
	font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
	font-family: 'Mulish';
	font-style: normal;
	font-weight: 500;
	src: url('https://static.immoserver.ch/fonts/google/mulish-v12-latin-500.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+ */
		 url('https://static.immoserver.ch/fonts/google/mulish-v12-latin-500.woff') format('woff'); /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}



/* mulish-700 - latin */
@font-face {
	font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
	font-family: 'Mulish';
	font-style: normal;
	font-weight: 700;
	src: url('https://static.immoserver.ch/fonts/google/mulish-v12-latin-700.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+ */
		 url('https://static.immoserver.ch/fonts/google/mulish-v12-latin-700.woff') format('woff'); /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}


:root
{
	--text-color:#0A2329;;
	--text-color-offer:#364b5c;
	--fancybox-content-color:var(--text-color);
	--theme-color: #0A2329;
	--hover-color: #9fb3ce;
	--odd-color: lightgrey;
	--swiper-navigation-size: 3em;
	--swiper-theme-color: #0A2329;
	--header-height: 0px;
	--offer-border-color:#d5d2cc;	
	--content-width: 67rem;
	--imagetext-width: 90rem;
	--images-max-width:2400px;
	--content-padding: 2rem;
	--content-padding-vertical: clamp(1.8rem, 4vw, 4rem);
	--content-padding-horizontal: clamp(1.1rem, 2vw, 2rem);

	--header-width:clamp(10rem,22vw,22rem);
	--header-padding:calc(0px + var(--header-width) * .04) calc(0px + var(--header-width) * .08);

	--status-color-available:darkgreen;
	--status-color-unknown:darkorange;
	--status-color-unavailable:darkred;
	--nav-toggle-size:clamp(2em,3vw,2.875em);
	--nav-padding-vertical: 0em;
	--nav-padding-horizontal: clamp(1.1rem, 5.5vw, 5.5rem);

}

section >.images {
	position: sticky;
	top:0px;
	z-index: -1;
}

main > section >.group,main > section > .slideshow.element,
.images:not(.intro).element{
	background: white;
	display: flex;
	flex-direction: column;
}

section + section > .group:first-child > .wrapper,.group:not(.offer) + .element,.group:not(.offer) +.element .content{
	margin-top:0;
} 

main .group,.slideshow.element,.images.element
{
	--content-padding-vertical: clamp(3rem, 7vw, 7rem);
}

main .slideshow,main .group
{
	--content-padding-horizontal: clamp(1.1rem, 3.5vw, 3.5rem);
}


.slideshow.element,.images.element
{
	border-bottom: clamp(4px,1vw,8px) solid white;
}

.fancybox__content>.f-button.is-close-btn
{
	color:white;
	border: 0px;
}

body
{
	color:var(--text-color);
	font-family: 'Mulish', sans-serif;
	font-weight: 300;
	margin:0;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	line-height: 1.25;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	min-height: 100dvh;
}

body.toggled
{
	overflow: hidden;
}

body.toggled header
{
	overflow: auto;
	max-height: 100vh;
}

a
{
	color:inherit;
	text-decoration: none;
}

.selectables a,.consent-settings a
{
	text-decoration: underline;
}

header {
	position: sticky;
	z-index:100;
	width:var(--header-width);
	height: 0;
	top:0;
	left:var(--content-padding-horizontal);
}

.navbox .nav
{
	background:white;
	z-index: 105;
	margin: var(--nav-padding-vertical) 0px;
}

.navbox .overlay
{
	position: fixed;
	top:0px;
	left:0px;
	right: 0px;
	bottom: 0px;
	z-index: 104;
	background:rgba(0,0,0,.6);
	display: flex;
	justify-content: flex-end;
}


header .items
{
	display:flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
	padding: var(--header-padding);

}

header .logo img
{
	display:block;
	width:100%;

}

.navbox
{
	position: absolute;	

}

.navbox a
{
	font-family: "bebas-neue-pro-expanded", sans-serif;
	font-weight: 500;
	letter-spacing: .05em;
	font-size: clamp(1.6em,4vw,2.2em);
	text-transform: uppercase;
	font-weight: 700;
	color:#495a5e;
}


footer
{
	background: #0A2329;
	color:#96A3B2;
}

body footer > .wrapper
{
	padding:var(--content-padding-vertical) var(--content-padding-horizontal);
	font-size: clamp(.9em,2.2vw,1.1em);
	display: flex;
	flex-direction: column;
	gap:1em;

}

footer span
{
	font-size: smaller;
}

footer nav a
{
	text-transform: uppercase;
	font-weight: bold;
	font-size: smaller;
}

footer nav
{
	margin-top: 2em;
	display:flex;
	flex-wrap:wrap;
	gap: .5em 1em;
}

.navbox
{
	display:none;
}

.navbox .nav
{
	overflow: auto;
	display: grid;
}

.navbox nav
{
	display: grid;
	grid-template-columns: 1fr;
	padding:clamp(6rem, 9vw, 8rem) var(--nav-padding-horizontal);
	align-content: center;
	gap:1.8em;
	text-align: center;	
}

.navbox nav a.active,
.navbox nav a:hover
{
	color: var(--hover-color);
}


.nav-toggle
{
	position: fixed;
	display: flex;
	align-items: center;
	justify-content: center;
	align-self: flex-end;
	z-index: 120;
	right: var(--nav-padding-horizontal);
	top: calc(var(--nav-padding-vertical) + (var(--content-padding-vertical) * .7) );
	color:rgb(248, 247, 247);
	background: #061d22;
	border:none;
	font-size: var(--nav-toggle-size);
	cursor: pointer;
	transition: color .5s linear .25s;
	padding:.5rem 1rem;
	width: calc(var(--nav-toggle-size) * .7);
	height: calc(var(--nav-toggle-size)  * .7);

}

.nav-toggle-reset
{
	--nav-padding-vertical:0em;
	top: 0px;
}

.toggled .navbox
{
	display: flex;
}


.nav-toggle::after
{
	content: "\f0c9";
	text-shadow: 1px 1px 5px rgba(0,0,0,0.6);

}

.toggled  .nav-toggle::after
{
	color:white;
	content: "\f00d";

}

main
{
	flex-grow:1;
}

main .group > .wrapper
{
	max-width:var(--content-width);
}

.group > .wrapper
{
	padding:0px var(--content-padding-horizontal);
	margin:var(--content-padding-vertical) auto calc(var(--content-padding-vertical) * 1.3) auto;
}

.group > .wrapper > :first-child,
.group > .wrapper > .title:first-child > .wrapper > h1,
.group > .wrapper > .subtitle:first-child > .wrapper > h2
{
	margin-top:0;
}

.group > .wrapper > :last-child,
.group > .wrapper > .title:last-child > .wrapper > h1,
.group > .wrapper > .subtitle:last-child > .wrapper > h2
{
	margin-bottom:0;
}

.group .element
{
	margin:clamp(1em,4vw,2em) 0;
}

section > :first-child
{
	margin-top: 0;
}

.title h1
{
	font-size: clamp(1.9em,7vw,100px);	
}

.houses
{
	font-size: clamp(1em, 4vw,1.3em);
}

.subtitle h2{
	font-weight: 200;
	line-height: 1.1;
	padding-bottom: 0;
	margin:0 0 .3em -.07em;
	font-size: clamp(1.7em,7vw,80px);

}
.offer .title h1{
	font-weight: 200;
	line-height: 1.1;
	padding-bottom: 0;
	margin:0 0 .3em -.07em;
	font-size: clamp(1.9em,7vw,80px);

}

.text +.subtitle h2
{
	margin:var(--content-padding-vertical) auto calc(var(--content-padding-vertical) * .5) auto;
}

.subtitle + .vtour
{
	margin-top:clamp(2em,4vw,3.3em);
}

.title h1
{
	font-weight: 200;
	line-height: 1.1;
	padding-bottom: 0;
	margin:0 0 .3em -.07em;
}

.offer-popup-header  h1
{
	font-size: clamp(1.2em,6vw,50px);
}

.offer .slideshow.element
{
	--content-padding-horizontal:0px;
}

.consent-dialog .consent-message
{
	font-size: clamp( 1em,2vw,1.2em);
	margin-bottom: .8em;
}

.consent-buttons button
{
	font-size: clamp( 1em,2vw,1.1rem);
}
.slideshow video
{
	width:100%;
	display: block;
}

.slideshow.main .swiper-captions
{
	max-width: var(--content-width);
	margin:0px auto;
}

.slideshow .swiper-captions,.vtour .legend
{
	font-size:clamp(.8em,1.8vw,21px);
	line-height: 1.25;
}

.text .typo,.facts,.consent-message,.imagetext.slideshow .swiper-captions
{
	font-size:clamp(1em,2.8vw,33px);
	line-height: 1.25;
}

.slideshow + .group > .wrapper
{
	margin-top: 0px;
}

/* elements */
.images .legend
{
	display: none;
}

.images img
{
	display:block;
	width:100%;
}


main .images img {
	max-height: 100vh;
    max-height: 100dvh;
    object-fit: cover;
    object-position: center;
}

.images:not(.intro).element .wrapper img,.slideshow .content
{
	max-width: var(--images-max-width);
	margin:0px auto;
}

.slideshow
{
	--swiper-navigation-size:var(--content-padding-horizontal);
	
	padding:0em var(--content-padding-horizontal);
	position: relative;
}

.slideshow.limited .swiper-slide > img
{
    max-height: 80vh;
    max-height: 80dvh;
	object-fit: contain;
	object-position: center;
}

.slideshow .wrapper
{
	position: relative;
}

.swiper-button-prev, .swiper-rtl .swiper-button-next,.swiper-button-next, .swiper-rtl .swiper-button-prev
{
	width:auto;
	--swiper-navigation-sides-offset:calc(0px - calc(var(--content-padding-horizontal) *.78) );
}

/*Fix Grid fr unit*/
.slideshow .swiper-slide
{
	width: 100% !important;
}

.slideshow .swiper-slide > img
{
	display:block;
	width:100%;
}

.slideshow .swiper-slide > .legend
{
	position: absolute;
	bottom: 0; 
	left:0; 
	right:0;
	color:white;
	text-align:center;
	z-index:1;
	pointer-events: none;
	text-shadow:0px 0px 15px #333;
	padding:2em;
}


.vtour img:first-child
{
	display: block;
	width: 100%;
}


.vtour .preview
{
	display: block;
	position: relative;
}

.vtour .content
{
	position: absolute;
	width: clamp(150px,24vw,320px);
	top:50%;
	left:50%;
	transform: translate(-50%,-50%);
}

.vtour .content:hover .vicon:not(.hover),.vtour .content .vicon.hover
{
	display: none;
}

.vtour .content:hover .vicon.hover
{
	display: block;
}

.vtour .wrapper
{
	display: flex;
	gap:calc(var(--content-padding-vertical) *.5);
	flex-direction: column;
}

.links .items
{
	display:flex;
	gap: .5em;
	flex-wrap:wrap;
}

[data-slider] .slider-input
{
	padding:0 8px;
	margin:8px 0;
	height: 10px;
}

[data-slider] .slider-value
{
	font-size:smaller;
}

[data-slider] .slider-value span
{
	white-space: nowrap;
}

[data-slider] .slider-input,
[data-slider] .slider-input .noUi-handle
{
	box-shadow: none;
}

/* Hide markers on slider handles */
[data-slider] .slider-input .noUi-handle::before,
[data-slider] .slider-input .noUi-handle::after
{
	display: none;
}

[data-slider] .slider-input .noUi-connect
{
	background: var(--hover-color);
}

[data-slider] .slider-input .noUi-handle
{
	height: 18px;
	width: 18px;
	top: -5px;
	right: -9px; /* half the width */
	border-radius: 9px;
}

[data-iso3d]
{
	position:relative;
	aspect-ratio: var(--is-iso-aspect-ratio,1);
}

[data-iso3d] canvas 
{
	position: absolute;
	top:0;
	left:0;
	box-sizing: border-box;
	background: transparent;
	bottom: 0;
	width: 100% !important;
	height: 100% !important;
	outline: none;
}

.model-toolbar,
.model-direction,
.model-quality
{
	position:absolute;
	display:flex;
	z-index:1;
}

.model-toolbar.model-toolbar-navigation
{
	top:0;
	left:1px;
}

.model-toolbar.model-toolbar-rotation
{
	bottom:0;
	right:1px;
}

.model-toolbar.model-toolbar-size
{
	right:1px;
	top:50%;
	flex-direction:column;
	transform:translateY(-50%);
}

.model-overlay,
.model-loading
{
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	display:grid;
	place-items: center;
	box-sizing: border-box;
	z-index:1;
	pointer-events:none;
}

.model-overlay
{
	display:none;
}

.model-overlay.model-overlay-mouse,
.model-overlay.model-overlay-touch
{
	/*display:grid;*/
	color:white;
	font-size:clamp(1em,3vw,1.5em);
	padding:2em;
	text-align:center;
}

.model-overlay.model-overlay-mouse > div,
.model-overlay.model-overlay-touch > div
{
	background:rgba(0,0,0,.3);
	padding: .5em 1em;
}

.model-overlay.model-overlay-mouse .model-info-touch,
.model-overlay.model-overlay-touch .model-info-mouse
{
	display:none;
}

.model-loading-done
{
	display:none;
}

.model-toolbar > div
{
	background:white;
	outline:1px solid black;
}

.model-toolbar > div::after,
.model-loading > div::after,
.model-direction::after,
.model-quality::after
{
	display: block;
	font:var(--fa-font-sharp-regular);
	cursor: pointer;
	width:1em;
	height:1em;
	padding: 1em;
	margin:auto;
}

.model-loading > div::after
{
	content:"\f110";
	animation-name: fa-spin;
	animation-duration: var(--fa-animation-duration, 2s);
	animation-iteration-count: var(--fa-animation-iteration-count, infinite);
	animation-timing-function: var(--fa-animation-timing, linear);
}

.model-toolbar
{
	display:none;
}

.model-toolbar .model-prev::after{content:"\f01e"; transform:rotate(-45deg)}
.model-toolbar .model-next::after{content:"\f0e2"; transform:rotate(45deg)}
.model-toolbar .model-zoom-in::after{content:"\f00e";}
.model-toolbar .model-home::after{content:"\f015";}
.model-toolbar .model-zoom-out::after{content:"\f010";}
.model-toolbar .model-fullscreen::after{content:"\f065";}
.model-toolbar .model-maximize::after{content:"\f31e";}
.model-toolbar .model-settings::after{content:"\f013";}

.model-direction
{
	right:0;
	bottom:0;
	font-size:2em;
}

.model-direction::after
{
	padding:.5em;
	content:"\f602"; 
	transform-style: preserve-3d;
	transform:rotate(calc(-45deg + var(--model-direction)))
}

.model-quality
{
	left:0;
	bottom:0;
	font-size:2em;
}

.model-quality::after{
	padding:.5em;
	content:"\e1ae";
}

.model-quality.active::after{
	color:#00ff00;
}

.offer
{
	--offer-height: 100dvh ;
	--offer-sidebar-margin: 0px;
	margin:0px auto;
	font-family: "bebas-neue-pro-expanded", sans-serif;
	font-weight: 500;
}

.offer > .wrapper
{
	width: 100%;
}

.offer h2
{
	font-weight: 700;
}

.offer .text .typo,.offer .slideshow .swiper-captions,.facts
{
	font-size: clamp(1em,3vw,22px);	
}

.facts
{
	font-size: clamp(.9em,3vw,20px);	
}

.slideshow .content
{
	margin:calc(var(--content-padding-vertical)/2) auto;
}

.offer.offer-has-iso > .wrapper
{
	background-color: var(--offer-background-color,none);
}

.offer.offer-has-iso .offer-ui
{
	grid-area: iso;
	pointer-events:none;
	overflow:hidden;
}

.offer.offer-has-iso .offer-ui > *
{
	pointer-events:auto;
}

.offer.offer-has-iso .offer-ui,
.offer.offer-has-iso .offer-iso
{
	position:sticky;
	top:0px;
	width:100%;
}

.offer.offer-has-iso.offer-size-medium .offer-iso
{
	aspect-ratio: var(--is-iso-aspect-ratio,1);
}

.offer.offer-has-iso.offer-size-large .offer-iso,
.offer.offer-has-iso.offer-size-large .offer-ui
{
	height:var(--offer-height);
}

.offer.offer-has-iso .offer-iso
{
	display:grid;
	overflow:hidden;
}

.offer.offer-has-iso.offer-size-medium .offer-iso
{
	grid-area: iso;
}

.offer.offer-has-iso.offer-size-large .offer-iso
{
	display:grid;
	overflow:hidden;
	grid-area: iso / iso / sidebar / sidebar;
}

.offer [data-iso3d]
{
	--is-iso-meta_zone_state_active_color: #1e2d4ab3;
}

.offer .houses .house[data-house="haus_a1"] [data-reference]:hover,
.offer .houses .house[data-house="haus_a1"] [data-reference].active,
.offer .houses .house[data-house="a1"] [data-reference]:hover,
.offer .houses .house[data-house="a1"] [data-reference].active
{
--hover-color:#9FBFD0;
}

.offer .houses .house[data-house="haus_a2"] [data-reference]:hover,
.offer .houses .house[data-house="haus_a2"] [data-reference].active,
.offer .houses .house[data-house="a2"] [data-reference]:hover,
.offer .houses .house[data-house="a2"] [data-reference].active
{
	--hover-color:#9FBFD0;
}

.offer .houses .house[data-house="haus_b1"] [data-reference]:hover,
.offer .houses .house[data-house="haus_b1"] [data-reference].active,
.offer .houses .house[data-house="b1"] [data-reference]:hover,
.offer .houses .house[data-house="b1"] [data-reference].active
{
	--hover-color:#EAD5B8;
}


.offer .houses .house[data-house="haus_c1"] [data-reference]:hover,
.offer .houses .house[data-house="haus_c1"] [data-reference].active,
.offer .houses .house[data-house="c1"] [data-reference]:hover,
.offer .houses .house[data-house="c1"] [data-reference].active
{
	--hover-color:#B3C4A6;
}



.offer .houses .house[data-house="haus_c2"] [data-reference]:hover,
.offer .houses .house[data-house="haus_c2"] [data-reference].active,
.offer .houses .house[data-house="c2"] [data-reference]:hover,
.offer .houses .house[data-house="c2"] [data-reference].active
{
	--hover-color:#B3C4A6;
}

.offer .houses .house[data-house="haus_c3"] [data-reference]:hover,
.offer .houses .house[data-house="haus_c3"] [data-reference].active,
.offer .houses .house[data-house="c3"] [data-reference]:hover,
.offer .houses .house[data-house="c3"] [data-reference].active
{
	--hover-color:#B3C4A6;
}

.offer .houses .house[data-house="haus_c4"] [data-reference]:hover,
.offer .houses .house[data-house="haus_c4"] [data-reference].active,
.offer .houses .house[data-house="c4"] [data-reference]:hover,
.offer .houses .house[data-house="c4"] [data-reference].active
{
	--hover-color:#B3C4A6;
}


.offer .houses .house[data-house="haus_d1"] [data-reference]:hover,
.offer .houses .house[data-house="haus_d1"] [data-reference].active,
.offer .houses .house[data-house="d1"] [data-reference]:hover,
.offer .houses .house[data-house="d1"] [data-reference].active
{
	--hover-color:#E2C8C4;
}

.offer .houses .house[data-house="haus_d2"] [data-reference]:hover,
.offer .houses .house[data-house="haus_d2"] [data-reference].active,
.offer .houses .house[data-house="d2"] [data-reference]:hover,
.offer .houses .house[data-house="d2"] [data-reference].active
{
	--hover-color:#E2C8C4;
}

.offer .houses .house[data-house="haus_d3"] [data-reference]:hover,
.offer .houses .house[data-house="haus_d3"] [data-reference].active,
.offer .houses .house[data-house="d3"] [data-reference]:hover,
.offer .houses .house[data-house="d3"] [data-reference].active
{
	--hover-color:#E2C8C4;
}



.offer [data-iso3d]
{
	aspect-ratio: auto;
}

.offer [data-iso] svg
{
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
}

.offer [data-iso] .is-iso-level 
{
	transition: all .6s ease;
}

.offer [data-iso] .is-iso-level.is-iso-open 
{
	transform: translateY(var(--is-iso-level-spacing));
}

.offer .offer-sidebar
{
	position:relative;
	container-type: inline-size;

	
}

.offer.offer-has-iso .offer-sidebar
{
	grid-area: sidebar;
}

.offer.offer-has-iso.offer-size-large,
.offer.offer-has-iso.offer-has-background
{
	--offer-sidebar-margin: 0em;
}

.offer.offer-has-iso.offer-size-large .offer-sidebar,
.offer.offer-has-iso.offer-has-background .offer-sidebar
{
	margin:var(--offer-sidebar-margin);
}

.offer.offer-has-iso .offer-list
{
	background:rgb(248, 247, 247)	;
}

.offer-popup-header
{
	background: white;
}

.offer.offer-has-iso .offer-popup 
{
	background: white;
	border-left:1em solid rgb(248, 247, 247);
}

.offer.offer-has-iso .offer-list
{
	grid-area: list;
	padding:calc(var(--content-padding-vertical) / 3) calc(var(--content-padding-horizontal) *.6);
	box-sizing: border-box;
}

.offer .offer-title
{
	display:flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 1.25em;
}

.offer .offer-title h1
{
	margin:0;
}

.offer.offer-has-iso .offer-detail
{
	grid-area: detail;
	position:sticky;
	bottom:0;
	width:100%;
	height:0;
	transition:all .5s;
	transform:translateY(100%);
	opacity:0;
	pointer-events:none;
	z-index: 100;

}

.offer.offer-has-iso.offer-state-popup .offer-detail
{
	transform:translateY(0%);
	height:var(--offer-height);
	opacity:1;
	pointer-events:auto;
}

@keyframes fade-in
{
	0% {transform:translateY(100%);opacity: 0;}
	100% {transform:translateY(0%);opacity: 1;}
}

@keyframes fade-out
{
	0% {opacity: 1;}
	100% {opacity: 0;}
}

.offer.offer-has-iso .offer-popup
{
	display:none;
	box-sizing: border-box;
}

.offer.offer-has-iso .offer-popup.toggled
{
	display:block;
	overflow:auto;
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	animation: fade-in 250ms forwards;
}

.offer.offer-has-iso .offer-popup .offer-popup-header
{
	position:sticky;
	top:0;
	z-index: 200;
	display: flex;

	flex-direction: column;
}

.offer-popup .offer-popup-body > .wrapper,.offer-popup .offer-popup-header > .wrapper
{
	padding-left:calc(var(--content-padding-vertical) / 3);
	padding-right:calc(var(--content-padding-vertical) / 3);
	margin:calc(var(--content-padding-vertical) / 3) 0;
}

.offer-popup .offer-popup-header > .wrapper
{	
	margin-bottom: 0px;
	width: calc(100% - calc(calc(var(--content-padding-vertical) / 3) * 2));
}
.offer-popup-header
{
	padding-bottom:calc(var(--content-padding-horizontal) / 2);

}

.offer-popup .offer-popup-body > .wrapper
{
	margin-top:0px;
}

.offer-popup .offer-popup-body > .wrapper,.offer-popup .offer-popup-header > .wrapper
{
	max-width: 23em;
	margin-left: auto;
	margin-right: auto;
}

.offer-popup .offer-popup-header h1
{
	display:grid;
	grid-template-columns: 1fr;
	gap: .2em;
}

.offer-popup .offer-popup-header h1 > span:first-child
{
	order: 2;
}

.offer-popup-close i
{
	margin-left:-.3em;
}

.offer-popup .offer-popup-close
{
	display:none;
	font-family: 'Mulish', sans-serif;
	font-weight: 500;
	font-size: clamp(.9em,2.4vw,24px);
	margin-bottom: 1em;
}

.offer.offer-has-iso .offer-popup .offer-popup-close
{
	display:block;
	cursor:pointer;
}

.offer.offer-has-iso .offer-popup.closing
{
	animation: fade-out 250ms forwards;
}

.offer .offer-tooltips
{
	position:absolute;
}


.offer .offer-tooltip
{
	--offer-tooltip-padding: 0em; 
	--offer-tooltip-background:#f8f7f7;
	
	display:none;
	width:30ch;
	transform-style: preserve-3d;
	text-align:center;
	container-type: inline-size;
	position:absolute;
	transform: translateX(-50%);
	pointer-events:none;
	padding:var(--offer-tooltip-padding);
	transition: opacity .5s;
	z-index:var(--offer-tooltip-z);
	cursor:pointer;
	font-size: clamp(.8em, 4vw,1em);
}

.offer .offer-tooltip.active
{
	display:block;
}

.offer .offer-tooltip::after
{
	content:"";
	display:block;
	position:absolute;
	width: 0; 
	height: 0; 
}

.offer .offer-tooltip .property-body
{
	display:block;
}

.offer .offer-tooltip.offer-tooltip-occluded
{
	opacity:.5;
}

.offer .offer-tooltip.offer-tooltip-orientation-top
{
	transform:translate(calc(-50% + var(--offer-tooltip-x)), calc(-100% + var(--offer-tooltip-y)));
}

.offer .offer-tooltip .property-container
{
	background:var(--offer-tooltip-background);
	padding:0 .5em;
}

.offer .offer-tooltip  .property-facts
{
	--property-column-sizes-required:minmax(0,.6fr) minmax(0,0.6fr) minmax(0,0.6fr);
}

.offer .offer-tooltip .property-field-title
{
	font-weight: 600;
	font-size:1.1em;
	color:var(--text-color-offer);
}

.offer .offer-tooltip .primary
{
	text-align:center;
}

.offer.offer-has-iso > .wrapper
{
	padding:0;
	margin:auto;
	max-width:none;
}

.offer.offer-has-iso > .wrapper > .items
{
	position:relative;
	display:grid;
}

.offer.offer-has-iso.offer-size-medium > .wrapper > .items
{
	grid-template-areas: "start iso sidebar end";
	grid-template-columns: auto minmax(0,60em) minmax(0,calc(40em + var(--offer-sidebar-margin) * 2)) auto;
}

.offer.offer-has-iso.offer-size-large > .wrapper > .items
{
	grid-template-areas: "iso sidebar";
	grid-template-columns: auto minmax(0,calc(40em + var(--offer-sidebar-margin) * 2));
}


.offer .houses table,
.facts table
{
	width: 100%;
	border-collapse: collapse;
}
.offer .houses .property-container + p{
	margin-top:.6em;
}
.offer .houses [data-offer-link]:hover
{
	cursor:pointer;
}
.houses .house:last-child
{
	margin-bottom: 1em;
}
.property-header
{
	border-bottom: 3px solid var(--offer-border-color);
}

.offer .offer-list .property-body
{
	border-bottom: 2px solid var(--offer-border-color);
}

.offer-popup .facts tr:first-child td
{
	border-top: 2px solid var(--offer-border-color);
}

.offer-popup .facts td:last-child
{
	text-align: right;
}

.offer .links a
{
	width: 100%;
	text-align: center;
	font-weight: bold;
}

.offer .button:not(.nav-toggle):not(.f-button), .offer button:not(.nav-toggle):not(.f-button)
{
	font-weight: bold;
}

.facts tr td,
.offer-tooltip .property-field,.offer .offer-tooltip .property-field-title
{
	border-bottom: 2px solid var(--offer-border-color);
	letter-spacing: .04em;
}

.offer-tooltip .property-body div:nth-last-child(-n + 2) .property-field
{
	border:0px;
}

.offer .houses td,
.offer .houses th,
.offer-tooltip .property-field
{
	padding:.35em .5em;
	white-space: nowrap;
}

.offer .house:first-child h2
{
	margin-top: .9em;
}

.offer .house h2
{
	font-size: clamp(1.5em,4vw,1.9em);
	margin-top: 1.2em;
	font-family: 'Mulish', sans-serif;
	margin-bottom: .4em;
	font-weight: 500;
}


.offer .houses [data-reference]:hover,
.offer .houses [data-reference].active
{
	background:var(--hover-color);
}

.offer.offer-has-iso .houses [data-reference].selected
{
	background:white;
}


.offer .offer-list .property-body[data-availability_status='reserved'],
.offer .offer-list .property-body[data-availability_status='reserved'].selected,
.offer .offer-list .property-body[data-availability_status='sold'],
.offer .offer-list .property-body[data-availability_status='sold'].selected
{
	background: #ec671975;
}



.offer .property-header,
.offer .property-body
{
	display:grid;
	grid-template-columns: minmax(0,.6fr) minmax(0,2fr) minmax(0,1fr) minmax(0,.2fr);
	grid-template-areas: "property-title property-facts property-primary property-arrow";
}

.offer .offer-tooltip .property-arrow{
	display: none;
}

@container (max-width: 22em)
{
	.offer  .property-field-floor
	{
		text-align: left;
	}
	.offer .property-header,
	.offer .property-body
	{
		grid-template-columns: minmax(0,2fr) minmax(0,1.2fr) minmax(0,.2fr);
		grid-template-areas: "property-title property-title property-arrow"
			"property-facts property-primary property-arrow";
	}
}

.offer .offer-list .property-container
{
	display:flex;
	flex-direction:column;
	letter-spacing: .02em;
}

.offer .offer-list .property-body
{
	padding:.25rem;
}



.offer .offer-list [data-reference]
{
	cursor:pointer;
}

.offer .offer-list .property-header,.offer.offer-has-iso .offer-list .property-header,.offer.offer-has-iso .offer-list .property-body
{
	padding:.5rem .35rem;
}


.offer .property-header .property-field
{
	text-transform:uppercase;
	font-size:clamp(.75em,3vw,.8em);
	font-weight: 600;
}

.offer .property-title
{
	grid-area: property-title;
}

.property-header .property-field
{
	letter-spacing: .08em;
}

.property-field
{
	letter-spacing: .04em;
}

.offer .property-facts
{
	grid-area: property-facts;
	display:grid;
	grid-template-columns: var(--property-column-sizes);
}


.property-header
{
	color:#687885;	
}

.offer .property-primary
{
	grid-area: property-primary;
}
.offer .property-arrow
{
	grid-area: property-arrow;
	display: flex;
	align-items: end;
}


.offer-popup .facts td
{
	padding:.5rem 0;
}

.offer-popup .facts td:first-child
{
	font-weight: bold;
	text-transform: uppercase;
	color:var(--text-color-offer);
}

.offer .property-field
{
	overflow:hidden;
	text-overflow: ellipsis;
	white-space:nowrap;
	box-sizing: border-box;
	padding-right:.2em;
}

.offer .title h1
{
	font-weight: 200;
	font-family: 'Mulish', sans-serif;
}


body .offer .title h1
{
	margin:.3em 0;
}

.property-field-floor
{
	text-align: center;
}

@container (max-width: 60em)
{
	.offer .property-field
	{
		display:none;
	}
	
	.offer .property-field.required
	{
		display:block;
	}
	
	.offer .property-facts
	{
		grid-template-columns: var(--property-column-sizes-required);
	}


}

.offer.offer-has-iso .iso 
{
	position:relative;
	display:grid;
}

.offer.offer-has-iso .iso > img
{
	width:100%;
}

.offer .filter-button
{
	display:grid;
	align-items:center;
	grid-template-columns:auto 1fr auto;
	gap:.5em;
	background:none;
	padding:.5em 0;
	cursor:pointer;
}

.offer .filters
{
	display:flex;
	flex-wrap:wrap;
	gap:0em;
	padding: 0;
	margin-top:1px;
}

.filter-title
{
	margin-bottom: .5em;
}

@container (max-width:40em)
{
	.offer .filters
	{
		flex-direction:column;
	}
}

.offer .toggled .filters,
.offer .filter-button:not(.active) .fa-angle-up,
.offer .filter-button .fa-angle-down
{
	display:none;
}

/*
.offer .filter-disabled,
.offer .filters-disabled
{
	display:none;
*/
.offer .filters .filter-items
{
	display: grid;
	grid-template-columns: repeat(3,1fr);
	max-width: 29em;
	gap:.25em;
}

.offer .filters .filter
{
	width: 100%;
}

.offer .filters .filter[data-filter-type=slider]
{
	flex: 1 0 auto;
	min-width:8em;
}

.offer .filters .filter[data-filter-type=slider][data-filter-field=rentalprice_incl],
.offer .filters .filter[data-filter-type=slider][data-filter-field=sellingprice],
.offer .filters .filter[data-filter-type=slider][data-filter-field=rentalpriceexcl_m2y]
{
	flex: 2 0 auto;
}

.offer .filters .checkbox
{
	display:block;
	margin:0;
	white-space: nowrap;
	display: flex;
	gap:.5em;
	font-weight: 400;
}

.offer .filtered
{
	display:none;
}
@media(max-width:1300px)
{	
	.offer .property-header .property-field{
		font-size: .65em;
	}
.offer.offer-has-iso.offer-size-large > .wrapper > .items{
	grid-template-columns:auto minmax(0,calc(32em + var(--offer-sidebar-margin) * 2));
}
}
@media(max-width:1000px)
{	
	
	:root
	{
		--nav-padding-horizontal:clamp(1.1rem, 3.5vw, 3.5rem);

	}

	.nav-toggle
	{		top: calc(var(--nav-padding-vertical) + (var(--content-padding-vertical) * .5) );

	}
	
	.offer .house:first-child h2
	{
		margin-top: 1.3em;
	}
	.offer .house h2
	{

		margin-top: 1.6em;

		margin-bottom: .25em;

	}
	

	.offer.offer-has-iso .offer-popup 
	{
		border-left: 0px;
	}

	.offer.offer-has-iso .offer-list
	{
		padding:calc(var(--content-padding-vertical) / 3) var(--content-padding-horizontal);
	}
	.offer.offer-has-iso.offer-size-medium > .wrapper > .items,
	.offer.offer-has-iso.offer-size-large > .wrapper > .items
	{
		grid-template-columns: none;
		grid-template-areas: "iso"
		"sidebar";
		height:auto;
	}
	
	.offer.offer-has-iso.offer-size-medium .offer-ui,
	.offer.offer-has-iso.offer-size-medium .offer-iso,
	.offer.offer-has-iso.offer-size-large .offer-ui,
	.offer.offer-has-iso.offer-size-large .offer-iso
	{
		grid-area: iso;
		height: 50dvh;
		z-index:2;
	}
	
	.offer.offer-has-iso .offer-iso
	{
		background:var(--offer-background-color,white);
	}
	
	.offer.offer-has-iso.offer-state-popup .offer-detail
	{
		height: 50dvh;
	}
	
	.offer.offer-has-iso.offer-size-large .offer-sidebar,
	.offer.offer-has-iso.offer-has-background .offer-sidebar
	{
		margin:0;
		display:block;
	}
	
	.offer .offer-tooltip.offer-tooltip-orientation-top
	{
		transform: translate(calc(-50% + var(--offer-tooltip-x)), calc(-100% + var(--offer-tooltip-y))) scale(.5) translateY(50%);
	}
}

.property_status.tag-pill
{
	display: none;
	font-size:.5em;
	vertical-align:middle;
	border-color:var(--contrast-color);
	color:var(--contrast-color);
	margin-top: -.3em;
}

:not([data-availability_status="free"]) .property_status.tag-pill
{
	--contrast-color:var(--status-color-unavailable);
}

[data-availability_status="reserved"] .property_status.tag-pill
{
	--contrast-color:var(--status-color-unknown);
}

[data-availability_status="free"] .property_status.tag-pill
{
	--contrast-color:var(--status-color-available);
}

.plan img
{
	display:block;
	width:100%;
	box-shadow: 0 0 2px 1px #ddd;
	margin: 0px auto;
}

::placeholder
{
	color:#0A2329;
	opacity: 1;
	font:inherit;
}

input,
select
{
	margin:0;
}
select{
	background-color: white;
}

.form textarea
{
	height: 80px;
	font:inherit;
	color:inherit;
	font-weight: normal;
}

input[type=text],
input[type=email],
input[type=tel],
textarea,
button,
select
{
	box-sizing:border-box;
	font:inherit;
	color:inherit;
}

input[type=text],
input[type=email],
input[type=tel],
textarea,
select
{
	display:block;
	width:100%;
	border:1px solid var(--theme-color);
	padding:.5em;
	border-radius: 0;
}


input[type=text],
input[type=email],
input[type=tel],
textarea,
select
{
	display:block;
	width:100%;
	border:0px solid var(--theme-color);
	padding:.6em .5em .4em .5em;
	border-radius: 0;
	font-weight: normal;
	
}

.filter input[type=checkbox], .filter input[type=radio]
{
	margin-bottom: .5em;
}

input[type=checkbox],
input[type=radio]
{
	appearance:none;
	-webkit-appearance:none;
	flex:0 0 auto;
	width:1.2em;
	height: 1.2em;
	background: white;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	border:0;
	border-radius: 0;
	font-size:inherit;
	font-size:.9em;
	margin-bottom: -.1em;

}

input[type=checkbox]:after,
input[type=radio]:after
{
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	font:var(--fa-font-sharp-regular);
	color:var(--text-color);
}

.property-field.property-field-arrow::after{
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	content: " ";

	font:var(--fa-font-sharp-regular);
	font-size: .8em;
	width: 1em;
	height: 1em;
}
.property-body .property-field.property-field-arrow::after{
	content: "\f105";	
}
.property-arrow{
	display: flex;
	justify-content: end;
}

input[type=checkbox]:after{content: "";}
input[type=checkbox]:checked:after{content: "\f00c";}
input[type=radio]:after{content:"";}
input[type=radio]:checked:after{content: "\f00c";}

.button:not(.nav-toggle):not(.f-button),
button:not(.nav-toggle):not(.f-button)
{
	font-family: 'Mulish', sans-serif;
	background:none;
	border:none;
	color:white;
	cursor:pointer;
	padding:.6em 2em .6em 2em;
	white-space: nowrap;
	display: inline-block;
	font-weight:normal;
	border:1px solid var(--theme-color);
	color:#0a2329;
	text-transform: uppercase;
}

.offer .button
{
	font-weight: 700;
}

.button.primary:not(.nav-toggle):not(.f-button), button.primary:not(.nav-toggle):not(.f-button)
{
	font-weight:700;
}

.button.secondary,
button.secondary
{
	color:var(--theme-color);
	border:1px solid var(--theme-color);
	background:none;
}

button:not(.nav-toggle):hover,.button:not(.nav-toggle):hover
{
	
	color:var(--hover-color);
	border-color: var(--hover-color);
}

select
{
	appearance:none;
}

strong
{
	font-weight: 500;
}

.responsive
{
	position: relative;
	padding-bottom: 40.25%;
	padding-top: 0px;
	height: 0;
	overflow: hidden;
	border: clamp(4px,1vw,8px) solid white;
	background:white;
}

.responsive iframe,
.responsive > .consent-content
{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border:0;
}

.text-left
{
	text-align: left;
}

.text-center
{
	text-align: center;
}

.text-right
{
	text-align: right;
}

.fancybox__container
{
	--fancybox-bg: rgba(24, 24, 27, 0.92);
}

.fancybox__carousel .fancybox__slide.has-iframe .fancybox__content
{
	
	height: 100% !important;
}
.fancybox__carousel .fancybox__slide.has-iframe{
	padding-bottom: 40px;
}

.fancybox__content {
	padding:0;
	width:60em;
	max-width:100%;
}

.fancybox__slide.has-image .fancybox__content {
	width: 100%;
}

.fancybox__container .text .typo,.fancybox__container  .consent-links a,.fancybox__content .button,
.fancybox__content button
{
	font-size:clamp(1em,2.8vw,20px);
}
.fancybox__content .title h1,.consent-dialog .consent-settings h1,.fancybox__content .subtitle h2
{

	font-size: clamp(1.9em,8vw,55px);
}

.fancybox__content .consent-preferences h2
{
	font-size: clamp(1.2em,3vw,1.4em);
}

.icon::after,
.icon::before
{
	text-align: center;
	font:var(--fa-font-sharp-regular);
}

.offer-popup-close i
{
	font:var(--fa-font-sharp-regular);
}

.consent-cover
{
	position:absolute;
	width:100%;
	height:100%;
	background:rgba(0,0,0,.2);
	display:flex;
	justify-content: center;
	align-items:center;
}

.consent-cover .consent-message
{
	text-align:center;
}

.consent-cover-info
{
	display:flex;
	flex-direction:column;
	align-items: center;
	gap:.5em;
	padding:2em;
}
.consent-cover .links .items{
	justify-content: center;
}
.consent-dialog
{
	position:sticky;
	bottom:0;
	background:white;
	z-index:100;
	box-shadow: 3px 3px 10px 0px rgb(50 50 50);
}
.consent-settings button.primary,.consent-dialog button.primary
{
	background: var(--hover-color);
	border-color: var(--theme-color);
	color:white;
}

.consent-settings button,.consent-dialog button
{
	border-color: var(--theme-color);
	font-weight: bold;
}

.consent-settings .links .items,.consent-dialog .links .items{
	gap:.5em;
	display: flex;
	flex-wrap: wrap;
}

.consent-dialog .wrapper
{
	display:flex;
	flex-direction:column;
	gap:.5em;
	margin:auto;
	max-width:var(--content-width);
	padding:1.5em var(--content-padding-horizontal);
}

.toggle-button
{
	font-size:1.4em;
	position:relative;
	width:2em;
	height:1em;
	background:gray;
	box-sizing:border-box;
	border-radius:.5em;
	transition:background .5s;
	cursor:pointer;
}

.toggle-button::after
{
	content:"";
	position:absolute;
	left:0;
	top:0;
	width:calc(1em - 4px);
	height:calc(1em - 4px);
	margin:2px;
	background:white;
	border-radius:.4em;
}

.toggle-button.active
{
	background:green;
}

.toggle-button.active::after
{
	right:0;
	left:auto;
}

a[consent-settings]
{
	cursor: pointer;
}

.consent-settings .tab
{
	border-top:1px solid black;
}

.consent-settings .consent-preferences
{
	border-bottom: 1px solid black;
}

.consent-settings .tab .header
{
	display:flex;
	justify-content: space-between;
	align-items:center;
	gap:.5em;
}

.consent-links
{
	gap:.5em;
	display:inline-flex;
	text-decoration: underline;
	flex-wrap: wrap;
}

.consent-links a
{
	font-weight: 300;
	text-decoration: underline;
}

.consent-settings .tab [data-toggle]
{
	cursor:pointer;
}

.consent-settings .tab [data-toggle] h2
{
	display: flex;
	gap:.5em;
	align-items: center;
}

.consent-settings .tab [data-toggle] h2::before
{
	display: grid;
	width:1em;
	height:1em;
	place-items:center;
	font:var(--fa-font-sharp-regular);
	content:"\f054"
}

.consent-settings .tab [data-toggle].active h2::before
{
	content:"\f078";
}

.consent-settings .tab .body
{
	padding-bottom: 1em;
}

.tab .body.toggled
{
	display:block;
}

.tag-pill
{
	padding:.1em .5em;
	border: 1px solid var(--odd-color);
	border-radius:.5em;
	margin-top:-.25em;
}

.hidden
{
	display:none;
}

@media(orientation: portrait)
{
	main .images img {
		height: 50vh;
		height: 50dvh;
	}
	.slideshow.limited .swiper-slide > img{
		max-height: 50dvh;
	}
}

@media(max-width:574px)
{
	.fancybox__carousel .fancybox__slide.has-iframe{
		padding-bottom: 4px;
	}
}

@media(max-width:520px)
{
	
	footer nav
	{
		flex-direction: column;
		gap: .4em;
		margin-bottom: 1.4em;
	}

	.offer .offer-list .property-header, .offer.offer-has-iso .offer-list .property-header, .offer.offer-has-iso .offer-list .property-body{
		padding:.5rem .25rem;
	}
}
