/* Animacion estandar para todos los modales Bootstrap */
:root {
  --gf-modal-duration: 0.22s;
  --gf-modal-easing: cubic-bezier(0.2, 0.8, 0.2, 1);
  --gf-modal-header-padding-y: 0.85rem;
  --gf-modal-header-padding-x: 1rem;
  --gf-modal-title-size: 1.05rem;
  --gf-modal-title-weight: 700;
}

.modal.fade .modal-dialog {
  opacity: 0;
  transform: translateY(18px) scale(0.98);
  transition:
    transform var(--gf-modal-duration) var(--gf-modal-easing),
    opacity var(--gf-modal-duration) var(--gf-modal-easing);
}

.modal.show .modal-dialog {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.modal.fade .modal-content {
  transition: box-shadow var(--gf-modal-duration) ease;
}

.modal.show .modal-content {
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.22);
}

.modal-backdrop.fade {
  transition: opacity 0.18s ease;
}

.modal-backdrop.show {
  opacity: 0.45;
}

/* Estandar visual para cabeceras de modales */
.modal .modal-header {
  padding: var(--gf-modal-header-padding-y) var(--gf-modal-header-padding-x) !important;
  min-height: 58px;
  display: flex;
  align-items: center;
}

.modal .modal-title {
  font-size: var(--gf-modal-title-size) !important;
  font-weight: var(--gf-modal-title-weight) !important;
  line-height: 1.2;
  margin: 0;
}

.modal .modal-header .btn-close {
  font-size: 0.9rem;
}

/* Evita mezcla de efectos entre animate.css y Bootstrap modal */
.modal.animate__animated,
.modal .animate__animated {
  animation: none !important;
}

@media (prefers-reduced-motion: reduce) {
  .modal.fade .modal-dialog,
  .modal.fade .modal-content,
  .modal-backdrop.fade {
    transition: none !important;
    transform: none !important;
  }
}
