/* ==========================================================================
   Financiero — page-specific styles
   Usa tokens del Adventio Design System + primitives .adv-*
   Namespace: .fin-page-* (layout/estructura)
   ========================================================================== */

/* ==========================================================================
   1. Layout general
   ========================================================================== */
.fin-page-layout {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--surface-app);
  overflow: hidden;
}

/* ==========================================================================
   2. Top nav (Resumen · Cuentas · Gastos · Proveedores · Vendedores · Pagos)
   ========================================================================== */
.fin-page-topnav {
  display: flex;
  align-items: center;
  gap: var(--space-0-5);
  padding: var(--space-2-5) var(--space-5) 0;
  background: var(--surface-card);
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.fin-page-toptab {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  font: var(--type-label-sm);
  color: var(--text-muted);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  border-radius: 0;
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--duration-fast) var(--ease-standard),
              border-color var(--duration-fast) var(--ease-standard);
}
.fin-page-toptab:hover { color: var(--text-default); }
.fin-page-toptab.is-active {
  color: var(--text-strong);
  font-weight: var(--weight-semibold);
  border-bottom-color: var(--action-primary);
}
.fin-page-toptab__icon { display: inline-flex; }
.fin-page-toptab__icon svg { width: 16px; height: 16px; display: block; }

/* ==========================================================================
   3. Views
   ========================================================================== */
.fin-page-view { display: flex; flex: 1; overflow: hidden; min-height: 0; }
.fin-page-view.is-hidden { display: none !important; }

/* ==========================================================================
   4. Sidebar (Proveedores / Vendedores / Cuentas)
   ========================================================================== */
.fin-page-sidebar {
  width: 240px;
  min-width: 240px;
  background: var(--surface-card);
  border-right: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.fin-page-sidebar__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-4) var(--space-3);
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}
.fin-page-sidebar__title {
  font: var(--type-eyebrow);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-muted);
}

.fin-page-sidebar__list {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-1-5) 0;
}

.fin-page-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-0-5);
  padding: var(--space-2) var(--space-4);
  cursor: pointer;
  border-left: 2px solid transparent;
  transition: background var(--duration-fast) var(--ease-standard),
              border-color var(--duration-fast) var(--ease-standard);
}
.fin-page-row:hover { background: var(--surface-hover); }
.fin-page-row.is-active {
  background: var(--surface-brand-soft);
  border-left-color: var(--action-accent);
}
.fin-page-row__name {
  font: var(--type-label-sm);
  color: var(--text-default);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.fin-page-row.is-active .fin-page-row__name { color: var(--text-brand); }
.fin-page-row__sub {
  font: var(--type-caption);
  color: var(--text-subtle);
}
.fin-page-row__balance {
  font: var(--type-caption);
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.fin-page-row__balance.is-debe   { color: var(--status-danger-fg); }
.fin-page-row__balance.is-cobrar { color: var(--status-success-fg); }
.fin-page-row__balance.is-ok     { color: var(--text-disabled); }

.fin-page-row__pct {
  display: inline-flex;
  align-items: center;
  font: var(--weight-semibold) var(--text-2xs);
  color: var(--fern-700);
  background: var(--status-success-bg);
  border: 1px solid var(--status-success-bd);
  border-radius: var(--radius-pill);
  padding: 1px var(--space-2);
}

.fin-page-sidebar__empty {
  padding: var(--space-5) var(--space-4);
  font: var(--type-caption);
  color: var(--text-subtle);
  font-style: italic;
}

/* ==========================================================================
   5. Main panel (proveedor / vendedor detail)
   ========================================================================== */
.fin-page-main {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.fin-page-empty {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2-5);
  color: var(--text-subtle);
  font: var(--type-body);
}
.fin-page-empty svg { width: 40px; height: 40px; color: var(--text-disabled); }

.fin-page-detail-header {
  padding: var(--space-5) var(--space-6) 0;
  flex-shrink: 0;
}
.fin-page-detail-header__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}
.fin-page-detail-header__title {
  font: var(--type-h1);
  color: var(--text-strong);
  margin: 0 0 var(--space-1);
}
.fin-page-detail-header__meta {
  font: var(--type-body-sm);
  color: var(--text-muted);
  margin: 0;
}
.fin-page-detail-header__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-1-5);
}
.fin-page-detail-header__chip {
  display: inline-flex;
  align-items: center;
  font: var(--type-caption);
  color: var(--text-muted);
  background: var(--surface-sunken);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-sm);
  padding: 2px var(--space-2);
}
.fin-page-detail-header__chip--comision {
  background: var(--status-success-bg);
  color: var(--fern-700);
  border-color: var(--status-success-bd);
  font-weight: var(--weight-semibold);
}

