/********************************/
/* COMMON ELEMENTS
/********************************/



/* 
Contents:
- Buttons
- Icons
- Loaders 
- Faders
- Swipers
- Lightbox
- Accordion gallery
- Pan and Zoom
- Video players
- Parallax 
- Google maps
- Text lists
- Masonry lists
- Isotope lists
- Custom select
- Custom radio group
- Forms
*/ 



/* Loaders */ 
.loader {
	position: absolute;
	z-index: -999;
	inset: 0;
	background-color: var(--white-color);
	opacity: 0;
	-webkit-transition: opacity 0.4s ease 0s, z-index 0s ease 0.4s;
			transition: opacity 0.4s ease 0s, z-index 0s ease 0.4s;
}
.loader.on {
	z-index: 999;
	opacity: 1;
	-webkit-transition: opacity 0.4s ease 0s, z-index 0s ease 0s;
			transition: opacity 0.4s ease 0s, z-index 0s ease 0s;
}
.loader.one {
	z-index: 9999;
}
.loader:after {
	content: '';
	display: block;
	position: absolute;
	inset: 0;
	width: 5em;
	height: 5em;
	margin: auto;
	/*background: var(--text-color); */ 
	background: url('data:image/png;base64,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') 50% 50% no-repeat;
	opacity: 0;
	-webkit-transition: opacity 0.4s ease 0s;
			transition: opacity 0.4s ease 0s;
}
.loader.on:after {
	opacity: 1;
	-webkit-transition: opacity 0.4s ease 0.8s;
			transition: opacity 0.4s ease 0.8s;
}
.loader.loading:after {
	-webkit-animation: loader-animation 5.0s infinite ease-in-out;
			animation: loader-animation 5.0s infinite ease-in-out;
}
@-webkit-keyframes loader-animation {
	  0% { -webkit-transform: perspective(12em); }
	 25% { -webkit-transform: perspective(12em) rotateY(360deg); }
	 35% { -webkit-transform: perspective(12em) rotateY(360deg); }
	 60% { -webkit-transform: perspective(12em) rotateY(720deg); }
	100% { -webkit-transform: perspective(12em) rotateY(720deg); }
}
@keyframes loader-animation {
	  0% { transform: perspective(12em); }
	 25% { transform: perspective(12em) rotateY(360deg); }
	 35% { transform: perspective(12em) rotateY(360deg); }
	 60% { transform: perspective(12em) rotateY(720deg); }
	100% { transform: perspective(12em) rotateY(720deg); }
}
#site-loader {
	position: fixed;
}
/***/



/* Faders */
.fader { 
}
.fader-items {
	position: relative;
	height: 100%;
}
.fader-items > div {
	position: absolute;
	inset: 0;
	opacity: 0;
	-webkit-transition:	opacity 1s cubic-bezier(0.250, 0.460, 0.450, 0.940) 1s; 
			transition:	opacity 1s cubic-bezier(0.250, 0.460, 0.450, 0.940) 1s;
}
.fader-items > div.current {
	position: relative;
	z-index: 3;
	height: 100%;
	opacity: 1;
	-webkit-transition:	opacity 1s cubic-bezier(0.250, 0.460, 0.450, 0.940) 0s; 
			transition:	opacity 1s cubic-bezier(0.250, 0.460, 0.450, 0.940) 0s;
}
/*
.fader-items > div > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
*/
/***/



/* Swipers */
.swiper-container { 
	--swiper-navigation-sides-offset: var(--gutter);
}
.small-swiper-container {
	height: 384px;
}	
.big-swiper-container {
	height: 768px;
}
.full-swiper-container {
	height: 100%;
}
.fit-screen-swiper-container {
	height: 100vh;
}
.swiper-container.overflow-hidden {
	overflow: hidden;
}
.swiper-button-prev, 
.swiper-button-next, 
.swiper-rtl .swiper-button-prev, 
.swiper-rtl .swiper-button-next {
	width: clamp(29px,5vw,58px);
	height: clamp(29px,5vw,58px);
	border-radius: 50%;
	filter: drop-shadow(1px 2px 4px rgba(0, 0, 0, 0.5));
}
.swiper-button-prev:after, 
.swiper-button-next:after {
	content: none !important;
}

