    /* Theme chooser modal */
#theme-chooser {
  position: fixed;
  inset: 0;
  display: flex; /* Cambiado de none a flex para permitir transición */
  align-items: center;
  justify-content: center;
  z-index: 99999;
  background: linear-gradient(180deg, rgba(0,0,0,0.45), rgba(0,0,0,0.6));
  
  /* --- Efecto Suave de Fondo --- */
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s;
  backdrop-filter: blur(4px); /* Opcional: añade un desenfoque al fondo */
}

/* Cuando se muestra el modal */
#theme-chooser[aria-hidden="false"] {
  opacity: 1;
  visibility: visible;
}

#theme-chooser .chooser {
  width: 94%;
  max-width: 720px;
  font-family: var(--brand-font);
  background: var(--panel);
  color: var(--text);
  border-radius: 12px;
  padding: 18px;
  box-shadow: 0 30px 60px rgba(0,0,0,0.6);
  display: flex;
  gap: 12px;
  flex-direction: column;
  align-items: stretch;

  /* --- Efecto Suave de la Caja --- */
  transform: scale(0.95) translateY(10px);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Animación interna cuando el padre se activa */
#theme-chooser[aria-hidden="false"] .chooser {
  transform: scale(1) translateY(0);
}

.theme-options { display: flex; gap: 12px; }

.theme-card {
  flex: 1;
  padding: 14px;
  border-radius: 10px;
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 8px;
  cursor: pointer;
  outline: none;
  /* Transición suave para el hover y selección */
  transition: all 0.3s ease;
}

.theme-card h4 { margin: 0; font-size: 1rem; }
.theme-card p { margin: 0; color: var(--muted); font-size: 0.9rem; }

/* Efecto al seleccionar */
.theme-card.selected {
  background: var(--active-bg); /* Opcional: un color sutil de fondo */
  border-color: var(--accent); /* Opcional: resaltar el borde */
  box-shadow: 0 10px 30px rgba(0,0,0,0.4);
  transform: translateY(-4px);
}



@media (max-width: 600px) {
  /* 1. Ajuste del contenedor principal (Modal) */
  #theme-chooser .chooser {
    width: 75%;           /* Aprovecha mejor el ancho en pantallas pequeñas */
    padding: 16px;
    gap: 10px;
    max-height: 90vh;    /* Asegura que no se corte en móviles bajos */
    overflow-y: auto;     /* Activa scroll si hay muchos temas */
  }

  /* 2. Cambio de Flex horizontal a Grid adaptable */
  .theme-options {
    display: grid;
    grid-template-columns: 1fr; /* Una tarjeta por fila para máxima legibilidad */
    gap: 10px;
  }

  /* 3. Optimización de la tarjeta para interacción táctil */
  .theme-card {
    flex-direction: row;  /* Ponemos el título y texto al lado del icono/color */
    align-items: center;
    padding: 12px 16px;
    gap: 15px;
    min-height: 60px;     /* Área de toque (touch target) más cómoda */
  }

  .theme-card h4 {
    font-size: 0.95rem;
    margin-bottom: 2px;
  }

  .theme-card p {
    font-size: 0.8rem;
  }

  /* 4. Ajuste del efecto de selección en móvil */
  .theme-card.selected {
    transform: scale(0.98); /* En móvil, un ligero hundimiento se siente mejor */
    border-width: 2px;      /* Borde más grueso para que se note la selección */
  }
}




/* Solo para computadoras (opcional pero recomendado para rendimiento) */
@media (min-width: 1024px) {
  
  .theme-card.selected {
    position: relative;
    z-index: 1;
    overflow: hidden; /* Corta el brillo sobrante */
    border: 1px solid transparent; /* Ocultamos el borde real para que brille el animado */
  }

  /* El brillo que gira */
  .theme-card.selected::before {
    content: '';
    position: absolute;
    z-index: -2;
    left: -50%;
    top: -50%;
    width: 200%;
    height: 200%;
    background-color: transparent;
    background-repeat: no-repeat;
    background-size: 50% 50%, 50% 50%;
    /* El degradado que crea el efecto de luz */
    background-image: conic-gradient(transparent, var(--accent), transparent 30%);
    
    /* Animación: dura 3 segundos y se repite 2 veces, luego se detiene */
    animation: rotateBorder 3s linear infinite; 
    animation-fill-mode: forwards; /* Se queda en la posición final */
  }

  /* Capa interna para que el contenido no se tape y mantenga el fondo */
  .theme-card.selected::after {
    content: '';
    position: absolute;
    z-index: -1;
    inset: 2px; /* Grosor del borde */
    background: var(--panel); /* El color de fondo de tu tarjeta */
    border-radius: 8px;
  }
}

/* Animación de rotación */
@keyframes rotateBorder {
  100% {
    transform: rotate(360deg);
  }
}
