/*
   PVlab Modal — переопределения Bootstrap-модалок под glass-дизайн (фигма node 454:6583).

   Все стили scope'д через `#Modal`, чтобы не задеть другие modal'ки сторонних библиотек
   (например, select2-popover, datepicker и т. д.).

   Источник истины — Drugs/Create в Figma:
     • контейнер: 962px, radius 16, bg rgba(255,255,255,0.16) + blur 16.55, border rgba(229,233,235,0.43)
     • поля: высота 40, gradient bg, border rgba(166,166,166,0.28), radius 12, padding 11
     • лейблы: 16px Inter Semi-Bold (600), белые, gap 8 до поля
     • строки полей: gap 60px между колонками, 26px между строками
     • кнопка submit: bg #283b85, radius 12, иконка + текст Semi-Bold 14
*/

/* ── Overlay (затемнение фона) ────────────────────────────────────────────
   Bootstrap по умолчанию использует .modal-backdrop полупрозрачный чёрный.
   Усиливаем + добавляем blur — фон страницы за модалкой смягчается. */
.modal-backdrop.show {
  --bs-backdrop-opacity: 0.5;
  --bs-backdrop-bg: #000;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

/* ── Контейнер модалки ───────────────────────────────────────────────────── */

#Modal .modal-dialog {
  max-width: 962px;          /* фигма: точно 962 */
}

@media (max-width: 1024px) {
  #Modal .modal-dialog { max-width: calc(100vw - 32px); }
}

#Modal .modal-content {
  position: relative;       /* anchor для абсолютного крестика */
  background: rgba(255, 255, 255, 0.16);
  border: 1px solid rgba(229, 233, 235, 0.43);
  border-radius: 16px;
  backdrop-filter: blur(16.55px) saturate(180%);
  -webkit-backdrop-filter: blur(16.55px) saturate(180%);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.45),
              inset 0 1px 0 rgba(255, 255, 255, 0.22);
  color: var(--pvlab-text);
  padding: 26px 36px;
  overflow-x: hidden;       /* не overflow:hidden — Bootstrap modal должен скроллиться по Y */
  overflow-y: auto;
}

/* В light glass работает чуть иначе — фон страницы тоже светлый, поэтому
   модалка должна быть плотнее, чтобы не сливалась. */
:root:not([data-theme="dark"]) #Modal .modal-content {
  background: rgba(255, 255, 255, 0.85);
  border-color: rgba(15, 23, 42, 0.08);
  box-shadow: 0 24px 64px rgba(15, 23, 42, 0.18),
              inset 0 1px 0 rgba(255, 255, 255, 0.85);
  color: var(--pvlab-text);
}

/* ── Header модалки ──────────────────────────────────────────────────────── */

#Modal .modal-header {
  padding: 0;
  margin-bottom: 26px;          /* gap между заголовком и формой */
  border-bottom: none;
  align-items: center;
  /* Крестик вынут абсолютно (см. ниже) — header содержит только title. */
  padding-right: 40px;          /* резерв под крестик чтобы длинный title не залазил */
}

#Modal .modal-title {
  font-size: 24px;
  font-weight: 600;             /* Inter Semi-Bold */
  letter-spacing: -0.022em;     /* -0.528px на 24 */
  line-height: 1.1;
  color: var(--pvlab-text);
  margin: 0;
}

/* Кнопка «×» — абсолютно прижата к правому верхнему углу модалки.
   Дефолтная Bootstrap btn-close использует SVG bg-image — рисуем сами через
   mask-image, чтобы currentColor работал на обеих темах. */
#Modal .btn-close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 28px;
  height: 28px;
  padding: 0;
  margin: 0;
  opacity: 1;
  background: none;
  color: var(--pvlab-text);
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 6L6 18M6 6l12 12'/%3E%3C/svg%3E");
          mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 6L6 18M6 6l12 12'/%3E%3C/svg%3E");
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  background-color: currentColor;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  z-index: 2;                   /* поверх header'а */
  transition: background-color 180ms ease, transform 220ms ease, opacity 180ms ease;
}

#Modal .btn-close:hover {
  opacity: 0.7;
  transform: rotate(90deg);
}

#Modal .btn-close:focus-visible {
  outline: 2px solid var(--pvlab-accent);
  outline-offset: 2px;
  box-shadow: none;
}

/* ── Body модалки ────────────────────────────────────────────────────────── */

#Modal .modal-body {
  padding: 0;
  overflow-x: hidden;           /* поля никогда не вылезают по горизонтали */
}

/* Bootstrap row mb-3 → 1rem (16px). Фигма требует 26px между секциями. */
#Modal .modal-body .row {
  margin-bottom: 18px;
}

#Modal .modal-body .row:last-child,
#Modal .modal-body .row.no-gap-bottom {
  margin-bottom: 0;
}

/* Внутри row у Bootstrap отступы col → mb-3 на col добавляет 16. Уберём,
   т.к. row-gap уже даёт паддинг. */
#Modal .modal-body .row > [class*="col-"].mb-3 {
  margin-bottom: 0;
}

#Modal .modal-body .row {
  --bs-gutter-x: 32px;          /* gap между колонками. 60 из фигмы — слишком много для row
                                    с отрицательными margin'ами, контент уходит за края.
                                    32 даёт визуально похожий просвет без overflow. */
  --bs-gutter-y: 18px;
  margin-left: 0;               /* перебиваем Bootstrap negative margin -15px каждая сторона */
  margin-right: 0;
}