/*
.swiper-rtl .swiper-button-prev:after, 
.swiper-rtl .swiper-button-next:after {
	content: none;
}
.swiper-button-prev, 
.swiper-rtl .swiper-button-next {
	background: var(--primary-color) url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAASJJREFUeNpi+P//PwMFmB+IzwCxAy41lBjOAsRX/0PATyDWpKYF7EB87T8mcENXy8JAOuAC4ktArIwmfg+I72OoJtHlHEB8C4vLD1AjDriB+C4Ww3fj00es4XxAfB+L4dsI6SXGcAEgfoLF8I3EOI6QAmEgfobF8NXEBi0+SXEgfoXF8BWkJAxcElJA/BqL4StJzTPYBD3+Ywdt5GRKJiwZiQ1HBvvBQA7AYbMiEH/C4osF1AgiGJYD4g9YLJlHLQtAWBqI32KxZBG1LIAlV2wpahm1LABhUSB+jsWStdSyAIQFgfgpFks2UMsCWBX5mJRCj5zaTBCHJReAWJ6YjEYIvAdiHSB+iCauDxWnqEbDVwGZULtVAUtdt4HYHZcagAADAKv0ULE36hQUAAAAAElFTkSuQmCC') 50% 50% no-repeat;
}
.swiper-button-next, 
.swiper-rtl .swiper-button-prev {
	background: var(--primary-color) url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAQ5JREFUeNqs1c0KAVEUB/BJQpSPpCmKLKeUjQewwpN5DMlCJMXGxsYDWNiwICb5KhJZsbr+N2zGucxM59Rvc0z3P+Z+aUIITaEIY4j8eOYv1Q8GPMSrpuDlDCiJ75qB302AR/suE1aWngFTCGpO60f6iPgncwhwzMHHkAhZQogrQBoQISaEuQKkPhGyhShXgNQhQvYQ5wqQWkTIEXSuAKlNhJwgyRUgVQVdFTsbzU7dFX2fk42mUife/AZZjk9UIwa/QppjkhvE4GdIcSzTpmLl6BwbrUsMfoAEx1HRIwbfQYzjsKMOuY3TK5RqZmCiGDzGcaPlIG/prd/9C9eNVnB7wTiZgzIs7K4WlacAAwD4cVC4bHoYegAAAABJRU5ErkJggg==') 50% 50% no-repeat;
}
*/

/*

.swiper-container ~ .swiper-button-prev {
	left: clamp(-90px, -5vw, -30px);
}
.swiper-container ~ .swiper-button-next {
	right: clamp(-90px, -5vw, -30px);
}

*/

.swiper-slide {
	overflow: hidden;
}
.swiper-slide img {
	display: block;
}

.swiper-slide figcaption,
.swiper-slide-caption {
	position: absolute;
	bottom: 0;
	width: 100%;
	padding: 0.5em 1em;
	background: rgba(4, 67, 73, 0.8);
	color: #fff;
	text-align: center;
	opacity: 0;
	-webkit-transform: translateY(25%);
			transform: translateY(25%);
	-webkit-transition: all 0.4s ease 1s;
			transition: all 0.4s ease 1s;
}
.swiper-slide-active figcaption, 
.swiper-slide-active .swiper-slide-caption {
	opacity: 1;
	-webkit-transform: none;
			transform: none;	
}


@media (min-width : 1200px) {
	
}
/***/



/* Parallax images */
.parallax-container {
	position: relative;
	overflow: hidden;
}
.parallax-img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: auto;
	will-change: transform;
}
/***/



/* Lightbox */
.lightbox {
	position: fixed;
	z-index: -999;
	visibility: hidden;
	inset: 0;
	padding: calc(36px + clamp(0px, 4.5vw, 48px)) clamp(1em, 4.5vw, 96px);
	align-content: center;
	opacity: 0;
	background: rgba(0,0,0,0.95);
	color: var(--white-color);
}
.lightbox.opening {
	z-index: 999;
	visibility: visible;
	opacity: 0;
	-webkit-transition: opacity 0.5s ease;
			transition: opacity 0.5s ease;
}
.lightbox.open {
	z-index: 999;
	visibility: visible;
	opacity: 1;
}
body:has(.lightbox.open) {
}


.lightbox-container {
	display: flex;
	position: relative;
	height: 100%;
}
.lightbox-content {
	flex: 1 0 auto;
	overflow-x: clip;
	overflow-y: auto;
}
.lightbox-content::-webkit-scrollbar {
	border-radius: 99px;
	background: rgba(128,128,128,0.125);
}

