/* =====================================================================
   Momentum — estilos del módulo de Finanzas
   Reutiliza los tokens de styles.css (mismo documento).
   ===================================================================== */

/* cabecera: selector de mes + sub-pestañas */
.fin-bar { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-bottom: 22px; }
.fin-month { display: inline-flex; align-items: center; gap: 4px; background: var(--surface); border: 1px solid var(--border); border-radius: 999px; padding: 4px; }
.fin-month button { width: 30px; height: 30px; border: 0; background: transparent; color: var(--text-soft); border-radius: 50%; font-size: 16px; transition: background var(--speed); }
.fin-month button:hover { background: var(--surface-2); color: var(--text); }
.fin-month-label { min-width: 132px; text-align: center; font-weight: 650; font-size: 14.5px; text-transform: capitalize; }

.fin-tabs { display: flex; gap: 4px; flex-wrap: wrap; }
.fin-tab { border: 0; background: transparent; color: var(--text-soft); padding: 8px 13px; border-radius: 999px; font-size: 14px; font-weight: 550; transition: background var(--speed), color var(--speed); }
.fin-tab:hover { background: var(--surface-2); color: var(--text); }
.fin-tab.is-active { background: var(--accent); color: #fff; }

/* rejilla de tarjetas */
.fin-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 16px; }
.fin-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: 20px; }
.fin-card.col-12 { grid-column: span 12; }
.fin-card.col-8 { grid-column: span 8; }
.fin-card.col-6 { grid-column: span 6; }
.fin-card.col-5 { grid-column: span 5; }
.fin-card.col-7 { grid-column: span 7; }
.fin-card.col-4 { grid-column: span 4; }
.fin-card-title { font-size: 12.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--text-faint); margin-bottom: 14px; }

/* saldo grande */
.fin-balance { }
.fin-balance .bal-label { font-size: 13px; color: var(--text-soft); }
.fin-balance .bal-num { font-size: 38px; font-weight: 780; letter-spacing: -.025em; line-height: 1.1; margin: 2px 0 14px; }
.fin-balance .bal-num.pos { color: var(--ok); }
.fin-balance .bal-num.neg { color: var(--danger); }
.fin-io { display: flex; gap: 22px; }
.fin-io > div { flex: 1; }
.fin-io .io-label { font-size: 12px; color: var(--text-faint); display: flex; align-items: center; gap: 6px; }
.fin-io .io-num { font-size: 19px; font-weight: 700; margin-top: 2px; }
.io-dot { width: 9px; height: 9px; border-radius: 50%; }
.io-in { background: var(--ok); }
.io-out { background: var(--danger); }

/* donut */
.donut-wrap { position: relative; width: 180px; height: 180px; flex-shrink: 0; margin: 0 auto; }
.donut { display: block; }
.donut-center { position: absolute; inset: 0; display: grid; place-items: center; text-align: center; }
.donut-center .dc-num { font-size: 21px; font-weight: 750; }
.donut-center .dc-lbl { font-size: 11px; color: var(--text-faint); }
.cat-split { display: flex; gap: 22px; align-items: center; flex-wrap: wrap; }
.fin-legend { flex: 1; min-width: 180px; display: flex; flex-direction: column; gap: 8px; }
.leg-item { display: flex; align-items: center; gap: 9px; font-size: 13.5px; }
.leg-dot { width: 11px; height: 11px; border-radius: 3px; flex-shrink: 0; }
.leg-name { flex: 1; }
.leg-val { font-weight: 650; }
.leg-pct { color: var(--text-faint); font-size: 12px; min-width: 38px; text-align: right; }

/* barras mensuales */
.bars { display: flex; align-items: flex-end; gap: 10px; height: 150px; padding-top: 8px; }
.bar-col { flex: 1; display: flex; flex-direction: column; align-items: center; height: 100%; gap: 6px; }
.bar-pair { flex: 1; display: flex; align-items: flex-end; gap: 4px; width: 100%; justify-content: center; }
.bar { width: 38%; max-width: 22px; border-radius: 5px 5px 0 0; min-height: 2px; transition: height .5s var(--ease); }
.bar-income { background: var(--ok); }
.bar-expense { background: var(--danger); }
.bar-label { font-size: 11px; color: var(--text-faint); text-transform: capitalize; }

/* leyenda ingreso/gasto */
.mini-legend { display: flex; gap: 16px; margin-top: 12px; font-size: 12.5px; color: var(--text-soft); }
.mini-legend span { display: inline-flex; align-items: center; gap: 6px; }

/* presupuesto 50/30/20 */
.budget-row { margin-bottom: 18px; }
.budget-head { display: flex; align-items: baseline; gap: 8px; margin-bottom: 7px; }
.budget-name { font-weight: 650; }
.budget-sub { color: var(--text-faint); font-size: 12.5px; }
.budget-amounts { margin-left: auto; font-size: 13.5px; }
.budget-amounts .over { color: var(--danger); font-weight: 650; }
.bar-track { height: 11px; background: var(--surface-2); border-radius: 6px; overflow: hidden; }
.bar-fill { height: 100%; width: 0; border-radius: 6px; transition: width .6s var(--ease); }