#Modal .modal-body .row > [class*="col-"] {
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left:  calc(var(--bs-gutter-x) * 0.5);
}

/* Первая/последняя колонка в ряду — без своего «бокового» паддинга, чтобы
   модалка идеально совпала по правому краю с position abs крестика. */
#Modal .modal-body .row > [class*="col-"]:first-child  { padding-left:  0; }
#Modal .modal-body .row > [class*="col-"]:last-child   { padding-right: 0; }

@media (max-width: 768px) {
  #Modal .modal-body .row { --bs-gutter-x: 18px; }
}

/* ── Лейблы ──────────────────────────────────────────────────────────────── */

#Modal .form-label {
  display: block;
  margin-bottom: 8px;
  font-size: 16px;
  font-weight: 600;             /* Inter Semi-Bold */
  letter-spacing: -0.022em;     /* -0.352px на 16 */
  line-height: 1.5;
  color: var(--pvlab-text);
}

/* ── Поля ввода ──────────────────────────────────────────────────────────── */

#Modal .form-control,
#Modal .form-select {
  height: 40px;
  padding: 0 11px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  color: var(--pvlab-text);
  background-image: linear-gradient(90deg, rgba(255, 255, 255, 0.22), rgba(255, 247, 247, 0.19));
  background-color: transparent;
  border: 1px solid rgba(166, 166, 166, 0.28);
  border-radius: 12px;
  box-shadow: none;
  transition: border-color 200ms ease, box-shadow 200ms ease, background 200ms ease;
}

/* Light тема — стекло мягче, плюс плейсхолдер виднее */
:root:not([data-theme="dark"]) #Modal .form-control,
:root:not([data-theme="dark"]) #Modal .form-select {
  background-image: linear-gradient(90deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.85));
  border-color: rgba(15, 23, 42, 0.12);
}

#Modal textarea.form-control {
  height: auto;
  min-height: 96px;
  padding: 10px 11px;
}

#Modal .form-control::placeholder,
#Modal .form-select::placeholder {
  color: rgba(255, 255, 255, 0.55);
}

:root:not([data-theme="dark"]) #Modal .form-control::placeholder,
:root:not([data-theme="dark"]) #Modal .form-select::placeholder {
  color: var(--pvlab-text-placeholder);
}

#Modal .form-control:hover,
#Modal .form-select:hover {
  border-color: rgba(166, 166, 166, 0.45);
}

#Modal .form-control:focus,
#Modal .form-select:focus {
  border-color: var(--pvlab-accent);
  box-shadow: 0 0 0 3px rgba(61, 167, 243, 0.18);
  background-image: linear-gradient(90deg, rgba(255, 255, 255, 0.28), rgba(255, 247, 247, 0.24));
}

:root:not([data-theme="dark"]) #Modal .form-control:focus,
:root:not([data-theme="dark"]) #Modal .form-select:focus {
  background-image: linear-gradient(90deg, #ffffff, #ffffff);
}

/* Невалидные поля (от unobtrusive validation). */
#Modal .form-control.input-validation-error,
#Modal .form-select.input-validation-error,
#Modal .is-invalid {
  border-color: var(--pvlab-danger);
  box-shadow: 0 0 0 3px rgba(197, 37, 58, 0.18);
}

/* ── select2 внутри модалки — выравниваем фон с .form-control ────────────
   Чтобы select2 НЕ был темнее соседних text-input'ов (.form-control), даём
   ему такой же gradient. Атрибут data-theme стоит на <html>, поэтому
   light/dark разделяем через `:root[data-theme="dark"]` / `:not([...])`.
   ВАЖНО: НЕ использовать `body.pvlab-app:not([data-theme="dark"])` —
   атрибута на body нет, :not срабатывает всегда → light перекрывает dark. */

/* ── DARK (по умолчанию для всех data-theme="dark" страниц) ─────────── */
:root[data-theme="dark"] #Modal .select2-container--bootstrap-5 .select2-selection {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.22), rgba(255, 247, 247, 0.19)) !important;
  border: 1px solid rgba(166, 166, 166, 0.28) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
}

/* ── LIGHT (когда data-theme отсутствует) ───────────────────────────── */
:root:not([data-theme="dark"]) #Modal .select2-container--bootstrap-5 .select2-selection {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.85)) !important;
  border: 1px solid rgba(15, 23, 42, 0.12) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
}

/* Размеры — общие для обеих тем. */
#Modal .select2-container--bootstrap-5 .select2-selection--single {
  height: 40px !important;
}

#Modal .select2-container--bootstrap-5 .select2-selection--multiple {
  min-height: 40px !important;
  height: auto !important;      /* multi-select растёт при множестве chip'ов */
  padding: 4px 6px !important;
}

#Modal .select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered {
  line-height: 38px !important;
  padding: 0 60px 0 14px !important;     /* 30 стрелка + 20 cross + buffer */
  color: var(--pvlab-text) !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

#Modal .select2-container--bootstrap-5 .select2-selection--single .select2-selection__arrow {
  height: 38px !important;
}

/* Placeholder в модальном select — светлее чем text-muted на странице. */
:root[data-theme="dark"] #Modal .select2-container--bootstrap-5 .select2-selection--single .select2-selection__placeholder {
  color: rgba(255, 255, 255, 0.7) !important;
  opacity: 1 !important;
}

:root:not([data-theme="dark"]) #Modal .select2-container--bootstrap-5 .select2-selection--single .select2-selection__placeholder {
  color: var(--pvlab-text-muted) !important;
  opacity: 1 !important;
}

