/* =========================================================
   Dörpen Kultur – Header Karussell (Frontend)
   - volle Breite
   - max. Höhe 500px (per --dhc-height überschreibbar)
   - Bild proportional, scharf zentriert
   - bei abweichendem Seitenverhältnis: gleiches Bild als
     verschwommener Hintergrund, der die Bildfarben übernimmt
   - Fallback-Farbe #C2303C wenn keine Bilder vorhanden
   ========================================================= */

.dhc-carousel {
	--dhc-fallback: #C2303C;
	--dhc-height: 500px;

	position: relative;
	width: 100%;
	max-width: 100%;
	height: var(--dhc-height);
	max-height: 500px;
	overflow: hidden;
	background: var(--dhc-fallback);
	box-sizing: border-box;
}

/* Volle Breite erzwingen, wenn der Block in einem zentrierten
   Container steckt (z. B. Theme-Content-Wrap). */
.dhc-carousel.dhc-fullwidth {
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}

/* Fallback (keine Bilder) */
.dhc-carousel.is-empty {
	background: var(--dhc-fallback);
}
.dhc-fallback {
	position: absolute;
	inset: 0;
	background: var(--dhc-fallback);
}

/* Swiper Container */
.dhc-carousel .swiper,
.dhc-carousel .dhc-swiper {
	width: 100%;
	height: 100%;
}

/* Einzelne Slide */
.dhc-slide {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: hidden;
	background: var(--dhc-fallback);
}

/* ---- Verschwommener Hintergrund-Layer ---- */
.dhc-slide-bg {
	position: absolute;
	inset: -40px;                /* leichte Übergröße, damit der Blur-Rand nicht sichtbar wird */
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	filter: blur(28px) saturate(1.15) brightness(.85);
	transform: scale(1.15);
	z-index: 1;
}
/* leichter Schwarz-Schleier für mehr Bild-Pop */
.dhc-slide-bg::after {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, .15);
}

/* ---- Vordergrund: Originalbild scharf, proportional ---- */
.dhc-slide-img-wrap {
	position: absolute;
	inset: 0;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: center;
}
.dhc-slide-img {
	display: block;
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
	object-fit: contain;
	box-shadow: 0 4px 28px rgba(0, 0, 0, .25);
}

/* ---- Veranstaltungs-Balken (Name | Datum) ----
   Ein einzelner, breiter Balken, der die Breite des Fotos übernimmt
   (per JS in die Variable --dhc-bar-width geschrieben) und an den
   Rändern in transparent ausläuft. Damit liegt der Balken genau
   über dem Foto, beeinträchtigt es aber nicht. */
.dhc-slide-bars {
	--dhc-bar-width: 100%;
	--dhc-bar-fade: 12%;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 3;
	display: flex;
	justify-content: center;
	pointer-events: none;
}
.dhc-bar {
	width: var(--dhc-bar-width);
	max-width: 100%;
	margin: 0 auto;
	box-sizing: border-box;
	padding: 16px 36px;
	text-align: center;
	color: #fff;
	font-family: inherit;
	font-weight: 700;
	letter-spacing: .4px;
	line-height: 1.2;
	text-shadow: 0 2px 4px rgba(0, 0, 0, .35);

	/* Linearer Verlauf: an den Enden transparent, in der Mitte solid #C2303C */
	background: linear-gradient(
		90deg,
		rgba(194, 48, 60, 0)   0%,
		var(--dhc-fallback)    var(--dhc-bar-fade),
		var(--dhc-fallback)    calc(100% - var(--dhc-bar-fade)),
		rgba(194, 48, 60, 0)   100%
	);
}
.dhc-bar-event {
	font-size: clamp(18px, 2.4vw, 32px);
	display: inline-flex;
	flex-wrap: wrap;
	align-items: baseline;
	justify-content: center;
	column-gap: .25em;
	row-gap: .15em;
}
.dhc-bar-name {
	font-weight: 800;
}
.dhc-bar-sep {
	display: inline-block;
	font-weight: 400;
	opacity: .85;
	margin: 0 .1em;
}
.dhc-bar-date {
	font-weight: 600;
	letter-spacing: .3px;
}

/* Wenn Pagination sichtbar ist: Balken etwas nach oben rücken */
.dhc-carousel.dhc-has-dots .dhc-slide-bars { bottom: 30px; }
.dhc-carousel.dhc-has-dots .swiper-pagination { z-index: 4; }

/* Mobil: kompakter, weniger horizontaler Padding */
@media (max-width: 600px) {
	.dhc-slide-bars { --dhc-bar-fade: 8%; }
	.dhc-bar { padding: 11px 18px; }
	.dhc-bar-event { font-size: clamp(15px, 4.2vw, 20px); }
}

/* ---- Pfeile ---- */
.dhc-carousel .dhc-arrow {
	color: #fff;
	background: rgba(194, 48, 60, .75);
	width: 44px;
	height: 44px;
	border-radius: 50%;
	transition: background .2s, transform .2s;
}
.dhc-carousel .dhc-arrow:hover {
	background: rgba(194, 48, 60, 1);
	transform: scale(1.05);
}
.dhc-carousel .dhc-arrow::after {
	font-size: 18px;
	font-weight: 900;
}

/* ---- Pagination ---- */
.dhc-carousel .swiper-pagination-bullet {
	background: #fff;
	opacity: .6;
	width: 10px;
	height: 10px;
	transition: opacity .2s, transform .2s;
}
.dhc-carousel .swiper-pagination-bullet-active {
	background: #C2303C;
	opacity: 1;
	transform: scale(1.2);
}

/* Mobile Anpassungen */
@media (max-width: 600px) {
	.dhc-carousel .dhc-arrow { width: 36px; height: 36px; }
	.dhc-slide-bg { inset: -20px; filter: blur(20px) saturate(1.1) brightness(.85); }
}

/* Reduced motion respektieren */
@media (prefers-reduced-motion: reduce) {
	.dhc-slide-bg { transform: none; }
}
