/* ----------------------------------------------------------------------------------------------------------------------------------------------------
CONTENEDOR PRINCIPAL DEL LOGIN
------------------------------------------------------------------------------------------------------------------------------------------------------- */

.container-login {
display: flex !important; /* Flex para centrar */
justify-content: center !important; /* Centrado horizontal */
align-items: center !important; /* Centrado vertical */
min-height: 80vh !important; /* Altura mínima visible */
}

.mi-login { /* Fondo general del body en la vista login */
display: flex !important;
justify-content: center !important;
align-items: center !important;
background-size: cover !important; /* Ajuste para imagen de fondo */
}

/* -----------------------------------------------------------------------------------------------------------------------------------------------------
  TARJETA DEL FORMULARIO DE LOGIN
-------------------------------------------------------------------------------------------------------------------------------------------------------- */

.card-login {
  position: relative !important;
  padding: 20px 30px !important;
  background-color: #ffffff9d !important;
  border-radius: 5px !important;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.08) !important;
  overflow: hidden;
  width: 400px;
}

.card-login::before,
.card-login::after {
  content: "";
  position: absolute;
  width: 5px;
  top: 0;
  bottom: 0;
  background: linear-gradient(to bottom, #1d9bac, #188290);
}

.card-login::before {
  left: 0;
}

.card-login::after {
  right: 0;
}

/* ---------------------------------------------
   CONTENEDOR Y ESTILO DEL LOGO EN IMAGEN
--------------------------------------------- */

.logo-img {
  text-align: left !important;
}

.img-logo {
  max-width: 180px; /* Ajusta el tamaño según necesidad */
  height: auto;
  display: block;
  margin: 0; /* Sin centrado */
  animation: logoFadeIn 0.6s ease-in-out;
}

/* Animación de entrada */
@keyframes logoFadeIn {
  0% {
    opacity: 0;
    transform: translateY(-10px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ------------------------------------------------------------------------------------------------------------------------------------------------------
   TÍTULO DEL LOGIN: Inicio de Sesión
--------------------------------------------------------------------------------------------------------------------------------------------------------- */

.encabezado-login {
  text-align: left !important;
  margin-bottom: 20px !important;
  position: relative;
}

.titulo-login {
  font-size: 14px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  color: #5a6b6d !important;
  letter-spacing: 1.2px !important;
  margin: 0 0 5px 0 !important;
  position: relative;
  z-index: 2;
}

/* Barra decorativa moderna */
.barra-login {
  width: 80px;
  height: 4px;
  border-radius: 2px;
  background: linear-gradient(to right, #1d9bac, #b7b418);
  animation: barraAnimacion 2s ease infinite alternate;
}

/* Animación sutil tipo brillo */
@keyframes barraAnimacion {
  0% {
    transform: scaleX(1);
    opacity: 0.7;
  }
  100% {
    transform: scaleX(1.15);
    opacity: 1;
  }
}

/* -----------------------------------------------------------------------------------------------------------------------------------------------------
  ETIQUETAS DE CAMPOS DE FORMULARIO: Labels e inputs
-------------------------------------------------------------------------------------------------------------------------------------------------------- */

.label-login {
font-size: 12px !important;
color: #696969 !important;
margin-bottom: 0 !important;
text-align: justify !important;
}

.check-label-login {
font-size: 12px !important;
color: #696969 !important;
margin-bottom: 0 !important;
text-align: justify !important;
}

.input-login {
background-color: #ffffff !important; /* Fondo blanco */
color: #606060 !important; /* Texto gris oscuro */
border: 1px solid #ccc !important; /* Borde gris claro */
border-radius: 4px !important;
font-size: 13px !important;
padding: 5px !important;
box-shadow: none !important; /* Elimina efectos de Bootstrap */
outline: none !important;
}

.input-login:focus {
border-color: #1d9bac !important; /* Borde verde al enfocar */
box-shadow: 0 0 0 2px rgba(22, 143, 86, 0.2) !important; /* Resplandor sutil */
}

/* -----------------------------------------------------------------------------------------------------------------------------------------------------
CHECKBOX: Mostrar contraseña
-------------------------------------------------------------------------------------------------------------------------------------------------------- */

.check-container-login { /* Contenedor */
display: flex !important;
align-items: center !important;
justify-content: flex-start !important; /* Alineado a la izquierda */
gap: 8px !important; /* Espacio entre el checkbox y el texto */
margin-top: 10px !important;
padding-left: 2px !important; /* Pequeño ajuste para alinear con inputs */
}

.check-label-login { /* Label*/
font-size: 10px !important;
color: #444 !important;
margin: 0 !important;
cursor: pointer !important;
user-select: none !important;
}

.check-input-login { /* Input */
width: 16px !important;
height: 16px !important;
accent-color: #1d9bac !important; /* Color verde institucional */
cursor: pointer !important;
border-radius: 3px !important;
margin: 0 !important;
}

/* -----------------------------------------------------------------------------------------------------------------------------------------------
MENSAJE ERROR
-------------------------------------------------------------------------------------------------------------------------------------------------*/

.mensaje-error { /* Estilo personalizado para el mensaje de error */
background-color: #ffe5e5 !important; /* Fondo rojo claro */
color: #a94442 !important; /* Texto rojo oscuro */
border: 1px solid #f5c2c2 !important; /* Borde suave */
padding: 0px 15px !important; /* Espaciado interno */
margin-bottom: 15px !important; /* Separación inferior */
border-radius: 4px !important; /* Bordes redondeados */
font-size: 13px !important; /* Tamaño de letra */
text-align: center !important; /* Texto centrado */
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05) !important; /* Sombra sutil */
}

/* -----------------------------------------------------------------------------------------------------------------------------------------------
BOTON INGRESAR
-------------------------------------------------------------------------------------------------------------------------------------------------*/

.btn-ingresar { /* Botón personalizado para el formulario de ingreso */
display: block !important; /* Necesario para que margin funcione bien */
margin-bottom: 15px;
background-color: #1d9bac!important; /* Color verde institucional */
color: white !important; /* Texto blanco */
font-size: 14px !important; /* Tamaño de fuente legible */
font-weight: 500 !important; /* Peso de fuente medio */
padding: 0px 20px !important; /* Espaciado interno */
border: none !important; /* Sin borde */
border-radius: 4px !important; /* Bordes redondeados */
width: 100% !important; /* Ocupa el ancho completo del contenedor */
height: 30px;
transition: background-color 0.3s ease, transform 0.2s ease !important; /* Animaciones suaves */
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15) !important; /* Sombra sutil para profundidad */
}

.btn-ingresar:hover { /* Efecto al pasar el mouse (hover) */
background-color: #188290!important; /* Verde más oscuro */
transform: translateY(-1px) !important; /* Levanta ligeramente el botón */
}

.btn-ingresar:active { /* Efecto al hacer clic (active) */
background-color: #188290 !important; /* Verde aún más oscuro al hacer clic */
transform: scale(0.98) !important;    /* Ligeramente más pequeño al presionar */
}

/* ---------------------------------------------
  VIDEO DE FONDO PARA EL LOGIN
--------------------------------------------- */

.video-fondo {
position: fixed;
top: 50%;
left: 50%;
width: 100%;
height: 100%;
transform: translate(-50%, -50%);
object-fit: cover; /* Contiene el video sin recortarlo */
z-index: -1;
opacity: 0.4;
filter: brightness(1) contrast(1.1);
}





/* --------------------------------------------------
   Estilos base (desktop)
   -------------------------------------------------- */
/* ... tu CSS existente ... */

/* --------------------------------------------------
   Responsive: tablets (hasta 768px)
   -------------------------------------------------- */
@media screen and (max-width: 768px) {
  .container-login {
    min-height: 100vh;          /* cubre toda la pantalla */
    padding: 20px;              /* algo de espacio interno */
  }

  .card-login {
    width: 90% !important;      /* ocupa casi todo el ancho */
    padding: 15px 20px !important;
  }

  .img-logo {
    max-width: 140px;
  }

  .titulo-login {
    font-size: 16px !important;
  }

  .barra-login {
    width: 60px;
    height: 3px;
  }

  .label-login,
  .check-label-login {
    font-size: 11px !important;
  }

  .input-login {
    font-size: 14px !important;
    padding: 8px !important;
  }

  .btn-ingresar {
    font-size: 13px !important;
    padding: 8px 15px !important;
    height: auto;
  }
}

/* --------------------------------------------------
   Responsive: móviles (hasta 480px)
   -------------------------------------------------- */
/* ---------------------------------------------
   Ajustes específicos para móviles (≤480px)
   --------------------------------------------- */
@media screen and (max-width: 480px) {

  /* Wrapper principal: full screen y algo de padding superior */
  .mi-login {
    height: 100vh;             /* asegura que cubra la pantalla */
    padding-top: 15px;         /* separa un poco del tope */
    justify-content: flex-start !important; /* comienza desde arriba */
  }

  /* Video de fondo: centrado y recortado suavemente */
  .video-fondo {
    object-fit: cover;
    object-position: center;   /* centra el punto de recorte */
    opacity: 0.3;              /* más tenue para mejorar contraste */
  }

  /* Contenedor del login: ocupa casi todo el ancho */
  .container-login {
    width: 100% !important;
    max-width: 400px;          /* tope razonable en pantallas pequeñas */
    margin: 0 auto;            /* centrado horizontal */
    padding: 10px;             /* espacio interior */
  }

  /* Tarjeta de login: fondo más opaco y menos padding */
  .card-login {
    background-color: rgba(255,255,255,0.95) !important;
    padding: 15px 20px !important;
    box-shadow: 0 2px 6px rgba(0,0,0,0.1) !important;
  }

  /* Logo: tamaño reducido */
  .img-logo {
    max-width: 100px !important;
    margin-bottom: 8px !important;
  }

  /* Título y barra decorativa centrados */
  .titulo-login {
    font-size: 14px !important;
    text-align: center !important;
  }
  .barra-login {
    width: 50px !important;
    margin: 6px auto 12px !important;
  }

  /* Campos e inputs: más grandes para dedos */
  .input-login {
    font-size: 15px !important;
    padding: 10px !important;
  }
  .label-login {
    font-size: 11px !important;
  }

  /* Checkbox y mensaje de error */
  .check-container-login {
    gap: 6px !important;
    margin-top: 8px !important;
  }
  .mensaje-error {
    font-size: 12px !important;
    padding: 10px 12px !important;
  }

  /* Botón ingresar: mayor altura y tipografía clara */
  .btn-ingresar {
    font-size: 14px !important;
    padding: 12px !important;
    height: auto;
  }
}


