/* modals.css */

.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  background: rgba(44, 38, 64, 0.45);
  animation: fn-fade-in var(--transition-fast) ease both;
}
.modal-overlay.modal--out { opacity: 0; transition: opacity var(--transition-fast); }

.modal {
  width: 100%;
  max-width: 460px;
  background: var(--clr-surface);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  max-height: 90vh;
  overflow-y: auto;
  animation: fn-rise var(--transition-normal) ease both;
}

.modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5) var(--space-6) 0;
}
.modal__title { font-size: var(--text-xl); }
.modal__close { font-size: var(--text-lg); padding: var(--space-2); }
.modal__body { padding: var(--space-4) var(--space-6) var(--space-6); }

.voice-btn--on {
  background: var(--clr-primary);
  color: #fff;
  animation: fn-pulse 1.2s ease-in-out infinite;
}
