/* ═══════════════════════════════════════════════════════════
   Component: .filters-bar  v3
   Barra de filtros – patrón fintech (Stripe / Mercury).
   Layout de dos filas con separador visual:
     Fila 1 → búsqueda prominente + contador de resultados
     Fila 2 → filtros categóricos + rango de fechas
   ═══════════════════════════════════════════════════════════ */

/* ── Contenedor principal ──────────────────────────────── */
.filters-bar {
    background: #fafbfc;
    border: 1px solid #e3e6eb;
    border-radius: .625rem;
    padding: 0;
    overflow: hidden;
}

/* ══════════════════════════════════════════════════════════
   FILA 1: Búsqueda + resultados
   ══════════════════════════════════════════════════════════ */
.filters-bar .filter-search-row {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: .875rem 1.125rem;
    background: #fff;
    border-bottom: 1px solid #eef0f3;
}

/* Input group de búsqueda */
.filters-bar .filter-search-row .input-group {
    flex: 1 1 auto;
    max-width: 380px;
    height: 2.25rem;
    display: flex !important;
    flex-wrap: nowrap;
    border-radius: .4375rem;
    overflow: hidden;
    border: 1px solid #d4d8df;
    transition: border-color .15s ease, box-shadow .15s ease;
}

.filters-bar .filter-search-row .input-group:focus-within {
    border-color: #3C76F2;
    box-shadow: 0 0 0 3px rgba(60, 118, 242, .1);
}

.filters-bar .filter-search-row .input-group .input-group-text {
    display: flex !important;
    align-items: center;
    height: 100%;
    padding: 0 .625rem;
    font-size: .875rem;
    background: #fff;
    border: none;
    color: #9ca3af;
}

.filters-bar .filter-search-row .input-group .form-control {
    width: auto !important;
    float: none !important;
    display: block !important;
    flex: 1 1 auto;
    height: 100%;
    font-size: .8125rem;
    border: none;
    box-shadow: none !important;
    padding-left: 0;
    color: #374151;
}

.filters-bar .filter-search-row .input-group .form-control::placeholder {
    color: #b0b6c0;
}

/* Status: resultados + limpiar */
.filters-bar .filter-status {
    display: flex;
    align-items: center;
    gap: .5rem;
    white-space: nowrap;
    margin-left: auto;
}

.filters-bar .filter-counter {
    font-size: .8125rem;
    color: #6b7280;
    display: inline-flex;
    align-items: center;
    gap: .3125rem;
}

.filters-bar .filter-counter i {
    color: #3C76F2;
    font-size: .8125rem;
}

.filters-bar .filter-status-sep {
    width: 1px;
    height: .875rem;
    background: #d1d5db;
}

.filters-bar .filter-clear-btn {
    background: #fee2e2;
    border: 1px solid #fecaca;
    width: 1.5rem;
    height: 1.5rem;
    border-radius: 50%;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: background .15s ease, border-color .15s ease;
}

.filters-bar .filter-clear-btn:hover {
    background: #fecaca;
    border-color: #fca5a5;
}

.filters-bar .filter-clear-btn img {
    opacity: .6;
    filter: invert(22%) sepia(89%) saturate(2196%) hue-rotate(345deg) brightness(88%) contrast(92%);
    transition: opacity .15s ease;
}

.filters-bar .filter-clear-btn:hover img {
    opacity: .85;
}

/* ══════════════════════════════════════════════════════════
   FILA 2: Filtros categóricos + fechas
   ══════════════════════════════════════════════════════════ */
.filters-bar .filter-row {
    display: flex;
    align-items: flex-end;
    gap: 1rem;
    padding: .75rem 1.125rem;
    flex-wrap: wrap;
}

/* Cada campo de filtro */
.filters-bar .filter-item {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

/* Label del filtro */
.filters-bar .filter-item label {
    font-size: .625rem !important;
    font-weight: 700;
    color: #8892a2;
    margin-bottom: .3125rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    line-height: 1;
}

/* Controles uniformes */
.filters-bar .filter-row .form-control,
.filters-bar .filter-row .form-select {
    height: 2rem;
    min-width: 7.5rem;
    font-size: .8125rem;
    color: #374151;
    background-color: #fff;
    border: 1px solid #d4d8df;
    border-radius: .375rem;
    padding: .25rem .625rem;
    transition: border-color .15s ease, box-shadow .15s ease;
}

.filters-bar .filter-row .form-select {
    padding-right: 2rem;
}

.filters-bar .filter-row .form-control:focus,
.filters-bar .filter-row .form-select:focus {
    border-color: #3C76F2;
    box-shadow: 0 0 0 3px rgba(60, 118, 242, .1);
}

/* Separador vertical entre grupos */
.filters-bar .filter-divider {
    width: 1px;
    background: #e3e6eb;
    align-self: stretch;
    margin: 0 .25rem;
    min-height: 2rem;
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════ */

/* Tablet */
@media (max-width: 991.98px) {
    .filters-bar .filter-divider { display: none; }
    .filters-bar .filter-row {
        gap: .625rem;
    }
    .filters-bar .filter-item {
        flex: 1 1 calc(33.333% - .5rem);
        min-width: 0;
    }
    .filters-bar .filter-item .form-control,
    .filters-bar .filter-item .form-select {
        width: 100%;
        min-width: 0;
    }
    .filters-bar .filter-search-row .input-group {
        max-width: 100%;
    }
}

/* Mobile */
@media (max-width: 575.98px) {
    .filters-bar .filter-item {
        flex: 1 1 100%;
    }
    .filters-bar .filter-search-row {
        flex-wrap: wrap;
        gap: .5rem;
    }
    .filters-bar .filter-search-row .input-group {
        max-width: 100%;
        flex: 1 1 100%;
    }
    .filters-bar .filter-status {
        flex: 1 1 100%;
        justify-content: center;
    }
    .filters-bar .filter-row {
        padding: .625rem .875rem;
    }
}