#Modal .select2-container--bootstrap-5 .select2-selection__clear {
  background-color: transparent !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231a1a23' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 6L6 18M6 6l12 12'/%3E%3C/svg%3E") !important;
}

[data-theme="dark"] #Modal .select2-container--bootstrap-5 .select2-selection__clear {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 6L6 18M6 6l12 12'/%3E%3C/svg%3E") !important;
}

#Modal .select2-container--bootstrap-5.select2-container--focus .select2-selection,
#Modal .select2-container--bootstrap-5.select2-container--open .select2-selection {
  border-color: rgba(61, 167, 243, 0.55) !important;
  box-shadow: 0 0 0 3px rgba(61, 167, 243, 0.18) !important;
}

#Modal .text-danger {
  color: var(--pvlab-danger) !important;
  font-size: 12px;
  margin-top: 4px;
  display: block;
}

#Modal .field-validation-error {
  color: var(--pvlab-danger);
  font-size: 12px;
  margin-top: 4px;
  display: block;
}

/* validation summary */
#Modal .validation-summary-errors {
  color: var(--pvlab-danger);
  padding: 10px 14px;
  margin-bottom: 16px;
  background: rgba(197, 37, 58, 0.08);
  border: 1px solid rgba(197, 37, 58, 0.25);
  border-radius: 12px;
}

#Modal .validation-summary-errors ul {
  margin: 0;
  padding-left: 20px;
}

/* ── Checkbox / radio внутри модалки ───────────────────────────────────── */

#Modal .form-check-input {
  background-color: rgba(255, 255, 255, 0.07);
  border-color: rgba(166, 166, 166, 0.28);
  width: 18px;
  height: 18px;
  border-radius: 5px;
}

/* Radio — всегда круглый (form-check-input выше делает квадратным). */
#Modal .form-check-input[type="radio"] {
  border-radius: 50%;
}

#Modal .form-check-input:checked {
  background-color: var(--pvlab-accent);
  border-color: var(--pvlab-accent);
}

#Modal .form-check-input:focus {
  border-color: var(--pvlab-accent);
  box-shadow: 0 0 0 3px rgba(61, 167, 243, 0.18);
}

#Modal .form-check-label {
  color: var(--pvlab-text);
  font-size: 14px;
  margin-left: 6px;
}

/* ── Утилитарные цветные классы (.text-success/.text-danger) внутри модалки.
   Bootstrap'овский text-danger #dc3545 не темизируется под нашу палитру. */
#Modal .text-success { color: #15803d !important; }
#Modal .text-danger  { color: var(--pvlab-danger) !important; }
[data-theme="dark"] #Modal .text-success { color: #4ade80 !important; }
[data-theme="dark"] #Modal .text-danger  { color: #ff8a96 !important; }

/* Унифицированный заголовок для парных групп (например, «Может» / «Не может»). */
.pvlab-permission-group-label {
  display: block;
  margin: 0 0 10px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.006em;
}
.pvlab-permission-group-label--allow { color: #15803d; }
.pvlab-permission-group-label--deny  { color: var(--pvlab-danger); }
[data-theme="dark"] .pvlab-permission-group-label--allow { color: #4ade80; }
[data-theme="dark"] .pvlab-permission-group-label--deny  { color: #ff8a96; }

/* ── Footer (кнопки) ─────────────────────────────────────────────────────── */

#Modal .modal-footer {
  padding: 0;
  margin-top: 26px;
  border-top: none;
  gap: 12px;
  justify-content: flex-end;
}

/* Bootstrap btn — общая стилизация под наш дизайн. Перебивает все варианты:
   btn-success / btn-primary / btn-secondary могут переопределять цвета сверху.
   min-width гарантирует, что Cancel и Submit одинакового размера независимо
   от длины текста («Отмена» / «Сохранить» / «Добавить»). */
#Modal .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 20px;
  height: 40px;
  min-width: 120px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.006em;
  line-height: 1.5;
  border-radius: 12px;
  border: 1px solid transparent;
  user-select: none;
  transition: background-color 200ms ease, color 200ms ease, transform 200ms ease, box-shadow 200ms ease;
}

/* Сбрасываем Bootstrap :focus / :active outline и box-shadow — рисуем свои.
   Без этого при клике появлялась толстая «обрезанная» рамка (Bootstrap
   `--bs-btn-focus-box-shadow` через :focus-visible + наша border-radius
   дают визуальный артефакт «полу-обведённой» кнопки). */
#Modal .btn:focus,
#Modal .btn:focus-visible,
#Modal .btn:active,
#Modal .btn.active,
#Modal .btn:active:focus {
  outline: none !important;
  box-shadow: none !important;
}

#Modal .btn:focus-visible {
  box-shadow: 0 0 0 3px rgba(61, 167, 243, 0.32) !important;
}

#Modal .btn:active {
  transform: scale(0.98);    /* лёгкая press-анимация вместо bootstrap'овской цветовой инверсии */
}

/* Primary action (Сохранить / Создать / Добавить) — синий из фигмы.
   :active/:focus у Bootstrap'а пытается заливать btn-success в зелёный
   (default --bs-btn-active-bg для success) — перебиваем нашим синим
   через :active-селекторы ниже. */
#Modal .btn-success,
#Modal .btn-primary,
#Modal .btn-success:focus,
#Modal .btn-primary:focus,
#Modal .btn-success:active,
#Modal .btn-primary:active,
#Modal .btn-success.active,
#Modal .btn-primary.active {
  background-color: #283b85 !important;
  border-color: #283b85 !important;
  color: #ffffff !important;
}

