/* ── Login shell + card ──
   Mueve los estilos inline antiguos a CSS reutilizable.
   Compatibilidad dark/light via tokens Bootstrap (.public-card). */

.login-shell {
  min-height: 100dvh;
}

@supports not (height: 100dvh) {
  .login-shell {
    min-height: 100vh;
  }
}

/* Card del login con el mismo look que .dir-card-v2:
 * radius 20px, background tema-aware, shadow sutil en light y glass
 * en dark, hover con glow azul apple. */
.login-card {
  background-color: var(--bs-body-bg);
  border: 1px solid transparent;
  border-radius: 1.25rem;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.06);
  max-width: 24rem;
  transition: box-shadow 0.3s ease, transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  width: 100%;
}

.login-card:hover {
  box-shadow: 0 18px 52px rgba(0, 122, 255, 0.3);
  transform: translateY(-4px);
}

[data-bs-theme="dark"] .login-card {
  background-color: #1c1c1e;
  border-color: #2c2c2e;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
}

[data-bs-theme="dark"] .login-card:hover {
  box-shadow: 0 18px 52px rgba(0, 122, 255, 0.45);
}

/* Main del login ocupa al menos un viewport completo → el footer queda fuera
   del primer pantalla y requiere scroll para llegar a él. UI limpia en la
   zona alcanzable por los dedos. */
.login-main {
  min-height: 100dvh;
}

@supports not (height: 100dvh) {
  .login-main {
    min-height: 100vh;
  }
}

/* ── Header del login ──
   Header no-sticky, ancho completo, logo izquierda + toggle tema derecha. */

.login-header {
  /* Linea inferior identica a la del header publico (.public-navbar). */
  border-bottom: 1px solid rgba(var(--bs-body-color-rgb), var(--public-border-alpha));
}

/* ── View Transition custom para /login ──
   Al entrar: la nueva pagina aparece desde el centro (zoom-in, efecto modal).
   Al salir: la pagina se contrae al centro antes de desaparecer.
   El fade por defecto viene de public.css. */
::view-transition-new(root) {
  animation-name: login-zoom-in;
  animation-duration: 1000ms;
  animation-timing-function: cubic-bezier(0.16, 1, 0.3, 1);
}

::view-transition-old(root) {
  animation-name: login-zoom-out;
  animation-duration: 750ms;
  animation-timing-function: cubic-bezier(0.65, 0, 0.35, 1);
}

@keyframes login-zoom-in {
  from { transform: scale(0.80); opacity: 0; }
  to   { transform: scale(1);    opacity: 1; }
}

@keyframes login-zoom-out {
  from { transform: scale(1);    opacity: 1; }
  to   { transform: scale(0.80); opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  ::view-transition-new(root),
  ::view-transition-old(root) {
    animation: none !important;
  }
}

.login-footer-divider {
  /* Linea superior del footer login, mismo aspecto que el border-top de
     .public-footer / .public-footer--minimal. */
  border: 0;
  border-top: 1px solid rgba(var(--bs-body-color-rgb), var(--public-border-alpha));
  margin: 0;
  opacity: 1;
}

.login-theme-toggle {
  min-width: 44px;
  min-height: 44px;
}

/* Boton submit del formulario de login — alineado con el sistema
 * Apple unificado (pill + border + glow hover azul). Mismo patron que
 * los CTAs primary de los modales voz/cookies y el boton de /seguimiento. */
.login-submit-btn {
  border: 1px solid var(--bs-primary) !important;
  border-radius: var(--bs-border-radius-pill) !important;
  font-weight: 600;
  transition: background-color 0.2s ease,
              border-color 0.2s ease,
              box-shadow 0.2s ease,
              transform 0.15s ease;
  box-shadow: 0 0 0 rgba(0, 122, 255, 0);
}
.login-submit-btn:hover,
.login-submit-btn:focus-visible {
  border-color: var(--bs-primary);
  box-shadow: 0 10px 28px rgba(var(--bs-primary-rgb), 0.45);
  transform: translateY(-1px);
}
.login-submit-btn:active {
  transform: translateY(0);
}

/* Toggle de icono dark/light: reglas movidas a `public.css` 2026-04-21
   para reutilizarlas tambien en el header publico (no solo login).
   `login/base.html` carga `public.css`, asi que las reglas siguen
   aplicando aqui sin duplicarlas. */
