/* 1. Definición de Variables CSS (Custom Properties) */
:root {
  /* Tema Claro (por defecto) */
  --font-size-base: 1rem; /* 16px por defecto */
  --font-size-h1: 2.25rem; /* text-4xl */
  --bg-main: rgba(174, 112, 151, 0.532); /* En modo claro, el fondo del main es transparente para ver las estrellas */
  --frosted-glass-bg: rgba(161, 78, 139, 0.103); /* Vidrio esmerilado claro, más translúcido */
  --frosted-glass-border: rgba(255, 255, 255, 0.6); /* Borde sutil para el efecto de vidrio */
  --text-primary: #0f172a; /* Texto principal oscuro (un poco más suave que negro puro) */
  --text-secondary: #334155; /* Aumentamos el contraste para el texto secundario */
  --input-bg: #ffffff;
  --input-text: #041201;
  --border-color: #d1d5db;
  /* Variables para el nuevo panel de administración plano */
  --admin-panel-bg: #ac7fc3; /* gray-50 */
  --admin-panel-border: #e3e7ed; /* gray-200 */
  --frosted-glass-shadow: 0 4px 20px rgba(0, 0, 0, 0.5); /* Sombra suave */
  /* Variables para botones primarios */
  --btn-primary-bg: #2563eb; /* blue-600 - Un azul más oscuro para mayor contraste */
  --btn-primary-text: #ffffff;
  --btn-primary-hover-bg: #1d4ed8; /* blue-700 */
  --ring-color: #93c5fd; /* blue-300 */
  /* Variables para el footer */
  --footer-bg: #1e40af; /* blue-800 */
  --footer-text: #dbeafe; /* blue-100 */
}

html[data-theme="dark"] {
  /* Tema Oscuro (se activa con el atributo data-theme) */
  --bg-main: rgba(67, 46, 96, 0.703); /* Un fondo principal oscuro y semi-transparente */
  --frosted-glass-bg: rgba(19, 9, 42, 0.444); /* Vidrio esmerilado oscuro, un poco más claro */
  --frosted-glass-border: rgba(255, 255, 255, 0.418); /* Borde sutil para el modo oscuro */
  --text-primary: #f1f5f9; /* Texto principal claro (casi blanco) */
  --text-secondary: #cbd5e1; /* Aumentamos el contraste para el texto secundario */
  --input-bg: #1f2937;
  --input-text: #f9fafb; /* Texto claro para inputs, para que sea visible en fondos oscuros */
  --border-color: #b59ba9;
  /* Variables para el nuevo panel de administración plano en modo oscuro */
  --admin-panel-bg: #1f2937; /* gray-800 */
  --admin-panel-border: #4b5563; /* gray-600 */
  --frosted-glass-shadow: 0 4px 30px rgba(0, 0, 0, 0.5); /* Sombra más pronunciada en oscuro */
  /* Variables para botones primarios en modo oscuro */
  --btn-primary-bg: #60a5fa; /* blue-400 - Un azul más claro para mayor contraste en oscuro */
  --btn-primary-text: #ffffff;
  --btn-primary-hover-bg: #3b82f6; /* blue-500 */
  --ring-color: #60a5fa; /* blue-400 */
  /* Variables para el footer en modo oscuro */
  --footer-bg: #111827; /* gray-900 */
  --footer-text: #9ca3af; /* gray-400 */
}

/* Sobrescribimos las variables de fuente si el usuario prefiere letra grande */
html[data-font-size="large"] {
  --font-size-base: 1.5rem; /* 18px, un 12.5% más grande */
  --font-size-h1: 2.5rem;
}

*{
  box-sizing: border-box;
  position: relative;
  min-width: 0;
  margin: 0;
  padding: 0;
}

/* Animación para el fondo de estrellas */
@keyframes erratic-move {
  0% {
    background-position: 45% 45%;
  }
  20% {
    background-position: 55% 45%;
  }
  40% {
    background-position: 55% 55%;
  }
  60% {
    background-position: 45% 55%;
  }
  80% {
    background-position: 40% 50%;
  }
  100% {
    background-position: 45% 45%;
  }
}

/* Animación para el reflejo de luz en el vidrio */
@keyframes shimmer {
  from {
    transform: translateX(-150%) skewX(-25deg); /* Empieza fuera de la pantalla a la izquierda */
  }
  to {
    transform: translateX(230%) skewX(-25deg); /* Termina fuera de la pantalla a la derecha */
  }
}

