/* Programmpunkt Accordion - self-contained styling */

.festival-accordion {
	max-width: 100%;
	min-height: calc(100dvh + 25vw);
	--festival-accent: #b0327a;
	--festival-accent-text: var(--wp--preset--color--base, #fff);
	--festival-border: #ddd;
	--festival-badge-bg: rgba(0, 0, 0, 0.06);
	--festival-filterbar-bg: var(--wp--preset--color--contrast, #14123a);
	--festival-filterbar-color: var(--wp--preset--color--base, #fff);
	--festival-card-bg: #fff;
	--festival-card-color: inherit;
	--festival-icon-bg: transparent;
	--festival-icon-border: currentColor;
	--festival-radius: 8px;
	--festival-filter-color: var(--festival-accent);
	--festival-filter-text: var(--wp--preset--color--beige, #f3efdf);
	--festival-filter-active: #0303d5;
	--festival-scroll-offset: 140px;
	font-size: 15px;
}

/* --- Sticky filter bar, full viewport width with rounded bottom corners --- */
.festival-accordion__sticky-sentinel {
	height: 1px;
}

.festival-accordion__filterbar {
	position: sticky;
	top: 57px; /* height of the fixed main navigation */
	z-index: 10;
	background: transparent;
	color: var(--festival-filterbar-color);
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	margin-bottom: 1.5em;
	border-radius: 0 0 var(--festival-radius) var(--festival-radius);
	transition: background 0.2s ease;
}

.festival-accordion__filterbar.is-stuck {
	background: var(--festival-filterbar-bg);
}

.festival-accordion__filterbar-inner {
	max-width: var(--wp--style--global--content-size, 1200px);
	margin: 0 auto;
	padding: 0.75em 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 0.5em;
}

.festival-accordion__filterbar-top {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.5em;
	width: 100%;
}

.festival-accordion__filterbar-top .festival-accordion__days {
	flex: 1 1 auto;
}

.festival-accordion__filters {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em;
}

.festival-accordion__filter {
	padding: 0.5em 1em;
	border: none;
	background: var(--festival-filter-color);
	border-radius: var(--festival-radius);
	cursor: pointer;
	font-family: inherit;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	line-height: 1;
	color: var(--festival-filter-text);
	transition: background 0.15s ease, color 0.15s ease;
}

.festival-accordion__filter:hover {
	background: var(--festival-filter-active);
	color: var(--festival-filter-text);
}

.festival-accordion__filter.is-active {
	background: var(--festival-filter-active);
	color: var(--festival-filter-text);
}

.festival-accordion__days .festival-accordion__filter {
	font-weight: 600;
}

/* Mobile "Filter" toggle button - hidden on desktop */
.festival-accordion__filter-toggle {
	display: none;
	padding: 0.5em 1.25em;
	border: none;
	background: var(--festival-filter-color);
	border-radius: var(--festival-radius);
	cursor: pointer;
	font-family: inherit;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	line-height: 1;
	font-weight: 600;
	color: var(--festival-filter-text);
}

.festival-accordion__filter-toggle:hover,
.festival-accordion__filter-toggle[aria-expanded="true"] {
	background: var(--festival-filter-active);
	color: var(--festival-filter-text);
}

/* Collapsible type/language filters - shown inline on desktop */
.festival-accordion__more-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em;
}

/* --- Day sections --- */
.festival-accordion__day {
	margin-bottom: 2.5em;
	scroll-margin-top: var(--festival-scroll-offset, 140px);
}

.festival-accordion-item {
	scroll-margin-top: var(--festival-scroll-offset, 140px);
}

.festival-accordion__day-heading {
	margin-bottom: 0.75em;
}

.festival-accordion__day.is-today .festival-accordion__day-heading {
	color: var(--festival-accent);
}

.festival-accordion__today-badge {
	display: inline-block;
	margin-left: 0.5em;
	padding: 0.15em 0.6em;
	border-radius: 999px;
	background: var(--festival-accent);
	color: #fff;
	font-size: 0.6em;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	vertical-align: middle;
}

/* --- Accordion items --- */
.festival-accordion-container .eb-accordion-inner {
	display: flex;
	flex-direction: column;
	gap: 0.75em;
}

.festival-accordion-item {
	border: 1px solid var(--festival-border);
	border-radius: 24px;
	overflow: hidden;
	background: var(--festival-card-bg);
	color: var(--festival-card-color);
}

.festival-accordion-title-wrapper {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1em;
	padding: 1.25em 1.5em;
	cursor: pointer;
	user-select: none;
	transition: background 0.6s ease;
}

.festival-accordion-title-wrapper:hover {
	background: var(--festival-badge-bg);
}

.festival-accordion-title-wrapper[aria-expanded="false"]:hover {
	background: var(--festival-accent);
}

.festival-accordion-title-wrapper:focus {
	outline-width: 0;
}

/* Circular +/- icon, positioned at the end (right side) */
.festival-accordion-title-wrapper .eb-accordion-icon-wrapper {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.25em;
	height: 2.25em;
	border-radius: 50%;
	border: 1px solid var(--festival-icon-border);
	background: var(--festival-icon-bg);
}

.festival-accordion-title-wrapper .eb-accordion-icon {
	font-size: 1.3em;
	line-height: 1;
}

.title-content-festival {
	display: flex;
	flex-direction: column;
	gap: 0.5em;
	flex: 1 1 auto;
}

.eb-accordion-title {
	margin: 0;
	font-size: 1.15em;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	transition: color 0.15s ease;
}

.festival-accordion-excerpt {
	margin: 0 0 0.75em;
	font-size: 0.9em;
	line-height: 1.4;
}

/* Hide the under-title excerpt once the item is expanded */
.festival-accordion-title-wrapper[aria-expanded="true"] .festival-accordion-excerpt {
	display: none;
}

/* --- Host chips (avatar + name), shown below title above meta badges --- */
.festival-accordion-hosts {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em;
	margin-bottom: 0.5em;
}

.festival-accordion-host {
	display: inline-flex;
	align-items: center;
	gap: 0.8em;
	text-decoration: none;
	color: inherit;
	font-size: 0.85em;
	transition: color 0.15s ease;
}
.festival-accordion-hosts a.festival-accordion-host:hover {
	color: var(--wp--preset--color--accent-6);
}

.festival-accordion-host__thumb {
	display: block;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	border-bottom-left-radius: 0;
	border-bottom-right-radius: 0;
	overflow: hidden;
	flex: 0 0 auto;
}

.festival-accordion-host__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.festival-accordion-host__name {
	font-weight: 600;
}

/* --- Meta badges (time, location, category, day, language) --- */
.festival-accordion-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4em;
}

.festival-accordion-badge {
	display: inline-block;
	padding: 0.4em 0.9em;
	border: none;
	border-radius: var(--festival-radius);
	font-family: inherit;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	line-height: 1;
	color: var(--festival-filter-text);
	background: var(--festival-filter-active);
	white-space: nowrap;
}

.festival-accordion--single .festival-accordion-badge {
	background: var(--festival-accent);
}

/* --- Content area --- */
.festival-accordion-content-wrapper {
	overflow: hidden;
	transition: max-height 0.35s ease;
}

.festival-accordion-content-wrapper .eb-accordion-content {
	padding: 1.25em 1.5em;
}

/* --- Related posts (Mitwirkende) list inside accordion content --- */
.festival-related-posts {
	margin-top: 1em;
	/* Temporarily hidden - the related Mitwirkende list at the bottom of an
	   expanded item is hidden for now; remove this line to bring it back. */
	display: none;
}

.festival-related-posts__heading {
	margin-bottom: 0.5em;
	font-size: 1em;
}

.festival-related-posts__list {
	display: flex;
	flex-wrap: wrap;
	gap: 1em;
}

.festival-related-posts__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	text-decoration: none;
	width: 100px;
}

.festival-related-posts__thumb img {
	border-radius: 50%;
	width: 64px;
	height: 64px;
	object-fit: cover;
}

.festival-related-posts__title {
	font-size: 0.85em;
	margin-top: 0.25em;
}

/* --- Mobile: collapse type/language filters behind "Filter" toggle --- */
@media (max-width: 767px) {
	.festival-accordion__filterbar {
		top: 0;
	}
	.festival-accordion__filter-toggle {
		display: inline-block;
	}
	.festival-accordion__filter-toggle:after {
		content: " +";
	}

	.festival-accordion__more-filters {
		display: none;
		flex-direction: column;
		gap: 0.5em;
	}

	.festival-accordion__more-filters.is-open {
		display: flex;
	}

	.festival-accordion__filters {
		flex-direction: column;
	}

	.festival-accordion__days {
		flex-direction: row;
		flex-wrap: wrap;
	}

	.festival-accordion__days .festival-accordion__filter[data-day-filter="all"] {
		display: none;
	}

	.festival-accordion-title-wrapper {
		padding: 1em;
	}

	.festival-accordion-content-wrapper .eb-accordion-content {
		padding: 1em;
	}
}

/* --- Modifiers for reuse outside the full schedule view --- */

/* Used by the related-programmpunkte block (single Mitwirkende page) and
   the single-Programmpunkt display: don't force the full schedule height. */
.festival-accordion--related,
.festival-accordion--single {
	min-height: auto;
}

.festival-accordion__heading {
	margin-bottom: 0.75em;
}