/*
 * Crouton - Toast Notifications
 *
 * Themeable via CSS custom properties:
 *   --crouton-notice-bg, --crouton-notice-border, --crouton-notice-color
 *   --crouton-alert-bg, --crouton-alert-border, --crouton-alert-color
 */

.crouton-container {
  position: fixed;
  top: 1rem;
  right: 1rem;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  pointer-events: none;
  max-width: 24rem;
  width: 100%;
}

.crouton-toast {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  border-radius: 8px;
  font-size: 0.875rem;
  line-height: 1.4;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  pointer-events: auto;
  transform: translateX(calc(100% + 1rem));
  opacity: 0;
  transition: transform 0.3s ease, opacity 0.3s ease;
  will-change: transform, opacity;
}

.crouton-toast--visible {
  transform: translateX(0);
  opacity: 1;
}

.crouton-toast--dismissing {
  transform: translateX(calc(100% + 1rem));
  opacity: 0;
}

.crouton-toast--notice {
  --crouton-notice-bg: #F0FDF4;
  --crouton-notice-border: #BBF7D0;
  --crouton-notice-color: #15803D;
  background-color: var(--crouton-notice-bg);
  border: 1px solid var(--crouton-notice-border);
  color: var(--crouton-notice-color);
}

.crouton-toast--alert {
  --crouton-alert-bg: #FEF2F2;
  --crouton-alert-border: #FECACA;
  --crouton-alert-color: #DC2626;
  background-color: var(--crouton-alert-bg);
  border: 1px solid var(--crouton-alert-border);
  color: var(--crouton-alert-color);
}

.crouton-message {
  flex: 1;
  min-width: 0;
}

.crouton-dismiss {
  appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.125rem;
  margin-left: auto;
  flex-shrink: 0;
  color: inherit;
  opacity: 0.5;
  transition: opacity 0.15s ease;
  line-height: 1;
  font-size: 1.125rem;
}

.crouton-dismiss:hover {
  opacity: 1;
}

/* Dark mode (system preference) */
@media (prefers-color-scheme: dark) {
  .crouton-toast--notice {
    --crouton-notice-bg: #14532D;
    --crouton-notice-border: #166534;
    --crouton-notice-color: #86EFAC;
  }

  .crouton-toast--alert {
    --crouton-alert-bg: #451A1A;
    --crouton-alert-border: #7F1D1D;
    --crouton-alert-color: #FCA5A5;
  }

  .crouton-toast {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .crouton-toast {
    transition: none;
    transform: none;
  }

  .crouton-toast--visible {
    transform: none;
    opacity: 1;
  }

  .crouton-toast--dismissing {
    transform: none;
    opacity: 0;
    transition: opacity 0.15s ease;
  }
}