#Modal .btn-success:hover,
#Modal .btn-primary:hover {
  background-color: #2e4a9e !important;
  border-color: #2e4a9e !important;
  color: #ffffff !important;
}

#Modal .btn-success:focus-visible,
#Modal .btn-primary:focus-visible {
  box-shadow: 0 0 0 3px rgba(40, 59, 133, 0.45) !important;
}

/* Cancel — ghost-кнопка на стекле. Все состояния явно сбрасываются, чтобы
   bootstrap'овский btn-secondary не заливал её серым. */
#Modal .btn-secondary,
#Modal .btn-secondary:focus,
#Modal .btn-secondary:active,
#Modal .btn-secondary.active {
  background-color: transparent !important;
  border-color: rgba(255, 255, 255, 0.28) !important;
  color: var(--pvlab-text) !important;
}

#Modal .btn-secondary:hover {
  background-color: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.42) !important;
  color: var(--pvlab-text) !important;
}

:root:not([data-theme="dark"]) #Modal .btn-secondary,
:root:not([data-theme="dark"]) #Modal .btn-secondary:focus,
:root:not([data-theme="dark"]) #Modal .btn-secondary:active {
  border-color: rgba(15, 23, 42, 0.15) !important;
}

:root:not([data-theme="dark"]) #Modal .btn-secondary:hover {
  background-color: rgba(15, 23, 42, 0.05) !important;
  border-color: rgba(15, 23, 42, 0.25) !important;
}

#Modal .btn-danger,
#Modal .btn-danger:focus,
#Modal .btn-danger:active,
#Modal .btn-danger.active {
  background-color: var(--pvlab-danger) !important;
  border-color: var(--pvlab-danger) !important;
  color: #ffffff !important;
}

#Modal .btn-danger:hover {
  filter: brightness(1.1);
  color: #ffffff !important;
}

/* Modal-footer от tag-helper'а: <div class="modal-footer mt-3 px-0 pb-0 pt-3 border-0">
   У нас своя единая стилизация — гасим лишние bootstrap-margins/paddings. */
#Modal .modal-footer.mt-3 { margin-top: 26px !important; }
#Modal .modal-footer.pt-3 { padding-top: 0 !important; }
#Modal .modal-footer.pb-0 { padding-bottom: 0 !important; }
#Modal .modal-footer.px-0 { padding-left: 0 !important; padding-right: 0 !important; }

/* ── Prompt-модалки (Delete / Restore / DeletePermanently) ────────────────
   У них тело — короткий текст в <p> + опциональный alert. Все Bootstrap-
   классы перетемизируем под glass. */

#Modal .modal-body p {
  margin: 0 0 12px;
  font-size: 15px;
  line-height: 1.5;
  color: var(--pvlab-text);
}

#Modal .modal-body p:last-child {
  margin-bottom: 0;
}

#Modal .modal-body p strong {
  font-weight: 600;
  color: var(--pvlab-text);
}

#Modal .text-muted {
  color: var(--pvlab-text-muted) !important;
}

#Modal .modal-body p.small,
#Modal .modal-body .small {
  font-size: 13px;
}

/* Bootstrap alert внутри модалки — превращаем в glass-уведомление. */
#Modal .alert {
  padding: 14px 16px;
  border-radius: 12px;
  border: 1px solid transparent;
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
}

#Modal .alert-danger {
  background: rgba(197, 37, 58, 0.12);
  border-color: rgba(197, 37, 58, 0.3);
  color: var(--pvlab-text);
}

[data-theme="dark"] #Modal .alert-danger {
  background: rgba(255, 107, 122, 0.12);
  border-color: rgba(255, 107, 122, 0.32);
}

#Modal .alert-danger strong {
  color: var(--pvlab-danger);
}

#Modal .alert-warning {
  background: rgba(202, 138, 4, 0.12);
  border-color: rgba(202, 138, 4, 0.3);
}

#Modal .alert-info {
  background: rgba(61, 167, 243, 0.12);
  border-color: rgba(61, 167, 243, 0.3);
}

#Modal .alert-success {
  background: rgba(34, 197, 94, 0.12);
  border-color: rgba(34, 197, 94, 0.3);
}

/* ── PVlab Popover (confirm / prompt) ────────────────────────────────────
   Лёгкий popover-«пузырь» рядом с кнопкой-триггером (см. pvlab-popover.js).
   Заменяет нативные window.confirm/prompt — те системные, не темизируются,
   блокируют main thread. Стиль «чёрное стекло», как у tooltip / flatpickr. */
.pvlab-popover {
  position: fixed;
  z-index: 1250;                    /* над модалкой Bootstrap (1055) и tooltip (1200) */
  min-width: 240px;
  max-width: 360px;
  padding: 14px;
  background: rgba(20, 22, 30, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 12px;
  backdrop-filter: blur(14px) saturate(160%);
  -webkit-backdrop-filter: blur(14px) saturate(160%);
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.55);
  color: #ffffff;
  font-size: 14px;
  line-height: 1.4;
  animation: pvlab-popover-in 160ms ease-out;
}

@keyframes pvlab-popover-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0);    }
}

.pvlab-popover__body {
  margin-bottom: 12px;
  color: #ffffff;
}

.pvlab-popover__label {
  display: block;
  margin-bottom: 6px;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.7);
}

.pvlab-popover__input {
  width: 100%;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 8px;
  color: #ffffff;
  font-size: 14px;
  font-family: inherit;
  outline: none;
  transition: border-color 160ms ease, background-color 160ms ease;
}

