/* ════════════════════════════════════════════════════════
   Módulo Finanzas Pedro — tema claro/crema, scopeado.
   ════════════════════════════════════════════════════════ */
.finanzas-root * { box-sizing: border-box; margin: 0; padding: 0; }
.finanzas-root {
  font-family: system-ui, sans-serif;
  background: #f0efe9; color: #1a1a1a;
  padding: 0 0 40px; border-radius: 12px; overflow: hidden;
}
.finanzas-root .fz-head { background: #fff; border-bottom: .5px solid rgba(0,0,0,.12); padding: 14px 16px 10px; }
.finanzas-root .fz-head h2 { font-size: 17px; font-weight: 600; }
.finanzas-root .fz-head p { font-size: 12px; color: #666; margin-top: 2px; }

.finanzas-root .fz-tabs { display: flex; gap: 6px; padding: 10px 16px 0; flex-wrap: wrap; }
.finanzas-root .fz-tab { padding: 8px 12px; border-radius: 8px; font-size: 13px; border: .5px solid rgba(0,0,0,.15); background: transparent; color: #666; cursor: pointer; }
.finanzas-root .fz-tab.active { background: #2e7d5b; color: #fff; border-color: #2e7d5b; }

.finanzas-root .fz-content { padding: 12px 16px; }
.finanzas-root .fz-card { background: #fff; border: .5px solid rgba(0,0,0,.13); border-radius: 12px; padding: 14px; margin-bottom: 10px; }
.finanzas-root .fz-block-title { font-size: 13px; font-weight: 700; margin-bottom: 8px; }

.finanzas-root table { width: 100%; border-collapse: collapse; font-size: 13px; }
.finanzas-root th { text-align: left; font-size: 10px; text-transform: uppercase; letter-spacing: .05em; color: #999; padding: 4px 6px; border-bottom: .5px solid rgba(0,0,0,.1); }
.finanzas-root td { padding: 6px; border-bottom: .5px solid rgba(0,0,0,.06); vertical-align: middle; }
.finanzas-root .fz-usd { color: #888; font-size: 11px; }
.finanzas-root .fz-amt-ing { color: #1d9e75; font-weight: 600; }
.finanzas-root .fz-amt-eg { color: #ef4444; font-weight: 600; }
.finanzas-root .fz-amt-deu { color: #f97316; font-weight: 600; }
.finanzas-root .fz-total { font-weight: 700; text-align: right; padding-top: 8px; }

/* Fila "hecha" (cobrado / pagado): se distingue a primera vista */
.finanzas-root tr.fz-done td { background: #c9edd5; }
.finanzas-root tr.fz-done td:first-child { box-shadow: inset 5px 0 0 #1f7a4d; font-weight: 700; }
.finanzas-root .fz-check { color: #1f7a4d; font-weight: 800; font-size: 12px; margin-left: 3px; }
.finanzas-root tr.fz-done .fz-select { background: #1f7a4d; color: #fff; border-color: #1f7a4d; font-weight: 700; }

.finanzas-root .fz-semaforo { border-radius: 10px; padding: 14px; text-align: center; margin-bottom: 10px; }
.finanzas-root .fz-semaforo.ok { background: #e6f5ee; color: #12704f; }
.finanzas-root .fz-semaforo.justo { background: #fbf3d9; color: #7a5c00; }
.finanzas-root .fz-semaforo.quiebre { background: #fde4e4; color: #a11; }

.finanzas-root .fz-input, .finanzas-root .fz-select {
  border: .5px solid rgba(0,0,0,.22); border-radius: 6px; padding: 5px 7px;
  font-size: 13px; background: #f8f8f5; color: #1a1a1a; outline: none; width: 100%;
}
.finanzas-root .fz-input:focus, .finanzas-root .fz-select:focus { border-color: #2e7d5b; }
.finanzas-root .fz-btn { background: #2e7d5b; color: #fff; border: none; border-radius: 8px; padding: 9px 14px; font-size: 14px; font-weight: 600; cursor: pointer; }
.finanzas-root .fz-btn-danger { background: transparent; color: #ef4444; border: none; cursor: pointer; font-size: 14px; }
.finanzas-root .fz-add { background: #2e7d5b18; border: 1px solid #2e7d5b44; color: #2e7d5b; border-radius: 6px; padding: 6px 12px; font-size: 12px; cursor: pointer; margin-top: 6px; }
.finanzas-root .fz-mes-nav { display: flex; align-items: center; justify-content: center; gap: 12px; margin-bottom: 10px; font-weight: 600; }
.finanzas-root .fz-mes-nav button { background: #fff; border: .5px solid rgba(0,0,0,.2); border-radius: 6px; padding: 4px 10px; cursor: pointer; font-size: 15px; }
