.search-cont {
	position: relative;
	z-index: 8;
}

.search-cont .headerbox-search-form {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
}

.search-cont .searchInput {
	display: block;
	flex-grow: 1;
	padding: 10px;
	margin: 0;
	font-family: var(--font-body);
	font-weight: normal;
	font-size: var(--text-base);
	line-height: 1.5;
	color: var(--gray-dark);
	background: var(--white);
	border: none;
	border-radius: 0;
}

.search-cont .submit-button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 45px;
	aspect-ratio: 1;
	flex-shrink: 0;
	padding: 0;
	margin: 0;
	font-size: var(--text-lg);
	line-height: 1;
	color: var(--white);
	background: var(--blue-mid-dark);
	border: 2px solid var(--white);
	border-radius: 0;
}

.search-cont .search-button {
	position: relative;
	display: none;
	align-items: center;
	justify-content: center;
	width: 70px;
	aspect-ratio: 1;
	padding: 0;
	margin: 0;
	font-size: var(--text-lg);
	line-height: 1;
	color: var(--white);
	background-color: var(--blue-mid-dark);
	border: none;
	border-radius: 0;
	transition: background-color var(--transition-appendix);
}

.search-cont .search-button .open,
.search-cont .search-button .close {
	transition: opacity var(--transition-appendix);
}

.search-cont .search-button .open {
	transform: rotateY(180deg);
	opacity: 1;
}

.search-cont .search-button .close {
	position: absolute;
	inset: 50% auto auto 50%;
	translate: -50% -50%;
	font-size: var(--text-2xl);
	opacity: 0;
}

/*----- open search form -----*/

.search-cont .search-button.active {
	background-color: var(--blue-mid);
}

.search-cont .search-button.active .open {
	opacity: 0;
}

.search-cont .search-button.active .close {
	opacity: 1;
}

/*----- microsite (black) theme -----*/

.theme-microsite .search-cont .submit-button {
	background: var(--black);
}

.theme-microsite .search-cont .search-button {
	background-color: var(--black);
}

/*----- lavender theme -----*/

.theme-lavender .search-cont .submit-button {
	background: var(--lavender-dark);
}

.theme-lavender .search-cont .search-button {
	background-color: var(--lavender-dark);
}

/*----- media queries -----*/

@media (hover: hover) {
	.search-cont .search-button:hover {
		background-color: var(--blue-mid);
	}

	.theme-microsite .search-cont .search-button:hover {
		background-color: var(--black);
	}
	
	.theme-lavender .search-cont .search-button:hover {
		background-color: var(--lavender-dark);
	}
}

@media (min-width: 64em) {
	.search-cont .headerbox-search-form {
		position: absolute;
		inset: 0 0 0 auto;
		z-index: -1;
		display: none;
		width: 394px;
		padding: 10px 75px 10px 10px;
		background: var(--blue-mid);
		opacity: 0;
	}

	.search-cont .submit-button {
		width: 58px;
		height: 45px;
		aspect-ratio: unset;
		background: var(--blue-mid);
	}

	.search-cont .search-button {
		display: flex;
	}

	/*----- active search -----*/

	.search-cont .headerbox-search-form.active,
	.search-cont .headerbox-search-form.in,
	.search-cont .headerbox-search-form.out {
		display: grid;
	}

	.search-cont .headerbox-search-form.active,
	.search-cont .headerbox-search-form.out {
		opacity: 1;
	}

	.search-cont .headerbox-search-form.in {
		animation: fade-in 0.3s ease 0s 1 normal forwards;
	}

	.search-cont .headerbox-search-form.out {
		animation: fade-out 0.3s ease 0s 1 normal forwards;
	}

	/*----- inside main menu -----*/

	.menu-container .search-cont .headerbox-search-form {
		position: static;
		display: grid;
		opacity: 1;
		width: 100%;
		max-width: 310px;
		padding: 0;
	}

	.menu-container .search-cont .search-button {
		display: none;
	}

	.menu-container .search-cont .headerbox-search-form.in,
	.menu-container .search-cont .headerbox-search-form.out {
		animation: none;
	}

	/*----- microsite (black) theme -----*/

	.theme-microsite .search-cont .headerbox-search-form {
		background: var(--black);
	}
	
	/*----- lavender theme -----*/

	.theme-lavender .search-cont .headerbox-search-form {
		background: var(--lavender-dark);
	}
}

/*----- animations -----*/

@keyframes fade-in {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

@keyframes fade-out {
	from {
		opacity: 1;
	}
	to {
		opacity: 0;
	}
}