/* ═══════════════════════════════════════════════════════════
   ACF Resim Galerisi — Frontend Gallery CSS  v1.1.0
   ═══════════════════════════════════════════════════════════ */

/* ══════════════════════════════
   GRID GALERİ
══════════════════════════════ */

.acf-galeri-grid {
	display: grid;
	grid-template-columns: repeat(var(--acg-cols, 3), 1fr);
	gap: var(--acg-gap, 12px);
	width: 100%;
}

@media (max-width: 900px) {
	.acf-galeri-grid {
		grid-template-columns: repeat(var(--acg-cols-tab, 2), 1fr);
	}
}
@media (max-width: 600px) {
	.acf-galeri-grid {
		grid-template-columns: repeat(var(--acg-cols-mob, 1), 1fr);
	}
}

/* ── Item ── */
.acf-galeri-item {
	position: relative;
	overflow: hidden;
	border-radius: 10px;
	background: #f1f5f9;
}

/* ── Link ── */
.acf-galeri-link {
	display: block;
	width: 100%;
	height: 100%;
	text-decoration: none !important;
}

/* ── Figure ── */
.acf-galeri-figure {
	position: relative;
	width: 100%;
	overflow: hidden;
	border-radius: 10px;
}

/* ── Boy Oranı ── */
.oran-otomatik .acf-galeri-figure { /* natural height */ }
.oran-otomatik .acf-galeri-img { width: 100%; height: auto; display: block; }
.oran-kare  .acf-galeri-figure { aspect-ratio: 1 / 1; }
.oran-yatay .acf-galeri-figure { aspect-ratio: 16 / 9; }
.oran-dikey .acf-galeri-figure { aspect-ratio: 3 / 4; }

.oran-kare  .acf-galeri-img,
.oran-yatay .acf-galeri-img,
.oran-dikey .acf-galeri-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

/* ── Overlay ── */
.acf-galeri-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(15, 23, 42, 0);
	transition: background .3s ease;
	pointer-events: none;
}
.acf-galeri-overlay svg {
	width: 40px;
	height: 40px;
	color: #fff;
	opacity: 0;
	transform: scale(.7);
	transition: opacity .3s ease, transform .3s ease;
	filter: drop-shadow(0 2px 8px rgba(0,0,0,.4));
}
.acf-galeri-link:hover .acf-galeri-overlay          { background: rgba(15,23,42,.45); }
.acf-galeri-link:hover .acf-galeri-overlay svg       { opacity: 1; transform: scale(1); }

/* ── Caption ── */
.acf-galeri-caption {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 10px 12px;
	background: linear-gradient(to top, rgba(0,0,0,.7), transparent);
	color: #fff;
	font-size: 12.5px;
	line-height: 1.4;
	transform: translateY(100%);
	transition: transform .3s ease;
	pointer-events: none;
}
.acf-galeri-link:hover .acf-galeri-caption { transform: translateY(0); }

/* ── Hover: Zoom ── */
.hover-zoom .acf-galeri-img { transition: transform .45s cubic-bezier(.4,0,.2,1); }
.hover-zoom .acf-galeri-link:hover .acf-galeri-img { transform: scale(1.08); }

/* ── Hover: Karart ── */
.hover-karart .acf-galeri-overlay                        { background: rgba(0,0,0,0); }
.hover-karart .acf-galeri-link:hover .acf-galeri-overlay { background: rgba(0,0,0,.6); }

/* ── Animasyonlar ── */
@keyframes acg-fade-in  { from { opacity:0; transform:translateY(18px); } to { opacity:1; transform:translateY(0); } }
@keyframes acg-slide-in { from { opacity:0; transform:translateY(32px); } to { opacity:1; transform:translateY(0); } }

.acf-galeri-grid.anim-fade  .acf-galeri-item { opacity:0; }
.acf-galeri-grid.anim-slide .acf-galeri-item { opacity:0; }
.acf-galeri-grid.anim-fade  .acf-galeri-item.acg-visible { animation: acg-fade-in  .55s ease forwards; }
.acf-galeri-grid.anim-slide .acf-galeri-item.acg-visible { animation: acg-slide-in .6s cubic-bezier(.4,0,.2,1) forwards; }

.acf-galeri-item:nth-child(1)    { animation-delay:.00s; }
.acf-galeri-item:nth-child(2)    { animation-delay:.06s; }
.acf-galeri-item:nth-child(3)    { animation-delay:.12s; }
.acf-galeri-item:nth-child(4)    { animation-delay:.18s; }
.acf-galeri-item:nth-child(5)    { animation-delay:.24s; }
.acf-galeri-item:nth-child(6)    { animation-delay:.30s; }
.acf-galeri-item:nth-child(7)    { animation-delay:.36s; }
.acf-galeri-item:nth-child(8)    { animation-delay:.42s; }
.acf-galeri-item:nth-child(9)    { animation-delay:.48s; }
.acf-galeri-item:nth-child(10)   { animation-delay:.54s; }
.acf-galeri-item:nth-child(n+11) { animation-delay:.60s; }

/* ── Hata ── */
.acf-galeri-hata {
	padding: 12px 16px;
	background: #fef2f2;
	border-left: 4px solid #ef4444;
	border-radius: 6px;
	color: #991b1b;
	font-size: 14px;
	margin: 0;
}


/* ══════════════════════════════
   SLİDER GALERİ
══════════════════════════════ */

/* ── Wrapper ── */
.acf-slider-wrap {
	width: 100%;
	user-select: none;
}

/* ── ANA GÖRSEL SAHNESI ── */
.acf-slider-main {
	position: relative;
	width: 100%;
	background: #0f172a;
	border-radius: 12px;
	overflow: hidden;
	margin-bottom: 10px;
}