.fin-page-balance-total {
  text-align: right;
  flex-shrink: 0;
}
.fin-page-balance-total__lbl {
  display: block;
  font: var(--type-eyebrow);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: var(--space-0-5);
}
.fin-page-balance-total__val {
  font: var(--weight-bold) var(--text-xl)/var(--leading-snug) var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.fin-page-balance-total__val.is-debe   { color: var(--status-danger-fg); }
.fin-page-balance-total__val.is-cobrar { color: var(--status-success-fg); }
.fin-page-balance-total__val.is-ok     { color: var(--text-disabled); font-size: var(--text-md); font-weight: var(--weight-regular); }

/* ==========================================================================
   6. Tabs de folio
   ========================================================================== */
.fin-page-tabs {
  display: flex;
  align-items: flex-end;
  gap: var(--space-0-5);
  border-bottom: 1px solid var(--border-subtle);
  padding: 0 var(--space-6);
}
.fin-page-tab {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: var(--space-2) var(--space-4);
  font: var(--type-label-sm);
  color: var(--text-muted);
  border: 1px solid transparent;
  border-bottom: none;
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  cursor: pointer;
  background: transparent;
  margin-bottom: -1px;
  white-space: nowrap;
  transition: color var(--duration-fast) var(--ease-standard),
              background var(--duration-fast) var(--ease-standard);
}
.fin-page-tab:hover { color: var(--text-default); background: var(--surface-hover); }
.fin-page-tab.is-active {
  background: var(--surface-card);
  color: var(--text-strong);
  font-weight: var(--weight-semibold);
  border-color: var(--border-subtle);
  border-bottom-color: var(--surface-card);
  position: relative;
  z-index: 1;
}
.fin-page-tab__balance {
  font: var(--weight-medium) var(--text-2xs);
  font-family: var(--font-mono);
  margin-top: 2px;
}
.fin-page-tab__balance.is-debe   { color: var(--status-danger-fg); }
.fin-page-tab__balance.is-cobrar { color: var(--status-success-fg); }
.fin-page-tab__balance.is-ok     { color: var(--text-disabled); }

.fin-page-tab-add {
  padding: var(--space-1-5) var(--space-2-5);
  color: var(--text-subtle);
  background: none;
  border: none;
  cursor: pointer;
  border-radius: var(--radius-sm);
  line-height: 1;
  margin-bottom: -1px;
  display: inline-flex;
  align-items: center;
  transition: color var(--duration-fast) var(--ease-standard),
              background var(--duration-fast) var(--ease-standard);
}
.fin-page-tab-add:hover { color: var(--text-default); background: var(--surface-active); }
.fin-page-tab-add svg { width: 16px; height: 16px; display: block; }

.fin-page-tab-empty {
  padding: var(--space-2-5) var(--space-4);
  font: var(--type-body-sm);
  color: var(--text-subtle);
  font-style: italic;
}

/* ==========================================================================
   7. Folio body (balance + acciones + stats + tabla)
   ========================================================================== */
.fin-page-folio-body {
  padding: var(--space-5) var(--space-6) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.fin-page-folio-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}
.fin-page-folio-summary__balance-lbl {
  display: block;
  font: var(--type-eyebrow);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: var(--space-0-5);
}
.fin-page-folio-summary__balance-val {
  font: var(--weight-bold) var(--text-lg)/var(--leading-snug) var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.fin-page-folio-summary__balance-val.is-debe   { color: var(--status-danger-fg); }
.fin-page-folio-summary__balance-val.is-cobrar { color: var(--status-success-fg); }
.fin-page-folio-summary__balance-val.is-ok     { color: var(--text-disabled); font-size: var(--text-sm); font-weight: var(--weight-regular); }
.fin-page-folio-summary__actions { display: flex; gap: var(--space-2); }

/* ==========================================================================
   8. Folio stats (3 columnas: total / pagado / pendiente)
   ========================================================================== */
.fin-page-stats {
  display: flex;
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
}
.fin-page-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: var(--space-3) var(--space-4);
  border-right: 1px solid var(--border-subtle);
}
.fin-page-stat:last-child { border-right: none; }
.fin-page-stat__lbl {
  font: var(--type-eyebrow);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-muted);
}
.fin-page-stat__val {
  font: var(--weight-bold) var(--text-md)/var(--leading-snug) var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--text-strong);
}
.fin-page-stat__val.is-positivo { color: var(--status-danger-fg); }
.fin-page-stat__val.is-negativo { color: var(--status-success-fg); }
.fin-page-stat__val.is-cero     { color: var(--text-disabled); font-size: var(--text-xs); font-weight: var(--weight-regular); }

/* ==========================================================================
   9. Tabla de movimientos
   ========================================================================== */