.close-lightbox {
	position: absolute;
	z-index: 99;
	width: 48px;
	height: 48px;
	padding: 10px;
	cursor: pointer;
}
.close-lightbox::before,
.close-lightbox::after {
	content: '';
	display: block;
	position: absolute;
	top: 24px;
	width: 28px;
	border-block: 1px solid;
	background-color: currentColor;
	opacity: 0;
}
.lightbox.open .close-lightbox::before,
.lightbox.open .close-lightbox::after {
	opacity: 1;
	-webkit-transition: all 0.4s ease 1s;
			transition: all 0.4s ease 1s;
}
.lightbox.open .close-lightbox::before {
	transform: rotateZ(45deg);
}
.lightbox.open .close-lightbox::after {
	transform: rotateZ(-45deg);
}
.lightbox > .close-lightbox {
	top: clamp(0px, 2.5vw, 24px);
	inset-inline-start: clamp(0px, 2.5vw, 24px);
}
.lightbox-container > .close-lightbox {
	top: -10px;
	inset-inline-end: -48px;
}



.gallery-lightbox {
}
.gallery-lightbox .lightbox-container,
.gallery-lightbox .lightbox-content {
	width: 100%;
	height: 100%;
}
.lightbox .swiper-container {
	height: 100%;
	overflow: clip; 
	text-align: center;
}
.lightbox .swiper-slide figure {
	position: relative;
	width: fit-content;
	height: 100%;
	margin: auto;
	align-content: center;
}
.lightbox .swiper-slide img {
	max-width: 100%;
	max-height: 100%;
	border: 1px solid var(--black-color);
	/*
	width: 100%;
	height: 100%;
	object-fit: contain;
	*/
}
.lightbox .swiper-slide figcaption {
	position: absolute;
	bottom: 0;
	width: 100%;
	padding: 0.5em 1em;
	background: rgba(0,0,0,0.5);
	color: #fff;
	text-align: center;
	-webkit-transform: translateY(100%);
			transform: translateY(100%);
	-webkit-transition: all 0.4s ease 1s;
			transition: all 0.4s ease 1s;
}
.lightbox .swiper-slide-active figcaption {
	-webkit-transform: none;
			transform: none;	
}

.lightbox .swiper-button-prev, 
.lightbox .swiper-button-next {
	color: var(--text-color);
	opacity: 0;
	-webkit-transition: all 0.4s ease 1s;
			transition: all 0.4s ease 1s;
}
.lightbox .swiper-button-prev {
	-webkit-transform: translateX(25px);
			transform: translateX(25px);
} 
.lightbox .swiper-button-next {
	-webkit-transform: translateX(-25px);
			transform: translateX(-25px);
}
.lightbox.open .swiper-button-prev, 
.lightbox.open .swiper-button-next {
	opacity: 1;
	-webkit-transform: none;
			transform: none;	
}


.lightbox .swiper-container ~ .swiper-pagination {
	bottom: -2em;
}
.gallery-lightbox .swiper-pagination-bullet,
.gallery-lightbox .swiper-pagination-bullet-active {
	background-color: var(--text-color);
}



@media (min-width : 1200px) {
	.lightbox .swiper-container ~ .swiper-button-prev {
		left: calc(-1.5em - 10px);
	} 
	.lightbox .swiper-container ~ .swiper-button-next {
		right: calc(-1.5em - 10px);
	}
}



@media (min-width : 1200px) {
}
/***/



