/* ============================================================
 * Barra de organización reutilizable para listados
 * Colores de la app (var(--color-primary) = #0265bd) — tono claro
 * Sticky: baja con la página
 * ============================================================ */

/* Tono azul secundario de la barra (mismo tono en ambos modos: un sky-blue
   que funciona sobre fondo claro y oscuro sin tener que cambiar las alphas). */
:root {
  --bl-accent: #7dbef5;
  --bl-accent-soft: rgba(125, 190, 245, 0.18);
  --bl-accent-softer: rgba(125, 190, 245, 0.09);
  --bl-accent-line: rgba(125, 190, 245, 0.32);
}
/* Dark mode: las variables son las mismas, ya contrastan bien sobre ambos fondos */

.bl-container {
  /* Scroll natural con el contenido (descendía "por la tabla"): NO sticky.
     El header sí es sticky (top:0) y mantiene la back button siempre visible. */
  position: relative;
  z-index: 2;
  width: 100%;
  margin-bottom: 12px;
  font-family: inherit;
  color: var(--color-text);
  background: var(--color-bg);
  /* Heredar esquinas redondeadas de la card para que encaje arriba */
  border-top-left-radius: inherit;
  border-top-right-radius: inherit;
}

/* Sombra sutil cuando la barra se queda pegada arriba */
.bl-container::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -8px;
  height: 8px;
  pointer-events: none;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.06), transparent);
  opacity: 0;
  transition: opacity 0.2s ease;
}
.bl-container.bl-stuck::after { opacity: 1; }

/* === Barra principal — banda header dentro de la card (un solo frame) === */
.bl-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  background: linear-gradient(180deg, var(--bl-accent-soft), var(--bl-accent-softer));
  border: none;
  border-bottom: 1px solid var(--bl-accent-line);
  border-top-left-radius: inherit;
  border-top-right-radius: inherit;
  min-height: 46px;
  box-shadow: none;
}

.bl-title {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--bl-accent);
  white-space: nowrap;
  letter-spacing: 0.1px;
}

.bl-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  padding: 2px 9px;
  background: var(--bl-accent);
  color: #fff;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 600;
  line-height: 1.45;
}

.bl-sep {
  width: 1px;
  height: 18px;
  background: var(--bl-accent-line);
  flex-shrink: 0;
}

.bl-total-label {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  white-space: nowrap;
}

