/* =========================
   КАРТИНКИ ВНУТРИ ТЕКСТА ЛИСТА

   Логика:
   - одиночная картинка получает ud-text-img-left через helpers.php
   - картинка с подписью получает ud-text-figure-left на figure/wp-caption
   - подпись едет вместе с картинкой
   - размер картинки берётся из WordPress / редактора
   - aligncenter / alignright не трогаем
========================= */
/* Обычные картинки внутри листа не вылезают за пределы */
.sphere-paper img {
  max-width: 100%;
  height: auto;
}

/* Обычный WordPress-блок картинки внутри листа */
.sphere-paper figure.wp-block-image {
  max-width: 100%;
  margin: 1rem 0;
  box-sizing: border-box;
}

/* Сама картинка внутри WordPress figure */
.sphere-paper figure.wp-block-image img {
  display: block;
  max-width: 100%;
  height: auto;
  border-radius: 0.35rem;
}

/* =========================
   ОБТЕКАНИЕ СЛЕВА

   Работает, если WordPress поставил:
   class="alignleft"

   Или если мы вручную поставили:
   class="ud-text-img-left"
========================= */

/* Картинка напрямую в тексте:
   <img class="alignleft ..." ...> */
.sphere-paper img.alignleft,
.sphere-paper img.ud-text-img-left {
  float: left;
  clear: none;
  display: block;

  max-width: 45%;
  height: auto;

  margin: 0 0.9rem 0.45rem 0;

  border-radius: 0.35rem;
  box-sizing: border-box;
}

/* WordPress-блок figure / caption с обтеканием */
.sphere-paper figure.wp-block-image.alignleft,
.sphere-paper figure.ud-text-figure-left,
.sphere-paper .wp-caption.ud-text-figure-left {
  float: left;
  clear: none;

  width: auto;
  max-width: 45%;

  margin: 0 0.9rem 0.45rem 0;

  box-sizing: border-box;
}
/* Картинка внутри обтекающей обёртки */
.sphere-paper figure.wp-block-image.alignleft img,
.sphere-paper figure.ud-text-figure-left img,
.sphere-paper .wp-caption.ud-text-figure-left img {
  display: block;

  width: auto;
  max-width: 100%;
  height: auto;

  border-radius: 0.35rem;
}
/* Мобильная подстройка для обтекающих картинок */
@media (max-width: 48rem) {
  .sphere-paper img.alignleft,
  .sphere-paper img.ud-text-img-left,
  .sphere-paper figure.wp-block-image.alignleft,
  .sphere-paper figure.ud-text-figure-left,
  .sphere-paper .wp-caption.ud-text-figure-left {
    max-width: 38%;
    margin: 0 0.75rem 0.4rem 0;
  }
}

/* Подпись под картинкой */
.sphere-paper figure.wp-block-image figcaption,
.sphere-paper .wp-caption .wp-caption-text {
  margin-top: 0.25rem;

  font-size: 0.78em;
  line-height: 1.25;
  text-align: center;

  color: var(--ud-theme-h1);
  opacity: 0.88;

  font-style: italic;
}

/* Мобильная подстройка подписи:
   подпись не вылезает за края картинки.
   Короткая остаётся компактной, длинная переносится. */
@media (max-width: 48rem) {
  .sphere-paper figure.wp-block-image figcaption,
  .sphere-paper .wp-caption .wp-caption-text {
    width: 100%;
    max-width: 100%;

    margin-left: auto;
    margin-right: auto;

    font-size: clamp(0.58em, 2.6vw, 0.66em);
    line-height: 1.12;

    white-space: normal;
    overflow-wrap: break-word;
    text-wrap: balance;
  }
}
/* Внутренние подзаголовки рядом с обтекающей картинкой.
   Если слева стоит картинка, заголовок центрируется
   в свободной текстовой зоне справа от неё. */
.sphere-paper h3:not([id]) {
  overflow: hidden;
  text-align: center;

  margin-top: 0.45rem;
  margin-bottom: 0.7rem;

  font-size: 1.05em;
  line-height: 1.25;
}
/* Первый абзац после обтекающей картинки не должен прыгать вниз */
.sphere-paper img.alignleft + p,
.sphere-paper img.ud-text-img-left + p,
.sphere-paper figure.wp-block-image.alignleft + p,
.sphere-paper figure.ud-text-figure-left + p,
.sphere-paper .wp-caption.ud-text-figure-left + p {
  margin-top: 0;
}
/* Стоп обтекания, если нужно начать новый чистый блок */
.sphere-paper .ud-clear {
  clear: both;
}

/* =========================
   LIGHTBOX ДЛЯ КАРТИНОК В ЛИСТЕ

   Маленькая картинка остаётся на своём месте,
   но временно становится прозрачной.
   Поверх неё создаётся копия, которая плавно увеличивается.
   Если у картинки есть подпись — она появляется под увеличенной картинкой.
========================= */