/* accordion Gallery */
.accordion-gallery-element {
	display: flex;
	gap: calc(var(--gap) / 2);
}
.accordion-gallery-item {
	position: relative;
	flex: 1;
	overflow: hidden;
	transition: all 0.4s cubic-bezier(0.65, 0, 0.35, 1);
	transform: translate3d(0,0,0);
	will-change: flex;
	cursor: pointer;
	filter: grayscale(1);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.accordion-gallery-item:hover {
	filter: grayscale(0);
}
.accordion-gallery-item:focus {
	flex: 0 0 50%;
	filter: grayscale(0);
}
.accordion-gallery-item figure {
	height: 100%;
}
.accordion-gallery-item img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.accordion-gallery-item figcaption {
	position: absolute;
	inset-block-end: 0;
	inset-inline-start: 0;
	margin: 1em;
	border: 1px solid;
	box-shadow: 1px 2px 4px rgba(0,0,0,0.3);
	padding: 0.75em;
	background: rgba(254, 252, 248, 0.8);
	opacity: 0;
	transition: all 0.2s ease 0s;
}
.accordion-gallery-item:focus figcaption {
	opacity: 1;
	transition: all 0.2s ease 0.4s;
}
.accordion-gallery-item .open-lightbox {
	position: absolute;
	inset: 0;
	z-index: -2;
}
.accordion-gallery-item:focus .open-lightbox {
	z-index: 2;
}

@media (max-width : 1199px) { 
	.accordion-gallery-element {
		min-height: calc(100vh - 128px);
		flex-direction: column;
	}
	.accordion-gallery-item {
		aspect-ratio: 16/9;
		transition: all 0.4s cubic-bezier(0.65, 0, 0.35, 1);
	}
	.accordion-gallery-item:focus {
		aspect-ratio: 1;
	}
	.accordion-gallery-item figcaption {
		font-size: 0.888888em;
	}
}

@media (min-width : 1200px) { 
	.accordion-gallery-element {
		aspect-ratio: 2/1;
	}
}
/***/



/* Isotope Filter */
.isotope-filter {
	position: relative;
	z-index: 9;
	max-height: 3em;
	overflow: hidden;
	margin: 1em auto;
	-webkit-transition: max-height 0.4s ease;
			transition: max-height 0.4s ease;
}
.isotope-filter.open {
	max-height: 100vh;
}
.isotope-filter ul {
	display: flex;
	flex-direction: column;
	background-color: #fff;
}
.isotope-filter.open ul{
	box-shadow: 0 2px 4px -1px rgba(0,0,0,0.5);
}
.isotope-filter li {
	display: flex;
	align-items: center;
	position: relative;
	border-bottom: 1px solid #eee;
	padding-block: 0.6667em;
}
.isotope-filter li.active-filter {
	order: -1;
}
.isotope-filter li.active-filter:after {
	content: '\00ab';
	-webkit-transform: rotate(90deg);
			transform: rotate(90deg);
	-webkit-transition: -webkit-transform 0.2s ease 0.2s;
			transition: 		transform 0.2s ease 0.2s;
}
.isotope-filter.open li.active-filter:after {
	-webkit-transform: rotate(-90deg);
			transform: rotate(-90deg);	
}
.isotope-filter li a {
	display: block;
	flex: 1;
	color: inherit;
}
.isotope-filter li a:hover {
	color: var(--link-hover-color);
}

@media (max-width : 1199px) { 
}

@media (min-width : 1200px) { 
	.isotope-filter {
		max-height: none;
	}
	.isotope-filter ul {
		flex-direction: initial;
		margin-inline: -0.5em;
		background-color: transparent;
	}
	.isotope-filter li {
		border-bottom: 0;
		padding: 0.5em;
	}
	.isotope-filter li.active-filter {
		order: initial;
	}
	.isotope-filter li:not(:first-child):before {
		content: ' | ';
		margin-inline-end: 1em;
	}
	.isotope-filter li.active-filter:after	{
		content: none;
	}
	.isotope-filter li a {
	}
	.isotope-filter li.active-filter a {
		color: var(--link-color);
	}
}

.isotope-list {
	-webkit-transition: height 0.8s ease;
			transition: height 0.8s ease;
}
/***/



/* Text lists */
.default-ul {
	list-style: default;
}

.text-ul {
}

.simple-ul {
	padding-inline-start: 0.75em;
}
.simple-ul li { 
	margin-inline-start: -0.75em;
}
.simple-ul li::before {
	content: '• ';
	display: inline-block;
	width: 0.75em;
}
/***/



/* Masonry Lists */
.masonry-list-element {
}
.masonry-list {
}
.masonry-list-item {
}
/***/



/* Video players */
.video-container {
	background: var(--grey-color);
}
.video-player {
}
.video-container video {
	display: block;
	width: 100%;
	height: auto;
}
/***/



/* Google maps */
.google-map {
}
.google-map > .map-canvas {
	width: 100%;
	height: 100%;
	background: #DDD;
	border: 1px solid #CCC;
}
.google-map.small-map > .map-canvas			{ height: clamp(240px, 32vh, 100vh); }
.google-map.medium-map 	> .map-canvas		{ height: clamp(360px, 48vh, 100vh); }
.google-map.large-map > .map-canvas			{ height: clamp(480px, 64vh, 100vh); }
.google-map.fullscreen-map > .map-canvas 	{ height: 100vh; }

.google-map > .map-title {
	margin: 30px 0;
}

.google-map > .map-marker,
.google-map > .map-pin,
.google-map > .map-infobox {
	display: none;
}

.map-popup-anchor {
	position: absolute; 
	width: 0;
	height: 0;
}
.map-popup-wrapper {
	position: absolute;
	width: max-content;
	min-width: 256px;
	bottom: 15px;
	left: 0;
	border-radius: 4px;
	/*
	background: var(--bg-color);
	color: var(--white-color);
	*/
	filter: drop-shadow(0px 2px 4px rgba(0,0,0,0.5));
	transform: translate3d(-50%,-100px,0);
	opacity: 0;
	-webkit-transition: all 0.6s ease;
			transition: all 0.6s ease;
}
.map-loaded .map-popup-wrapper {
	transform: translate3d(-50%,0,0);
	opacity: 1;
}
.map-popup-content {
	padding: 1em 1.5em;
	font-family: var(--primary-font);
	font-size: 1.6rem;
	line-height: 1.3333em;
	text-align: center;
}
.map-popup-content::after {
	content: "";
	position: absolute;
	bottom: -14px;
	left: 50%;
	transform: translateX(-50%);
	width: 0;
	height: 0;
	border-top: 16px solid var(--bg-color);
	border-left: 12px solid transparent;
	border-right: 12px solid transparent;
	border-bottom: 0;
}
/*
.map-popup-bubble-anchor {
	position: absolute;
	width: 100%;
	bottom: 12px;
	left: 0;
	transform: translate3d(0,-100px,0);
	opacity: 0;
}
.map-loaded .map-popup-bubble-anchor {
	transform: translate3d(0,0,0);
	opacity: 1;
	-webkit-transition: all 0.8s cubic-bezier(0.770, 0.000, 0.175, 1.000);
			transition: all 0.8s cubic-bezier(0.770, 0.000, 0.175, 1.000);
}
.map-popup-bubble-content {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	transform: translate(-50%,-100%);
	background-color: var(--dark-color);
	color: #fff;
	padding: 1em;
	overflow-y: auto;
	box-shadow: 0px 2px 6px 1px rgba(0,0,0,0.3);
	font-size: 1.1667rem;
}
.map-popup-bubble-content h3,
.map-popup-bubble-content h4 {
	margin: 0.25em 0;
}
.map-popup-bubble-content p {
	margin-bottom: 0.75em;
}
.map-popup-bubble-content p:last-child {
	font-size: 0.857142em;
}
.map-popup-bubble-content a {
	color: inherit;
	white-space: nowrap;
}
*/
.map-popup-content .map-infobox-more {
	margin-top: 0.5em;
	border-top: 1px solid;
	padding-top: 0.75em;
}
.map-popup-content .map-infobox-more a {
	display: inline-block;
	width: 24px;
	height: 24px;
	background: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAa5JREFUeNqcljFLw0AYhmNwCMWhYwUnpyLSOWToGEqH/goHx/6NTh37E/IDSqdO0slZRJ1EUaJCUUEFKen5XnlPjiN3l+SDB9LL3fu23333XQMhRNCQGGQgBwVYgzkY6vOaCIdgQlFbSOOoiYEUn4lqkdU1KBO/BCnogAQsjPfDOgZn4Bp8c/FSpcH4ErrJvMke7IN+ibgi0QzWe7s8+eMAHIEf8AS2jrkdkPN5G3qEB2AFPsENeADPYALaljU97fnNtaFTT5Xcg66xLuLG/1dSnVJ8Bxtj7I7zlfhSeyfPSVxFfAVO+b4FxuCXjCzigocx8IkvLdVy7hGfqV9WVXxE0aAk51Zx3WDiEVcpGTNNcvwEXLjElUFsNC5dPORG6rHhhgufuDLIjN5i5rzLknTFtExcGeTaxNRyLtpM46tRhrLCBq7WIltFgROnTvQheHGc7JAto8WW8eXrMXLBh/b52DIvAn3OfwS3VcR3wWtOxaIkl3opylZ9xdZdqfsGvEOFYZLwEkmN3mKtFpeBWUmuqCWuG0Qek4JVFNa9oMyBIfdkTdGcxnHTvzd/AgwADHhtbv9WHZAAAAAASUVORK5CYII=') 50% 50% no-repeat;
}
/***/



/* Forms */
.form-container {
	position: relative;
}
.form-container form {
	text-align: initial;
}
.form-container > form.off {
	opacity: 0;
	-webkit-transition: opacity 0.4s ease;
			transition: opacity 0.4s ease;	
}
.form-row {
	display: flex;
	margin: 0 -10px;
}
.form-col {
	padding: 0 10px;
}
.form-field {
	position: relative;
	margin-bottom: 1.25em;
}
.subscribe-field {
	display: flex;
	align-items: flex-start;
	gap: 0.25em;
	font-size: round(0.75em,1px);
	font-weight: 600;
	line-height: 1;
}
.submit-field {
}

::-webkit-input-placeholder { color: var(--text-color); opacity: 0.7; }
:-moz-placeholder 			{ color: var(--text-color); opacity: 0.7; }
::-moz-placeholder 			{ color: var(--text-color); opacity: 0.7; }
:-ms-input-placeholder 		{ color: var(--text-color); opacity: 0.7; }

input, 
textarea {
	outline: 0;
	background: #f8f8f8;
	color: inherit;
	font: inherit;
	text-align: initial;
	text-align-last: initial;
}
input[type=text], 
input[type=email], 
input[type=password], 
textarea {
	display: block;
	box-sizing: border-box;
	width: 100%;
	border: 1px solid;
	padding: 0.5em 0.75em;
	background: transparent;
	font-size: round(up, 1.125em, 1px);
	-webkit-transition: all 0.2s ease;
			transition: all 0.2s ease;
}
input[type=text]:focus,
input[type=email]:focus,
input[type=password]:focus, 
textarea:focus {
	-webkit-box-shadow: 0px 4px 4px -4px rgba(0,0,0,0.5);
	   -moz-box-shadow: 0px 4px 4px -4px rgba(0,0,0,0.5);
			box-shadow: 0px 4px 4px -4px rgba(0,0,0,0.5);
}
textarea {
	height: calc(7.166667em + 4px);
}

input[type=checkbox] {
	appearance: none;
	vertical-align: middle;
	width: 1.5em;
	height: 1.5em;
	line-height: 1.5em;
	border: 1px solid;
	background: transparent;
	/*
	background: var(--primary-color);
	color: var(--white-color);
	*/
}
input[type=checkbox]:before {
	content: "\00a0";
	display: block;
	height: 100%;
	font-weight: 900;
	text-align: center;
	will-change: transform;
	-webkit-transform: scale(0);
			transform: scale(0);
	-webkit-transition: all 0.2s cubic-bezier(0.33, 1.66, 0.66, 1);
			transition: all 0.2s cubic-bezier(0.33, 1.66, 0.66, 1);
}
input[type=checkbox]:checked:before {
	content: "\2713";
	-webkit-transform: none;
			transform: none;
}
input[type=checkbox] + label {
	vertical-align: middle;
	cursor: pointer;
	text-wrap: balance;
}
.subscribe-field input[type=checkbox] {
	flex: 0 0 auto;
}

input[type=submit] {
	width: 100%;
	border: 1px solid;
	padding: 0.3333em 2em;
	background: transparent;
	font-size: round(up, 1.125em, 1px);
	font-weight: 700;
	background: var(--hover-color);
	color: var(--text-color);
	text-align: center;
	cursor: pointer;
	-webkit-transition: all 0.2s ease;
			transition: all 0.2s ease;
}
input[type=submit]:hover {
	background: var(--text-color);
	color: var(--white-color);
}

.form-field > .error-box {
	display: block;
	position: absolute;
	z-index: -1;
	top: 50%;
	inset-inline-start: 40%;
	border-radius: 4px;
	padding: 0.75em 1em;
	background: var(--error-color);
	color: #fff;
	font-size: 0.875em;
	white-space: nowrap;
	opacity: 0;
	-webkit-transform: translate3D(-1em,-50%,0);
			transform: translate3D(-1em,-50%,0);
	-webkit-transition: all 0.2s ease;
			transition: all 0.2s ease;
	-webkit-box-shadow: 0px 2px 5px -3px rgba(0,0,0,0.75);
			box-shadow: 0px 2px 5px -3px rgba(0,0,0,0.75);
}
.form-field > .error-box:after {
	content: "";
	display: block;
	position: absolute;
	inset-inline-start: -5px;
	top: calc(50% - 5px);
	width: 0px;
	height: 0px;
	border-block: 5px solid transparent;
	border-inline-start: 0;
	border-bottom: 5px solid transparent;
	border-inline-end: 5px solid var(--error-color);
}
.form-field.invalid-field > .error-box {
	z-index: 9;
	opacity: 1;
	-webkit-transform: translate3D(0,-50%,0);
			transform: translate3D(0,-50%,0);
}

.form-return {
	position: absolute;
	z-index: -9;
	inset: 0;
	padding-block: var(--gutter);
	align-content: center;
	text-align: center;
	opacity: 0;
	-webkit-transition: opacity 0.4s ease 0s, z-index 0s ease 0.4s;
			transition: opacity 0.4s ease 0s, z-index 0s ease 0.4s;	
}
.form-return.on {
	z-index: 9;
	opacity: 1;
	-webkit-transition: opacity 0.4s ease 0.4s;
			transition: opacity 0.4s ease 0.4s;
}
.form-success, 
.form-failure {
	display: none;
}
.form-success.on, 
.form-failure.on {
	display: block;
}
.form-return p {
	margin-bottom: 0;
}
/***/



/* Custom select list */
.custom-select {
	position: relative;
	display: flex;
	gap: 0.25em;
	align-items: center;
	margin-bottom: 0.75em;
	padding: 0.25em 0.25em 0.25em 0.5em;
	background: #f8f8f8;
	cursor: pointer;
}
.custom-select.open {
	z-index: 11;
}
.custom-select:before {
	content: '\00BB';
	width: 1.5em;
	height: 1.5em;
	text-align: center;
	font-size: 1.3333em;
	color: var(--link-color);
	-webkit-transition: all 0.2s ease;
			transition: all 0.2s ease;
	-webkit-transform: rotateZ(-90deg);
			transform: rotateZ(-90deg);
}
.custom-select.open:before {
	-webkit-transform: rotateZ(90deg);
			transform: rotateZ(90deg);
}
.custom-select > input {
	padding: 0 0.5em;
	cursor: pointer;
	border: 0;
	border-inline-start: 1px solid var(--link-color);
	background: transparent;
}
.custom-select > input::-webkit-input-placeholder	{ opacity: 1; }
.custom-select > input:-moz-placeholder 			{ opacity: 1; }
.custom-select > input::-moz-placeholder 			{ opacity: 1; }
.custom-select > input:-ms-input-placeholder 		{ opacity: 1; }
.custom-select > input:focus {
	box-shadow: none;
}
.custom-select.open > input {
}
.custom-select > ul {
	position: absolute;
	z-index: 2;
	display: none;
	top: 100%;
	right: 0;
	min-width: 100%;
	overflow: auto;
	margin-top: 1px;
	padding-block: 0.5em;
	-webkit-box-shadow: 0px 2px 6px -2px rgba(0,0,0,0.75);
	   -moz-box-shadow: 0px 2px 6px -2px rgba(0,0,0,0.75);
			box-shadow: 0px 2px 6px -2px rgba(0,0,0,0.75);
}
.custom-select.open > ul {
	display: block;
	z-index: 11;
}
.custom-select > ul > li {
	display: flex;
	align-items: center;
	gap: 0.25em;
	padding: 0.25em 0.25em 0.25em 2em;
	-webkit-transition: all 0.2s ease;
			transition: all 0.2s ease;
	cursor: pointer;
}
.custom-select > ul > li:before {
	content: '\203A';
	width: 1.5em;
	height: 1.5em;
	text-align: center;
	font-size: 1.3333em;
	color: var(--link-color); 
	opacity: 0;
	-webkit-transition: all 0.2s ease;
			transition: all 0.2s ease;
}
.custom-select > ul > li:hover:before {
	opacity: 1;
}
.custom-select > button {
	border: 1px solid;
	border-radius: 0.166667em;
	color: var(--link-color);
	font-weight: 700;
	visibility: hidden;
	opacity: 0;
	cursor: pointer;
	scale: 0.7; 
	-webkit-transition: all 0.2s ease;
			transition: all 0.2s ease;
}
.custom-select.option-selected > button {
	opacity: 1;
	scale: 1;
	visibility: visible;
}
.custom-select.open:after {
	content: '';
	position: fixed;
	z-index: 9;
	inset: 0;
}
/***/



/* Custom checkbox-group */
.custom-checkbox-group {
	position: relative;
	display: flex;
	gap: 0.25em;
	align-items: center;
	margin-bottom: 0.75em;
	padding: 0.25em 0.25em 0.25em 0.5em;
	background: #f8f8f8;
	color: var(--text-color);
	cursor: pointer;
}
.custom-checkbox-group:before {
	content: '\00BB';
	width: 1.5em;
	height: 1.5em;
	text-align: center;
	font-size: 1.3333em;
	color: var(--link-color);
	-webkit-transition: all 0.2s ease;
			transition: all 0.2s ease;
	-webkit-transform: rotateZ(-90deg);
			transform: rotateZ(-90deg);
}
.custom-checkbox-group.open:before {
	-webkit-transform: rotateZ(90deg);
			transform: rotateZ(90deg);
}
.custom-checkbox-group > .checkbox-group-label {
	padding: 0 0.5em;
	cursor: pointer;
	border: 0;
	border-inline-start: 1px solid var(--link-color);
	background: transparent;
}
/*
.custom-select > input::-webkit-input-placeholder	{ opacity: 1; }
.custom-select > input:-moz-placeholder 			{ opacity: 1; }
.custom-select > input::-moz-placeholder 			{ opacity: 1; }
.custom-select > input:-ms-input-placeholder 		{ opacity: 1; }
.custom-select > input:focus {
	box-shadow: none;
}
*/
.custom-checkbox-group > ul {
	position: absolute;
	z-index: 2;
	display: none;
	top: 100%;
	right: 0;
	min-width: 100%;
	overflow: auto;
	margin-top: 1px;
	padding-block: 0.5em;
	-webkit-box-shadow: 0px 2px 6px -2px rgba(0,0,0,0.75);
	   -moz-box-shadow: 0px 2px 6px -2px rgba(0,0,0,0.75);
			box-shadow: 0px 2px 6px -2px rgba(0,0,0,0.75);
}
.custom-checkbox-group.open > ul {
	display: block;
}
.custom-checkbox-group > ul > li {
	display: flex;
	align-items: baseline;
	gap: 0.75em;
	padding: 0.25em 0.5em 0.25em 2em;
	-webkit-transition: all 0.2s ease;
			transition: all 0.2s ease;
	cursor: pointer;
}
.custom-checkbox-group > ul > li:hover:before {
	opacity: 1;
}
.custom-checkbox-group.open:after {
	content: '';
	position: fixed;
	inset: 0;
}
/***/





/* SVG views */
.svg-container {
}
.svg-canvas {
}
.svg-canvas > svg {
	display: block;
}
.svg-canvas.cover-svg > svg {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
/***/




/* Pan and Zoom */
.panzoom-container {
	overflow: hidden;	
}
.panzoom {
	will-change: transform;
}
.panzoom.smooth-zoom {
	transition: transform 0.5s ease-out !important;
}

.panzoom > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
/***/



/* Extensible */
.extensible-element {
}
.extensible-container {
	transition: height 0.4s cubic-bezier(0.65, 0, 0.35, 1);
}
.extensible-element.extended > .extensible-container {
	-webkit-line-clamp: unset;
}
.extensible-content {
}
.extensible-toggle {
}

/***/





/* Icons */

/*
.inline-icon {
	display: inline-block;
	vertical-align: middle;
	width: 1em;
	aspect-ratio: 1;
	background-size: 100% auto;
}
a > .inline-icon:after {
	
}
.building-icon {
	background-image: url('../img/icons-building.png');
}

.inline-icon-set {
	display: inline-block;
	position: relative;
	vertical-align: bottom;
	width: 1em;
	aspect-ratio: 1;
}
.inline-icon-set:before,
.inline-icon-set:after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	background-size: 100% auto;
}
.inline-icon-set:after {
	position: absolute;
	top: 0;
	left: 0;
}
.inline-icon-set.icon-building:before,
.inline-icon-set.icon-building:after {
}
.icon-building {
	background-image: url('../img/icon-building.png');
}
.icon-document {
	background-image: url('../img/icon-building.png');
}

.icon-building.hover-icon {
	background-image: url('../img/icons-building.png');
}
*/




.inline-icons {
	position: relative;
	display: inline-block;
	margin-inline-end: 0.125em;
	vertical-align: middle;
	width: 1em;
	aspect-ratio: 1;
}
.inline-icons:before,
.inline-icons:after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	background-size: 100% auto;
	-webkit-transition: all 0.2s ease;
			transition: all 0.2s ease;
}
.inline-icons:before {
	background-position: 0 0;
}
.inline-icons:after {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	background-position: 0 -1em;
}
a:hover > .inline-icons:before {
	opacity: 0;
}
a:hover > .inline-icons:after {
	opacity: 1;
}
.building-icons:before,
.building-icons:after {
	background-image: url('../img/icons-building.png');
}
.document-icons:before,
.document-icons:after {
	background-image: url('../img/icons-document.png');
}

/***/









