/* ============================================================
   Toast — notification messages
   ============================================================ */

.toast {
  position: fixed;
  bottom: calc(var(--nav-height) + var(--space-4) + var(--safe-bottom));
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  opacity: 0;
  z-index: var(--z-toast);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  box-shadow: var(--shadow-lg);
  pointer-events: none;
  transition:
    opacity var(--duration-normal) var(--ease-out),
    transform var(--duration-normal) var(--ease-spring);
  max-width: calc(100vw - var(--space-8));
  text-align: center;
}

.toast--visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.toast--success {
  background-color: var(--color-success);
  color: white;
}

.toast--error {
  background-color: var(--color-danger);
  color: white;
}

.toast--info {
  background-color: var(--surface-elevated);
  color: var(--text-primary);
  border: 1px solid var(--border-default);
}