/* Boy oranları */
.acf-slider-wrap.oran-yatay    .acf-slider-main { aspect-ratio: 16 / 9; }
.acf-slider-wrap.oran-kare     .acf-slider-main { aspect-ratio: 1 / 1; }
.acf-slider-wrap.oran-otomatik .acf-slider-main { aspect-ratio: auto; }
.acf-slider-wrap.oran-otomatik .acf-slider-img  { position:static !important; height:auto !important; max-height:80vh; }

/* ── Slides container ── */
.acf-slider-slides {
	position: relative;
	width: 100%;
	height: 100%;
}

/* ── Tek slide ── */
.acf-slider-slide {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity .45s cubic-bezier(.4,0,.2,1);
	pointer-events: none;
}
.acf-slider-slide.is-active {
	opacity: 1;
	pointer-events: auto;
	position: relative;
}

/* Otomatik oran için slide stack düzeltmesi */
.acf-slider-wrap.oran-otomatik .acf-slider-slide          { position:relative; inset:auto; }
.acf-slider-wrap.oran-otomatik .acf-slider-slide:not(.is-active) { display:none; }

/* ── Ana görsel ── */
.acf-slider-img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
}

/* ── Lightbox link ── */
.acf-slider-lb-link {
	display: contents;
	text-decoration: none;
}

/* ── Büyüt (zoom) ikonu ── */
.acf-slider-zoom-icon {
	position: absolute;
	top: 12px;
	right: 12px;
	width: 38px;
	height: 38px;
	background: rgba(0,0,0,.55);
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity .25s ease;
	pointer-events: none;
}
.acf-slider-zoom-icon svg { width:18px; height:18px; color:#fff; }
.acf-slider-slide:hover .acf-slider-zoom-icon { opacity:1; }

/* ── Ok butonları ── */
.acf-slider-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10;
	width: 48px;
	height: 48px;
	background: rgba(255,255,255,.92);
	border: none;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: 0 4px 20px rgba(0,0,0,.28);
	transition: background .2s ease, box-shadow .2s ease, transform .15s ease;
	padding: 0;
}
.acf-slider-arrow:hover  { background:#fff; box-shadow:0 6px 28px rgba(0,0,0,.38); }
.acf-slider-arrow:active { transform:translateY(-50%) scale(.92); }
.acf-slider-arrow svg    { width:20px; height:20px; color:#1e293b; }
.acf-slider-prev { left:14px; }
.acf-slider-next { right:14px; }

@media (max-width:600px) {
	.acf-slider-arrow        { width:36px; height:36px; }
	.acf-slider-arrow svg    { width:16px; height:16px; }
	.acf-slider-prev         { left:8px; }
	.acf-slider-next         { right:8px; }
}

/* ── Sayaç ── */
.acf-slider-counter {
	position: absolute;
	bottom: 12px;
	left: 50%;
	transform: translateX(-50%);
	background: rgba(0,0,0,.55);
	color: #fff;
	font-size: 12px;
	font-weight: 600;
	padding: 4px 12px;
	border-radius: 20px;
	letter-spacing: .04em;
	pointer-events: none;
	z-index: 5;
	white-space: nowrap;
}

/* ── Caption ── */
.acf-slider-caption {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 14px 60px;
	background: linear-gradient(to top, rgba(0,0,0,.75), transparent);
	color: #fff;
	font-size: 13.5px;
	line-height: 1.5;
	text-align: center;
	pointer-events: none;
}

/* ── THUMBNAIL ŞERİDİ ── */
.acf-slider-thumbs-wrap {
	display: flex;
	align-items: center;
	gap: 8px;
	width: 100%;
}

.acf-slider-thumbs-viewport {
	flex: 1;
	overflow: hidden;
	position: relative;
}

.acf-slider-thumbs {
	display: flex;
	gap: 8px;
	transition: transform .35s cubic-bezier(.4,0,.2,1);
	will-change: transform;
}

/* Tek thumb — genişlik JS tarafından da set edilir, burada başlangıç değeri */
.acf-slider-thumb {
	flex-shrink: 0;
	aspect-ratio: 1 / 1;
	border: 2.5px solid transparent;
	border-radius: 8px;
	overflow: hidden;
	cursor: pointer;
	padding: 0;
	background: #e2e8f0;
	transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
	position: relative;
}
.acf-slider-thumb img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform .35s ease;
}
.acf-slider-thumb:hover              { border-color:#94a3b8; transform:translateY(-2px); }
.acf-slider-thumb:hover img          { transform:scale(1.06); }
.acf-slider-thumb.is-active          { border-color:#667EEA; box-shadow:0 0 0 3px rgba(102,126,234,.25); }
.acf-slider-thumb.is-active img      { transform:scale(1.04); }
.acf-slider-thumb.is-active::after   {
	content:'';
	position:absolute;
	inset:0;
	background:rgba(102,126,234,.12);
	pointer-events:none;
}

/* Thumb navigasyon okları */
.acf-slider-thumb-nav {
	flex-shrink: 0;
	width: 34px;
	height: 34px;
	background: #f1f5f9;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	padding: 0;
	transition: background .2s ease, border-color .2s ease;
}
.acf-slider-thumb-nav:hover         { background:#667EEA; border-color:#667EEA; }
.acf-slider-thumb-nav:hover svg     { color:#fff; }
.acf-slider-thumb-nav svg           { width:16px; height:16px; color:#64748b; transition:color .2s ease; }
.acf-slider-thumb-nav:disabled      { opacity:.35; pointer-events:none; }

@media (max-width:600px) {
	.acf-slider-caption { padding:10px 48px; font-size:12px; }
}