/* Animación para que los botones del carrusel aparezcan con retraso */
@keyframes fade-in-buttons {
  to {
    opacity: 1;
  }
}

body{
  font-size: var(--font-size-base); /* Aplicamos el tamaño de fuente base */
  min-height: 100dvh;
  overflow-x: hidden;
  background-image: url('/global/images/fondo_stars.webp');
  background-attachment: fixed;
  background-size: 113%; /* Hacemos un "zoom-in" para tener margen de movimiento */
  /* Añadimos position relative y isolation para que el pseudo-elemento ::before funcione correctamente */
  position: relative;
  isolation: isolate;
  /* Aplicamos la animación de scroll infinito */
  animation: erratic-move 60s ease-in-out infinite;
}

/*
 * Creamos la capa de lluvia global usando un pseudo-elemento en el body.
 * Esto la coloca por encima del fondo de estrellas pero por debajo de todo el contenido.
*/
body::before {
  content: "";
  position: fixed; /* Fijo para que cubra toda la pantalla, incluso al hacer scroll */
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("/global/images/raindrops-animate.svg");
  background-size: cover; /* Estira el SVG para cubrir toda la pantalla sin distorsión */
  background-repeat: no-repeat; /* Evita que el fondo se repita */
  opacity: 0.85; /* Aumentamos la opacidad para que las estrellas sutiles sean visibles */
  z-index: -1; /* Lo pone detrás de todo el contenido del body */
  pointer-events: none; /* La capa no debe ser clickeable */
}
h1, h2, h3, h4 {
  text-wrap: balance;
}
p {
  text-wrap: pretty;
}

/* 2. Aplicamos el fondo base al contenedor principal del layout */
main {
  /* Solución "Sticky Footer" con Flexbox */
  display: flex;
  flex-direction: column;
  min-height: 100vh; /* Ocupa al menos toda la altura de la pantalla */

  background-color: var(--bg-main);
  color: var(--text-primary);
  transition: background-color 0.5s ease-in-out, color 0.5s ease-in-out;
}
/* Clase de utilidad para usar el color de texto secundario del tema */
.text-theme-secondary {
  color: var(--text-secondary);
}

/* 3. Adaptamos tus estilos existentes para que usen las variables */
.frosted-glass {
  position: relative; /* Necesario para posicionar el reflejo dentro del contenedor */
  overflow: hidden;   /* Oculta el reflejo cuando está fuera de los bordes */
  background: var(--frosted-glass-bg);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px); /* Compatibilidad con Safari (iOS) */
  border-radius: 25px;
  border-top: 1px solid var(--frosted-glass-border); /* Borde solo en la parte superior */
  border-left: 1px solid var(--frosted-glass-border); /* Borde solo en la parte izquierda */
  box-shadow: var(--frosted-glass-shadow);
  text-wrap: balance;
}

/* 4. Estilo plano para paneles de administración */
.admin-panel {
  /* Usa las nuevas variables para un fondo sólido y un borde simple */
  background-color: var(--admin-panel-bg);
  border: 1px solid var(--admin-panel-border);
  /* Mantenemos el borde redondeado para una apariencia suave */
  border-radius: 16px; /* Un poco menos redondeado que el frosted-glass */
  /* No hay backdrop-filter, ni sombras, ni animaciones. Es limpio y rápido. */
  padding: 1.5rem; /* Un buen padding interno */
  transition: background-color 0.5s ease-in-out, border-color 0.5s ease-in-out;
}

/* El pseudo-elemento que crea el reflejo de luz */
.frosted-glass::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 60%;
  height: 100%;
  background: linear-gradient(
    to right,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.238) 50%, /* Un blanco muy sutil y translúcido */
    rgba(255, 255, 255, 0) 100%
  );
  /* Estado inicial: posiciona el reflejo fuera de la pantalla para evitar el "flash" al cargar. */
  transform: translateX(-150%) skewX(-25deg);
  z-index: 1; /* Lo ponemos por encima del contenido del div */
  pointer-events: none; /* Hacemos que el reflejo no sea interactuable (no bloquea clicks/texto) */
  animation: shimmer 13s ease-in-out 6s infinite; /* Se ejecuta por 6s, espera 4s, y repite */
}
/* Estilo para tarjetas con efecto de brillo ambiental (Ambient Glow) */
.image-glow-card {
  position: relative; /* Necesario para el pseudo-elemento ::before */
  background: rgba(0, 0, 0, 0.591); /* Fondo oscuro semi-transparente para la tarjeta */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(5px);
  border-radius: 1rem; /* 16px */
  border: 1px solid rgba(227, 221, 221, 0.58);
  color: rgb(255, 255, 255);
  transition: transform 0.3s ease;
  z-index: 1; /* Asegura que la tarjeta esté por encima del brillo */
  padding: 1rem;
}

