/* ================================================================
   SONNER TOAST - VANILLA JS VERSION
   Replica exacta del CSS de Sonner (https://sonner.emilkowal.ski/)
   Adaptado para usar con Font Awesome en lugar de Lucide
   ================================================================ */

/* Colores del Design System de Monyma */
:root {
  --bg-primary: #09080b;
  --bg-secondary: #131215;
  --border-primary: #1e1e20;
  --text-primary: #E4E6E7;
  --text-secondary: #9ca3af;

  --success: #10b981;
  --success-bg: #1a3d2e;

  --danger: #ef4444;
  --danger-bg: #3d1a1a;

  --warning: #f59e0b;
  --warning-bg: #3d2e1a;

  --blue: #2746e3;
  --blue-bg: #192455;
}

/* Variables de dirección (LTR) */
html[dir='ltr'],
[data-sonner-toaster][dir='ltr'] {
  --toast-icon-margin-start: -3px;
  --toast-icon-margin-end: 4px;
  --toast-svg-margin-start: -1px;
  --toast-svg-margin-end: 0px;
  --toast-button-margin-start: auto;
  --toast-button-margin-end: 0;
  --toast-close-button-start: 0;
  --toast-close-button-end: unset;
  --toast-close-button-transform: translate(-35%, -35%);
}

/* Variables de dirección (RTL) */
html[dir='rtl'],
[data-sonner-toaster][dir='rtl'] {
  --toast-icon-margin-start: 4px;
  --toast-icon-margin-end: -3px;
  --toast-svg-margin-start: 0px;
  --toast-svg-margin-end: -1px;
  --toast-button-margin-start: 0;
  --toast-button-margin-end: auto;
  --toast-close-button-start: unset;
  --toast-close-button-end: 0;
  --toast-close-button-transform: translate(35%, -35%);
}

/* Contenedor principal de toasts */
[data-sonner-toaster] {
  position: fixed;
  width: var(--width);
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, Arial,
    Noto Sans, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;
  --gray1: hsl(0, 0%, 99%);
  --gray2: hsl(0, 0%, 97.3%);
  --gray3: hsl(0, 0%, 95.1%);
  --gray4: hsl(0, 0%, 93%);
  --gray5: hsl(0, 0%, 90.9%);
  --gray6: hsl(0, 0%, 88.7%);
  --gray7: hsl(0, 0%, 85.8%);
  --gray8: hsl(0, 0%, 78%);
  --gray9: hsl(0, 0%, 56.1%);
  --gray10: hsl(0, 0%, 52.3%);
  --gray11: hsl(0, 0%, 43.5%);
  --gray12: hsl(0, 0%, 9%);
  --border-radius: 8px;
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  list-style: none;
  outline: none;
  z-index: 999999999;
  transition: transform 400ms ease;
  pointer-events: none;
}

/* Posicionamiento horizontal */
[data-sonner-toaster][data-x-position='right'] {
  right: max(var(--offset), env(safe-area-inset-right));
}

[data-sonner-toaster][data-x-position='left'] {
  left: max(var(--offset), env(safe-area-inset-left));
}

[data-sonner-toaster][data-x-position='center'] {
  left: 50%;
  transform: translateX(-50%);
}

/* Posicionamiento vertical */
[data-sonner-toaster][data-y-position='top'] {
  top: max(var(--offset), env(safe-area-inset-top));
}

[data-sonner-toaster][data-y-position='bottom'] {
  bottom: max(var(--offset), env(safe-area-inset-bottom));
}

/* Toast individual */
[data-sonner-toast] {
  --y: translateY(100%);
  --lift-amount: calc(var(--lift) * var(--gap));
  z-index: var(--z-index);
  position: absolute;
  bottom: 0;
  width: 100%;
  opacity: 0;
  transform: var(--y);
  touch-action: none;
  transition: transform 300ms ease-out, opacity 300ms ease-out, height 300ms ease-out, box-shadow 200ms;
  box-sizing: border-box;
  outline: none;
  overflow-wrap: anywhere;
  pointer-events: auto;
}

/* Toast con estilos */
[data-sonner-toast][data-styled='true'] {
  padding: 16px;
  background: var(--normal-bg);
  border: 1px solid var(--normal-border);
  color: var(--normal-text);
  border-radius: var(--border-radius);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
  width: var(--width);
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Focus visible */
[data-sonner-toast]:focus-visible {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5), 0 0 0 2px rgba(0, 0, 0, 0.2);
}

/* Posición Y del toast */
[data-sonner-toast][data-y-position='top'] {
  --y: translateY(-100%);
  --lift: 1;
  --lift-amount: calc(1 * var(--gap));
}

[data-sonner-toast][data-y-position='bottom'] {
  --y: translateY(100%);
  --lift: -1;
  --lift-amount: calc(var(--lift) * var(--gap));
}