.bl-total-value {
  font-weight: 600;
  font-size: 0.92rem;
  color: var(--color-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bl-spacer {
  flex: 1 1 auto;
  min-width: 4px;
}

/* === Buscador (input + botón) integrado en la barra === */
.bl-search {
  display: flex;
  align-items: stretch;
  flex-shrink: 0;
  margin-right: 8px;
  gap: 0;
}
.bl-search-input {
  padding: 5px 10px;
  background: var(--color-bg);
  border: 1px solid var(--bl-accent-line);
  border-right: none;
  border-radius: 6px 0 0 6px;
  color: var(--color-text);
  font-size: 0.82rem;
  font-family: inherit;
  outline: none;
  width: 150px;
  height: 30px;
  transition: border-color 0.15s, width 0.2s ease, box-shadow 0.15s;
}
.bl-search-input:focus {
  border-color: var(--bl-accent);
  width: 220px;
  box-shadow: 0 0 0 3px var(--bl-accent-soft);
}
.bl-search-input::placeholder { color: var(--color-text-light); }
.bl-search-btn {
  position: relative;
  height: 30px;
  width: 32px;
  padding: 0;
  background: transparent;
  border: 1px solid var(--bl-accent-line);
  border-radius: 0 6px 6px 0;
  color: var(--bl-accent);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  flex-shrink: 0;
}
/* Puntito indicador cuando hay búsqueda activa (mismo estilo que filter/sort) */
.bl-search-btn.bl-has-dot .bl-dot { display: block; }
.bl-search-btn:hover {
  background: var(--bl-accent-soft);
  border-color: var(--bl-accent);
}

/* Botón cerrar búsqueda — solo visible en móvil cuando search-mode activo */
.bl-search-close {
  display: none;
  height: 30px;
  width: 32px;
  padding: 0;
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  color: var(--color-text-muted);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  transition: all 0.15s;
  margin-right: 6px;
  flex-shrink: 0;
}
.bl-search-close:hover {
  border-color: #c62828;
  color: #c62828;
  background: #fde8e8;
}

/* === Botones de icono (estilo .btn-accion de la app) === */
.bl-icon-group {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}

.bl-icon-btn {
  position: relative;
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  background: transparent;
  border: 1px solid var(--bl-accent-line);
  border-radius: 8px;
  color: var(--bl-accent);
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.15s;
  font-size: 0.9rem;
  line-height: 1;
}

.bl-icon-btn:not(.bl-static):hover {
  background: var(--bl-accent-soft);
  border-color: var(--bl-accent);
  transform: scale(1.05);
}

/* .bl-static: sin interacción (indicador informativo), sin hover, cursor normal.
   Los colores de estado (np-sync-ok, etc.) siguen funcionando tal cual. */
.bl-icon-btn.bl-static {
  cursor: default;
}

.bl-icon-btn.bl-active {
  background: var(--bl-accent);
  border-color: var(--bl-accent);
  color: #fff;
  box-shadow: 0 2px 6px rgba(45, 86, 133, 0.35);
}

/* Reset global (separado visualmente del grupo) */
.bl-reset-all {
  margin-left: 8px;
  color: var(--color-text-muted);
  border-color: var(--color-border);
}
.bl-reset-all:hover {
  color: #c62828;
  border-color: #e57373;
  background: #fde8e8;
}

/* === Toggle (Pendientes / Pagados, etc.) — botones segmentados === */
.bl-toggle {
  display: inline-flex;
  gap: 0;
  border: 1px solid var(--bl-accent-line);
  border-radius: 999px;
  padding: 2px;
  background: var(--color-bg);
}
.bl-toggle-btn {
  background: transparent;
  border: none;
  padding: 4px 12px;
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--color-text-muted);
  cursor: pointer;
  border-radius: 999px;
  transition: background 0.15s, color 0.15s;
  font-family: inherit;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.bl-toggle-btn .bi { font-size: 0.85rem; }
.bl-toggle-btn:hover {
  color: var(--bl-accent);
}
.bl-toggle-btn.bl-toggle-active {
  background: var(--bl-accent);
  color: #fff;
  font-weight: 600;
}

/* === Toggle compacto en select (cobros: Pendientes/Pagados/Todos) ===
   Pill con fondo accent suave, borde accent y texto accent. Mismo tono que
   .bl-count pero con flecha y texto, así queda visualmente alineado con la
   barra y se distingue como acción interactiva (no un dato). */
.bl-toggle-select {
  border: 1.5px solid var(--bl-accent);
  border-radius: 999px;
  padding: 4px 26px 4px 12px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--bl-accent);
  background: var(--bl-accent-soft);
  cursor: pointer;
  font-family: inherit;
  flex-shrink: 0;
  line-height: 1.2;
  letter-spacing: 0.1px;
  transition: background 0.15s, border-color 0.15s, transform 0.1s;
  /* Flecha custom: chevron en color accent */
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%237dbef5'><path d='M4 6l4 4 4-4'/></svg>");
  background-repeat: no-repeat;
  background-position: right 8px center;
  background-size: 12px 12px;
}
.bl-toggle-select:hover {
  background: var(--bl-accent);
  color: #fff;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ffffff'><path d='M4 6l4 4 4-4'/></svg>");
  background-repeat: no-repeat;
  background-position: right 8px center;
  background-size: 12px 12px;
}
.bl-toggle-select:focus {
  outline: none;
  box-shadow: 0 0 0 3px var(--bl-accent-soft);
}
.bl-toggle-select option {
  /* En el dropdown nativo dejamos colores normales (no accent) por legibilidad */
  background: var(--color-bg);
  color: var(--color-text);
}

/* === Kebab (3 puntos) en .bl-icon-group: en desktop oculto.
   En móvil se muestra y oculta los 3 botones individuales (filter/sort/export);
   al pulsarlo despliega un dropdown vertical con esos 3 botones. === */
.bl-icon-more { display: none; }

/* === Label "Pagado" en filas de cobros (no es un botón, no hover) ===
   Reemplaza al botón disabled que se usaba antes para indicar el estado. */
.venc-pagado-label {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.78rem;
  font-weight: 600;
  color: #27ae60;
  cursor: default;
  user-select: none;
  white-space: nowrap;
}
.venc-pagado-label i { font-size: 0.95rem; }

.bl-icon-btn .bi {
  font-size: 0.95rem;
}

.bl-dot {
  position: absolute;
  top: 3px;
  right: 3px;
  width: 7px;
  height: 7px;
  background: #ff9800;
  border: 1.5px solid var(--color-bg);
  border-radius: 50%;
  display: none;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.05);
}

