/* =============================================================================
   AppRex RRHH — Estilos de calendario y Gantt
   ============================================================================= */

/* --- Gantt --- */
.gantt-wrap {
    overflow-x: auto;
    border-radius: var(--radius);
    border: 1px solid var(--rex-gray-100);
}

.gantt-table {
    border-collapse: collapse;
    min-width: 100%;
    font-size: var(--text-xs);
}

.gantt-table th {
    background: var(--rex-purple);
    color: var(--rex-white);
    padding: .4rem .6rem;
    font-weight: 600;
    white-space: nowrap;
    border: 1px solid var(--rex-purple-dark);
    text-align: center;
}

.gantt-table th.col-nombre {
    text-align: left;
    min-width: 160px;
    position: sticky;
    left: 0;
    z-index: 2;
}

.gantt-table td {
    padding: .3rem .4rem;
    border: 1px solid var(--rex-gray-100);
    white-space: nowrap;
    vertical-align: middle;
    height: 36px;
}

.gantt-table td.col-nombre {
    font-weight: 600;
    background: var(--rex-white);
    position: sticky;
    left: 0;
    z-index: 1;
    min-width: 160px;
    border-right: 2px solid var(--rex-gray-300);
}

.gantt-table tr:hover td { background: var(--rex-gray-50); }
.gantt-table tr:hover td.col-nombre { background: var(--rex-gray-50); }

/* Día de hoy */
.gantt-table td.gantt-hoy {
    background: rgba(250, 204, 21, .18) !important;
    border-left: 2px solid var(--rex-yellow-dark);
    border-right: 2px solid var(--rex-yellow-dark);
}

/* Feriado */
.gantt-table td.gantt-feriado,
.gantt-table th.gantt-feriado {
    background: rgba(107, 33, 168, .06);
}

/* Fin de semana */
.gantt-table td.gantt-finde,
.gantt-table th.gantt-finde {
    background: #F0EDFB;
}

/* Abreviatura de día de semana (fila superior del header) */
.gantt-table th.gantt-th-ds {
    font-size: .65rem;
    font-weight: 500;
    opacity: .7;
    padding: .15rem .4rem;
    border-bottom: none;
}

/* Texto dentro de la celda de licencia */
.gantt-cell-lic {
    font-size: .6rem;
    font-weight: 700;
    letter-spacing: .02em;
    padding: 0 2px;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    max-width: 100%;
    height: 22px;
    border-radius: 3px;
    display: block;
    opacity: .9;
}

/* --- Filtros de calendario --- */
.calendario-filtros {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.calendario-nav {
    display: flex;
    align-items: center;
    gap: .5rem;
}

.calendario-nav .mes-label {
    font-weight: 700;
    font-size: var(--text-lg);
    color: var(--rex-purple-dark);
    min-width: 160px;
    text-align: center;
}

/* --- Leyenda de colores --- */
.leyenda {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem 1.25rem;
    align-items: center;
    font-size: var(--text-xs);
    color: var(--rex-gray-600);
}

.leyenda-item {
    display: flex;
    align-items: center;
    gap: .4rem;
}

.leyenda-color {
    width: 14px;
    height: 14px;
    border-radius: 3px;
    flex-shrink: 0;
}