.fin-page-table-wrap {
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
}
.fin-page-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--surface-card);
}
.fin-page-table th {
  text-align: left;
  font: var(--type-eyebrow);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  padding: var(--space-2-5) var(--space-4);
  background: var(--surface-sunken);
  border-bottom: 1px solid var(--border-subtle);
}
.fin-page-table td {
  padding: var(--space-2-5) var(--space-4);
  font: var(--type-body);
  color: var(--text-default);
  border-bottom: 1px solid var(--border-subtle);
  vertical-align: middle;
}
.fin-page-table tr:last-child td { border-bottom: none; }
.fin-page-table tbody tr:hover td { background: var(--surface-hover); }
.fin-page-table tr.is-pagado td { color: var(--text-disabled); }
.fin-page-table tr.is-pagado .fin-page-monto { color: var(--text-disabled) !important; }
.fin-page-table tr.is-ajustado td { color: var(--text-subtle); font-style: italic; }
.fin-page-table tr.is-anulado td { color: var(--text-disabled); text-decoration: line-through; }
.fin-page-table tr.is-conciliado td { background: var(--status-success-bg); }

.fin-page-table__empty {
  padding: var(--space-8);
  text-align: center;
  font: var(--type-body-sm);
  color: var(--text-subtle);
  background: var(--surface-card);
}

.fin-page-cell-date,
.fin-page-cell-meta {
  font: var(--type-caption);
  color: var(--text-subtle);
  white-space: nowrap;
}
.fin-page-cell-meta { white-space: normal; }
.fin-page-cell-concepto {
  color: var(--text-default);
}
.fin-page-cell-concepto__notas {
  font: var(--type-caption);
  color: var(--text-subtle);
  margin-top: 2px;
}

.fin-page-monto {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-weight: var(--weight-semibold);
  text-align: right;
  white-space: nowrap;
}
.fin-page-monto.is-egreso  { color: var(--status-danger-fg); }
.fin-page-monto.is-ingreso { color: var(--status-success-fg); }
.fin-page-monto.is-neutro  { color: var(--text-subtle); font-weight: var(--weight-regular); }

.fin-page-saldo {
  font: var(--weight-semibold) var(--text-sm);
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  text-align: right;
  white-space: nowrap;
}
.fin-page-saldo.is-positivo { color: var(--status-danger-fg); }
.fin-page-saldo.is-negativo { color: var(--status-success-fg); }
.fin-page-saldo.is-cero     { color: var(--text-disabled); }

.fin-page-saldada-row td {
  padding: var(--space-1) var(--space-4);
  background: var(--status-success-bg);
  border-top: 1px solid var(--status-success-bd);
  border-bottom: 1px solid var(--status-success-bd);
}
.fin-page-saldada-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1-5);
  font: var(--weight-semibold) var(--text-2xs);
  color: var(--fern-700);
  letter-spacing: var(--tracking-wide);
}
.fin-page-saldada-label svg { width: 12px; height: 12px; display: block; }

/* ==========================================================================
   10. Modal genérico (.fin-page-modal-*)
   ========================================================================== */
.fin-page-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(13, 24, 21, 0.32);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
}
.fin-page-modal-overlay.hidden { display: none; }

.fin-page-modal {
  background: var(--surface-card);
  border-radius: var(--radius-xl);
  width: 480px;
  max-width: 94vw;
  box-shadow: var(--shadow-overlay);
  display: flex;
  flex-direction: column;
  max-height: 90vh;
  overflow: hidden;
}
.fin-page-modal__header {
  padding: var(--space-5) var(--space-5) 0;
  flex-shrink: 0;
}
.fin-page-modal__title {
  font: var(--type-h3);
  color: var(--text-strong);
  margin: 0 0 var(--space-3);
}
.fin-page-modal__tabs {
  display: flex;
  border-bottom: 1px solid var(--border-subtle);
  margin: 0 var(--space-5);
}
.fin-page-modal__tab {
  padding: var(--space-2) var(--space-4);
  font: var(--type-label-sm);
  color: var(--text-subtle);
  border-bottom: 2px solid transparent;
  cursor: pointer;
  margin-bottom: -1px;
  transition: color var(--duration-fast) var(--ease-standard),
              border-color var(--duration-fast) var(--ease-standard);
}
.fin-page-modal__tab:hover { color: var(--text-default); }
.fin-page-modal__tab.is-active {
  color: var(--action-primary);
  border-bottom-color: var(--action-primary);
}
.fin-page-modal__body {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-4) var(--space-5);
}
.fin-page-modal__footer {
  padding: var(--space-3) var(--space-5) var(--space-5);
  border-top: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-shrink: 0;
}
.fin-page-modal__total {
  font: var(--type-body-sm);
  color: var(--text-default);
}
.fin-page-modal__total strong {
  font: var(--weight-semibold) var(--text-md);
  color: var(--text-strong);
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  margin-left: var(--space-1-5);
}
.fin-page-modal__total-hint {
  font: var(--type-caption);
  color: var(--text-subtle);
}
.fin-page-modal__actions { display: flex; gap: var(--space-2); }
.fin-page-modal__hint {
  font: var(--type-caption);
  color: var(--text-subtle);
  margin: var(--space-1) 0 0;
}
.fin-page-modal__label {
  display: block;
  font: var(--type-label-sm);
  color: var(--text-default);
  margin: var(--space-3-5) 0 var(--space-1);
}
.fin-page-modal__label:first-child { margin-top: 0; }

