/********************************/
/* COMMON ELEMENTS
/********************************/


/* Loaders */ 
.loader {
	position: absolute;
	z-index: -999;
	inset: 0;
	background: #fff;
	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: 64px;
	height: 64px;
	margin: auto;
	background: var(--primary-color);
	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(200px); }
	 25% { -webkit-transform: perspective(200px) rotateY(360deg); }
	 35% { -webkit-transform: perspective(200px) rotateY(360deg); }
	 60% { -webkit-transform: perspective(200px) rotateY(720deg); }
	100% { -webkit-transform: perspective(200px) rotateY(720deg); }
}
@keyframes loader-animation {
	  0% { transform: perspective(200px); }
	 25% { transform: perspective(200px) rotateY(360deg); }
	 35% { transform: perspective(200px) rotateY(360deg); }
	 60% { transform: perspective(200px) rotateY(720deg); }
	100% { transform: perspective(200px) 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;
}
/***/



/* Swipers */
.swiper-container {
}
.small-swiper-container {
	height: 384px;
}	
.big-swiper-container {
	height: 768px;
}
.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: 48px;
	height: 48px;
}
.swiper-button-prev:after, 
.swiper-button-next:after, 
.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-caption {
	position: absolute;
	bottom: 0;
	width: 100%;
	background: rgba(0,0,0,0.5);
	color: #fff;
}
/*
.swiper-slide-caption {
	position: absolute;
	bottom: 0;
	width: 100%;
	padding: 1em;
	font-size: 1.166667;
	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 0s;
			transition: all 0.4s ease 0s;
}
.swiper-slide-active .swiper-slide-caption {
	-webkit-transform: none;
			transform: none;	
	-webkit-transition: all 0.4s ease 1s;
			transition: all 0.4s ease 1s;
}
*/
@media (min-width : 1200px) {
}


/*
.swiper-button-prev.fancy, 
.swiper-button-next.fancy {
	width: 4rem;
	height: 4rem;
	border-radius: 50%;
	box-shadow: 8px 8px 16px -8px rgba(0,0,0,0.5);
	background: var(--primary-color) 50% 50% no-repeat;
	background-size: contain;
	color: var(--secondary-color);
}
.swiper-button-prev.fancy {
	background-image: url(../img/fancy-arrow-right.svg);
}
.swiper-button-next.fancy {
	background-image: url(../img/fancy-arrow-left.svg);
}
.swiper-button-prev.fancy:after, 
.swiper-button-next.fancy:after {
	content: none;
}

@media (min-width : 1200px) {
	.swiper-button-prev.fancy, 
	.swiper-button-next.fancy {
		width: 6rem;
		height: 6rem;
	}
}

@media (min-width : 1600px) {
	.swiper-button-prev.fancy, 
	.swiper-button-next.fancy {
		width: 8rem;
		height: 8rem;
	}
}
*/
/***/



/* Lightbox */
.lightbox {
	position: fixed;
	z-index: -999;
	inset: 0;
	padding: 50px 10px;
	opacity: 0;
	background: rgba(0,0,0,0.95);
	color: var(--white-color);
	-webkit-transition: z-index 0s ease 0.5s, opacity 0.35s ease;
			transition: z-index 0s ease 0.5s, opacity 0.35s ease;	
}
.lightbox.open {
	z-index: 999;
	opacity: 1;
	-webkit-transition: z-index 0s ease, opacity 0.5s ease;
			transition: z-index 0s ease, opacity 0.5s ease;	
}
.lightbox .spinner {
	background-color: #ccc;
}
.lightbox-content {
	position: relative;
	width: 100%;
	height: 100%;
}
.close-lightbox {
	position: absolute;
	z-index: 99;
	top: 5px;
	right: 5px;
	width: 48px;
	height: 48px;
	padding: 7px;
	cursor: pointer;
}
.close-lightbox::before,
.close-lightbox::after {
	content: '';
	display: block;
	position: absolute;
	top: 22px;
	width: 34px;
	height: 3px;
	background-color: currentColor;
	opacity: 0;
}
.lightbox.open .close-lightbox::before,
.lightbox.open .close-lightbox::after {
	opacity: 1;
	-webkit-transition: all 0.4s ease 1.2s;
			transition: all 0.4s ease 1.2s;
}
.lightbox.open .close-lightbox::before {
	transform: rotateZ(45deg);
}
.lightbox.open .close-lightbox::after {
	transform: rotateZ(-45deg);
}

