body {
    padding-right: 0px !important;
}

.tamanioLetra1 {
    font-size: 12px;
    text-align: center;
}

.tamanioLetra1_izquierda {
    font-size: 12px;
    text-align: left;
}

label {
    margin-top: 4px;
    margin-bottom: 2px;
    font-weight: 600;
}

.justificarTexto {

    text-align: justify
}

.form_boton {
    transition: .4s ease-in-out all;
    position: absolute;
}

.form_boton:hover {
    background: #198754;
}

.justificar_texto {
    text-align: justify
}

ol {
    list-style: none !important;
}

#resultadoEvaluacion {
    height: 709px;
}

.validarrolFormulario {
    display: block;
}

.fa-solid,
.fas {
    font-family: "Font Awesome 6 Free";
    font-weight: 900 !important;
}

.w1-100 {
    width: 55% !important;
    height: 635px !important;
}

.w2-100 {
    width: 100% !important;
    height: 906px !important;
}

input:invalid+span:after {
    position: absolute;
    content: '✖';
    padding-left: 11px;
    font-size: 23px;
}

input:valid+span:after {
    position: absolute;
    /* content: '✓';*/
    padding-left: 11px;
    font-size: 23px;
}


.checkbox-xl .form-check-input {
    scale: 1.7;
    position: absolute;
}

.justificar_texto_izquierda {
    text-align: left;
}

.is-invalid {
    border-color: red !important;
}

.is-valid {
    border-color: green !important;
}

.button-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
}

input:-webkit-autofill {
    -webkit-text-fill-color: rgb(12, 12, 12) !important;
    -webkit-text-stroke-color: #198754 !important;
    color: white;
    background-color: royalblue;
}

/* Estilo para el cursor cuando el campo esté deshabilitado */
input[disabled] {
    cursor: not-allowed;
}

/* Estilo para las sugerencias */
#sugerencias {
    margin-top: 3px;
    border: 1px solid #ccc;
    background-color: #fff;
    max-height: 150px;
    overflow-y: auto;
    box-shadow: 0px 0px 5px rgba(0, 0, 0, 0.2);
    margin-left: 2px;
    z-index: 100%;
}

#sugerencias p {
    padding: 0% 0% 0% 2%;
    cursor: pointer;
}

.estado {
    padding: 0.5rem 1rem;
    border-radius: 0.25rem;
    font-weight: bold;
    text-align: center;
    margin-bottom: 0.5rem;
    display: inline-block;
}

/* Estado: Solicitud */
.estado-solicitud {
    background-color: #007bff;
    color: white;
}

/* Estado: Anulado */
.estado-anulado {
    background-color: #ff8307;
    color: white;
}

/* Estado: Rechazar */
.estado-rechazar {
    background-color: #d9534f;
    color: white;
}

/* Estado: Autorizar */
.estado-autorizar {
    background-color: #ffc107;
    color: white;
}

/* Estado: Autorización Final */
.estado-autorizacion-final {
    background-color: #28a745;
    color: white;
}

/* Estado: Preselección */
.estado-preseleccion {
    background-color: #28a745;
    color: white;
}

/* Estado: Cerrada */
.estado-cerrada {
    background-color: #616263;
    color: white;
}

/* Estado: Novedad */
.estado-novedad {
    background-color: #ff8307;
    color: white;
}

/* Estado: Pendiente */
.estado-pendiente {
    background-color: #7FB3D5;
    color: white;
}

.swal-btn-danger {
    background-color: #dc3545 !important;
    border-color: #dc3545 !important;
    color: #fff !important;
}

.swal-btn-secondary {
    background-color: #6c757d !important;
    border-color: #6c757d !important;
    color: #fff !important;
}

.swal-btn-primary {
    background-color: #007bff !important;
    border-color: #007bff !important;
    color: #fff !important;
}

.swal-btn-success {
    background-color: #198754 !important;
    border-color: #198754 !important;
    color: #fff !important;
}