.bl-icon-btn.bl-has-dot .bl-dot { display: block; }
.bl-icon-btn.bl-active.bl-has-dot .bl-dot {
  border-color: var(--color-primary);
}

/* === Paneles desplegables === */
.bl-panel {
  display: none;
  padding: 14px 16px;
  background: var(--color-bg);
  border: none;
  border-bottom: 1px solid var(--bl-accent-line);
  border-radius: 0;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.04);
  animation: blSlideIn 0.18s ease;
}

.bl-panel.bl-open { display: block; }

@keyframes blSlideIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.bl-panel-title {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--bl-accent);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  margin-bottom: 10px;
}

/* === Pills (operaciones / orden / estado) — estilo app === */
.bl-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.bl-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 13px;
  background: transparent;
  border: 1px solid var(--bl-accent-line);
  border-radius: 999px;
  color: var(--color-text-muted);
  font-size: 0.82rem;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  user-select: none;
}

@media (hover: hover) {
  .bl-pill:hover {
    background: var(--bl-accent-soft);
    border-color: var(--bl-accent);
    color: var(--bl-accent);
  }
}

.bl-pill.bl-pill-active {
  background: var(--bl-accent-soft);
  border-color: var(--bl-accent);
  color: var(--bl-accent);
  font-weight: 600;
}

.bl-pill-dir {
  font-size: 0.72rem;
  opacity: 0.95;
  font-weight: 700;
}

/* === Panel operaciones: resultado === */
.bl-op-result {
  margin-top: 12px;
  padding: 12px 14px;
  background: linear-gradient(180deg, var(--bl-accent-soft), var(--bl-accent-softer));
  border-left: 3px solid var(--bl-accent);
  border-radius: var(--radius-sm);
  display: none;
}

.bl-op-result.bl-visible { display: block; }

.bl-op-result-value {
  font-size: 20px;
  font-weight: 600;
  color: var(--bl-accent);
  line-height: 1.2;
}

.bl-op-result-sub {
  font-size: 11px;
  color: var(--color-text-muted);
  margin-top: 3px;
}

/* === Panel filtros: grid === */
.bl-filter-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px 12px;
}

.bl-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.bl-field-label {
  font-size: 0.72rem;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  font-weight: 500;
}

.bl-field-input {
  padding: 7px 10px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  color: var(--color-text);
  font-size: 0.85rem;
  font-family: inherit;
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.bl-field-input:focus {
  border-color: var(--bl-accent);
  box-shadow: 0 0 0 3px var(--bl-accent-soft);
}

.bl-field-input::placeholder {
  color: var(--color-text-light);
}

.bl-field-estado { grid-column: 1 / -1; }

.bl-estado-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.bl-panel-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--color-border);
}

/* === Botones del panel — estilo app === */
.bl-btn {
  padding: 7px 16px;
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-text-muted);
  border-radius: var(--radius-sm);
  font-size: 0.82rem;
  cursor: pointer;
  transition: all 0.15s;
  font-family: inherit;
}

.bl-btn:hover {
  border-color: var(--bl-accent);
  color: var(--bl-accent);
  background: var(--bl-accent-softer);
}

.bl-btn-primary {
  background: var(--bl-accent);
  border-color: var(--bl-accent);
  color: #fff;
  font-weight: 600;
  box-shadow: 0 2px 6px rgba(45, 86, 133, 0.3);
}

.bl-btn-primary:hover {
  filter: brightness(1.1);
  color: #fff;
  background: var(--bl-accent);
  border-color: var(--bl-accent);
  box-shadow: 0 3px 10px rgba(45, 86, 133, 0.4);
}

/* Dark mode manual */
.dark-mode .bl-panel {
  background: var(--color-bg-muted);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.25);
}
/* Dark mode auto según sistema */
@media (prefers-color-scheme: dark) {
  :root:not(.light-mode) .bl-panel {
    background: var(--color-bg-muted);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.25);
  }
}

