/* FAQ Accordion – frame-faq-box */

/* Gleiche Breite / Seitenabstand wie .frame-default (24px) */
.space-content .frame-faq-box {
	padding: 0 24px;
	max-width: 100%;
	box-sizing: border-box;
}

/* In bereits gepaddeten Containern: auf volle Inhaltsbreite ausdehnen */
.space-content .frame-default .frame-faq-box,
.space-content .frame-greybox .frame-faq-box,
.space-content .frame-whitebox .frame-faq-box,
.space-content .grid-row .frame-faq-box {
	margin-left: -24px;
	margin-right: -24px;
	width: calc(100% + 48px);
	max-width: calc(100% + 48px);
	padding-left: 24px;
	padding-right: 24px;
}

.frame-faq-box {
	margin: 25px 0 50px;
}

.frame-faq-box .ge-container,
.frame-faq-box .grid-container,
.frame-faq-box .grid-row,
.frame-faq-box .grid-col {
	padding-left: 0;
	padding-right: 0;
	max-width: none;
	width: 100%;
}

@media only screen and (min-width: 860px) {
	.frame-faq-box .grid-col {
		padding-right: 0;
	}
}

.frame-faq-box .frame-default {
	padding: 0;
	margin: 0 0 12px;
	border: 1px solid #e9e9e9;
	border-radius: 12px;
	background-color: #fff;
	overflow: hidden;
	transition: filter 0.3s ease, border-color 0.3s ease, margin 0.3s ease;
}

.frame-faq-box .frame-default:has(.faq-accordion__toggle:checked),
.frame-faq-box details.faq-accordion__item[open] {
	position: relative;
	z-index: 1;
	margin-bottom: 20px;
	border-color: #ccc;
	filter:
		drop-shadow(0 8px 28px rgba(0, 0, 0, 0.16))
		drop-shadow(0 4px 14px rgba(0, 0, 0, 0.1));
}

.frame-faq-box .frame-default:last-child {
	margin-bottom: 0;
}

.frame-faq-box .frame-default:has(.faq-accordion__toggle:checked):last-child {
	margin-bottom: 4px;
}