/* Показываем, что картинку можно открыть */
.sphere-paper img.ud-text-img-left,
.sphere-paper img.alignleft,
.sphere-paper figure.ud-text-figure-left img,
.sphere-paper .wp-caption.ud-text-figure-left img {
  cursor: zoom-in;
}

/* Когда картинка раскрыта, исходник невидим,
   но место в тексте сохраняется */
.ud-lightbox-source-hidden {
  opacity: 0 !important;
}

/* Контейнер поверх страницы */
.ud-image-lightbox {
  position: fixed;
  inset: 0;
  z-index: 99999;

  display: none;

  background: transparent;
  pointer-events: none;
}

/* Открытое состояние */
.ud-image-lightbox.is-open {
  display: block;
  pointer-events: auto;
}

/* Увеличивающаяся картинка.
   Размер и позицию задаёт JS через left/top/width/height. */
.ud-image-lightbox-img {
  position: fixed;
  z-index: 100000;

  display: block;

  max-width: none;
  max-height: none;

  object-fit: contain;

  border-radius: 0.35rem;
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.28);

  cursor: zoom-out;
  will-change: left, top, width, height, border-radius;
}

/* Когда картинка раскрылась */
.ud-image-lightbox-img.is-expanded {
  border-radius: 0.65rem;
}

/* Подпись под увеличенной картинкой.
   Позицию и ширину задаёт JS, чтобы подпись ехала вместе с картинкой. */
.ud-image-lightbox-caption {
  position: fixed;
  z-index: 100000;

  display: block;

  margin: 0;
  padding: 0.15rem 0.35rem;

  box-sizing: border-box;

  font-size: clamp(0.9rem, 1.8vw, 1.15rem);
  line-height: 1.18;
  text-align: center;
  font-style: italic;

  color: var(--ud-theme-h1);
  background: transparent;
  border-radius: 0;

  white-space: normal;
  overflow-wrap: normal;

  opacity: 0;
  pointer-events: none;

  will-change: left, top, width, opacity;
}

/* Когда подпись раскрылась */
.ud-image-lightbox-caption.is-visible {
  opacity: 1;
}

/* Когда картинка раскрыта — страницу под ней не прокручиваем */
body.ud-lightbox-open {
  overflow: hidden;
}

/* Мобильная подстройка */
@media (max-width: 48rem) {
  .ud-image-lightbox-img.is-expanded {
    border-radius: 0.5rem;
  }

  .ud-image-lightbox-caption {
    font-size: clamp(0.78rem, 3.2vw, 0.95rem);
    line-height: 1.14;

    padding: 0.12rem 0.3rem;
    border-radius: 0.3rem;
  }
}

/* =========================
   EMOJI В ТЕКСТЕ СФЕРЫ
   Конфетки, смайлики и другие WordPress-emoji
   Не даём им раздуваться как обычным картинкам
========================= */

body .sphere-article img.emoji,
body .sphere-article img.wp-smiley,
body .sphere-article img[src*="/emoji/"],
body .sphere-article img[src*="s.w.org/images/core/emoji"],
body .sphere-paper img.emoji,
body .sphere-paper img.wp-smiley,
body .sphere-paper img[src*="/emoji/"],
body .sphere-paper img[src*="s.w.org/images/core/emoji"] {
  display: inline-block !important;

  width: 1em !important;
  height: 1em !important;
  min-width: 0 !important;
  min-height: 0 !important;
  max-width: 1em !important;
  max-height: 1em !important;

  margin: 0 0.08em !important;
  padding: 0 !important;

  vertical-align: -0.12em !important;
  object-fit: contain !important;
}
/* =========================
   FINAL: подпись под увеличенной картинкой
   Без тестового фона.
   Подпись максимально заметная, широкая, адаптивная.
========================= */

.ud-image-lightbox-caption {
  background: transparent !important;
  color: var(--ud-theme-h1) !important;

  font-size: clamp(1.35rem, 4.4vw, 2.25rem) !important;
  line-height: 1.08 !important;

  width: 86vw !important;
  min-width: 86vw !important;
  max-width: 86vw !important;

  left: 7vw !important;

  padding: 0.35rem 0.7rem !important;
  text-align: center !important;

  white-space: normal !important;
  overflow-wrap: normal !important;
}

/* Мобильная подстройка увеличенной подписи */
@media (max-width: 48rem) {
  .ud-image-lightbox-caption {
    width: 88vw !important;
    min-width: 88vw !important;
    max-width: 88vw !important;

    left: 6vw !important;

    font-size: clamp(1.2rem, 6vw, 1.75rem) !important;
    line-height: 1.08 !important;

    padding: 0.25rem 0.45rem !important;
  }
}