.pvlab-popover__input::placeholder {
  color: rgba(255, 255, 255, 0.4);
}

.pvlab-popover__input:focus {
  border-color: var(--pvlab-accent);
  background: rgba(255, 255, 255, 0.08);
}

.pvlab-popover__error {
  margin-top: 6px;
  font-size: 12px;
  color: #ff8a96;
}

.pvlab-popover__actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

.pvlab-popover__btn {
  padding: 6px 14px;
  height: 32px;
  font-size: 13px;
  font-weight: 500;
  font-family: inherit;
  border: 1px solid transparent;
  border-radius: 8px;
  cursor: pointer;
  user-select: none;
  transition: background-color 140ms ease, color 140ms ease, transform 140ms ease;
}

.pvlab-popover__btn:focus {
  outline: none;
}

.pvlab-popover__btn:focus-visible {
  outline: 2px solid var(--pvlab-accent);
  outline-offset: 2px;
}

.pvlab-popover__btn:active {
  transform: scale(0.97);
}

.pvlab-popover__btn--ghost {
  background: transparent;
  border-color: rgba(255, 255, 255, 0.18);
  color: rgba(255, 255, 255, 0.85);
}

.pvlab-popover__btn--ghost:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
}

.pvlab-popover__btn--primary {
  background: var(--pvlab-accent);
  color: #ffffff;
}

.pvlab-popover__btn--primary:hover {
  filter: brightness(1.1);
}

.pvlab-popover__btn--danger {
  background: var(--pvlab-danger);
  color: #ffffff;
}

.pvlab-popover__btn--danger:hover {
  filter: brightness(1.1);
}

/* ── Spinner внутри модалки ──────────────────────────────────────────────── */

#Modal .spinner-border.text-primary {
  color: var(--pvlab-accent) !important;
}

/* ── Constructor таблицы (TablePresets/_Constructor) ──────────────────────
   Большая модалка: табы пресетов + список колонок + footer с reset/cancel/save.
   Стилизуем все Bootstrap-классы (nav-tabs, list-group, btn-outline-*, badge). */

/* Табы пресетов: bg-страницы, активный — заливка accent, на hover — мягкий glow.
   При большом количестве пресетов — горизонтальный скролл вместо обёртки
   на новую строку (Bootstrap default flex-wrap: wrap → у нас nowrap + scroll). */
#Modal .nav-tabs {
  border-bottom: 1px solid var(--pvlab-divider);
  margin-bottom: 16px;
  gap: 4px;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
  scrollbar-color: var(--pvlab-scrollbar-thumb, rgba(255, 255, 255, 0.18)) transparent;
}

/* Webkit-скроллбар тонкий, без углов — под общий стиль scrollbar'ов таблицы. */
#Modal .nav-tabs::-webkit-scrollbar {
  height: 6px;
}
#Modal .nav-tabs::-webkit-scrollbar-track {
  background: transparent;
}
#Modal .nav-tabs::-webkit-scrollbar-thumb {
  background: var(--pvlab-scrollbar-thumb, rgba(255, 255, 255, 0.18));
  border-radius: 4px;
}

#Modal .nav-tabs .nav-item {
  margin-bottom: -1px;
  flex-shrink: 0;                  /* табы не сжимаются — лучше скролл, чем обрезанный текст */
}

#Modal .nav-tabs .nav-link {
  padding: 8px 14px;
  font-size: 14px;
  font-weight: 500;
  color: var(--pvlab-text-muted);
  background: transparent;
  border: 1px solid transparent;
  border-bottom: 2px solid transparent;
  border-radius: 10px 10px 0 0;
  white-space: nowrap;             /* название пресета — в одну строку, без переноса */
  transition: color 160ms ease, background-color 160ms ease, border-color 160ms ease;
  cursor: pointer;
}

#Modal .nav-tabs .nav-link:hover:not(.active) {
  color: var(--pvlab-text);
  background: var(--pvlab-row-hover);
}

#Modal .nav-tabs .nav-link.active {
  color: var(--pvlab-text);
  background: transparent;
  border-color: transparent;
  border-bottom-color: var(--pvlab-accent);
}

#Modal .nav-tabs .nav-link.text-success {
  color: var(--pvlab-accent) !important;
  font-weight: 500;
}

/* Заголовок активного таба + операции над ним (Сделать активным / Переименовать / Удалить). */
#Modal .modal-body > form > .d-flex.align-items-center {
  margin-bottom: 14px;
}

#Modal .modal-body > form > .d-flex.align-items-center strong {
  font-size: 16px;
  font-weight: 600;
}

/* Bootstrap badge внутри модалки — наш pvlab-style. */
#Modal .badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.4;
  border-radius: 999px;
  white-space: nowrap;
}

#Modal .badge.bg-success {
  background: rgba(34, 197, 94, 0.15) !important;
  color: #15803d !important;
}

[data-theme="dark"] #Modal .badge.bg-success {
  background: rgba(34, 197, 94, 0.18) !important;
  color: #4ade80 !important;
}

/* Список колонок (drag-reorder + checkbox + width). */
#Modal .list-group {
  background: transparent;
  border: 1px solid var(--pvlab-divider);
  border-radius: 12px;
  overflow: hidden;
  padding: 0;
}

#Modal .list-group-item {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--pvlab-divider);
  color: var(--pvlab-text);
  padding: 10px 14px;
  font-size: 14px;
  transition: background-color 160ms ease;
}

