/* Estilos para la cabecera del módulo de reportes */

.report-header {
    background-color: var(--primary-solid-color, #343a40); /* Usa la variable --primary-color */
    color: white;
    padding: 0.75rem 1.25rem;
    border-radius: 0.375rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
}

.report-title {
    font-size: 1.5rem;
    margin: 0;
    flex-shrink: 0;
}

.report-controls {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-grow: 1;
    justify-content: flex-end;
    flex-wrap: nowrap; /* Fuerza a que los controles se mantengan en una sola línea */
    overflow-x: auto;  /* Añade scroll horizontal si los controles no caben */
    padding-bottom: 5px; /* Pequeño espacio para que el scrollbar no se pegue a los controles */
}

/* Estilos para la cabecera y pie de la tabla de reportes */
/* Hacemos la regla más específica para ganar la batalla contra Bootstrap en los thead pegajosos */
/* La clave es aplicar el color a las celdas (th/td) DENTRO del thead/tfoot, no al elemento contenedor. */
thead.table-custom-header-footer th,
tfoot.table-custom-header-footer td {
    /* 
      Usa la variable --primary-solid-color definida globalmente por main.js.
      Si no existe, usa un color oscuro por defecto.
    */
    background-color: var(--primary-solid-color, #343a40);
    color: white;
}

/* Borde superior para separar visualmente las ventas en el reporte detallado */
.sale-separator > td {
    border-top: 2px solid #a9a9a9;
}

/* Contenedor para la tabla con scroll y altura máxima */
.table-container-scroll {
    max-height: 75vh; /* Altura máxima para ver aprox. 30 filas antes de necesitar scroll */
    overflow-y: auto;
    position: relative; /* Necesario para que el thead sticky funcione correctamente dentro */
}

/* Estilos para el reporte de compras colapsable */
.expand-button {
    width: 24px;
    height: 24px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.details-table-container td {
    padding: 0 !important;
    border: 0;
}

/* Estilos para el ranking de vendedores */
.progress-bar {
    color: white;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.6);
    font-size: 0.8rem;
    white-space: nowrap;
    display: flex;
    align-items: center;
    justify-content: center;
}