/* ============================================================
 * Modales/drawers de Filtrar, Ordenar, Exportar
 * ============================================================ */

.bl-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.18s ease;
  backdrop-filter: blur(2px);
}
.bl-overlay.bl-open { opacity: 1; }

/* Drawer derecho (filtros) */
.bl-overlay-drawer {
  justify-content: flex-end;
  align-items: stretch;
}

.bl-modal {
  background: var(--color-bg);
  color: var(--color-text);
  border-radius: 12px;
  width: 520px;
  max-width: calc(100vw - 32px);
  max-height: calc(100vh - 32px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.25);
  display: flex;
  flex-direction: column;
  transform: scale(0.95);
  transition: transform 0.18s ease;
  overflow: hidden;
}
.bl-overlay.bl-open .bl-modal { transform: scale(1); }

.bl-modal-drawer {
  width: 440px;
  height: 100%;
  max-height: 100%;
  border-radius: 12px 0 0 12px;
  transform: translateX(30px);
}
.bl-overlay.bl-open .bl-modal-drawer { transform: translateX(0); }

.bl-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--bl-accent-line);
  background: linear-gradient(180deg, var(--bl-accent-soft), var(--bl-accent-softer));
}
.bl-modal-header h3 {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  color: var(--bl-accent);
}
.bl-modal-header-actions {
  display: flex;
  align-items: center;
  gap: 4px;
}
.bl-modal-reset {
  background: none;
  border: 1px solid transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  width: 30px; height: 30px;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  transition: all 0.15s;
}
.bl-modal-reset:hover {
  color: #c62828;
  border-color: #e57373;
  background: #fde8e8;
}
.bl-modal-close {
  background: none;
  border: none;
  font-size: 1.4rem;
  line-height: 1;
  color: var(--color-text-muted);
  cursor: pointer;
  padding: 0 6px;
  border-radius: 4px;
  transition: background 0.15s;
}
.bl-modal-close:hover { background: var(--bl-accent-soft); color: var(--bl-accent); }

.bl-modal-body {
  padding: 16px 18px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1 1 auto;
}

.bl-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 12px 18px;
  border-top: 1px solid var(--color-border);
  background: var(--color-bg-muted);
}

.bl-modal-body .bl-field { display: flex; flex-direction: column; gap: 6px; }
.bl-modal-body .bl-field-label { font-size: 0.78rem; font-weight: 600; }

.bl-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
/* Asegura que selects/inputs dentro del modal nunca exceden el ancho de su columna,
   independientemente de la longitud del contenido (forma pago/tesorería con etiquetas
   largas hacían que el grid se desequilibrara). */
.bl-modal-body select.bl-field-input,
.bl-modal-body input.bl-field-input {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

/* === Filtro Cliente: input con autocomplete + dropdown de resultados === */
.bl-field-cliente { grid-column: 1 / -1; }  /* fila completa cuando esté en grid */
.bl-cliente-wrap { position: relative; }
.bl-cliente-input { padding-right: 32px; }   /* hueco para la "X" de limpiar */
.bl-cliente-clear {
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  width: 22px; height: 22px;
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.bl-cliente-clear:hover { background: var(--bl-accent-soft); color: var(--bl-accent); }

.bl-cliente-results {
  position: absolute;
  top: calc(100% + 4px);
  left: 0; right: 0;
  background: var(--color-bg);
  border: 1px solid var(--bl-accent-line);
  border-radius: 8px;
  box-shadow: 0 6px 16px rgba(0,0,0,0.12);
  max-height: 200px;
  overflow-y: auto;
  z-index: 50;
}
@media (min-width: 768px) {
  .bl-cliente-results { max-height: 160px; }
}
.bl-cliente-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 6px 12px;
  cursor: pointer;
  font-size: 0.85rem;
  border-bottom: 1px solid var(--color-border-light, rgba(0,0,0,0.06));
}
.bl-cliente-option:last-child { border-bottom: none; }
.bl-cliente-option:hover { background: var(--bl-accent-soft); }
.bl-cliente-option-nombre {
  flex: 1; min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--color-text);
}
.bl-cliente-option-codigo {
  flex-shrink: 0;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--bl-accent);
  background: var(--bl-accent-soft);
  padding: 2px 8px;
  border-radius: 999px;
  white-space: nowrap;
}
.bl-cliente-empty {
  padding: 10px 12px;
  font-size: 0.82rem;
  color: var(--color-text-muted);
  text-align: center;
}

