/* =====================================================================
   Villa Detay Galerisi — Modern (PhotoSwipe 5 + Swiper 11)
   Mobile-first / CLS-safe / Progressive Enhancement
   Bu dosya yalnızca villa detay sayfasında yüklenir.
   ===================================================================== */

:root {
	--vg-accent: #13213a;        /* mevcut tema lacivert */
	--vg-radius: 14px;
	--vg-gap: 8px;
	--vg-bg: #0d1117;
}

/* Kapsayıcı: layout shift'i önlemek için sabit en-boy oranı */
.villa-galeri {
	position: relative;
	width: 100%;
	margin: 0 0 22px;
	-webkit-tap-highlight-color: transparent;
}

/* ---------- ANA SLIDER ---------- */
.villa-galeri .vg-main {
	width: 100%;
	border-radius: var(--vg-radius);
	overflow: hidden;
	background: var(--vg-bg);
	/* CLS-safe: JS yüklenmeden de yükseklik rezerve edilir */
	aspect-ratio: 16 / 10;
}

.villa-galeri .vg-main .swiper-slide {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--vg-bg);
	overflow: hidden;
}

.villa-galeri .vg-main .swiper-slide a {
	display: block;
	width: 100%;
	height: 100%;
	cursor: zoom-in;
}

.villa-galeri .vg-main .swiper-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	/* Keskinlik: upscale eden transform/scale YOK, filter YOK. Görsel piksel-piksel net. */
}

/* Sayaç rozeti */
.villa-galeri .vg-counter {
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 5;
	background: rgba(0,0,0,.55);
	color: #fff;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: .3px;
	padding: 5px 11px;
	border-radius: 999px;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	pointer-events: none;
}

/* "Tümünü gör" ipucu */
.villa-galeri .vg-zoom-hint {
	position: absolute;
	bottom: 12px;
	right: 12px;
	z-index: 5;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: rgba(0,0,0,.55);
	color: #fff;
	font-size: 12px;
	font-weight: 600;
	padding: 6px 12px;
	border-radius: 999px;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	pointer-events: none;
}

/* Oklar (sadece masaüstü; mobilde swipe yeterli) */
.villa-galeri .swiper-button-next,
.villa-galeri .swiper-button-prev {
	color: #fff;
	width: 42px;
	height: 42px;
	background: rgba(0,0,0,.4);
	border-radius: 50%;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	transition: background .2s ease, opacity .2s ease;
}
.villa-galeri .swiper-button-next:hover,
.villa-galeri .swiper-button-prev:hover { background: rgba(0,0,0,.65); }
.villa-galeri .swiper-button-next::after,
.villa-galeri .swiper-button-prev::after { font-size: 17px; font-weight: 700; }

/* ---------- THUMBNAIL ŞERİDİ ---------- */
.villa-galeri .vg-thumbs {
	width: 100%;
	margin-top: var(--vg-gap);
	box-sizing: border-box;
}
.villa-galeri .vg-thumbs .swiper-slide {
	width: 90px;
	height: 62px;
	border-radius: 9px;
	overflow: hidden;
	opacity: .55;
	cursor: pointer;
	transition: opacity .25s ease, transform .25s ease;
	border: 2px solid transparent;
}
.villa-galeri .vg-thumbs .swiper-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.villa-galeri .vg-thumbs .swiper-slide-thumb-active {
	opacity: 1;
	border-color: var(--vg-accent);
	transform: translateY(-2px);
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 768px) {
	.villa-galeri .vg-main { aspect-ratio: 4 / 3; border-radius: 12px; }
	.villa-galeri .swiper-button-next,
	.villa-galeri .swiper-button-prev { display: none; } /* mobilde swipe */
	.villa-galeri .vg-thumbs .swiper-slide { width: 72px; height: 50px; }
	.villa-galeri .vg-zoom-hint { display: none; }
}
@media (min-width: 1200px) {
	.villa-galeri .vg-main { aspect-ratio: 16 / 9; }
}

/* ---------- PROGRESSIVE ENHANCEMENT FALLBACK ----------
   Swiper init olmadan (JS yok / yavaş) galeri yine de kullanılır:
   yatay kaydırmalı şerit + çalışan tam-boy linkleri. */
.villa-galeri .swiper:not(.swiper-initialized) .swiper-wrapper {
	display: flex;
	gap: var(--vg-gap);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
}
.villa-galeri .vg-main:not(.swiper-initialized) .swiper-slide {
	flex: 0 0 100%;
	scroll-snap-align: center;
}
.villa-galeri .vg-thumbs:not(.swiper-initialized) .swiper-slide {
	flex: 0 0 auto;
	opacity: 1;
}
/* JS yokken ken-burns kapalı (titreşim olmasın) */
.villa-galeri .vg-main:not(.swiper-initialized) .swiper-slide img { transform: none; }

/* Erişim: klavye odak halkası */
.villa-galeri a:focus-visible {
	outline: 3px solid var(--vg-accent);
	outline-offset: 2px;
}

/* PhotoSwipe arka plan tonu (premium koyu) */
.pswp { --pswp-bg: #0b0e14; }