#Modal .list-group-item:last-child {
  border-bottom: none;
}

#Modal .list-group-item:hover {
  background: var(--pvlab-row-hover);
}

/* drag-handle иконка — приглушённая по дефолту, ярче при hover row'а. */
#Modal .constructor-drag-handle {
  font-size: 18px;
  line-height: 1;
  color: var(--pvlab-text-muted);
  user-select: none;
  cursor: grab;
  transition: color 160ms ease;
}

#Modal .list-group-item:hover .constructor-drag-handle {
  color: var(--pvlab-text);
}

#Modal .constructor-drag-handle:active {
  cursor: grabbing;
}

/* SortableJS ghost — placeholder, который остаётся под курсором при drag. */
#Modal .list-group-item.bg-light {
  background: var(--pvlab-row-selected) !important;
  opacity: 0.6;
}

/* Маленький width-input в строке колонки — компактный glass. */
#Modal .form-control.form-control-sm {
  height: 32px;
  padding: 0 10px;
  font-size: 13px;
  border-radius: 8px;
}

/* ── Outline-варианты Bootstrap-кнопок (для actions над пресетом) ───────
   В Bootstrap btn-outline-* — прозрачный фон + цветной border. Темизируем. */
#Modal .btn.btn-sm {
  height: 32px;
  min-width: 0;                  /* перебиваем общий 120px — sm-кнопки могут быть короче */
  padding: 0 12px;
  font-size: 13px;
  border-radius: 8px;
}

#Modal .btn-outline-success {
  background: transparent;
  border-color: rgba(34, 197, 94, 0.45);
  color: #4ade80;
}

#Modal .btn-outline-success:hover {
  background: rgba(34, 197, 94, 0.15);
  border-color: #4ade80;
  color: #4ade80;
}

:root:not([data-theme="dark"]) #Modal .btn-outline-success {
  color: #15803d;
  border-color: rgba(21, 128, 61, 0.5);
}

:root:not([data-theme="dark"]) #Modal .btn-outline-success:hover {
  background: rgba(21, 128, 61, 0.12);
  color: #15803d;
}

#Modal .btn-outline-secondary {
  background: transparent;
  border-color: rgba(255, 255, 255, 0.22);
  color: var(--pvlab-text-muted);
}

#Modal .btn-outline-secondary:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.35);
  color: var(--pvlab-text);
}

:root:not([data-theme="dark"]) #Modal .btn-outline-secondary {
  border-color: rgba(15, 23, 42, 0.18);
  color: var(--pvlab-text-muted);
}

:root:not([data-theme="dark"]) #Modal .btn-outline-secondary:hover {
  background: rgba(15, 23, 42, 0.05);
  border-color: rgba(15, 23, 42, 0.32);
  color: var(--pvlab-text);
}

#Modal .btn-outline-danger {
  background: transparent;
  border-color: rgba(255, 107, 122, 0.45);
  color: #ff8a96;
}

#Modal .btn-outline-danger:hover {
  background: rgba(255, 107, 122, 0.15);
  border-color: #ff8a96;
  color: #ff8a96;
}

:root:not([data-theme="dark"]) #Modal .btn-outline-danger {
  color: var(--pvlab-danger);
  border-color: rgba(197, 37, 58, 0.45);
}

:root:not([data-theme="dark"]) #Modal .btn-outline-danger:hover {
  background: rgba(197, 37, 58, 0.1);
  color: var(--pvlab-danger);
}

#Modal .btn-outline-warning {
  background: transparent;
  border-color: rgba(250, 204, 21, 0.45);
  color: #facc15;
}

#Modal .btn-outline-warning:hover {
  background: rgba(250, 204, 21, 0.15);
  border-color: #facc15;
  color: #facc15;
}

:root:not([data-theme="dark"]) #Modal .btn-outline-warning {
  color: #854d0e;
  border-color: rgba(202, 138, 4, 0.45);
}

:root:not([data-theme="dark"]) #Modal .btn-outline-warning:hover {
  background: rgba(202, 138, 4, 0.12);
  color: #854d0e;
}

/* ── Иконка календаря на alt-input от flatpickr ───────────────────────────
   flatpickr заменяет оригинальный <input type="date"> на видимый text-input
   (alt-input), а оригинал скрывает. У text-input нет нативного calendar-picker
   indicator — рисуем SVG справа через background-image.

   Базовый стиль input.pvlab-date-input — для использования НА СТРАНИЦЕ
   (фильтры таблиц, формы вне модалки). В модалке overrides ниже. */
input.pvlab-date-input {
  height: 36px;
  padding: 0 38px 0 12px !important;
  font-size: 14px;
  color: var(--pvlab-text);
  background-color: var(--pvlab-input-bg);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231a1a23' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 11px center;
  background-size: 18px 18px;
  border: 1px solid var(--pvlab-input-border);
  border-radius: 10px;
  outline: none;
  cursor: pointer;
  transition: background-color 200ms ease, border-color 200ms ease;
}

input.pvlab-date-input:hover  { background-color: var(--pvlab-input-bg-hover); }
input.pvlab-date-input:focus  { background-color: var(--pvlab-input-bg-focus); border-color: var(--pvlab-accent); }

/* Placeholder «ДД.ММ.ГГГГ» — темизированный, не browser-default серый. */
input.pvlab-date-input::placeholder {
  color: var(--pvlab-text-placeholder);
  opacity: 1;          /* Firefox по дефолту понижает opacity placeholder'а */
}

