/* Tam ekran karartma katmanı */
.zoom-overlay {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

/* Açıkken görünsün */
.zoom-overlay.open {
  display: flex;
}

/* Wrapper: image + close button */
.zoom-wrapper {
  position: relative;               /* Close button's reference */
  display: inline-block;            /* Fit exactly to image size */
}

/* İçerideki büyük resim */
.zoom-overlay img {
  max-width: 95vw;
  max-height: 80vh;
  box-shadow: 0 10px 40px color-mix(in srgb, var(--bs-body-color) 70%, transparent);
}

/* Kapatma butonu (sağ üst) */
.zoom-overlay-close {
  position: absolute;
  top: -2.3rem;
  right: -2.3rem;
  font-size: 1.4rem;
  color: var(--bs-body-bg);
  background: color-mix(in srgb, var(--bs-body-color) 40%, transparent);
  /* rgba(0, 0, 0, 0.4);*/
  border-radius: 999px;
  border: none;
  width: 2rem;
  height: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

@media (max-width: 600px) {
  .zoom-overlay-close {
    top: -2.6rem;
    right: 0rem;
  }

}

/* Viewer açıkken sayfa kaymasın */
body.zoom-open {
  overflow: hidden;
}

/* Küçük imajlar için cursor ipucu */
figure.zoom-image img,
img.zoom-image {
  cursor: zoom-in;
}
