/* toast.css — ephemeral notifications */
/* Extracted from toast.js for better maintainability */

#toast-region {
  position: fixed;
  bottom: var(--toast-offset, 20px);
  right: var(--toast-offset, 20px);
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-end;
  z-index: 9999;
  pointer-events: none;
}

#toast-region .toast {
  pointer-events: auto;
  background: var(--studio);
  color: var(--surface);
  padding: 10px 18px;
  border-radius: var(--rad-pill);
  font-size: 13.5px;
  font-weight: 600;
  box-shadow: var(--shadow-md);
  animation: toast-in 220ms var(--transition-base);
  cursor: pointer;
  max-width: min(360px, 80vw);
  transition: transform var(--t-fast) var(--ease-out), opacity var(--t-fast) var(--ease-out);
}

#toast-region .toast:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px oklch(0.19 0.018 72 / 0.12);
}

#toast-region .toast:focus-visible {
  outline: 2px solid var(--surface);
  outline-offset: -3px;
}

#toast-region .toast.toast--success {
  background: var(--success);
}

#toast-region .toast.toast--success:hover {
  background: oklch(0.5 0.13 145);
}

#toast-region .toast.toast--danger {
  background: var(--danger);
}

#toast-region .toast.toast--danger:hover {
  background: oklch(0.5 0.17 28);
}

#toast-region .toast.toast--leaving {
  animation: toast-out 220ms var(--transition-base) forwards;
}

@keyframes toast-in {
  from { transform: translateX(20px); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}

@keyframes toast-out {
  to { transform: translateX(20px); opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  #toast-region .toast,
  #toast-region .toast.toast--leaving {
    animation: none;
    transition: opacity 0ms;
  }
}