[data-theme="dark"] input.pvlab-date-input {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");
}

/* Внутри модалки — multi-layer background чтобы совпадать с .form-control gradient. */
#Modal input.pvlab-date-input {
  height: 40px;
  border-radius: 12px;
  border-color: rgba(166, 166, 166, 0.28);
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231a1a23' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E"),
    linear-gradient(90deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.85)) !important;
  background-color: transparent !important;
  background-repeat: no-repeat, no-repeat !important;
  background-position: right 11px center, 0 0 !important;
  background-size: 18px 18px, auto !important;
}

[data-theme="dark"] #Modal input.pvlab-date-input {
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E"),
    linear-gradient(90deg, rgba(255, 255, 255, 0.22), rgba(255, 247, 247, 0.19)) !important;
}

/* ── flatpickr под «чёрное стекло» ────────────────────────────────────────
   flatpickr заменяет нативный browser-popup своим HTML — мы его стилизуем
   полностью под PVlab glass. Каждый элемент: контейнер, header (стрелки
   месяца + селектор года), grid weekdays/days, текущая выбранная дата —
   получает «тёмное стекло» с blur'ом и тонкими белыми контурами.

   ВАЖНО: popup ВСЕГДА тёмный (одинаков в light и dark) — для контраста
   стрелки внутри (year-spinner и т.п.) ВСЕГДА белые. */
.flatpickr-calendar {
  background: rgba(20, 22, 30, 0.92) !important;
  border: 1px solid rgba(255, 255, 255, 0.10) !important;
  border-radius: 14px !important;
  backdrop-filter: blur(18px) saturate(160%);
  -webkit-backdrop-filter: blur(18px) saturate(160%);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.45) !important;
  color: #ffffff !important;
  padding: 10px !important;          /* симметричный со всех сторон — раньше асимметрия */
  /* Фиксированная ширина: 7 дней × 38px + горизонтальный padding 10×2 = 286.
     Чуть округлили вверх, чтобы дни помещались без обрезки. */
  width: 296px !important;
  min-width: 0 !important;
  z-index: var(--pvlab-z-tooltip, 1200) !important;
}

/* В light — тоже «чёрное стекло» (как и tooltip — единый design language). */
:root:not([data-theme="dark"]) .flatpickr-calendar {
  background: rgba(15, 23, 42, 0.94) !important;
}

/* Стрелка-указатель над/под календарём (треугольник указывающий на input).
   arrowTop — popup ПОД input'ом, треугольник смотрит ВВЕРХ (border-bottom).
   arrowBottom — popup НАД input'ом, треугольник смотрит ВНИЗ (border-top).
   Раньше я применял ОБА border-color ко всем 4 псевдоэлементам — получался
   ромб «песочные часы». Теперь разделено по направлениям. */
.flatpickr-calendar.arrowTop::before {
  border-bottom-color: rgba(255, 255, 255, 0.10) !important;
}
.flatpickr-calendar.arrowTop::after {
  border-bottom-color: rgba(20, 22, 30, 0.92) !important;
}
.flatpickr-calendar.arrowBottom::before {
  border-top-color: rgba(255, 255, 255, 0.10) !important;
}
.flatpickr-calendar.arrowBottom::after {
  border-top-color: rgba(20, 22, 30, 0.92) !important;
}

/* ── Header: стрелки переключения месяца + название месяца/год ──────────
   Высоту увеличиваем — кнопки prev/next были 26x26 и казались мелкими.
   Теперь 40x40 (с padding 11), идеально кликабельно. */
.flatpickr-months {
  padding: 4px 0 10px !important;
  align-items: center !important;
  display: flex !important;
}

.flatpickr-month {
  color: #ffffff !important;
  height: 40px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
}

.flatpickr-current-month {
  padding: 0 !important;
  position: static !important;
  font-size: 15px;
  font-weight: 500;
  color: #ffffff;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px;
  height: 40px !important;
  left: auto !important;
  transform: none !important;
  width: auto !important;
}

.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year {
  color: #ffffff !important;
  background: transparent !important;
  border: none !important;
  font-weight: 500;
  font-size: 14px;
  padding: 4px 6px !important;
  border-radius: 6px;
}

/* Year input — компактная ширина под 4 цифры + чуть-чуть на padding/spinner.
   5ch ≈ 37px в Inter 14 — хватает на «2025» и оставляет место под наши
   кастомные ↑↓ стрелки сбоку, не отъедая лишнюю ширину у header'а. */
.flatpickr-current-month input.cur-year {
  width: 5ch !important;
  min-width: 0 !important;
  padding: 4px 2px !important;
  text-align: center;
  -moz-appearance: textfield;      /* убираем системные spinner'ы у number-input */
  appearance: textfield;
}

.flatpickr-current-month input.cur-year::-webkit-outer-spin-button,
.flatpickr-current-month input.cur-year::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Hover'а на year input НЕТ — пользователь не хочет подсветки.
   Селектор сразу для month-dropdown даёт hover, а для year-input — нет. */
.flatpickr-current-month .flatpickr-monthDropdown-months {
  transition: background-color 160ms ease;
}

.flatpickr-current-month .flatpickr-monthDropdown-months:hover {
  background: rgba(255, 255, 255, 0.08) !important;
}

.flatpickr-current-month .flatpickr-monthDropdown-months option {
  background: #1A2030;
  color: #ffffff;
}

.flatpickr-monthDropdown-months {
  appearance: none;
  -webkit-appearance: none;
}

