.accordions {
	display: flex;
	flex-direction: column;
	justify-content: stretch;
	align-items: stretch;
	gap: 0;
	width: 100%;
}

.accordion {
	--accordion-gap: 1rem;
	--accordion-color: var(--color-white);
	--accordion-hover-color: var(--color-white-alt);
	--accordion-text-color: var(--color-black);
	--accordion-indicator-color: var(--color-dark-grey);

	display: grid;
	grid-template-columns: 1fr;
	grid-template-rows: max-content 0fr;
	gap: 0;
	width: 100%;
	position: relative;
	transition: 0.35s cubic-bezier(0.5, 0, 0.5, 1);

	container-name: accordion;
	container-type: inline-size;
}

.accordion::before {
	content: '';
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	box-shadow: 0 0.5rem 1rem rgba(var(--color-black-rgb), 0.1);
	transition: 0.3s ease-in-out;
	z-index: 1;
}

.accordion-label {
	display: grid;
	grid-template-columns: 1fr 5rem;
	place-content: stretch;
	place-items: stretch;
	gap: 0;
	width: 100%;
	min-height: 5rem;
	text-align: left;
	cursor: pointer;
	transition: 0.3s ease-in-out;
	background-color: var(--accordion-color);
	color: var(--accordion-text-color);
	position: relative;
	z-index: 2;
}

.accordion-label:hover {
	background-color: var(--accordion-hover-color);
}

.accordion-title {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	margin: 0 !important;
	padding: 0 2rem;
}

.accordion-indicator {
	display: flex;
	align-items: center;
	justify-content: center;
	transition: 0.3s ease-in-out;
	color: var(--accordion-indicator-color);
}

.accordion-content {
	overflow: hidden;
	background-color: var(--accordion-color);
	color: var(--accordion-text-color);
	position: relative;
	z-index: 2;
}

.accordion-padding {
	padding: var(--padding-blocks);
}

.accordions > .accordion:first-child::before,
.accordions > .accordion:first-child > .accordion-label {
	border-top-left-radius: var(--border-radius-fields);
	border-top-right-radius: var(--border-radius-fields);
}

.accordions > .accordion:last-child::before,
.accordions > .accordion:last-child > .accordion-label,
.accordion-content {
	border-bottom-left-radius: var(--border-radius-fields);
	border-bottom-right-radius: var(--border-radius-fields);
}

:not(.accordions) > .accordion,
:not(.accordions) > .accordion:last-child::before {
	border-radius: var(--border-radius-fields);
}

.accordions > .accordion:not(:last-child) > .accordion-label {
	border-bottom: 1px solid rgba(var(--color-black-rgb), 0.1);
}

/* Open State */
.accordion.open {
	grid-template-rows: max-content 1fr;
}

.accordion.open .accordion-indicator {
	transform: rotate(180deg);
}

.accordion.open .accordion-label {
	background-color: var(--accordion-text-color);
	color: var(--accordion-color);
	border-bottom-color: transparent !important;

	border-top-left-radius: var(--border-radius-fields) !important;
	border-top-right-radius: var(--border-radius-fields) !important;
	border-bottom-left-radius: 0 !important;
	border-bottom-right-radius: 0 !important;
}

.accordion.open::before {
	border-radius: var(--border-radius-fields) !important;
}

.accordions > .accordion.open:not(:last-child):not(:first-child) {
	margin-bottom: var(--accordion-gap);
	margin-top: var(--accordion-gap);
}

.accordions > .accordion.open:first-child {
	margin-bottom: var(--accordion-gap);
}

.accordions > .accordion.open:last-child {
	margin-top: var(--accordion-gap);
}

.accordions > .accordion.open + .accordion.open {
	margin-top: calc(var(--accordion-gap) / 2);
}

.accordions > .accordion.open:has(+ .accordion.open) {
	margin-bottom: calc(var(--accordion-gap) / 2);
}

.accordions > .accordion.open + .accordion > .accordion-label {
	border-top-left-radius: var(--border-radius-fields);
	border-top-right-radius: var(--border-radius-fields);
}

.accordions > .accordion:has(+ .accordion.open) > .accordion-label {
	border-bottom-left-radius: var(--border-radius-fields);
	border-bottom-right-radius: var(--border-radius-fields);
	border-bottom-color: transparent !important;
}

/*
	List columns
*/
@container accordion (min-width: 768px) {
	.accordion-padding > ul:not(.list-unstyled) {
		columns: 2 auto;
		column-gap: 4rem;
	}

	.accordion-padding > ul:not(.list-unstyled) > li {
		break-inside: avoid;
	}
}

/* mobile */
@container accordion (max-width: 563px) {
	.accordion-title {
		padding-top: 1rem;
		padding-bottom: 1rem;
	}
}