/* versteckter Toggle (per JS eingefügt) */
.frame-faq-box .faq-accordion__toggle {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Frage (Label / Summary) */
.frame-faq-box .faq-accordion__trigger,
.frame-faq-box .frame-default > header {
	display: block;
	margin: 0;
	padding: 0;
}

.frame-faq-box .faq-accordion__trigger {
	cursor: pointer;
	-webkit-tap-highlight-color: transparent;
}

.frame-faq-box .faq-accordion__trigger h3,
.frame-faq-box .frame-default > header h3 {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin: 0;
	padding: 1rem 1.25rem;
	font-family: 'Work Sans', sans-serif;
	font-size: 1.125rem;
	font-weight: 400;
	line-height: 1.4;
	color: #000;
	text-shadow: none;
	cursor: pointer;
	transition: color 0.2s ease, background-color 0.2s ease, font-weight 0.2s ease;
}

.frame-faq-box .faq-accordion__trigger:hover h3,
.frame-faq-box .frame-default > header h3:hover {
	color: #000;
	background-color: #f5f5f5;
}

/* aktiv (geöffnet) – Hintergrund am Header, bleibt in den runden Ecken */
.frame-faq-box .frame-default:has(.faq-accordion__toggle:checked) > header,
.frame-faq-box .frame-default:has(.faq-accordion__toggle:checked) .faq-accordion__trigger,
.frame-faq-box details.faq-accordion__item[open] .faq-accordion__summary {
	background-color: #eee;
}

.frame-faq-box .frame-default:has(.faq-accordion__toggle:checked) .faq-accordion__trigger h3,
.frame-faq-box .frame-default:has(.faq-accordion__toggle:checked) > header h3,
.frame-faq-box details.faq-accordion__item[open] .faq-accordion__summary h3 {
	font-weight: 700;
	background-color: transparent;
	color: #c9070a;
}

.frame-faq-box .frame-default:has(.faq-accordion__toggle:checked) .faq-accordion__trigger:hover h3,
.frame-faq-box .frame-default:has(.faq-accordion__toggle:checked) > header h3:hover {
	color: #c9070a;
	background-color: transparent;
}

/* Chevron */
.frame-faq-box .faq-accordion__trigger h3::after,
.frame-faq-box .frame-default > header h3::after {
	content: '';
	flex-shrink: 0;
	width: 0.55em;
	height: 0.55em;
	margin-top: -0.15em;
	border-right: 2px solid #888;
	border-bottom: 2px solid #888;
	transform: rotate(45deg);
	transition: transform 0.25s ease, border-color 0.2s ease;
}

.frame-faq-box .frame-default:has(.faq-accordion__toggle:checked) .faq-accordion__trigger h3::after,
.frame-faq-box .frame-default:has(.faq-accordion__toggle:checked) > header h3::after,
.frame-faq-box details.faq-accordion__item[open] .faq-accordion__summary h3::after {
	transform: rotate(-135deg);
	margin-top: 0.15em;
	border-color: #555;
}

/* Antwort-Panel */
.frame-faq-box .frame-default .ce-textpic {
	display: grid;
	grid-template-rows: 0fr;
	transition: grid-template-rows 0.35s ease;
}

.frame-faq-box .frame-default .ce-textpic > .faq-accordion__panel {
	overflow: hidden;
	min-height: 0;
}

.frame-faq-box .frame-default:has(.faq-accordion__toggle:checked) .ce-textpic,
.frame-faq-box details.faq-accordion__item[open] .ce-textpic {
	grid-template-rows: 1fr;
}

.frame-faq-box .frame-default .ce-bodytext {
	padding: 0 1.25rem 1.25rem;
	color: #444;
	font-size: 1rem;
	line-height: 1.6;
}

/* Antwort optisch von der nächsten Frage trennen */
.frame-faq-box .frame-default:has(.faq-accordion__toggle:checked) .faq-accordion__panel {
	border-top: 1px solid #e9e9e9;
	padding-top: 1rem;
}

/* Bilder in Antworten (ce-below / ce-above) */
.frame-faq-box .frame-default .ce-gallery {
	padding: 0 1.25rem 1.25rem;
}

.frame-faq-box .frame-default .ce-gallery .ce-row {
	display: block;
}

.frame-faq-box .frame-default .ce-gallery img {
	max-width: 100%;
	height: auto;
}

/* erste Zeile nur geschlossen ausblenden (sonst blitzt sie beim Einklappen auf) */
.frame-faq-box .frame-default:not(:has(.faq-accordion__toggle:checked)) .ce-bodytext > p:first-child,
.frame-faq-box details.faq-accordion__item:not([open]) .ce-bodytext > p:first-child {
	display: none;
}

.frame-faq-box .frame-default .ce-bodytext p:last-child {
	margin-bottom: 0;
}

/* natives <details> (falls per JS umgebaut) */
.frame-faq-box details.faq-accordion__item {
	margin: 0 0 12px;
	border: 1px solid #e9e9e9;
	border-radius: 12px;
	background-color: #fff;
	overflow: hidden;
}

.frame-faq-box details.faq-accordion__item:last-child {
	margin-bottom: 0;
}

.frame-faq-box .faq-accordion__summary {
	display: block;
	list-style: none;
	cursor: pointer;
}

.frame-faq-box .faq-accordion__summary::-webkit-details-marker {
	display: none;
}

.frame-faq-box .faq-accordion__summary::marker {
	content: '';
}

@media only screen and (max-width: 768px) {
	.space-content .frame-faq-box {
		padding-left: 24px;
		padding-right: 24px;
	}

	.space-content .frame-default .frame-faq-box,
	.space-content .frame-greybox .frame-faq-box,
	.space-content .frame-whitebox .frame-faq-box,
	.space-content .grid-row .frame-faq-box {
		margin-left: -24px;
		margin-right: -24px;
		width: calc(100% + 48px);
		max-width: calc(100% + 48px);
	}

	.frame-faq-box .faq-accordion__trigger h3,
	.frame-faq-box .frame-default > header h3 {
		font-size: 1rem;
		padding: 0.875rem 1rem;
	}

	.frame-faq-box .frame-default .ce-bodytext {
		padding: 0 1rem 1rem;
		font-size: 0.95rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.frame-faq-box .frame-default,
	.frame-faq-box .frame-default .ce-textpic,
	.frame-faq-box .faq-accordion__trigger h3::after,
	.frame-faq-box .frame-default > header h3::after {
		transition: none;
	}
}