/* Cancel list inside modal */
.fin-page-cancel-list { display: flex; flex-direction: column; gap: var(--space-1-5); }
.fin-page-cancel-item {
  display: flex;
  align-items: center;
  gap: var(--space-2-5);
  padding: var(--space-2-5) var(--space-3);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-standard),
              border-color var(--duration-fast) var(--ease-standard);
}
.fin-page-cancel-item:hover { background: var(--surface-hover); }
.fin-page-cancel-item.is-selected {
  background: var(--surface-brand-soft);
  border-color: var(--border-brand);
}
.fin-page-cancel-item input[type="checkbox"] {
  width: 16px;
  height: 16px;
  cursor: pointer;
  flex-shrink: 0;
  accent-color: var(--action-primary);
}
.fin-page-cancel-item__info { flex: 1; min-width: 0; }
.fin-page-cancel-item__concepto {
  font: var(--type-label-sm);
  color: var(--text-default);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.fin-page-cancel-item__meta {
  font: var(--type-caption);
  color: var(--text-subtle);
  margin-top: 2px;
}
.fin-page-cancel-item__monto {
  font: var(--weight-semibold) var(--text-sm);
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  flex-shrink: 0;
}
.fin-page-cancel-item__monto.is-egreso  { color: var(--status-danger-fg); }
.fin-page-cancel-item__monto.is-ingreso { color: var(--status-success-fg); }
.fin-page-cancel-empty {
  padding: var(--space-5);
  text-align: center;
  font: var(--type-body-sm);
  color: var(--text-subtle);
}

/* Comprobante drop zone */
.fin-page-drop {
  display: block;
  border: 2px dashed var(--border-strong);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  text-align: center;
  font: var(--type-body-sm);
  color: var(--text-muted);
  cursor: pointer;
  transition: border-color var(--duration-fast) var(--ease-standard),
              color var(--duration-fast) var(--ease-standard);
}
.fin-page-drop:hover { border-color: var(--border-brand); color: var(--text-brand); }
.fin-page-drop input[type="file"] { display: none; }

.fin-page-drop__preview {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-2-5);
  background: var(--status-info-bg);
  border: 1px solid var(--status-info-bd);
  border-radius: var(--radius-md);
  font: var(--type-body-sm);
  color: var(--status-info-fg);
  margin-top: var(--space-1-5);
}
.fin-page-drop__preview span { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.fin-page-drop__preview button {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 2px;
  display: inline-flex;
  align-items: center;
}
.fin-page-drop__preview button:hover { color: var(--text-default); }
.fin-page-drop__preview svg { width: 14px; height: 14px; display: block; }

/* ==========================================================================
   11. Modal comprobante
   ========================================================================== */
.fin-page-comp-overlay {
  position: fixed;
  inset: 0;
  background: rgba(13, 24, 21, 0.32);
  z-index: var(--z-overlay);
  display: flex;
  align-items: center;
  justify-content: center;
}
.fin-page-comp {
  background: var(--surface-card);
  border-radius: var(--radius-xl);
  width: 580px;
  max-width: 95vw;
  max-height: 90vh;
  box-shadow: var(--shadow-overlay);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.fin-page-comp__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}
.fin-page-comp__title {
  font: var(--type-h4);
  color: var(--text-strong);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.fin-page-comp__meta {
  font: var(--type-caption);
  font-weight: var(--weight-regular);
  color: var(--text-subtle);
}
.fin-page-comp__body {
  flex: 1;
  overflow: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-5);
  background: var(--surface-sunken);
}
.fin-page-comp__body img {
  max-width: 100%;
  max-height: 60vh;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
}
.fin-page-comp__body iframe {
  width: 100%;
  height: 60vh;
  border: none;
  border-radius: var(--radius-md);
}
.fin-page-comp__footer {
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--border-subtle);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-shrink: 0;
  background: var(--surface-sunken);
}
.fin-page-comp__name {
  font: var(--type-body-sm);
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 300px;
}

/* ==========================================================================
   12. Modal anular
   ========================================================================== */
