/* ===== BB Preview: изображения с оверлеем подписи, базовые утилиты ===== */

.bb-figure { margin: 0; }

.bb-media {
  position: relative;
  display: inline-block;
  max-width: 100%;
  border-radius: 0.9rem; /* чуть больше скругление */
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(1200px 300px at -20% -40%, rgba(55,246,225,.06), transparent 55%),
    radial-gradient(900px 360px at 120% 120%, rgba(124,58,237,.06), transparent 55%),
    rgba(255,255,255,.03);
  box-shadow:
    0 1px 0 rgba(255,255,255,.04) inset,
    0 10px 28px -14px rgba(0,0,0,.45);
}
.bb-media.neo-img:hover {
  box-shadow:
    0 1px 0 rgba(255,255,255,.05) inset,
    0 16px 40px -16px rgba(0,0,0,.55);
}

.bb-img {
  display: block;
  max-width: 100%;
  height: auto;
}

/* ===== Подпись поверх изображения ===== */
/* Базовый слой оверлея — всегда в пределах .bb-media благодаря overflow:hidden */
.bb-cap-overlay {
  position: absolute;
  left: 0; right: 0;
  padding: 10px 12px;
  display: flex;
  pointer-events: none; /* overlay не перехватывает клики */
}

/* «Плашка» подписи: тянется по содержимому, не шире 92% изображения */
.bb-cap-badge {
  max-width: 92%;
  display: inline-block;
  padding: 6px 10px;
  font-size: 12px;
  line-height: 1.35;
  border-radius: 0.75rem;
  border: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(6px);
  text-shadow: 0 1px 0 rgba(0,0,0,.25);
  white-space: normal;      /* перенос по словам/символам */
  overflow-wrap: anywhere;
  pointer-events: auto;     /* позволяем выделять текст */
}

/* Позиции — 6 вариантов (без тёмных полос/градиентов) */
.bb-cap-pos-bottom-left   { bottom: 0; justify-content: flex-start; align-items: flex-end; }
.bb-cap-pos-bottom-center { bottom: 0; justify-content: center;     align-items: flex-end; }
.bb-cap-pos-bottom-right  { bottom: 0; justify-content: flex-end;   align-items: flex-end; }
.bb-cap-pos-top-left      { top: 0;    justify-content: flex-start; align-items: flex-start; }
.bb-cap-pos-top-center    { top: 0;    justify-content: center;     align-items: flex-start; }
.bb-cap-pos-top-right     { top: 0;    justify-content: flex-end;   align-items: flex-start; }

/* Выравнивание текста внутри бейджа согласно позиции */
.bb-cap-align-left   { text-align: left; }
.bb-cap-align-center { text-align: center; }
.bb-cap-align-right  { text-align: right; }