.text-lightbox .lightbox-content {
	background: var(--white-color);
	color: var(--text-color);	
}
.text-lightbox > .lightbox-content {
	padding: 60px 10px;
	overflow: auto;
}

.gallery-lightbox {
	text-align: center;
}
.gallery-lightbox .swiper-pagination {
	/*display: none;*/
}

.lightbox-content .swiper-container {
	height: 100%;
	overflow: clip; 
}
.lightbox-content .swiper-slide {
}
.lightbox-content .swiper-slide img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.lightbox .swiper-button-prev, 
.lightbox .swiper-button-next {
	color: #fff;
	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-slide-active .swiper-slide-caption {
	-webkit-transform: translateY(100%);
			transform: translateY(100%);
}
.lightbox.open .swiper-slide-active .swiper-slide-caption {
	-webkit-transform: none;
			transform: none;	
}

.lightbox-content .google-map {
	height: 100%;
}

@media (min-width : 1200px) {
	.lightbox {
		padding: 75px;
	}
	.close-lightbox {
		top: 20px;
		right: 25px;
	}
}
/***/



/* 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;
}
/***/



/* Masonry Lists */
.masonry-list-element {
}
.masonry-list {
}
.masonry-list-item {
}
/***/



/* Video players */
.video-container {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
	box-shadow: 0 2px 4px -2px rgba(0,0,0,0.5);
	background: #000;
}
.video-player {
	position: absolute;
	inset: 0;
}
/***/



/* Google maps */
.google-map {
}
.google-map > .map-canvas {
	width: 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 {
	margin: 0 -10px;
}
.form-col {
	padding: 10px;
}
*/
.form-field {
	position: relative;
	margin-bottom: 1em;
}
.subscribe-field {
	display: flex;
	align-items: middle;
	gap: 0.5em;
	font-size: round(0.888889em,1px);
}
.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 var(--primary-color);
	padding: 0.75em;
	-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 8px -6px rgba(0,0,0,0.7);
	   -moz-box-shadow: 0px 4px 8px -6px rgba(0,0,0,0.7);
			box-shadow: 0px 4px 8px -6px rgba(0,0,0,0.7);
}
textarea {
	height: calc(7.166667em + 4px);
}

input[type=checkbox] {
	appearance: none;
	padding: 0.125em;
	vertical-align: middle;
	width: 1.5em;
	height: 1.5em;
	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.34, 1.56, 0.64, 1);
			transition: all 0.2s cubic-bezier(0.34, 1.56, 0.64, 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 var(--primary-color);
	padding: 0.566667em 1.5em;
	background: var(--primary-color);
	color: var(--white-color);
	font-size: round(1.166666em,1px);
	text-align: center;
	cursor: pointer;
	-webkit-transition: all 0.2s ease;
			transition: all 0.2s ease;
}
input[type=submit]:hover {
}

.form-field > .error-box {
	display: block;
	position: absolute;
	z-index: -1;
	top: 50%;
	inset-inline-start: 75%;
	margin-top: -1.416667em;
	border-radius: 4px;
	padding: 0.75em 1em;
	white-space: nowrap;
	background: var(--error-color);
	color: #fff;
	font-size: 0.8333em;
	opacity: 0;
	-webkit-transform: translateX(-1em);
			transform: translateX(-1em);
	-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;
	right: -5px;
	top: calc(50% - 5px);
	width: 0px;
	height: 0px;
	border-top: 5px solid transparent;
	border-right: 0;
	border-bottom: 5px solid transparent;
	border-left: 5px solid var(--error-color);
}
.form-field.invalid-field > .error-box {
	z-index: 9;
	opacity: 1;
	-webkit-transform: none;
			transform: none;
}

.form-return {
	position: absolute;
	z-index: -9;
	inset: 0;
	padding-block: 2em;
	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;
	padding-inline-start: 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:hover,
.custom-select > ul > li.selected {
	background-color: #eee;
}
.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,
.custom-select > ul > li.selected: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;
}
/***/
