/**
 * envitron 2026 - Slider Styles
 *
 * Erweitert Swiper.js mit Brand-Stilen.
 * Wird nur auf Pages mit aktivem Slider geladen.
 */

/* ===================================================================== */
/* Slider-Wrapper + Innenraum                                            */
/* ===================================================================== */
.envitron-slider {
	position: relative;
	padding-inline: clamp(1rem, 4vw, 3.5rem);
	/* Atemraum nach unten - Pagination sitzt static darunter, der Wrapper
	 * braucht nur etwas Padding gegen den naechsten Section-Rand. */
	padding-block-end: 1rem;
}

.envitron-slider .swiper {
	overflow: hidden;
	padding-block: 0.5rem;
}

/* Slides in einem Slider strecken sich auf die Hoehe der hoechsten Card.
 * Das ist der "Equal-Height"-Trick fuer Swiper:
 *   1. Wrapper als flex-Container mit align-items: stretch (mit !important,
 *      weil Swiper im Inline-Style gerne dazwischenfunkt).
 *   2. Slide bekommt height: auto (statt Swiper-Default) und ist selbst ein
 *      flex-column. Sein direkt-Inhalt darf dadurch auf 100 % Hoehe wachsen.
 *   3. Im Card-Layout sorgt .product-card__body { flex:1 } + .product-card__link
 *      { margin-top:auto } dafuer, dass die CTAs auf einer Linie sitzen.
 */
.envitron-slider .swiper-wrapper {
	align-items: stretch !important;
}
.envitron-slider .swiper-slide {
	height: auto !important;
	display: flex;
	flex-direction: column;
}

/* ===================================================================== */
/* Use-Case-Card (verwendet von Anwendungsbereiche-Slider auf der Front) */
/* ===================================================================== */
.usecase-card {
	display: flex !important;
	flex-direction: column;
	background: var(--white, #ffffff);
	border-radius: 14px;
	overflow: hidden;
	box-shadow: 0 4px 18px rgba(15, 23, 32, 0.08);
	height: auto;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.usecase-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 28px rgba(15, 23, 32, 0.14);
}

.usecase-card__media {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--ink-50, #f2f4f7);
}

.usecase-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.5s ease;
}

.usecase-card:hover .usecase-card__media img {
	transform: scale(1.04);
}

.usecase-card__body {
	padding: 1.5rem 1.5rem 1.75rem;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	flex: 1;
}