/* Цвет текста подписи */
.bb-cap-color-default { color: #e5e7eb !important; }
.bb-cap-color-neon    { color: #37f6e1 !important; }
.bb-cap-color-violet  { color: #c4b5fd !important; }
.bb-cap-color-amber   { color: #fbbf24 !important; }
.bb-cap-color-emerald { color: #34d399 !important; }
.bb-cap-color-rose    { color: #fda4af !important; }
.bb-cap-color-sky     { color: #7dd3fc !important; }

/* Приглушённые фоны подписи (подбирались как «soft» оттенки) */
.bb-cap-bg-default { background: rgba(148,163,184,.18); border-color: rgba(148,163,184,.35); } /* gray-400 */
.bb-cap-bg-neon    { background: rgba(55,246,225,.16);  border-color: rgba(55,246,225,.35);  }
.bb-cap-bg-violet  { background: rgba(196,181,253,.16); border-color: rgba(196,181,253,.35); }
.bb-cap-bg-amber   { background: rgba(251,191,36,.16);  border-color: rgba(251,191,36,.35);  }
.bb-cap-bg-emerald { background: rgba(52,211,153,.16);  border-color: rgba(52,211,153,.35);  }
.bb-cap-bg-rose    { background: rgba(253,164,175,.16); border-color: rgba(253,164,175,.35); }
.bb-cap-bg-sky     { background: rgba(125,211,252,.16); border-color: rgba(125,211,252,.35); }

/* ===== Видео: подпись под плеером (и ALT у изображений) ===== */
.bb-video-cap {
  text-align: center;
  color: #9ca3af; /* gray-400 */
  font-size: 12px;
  margin-top: .35rem;
}

/* ===== BB Links: безопасные цвета по белому списку ===== */
.bb-link { text-decoration: underline; transition: color .15s ease; }
.bb-link-default { color: #7dd3fc !important; } /* sky-300 */
.bb-link-neon    { color: #37f6e1 !important; }
.bb-link-violet  { color: #c4b5fd !important; }
.bb-link-amber   { color: #fbbf24 !important; }
.bb-link-emerald { color: #34d399 !important; }
.bb-link-rose    { color: #fda4af !important; }
.bb-link-sky     { color: #7dd3fc !important; }

/* ===== BB Color: общий цвет текста через [color=token]…[/color] ===== */
.bb-color { transition: color .15s ease; }
.bb-color-default { color: #e5e7eb !important; } /* gray-200 */
.bb-color-neon    { color: #37f6e1 !important; }
.bb-color-violet  { color: #c4b5fd !important; }
.bb-color-amber   { color: #fbbf24 !important; }
.bb-color-emerald { color: #34d399 !important; }
.bb-color-rose    { color: #fda4af !important; }
.bb-color-sky     { color: #7dd3fc !important; }

/* ===== Поповер описания ссылки (hover) — без кнопки и без внутренней прокрутки ===== */
.bb-link-popover {
  position: fixed;
  z-index: 70;
  max-width: min(360px, 90vw);
  background: rgba(15,20,26,1);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 0.75rem;
  box-shadow: 0 12px 40px -10px rgba(0,0,0,.45);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .12s ease, transform .12s ease;
  padding: 10px 12px;
}
.bb-link-popover.in { opacity: 1; transform: translateY(0); }
.bb-popover-body { color: #e5e7eb; font-size: 13px; line-height: 1.45; word-break: break-word; }
/* Указатель */
.bb-link-popover.bb-popover-top::after,
.bb-link-popover.bb-popover-bottom::after {
  content: ''; position: absolute; left: 16px; width: 10px; height: 10px;
  background: rgba(15,20,26,1);
  border-left: 1px solid rgba(255,255,255,.08);
  border-top: 1px solid rgba(255,255,255,.08);
  transform: rotate(225deg);
}
.bb-link-popover.bb-popover-top::after { bottom: -6px; }
.bb-link-popover.bb-popover-bottom::after { top: -6px; transform: rotate(45deg); }

/* ====== ЦИТАТЫ (улучшенный дизайн) ====== */
.bb-quote {
  position: relative;
  margin: .9rem 0;
  border-radius: 1rem;
  border: 1px solid rgba(148,163,184,.28);      /* gray-400/28 */
  background:
    radial-gradient(900px 300px at -10% -40%, rgba(55,246,225,.06), transparent 55%),
    radial-gradient(800px 300px at 120% 120%, rgba(124,58,237,.06), transparent 55%),
    rgba(3,7,18,.58);                            /* slate-950/58 */
  box-shadow:
    0 2px 0 rgba(255,255,255,.04) inset,
    0 18px 48px -24px rgba(0,0,0,.65);
  overflow: hidden;
  backdrop-filter: blur(6px);
}

.bb-quote-accent {
  position: absolute; left: 0; top: 0; bottom: 0; width: 5px;
  background: linear-gradient(180deg, #37f6e1 0%, #22d3ee 50%, #7dd3fc 100%); /* neon→cyan→sky */
  box-shadow: 0 0 16px #37f6e180, inset 0 0 1px rgba(255,255,255,.25);
}

.bb-quote-body {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .7rem;
  padding: 14px 16px 14px 18px;
  align-items: start;
}

.bb-quote-icon {
  display: inline-flex;
  width: 24px; height: 24px;
  color: #a5b4fc; /* indigo-300 */
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.35));
  opacity: .95;
}

.bb-quote-content { min-width: 0; }
.bb-quote-text {
  color: #e5e7eb; /* gray-200 */
  font-size: 15px; line-height: 1.6;
  word-break: break-word;
}
.bb-quote-by {
  margin-top: .4rem;
  font-size: 12px; color: #93a3b5; /* desaturated */
  text-align: right;
  letter-spacing: .01em;
}