/* ==========================================================
   Toast Component
   ========================================================== */

.toast-container {
  position: fixed;
  top: var(--space-lg);
  left: var(--space-lg);
  right: var(--space-lg);
  z-index: 9000;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  pointer-events: none;
}

.toast {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-sm);
  font-size: var(--font-sm);
  font-weight: var(--weight-medium);
  box-shadow: var(--shadow-md);
  pointer-events: auto;
  animation: toast-slide-in 250ms ease forwards,
    toast-slide-out 250ms ease 2750ms forwards;
}

.toast-success {
  background: var(--tg-theme-button-color);
  color: var(--tg-theme-button-text-color);
}

.toast-error {
  background: var(--tg-theme-destructive-text-color);
  color: var(--tg-theme-button-text-color);
}

/* --- Animations --- */

@keyframes toast-slide-in {
  from {
    opacity: 0;
    transform: translateY(-16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes toast-slide-out {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 0;
    transform: translateY(-16px);
  }
}