.fin-page-anular-overlay {
  position: fixed;
  inset: 0;
  background: rgba(13, 24, 21, 0.32);
  z-index: var(--z-toast);
  display: flex;
  align-items: center;
  justify-content: center;
}
.fin-page-anular {
  background: var(--surface-card);
  border-radius: var(--radius-xl);
  width: 380px;
  max-width: 94vw;
  box-shadow: var(--shadow-overlay);
  padding: var(--space-6) var(--space-6) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3-5);
}
.fin-page-anular__icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--status-danger-bg);
  color: var(--status-danger-fg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.fin-page-anular__icon svg { width: 20px; height: 20px; display: block; }
.fin-page-anular h3 { font: var(--type-h3); color: var(--text-strong); margin: 0; }
.fin-page-anular p {
  font: var(--type-body-sm);
  color: var(--text-muted);
  margin: 0;
  line-height: var(--leading-normal);
}
.fin-page-anular__detail {
  background: var(--surface-sunken);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: var(--space-2-5) var(--space-3-5);
  font: var(--type-body-sm);
  color: var(--text-muted);
}
.fin-page-anular__detail strong {
  color: var(--text-strong);
  font-weight: var(--weight-semibold);
}
.fin-page-anular__actions { display: flex; gap: var(--space-2-5); justify-content: flex-end; margin-top: var(--space-1); }

/* ==========================================================================
   13. Sub-vista Pagos
   ========================================================================== */
.fin-page-pagos {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-width: 0;
  background: var(--surface-app);
}

.fin-page-pagos__filters {
  background: var(--surface-card);
  border-bottom: 1px solid var(--border-subtle);
  padding: var(--space-3-5) var(--space-6);
  flex-shrink: 0;
}
.fin-page-pagos__filters-row {
  display: flex;
  align-items: flex-end;
  gap: var(--space-2-5);
  flex-wrap: wrap;
}
.fin-page-pagos__group { display: flex; flex-direction: column; gap: var(--space-1); }
.fin-page-pagos__group--search {
  position: relative;
  min-width: 240px;
  flex: 1;
}
.fin-page-pagos__search-icon {
  position: absolute;
  left: 11px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--text-subtle);
  display: inline-flex;
}
.fin-page-pagos__search-icon svg { width: 14px; height: 14px; display: block; }
.fin-page-pagos__search-input {
  padding-left: 32px !important;
}

.fin-page-pagos__summary {
  display: flex;
  gap: 0;
  padding: var(--space-3-5) var(--space-6);
  background: var(--surface-card);
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
  flex-wrap: wrap;
}
.fin-page-pagos__summary-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-0-5);
  padding: 0 var(--space-6) 0 0;
  margin-right: var(--space-6);
  border-right: 1px solid var(--border-subtle);
}
.fin-page-pagos__summary-item:last-child { border-right: none; }
.fin-page-pagos__summary-lbl {
  font: var(--type-eyebrow);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-muted);
}
.fin-page-pagos__summary-val {
  font: var(--weight-bold) var(--text-lg)/var(--leading-snug) var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--text-strong);
  letter-spacing: var(--tracking-tight);
}

.fin-page-pagos__table-wrap {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-5) var(--space-6) var(--space-6);
}

.fin-page-pagos__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: var(--space-16) var(--space-6);
  color: var(--text-subtle);
  font: var(--type-body);
  text-align: center;
}
.fin-page-pagos__empty svg { width: 36px; height: 36px; color: var(--text-disabled); }
.fin-page-pagos__empty p { margin: 0; color: var(--text-muted); }

.fin-page-pagos__reserva {
  font: var(--weight-semibold) var(--text-sm);
  font-family: var(--font-mono);
  color: var(--text-link);
  background: var(--status-info-bg);
  padding: 2px var(--space-1-5);
  border-radius: var(--radius-xs);
}
.fin-page-pagos__no-reserva { color: var(--text-disabled); font: var(--type-body-sm); }
.fin-page-pagos__concepto {
  max-width: 200px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--text-default);
  font: var(--type-body-sm);
}
.fin-page-pagos__comp-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-2-5);
  border: 1px solid var(--status-info-bd);
  border-radius: var(--radius-pill);
  font: var(--weight-semibold) var(--text-2xs);
  color: var(--status-info-fg);
  background: var(--status-info-bg);
  cursor: pointer;
  transition: var(--transition-control);
  white-space: nowrap;
}
.fin-page-pagos__comp-btn:hover {
  background: var(--sky-100);
  border-color: var(--sky-300);
}

/* ==========================================================================
   14. Sub-vista Gastos
   ========================================================================== */