.swal-container-modal {
    z-index: 9999;
}


table {
    width: 100% !important;
    /*border-collapse: collapse;*/
    margin-top: 20px;
    border: 1px solid #ddd;
}

/*
table,
th,
td {
    border: 1px solid #ddd;
}

th,
td {
    padding: 15px;
    text-align: left;
} 
*/

@media only screen and (max-width: 1366px) {

    th,
    td {
        font-size: 12px !important;
        /* Ajusta el tamaño de la fuente para pantallas pequeñas */
    }
}

/* Media query para cambiar el tamaño de letra en pantallas pequeñas */
@media (max-width: 1366px) {
    label {
        font-size: 12px !important;
    }
}

/* Media query para cambiar el tamaño de letra en pantallas grandes*/
@media (min-width: 1600px) and (max-width: 2024px) {
    label {
        font-size: 14px !important;
    }
}

td.details-control {
    background: url('https://www.datatables.net/examples/resources/details_open.png') no-repeat center center;
    cursor: pointer;
}

tr.shown td.details-control {
    background: url('https://www.datatables.net/examples/resources/details_close.png') no-repeat center center;
}


/*CSS PARA LOS ICONOS DE LOS BOTONES*/
.icono_eliminar::before {
    font-family: "Font Awesome 6 Free";
    /* Asegúrate de usar la versión correcta */
    font-weight: 900;
    /* Necesario para los iconos sólidos */
    content: "\f1f8";
    /* Código Unicode del icono deseado */
    font-size: 15px;
    /* Tamaño del icono */
}

.icono_agregar::before {
    font-family: "Font Awesome 6 Free";
    /* Asegúrate de usar la versión correcta */
    font-weight: 900;
    /* Necesario para los iconos sólidos */
    content: "\2b";
    /* Código Unicode del icono deseado */
    font-size: 15px;
    /* Tamaño del icono */
}

.icono_detalle::before {
    font-family: "Font Awesome 6 Free";
    /* Asegúrate de usar la versión correcta */
    font-weight: 900;
    /* Necesario para los iconos sólidos */
    content: "\f05a";
    /* Código Unicode del icono deseado */
    font-size: 15px;
    /* Tamaño del icono */
}

.icono_desplegar::before {
    font-family: "Font Awesome 6 Free";
    /* Asegúrate de usar la versión correcta */
    font-weight: 900;
    /* Necesario para los iconos sólidos */
    content: "\f077";
    /* Código Unicode del icono deseado */
    font-size: 15px;
    /* Tamaño del icono */
}

.icono_pdf::before {
    font-family: "Font Awesome 6 Free";
    /* Asegúrate de usar la versión correcta */
    font-weight: 900;
    /* Necesario para los iconos sólidos */
    content: "\f1c1";
    /* Código Unicode del icono deseado */
    font-size: 15px;
    /* Tamaño del icono */
}

/* andres marin rodriguez*/
/*CSS PARA LOS ICONOS DE LOS BOTONES*/
.icono_descargar_imagen::before {
    font-family: "Font Awesome 6 Free";
    /* Asegúrate de usar la versión correcta */
    font-weight: 900;
    /* Necesario para los iconos sólidos */
    content: "\f019";
    /* Código Unicode del icono deseado */
    font-size: 15px;
    /* Tamaño del icono */
}

/* andres marin rodriguez*/
/*CSS PARA LOS ICONOS DE LOS BOTONES*/
.icono_imprimir::before {
    font-family: "Font Awesome 6 Free";
    /* Asegúrate de usar la versión correcta */
    font-weight: 900;
    /* Necesario para los iconos sólidos */
    content: "\f02f";
    /* Código Unicode del icono deseado */
    font-size: 15px;
    /* Tamaño del icono */
}

/* andres marin rodriguez*/

/*CSS PARA LOS ICONOS DE LOS BOTONES*/