.usecase-card__title {
	margin: 0;
	font-size: clamp(1.05rem, 1.5vw, 1.2rem);
	line-height: 1.3;
	color: var(--ink-900, #2a3142);
	font-weight: 700;
}

.usecase-card__description {
	margin: 0;
	color: var(--ink-700, #40495d);
	font-size: 0.95rem;
	line-height: 1.55;
}

/* ===================================================================== */
/* Swiper Navigation & Pagination - Brand-Style                          */
/* ===================================================================== */
.envitron-slider .swiper-button-prev,
.envitron-slider .swiper-button-next {
	width: 44px;
	height: 44px;
	min-width: 44px;
	background: var(--white, #ffffff);
	color: var(--brand-700, #1b7e36);
	border: 1px solid var(--brand-100, #d1f0db);
	border-radius: 50%;
	box-shadow: 0 4px 12px rgba(15, 23, 32, 0.12);
	transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
	margin-top: -22px;
}

.envitron-slider .swiper-button-prev:hover,
.envitron-slider .swiper-button-next:hover {
	background: var(--brand-700, #1b7e36);
	color: var(--white, #ffffff);
	transform: scale(1.05);
}

.envitron-slider .swiper-button-prev:focus-visible,
.envitron-slider .swiper-button-next:focus-visible {
	outline: 3px solid var(--brand-500, #28a745);
	outline-offset: 3px;
}

.envitron-slider .swiper-button-prev::after,
.envitron-slider .swiper-button-next::after {
	font-size: 1rem;
	font-weight: 700;
}

/* Disabled-State: komplett verstecken (User-Wunsch 20260519). Wenn der
 * Slider an Anfang/Ende ist, soll der jeweilige Pfeil nicht "ausgegraut"
 * stehen bleiben, sondern verschwinden. */
.envitron-slider .swiper-button-prev.swiper-button-disabled,
.envitron-slider .swiper-button-next.swiper-button-disabled {
	display: none;
}

/* ----- Pagination
 * Zwei Layouts:
 *   1) Pagination als Sibling des .swiper im .envitron-slider Wrapper
 *      (neue Slider) -> sitzt sauber UNTER den Slides, kein Overlay.
 *   2) Pagination INNERHALB der .swiper (Fallback fuer Legacy-Markup)
 *      -> position: absolute am unteren Rand, Layout wie bisher.
 */
.envitron-slider > .swiper-pagination {
	position: static;
	display: flex;
	justify-content: center;
	gap: 0.4rem;
	margin-block-start: 1.25rem;
}
.envitron-slider .swiper > .swiper-pagination {
	position: absolute;
	bottom: 0.5rem;
	left: 0;
	right: 0;
	display: flex;
	justify-content: center;
	gap: 0.4rem;
}

.envitron-slider .swiper-pagination-bullet {
	width: 10px;
	height: 10px;
	background: var(--ink-200, #d8dde6);
	opacity: 1;
	transition: background 0.2s ease, transform 0.2s ease;
	border: 0;
	cursor: pointer;
}

.envitron-slider .swiper-pagination-bullet:hover {
	background: var(--brand-300, #6dd286);
}

.envitron-slider .swiper-pagination-bullet:focus-visible {
	outline: 2px solid var(--brand-500, #28a745);
	outline-offset: 3px;
}

.envitron-slider .swiper-pagination-bullet-active {
	background: var(--brand-700, #1b7e36);
	transform: scale(1.2);
}

/* ===================================================================== */
/* Reduced motion - Autoplay-Pausen + ruhigere Transitions               */
/* ===================================================================== */
@media (prefers-reduced-motion: reduce) {
	.envitron-slider .swiper-wrapper {
		transition-duration: 0.05s !important;
	}
	.usecase-card,
	.usecase-card:hover,
	.usecase-card__media img {
		transition: none;
		transform: none;
	}
}

/* ===================================================================== */
/* Hide native swiper arrow buttons on very small screens (Pagination genuegt) */
/* ===================================================================== */
@media (max-width: 640px) {
	.envitron-slider {
		padding-inline: 0.5rem;
	}
	.envitron-slider .swiper-button-prev,
	.envitron-slider .swiper-button-next {
		display: none;
	}
}

/* ===================================================================== */
/* Product-Slider (Front-Page + Produkt-Detail "Weitere Loesungen")      */
/* ===================================================================== */
/* Der Product-Slider nutzt dieselben .product-card-Styles wie das Grid,
 * benoetigt aber etwas mehr vertikale Luft, damit der Hover-Lift
 * (translateY(-4px) + box-shadow) nicht vom swiper-overflow:hidden
 * abgeschnitten wird. */
.product-slider .swiper {
	padding-block: 0.75rem 0.5rem;
	margin-inline: -0.25rem;
	padding-inline: 0.25rem;
}

/* Volle Hoehe pro Slide -> .product-card kann sich in die Vertikale strecken
 * und die "Mehr erfahren"-Links fluchten auf einer Linie. */
.product-slider .swiper-slide.product-card {
	height: auto;
	display: flex;
	flex-direction: column;
}

/* Kompakter Modus auf der Produkt-Detailseite ("Weitere Loesungen"): kleinerer
 * Body, gleich wie im urspruenglichen .product-grid--compact. */
.product-slider--compact .product-card {
	background: var(--white, #ffffff);
}
.product-slider--compact .product-card__body {
	padding: 1rem 1.1rem 1.25rem;
	gap: 0.45rem;
}
.product-slider--compact .product-card__title {
	font-size: 1rem;
}

/* Product-Slider hat die Pagination als Sibling unter der .swiper
 * (siehe Markup in front-page.php / template-product.php).
 * Wir geben hier nur den Abstand nach den Cards an. */
.product-slider > .swiper-pagination {
	margin-block-start: 1rem;
}