.fin-page-gastos {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-width: 0;
  background: var(--surface-app);
}
.fin-page-gastos__tabs {
  display: flex;
  align-items: center;
  gap: var(--space-0-5);
  background: var(--surface-card);
  padding: var(--space-2-5) var(--space-6) 0;
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}
.fin-page-gastos__tab {
  padding: var(--space-2) var(--space-4);
  font: var(--type-label-sm);
  color: var(--text-muted);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  margin-bottom: -1px;
  border-radius: 0;
  white-space: nowrap;
  transition: color var(--duration-fast) var(--ease-standard);
}
.fin-page-gastos__tab:hover { color: var(--text-default); }
.fin-page-gastos__tab.is-active {
  color: var(--text-strong);
  font-weight: var(--weight-semibold);
  border-bottom-color: var(--action-primary);
}

.fin-page-gastos__filters {
  display: flex;
  align-items: flex-end;
  gap: var(--space-2-5);
  padding: var(--space-3-5) var(--space-6);
  background: var(--surface-card);
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
  flex-wrap: wrap;
}
.fin-page-gastos__summary {
  display: flex;
  gap: 0;
  padding: var(--space-3-5) var(--space-6);
  background: var(--surface-card);
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
  flex-wrap: wrap;
}
.fin-page-gastos__summary-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-0-5);
  padding: 0 var(--space-6) 0 0;
  margin-right: var(--space-6);
  border-right: 1px solid var(--border-subtle);
}
.fin-page-gastos__summary-item:last-child { border-right: none; }
.fin-page-gastos__summary-lbl {
  font: var(--type-eyebrow);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-muted);
}
.fin-page-gastos__summary-val {
  font: var(--weight-bold) var(--text-lg)/var(--leading-snug) var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--text-strong);
}
.fin-page-gastos__table-wrap {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-5) var(--space-6) var(--space-6);
}

.fin-page-gastos__resumen { padding: var(--space-5) var(--space-6); }
.fin-page-gastos__hero {
  background: var(--pine-700);
  color: var(--text-nav-strong);
  padding: var(--space-5) var(--space-6);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.fin-page-gastos__hero-lbl {
  font: var(--type-eyebrow);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.7);
}
.fin-page-gastos__hero-total {
  font: var(--weight-bold) var(--text-4xl)/var(--leading-tight) var(--font-display);
  font-variant-numeric: tabular-nums;
  margin-top: var(--space-1);
  letter-spacing: var(--tracking-tight);
}

.fin-page-gastos__cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-5);
}
.fin-page-gastos__cat-card {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-3-5) var(--space-4);
  box-shadow: var(--shadow-xs);
}
.fin-page-gastos__cat-name {
  font: var(--type-eyebrow);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: var(--space-1);
}
.fin-page-gastos__cat-total {
  font: var(--weight-bold) var(--text-lg)/var(--leading-snug) var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--text-strong);
}
.fin-page-gastos__cat-count {
  font: var(--type-caption);
  color: var(--text-subtle);
  margin-top: var(--space-0-5);
}

/* ==========================================================================
   15. Sub-vista Resumen (KPIs migrados a .adv-stat + dot de status)
   ========================================================================== */
.fin-page-resumen {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-5) var(--space-6);
  background: var(--surface-app);
}
.fin-page-resumen__header { margin-bottom: var(--space-5); }
.fin-page-resumen__kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-3-5);
  margin-bottom: var(--space-5);
}
.fin-page-resumen-kpi {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  box-shadow: var(--shadow-xs);
  display: flex;
  flex-direction: column;
  gap: var(--space-1-5);
}
.fin-page-resumen-kpi__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}
.fin-page-resumen-kpi__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.fin-page-resumen-kpi__dot--fern { background: var(--status-success-dot); }
.fin-page-resumen-kpi__dot--rust { background: var(--status-danger-dot); }
.fin-page-resumen-kpi__dot--pine { background: var(--status-brand-dot); }
.fin-page-resumen-kpi__dot--clay { background: var(--status-accent-dot); }
.fin-page-resumen-kpi__sub {
  font: var(--type-caption);
  color: var(--text-subtle);
}

.fin-page-resumen__alerts {
  background: var(--status-warning-bg);
  border: 1px solid var(--status-warning-bd);
  border-radius: var(--radius-md);
  padding: var(--space-3-5) var(--space-4);
  margin-bottom: var(--space-5);
}
.fin-page-resumen__alerts-title {
  font: var(--weight-semibold) var(--text-sm);
  color: var(--status-warning-fg);
  margin-bottom: var(--space-1-5);
}
.fin-page-resumen__alert-item {
  font: var(--type-body-sm);
  color: var(--text-muted);
  padding: 4px 0;
}

.fin-page-resumen__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}
@media (max-width: 900px) {
  .fin-page-resumen__grid { grid-template-columns: 1fr; }
}
.fin-page-resumen__section h3 {
  font: var(--type-h4);
  color: var(--text-strong);
  margin: 0 0 var(--space-3);
}