.icono_renombrar_imagen::before {
    font-family: "Font Awesome 6 Free";
    /* Asegúrate de usar la versión correcta */
    font-weight: 900;
    /* Necesario para los iconos sólidos */
    content: "\f303";
    /* Código Unicode del icono deseado */
    font-size: 15px;
    /* Tamaño del icono */
}

.icono_emergente::before {
    font-family: "Font Awesome 6 Free";
    /* Asegúrate de usar la versión correcta */
    font-weight: 900;
    /* Necesario para los iconos sólidos */
    content: "\f08e";
    /* Código Unicode del icono deseado */
    font-size: 15px;
    /* Tamaño del icono */
    font-family: "Font Awesome 6 Free";
    /* Asegúrate de usar la versión correcta */
    font-weight: 900;
    /* Necesario para los iconos sólidos */
    content: "\f08e";
    /* Código Unicode del icono deseado */
    font-size: 15px;
    /* Tamaño del icono */
}

.icono_cruzar::before {
    font-family: "Font Awesome 6 Free";
    /* Asegúrate de usar la versión correcta */
    font-weight: 900;
    /* Necesario para los iconos sólidos */
    content: "\f074";
    /* Código Unicode del icono deseado */
    font-size: 15px;
    /* Tamaño del icono */
}
.icono_editar::before {
    font-family: "Font Awesome 6 Free";
    /* Asegúrate de usar la versión correcta */
    font-weight: 900;
    /* Necesario para los iconos sólidos */
    content: "\f044";
    /* Código Unicode del icono deseado */
    font-size: 15px;
    /* Tamaño del icono */
}


:root {
    --primary-color: rgb(255, 255, 255);
    /* Un azul verdoso más vibrante pero suave */
    --secondary-color: #e0f2f7;
    /* Tono claro para fondos */
    --text-color: #333;
    --light-gray: #f8f9fa;
    --border-color: #dee2e6;
    --shadow-color: rgba(0, 0, 0, 0.08);
    --card-bg: #ffffff;
}


.container-modern {
    max-width: 960px;
    /* Ajusta el ancho máximo según necesites */
    margin: 0 auto;
}

/* Contenedor principal de la vista */
.main-card {
    background-color: var(--card-bg);
    border-radius: 12px;
    box-shadow: 0 6px 15px var(--shadow-color);
    padding: 30px;
    margin-top: 25px;
}

/* Estilos para el menú de pestañas (años) */
.nav-tabs-modern {
    border-bottom: none;
    margin-bottom: 25px;
}

.nav-tabs-modern .nav-item {
    margin-right: 10px;
}

.nav-tabs-modern .nav-link {
    border: none;
    border-radius: 8px;
    padding: 10px 20px;
    color: var(--text-color);
    background-color: var(--secondary-color);
    transition: all 0.3s ease;
    font-weight: 500;
}

.nav-tabs-modern .nav-link.active {
    background-color: var(--primary-color);
    color: rgb(0, 147, 219);
   /* box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);*/
}

.nav-tabs-modern .nav-link:hover:not(.active) {
    background-color: #d1eff6;
    /* Un tono un poco más oscuro que secondary-color */
    color: var(--text-color);
}

/* Título de la sección */
h2.section-title {
    font-size: 1.8rem;
    font-weight: 600;
    color: var(--text-color);
    margin-bottom: 20px;
}

/* Contenedor de la tabla */
.table-card {
    background-color: var(--card-bg);
    border-radius: 12px;
    box-shadow: 0 6px 15px var(--shadow-color);
    padding: 25px;
}

/* Estilos para la tabla DataTables */
.data-table-modern {
    width: 100% !important;
    /* Importante para DataTables */
    border-collapse: separate;
    border-spacing: 0;
    margin-top: 15px !important;
}

.data-table-modern thead th {
    background-color: var(--secondary-color);
    color: var(--text-color);
    font-weight: 600;
    padding: 12px 15px;
    text-align: left;
    border-bottom: 2px solid var(--primary-color);
    position: sticky;
    top: 0;
    /* Para que el header se mantenga visible al hacer scroll */
    z-index: 1;
}

