/* Fast transition class for arrow/dot clicks */
.fs-slideshow.fs-fast-transition .fs-slide {
/*	transition: opacity 250ms ease, transform 250ms ease !important;*/
}

.fs-slideshow {
	position: relative;
	inset: 0;
	width: 100vw;
	height: 100vh;
	overflow: hidden;
	z-index: 9999;
	background: #000;
}

.fs-slides {
	position: relative;
	width: 100%;
	height: 100%;
}

.fs-slide {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0;
	transition: opacity 0.5s ease, transform 0.5s ease;
}

.fs-slide.active {
	opacity: 1;
	z-index: 1;
}

/* Aspect Ratio Overrides */
.fs-slideshow[data-aspect="contain"] .fs-slide { object-fit: contain; }
.fs-slideshow[data-aspect="fill"] .fs-slide { object-fit: fill; }

/* Transition Types */
.fs-slideshow[data-transition="slide_left"] .fs-slide { transform: translateX(100%); }
.fs-slideshow[data-transition="slide_left"] .fs-slide.active { transform: translateX(0); }
.fs-slideshow[data-transition="slide_left"] .fs-slide.prev { transform: translateX(-100%); }

.fs-slideshow[data-transition="slide_right"] .fs-slide { transform: translateX(-100%); }
.fs-slideshow[data-transition="slide_right"] .fs-slide.active { transform: translateX(0); }
.fs-slideshow[data-transition="slide_right"] .fs-slide.prev { transform: translateX(100%); }

.fs-slideshow[data-transition="zoom"] .fs-slide { transform: scale(1.2); }
.fs-slideshow[data-transition="zoom"] .fs-slide.active { transform: scale(1); }

/* Navigation */
.fs-nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: rgba(0,0,0,0.3);
	color: #fff;
	border: none;
	padding: 15px 20px;
	cursor: pointer;
	z-index: 9999;
	transition: background 0.3s;
	pointer-events: auto;
}
.fs-nav:hover { background: rgba(0,0,0,0.6); }
.fs-nav-prev { left: 20px; }
.fs-nav-next { right: 20px; }

.fs-nav-dots {
	position: absolute;
	bottom: 30px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: 10px;
	z-index: 10;
}
.fs-dot {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: rgba(255,255,255,0.5);
	border: none;
	padding: 0;
	margin: 0;
	cursor: pointer;
	transition: background 0.3s;
	box-sizing: border-box;
}
.fs-dot.active { background: #fff; }

/* Overlay */
.fs-overlay {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 5;
}
.fs-overlay img {
	max-width: 80vw;
	max-height: 80vh;
	object-fit: contain;
	cursor: pointer;
}