/* Login page professional styling */
:root{
  --primary: #16a34a;
  --primary-600: #15803d;
}

body.login-page{
  min-height: 100vh;
  display: grid;
  place-items: center;
  background-color: var(--color-bg);
  width: 100vw;
  overflow-x: hidden;
}
/* Asegurar que el overlay de fondo cubre toda la altura en login */
body.login-page::before{
  height: 100vh;
}

.login-container{
  width: min(92vw, 480px);
  max-width: 100%;
  margin-inline: auto;
  padding: clamp(1rem, 3vw, 2rem);
}

.login-card{
  margin: 0 auto;
  width: 100%;
  max-width: none;
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 16px;
  border: 1px solid var(--color-border);
  box-shadow: 0 20px 60px rgba(0,0,0,0.18);
  padding: clamp(1.25rem, 3.5vw, 2rem);
}

body.dark-mode .login-card{
  background: rgba(18,20,26,0.85);
  border-color: rgba(255,255,255,0.08);
  box-shadow: 0 20px 60px rgba(0,0,0,0.45);
}

.login-header{
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-bottom: 1.25rem;
}
.login-header .brand{
  width: 72px;
  height: 72px;
  object-fit: contain;
  margin-bottom: 0.75rem;
}
.login-header h1{
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-text-primary);
}
.login-header .subtitle{
  font-size: 0.95rem;
  color: var(--color-text-secondary);
}

.login-alert{
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 0.9rem;
  border-radius: 8px;
  background: #fee2e2;
  color: #b91c1c;
  border: 1px solid #fecaca;
  margin: 0.5rem 0 1rem 0;
}
body.dark-mode .login-alert{
  background: rgba(185,28,28,0.15);
  color: #fecaca;
  border-color: rgba(185,28,28,0.35);
}

.login-form{
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.input-group{
  display: grid;
  grid-template-columns: 1.75rem 1fr auto;
  align-items: center;
  gap: 0.35rem;
  border: 1px solid var(--color-border);
  background: transparent;
  /* variable usada para autofill */
  --input-bg: transparent;
  border-radius: 10px;
  padding: 0.5rem 0.6rem;
  /* Overflow visible para que el botón no se recorte */
  overflow: visible;
  box-shadow: none !important;
}
.input-group.invalid{
  border-color: #dc2626 !important;
  box-shadow: none !important;
}
.input-group.valid{
  border-color: #16a34a !important;
  box-shadow: none !important;
}
body.dark-mode .input-group{
  background: transparent;
  --input-bg: transparent;
  box-shadow: none !important;
}
.input-group i{
  font-size: 1.2rem;
  color: var(--color-text-secondary);
}
.input-group input{
  border: none !important;
  outline: none !important;
  background: transparent;
  color: var(--color-text-primary);
  font-size: 0.95rem;
  padding: 0.4rem 0.2rem;
  width: 100%;
  /* evita que el autofill pinte fuera del padding */
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
  box-shadow: none !important;
}
/* Ocultar el botón nativo de mostrar/ocultar contraseña en Edge/IE */
.input-group input::-ms-reveal,
.input-group input::-ms-clear {
  display: none;
}
.icon-btn{
  background: transparent;
  border: none;
  color: var(--color-text-secondary);
  font-size: 1.2rem;
  cursor: pointer;
  padding: 0.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  min-height: 2rem;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}
.icon-btn:active{
  background: rgba(0,0,0,0.05);
  border-radius: 6px;
}
body.dark-mode .icon-btn:active{
  background: rgba(255,255,255,0.08);
}
.icon-btn i{
  pointer-events: none;
}
#eye-closed{ display: none; }

.field-hint{
  color: var(--color-text-secondary);
  font-size: 0.85rem;
  margin-top: -0.25rem;
}
.field-error{
  color: #dc2626;
  font-size: 0.85rem;
  min-height: 1rem;
}

.login-meta{
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.25rem;
  margin-bottom: 0.25rem;
}
.login-meta .remember{
  display: flex;
  align-items: center;
  gap: 0.45rem;
  color: var(--color-text-secondary);
  font-size: 0.95rem;
}
.login-meta .link{
  color: var(--primary);
  text-decoration: none;
  font-size: 0.95rem;
}

.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1rem;
  border-radius: 10px;
  border: 1px solid transparent;
  cursor: pointer;
  font-weight: 600;
}
.btn.primary{
  background: var(--primary);
  color: white;
}
.btn.primary:hover{
  background: var(--primary-600);
}
.btn.full{ width: 100%; }

.login-footer{
  margin-top: 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.login-footer .dark-mode-btn{
  position: static;
  display: inline-flex;
  width: 2rem;
  height: 2rem;
}
.login-footer .copyright{
  color: var(--color-text-secondary);
  font-size: 0.85rem;
}

/* Neutralizar estilos de autocompletado del navegador */
body.login-page input:-webkit-autofill,
body.login-page input:-webkit-autofill:hover,
body.login-page input:-webkit-autofill:focus{
  -webkit-text-fill-color: var(--color-text-primary) !important;
  caret-color: var(--color-text-primary);
  -webkit-box-shadow: 0 0 0px 9999px var(--color-bg, #ffffff) inset !important;
  box-shadow: none !important;
  border-radius: inherit;
  transition: background-color 100000s ease-in-out 0s;
}
body.login-page input:-moz-autofill{
  -moz-text-fill-color: var(--color-text-primary) !important;
  caret-color: var(--color-text-primary);
  box-shadow: none !important;
  border-radius: inherit;
}
body.dark-mode.login-page input:-webkit-autofill,
body.dark-mode.login-page input:-webkit-autofill:hover,
body.dark-mode.login-page input:-webkit-autofill:focus{
  -webkit-box-shadow: 0 0 0px 9999px #12141a inset !important;
}

/* Sobrescribir estilos globales de focus para eliminar aureola interna */
/* IMPORTANTE: Los estilos globales en style.css tienen !important, necesitamos ser MÁS específicos */
body.login-page .input-group input[type="text"],
body.login-page .input-group input[type="password"],
body.login-page input[type="text"],
body.login-page input[type="password"] {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}

body.login-page .input-group input[type="text"]:focus,
body.login-page .input-group input[type="password"]:focus,
body.login-page input[type="text"]:focus,
body.login-page input[type="password"]:focus {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}

body.dark-mode.login-page .input-group input[type="text"],
body.dark-mode.login-page .input-group input[type="password"],
body.dark-mode.login-page input[type="text"],
body.dark-mode.login-page input[type="password"] {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}

body.dark-mode.login-page .input-group input[type="text"]:focus,
body.dark-mode.login-page .input-group input[type="password"]:focus,
body.dark-mode.login-page input[type="text"]:focus,
body.dark-mode.login-page input[type="password"]:focus {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Asegurar que el contenedor input-group tampoco tenga box-shadow en focus */
body.login-page .input-group,
body.login-page .input-group:focus-within,
body.dark-mode.login-page .input-group,
body.dark-mode.login-page .input-group:focus-within {
    box-shadow: none !important;
}

/* Responsive */
@media (max-width: 480px){
  .login-container{ width: 92vw; padding: 1rem; }
  .login-card{ padding: 1rem; }
  .login-header h1{ font-size: 1.2rem; }
  
  /* Asegurar que el botón del ojito sea visible y tocable en móvil */
  .icon-btn{
    min-width: 2.5rem;
    min-height: 2.5rem;
    font-size: 1.3rem;
  }
}
