body {
    background-color: #e9ecef;
    /* Fondo gris muy claro, suave */
    display: flex;
    /* Activar Flexbox */
    justify-content: center;
    /* Centrar horizontalmente */
    align-items: center;
    /* Centrar verticalmente */
    min-height: 100vh;
    /* Asegurar altura mínima de la ventana */
    padding: 1rem;
    /* Añadir un poco de padding alrededor */
    margin: 0;
    /* Eliminar margen por defecto del body */
    overflow: hidden;
}

.login-container {
    display: flex;
    margin-left: 10%;
    align-items: center; /* Centrado vertical */
    justify-content: center; /* Centrado horizontal */
    min-height: 100vh; /* Asegura que el contenedor ocupe al menos toda la altura de la ventana */
    width: 50%;
    /* Asegurar que el contenedor interno pueda usar max-width */
}

.form-section {
    background-color: #ffffff;
    border-radius: 12px;
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.08);
    width: 100%;
    max-width: 450px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 420px;
    padding: 2.5rem;
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}

.form-section:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
}


.logo {
    text-align: center;
    margin-bottom: 2rem;
}

form {
    margin-bottom: 2rem;
}

.form-floating label {
    color: #6c757d;
    transition: color 0.2s ease-in-out;
    /* Transición de color suave */
}

.form-floating input:focus~label,
.form-floating input:not(:placeholder-shown)~label {
    color: #007bff;
    /* Cambia el color del label al enfocar o cuando el input tiene valor */
    transform: translateY(-0.75rem) scale(0.85);
    /* Mejora la animación del label */
}

.form-control {
    border: 1px solid #ced4da;
    /* Borde un poco más claro */
    border-radius: 8px;
    /* Bordes redondeados para los inputs */
    padding: 0.75rem;
    /* Padding vertical aumentado */
    transition: border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
    /* Transiciones */
}

.form-control:focus {
    border-color: #007bff;
    /* Color del borde al enfocar */
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1);
    /* Sombra de enfoque más sutil */
    outline: none;
    /* Elimina el outline por defecto en algunos navegadores */
}

.btn-success {
    width: 100%;
    padding: 0.8rem;
    margin-top: 1rem;
    border-radius: 8px;
    font-size: 1.1rem;
    font-weight: 500;
    background-color: #28a745;
    border: none;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    transition: background-color 0.2s ease-in-out, transform 0.1s ease;
}

.btn-success:hover {
    background-color: #218838;
    box-shadow: 0 3px 7px rgba(0, 0, 0, 0.15);
}

.btn-success:active {
    background-color: #1e7e34;
    transform: translateY(0);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}


.error-message {
    color: #dc3545;
    margin-top: 1.5rem;
    text-align: center;
    font-size: 0.9rem;
    padding: 0.5rem;
    background-color: #f8d7da;
    border-radius: 6px;
    border: 1px solid #f5c6cb;
}

.footer {
    text-align: center;
    font-size: 0.9rem;
    color: #6c757d;
    margin-top: 2rem;
}

.footer a {
    color: #007bff;
    text-decoration: none;
    margin: 0 0.75rem;
    font-weight: 400;
    transition: color 0.2s ease-in-out, text-decoration 0.2s ease-in-out;
}

.footer a:hover {
    color: #0056b3;
    text-decoration: underline;
}

/* Estilos para posicionar las alertas en la esquina superior derecha */
.alert-container {
    position: absolute;
    top: 70px;
    right: 10px;
    z-index: 1000;
}

.legend {
    margin-top: 1.5rem;
    font-size: 0.8rem;
    color: #666;
    padding: 0.5rem;
    background-color: #f8f9fa;
    border-radius: 6px;
    border: 1px solid #e2e3e4;
}

.custom-icon {
    font-size: 3rem; /* Ajustado para que quepa en el formulario */
    font-weight: bold;
    color: #66BB6A; /* Verde para "UniWeb" */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* Sombra de texto sutil */
}

.custom-icon:hover {
    transform: translateY(-2px) scale(1.05);
}

.admin-title-text {
    font-size: 2.2rem; /* Mismo tamaño que custom-icon */
    font-weight: bold;
    color: white; /* Blanco para "Admin" */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* Sombra de texto sutil */
}

/* Efecto hover sutil para las tarjetas principales de los widgets */
.card {
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}
.card:hover {
    transform: translateY(-3px); /* Levanta ligeramente la tarjeta */
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important; /* Sombra más pronunciada */
}

/* Efecto hover para los items de tarea */
.today-task-item {
    transition: background-color 0.2s ease-in-out;
    border-radius: 0.25rem; /* Bordes redondeados para el hover */
}
.today-task-item:hover {
    background-color: #f8f9fa; /* Un fondo gris muy claro */
}

/* Efecto hover para las filas de la tabla de estado de cierre */
.table tbody tr {
    transition: background-color 0.2s ease-in-out;
}
.table tbody tr:hover {
    background-color: #e9ecef; /* Un gris un poco más oscuro */
}

/* Efecto hover específico para las tarjetas dentro del widget de estado de empleados */
/* Seleccionamos las tarjetas que son hijas directas de .col-xl-3 dentro del widget */
#employee-status-widget .col-xl-3 > .card:hover {
        transform: translateY(-5px); /* Un poco más de elevación */
        box-shadow: 0 0.75rem 1.5rem rgba(0, 0, 0, 0.18) !important;
}