/* Toast visible */
[data-sonner-toast][data-mounted='true'] {
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* Toast frontal - el más reciente */
[data-sonner-toast][data-front='true'] {
  z-index: 10;
}

/* Apilamiento en 3D - toasts de atrás */
[data-sonner-toast][data-front='false'] {
  z-index: calc(10 - var(--toasts-before));
}

[data-sonner-toast][data-mounted='true'][data-front='false'] {
  --scale: calc(1 - (var(--toasts-before) * 0.05));
  --offset-y: calc(var(--toasts-before) * 20px);
  transform: translateY(calc(var(--offset-y) * -1)) scale(var(--scale)) !important;
  transform-origin: bottom center;
}

[data-sonner-toast][data-expanded='false'][data-front='false'][data-styled='true'] {
  cursor: pointer;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

/* Hover en contenedor -> expandir toasts verticalmente */
/* Card 1 (frontal) NO se mueve */
[data-sonner-toaster]:hover [data-sonner-toast][data-front='true'] {
  transform: translateY(0) scale(1) !important;
  transition: all 300ms ease-out;
}

/* Cards 2 y 3 (de atrás) se expanden verticalmente */
[data-sonner-toaster]:hover [data-sonner-toast] {
  position: relative !important;
  bottom: auto !important;
  transform: scale(1) translateY(0) !important;
  transition: all 300ms ease-out;
}

/* Espaciado entre cards cuando están expandidas */
[data-sonner-toaster]:hover [data-sonner-toast]:not(:last-child) {
  margin-bottom: var(--gap);
}

/* Al quitar hover, reset margin-bottom con transición */
[data-sonner-toast]:not(:last-child) {
  margin-bottom: 0;
}

[data-sonner-toaster]:hover [data-sonner-toast][data-expanded='false'][data-front='false'] {
  opacity: 1;
}

[data-sonner-toast] > * {
  transition: opacity 300ms ease-out, transform 300ms ease-out;
}

[data-sonner-toast][data-expanded='false'][data-front='false'][data-styled='true'] > * {
  opacity: 0;
}

[data-sonner-toaster]:hover [data-sonner-toast][data-expanded='false'][data-front='false'][data-styled='true'] > * {
  opacity: 1;
  transition-delay: 100ms;
}

/* Descripción */
[data-sonner-toast][data-styled='true'] [data-description] {
  font-weight: 400;
  line-height: 1.4;
  color: var(--gray-400); /* Gris más contrastado del Design System */
}

[data-rich-colors='true'][data-sonner-toast][data-styled='true'] [data-description] {
  color: var(--gray-400); /* Mantener gris contrastado en rich colors */
}

/* Título */
[data-sonner-toast][data-styled='true'] [data-title] {
  font-weight: 500;
  line-height: 1.5;
  color: inherit;
}

/* Icono */
[data-sonner-toast][data-styled='true'] [data-icon] {
  display: flex;
  height: 16px;
  width: 16px;
  position: relative;
  justify-content: flex-start;
  align-items: center;
  flex-shrink: 0;
  margin-left: var(--toast-icon-margin-start);
  margin-right: var(--toast-icon-margin-end);
}

[data-sonner-toast][data-styled='true'] [data-icon] > * {
  flex-shrink: 0;
}

[data-sonner-toast][data-styled='true'] [data-icon] i {
  margin-left: var(--toast-svg-margin-start);
  margin-right: var(--toast-svg-margin-end);
  font-size: 16px;
}

/* Contenido */
[data-sonner-toast][data-styled='true'] [data-content] {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}

/* Botón de acción */
[data-sonner-toast][data-styled='true'] [data-button] {
  border-radius: 4px;
  padding-left: 8px;
  padding-right: 8px;
  height: 24px;
  font-size: 12px;
  color: var(--normal-bg);
  background: var(--normal-text);
  margin-left: var(--toast-button-margin-start);
  margin-right: var(--toast-button-margin-end);
  border: none;
  font-weight: 500;
  cursor: pointer;
  outline: none;
  display: flex;
  align-items: center;
  flex-shrink: 0;
  transition: opacity 400ms, box-shadow 200ms;
}

[data-sonner-toast][data-styled='true'] [data-button]:hover {
  opacity: 0.8;
}

[data-sonner-toast][data-styled='true'] [data-button]:focus-visible {
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.4);
}

/* Botón de cerrar */
[data-sonner-toast] [data-close-button] {
  position: absolute;
  left: var(--toast-close-button-start);
  right: var(--toast-close-button-end);
  top: 0;
  height: 20px;
  width: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0;
  background: var(--gray1);
  color: var(--gray12);
  border: 1px solid var(--gray4);
  transform: var(--toast-close-button-transform);
  border-radius: 50%;
  cursor: pointer;
  z-index: 1;
  transition: opacity 100ms, background 200ms, border-color 200ms;
}

[data-sonner-toast] [data-close-button]:focus-visible {
  box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.1), 0 0 0 2px rgba(0, 0, 0, 0.2);
}