.image-glow-card:hover {
  transform: translateY(-5px);
}
/* El pseudo-elemento que crea el brillo */
.image-glow-card::before {
  content: "";
  position: absolute;
  /* Lo hacemos un poco más grande que la tarjeta y lo ponemos detrás */
  inset: -15px;
  z-index: -1; /* Detrás de la tarjeta */
  /* Usamos la variable CSS para poner la misma imagen que la tarjeta */
  background-image: var(--bg-image);
  background-size: cover;
  background-position: center;
  /* La magia del efecto: desenfoque y saturación */
  filter: blur(20px) saturate(1.5);
  opacity: 0.3; /* Hacemos el brillo un poco sutil */
}
/* Estilos base para los campos de entrada de texto y áreas de texto */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="search"],
textarea,
select { /* Aprovechamos y añadimos 'select' también */
  width: 90%;
  background-color: var(--input-bg);
  color: var(--input-text);
  border: 1px solid var(--border-color);
}
.super {
  background-color: blue;
  color: pink;
  padding: 10px 20px;
  border: none;
  border-radius: 5px;
}
.styled:hover {
  background-color: rgba(255, 0, 0, 1);
}
.container{
  min-height: 50vh;
  justify-content: center;
  align-items: center;
}

.rainfall {
  background-color: transparent;
  background-image: url("/global/images/raindrops-animate.svg");
}

.buttons{
  display: flex;
  flex-direction: row;
}

.btn{
  padding: 10px 30px;
  font-size: 1.5rem;
  position: relative;
  margin: 0px;
  /* Hacemos que los botones tengan la misma altura que la imagen del carrusel (h-80 -> 20rem) */
  height: 20rem;
  /* Hacemos los botones invisibles por defecto para evitar clicks antes de la hidratación */
  opacity: 0;
  /* Animación para que aparezcan con un retraso de 1.5s, dando tiempo a que el JS cargue */
  animation: fade-in-buttons 1.5s ease-in-out 2.5s forwards;
}
.btn-1{
  background: #039BE5;
  color: #FFFFFF;
  border-radius: 50px;
  transition: transform 1.9s ease;
}
.btn-1::after, .btn-1::before{
  content: "";
  position: absolute;
  opacity: 0.3;
  background: #039BE5;
  border-radius: inherit;
  width: 100%;
  height: 100%;
  left: 0;
  bottom: 0;
  z-index: -1;
  transition: transform 1.9s ease;
}
.btn-1:hover{
  transform: translate(-15px);
}
.btn-1:hover::after{
  transform: translate(8px);
}
.btn-1:hover::before{
  transform: translate(15px);
}
.btn-3{
  background: #039BE5;
  color: #FFFFFF;
  border-radius: 50px;
  transition: transform 1.9s ease;
}
.btn-3::after, .btn-3::before{
  content: "";
  position: absolute;
  opacity: 0.3;
  background: #039BE5;
  border-radius: inherit;
  width: 100%;
  height: 100%;
  left: 0;
  bottom: 0;
  z-index: -1;
  transition: transform 1.9s ease;
}
.btn-3:hover{
  transform: translate(15px);
}                                                                                                                                            
.btn-3:hover::after{
  transform: translate(-8px);
}                                                                                                                                            
.btn-3:hover::before{
  transform: translate(-15px);
}

/* Botón primario reutilizable */
.btn-primary {
  background-color: var(--btn-primary-bg);
  color: var(--btn-primary-text);
  font-weight: 500; /* font-medium */
  font-size: 0.875rem; /* text-sm */
  padding: 0.625rem 1.25rem; /* py-2.5 px-5 */
  border-radius: 0.5rem; /* rounded-lg */
  text-align: center;
  border: none;
  cursor: pointer;
  transition: background-color 0.2s ease-in-out;
}

