/* ===== Overlays (modal & sheet): центрирование, непрозрачные панели, анимации, блюр ===== */

/* Общий контейнер */
.rp-overlay { /* класс в разметке; видимость управляется JS классом .open */
  /* ничего, кроме позиционирования в blade; поведение ниже через дочерние селекторы */
}

/* Бэкдроп: затемнение + сильный блюр, плавный fade/blur */
.rp-overlay__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(3, 7, 18, 0.55); /* тёмное затемнение */
  backdrop-filter: blur(0px);
  opacity: 0;
  transition: opacity .28s ease, backdrop-filter .28s ease;
  will-change: opacity, backdrop-filter;
}

/* Контейнер модалки для идеального центрирования */
.rp-overlay__center {
  position: relative;
  z-index: 1;
}

/* Панель модалки: непрозрачная, плавное появление (fade + translate/scale) */
.rp-overlay__panel {
  transform: translateY(12px) scale(.98);
  opacity: 0;
  transition: transform .30s cubic-bezier(.2,.7,.2,1), opacity .30s ease;
  will-change: transform, opacity;
}

/* Панель шита: выезд снизу */
.rp-sheet__panel {
  transform: translateY(100%);
  transition: transform .34s cubic-bezier(.2,.8,.2,1);
  will-change: transform;
}

/* Открытое состояние (добавляется JS классом .open на root .rp-overlay) */
.rp-overlay.open .rp-overlay__backdrop {
  opacity: 1;
  backdrop-filter: blur(14px);
}

/* Модалка вошла */
.rp-overlay.open .rp-overlay__panel {
  transform: translateY(0) scale(1);
  opacity: 1;
}

/* Шит въехал */
.rp-overlay.open .rp-sheet__panel {
  transform: translateY(0);
}

/* Непрозрачная панель (поверх neo-card): глухой фон, без прозрачности/градиента */
.rp-opaque {
  background-color: #0f141a; /* тот же тон, что и theme.surface.100 */
  background-image: none !important;
  backdrop-filter: none !important;
  /* можно усилить границу и тень для читаемости */
  border-color: rgba(255,255,255,.10) !important;
  box-shadow: 0 10px 40px -10px rgba(0,0,0,.6);
}

/* Адаптация для клавиатуры/фокуса внутри */
.rp-opaque :focus-visible {
  outline: 2px solid rgba(55, 246, 225, .45);
  outline-offset: 2px;
}

/* Утилита: внешний контейнер bottom-sheet */
.rp-sheet__outer {
  position: absolute;
  z-index: 1;
}

/* Небольшой «snap» эффект при открытии модалки на больших экранах */
@media (min-width: 768px) {
  .rp-overlay__panel {
    transform: translateY(16px) scale(.975);
  }
  .rp-overlay.open .rp-overlay__panel {
    transform: translateY(0) scale(1);
  }
}