/* lista de movimientos */
.tx-list { display: flex; flex-direction: column; }
.tx-date { font-size: 12px; font-weight: 700; color: var(--text-faint); text-transform: uppercase; letter-spacing: .05em; margin: 16px 2px 6px; }
.tx { display: flex; align-items: center; gap: 13px; padding: 10px 8px; border-radius: var(--radius-sm); transition: background var(--speed); }
.tx:hover { background: var(--surface-2); }
.tx-ico { width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; font-size: 18px; flex-shrink: 0; background: var(--surface-2); }
.tx-main { flex: 1; min-width: 0; }
.tx-cat { font-weight: 550; }
.tx-note { font-size: 12.5px; color: var(--text-faint); }
.tx-amount { font-weight: 700; font-variant-numeric: tabular-nums; white-space: nowrap; }
.tx-amount.exp { color: var(--text); }
.tx-amount.inc { color: var(--ok); }
.tx-del { opacity: 0; }
.tx:hover .tx-del { opacity: 1; }
.tx-main[data-fin] { cursor: pointer; border-radius: var(--radius-sm); }
.tx-acct { font-size: 11px; font-weight: 600; color: var(--text-soft); background: var(--surface-2); border-radius: 999px; padding: 1px 8px; margin-left: 6px; white-space: nowrap; }
.tx-amount.xfer { color: var(--text-faint) !important; font-weight: 600; }

/* chips de filtro por cuenta */
.acct-chips { display: flex; gap: 6px; flex-wrap: wrap; margin: 4px 0 12px; }
.acct-chip { border: 1px solid var(--border); background: var(--surface); color: var(--text-soft); padding: 5px 13px; border-radius: 999px; font-size: 13px; font-weight: 550; transition: background var(--speed), color var(--speed), border-color var(--speed); }
.acct-chip:hover { background: var(--surface-2); color: var(--text); }
.acct-chip.is-on { background: var(--accent); border-color: var(--accent); color: #fff; }

/* formulario de alta rápido */
.fin-form { display: flex; gap: 10px; flex-wrap: wrap; align-items: flex-end; }
.fin-field { display: flex; flex-direction: column; gap: 5px; }
.fin-field label { font-size: 12px; font-weight: 600; color: var(--text-soft); }
.fin-input, .fin-select {
  border: 1px solid var(--border); background: var(--surface-2); color: var(--text);
  border-radius: var(--radius-sm); padding: 9px 11px; font-size: 14.5px; outline: none;
  transition: border-color var(--speed), background var(--speed);
}
.fin-input:focus, .fin-select:focus { border-color: var(--accent); background: var(--surface); }
.fin-amount { width: 120px; font-weight: 650; }
.type-toggle { display: inline-flex; background: var(--surface-2); border-radius: var(--radius-sm); padding: 3px; }
.type-toggle button { border: 0; background: transparent; color: var(--text-soft); padding: 7px 13px; border-radius: 7px; font-size: 13.5px; font-weight: 600; transition: all var(--speed); }
.type-toggle button.is-on { background: var(--surface); color: var(--text); box-shadow: var(--shadow-sm); }
.type-toggle button.exp.is-on { color: var(--danger); }
.type-toggle button.inc.is-on { color: var(--ok); }

/* metas de ahorro */
.goal { padding: 16px 18px; margin-bottom: 14px; }
.goal-top { display: flex; align-items: center; gap: 12px; }
.goal-name { font-weight: 650; font-size: 16px; }
.goal-amt { margin-left: auto; font-weight: 650; }
.goal-amt small { color: var(--text-faint); font-weight: 500; }
.goal-bar { margin-top: 12px; height: 12px; background: var(--surface-2); border-radius: 7px; overflow: hidden; }
.goal-fill { height: 100%; width: 0; border-radius: 7px; transition: width .6s var(--ease); }
.goal-foot { display: flex; align-items: center; gap: 8px; margin-top: 11px; }
.goal-pct { font-size: 12.5px; color: var(--text-faint); }

/* patrimonio neto */
.nw-num { font-size: 34px; font-weight: 780; letter-spacing: -.02em; margin: 2px 0 6px; }
.nw-bar { display: flex; height: 14px; border-radius: 7px; overflow: hidden; background: var(--surface-2); margin: 14px 0 6px; }
.nw-assets { background: var(--ok); }
.nw-debts { background: var(--danger); }
.acct-row { display: flex; align-items: center; gap: 12px; padding: 11px 4px; border-bottom: 1px solid var(--border); }
.acct-row:last-child { border-bottom: 0; }
.acct-name { flex: 1; }
.acct-bal { font-weight: 650; font-variant-numeric: tabular-nums; }
.acct-bal.debt { color: var(--danger); }

.chart-empty { padding: 30px; text-align: center; color: var(--text-faint); font-size: 14px; }

/* importador CSV */
.imp-maps { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin-top: 16px; }
.imp-maps .fin-select { width: 100%; }
.imp-summary { margin: 16px 0 8px; font-size: 13.5px; color: var(--text-soft); }
.imp-preview { max-height: 320px; overflow: auto; border: 1px solid var(--border); border-radius: var(--radius-sm); }
.imp-row { display: flex; align-items: center; gap: 10px; padding: 8px 12px; border-bottom: 1px solid var(--border); font-size: 13.5px; }
.imp-row:last-child { border-bottom: 0; }
.imp-row.is-dup { opacity: .5; }
.imp-date { color: var(--text-faint); font-variant-numeric: tabular-nums; white-space: nowrap; }
.imp-cat { width: 20px; text-align: center; }
.imp-concept { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.imp-amt { font-weight: 650; font-variant-numeric: tabular-nums; white-space: nowrap; }
.imp-amt.inc { color: var(--ok); }
.imp-dup { font-size: 11px; color: var(--warn); border: 1px solid var(--border); border-radius: 999px; padding: 1px 7px; white-space: nowrap; }
.imp-more { margin-top: 8px; font-size: 12.5px; color: var(--text-faint); text-align: center; }

/* responsive */
@media (max-width: 760px) {
  .fin-card.col-8, .fin-card.col-6, .fin-card.col-5, .fin-card.col-7, .fin-card.col-4 { grid-column: span 12; }
  .cat-split { flex-direction: column; }
  .donut-wrap { margin: 0 auto; }
}