/* ── Year spinner (стрелки ↑↓ рядом с числом года) ─────────────────────
   flatpickr рендерит .numInputWrapper с двумя span'ами .arrowUp/.arrowDown,
   каждый — треугольник через border-bottom/top-color. По дефолту цвет —
   серый rgba(57,57,57,0.6), невидим на тёмном popup'е. Принудительно белый
   ВСЕГДА (popup тёмный в обеих темах). */
.numInputWrapper {
  width: auto !important;
}

.numInputWrapper span {
  border: none !important;
  background: transparent !important;
  opacity: 0.7;
  transition: background-color 160ms ease, opacity 160ms ease;
}

.numInputWrapper span:hover {
  background: rgba(255, 255, 255, 0.1) !important;
  opacity: 1;
}

.numInputWrapper span.arrowUp::after {
  border-left: 4px solid transparent !important;
  border-right: 4px solid transparent !important;
  border-bottom: 5px solid rgba(255, 255, 255, 0.85) !important;
  top: 33% !important;
}

.numInputWrapper span.arrowDown::after {
  border-left: 4px solid transparent !important;
  border-right: 4px solid transparent !important;
  border-top: 5px solid rgba(255, 255, 255, 0.85) !important;
  top: 40% !important;
}

.numInputWrapper:hover span.arrowUp::after,
.numInputWrapper span.arrowUp:hover::after {
  border-bottom-color: #ffffff !important;
}

.numInputWrapper:hover span.arrowDown::after,
.numInputWrapper span.arrowDown:hover::after {
  border-top-color: #ffffff !important;
}

/* Стрелки prev/next — крупные квадратные кнопки 40x40 (фигурно flatpickr
   их позиционирует absolute, перебиваем на static-flex и убираем absolute). */
.flatpickr-prev-month,
.flatpickr-next-month {
  position: static !important;
  fill: rgba(255, 255, 255, 0.75) !important;
  padding: 0 !important;
  width: 40px !important;
  height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 10px;
  flex-shrink: 0;
  transition: background-color 160ms ease, fill 160ms ease;
}

.flatpickr-prev-month:hover,
.flatpickr-next-month:hover {
  background: rgba(255, 255, 255, 0.1) !important;
  fill: #ffffff !important;
}

.flatpickr-prev-month svg,
.flatpickr-next-month svg {
  width: 18px !important;
  height: 18px !important;
  fill: inherit !important;
}

/* ── Weekdays (Пн Вт Ср …) ───────────────────────────────────────────── */
.flatpickr-weekdays {
  background: transparent !important;
}

.flatpickr-weekday {
  color: rgba(255, 255, 255, 0.55) !important;
  font-weight: 400 !important;
  font-size: 12px !important;
  background: transparent !important;
}

/* ── Days grid ───────────────────────────────────────────────────────── */
.flatpickr-days {
  padding: 0 !important;
  width: auto !important;
  min-width: 0 !important;
}

.dayContainer {
  padding: 0 !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
}

.flatpickr-rContainer,
.flatpickr-weekdaycontainer,
.flatpickr-weekdays {
  width: auto !important;
}

.flatpickr-day {
  color: rgba(255, 255, 255, 0.85) !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  border-radius: 8px !important;
  font-weight: 400;
  font-size: 13px;
  transition: background-color 160ms ease, color 160ms ease;
  max-width: 38px;
  height: 36px;
  line-height: 34px;
}

.flatpickr-day:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
}

/* Сегодня — кольцо акцента. */
.flatpickr-day.today {
  border-color: var(--pvlab-accent, #3da7f3) !important;
  color: #ffffff !important;
}

.flatpickr-day.today:hover {
  background: rgba(61, 167, 243, 0.18) !important;
  color: #ffffff !important;
}

/* Выбранная дата — заливка акцента. */
.flatpickr-day.selected,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected.startRange,
.flatpickr-day.selected.endRange {
  background: var(--pvlab-accent, #3da7f3) !important;
  border-color: var(--pvlab-accent, #3da7f3) !important;
  color: #ffffff !important;
}

/* Дни предыдущего/следующего месяца — приглушённые. */
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
  color: rgba(255, 255, 255, 0.25) !important;
}

.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover {
  color: rgba(255, 255, 255, 0.5) !important;
}

/* Disabled и flatpickr-disabled. */
.flatpickr-day.disabled,
.flatpickr-day.disabled:hover,
.flatpickr-day.flatpickr-disabled {
  color: rgba(255, 255, 255, 0.15) !important;
  background: transparent !important;
  cursor: not-allowed;
}

/* ── Alt-input (визуальный input, которым flatpickr заменяет оригинал) ─
   Унаследует все наши стили .form-control автоматически (flatpickr копирует
   classes), но clipboard-icon индикатор браузера на нём не виден. */
input.flatpickr-input {
  /* Оригинальный input скрыт flatpickr'ом — стилизация не нужна. */
}

/* color-scheme — нативный механизм. На html-элементе говорит браузеру,
   какие system-colors использовать. Дефолт light, override на dark.
   Влияет на: nativе scrollbars, native <select> dropdown, system colors.
   <input type="date"> popup мы заменили на flatpickr — этой переменной
   управляются ОСТАЛЬНЫЕ native UI элементы. */
:root           { color-scheme: light; }
[data-theme="dark"] { color-scheme: dark; }

/* ── Адаптив ─────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  #Modal .modal-content { padding: 20px 18px; border-radius: 14px; }
  #Modal .modal-title   { font-size: 20px; }
  #Modal .btn-close     { top: 14px; right: 14px; }
}