.btn-primary:hover {
  background-color: var(--btn-primary-hover-bg);
}

.btn-primary:focus-visible {
  outline: none;
  box-shadow: 0 0 0 6px var(--ring-color);
}

/* Estilos para el Footer */
.site-footer {
  background-color: var(--footer-bg);
  color: var(--footer-text);
  padding: 1rem 0; /* py-4 */
  text-align: center;
  width: 100%;
  transition: background-color 0.5s ease-in-out, color 0.5s ease-in-out;
  /* --- ¡AQUÍ ESTÁ EL EFECTO "CERAMIC GLASS" INVERTIDO PARA EL FOOTER! --- */
  box-shadow:
    /* 1. Sombra principal que se proyecta hacia ARRIBA. */
    0 -5px 15px rgba(0, 0, 0, 0.3),
    /* 2. Sombra interna en el borde SUPERIOR para el efecto biselado. */
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    /* 3. Línea de luz superior para definir el borde esmaltado. */
    0 -1px 0 rgba(255, 255, 255, 0.05);
}

/* Estilos para el Nav, para que sea uniforme con el Footer */
.site-nav {
  background-color: var(--footer-bg);
  color: var(--footer-text);
  transition: background-color 0.5s ease-in-out, color 0.5s ease-in-out;
  /* Hacemos que la navegación se quede fija en la parte superior */
  position: sticky;
  top: 0;
  z-index: 50; /* Un valor alto para que esté por encima de otro contenido */

  /* --- ¡AQUÍ ESTÁ EL EFECTO "CERAMIC GLASS"! --- */
  /* Usamos una combinación de sombras para crear un borde con profundidad y brillo. */
  box-shadow:
    /* 1. Sombra principal para dar profundidad y separación. */
    0 5px 15px rgba(0, 0, 0, 0.3),
    /* 2. Sombra interna sutil para simular un borde biselado que atrapa la luz. */
    inset 0 -1px 0 rgba(255, 255, 255, 0.1),
    /* 3. Línea de luz inferior para definir el borde esmaltado. */
    0 1px 0 rgba(255, 255, 255, 0.05);
}

/* Nuevas clases de estado para las tarjetas de producto en el admin */
.card-in-trash {
  /* Fondo rojo semi-transparente para indicar peligro/papelera */
  background-color: rgba(155, 42, 40, 0.7) !important;
}

.card-not-visible {
  /* Opacidad reducida para indicar que no está online */
  opacity: 0.6;
}

/*
 * Nueva clase de utilidad para forzar el ajuste de línea en palabras largas.
 * Ideal para URLs, hashes o cualquier texto sin espacios que pueda desbordar su contenedor.
*/
.break-words {
  overflow-wrap: break-word; /* Propiedad estándar */
  word-break: break-word; /* Alternativa/fallback para mayor compatibilidad */
}

/* --- ESTILOS EXCLUSIVOS PARA IMPRESIÓN --- */
@media print {
  /* Oculta cualquier elemento con esta clase al imprimir.
     Lo usamos en el Nav, Footer y los textos de ayuda. */
  .print\:hidden {
    display: none !important;
  }

  /* Forzamos la cuadrícula de QRs a tener 4 columnas en el papel. */
  #qr-container {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }

  /* Estilizamos cada tarjeta QR para la impresión. */
  .qr-card {
    border: 2px dashed black !important; /* Borde punteado negro, ¡muy importante! */
    -webkit-print-color-adjust: exact !important; /* Fuerza al navegador a imprimir colores y bordes como se ven. */
    print-color-adjust: exact !important;
  }
}

/* --- Animación para los enlaces del Nav --- */
.nav-link {
  position: relative; /* Necesario para el pseudo-elemento */
  text-decoration: none; /* Quitamos el subrayado por defecto */
  color: inherit; /* Hereda el color del texto del Nav */
}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: -2px; /* Posición justo debajo del texto */
  left: 50%; /* Empieza en el centro */
  width: 0; /* Empieza sin ancho */
  height: 2px; /* Grosor del subrayado */
  background-color: currentColor; /* Usa el color del texto actual */
  transition: all 0.3s ease-in-out; /* Animación suave */
  transform: translateX(-50%); /* Mantiene el centrado mientras crece */
}

.nav-link:hover::after {
  width: 100%; /* Al pasar el cursor, el ancho crece al 100% */
}