/* Pills checkbox (filtro de estado) */
.bl-check-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.bl-check-pill {
  display: inline-flex;
  align-items: center;
  padding: 5px 12px;
  border: 1px solid var(--bl-accent-line);
  border-radius: 999px;
  font-size: 0.82rem;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: all 0.15s;
  user-select: none;
}
.bl-check-pill:hover { background: var(--bl-accent-soft); color: var(--bl-accent); }
.bl-check-pill input { display: none; }
.bl-check-pill:has(input:checked) {
  background: var(--bl-accent-soft);
  border-color: var(--bl-accent);
  color: var(--bl-accent);
  font-weight: 600;
}

/* Ordenar */
.bl-sort-list { display: flex; flex-direction: column; gap: 8px; }
.bl-sort-row {
  display: grid;
  grid-template-columns: 24px 1fr 150px auto;
  gap: 8px;
  align-items: center;
}
.bl-sort-dir { max-width: 150px; }
.bl-sort-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px; height: 22px;
  background: var(--bl-accent);
  color: #fff;
  border-radius: 50%;
  font-size: 0.75rem;
  font-weight: 600;
}
.bl-icon-mini {
  width: 30px; height: 30px;
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  font-size: 1.2rem; line-height: 1;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: all 0.15s;
}
.bl-icon-mini:hover { background: #fde8e8; border-color: #e57373; color: #c62828; }

.bl-btn-ghost {
  background: transparent;
  border: 1px dashed var(--bl-accent-line);
  color: var(--bl-accent);
  margin-top: 4px;
}
.bl-btn-ghost:hover {
  background: var(--bl-accent-soft);
  border-color: var(--bl-accent);
  border-style: solid;
}

.bl-hint {
  font-size: 0.78rem;
  color: var(--color-text-muted);
  margin: 0;
}

/* Radios */
.bl-radio-group { display: flex; gap: 14px; flex-wrap: wrap; }
.bl-radio {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.88rem;
  cursor: pointer;
}
.bl-radio input { accent-color: var(--bl-accent); }

/* Animación de entrada del menú kebab (móvil) — fade + slide-down con stagger.
   Está fuera del @media porque @keyframes a nivel global se aplica donde se referencie. */
@keyframes bl-menu-in {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* === Responsive === */
@media (max-width: 768px) {
  /* Evitar scroll horizontal en móvil + matar la sombra sticky que creaba una franja gris */
  .bl-container {
    max-width: 100%;
    width: 100%;
    overflow: hidden;
    box-sizing: border-box;
  }
  .bl-container::after { display: none; }
  .bl-bar {
    padding: 7px 8px;
    gap: 6px;
    max-width: 100%;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
    flex-wrap: wrap;       /* si algo no cabe, que envuelva a la siguiente línea */
    row-gap: 6px;
  }
  /* Ahorrar espacio en móvil (ventas): ocultar título y etiqueta "Total" */
  .bl-title { display: none; }
  /* Separador entre cantidad y precio: visible en móvil, compacto */
  .bl-sep { display: inline-block; height: 14px; margin: 0 1px; }
  .bl-total-label { display: none; }

  /* En la página de carritos SÍ queremos mantener título y pill visibles
     (no hay "importe total" que quite espacio, así que caben de sobra) */
  .carr-page .bl-title {
    display: inline-flex;
    font-size: 0.92rem;
    font-weight: 600;
    gap: 6px;
  }
  .carr-page .carr-card-estado { flex-shrink: 0; }
  .bl-count { font-size: 0.72rem; flex-shrink: 0; }
  /* El importe se encoge si hace falta, con elipsis, para no sacar el reset fuera */
  .bl-total-value {
    font-size: 0.82rem;
    min-width: 0;
    max-width: 100%;
    flex: 0 1 auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .bl-filter-grid { grid-template-columns: 1fr; }
  .bl-panel { padding: 12px; }
  .bl-icon-btn { width: 28px; height: 28px; flex-shrink: 0; }
  .bl-icon-btn .bi { font-size: 0.82rem; }
  /* Toggle (Pendientes/Pagados): solo iconos en móvil para que entre todo en una línea */
  .bl-toggle-btn .bl-toggle-label { display: none; }
  .bl-toggle-btn { padding: 3px 6px; gap: 0; }
  .bl-toggle-btn .bi { font-size: 0.78rem; }
  .bl-toggle { padding: 1px; }
  .bl-reset-all { margin-left: 4px; }
  .bl-icon-group { gap: 3px; flex-shrink: 0; }
  /* Búsqueda al mismo gap que los iconos: quitamos margin-right para que el gap
     base del .bl-bar separe igual a los 4 botones (búsqueda + filtros + orden + exportar). */
  .bl-search { margin-right: 0; flex-shrink: 0; }
  .bl-search-btn { width: 28px; height: 28px; }

  /* Móvil: input colapsado por defecto, solo la lupa visible.
     Al pulsarla → JS añade .bl-search-mode al contenedor y se expande. */
  .bl-search-input { display: none; }
  .bl-search-btn {
    border-radius: 6px;
    border: 1px solid var(--bl-accent-line);
  }

  /* Modo búsqueda activo en móvil */
  .bl-container.bl-search-mode .bl-title,
  .bl-container.bl-search-mode .bl-count,
  .bl-container.bl-search-mode .bl-sep,
  .bl-container.bl-search-mode .bl-total-label,
  .bl-container.bl-search-mode .bl-total-value,
  .bl-container.bl-search-mode .bl-spacer,
  .bl-container.bl-search-mode .bl-icon-group,
  .bl-container.bl-search-mode .bl-toggle,
  .bl-container.bl-search-mode .bl-toggle-select,
  .bl-container.bl-search-mode .bl-reset-all { display: none; }
  /* Móvil: select algo más compacto para que entre todo en la barra */
  .bl-toggle-select {
    font-size: 0.72rem;
    padding: 3px 20px 3px 9px;
    background-position: right 6px center;
    background-size: 10px 10px;
  }
  /* Cuando hay select, el título "Cobros" ocupa hueco innecesario en móvil
     (el desplegable indica el contexto). Lo escondemos para que entren los iconos. */
  .bl-bar:has(.bl-toggle-select) .bl-title { display: none; }
  /* Apretamos la barra: gap menor entre elementos para que entre el reset */
  .bl-bar:has(.bl-toggle-select) { gap: 6px; padding-left: 10px; padding-right: 10px; }
  .bl-bar:has(.bl-toggle-select) .bl-spacer { min-width: 0; flex-shrink: 1; }

  /* === Kebab móvil: oculta los 3 iconos individuales y muestra el kebab === */
  .bl-icon-group [data-bl-open] { display: none; }
  .bl-icon-more { display: inline-flex; }
  .bl-icon-group { position: relative; }

  /* Al abrirse, los 3 botones aparecen como un panel UNIFICADO debajo del kebab.
     position:fixed escapa de cualquier overflow:hidden en ancestros.
     Las coords (--bl-menu-top/--bl-menu-right) las calcula JS desde getBoundingClientRect.
     Estilo de panel: ancho/borde común; los segmentos del medio sin border top/bottom
     para que parezca una caja continua. */
  .bl-icon-group.bl-icon-group-open [data-bl-open] {
    display: inline-flex !important;
    position: fixed !important;
    right: var(--bl-menu-right, 10px);
    width: 38px;
    height: 38px;
    background: var(--color-bg);
    border-left: 1px solid var(--bl-accent-line);
    border-right: 1px solid var(--bl-accent-line);
    border-top: none;
    border-bottom: none;
    border-radius: 0;
    z-index: 9999;
    /* Sombra solo en el panel completo (no por elemento) */
    box-shadow: none;
    /* Animación de entrada con stagger (cada botón cae con un pequeño delay) */
    animation: bl-menu-in 0.18s ease backwards;
  }
  /* Primer botón: borde superior + esquinas redondeadas arriba + sombra que cubre el panel */
  .bl-icon-group.bl-icon-group-open [data-bl-open="filter"] {
    top: calc(var(--bl-menu-top, 50px) + 0px);
    border-top: 1px solid var(--bl-accent-line);
    border-radius: 8px 8px 0 0;
    box-shadow: 0 4px 14px rgba(0,0,0,0.18);
    animation-delay: 0s;
  }
  /* Segundo botón: sin borders horizontales, "cose" el panel */
  .bl-icon-group.bl-icon-group-open [data-bl-open="sort"] {
    top: calc(var(--bl-menu-top, 50px) + 38px);
    box-shadow: 4px 0 14px rgba(0,0,0,0.06), -4px 0 14px rgba(0,0,0,0.06);
    animation-delay: 0.04s;
  }
  /* Último botón: borde inferior + esquinas redondeadas abajo */
  .bl-icon-group.bl-icon-group-open [data-bl-open="export"] {
    top: calc(var(--bl-menu-top, 50px) + 76px);
    border-bottom: 1px solid var(--bl-accent-line);
    border-radius: 0 0 8px 8px;
    box-shadow: 0 4px 14px rgba(0,0,0,0.18);
    animation-delay: 0.08s;
  }
  /* Hover: tinta accent suave (independiente del color base del .bl-icon-btn) */
  .bl-icon-group.bl-icon-group-open [data-bl-open]:hover {
    background: var(--bl-accent-soft);
    color: var(--bl-accent);
  }
  /* Kebab marcado como activo cuando el menú está abierto */
  .bl-icon-group.bl-icon-group-open .bl-icon-more {
    background: var(--bl-accent-soft);
    color: var(--bl-accent);
  }
  .bl-container.bl-search-mode .bl-search {
    flex: 1 1 auto;
    margin-right: 0;
    width: 100%;
  }
  .bl-container.bl-search-mode .bl-search-close { display: inline-flex; }
  .bl-container.bl-search-mode .bl-search-input {
    display: block;
    flex: 1 1 auto;
    width: 100%;
    min-width: 0;
    border: 1px solid var(--bl-accent-line);
    border-right: none;
    border-radius: 6px 0 0 6px;
  }
  .bl-container.bl-search-mode .bl-search-input:focus { width: 100%; }
  .bl-container.bl-search-mode .bl-search-btn {
    border-radius: 0 6px 6px 0;
    border-left: none;
  }

  /* Listado de ventas a ancho completo en móvil (como carritos).
     El wrapper es <div class="card shadow-2-strong px-2 px-lg-0"> — al quitarle
     el padding y los bordes laterales, las filas llegan a los bordes de pantalla. */
  .card:has(> .bl-container) {
    padding-left: 0 !important;
    padding-right: 0 !important;
    border-radius: 0;
    border-left-width: 0;
    border-right-width: 0;
  }

  /* Modales: en móvil suben desde abajo (bottom-sheet) — mismo patrón que el resto
     de modales Bootstrap del proyecto. Animación de translateY al abrir. */
  .bl-overlay {
    padding: 0;
    align-items: flex-end;
    justify-content: stretch;
  }
  .bl-overlay-drawer {
    align-items: flex-end;
    justify-content: stretch;
  }
  .bl-modal,
  .bl-modal-drawer {
    width: 100%;
    max-width: 100%;
    max-height: 90vh;
    border-radius: 16px 16px 0 0;
    transform: translateY(100%);
    height: auto;
  }
  .bl-overlay.bl-open .bl-modal,
  .bl-overlay.bl-open .bl-modal-drawer {
    transform: translateY(0);
  }
  .bl-modal-header { padding: 12px 14px; }
  .bl-modal-header h3 { font-size: 0.95rem; }
  .bl-modal-body { padding: 14px; gap: 12px; }
  .bl-modal-footer { padding: 10px 14px; }
  .bl-grid-2 { grid-template-columns: 1fr; gap: 8px; }
  .bl-check-pill { padding: 6px 12px; font-size: 0.8rem; }
  .bl-sort-row { grid-template-columns: 22px 1fr 1fr 32px; gap: 6px; }
  .bl-sort-row .bl-field-input { padding: 6px 8px; font-size: 0.82rem; }
  .bl-sort-dir { max-width: none; }
  .bl-icon-mini { width: 32px; height: 32px; }
  .bl-btn { padding: 8px 14px; font-size: 0.85rem; }
  .bl-modal-reset, .bl-modal-close { width: 34px; height: 34px; }
}
