/* ════════════════════════════════════════════════════════════════
   lightbox.css — простой лайтбокс для увеличения иллюстраций по клику
   Подключается вместе с lightbox.js.
   Применяется к любому <img>, у которого есть атрибут data-lightbox,
   ИЛИ к <img> внутри элемента с атрибутом data-lightbox.
   ════════════════════════════════════════════════════════════════ */

/* Курсор + микро-эффект при наведении на кликабельную картинку */
[data-lightbox] img,
img[data-lightbox] {
  cursor: zoom-in;
  transition: transform .25s ease, box-shadow .25s ease;
}
[data-lightbox]:hover img,
img[data-lightbox]:hover {
  /* Лёгкий «всплыв» при наведении — намекает что картинка кликабельна */
  filter: brightness(1.02);
}

/* Оверлей создаётся JS-ом и добавляется в body */
.lb-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(15, 12, 10, .92);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5vh 4vw;
  opacity: 0;
  /* НЕ ловить клики и курсор, когда закрыт, иначе zoom-out «прилипает» */
  pointer-events: none;
  visibility: hidden;
  /* visibility меняется с задержкой при закрытии, чтобы opacity успела отыграть */
  transition: opacity .22s ease, visibility 0s linear .22s;
}
.lb-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
  cursor: zoom-out;
  /* при открытии visibility включается сразу */
  transition: opacity .22s ease, visibility 0s linear 0s;
}

.lb-overlay img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 6px;
  box-shadow: 0 30px 80px rgba(0, 0, 0, .6);
  transform: scale(.96);
  transition: transform .25s ease;
  cursor: default;
}
.lb-overlay.is-open img {
  transform: scale(1);
}

.lb-close {
  position: absolute;
  top: 18px;
  right: 22px;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .12);
  border: none;
  color: #fff;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s;
  font-family: Arial, sans-serif;
}
.lb-close:hover {
  background: rgba(255, 255, 255, .22);
}

.lb-caption {
  position: absolute;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  max-width: 80vw;
  text-align: center;
  font-size: 13px;
  color: rgba(255, 255, 255, .75);
  line-height: 1.5;
  font-style: italic;
}

/* Запрет скролла body, когда оверлей открыт — выставляется JS */
body.lb-locked {
  overflow: hidden;
}

@media (max-width: 640px) {
  .lb-overlay { padding: 4vh 3vw; }
  .lb-close { top: 12px; right: 14px; width: 36px; height: 36px; font-size: 18px; }
}
