/* --- VARIABLES DE DISEÑO Y ESTILOS GENERALES --- */
:root {
  /* Paleta de colores premium, animada y de alto contraste */
  --bg-gradient-1: #0a0c10; /* Negro espacial */
  --bg-gradient-2: #1a2038; /* Azul índigo oscuro */
  --bg-gradient-3: #2a5298; /* Azul corporativo oscuro */
  --card-bg: rgba(10, 12, 16, 0.75); /* Cristal oscuro, más opaco */
  --card-border: rgba(255, 255, 255, 0.12);
  --card-glow: rgba(78, 115, 223, 0.25);
  --text-color: #ffffff; /* Blanco puro para máxima legibilidad */
  --primary-accent: #4e73df;
  --primary-accent-darker: #3b5bbf;
  --input-bg: rgba(0, 0, 0, 0.3);
  /* --input-focus-bg: rgba(0, 0, 0, 0.4); Eliminado para evitar cambio de color */
  --input-border: rgba(255, 255, 255, 0.2);
  --input-focus-border: var(--primary-accent);
  --input-focus-shadow: rgba(78, 115, 223, 0.4);
  --placeholder-color: #b0b3b8; /* [SOLUCIÓN] Placeholder con color sólido y legible */
}

@keyframes gradient-animation {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

body {
  /* Fondo animado, sutil y profesional */
  background: linear-gradient(-45deg, var(--bg-gradient-2), var(--bg-gradient-1), var(--bg-gradient-3), var(--bg-gradient-1));
  background-size: 400% 400%;
  animation: gradient-animation 20s ease infinite;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  font-family: "Segoe UI", sans-serif;
}

.login-card {
  /* Tarjeta de cristal refinada con brillo */
  background: var(--card-bg);
  color: var(--text-color); /* Color por defecto para el texto */
  padding: 2.5rem;
  border-radius: 15px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5), 0 0 20px var(--card-glow);
  width: 100%;
  max-width: 420px; /* Un poco más ancha */
  transition: all 0.3s ease;
  border: 1px solid var(--card-border);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* --- SOLUCIÓN DEFINITIVA DE LEGIBILIDAD --- */
/* Forzamos el color blanco en los elementos de texto clave */
.login-card h1,
.login-card h3 {
  color: var(--text-color) !important; /* Forzar el color blanco */
  font-weight: 700;
  /* Se elimina la sombra de texto para máxima nitidez y claridad */
}

/* [SOLUCIÓN] Anular clases de color de Bootstrap para una legibilidad perfecta */
.login-card .form-label,
.login-card .text-secondary {
    color: rgba(255, 255, 255, 0.85) !important; /* Labels y texto secundario ligeramente atenuados */
}

.login-card .text-muted {
    color: rgba(255, 255, 255, 0.7) !important; /* Texto "muted" aún más sutil */
}

.btn-login {
  background: var(--primary-accent);
  border-color: var(--primary-accent);
  padding: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
  font-size: 1rem;
  color: white;
  transition: all 0.2s ease-in-out;
}
.btn-login:hover {
  background: var(--primary-accent-darker);
  border-color: var(--primary-accent-darker);
  box-shadow: 0 0 10px var(--primary-accent);
}

.form-control {
  padding: 12px 15px;
  border-radius: 8px;
  background-color: var(--input-bg);
  border: 1px solid var(--input-border);
  color: var(--text-color);
  height: 50px;
}

.form-control:focus {
  box-shadow: 0 0 0 0.25rem var(--input-focus-shadow);
  border-color: var(--input-focus-border);
  outline: none;
  color: var(--text-color); /* [SOLUCIÓN] Asegura que el texto escrito sea blanco */
  background-color: var(--input-bg); /* [SOLUCIÓN] Evita que el fondo se oscurezca al hacer clic */
}

.form-control::placeholder {
  color: var(--placeholder-color);
  opacity: 1; /* Firefox necesita esto */
}

/* --- [NUEVO] CORRECCIÓN PARA AUTOFILL DEL NAVEGADOR (CHROME, EDGE) --- */
/* Evita que el navegador ponga un fondo blanco/azul en campos autocompletados */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
    -webkit-text-fill-color: var(--text-color) !important; /* Forzar texto blanco */
    -webkit-box-shadow: 0 0 0 40px var(--input-bg) inset !important; /* [SOLUCIÓN] Mantiene el fondo consistente */
    /* Transición larga para evitar que el navegador la anule */
    transition: background-color 5000s ease-in-out 0s;
    caret-color: var(--text-color); /* Asegurar que el cursor de texto sea visible */
}

/* --- MEDIA QUERIES (MÓVIL) --- */
@media (max-width: 576px) {
  .login-card {
    padding: 1.5rem;
    border-radius: 12px;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.6), 0 0 15px var(--card-glow);
  }
  h1 { font-size: 2rem; }
  h3 { font-size: 1.5rem; }
  .form-control {
    font-size: 16px; /* Evita que iOS haga zoom al escribir */
  }
}

/* Ajuste para móviles en horizontal (Landscape) */
@media (max-height: 500px) {
  body {
    align-items: flex-start;
    padding-top: 20px;
    padding-bottom: 20px;
  }
}