.fin-page-resumen__cuentas {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
}
.fin-page-resumen__cuenta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-subtle);
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-standard);
}
.fin-page-resumen__cuenta-row:last-child { border-bottom: none; }
.fin-page-resumen__cuenta-row:hover { background: var(--surface-hover); }
.fin-page-resumen__cuenta-info { display: flex; align-items: center; gap: var(--space-1-5); }
.fin-page-resumen__cuenta-nombre { font: var(--type-label-sm); color: var(--text-strong); }
.fin-page-resumen__cuenta-titular { font: var(--type-caption); color: var(--text-subtle); }
.fin-page-resumen__cuenta-nums { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.fin-page-resumen__cuenta-mes { font: var(--type-caption); color: var(--text-muted); }
.fin-page-resumen__cuenta-saldo {
  font: var(--weight-bold) var(--text-md);
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.fin-page-resumen__cuenta-saldo.is-pos { color: var(--text-brand); }
.fin-page-resumen__cuenta-saldo.is-neg { color: var(--status-danger-fg); }
.fin-page-resumen__cuenta-saldo.is-cero { color: var(--text-disabled); }

.fin-page-resumen__cats {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-4);
  box-shadow: var(--shadow-xs);
}
.fin-page-resumen__cat-row {
  display: grid;
  grid-template-columns: 140px 1fr 100px;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-1-5) 0;
}
.fin-page-resumen__cat-lbl { font: var(--type-body-sm); color: var(--text-default); }
.fin-page-resumen__cat-bar-wrap {
  background: var(--stone-200);
  height: 6px;
  border-radius: var(--radius-pill);
  overflow: hidden;
}
.fin-page-resumen__cat-bar {
  height: 100%;
  border-radius: var(--radius-pill);
}
.fin-page-resumen__cat-val {
  font: var(--weight-semibold) var(--type-body-sm);
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--text-strong);
  text-align: right;
}

/* ==========================================================================
   16. Cuentas (sub-vista montada dinámicamente)
   ========================================================================== */
.fin-page-cta-layout {
  display: flex;
  flex: 1;
  overflow: hidden;
  min-height: 0;
  background: var(--surface-app);
}
.fin-page-cta-main {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.fin-page-cta-alert {
  background: var(--status-warning-bg);
  border: 1px solid var(--status-warning-bd);
  color: var(--status-warning-fg);
  padding: var(--space-2-5) var(--space-3-5);
  border-radius: var(--radius-md);
  font: var(--type-label-sm);
  font-weight: var(--weight-medium);
  margin: 0 0 var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.fin-page-cta-alert svg { width: 16px; height: 16px; flex-shrink: 0; display: block; }

.fin-page-cuenta-color-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  vertical-align: middle;
  margin-right: var(--space-2);
}

.fin-page-gastos__group {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

/* ==========================================================================
   17. Vendedor — folio sin asignar
   ========================================================================== */
.fin-page-vnd-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2-5);
  padding: var(--space-10) var(--space-5);
  color: var(--text-subtle);
  font: var(--type-body);
  text-align: center;
}

/* ==========================================================================
   18. Botón "Anular" en filas (ghost danger)
   ========================================================================== */
.fin-page-btn-danger-ghost {
  background: var(--status-danger-bg);
  color: var(--status-danger-fg);
  border: 1px solid var(--status-danger-bd);
}
.fin-page-btn-danger-ghost:hover:not(:disabled) {
  background: var(--rust-100);
  border-color: var(--rust-300);
}