/* ================================================================
   TEMA OSCURO (DARK MODE ONLY)
   Usando variables del Design System de Monyma
   ================================================================ */
[data-sonner-toaster] {
  --normal-bg: var(--bg-secondary);
  --normal-border: var(--border-primary);
  --normal-text: var(--text-primary);

  --success-bg: var(--success-bg);
  --success-border: var(--success);
  --success-text: var(--success);

  --info-bg: var(--blue-bg);
  --info-border: var(--blue);
  --info-text: var(--blue);

  --warning-bg: var(--warning-bg);
  --warning-border: var(--warning);
  --warning-text: var(--warning);

  --error-bg: var(--danger-bg);
  --error-border: var(--danger);
  --error-text: var(--danger);
}

[data-sonner-toaster] [data-description] {
  color: var(--gray-400); /* Gris clarito del Design System */
}

/* ================================================================
   COLORES RICOS (RICH COLORS)
   Diseño: card normal + icono de color + gradiente spotlight sutil
   ================================================================ */
[data-sonner-toaster][data-rich-colors='true'] [data-sonner-toast][data-type='success'] {
  background: radial-gradient(circle at top left, #1a1e1c, var(--bg-secondary) 60%);
  border-color: var(--border-primary);
  color: var(--text-primary);
}

[data-sonner-toaster][data-rich-colors='true'] [data-sonner-toast][data-type='success'] [data-icon] {
  color: var(--success);
}

[data-sonner-toaster][data-rich-colors='true'] [data-sonner-toast][data-type='success'] [data-description] {
  color: var(--gray-400);
}

[data-sonner-toaster][data-rich-colors='true'] [data-sonner-toast][data-type='info'] {
  background: radial-gradient(circle at top left, #16171f, var(--bg-secondary) 60%);
  border-color: var(--border-primary);
  color: var(--text-primary);
}

[data-sonner-toaster][data-rich-colors='true'] [data-sonner-toast][data-type='info'] [data-icon] {
  color: var(--blue);
}

[data-sonner-toaster][data-rich-colors='true'] [data-sonner-toast][data-type='info'] [data-description] {
  color: var(--gray-400);
}

[data-sonner-toaster][data-rich-colors='true'] [data-sonner-toast][data-type='warning'] {
  background: radial-gradient(circle at top left, #1f1a16, var(--bg-secondary) 60%);
  border-color: var(--border-primary);
  color: var(--text-primary);
}

[data-sonner-toaster][data-rich-colors='true'] [data-sonner-toast][data-type='warning'] [data-icon] {
  color: var(--warning);
}

[data-sonner-toaster][data-rich-colors='true'] [data-sonner-toast][data-type='warning'] [data-description] {
  color: var(--gray-400);
}

[data-sonner-toaster][data-rich-colors='true'] [data-sonner-toast][data-type='error'] {
  background: radial-gradient(circle at top left, #1f1616, var(--bg-secondary) 60%);
  border-color: var(--border-primary);
  color: var(--text-primary);
}

[data-sonner-toaster][data-rich-colors='true'] [data-sonner-toast][data-type='error'] [data-icon] {
  color: var(--danger);
}

[data-sonner-toaster][data-rich-colors='true'] [data-sonner-toast][data-type='error'] [data-description] {
  color: var(--gray-400);
}

/* ================================================================
   ANIMACIONES
   ================================================================ */
@keyframes sonner-fade-in {
  0% {
    opacity: 0;
    transform: scale(0.8);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes sonner-fade-out {
  0% {
    opacity: 1;
    transform: scale(1);
  }
  100% {
    opacity: 0;
    transform: scale(0.8);
  }
}

@keyframes sonner-spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

/* Animación para toast que aparece */
[data-sonner-toast][data-mounted='true'] {
  animation: sonner-fade-in 400ms ease forwards;
}

/* Animación para toast que desaparece */
[data-sonner-toast][data-removed='true'] {
  animation: sonner-fade-out 300ms ease forwards;
  opacity: 0;
  transform: translateY(-20px) scale(0.95);
}

/* Loader spinner para promesas */
[data-sonner-toast][data-promise='true'] [data-icon] > i.fa-spinner {
  animation: sonner-spin 1s linear infinite;
}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 600px) {
  [data-sonner-toaster] {
    --width: 356px !important;
  }

  [data-sonner-toaster][data-x-position='left'],
  [data-sonner-toaster][data-x-position='right'] {
    left: var(--offset) !important;
    right: var(--offset) !important;
    transform: none !important;
  }
}

@media (hover: none) and (pointer: coarse) {
  [data-sonner-toaster][data-lifted='true'] {
    transform: none;
  }
}
