/**
 * KI Gallery Carousel Styles
 * Version: 1.0.0
 */

.ki-carousel-container {
	position: relative;
	width: 100%;
	/*max-width: 1400px;*/
	margin: 0 auto;
	padding: 20px 50px 20px 20px;
	--carousel-height: 450px;
}

.ki-carousel-container .swiper {
	width: 100%;
	height: var(--carousel-height);
	border-radius: 12px;
	overflow: visible;
}

.ki-carousel-container .swiper-wrapper {
	align-items: center;
}

.ki-carousel-container .swiper-slide {
	width: auto !important;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	background: transparent;
}

/* Querformat: breiter (ca. 1/3 der Breite) */
.ki-carousel-container .swiper-slide.landscape {
	flex: 0 0 auto;
	max-width: 32%;
}

/* Hochformat: schmaler (ca. 1/5 der Breite) */
.ki-carousel-container .swiper-slide.portrait {
	flex: 0 0 auto;
	max-width: 20%;
}

/* Quadratisch: mittel */
.ki-carousel-container .swiper-slide.square {
	flex: 0 0 auto;
	max-width: 28%;
}

.ki-carousel-container .swiper-slide a {
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 3px;
	overflow: hidden;
	box-shadow: 0em 0.65em 1.35em 0em rgba(0, 0, 0, 0.16);
	transition: all 0.3s ease;
}

.ki-carousel-container .swiper-slide a:hover {
	box-shadow: 0 8px 25px rgba(0, 0, 0, 0.25);
	transform: translateY(-5px);
}

.ki-carousel-container .swiper-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Navigation Wrapper - rechts positioniert */
.ki-carousel-container .swiper-navigation-wrapper {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	flex-direction: row;
	gap: 10px;
	z-index: 10;
}

.ki-carousel-container .swiper-button-prev,
.ki-carousel-container .swiper-button-next {
	position: relative;
	left: auto;
	right: auto;
	top: auto;
	bottom: auto;
	margin: 0;
	color: #fff;
	background: rgba(0, 0, 0, 0.6);
	width: 44px;
	height: 44px;
	border-radius: 50%;
	transition: all 0.3s ease;
}

.ki-carousel-container .swiper-button-prev:hover,
.ki-carousel-container .swiper-button-next:hover {
	background: rgba(0, 0, 0, 0.9);
	transform: scale(1.15);
}

.ki-carousel-container .swiper-button-prev:after,
.ki-carousel-container .swiper-button-next:after {
	font-size: 18px;
	font-weight: bold;
}

.ki-carousel-container .swiper-button-prev.swiper-button-disabled,
.ki-carousel-container .swiper-button-next.swiper-button-disabled {
	opacity: 0.35;
	cursor: not-allowed;
}

.ki-carousel-container .swiper-pagination {
	bottom: -25px;
	position: relative;
	margin-top: 20px;
}

.ki-carousel-container .swiper-pagination-bullet {
	background: #666;
	opacity: 0.5;
	width: 8px;
	height: 8px;
	transition: all 0.3s ease;
}

.ki-carousel-container .swiper-pagination-bullet-active {
	opacity: 1;
	background: #007bff;
	width: 24px;
	border-radius: 4px;
}

/* Tablet Anpassungen */
@media (max-width: 1024px) {
	.ki-carousel-container {
		padding: 20px;
		--carousel-height: 350px;
	}

	.ki-carousel-container .swiper-slide.landscape {
		max-width: 45%;
	}

	.ki-carousel-container .swiper-slide.portrait {
		max-width: 28%;
	}

	.ki-carousel-container .swiper-slide.square {
		max-width: 40%;
	}
}

/* Mobile Anpassungen */
@media (max-width: 768px) {
	.ki-carousel-container {
		padding: 15px 0;
		--carousel-height: 300px;
	}

	.ki-carousel-container .swiper {
		overflow: hidden;
	}

	/* Mobile: nur 1-2 Bilder sichtbar */
	.ki-carousel-container .swiper-slide.landscape {
		max-width: 85%;
	}

	.ki-carousel-container .swiper-slide.portrait {
		max-width: 55%;
	}

	.ki-carousel-container .swiper-slide.square {
		max-width: 75%;
	}

	/* Navigation ausblenden auf Mobile */
	.ki-carousel-container .swiper-navigation-wrapper {
		display: none;
	}

	.ki-carousel-container .swiper-pagination {
		bottom: -20px;
		margin-top: 15px;
	}
}

/* Kleine Mobile Geräte */
@media (max-width: 480px) {
	.ki-carousel-container {
		--carousel-height: 250px;
	}

	.ki-carousel-container .swiper-slide.landscape {
		max-width: 90%;
	}

	.ki-carousel-container .swiper-slide.portrait {
		max-width: 60%;
	}

	.ki-carousel-container .swiper-slide.square {
		max-width: 80%;
	}
}