@media (max-width: 768px) {
  /* ── Top nav: scroll horizontal ── */
  .fin-page-topnav {
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
    gap: var(--space-0-5);
    padding: var(--space-2) var(--space-3);
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .fin-page-topnav::-webkit-scrollbar { display: none; }

  .fin-page-toptab {
    padding: var(--space-2) var(--space-3);
    font-size: 12px;
    flex-shrink: 0;
    min-height: 44px;
  }
  .fin-page-toptab__icon svg { width: 14px; height: 14px; }

  /* ── Sidebar views: stack en columna ── */
  .fin-page-view {
    flex-direction: column;
  }

  .fin-page-sidebar {
    width: 100%;
    min-width: 0;
    max-height: 40vh;
    border-right: none;
    border-bottom: 1px solid var(--border-subtle);
    flex-shrink: 0;
  }

  .fin-page-sidebar__head {
    padding: var(--space-3) var(--space-3);
  }

  .fin-page-sidebar__list {
    padding: var(--space-1) 0;
  }

  .fin-page-row {
    padding: var(--space-2) var(--space-3);
  }

  .fin-page-main {
    flex: 1;
    overflow-y: auto;
  }

  .fin-page-detail-header {
    padding: var(--space-4) var(--space-4) 0;
  }

  .fin-page-detail-header__top {
    flex-direction: column;
    gap: var(--space-2);
  }

  .fin-page-detail-header__title {
    font-size: var(--text-lg);
  }

  .fin-page-detail-header__chips {
    gap: var(--space-1-5);
  }

  /* ── Pagos: filtros en columna ── */
  .fin-page-pagos__filters {
    padding: var(--space-3) var(--space-3);
  }

  .fin-page-pagos__filters-row {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-3);
  }

  .fin-page-pagos__group {
    width: 100%;
  }

  .fin-page-pagos__group--search {
    min-width: 0;
  }

  .fin-page-pagos__search-input {
    width: 100%;
    font-size: 16px;
  }

  .fin-page-pagos__group input,
  .fin-page-pagos__group select {
    width: 100%;
    font-size: 16px;
  }

  /* ── Pagos: summary ajustado ── */
  .fin-page-pagos__summary {
    padding: var(--space-2) var(--space-3);
    gap: var(--space-3);
    justify-content: flex-start;
  }

  .fin-page-pagos__summary-item {
    margin-right: var(--space-3);
    padding-right: var(--space-3);
    border-right-width: 1px;
  }

  .fin-page-pagos__summary-val {
    font-size: var(--text-base);
  }

  /* ── Pagos: tabla ── */
  .fin-page-pagos__table-wrap {
    padding: var(--space-3) var(--space-2) var(--space-4);
  }

  .fin-page-table-wrap {
    border-radius: var(--radius-md);
  }

  .fin-page-table th,
  .fin-page-table td {
    padding: var(--space-2) var(--space-2-5);
    font-size: 12px;
    white-space: nowrap;
  }

  /* ── Stats grid: wrap ── */
  .fin-page-stats {
    flex-wrap: wrap;
    gap: 0;
  }

  .fin-page-stat {
    flex: 1 1 120px;
    min-width: 0;
    padding: var(--space-2) var(--space-3);
  }

  /* ── Modal: footer stack ── */
  .fin-page-modal__footer {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4) var(--space-4);
  }

  .fin-page-modal__total {
    text-align: center;
  }

  .fin-page-modal__actions {
    width: 100%;
    justify-content: stretch;
  }

  .fin-page-modal__actions button {
    flex: 1;
    min-height: 44px;
  }

  .fin-page-modal {
    width: 100vw;
    max-width: none;
    max-height: 100vh;
    border-radius: 0;
    height: 100vh;
  }

  .fin-page-modal__body {
    flex: 1;
    overflow-y: auto;
  }

  .fin-page-modal__tabs {
    overflow-x: auto;
    white-space: nowrap;
    margin: 0 var(--space-3);
  }

  .fin-page-resumen__cat-row {
    grid-template-columns: 1fr;
    gap: var(--space-1);
  }

  /* ── Gastos: tabs scroll + filtros columna ── */
  .fin-page-gastos__tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding: var(--space-2) var(--space-3) 0;
    scrollbar-width: none;
  }
  .fin-page-gastos__tabs::-webkit-scrollbar { display: none; }

  .fin-page-gastos__tab {
    padding: var(--space-2) var(--space-3);
    font-size: 12px;
    flex-shrink: 0;
    min-height: 44px;
  }

  .fin-page-gastos__filters {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-3);
  }

  .fin-page-gastos__filters .adv-input,
  .fin-page-gastos__filters .adv-select {
    width: 100%;
    font-size: 16px;
  }

  .fin-page-gastos__summary {
    padding: var(--space-2) var(--space-3);
    gap: var(--space-3);
  }

  .fin-page-gastos__summary-item {
    margin-right: var(--space-3);
    padding-right: var(--space-3);
  }

  .fin-page-gastos__summary-val {
    font-size: var(--text-base);
  }

  .fin-page-gastos__table-wrap {
    padding: var(--space-3) var(--space-2) var(--space-4);
  }

  .fin-page-gastos__resumen {
    padding: var(--space-3) var(--space-3);
    overflow-y: auto;
  }

  .fin-page-gastos__hero {
    padding: var(--space-4) var(--space-4);
  }

  .fin-page-gastos__hero-total {
    font-size: var(--text-2xl);
  }

  /* ── Resumen: KPIs ── */
  .fin-page-resumen-kpi {
    padding: var(--space-3) var(--space-4);
  }

  .fin-page-resumen__header {
    margin-bottom: var(--space-3);
  }

  .fin-page-resumen__alerts {
    padding: var(--space-3) var(--space-3);
  }

  .fin-page-resumen__cuenta-row {
    padding: var(--space-2) var(--space-3);
    flex-wrap: wrap;
    gap: var(--space-1);
  }
}