.data-table-modern tbody tr {
    border-bottom: 1px solid var(--border-color);
    transition: background-color 0.2s ease;
}

.data-table-modern tbody tr:last-child {
    border-bottom: none;
}


.data-table-modern tbody td {
    padding: 12px 15px;
    vertical-align: middle;
}

/* Centrar contenido en las celdas específicas */
.data-table-modern .centro {
    text-align: center;
}

/* Estilos para los botones de acción */
.action-buttons .btn {
    padding: 6px 10px;
    font-size: 0.9rem;
    border-radius: 6px;
    margin-left: 5px;
}

/* Iconos de acciones */
.action-buttons .btn i {
    margin-right: 5px;
}

/* Estilo para el botón de añadir (ejemplo) */
.btn-add-item {
    background-color: var(--primary-color);
    color: white;
    border: none;
    border-radius: 8px;
    padding: 10px 20px;
    font-weight: 600;
    transition: background-color 0.3s ease, transform 0.2s ease;
    margin-bottom: 20px;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .main-card {
        padding: 20px;
    }

    .table-card {
        padding: 15px;
    }

    h2.section-title {
        font-size: 1.5rem;
    }

    .nav-tabs-modern .nav-link {
        padding: 8px 15px;
        font-size: 0.9rem;
    }
}


/**************************************************************************ESTILOS PARA LOS GRAFICOS******************************************************************/
.contenedor-grafico {
    background-color: #fff;
    border-radius: 15px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05),
        0 6px 20px rgba(0, 0, 0, 0.03);
    padding: 20px;
    /* QUITADO: margin: 20px auto; */
    margin-bottom: 20px;
    /* Añadido para espaciar las tarjetas verticalmente */
    width: 100%;
    /* Asegura que ocupe todo el ancho disponible de la columna */
    position: relative;
    /*overflow: hidden;
    /* Opcional: añade un min-height si quieres que todas las tarjetas tengan una altura mínima consistente */
    /* min-height: 300px; */
}

/* Estilos para el título del gráfico, si lo añades como un h2/h3 */
.titulo-grafico {
    font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    /* Fuente similar a la de la imagen */
    font-size: 24px;
    /* Tamaño del título */
    color: #333;
    /* Color del texto */
    text-align: left;
    /* Alineación a la izquierda */
    margin-bottom: 25px;
    /* Espacio debajo del título */
    padding-left: 10px;
    /* Pequeño padding si el gráfico tiene uno */
    font-weight: 600;
    /* Un poco más de peso para el título */
}

/* Estilos para la leyenda, si la pones fuera del canvas o si la quieres personalizar */
.leyenda-grafico {
    font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    font-size: 14px;
    color: #555;
    margin-bottom: 15px;
    display: flex;
    /* Para que los elementos de la leyenda se alineen */
    gap: 20px;
    /* Espacio entre los elementos de la leyenda */
    padding-left: 10px;
}

.leyenda-item {
    display: flex;
    align-items: center;
}

.leyenda-color-box {
    width: 12px;
    height: 12px;
    border-radius: 3px;
    margin-right: 8px;
}

.color-novedad {
    background-color: #4CAF50;
    /* Color de ejemplo, ajusta al color de tu gráfico */
}

.color-empleados {
    background-color: #FFC107;
    /* Color de ejemplo, ajusta al color de tu gráfico */
}

.novedadCierre {
    background-color: white;
    border-radius: 1rem;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    padding: 1.5rem;
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
    cursor: pointer;
    border: 2px solid #00000024;
}
.novedadCierre:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 15px rgba(0, 0, 0, 0.15), 0 0 20px rgba(0, 147, 219, 0.4);
    /* Nuevo color de brillo */
    border-color: #0093db;
    /* Nuevo color de borde */
}

.cavezeras{
    background-color: #0093db !important;
    color: white;
}

.no-pointer-cursor {
    cursor: default !important;
}