@layer feature-modules {
/* Vista /financiera — usa tokens.css */

.financiera-container {
    padding-bottom: var(--space-xl, 2rem);
}

/* Mobile-first: tablas con scroll táctil y herramientas apiladas */
.financiera-table-toolbar {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

@media (min-width: 640px) {
    .financiera-table-toolbar {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
    }

    .financiera-table-toolbar .financiera-table-search {
        flex: 1 1 12rem;
        max-width: min(100%, 24rem);
    }
}

.financiera-table-search {
    width: 100%;
    min-height: 44px;
}

.financiera-table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin: 0 -0.25rem;
    padding: 0 0.25rem;
}

.financiera-mini-pager {
    width: 100%;
}

/*
 * Paginación mobile-first:
 * - Fila 1: texto “Mostrando…” a ancho completo
 * - Fila 2: Anterior | Siguiente (dos columnas iguales, misma altura)
 * Evita que el texto flex 100% empuje un botón a una tercera fila.
 */
.financiera-mini-pager-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-sm);
    width: 100%;
    align-items: stretch;
}

.financiera-mini-pager-inner > .financiera-mini-pager-meta {
    grid-column: 1 / -1;
    grid-row: 1;
    font-size: var(--text-sm, 0.8125rem);
    color: var(--color-text-muted);
    text-align: center;
    line-height: 1.35;
}

.financiera-mini-pager-inner > button:first-of-type {
    grid-column: 1;
    grid-row: 2;
}

.financiera-mini-pager-inner > button:last-of-type {
    grid-column: 2;
    grid-row: 2;
}

.financiera-mini-pager-inner > button {
    min-height: 44px;
}

@media (min-width: 640px) {
    .financiera-mini-pager-inner {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        justify-content: flex-end;
        width: auto;
        gap: var(--space-sm);
    }

    .financiera-mini-pager-inner > .financiera-mini-pager-meta {
        flex: 1 1 auto;
        text-align: right;
        order: 2;
        grid-column: unset;
        grid-row: unset;
    }

    .financiera-mini-pager-inner > button:first-of-type {
        order: 1;
        grid-column: unset;
        grid-row: unset;
    }

    .financiera-mini-pager-inner > button:last-of-type {
        order: 3;
        grid-column: unset;
        grid-row: unset;
    }
}

.financiera-card-nested {
    margin-bottom: var(--space-md);
    border-style: dashed;
}

.financiera-subsection-title {
    margin: 0 0 var(--space-sm);
    font-size: 1.05rem;
    font-weight: 600;
}

.fin-garantias-acceso-row {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

@media (min-width: 480px) {
    .fin-garantias-acceso-row {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: stretch;
    }

    .fin-garantias-acceso-row .input {
        flex: 1 1 12rem;
        min-width: 0;
    }

    .fin-garantias-acceso-row .btn-primary {
        flex: 0 0 auto;
        min-height: 44px;
    }
}

/* Tabla global: todos los clientes (cartera) */
.financiera-cartera-global-head {
    margin-bottom: var(--space-md);
}

.financiera-cartera-global-head h2 {
    margin: 0;
    font-size: 1.125rem;
    color: var(--color-text);
}

.financiera-cartera-global-desc {
    margin: 0.35rem 0 0;
    font-size: var(--text-sm, 0.875rem);
    color: var(--color-text-muted);
    line-height: 1.45;
    max-width: 52rem;
}

.financiera-cartera-global-toolbar {
    margin-bottom: var(--space-md);
}

.financiera-cartera-search-wrap {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
}

@media (min-width: 640px) {
    .financiera-cartera-global-toolbar .financiera-cartera-search-wrap {
        flex: 1 1 14rem;
        max-width: min(100%, 26rem);
    }
}

.financiera-cartera-search-icon {
    position: absolute;
    left: 0.85rem;
    width: 1rem;
    height: 1rem;
    pointer-events: none;
    opacity: 0.55;
    background-color: currentColor;
    mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='M20 20l-3-3'/%3E%3C/svg%3E") center / contain no-repeat;
    -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='M20 20l-3-3'/%3E%3C/svg%3E") center / contain no-repeat;
    color: var(--color-text-muted);
}

.financiera-cartera-search-wrap .financiera-table-search {
    padding-left: 2.5rem;
}

.financiera-cartera-global-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-sm);
    width: 100%;
}

@media (min-width: 640px) {
    .financiera-cartera-global-actions {
        width: auto;
        flex: 0 0 auto;
        margin-left: auto;
    }
}

.financiera-cartera-global-toolbar .financiera-cartera-solo-deuda,
.financiera-cartera-global-toolbar #fin-cartera-global-refrescar {
    min-height: 2.75rem;
    white-space: nowrap;
}

.financiera-cartera-global-scroll {
    overflow: auto;
    max-width: 100%;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md, 8px);
    background: var(--color-surface);
    max-height: min(70vh, 42rem);
}

.financiera-cartera-global-table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
}

.financiera-cartera-global-table th,
.financiera-cartera-global-table td {
    font-size: var(--text-sm, 0.875rem);
    white-space: nowrap;
    padding: 0.72rem 0.9rem;
    vertical-align: middle;
}

.financiera-cartera-global-table .financiera-num {
    font-variant-numeric: tabular-nums;
    font-feature-settings: 'tnum' 1;
}

.financiera-cartera-global-table th:first-child,
.financiera-cartera-global-table td:first-child {
    padding-left: 1rem;
}

.financiera-cartera-global-table .financiera-cartera-col-cliente {
    white-space: normal;
    min-width: 11rem;
    border-right: 1px solid color-mix(in srgb, var(--color-border) 70%, transparent);
}

.financiera-cartera-col-limite {
    min-width: 5.5rem;
}

.financiera-cartera-lim--na,
.financiera-cartera-lim--sin-tope,
.financiera-cartera-lim--cero {
    color: var(--color-text-muted);
    font-weight: var(--font-weight-normal, 400);
}

.fin-cartera-card-stats .financiera-cartera-lim--na,
.fin-cartera-card-stats .financiera-cartera-lim--sin-tope,
.fin-cartera-card-stats .financiera-cartera-lim--cero {
    color: var(--color-text-muted);
}

.financiera-cartera-col-disp {
    border-left: 1px solid color-mix(in srgb, var(--color-border) 55%, transparent);
    border-right: 1px solid color-mix(in srgb, var(--color-border) 55%, transparent);
}

.financiera-cartera-cliente-cell {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
    min-height: 1.35rem;
}

.financiera-cartera-cliente-cell strong {
    font-weight: 600;
    line-height: 1.35;
}

.financiera-badge--trab {
    background: color-mix(in srgb, var(--color-info) 14%, var(--color-surface));
    color: var(--color-info, #0284c7);
    border: 1px solid color-mix(in srgb, var(--color-info) 28%, var(--color-border));
    font-size: 0.68rem;
    letter-spacing: 0.02em;
    padding: 0.1rem 0.45rem;
}

.financiera-cartera-global-table thead .financiera-cartera-col-disp,
.financiera-cartera-global-table tbody .financiera-cartera-col-disp {
    background: transparent;
}

.financiera-cartera-row--deuda .financiera-cartera-col-disp,
.financiera-cartera-row--deuda:hover .financiera-cartera-col-disp {
    background: transparent;
}

.financiera-cartera-col-total {
    border-left: 1px solid color-mix(in srgb, var(--color-border) 90%, transparent);
}

.financiera-cartera-col-accion {
    text-align: center;
    width: 5.75rem;
    padding-right: 1rem;
}

.financiera-cartera-global-table .financiera-btn-cartera-ver {
    min-width: 4.75rem;
    min-height: 2.125rem;
    padding-inline: 0.85rem;
    font-size: 0.8125rem;
}

.financiera-cartera-global-table tbody tr:nth-child(even):not(.financiera-cartera-row--deuda) {
    background: color-mix(in srgb, var(--color-text) 2.5%, var(--color-surface));
}

.financiera-cartera-global-table tbody tr {
    transition: background-color 0.12s ease;
}

/* Cartera global — tokens legibles (claro / oscuro) */
:root,
[data-theme="light"] {
    --fin-cartera-row-deuda-bg: color-mix(in srgb, var(--color-warning) 9%, var(--color-surface));
    --fin-cartera-row-deuda-bg-hover: color-mix(in srgb, var(--color-warning) 15%, var(--color-surface));
    --fin-cartera-row-deuda-accent: #c2410c;
    --fin-cartera-saldo-nio: #9a3412;
    --fin-cartera-saldo-usd: #075985;
    --fin-cartera-saldo-cero: #64748b;
    --fin-cartera-thead-text: #334155;
    --fin-cartera-thead-bg: #e8ecf2;
    --fin-cartera-disp-ok: #15803d;
}

[data-theme="dark"] {
    --fin-cartera-row-deuda-bg: color-mix(in srgb, var(--color-surface-elevated, #1a1a1d) 96%, var(--color-warning) 4%);
    --fin-cartera-row-deuda-bg-hover: color-mix(in srgb, var(--color-surface-elevated, #1a1a1d) 92%, var(--color-warning) 8%);
    --fin-cartera-row-deuda-accent: #f97316;
    --fin-cartera-saldo-nio: #fde68a;
    --fin-cartera-saldo-usd: #7dd3fc;
    --fin-cartera-saldo-cero: #64748b;
    --fin-cartera-thead-text: #94a3b8;
    --fin-cartera-thead-bg: #141416;
    --fin-cartera-disp-ok: #4ade80;
}

:root:not([data-theme="dark"]) {
    --fin-cartera-row-deuda-bg: color-mix(in srgb, var(--color-warning) 9%, var(--color-surface));
    --fin-cartera-row-deuda-bg-hover: color-mix(in srgb, var(--color-warning) 15%, var(--color-surface));
    --fin-cartera-row-deuda-accent: #c2410c;
    --fin-cartera-saldo-nio: #9a3412;
    --fin-cartera-saldo-usd: #075985;
    --fin-cartera-saldo-cero: #64748b;
    --fin-cartera-thead-text: #334155;
    --fin-cartera-thead-bg: #e8ecf2;
    --fin-cartera-disp-ok: #15803d;
}

.financiera-cartera-global-table thead th {
    position: sticky;
    top: 0;
    z-index: 2;
    color: var(--fin-cartera-thead-text);
    background: var(--fin-cartera-thead-bg);
    border-bottom: 1px solid var(--color-border-strong);
    font-weight: 700;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.045em;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    box-shadow: 0 1px 0 var(--color-border);
}

.financiera-cartera-global-table tbody td {
    color: var(--color-text);
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 65%, transparent);
    vertical-align: middle;
}

.financiera-cartera-global-table tbody tr:last-child td {
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 65%, transparent);
}

.financiera-cartera-global-tfoot td {
    border-top: 2px solid var(--color-border-strong);
    background: var(--fin-cartera-thead-bg);
    color: var(--color-text);
    font-weight: 600;
}

.financiera-cartera-foot-limite,
.financiera-cartera-foot-disp {
    font-variant-numeric: tabular-nums;
    font-feature-settings: 'tnum' 1;
}

/* Cartera global — saldos con deuda vs cero */
.financiera-cartera-row--deuda {
    background: var(--fin-cartera-row-deuda-bg);
    box-shadow: inset 3px 0 0 var(--fin-cartera-row-deuda-accent);
}

.financiera-cartera-row--deuda td.financiera-cartera-disp-trab.financiera-cartera-disp--ok {
    color: var(--fin-cartera-disp-ok);
}

.financiera-cartera-row--deuda:hover {
    background: var(--fin-cartera-row-deuda-bg-hover);
}

.financiera-cartera-row--deuda td.financiera-saldo--deuda,
.financiera-cartera-row--deuda td.financiera-saldo--deuda-usd {
    font-weight: 700;
}

.financiera-cartera-row--deuda td.financiera-cartera-col-cliente .financiera-cartera-cliente-cell strong {
    color: var(--color-text);
    font-weight: 700;
}

/* Especificidad > .financiera-table tbody td { color: … } */
.financiera-cartera-global-table tbody td.financiera-saldo--cero,
.financiera-cartera-global-table tfoot td.financiera-saldo--cero {
    color: var(--fin-cartera-saldo-cero);
    opacity: 1;
    font-weight: var(--font-weight-normal, 400);
}

.financiera-cartera-global-table tbody td.financiera-saldo--deuda,
.financiera-cartera-global-table tfoot td.financiera-saldo--deuda {
    color: var(--fin-cartera-saldo-nio);
    font-weight: 700;
}

.financiera-cartera-global-table tbody td.financiera-saldo--deuda-usd,
.financiera-cartera-global-table tfoot td.financiera-saldo--deuda-usd {
    color: var(--fin-cartera-saldo-usd);
    font-weight: 700;
}

.financiera-cartera-global-table tfoot td.financiera-saldo--deuda,
.financiera-cartera-global-table tfoot td.financiera-saldo--deuda-usd {
    font-weight: 800;
}

.financiera-cartera-disp-trab.financiera-cartera-disp--na {
    color: var(--fin-cartera-saldo-cero);
    font-weight: 400;
    font-size: 0.8125rem;
    letter-spacing: 0.08em;
}

.financiera-cartera-disp-trab.financiera-cartera-disp--sin-tope {
    color: var(--color-info, #0284c7);
    font-weight: 600;
    font-size: 0.8125rem;
}

.financiera-cartera-disp-trab.financiera-cartera-disp--ok {
    color: var(--fin-cartera-disp-ok, var(--color-success, #15803d));
    font-weight: 600;
}

.financiera-cartera-disp-trab.financiera-cartera-disp--agotado {
    color: var(--color-danger, #f87171);
    font-weight: 700;
}

.financiera-cartera-global-table tbody td.financiera-cartera-disp-trab.financiera-cartera-disp--agotado {
    background: color-mix(in srgb, var(--color-danger, #ef4444) 14%, transparent);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-danger, #ef4444) 22%, transparent);
    border-radius: 4px;
}

.financiera-cartera-disp-trab.financiera-cartera-disp--bajo {
    color: var(--color-warning, #b8860b);
    font-weight: 600;
}

.fin-cartera-card-stats .financiera-cartera-disp-trab.financiera-cartera-disp--bajo {
    font-weight: inherit;
}

.fin-cartera-card-stats .financiera-cartera-disp-trab.financiera-cartera-disp--agotado {
    background: color-mix(in srgb, var(--color-danger, #c0392b) 10%, transparent);
    border-radius: var(--radius-sm, 4px);
    padding: 0.1rem 0.35rem;
}

.fin-cartera-card-stats .financiera-cartera-disp-trab.financiera-cartera-disp--ok {
    color: var(--fin-cartera-disp-ok, var(--color-success, #15803d));
}

.fin-cartera-card-stats .financiera-cartera-disp-trab.financiera-cartera-disp--sin-tope {
    color: var(--color-info, #0284c7);
}

.financiera-cartera-solo-deuda.is-active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-primary-contrast);
}

.financiera-cartera-global-pager {
    margin-top: var(--space-md);
    padding-top: var(--space-md);
    border-top: 1px solid var(--color-border);
}

.financiera-cartera-global-pager-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
}

.financiera-cartera-global-pager-meta {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    flex: 1 1 auto;
    min-width: min(100%, 12rem);
}

.financiera-cartera-global-pager-btns .btn:disabled {
    opacity: 1;
    color: var(--color-text-disabled);
    border-color: var(--color-border);
    background: var(--color-surface-muted);
}

.financiera-cartera-global-pager-btns {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-left: auto;
}

.financiera-cartera-global-pager-btns .btn {
    min-height: 2.75rem;
}

@media (max-width: 639px) {
    .financiera-cartera-global-pager-inner {
        flex-direction: column;
        align-items: stretch;
    }

    .financiera-cartera-global-pager-meta {
        text-align: center;
    }

    .financiera-cartera-global-pager-btns {
        margin-left: 0;
        width: 100%;
    }

    .financiera-cartera-global-pager-btns .btn {
        flex: 1 1 auto;
        justify-content: center;
    }
}

.financiera-th-usd {
    font-weight: 600;
}

.financiera-cartera-totales-hint {
    font-weight: 400;
    color: var(--color-text-secondary);
    font-size: var(--text-sm, 0.8125rem);
}

/* Cartera global — tarjetas móvil */
.financiera-cartera-cards {
    display: none;
    flex-direction: column;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

.fin-cartera-card {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-md);
    background: var(--color-surface);
}

.fin-cartera-card--deuda {
    background: var(--fin-cartera-row-deuda-bg);
    border-color: color-mix(in srgb, var(--color-warning) 35%, var(--color-border));
}

.fin-cartera-card-head {
    margin-bottom: var(--space-sm);
}

.fin-cartera-card-name {
    font-size: 1rem;
    word-break: break-word;
}

.fin-cartera-card-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-xs) var(--space-md);
    margin: 0 0 var(--space-md);
}

.fin-cartera-card-stats div {
    min-width: 0;
}

.fin-cartera-card-stats dt {
    margin: 0;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--color-text-muted);
}

.fin-cartera-card-stats dd {
    margin: 0.1rem 0 0;
    font-variant-numeric: tabular-nums;
    font-weight: 600;
}

.fin-cartera-card-total {
    grid-column: 1 / -1;
    padding-top: var(--space-xs);
    border-top: 1px dashed var(--color-border);
}

.fin-cartera-card-ver {
    width: 100%;
    min-height: 2.75rem;
}

.fin-cartera-card--totales {
    border-style: dashed;
    background: color-mix(in srgb, var(--color-surface-muted) 60%, var(--color-surface));
}

.fin-cartera-card--totales .fin-cartera-card-name {
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text-muted);
}

.fin-amort-aviso {
    margin: 0 0 var(--space-md);
    font-size: var(--text-sm);
}

@media (max-width: 767px) {
    .financiera-cartera-cards {
        display: flex;
    }

    .financiera-cartera-table-desktop {
        display: none;
    }

    .financiera-cartera-global-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .financiera-cartera-global-actions {
        width: 100%;
    }

    .financiera-cartera-global-actions .btn {
        flex: 1 1 auto;
        min-height: 2.75rem;
    }
}

@media (min-width: 768px) {
    .financiera-cartera-cards {
        display: none !important;
    }
}

/* Contenedor principal Financiera (pestañas segmentadas) */
/* Ficha cliente: bloques apilados (resumen + deudas + garantías + nuevo préstamo) */
/* Referencia clicable → modal estado de cuenta (misma idea que Cobranza) */
.financiera-linea-ref {
    background: none;
    border: none;
    padding: 0;
    margin: 0;
    font: inherit;
    color: var(--color-info);
    cursor: pointer;
    text-decoration: underline;
    text-align: left;
    max-width: 100%;
}

.financiera-linea-ref:hover {
    filter: brightness(1.08);
}

.financiera-ficha-stack {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.financiera-shell {
    background: var(--color-surface, var(--color-background-alt));
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg, 10px);
    padding: var(--space-md);
    margin-bottom: var(--space-md);
}

/* Texto guía al entrar (mobile-first) */
.financiera-lead {
    font-size: var(--text-sm, 0.875rem);
    color: var(--color-text-secondary);
    margin: 0 0 var(--space-md);
    line-height: 1.45;
}

/* Pestañas: barra horizontal deslizable en pantallas angostas */
.financiera-tabs-scroll-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin: 0 calc(-1 * var(--space-md));
    padding: 0 var(--space-md) 2px;
    scrollbar-width: thin;
}

.financiera-tabs-scroll-wrap .financiera-tabs--segment {
    flex-wrap: nowrap;
    min-width: min-content;
    margin-bottom: var(--space-md);
}

.financiera-tabs-scroll-wrap .financiera-tab {
    flex: 0 0 auto;
    white-space: nowrap;
}

/* Cliente seleccionado: atajos sin saltar de pestaña a ciegas */
.financiera-cliente-context {
    position: sticky;
    top: 0;
    z-index: 4;
    margin: 0 0 var(--space-md);
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md);
    background: var(--color-surface-muted);
    border: 1px solid var(--color-border);
}

.financiera-cliente-context-inner {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.financiera-cliente-context-top {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    min-width: 0;
}

.financiera-cliente-context-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
    color: var(--color-text-muted);
}

.financiera-cliente-context-name {
    font-size: 1.0625rem;
    font-weight: 600;
    line-height: 1.3;
    word-break: break-word;
}

.financiera-cliente-context-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    align-items: center;
}

.financiera-cliente-context-actions .btn {
    min-height: 40px;
}

@media (min-width: 640px) {
    .financiera-cliente-context-inner {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
        gap: var(--space-md);
    }

    .financiera-cliente-context-top {
        flex: 1 1 12rem;
        max-width: min(100%, 24rem);
    }

    .financiera-cliente-context-actions {
        flex: 1 1 12rem;
        justify-content: flex-end;
    }
}

/* Pestañas estilo píldora (referencia: activa = naranja óxido, inactiva = borde sutil) */
.financiera-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: var(--space-md);
    padding: 0;
    border-bottom: none;
}

.financiera-tabs--segment {
    margin-bottom: var(--space-lg);
    justify-content: flex-start;
}

.financiera-tab {
    flex: 0 1 auto;
    min-width: min(100%, 5.25rem);
    min-height: 42px;
    padding: 0.4rem 0.75rem;
    font-size: var(--text-sm);
    font-weight: 500;
    font-family: inherit;
    cursor: pointer;
    border-radius: 7px;
    color: var(--color-text);
    border: 1px solid var(--color-border-strong);
    background: var(--color-surface-muted);
    transition:
        background-color 0.15s ease,
        color 0.15s ease,
        border-color 0.15s ease,
        font-weight 0.15s ease,
        box-shadow 0.15s ease;
}

[data-theme='dark'] .financiera-tabs--segment .financiera-tab {
    background: var(--color-surface-hover);
    border-color: var(--color-border);
    color: var(--color-text);
}

.financiera-tabs--segment .financiera-tab:hover {
    border-color: var(--color-border);
}

.financiera-tabs--segment .financiera-tab.is-active,
.financiera-tabs--segment .financiera-tab[aria-selected='true'] {
    background: var(--financiera-tab-active-bg);
    border-color: var(--financiera-tab-active-bg);
    color: var(--color-primary-contrast);
    font-weight: 600;
    box-shadow: 0 1px 3px color-mix(in srgb, var(--color-primary) 35%, transparent);
}

.financiera-tabs--segment .financiera-tab.is-active:hover,
.financiera-tabs--segment .financiera-tab[aria-selected='true']:hover {
    background: var(--financiera-tab-active-hover);
    border-color: var(--financiera-tab-active-hover);
    color: var(--color-primary-contrast);
}

.financiera-tab:focus-visible {
    outline: 2px solid var(--color-border-focus);
    outline-offset: 2px;
}

.financiera-sin-cliente-banner {
    margin: 0 0 var(--space-md);
    padding: var(--space-md);
    font-size: var(--text-sm);
    line-height: 1.45;
    color: var(--color-text);
    background: var(--color-surface-muted);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    border-left: 4px solid var(--color-primary);
}

.financiera-tab-panel[hidden] {
    display: none !important;
}

.financiera-nuevo-title {
    font-size: 1.125rem;
    font-weight: 600;
    margin: 0 0 var(--space-sm);
}

.financiera-hint {
    color: var(--color-text-muted);
    font-size: var(--text-sm, 0.875rem);
    margin: 0 0 var(--space-md, 1rem);
}

.financiera-kpi-disclaimer {
    margin-bottom: var(--space-md);
}

.financiera-details {
    border: 0;
    padding: 0;
}

.financiera-details-summary {
    cursor: pointer;
    font-size: 1.125rem;
    font-weight: 600;
    list-style: none;
    padding: 0.25rem 0;
    min-height: 44px;
    display: flex;
    align-items: center;
}

.financiera-details-summary::-webkit-details-marker {
    display: none;
}

.financiera-details-summary::before {
    content: '▸';
    display: inline-block;
    margin-right: 0.5rem;
    transition: transform 0.15s ease;
}

.financiera-details[open] .financiera-details-summary::before {
    transform: rotate(90deg);
}

.financiera-details-body {
    padding-top: var(--space-md);
}

.financiera-search-wrap {
    position: relative;
    max-width: 28rem;
}

.financiera-suggestions {
    position: absolute;
    z-index: 20;
    left: 0;
    right: 0;
    top: 100%;
    margin: 4px 0 0;
    padding: 0;
    list-style: none;
    background: var(--color-surface-elevated);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md, 8px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
    max-height: 240px;
    overflow-y: auto;
}

[data-theme="dark"] .financiera-suggestions {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
}

.financiera-suggestions li {
    padding: 0.5rem 0.75rem;
    cursor: pointer;
    color: var(--color-text);
}

.financiera-suggestions li:hover,
.financiera-suggestions li:focus {
    background: var(--color-surface-muted);
}

.financiera-suggestion-empty {
    cursor: default;
    color: var(--color-text-muted);
}

.financiera-inv-filters {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-md);
    align-items: flex-end;
    margin-bottom: var(--space-md);
}

.financiera-inv-filters .input-group {
    min-width: 140px;
}

.financiera-checkbox-label {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: var(--text-sm);
    cursor: pointer;
    user-select: none;
}

.financiera-gar-form {
    margin-top: 0;
}

/* Modal garantías del préstamo */
.fin-gar-modal {
    max-width: min(780px, 100%);
    max-height: min(90dvh, 880px);
}

.fin-gar-modal-head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-md);
    margin: calc(-1 * var(--space-xs)) 0 var(--space-md);
    padding-bottom: var(--space-md);
    border-bottom: 1px solid var(--color-border);
}

.fin-gar-modal-head-text {
    min-width: 0;
    flex: 1 1 12rem;
}

.fin-gar-modal-head-text h2 {
    margin: 0 0 0.25rem;
}

.fin-gar-modal-head-text .financiera-hint {
    margin: 0;
}

.fin-gar-modal-section-title {
    margin: 0 0 var(--space-sm);
    font-size: var(--text-sm);
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
}

.fin-gar-modal-lista {
    min-width: 0;
}

.fin-gar-lista-wrap {
    min-width: 0;
}

.fin-gar-lista-toolbar {
    margin-bottom: var(--space-sm);
}

.fin-gar-lista-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md, 8px);
    background: var(--color-surface);
}

.fin-gar-modal-table {
    width: 100%;
    min-width: 0;
    table-layout: auto;
}

.fin-gar-modal-table th:first-child,
.fin-gar-modal-table td:first-child {
    max-width: min(14rem, 42vw);
    word-break: break-word;
    overflow-wrap: anywhere;
}

.fin-gar-th-acciones,
.fin-gar-acciones-cell {
    width: 1%;
    white-space: nowrap;
    vertical-align: middle;
}

.fin-gar-row-actions {
    display: inline-flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.3rem;
}

.fin-gar-row-actions .btn {
    min-height: 2rem;
    padding: 0.2rem 0.45rem;
    font-size: var(--text-xs);
    white-space: nowrap;
}

.fin-gar-modal-form-section {
    margin-top: var(--space-lg);
    padding-top: var(--space-lg);
    border-top: 1px solid var(--color-border);
}

.fin-gar-form-grid .financiera-form-row {
    margin-bottom: var(--space-sm);
}

.fin-gar-form-grid > .input-group {
    margin-bottom: var(--space-sm);
}

.fin-gar-form-actions {
    margin-top: var(--space-sm);
    padding-top: var(--space-sm);
    border-top: 1px solid color-mix(in srgb, var(--color-border) 65%, transparent);
}

@media (min-width: 640px) {
    .fin-gar-form-grid .fin-gar-form-span-full {
        grid-column: 1 / -1;
    }
}

@media (max-width: 639px) {
    .fin-gar-row-actions {
        flex-wrap: wrap;
        justify-content: flex-start;
        max-width: 9rem;
    }
}

.fin-gar-cobranza-intro {
    margin: var(--space-sm) 0 var(--space-md);
    padding: var(--space-sm) var(--space-md);
    background: var(--color-surface-muted, rgba(0, 0, 0, 0.04));
    border-radius: var(--radius-md, 8px);
    border-left: 3px solid var(--color-primary, #2563eb);
}

.fin-gar-cobranza-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin: 0;
    flex-shrink: 0;
    align-self: center;
}

.fin-gar-cobranza-wizard-modal {
    max-width: 32rem;
}

.fin-gar-cobranza-wizard-hint {
    margin-bottom: var(--space-md);
}

.fin-gar-cobranza-wizard-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    padding: var(--space-md);
    border: 1px solid var(--color-border, #e2e8f0);
    border-radius: var(--radius-md, 8px);
    background: var(--color-surface-muted, rgba(0, 0, 0, 0.02));
}

.fin-gar-cobranza-wizard-meta p {
    margin: 0 0 0.35rem;
}

.fin-gar-cobranza-wizard-actions {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.fin-gar-cobranza-wizard-actions .fin-gar-cobranza-wizard-cta {
    width: 100%;
}

.fin-gar-cobranza-precio-wrap {
    margin: var(--space-sm) 0;
}

.fin-gar-cobranza-precio-wrap .financiera-hint {
    margin-top: 0.25rem;
}

.fin-gar-cobranza-steps--wizard {
    justify-content: space-between;
    gap: 0.5rem;
    padding: var(--space-sm) 0;
}

.fin-gar-cobranza-steps--wizard .fin-gar-cobranza-step {
    flex: 1;
    min-width: 4rem;
}

.fin-gar-cobranza-steps--wizard .fin-gar-cobranza-step__dot {
    width: 0.75rem;
    height: 0.75rem;
}

.fin-gar-cobranza-steps--wizard .fin-gar-cobranza-step__lbl {
    font-size: 0.75rem;
}

.fin-gar-acciones-cell {
    vertical-align: middle;
}

.fin-gar-cobranza-cell {
    vertical-align: top;
    min-width: 10rem;
}

.fin-gar-cobranza-steps {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem 0.5rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.fin-gar-cobranza-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.15rem;
    min-width: 3.25rem;
    opacity: 0.45;
}

.fin-gar-cobranza-step--done,
.fin-gar-cobranza-step--current {
    opacity: 1;
}

.fin-gar-cobranza-step__dot {
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background: var(--color-border, #cbd5e1);
    border: 2px solid var(--color-border, #cbd5e1);
}

.fin-gar-cobranza-step--done .fin-gar-cobranza-step__dot {
    background: var(--color-success, #16a34a);
    border-color: var(--color-success, #16a34a);
}

.fin-gar-cobranza-step--current .fin-gar-cobranza-step__dot {
    background: var(--color-primary, #2563eb);
    border-color: var(--color-primary, #2563eb);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.2);
}

.fin-gar-cobranza-step__lbl {
    font-size: 0.65rem;
    line-height: 1.1;
    text-align: center;
    color: var(--color-text-muted);
}

.fin-gar-cobranza-step--current .fin-gar-cobranza-step__lbl {
    color: var(--color-text);
    font-weight: 600;
}

.fin-gar-cobranza-devuelto,
.fin-gar-cobranza-done-hint,
.fin-gar-cobranza-estado-only {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

@media (min-width: 640px) {
    .fin-gar-cobranza-actions {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
    }
}

.financiera-panel-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    margin-bottom: var(--space-md);
}

.financiera-resumen-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--space-md);
}

.financiera-credit-info {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-md);
}

.financiera-kpi-table-wrap {
    overflow-x: auto;
    margin-bottom: var(--space-sm);
}

.financiera-kpi-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
}

.financiera-kpi-table th,
.financiera-kpi-table td {
    padding: 0.4rem 0.5rem;
    border-bottom: 1px solid var(--color-border);
}

.financiera-kpi-warning {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    margin: var(--space-sm) 0 0;
}

.financiera-kpi-total-line {
    margin: var(--space-sm) 0 0;
    font-size: var(--text-sm);
}

.financiera-kpi {
    padding: var(--space-md);
    border-radius: var(--radius-md);
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
}

.financiera-kpi-total {
    border-color: var(--color-success);
    border-width: 2px;
}

.financiera-kpi-total .financiera-kpi-value {
    color: var(--color-success);
}

.financiera-kpi-label {
    display: block;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: 0.25rem;
}

.financiera-kpi-value {
    font-size: 1.35rem;
    font-weight: 600;
}

.financiera-kpi-sub {
    display: block;
    font-size: 0.75rem;
    color: var(--color-text-muted);
    margin-top: 0.35rem;
}

.financiera-table-wrap {
    overflow-x: auto;
}

.financiera-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
}

.financiera-table tbody td,
.financiera-table tfoot td {
    padding: 0.5rem 0.75rem;
    text-align: left;
    border-bottom: 1px solid var(--color-border);
    color: var(--color-text);
    font-weight: var(--font-weight-normal, 400);
    vertical-align: middle;
}

/* Mismo padding/alineación que celdas (components.css usa padding distinto en thead) */
.financiera-table thead th {
    padding: 0.5rem 0.75rem;
    vertical-align: middle;
}

.financiera-table thead th.financiera-num,
.financiera-table tbody td.financiera-num,
.financiera-table tfoot td.financiera-num {
    text-align: right;
}

.financiera-num {
    white-space: nowrap;
}

.financiera-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
}

.financiera-badge-factura {
    background: var(--color-info-muted);
    color: var(--color-info-on-muted);
}

.financiera-badge-prestamo {
    background: var(--color-primary-muted);
    color: var(--color-primary);
}

.financiera-badge--ok {
    background: var(--color-success-muted);
    color: var(--color-success-on-muted);
}

.financiera-badge--atrasado {
    background: var(--color-warning-muted);
    color: var(--color-warning-fg);
}

.financiera-badge--muted {
    background: var(--color-secondary-muted);
    color: var(--color-text-muted);
}

.financiera-badge--danger {
    background: var(--color-danger-muted);
    color: var(--color-danger-on-muted);
}

.financiera-badge--neutral {
    background: color-mix(in srgb, var(--color-text-muted) 16%, var(--color-surface));
    color: var(--color-text-secondary);
    border: 1px solid var(--color-border);
}

.financiera-pago-saldos {
    margin-bottom: var(--space-md);
}

.financiera-pago-saldos-grid {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0.35rem 1rem;
    align-items: baseline;
    font-size: var(--text-sm);
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md);
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
}

.financiera-pago-saldos-label {
    color: var(--color-text-muted);
}

/* Modal registrar pago a préstamo */
.fin-pago-modal {
    max-width: min(520px, 100%);
}

.fin-pago-modal-head {
    margin: calc(-1 * var(--space-xs)) 0 var(--space-md);
    padding-bottom: var(--space-md);
    border-bottom: 1px solid var(--color-border);
}

.fin-pago-modal-head h2 {
    margin: 0 0 0.25rem;
}

.fin-pago-modal-head .financiera-hint {
    margin: 0;
}

.fin-pago-saldos-wrap {
    margin-bottom: var(--space-md);
}

.fin-pago-saldo-card {
    padding: var(--space-md);
    border-radius: var(--radius-md, 8px);
    border: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--color-primary) 8%, var(--color-surface));
}

.fin-pago-saldo-total {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.35rem 1rem;
    padding-bottom: var(--space-sm);
    margin-bottom: var(--space-sm);
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 70%, transparent);
}

.fin-pago-saldo-total-label {
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
}

.fin-pago-saldo-total-val {
    font-size: var(--text-lg);
    font-weight: 700;
    color: var(--color-text);
}

.fin-pago-saldo-breakdown {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-sm);
}

.fin-pago-saldo-item {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 0;
}

.fin-pago-saldo-item-label {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.fin-pago-saldo-item-val {
    font-size: var(--text-sm);
    font-weight: 600;
}

.fin-pago-saldo-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.35rem 1rem;
    font-size: var(--text-sm);
}

.fin-pago-saldo-meta-label {
    color: var(--color-text-muted);
}

.fin-pago-saldo-card--offline .fin-pago-saldo-total {
    border-bottom: none;
    margin-bottom: var(--space-xs);
    padding-bottom: 0;
}

.fin-pago-offline-hint {
    margin: calc(-1 * var(--space-xs)) 0 var(--space-md);
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md, 8px);
    background: color-mix(in srgb, var(--color-warning, #f59e0b) 12%, var(--color-surface));
    border: 1px solid color-mix(in srgb, var(--color-warning, #f59e0b) 35%, var(--color-border));
}

.fin-pago-form-section {
    margin-bottom: var(--space-md);
}

.fin-pago-form-section:last-of-type {
    margin-bottom: var(--space-sm);
}

.fin-pago-section-title {
    margin: 0 0 var(--space-sm);
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
}

.fin-pago-sugerido-wrap {
    margin-bottom: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md, 8px);
    border: 1px solid color-mix(in srgb, var(--color-primary) 35%, var(--color-border));
    background: color-mix(in srgb, var(--color-primary) 6%, var(--color-surface));
}

.fin-pago-sugerido-main {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.75rem;
}

.fin-pago-sugerido-label {
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
}

.fin-pago-sugerido-val {
    font-size: var(--text-base);
    color: var(--color-text);
}

.fin-pago-sugerido-hint {
    margin: 0.35rem 0 0;
    font-size: var(--text-xs);
}

.fin-pago-clamp-aviso {
    margin: 0.35rem 0 0;
    font-size: var(--text-xs);
    color: var(--color-warning, #f59e0b);
}

.fin-pago-sugerido-main .btn {
    flex-shrink: 0;
}

.fin-pago-desglose-hint {
    margin: 0 0 var(--space-sm);
    font-size: var(--text-xs);
}

.fin-pago-readonly {
    background: color-mix(in srgb, var(--color-surface) 88%, var(--color-bg));
    color: var(--color-text);
    cursor: default;
    opacity: 1;
}

.fin-pago-sin-aplicar {
    margin: var(--space-sm) 0 0;
    color: var(--color-warning, #f59e0b);
}

.fin-pago-total-wrap {
    margin-bottom: 0;
}

.fin-pago-input-total {
    font-size: var(--text-lg);
    font-weight: 600;
}

.fin-pago-desglose-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-sm);
}

.fin-pago-desglose-grid .input-group {
    margin-bottom: 0;
}

.fin-pago-form .fin-pago-detalle-row {
    margin-bottom: var(--space-sm);
}

.fin-pago-caja-check {
    margin: 0;
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md, 8px);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
}

.fin-pago-alert {
    margin-bottom: var(--space-sm);
}

.fin-pago-form-actions {
    margin-top: var(--space-md);
    padding-top: var(--space-md);
    border-top: 1px solid var(--color-border);
}

@media (max-width: 480px) {
    .fin-pago-saldo-breakdown,
    .fin-pago-desglose-grid {
        grid-template-columns: 1fr;
    }
}

.financiera-row-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    justify-content: flex-end;
}

.financiera-muted {
    color: var(--color-text-muted);
    font-weight: normal;
}

.financiera-form-prestamo .financiera-form-row,
.financiera-modal-content .financiera-form-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--space-md);
    margin-bottom: var(--space-md);
}

#financiera-modal-amortizacion {
    z-index: 1100;
}

#financiera-modal-garantia-cobranza {
    z-index: 1150;
}

#financiera-modal-pago {
    z-index: 1200;
}

#fin-amort-table-wrap {
    max-height: min(340px, 48dvh);
    overflow: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    margin-bottom: var(--space-xs);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm, 6px);
    background: var(--color-surface);
}

#fin-amort-table-wrap .fin-amort-table thead th {
    position: sticky;
    top: 0;
    z-index: 1;
    background: color-mix(in srgb, var(--color-surface-elevated) 94%, var(--color-bg));
    box-shadow: 0 1px 0 var(--color-border);
}

#fin-amort-table-wrap .fin-amort-table tbody tr {
    background: var(--color-surface);
}

/* Modal amortización: un solo scroll en móvil; tarjetas en lugar de tabla ancha */
.fin-amort-modal.financiera-modal-content {
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.fin-amort-modal-scroll {
    flex: 1 1 auto;
    min-height: 0;
    min-width: 0;
}

.fin-amort-cards {
    display: none;
    flex-direction: column;
    gap: var(--space-xs);
}

.fin-prest-plan-card__head .fin-amort-estado {
    margin-left: auto;
    flex-shrink: 0;
}

.fin-prest-plan-card--vencida {
    border-color: color-mix(in srgb, var(--color-danger) 35%, var(--color-border));
    background: color-mix(in srgb, var(--color-danger) 5%, var(--color-surface));
}

.fin-prest-plan-card--pagada {
    opacity: 0.92;
}

@media (max-width: 639px) {
    #financiera-modal-amortizacion.financiera-modal {
        align-items: flex-end;
        padding: 0;
    }

    .fin-amort-modal.financiera-modal-content {
        width: 100%;
        max-width: none;
        max-height: min(92dvh, 900px);
        margin: 0;
        border-radius: var(--radius-lg, 12px) var(--radius-lg, 12px) 0 0;
        overflow: hidden;
        padding: var(--space-md);
    }

    .fin-amort-modal-scroll {
        overflow-y: auto;
        overscroll-behavior: contain;
        touch-action: pan-y;
        -webkit-overflow-scrolling: touch;
        padding-bottom: var(--space-xs);
    }

    .fin-amort-modal #fin-amort-table-wrap.fin-amort-table-wrap {
        display: none !important;
    }

    .fin-amort-cards {
        display: flex;
    }

    .fin-amort-modal .credits-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fin-amort-modal-actions {
        flex-shrink: 0;
        margin-top: var(--space-sm);
        padding-top: var(--space-sm);
        border-top: 1px solid var(--color-border);
    }
}

@media (min-width: 640px) {
    .fin-amort-modal-scroll {
        overflow: visible;
    }

    .fin-amort-cards {
        display: none !important;
    }
}

.fin-amort-modal-actions {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-sm);
}

.fin-amort-wa-actions,
.fin-amort-modal-actions__secondary {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
}

.fin-amort-modal-actions__secondary {
    justify-content: flex-end;
}

.fin-amort-modal--preview .fin-amort-wa-actions {
    display: none !important;
}

@media (min-width: 640px) {
    .fin-amort-modal-actions {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
    }

    .fin-amort-wa-actions {
        flex: 1 1 auto;
        justify-content: flex-start;
    }
}

.financiera-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.45);
    padding: var(--space-md);
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    box-sizing: border-box;
}

.financiera-modal-content {
    background: var(--color-surface-elevated);
    color: var(--color-text);
    border-radius: var(--radius-lg, 12px);
    padding: var(--space-lg);
    max-width: 520px;
    width: 100%;
    min-width: 0;
    max-height: min(85dvh, 800px);
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    border: 1px solid var(--color-border);
    box-shadow: 0 12px 40px color-mix(in srgb, var(--color-bg) 55%, transparent);
}

.financiera-modal-content .input-group label {
    color: var(--color-text-secondary);
}

.financiera-modal-content .btn-outline:hover {
    color: var(--color-primary-contrast);
    background: var(--color-primary);
    border-color: var(--color-primary);
}

.financiera-modal-wide {
    max-width: 720px;
}

.financiera-modal-content--cliente {
    max-width: min(520px, 100%);
}

.financiera-modal-content--cliente .fin-prestamo-modal__header {
    margin: calc(-1 * var(--space-md, 1rem)) calc(-1 * var(--space-md, 1rem)) var(--space-md);
    padding: var(--space-sm) var(--space-md) var(--space-md);
}

.financiera-modal-content--cliente .fin-prestamo-modal__header .financiera-hint {
    margin: 0.35rem 0 0;
}

.financiera-form-row--3 {
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}

@media (min-width: 520px) {
    .financiera-modal-content .financiera-form-row--3 {
        grid-template-columns: 1fr 1fr 1fr;
    }
}

/* Mobile-first dentro de modales (historial pagos, garantías): tabla por contenido + scroll X, misma idea que ventas/compras */
.financiera-modal-content .financiera-table-wrap {
    min-width: 0;
    overscroll-behavior-x: contain;
}

.financiera-modal-content .financiera-table-scroll {
    min-width: 0;
    overscroll-behavior-x: contain;
}

.financiera-modal-content .financiera-table-scroll .financiera-table {
    width: max-content;
    min-width: 100%;
    table-layout: auto;
}

.financiera-modal-content .financiera-table-scroll .financiera-table th:first-child,
.financiera-modal-content .financiera-table-scroll .financiera-table td:first-child {
    max-width: min(14rem, 48vw);
    hyphens: auto;
    word-break: break-word;
    overflow-wrap: anywhere;
}

@media (min-width: 768px) {
    .financiera-modal-content .financiera-table-scroll .financiera-table {
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }

    .financiera-modal-content .financiera-table-scroll .financiera-table th:first-child,
    .financiera-modal-content .financiera-table-scroll .financiera-table td:first-child {
        max-width: none;
    }
}

.financiera-modal-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: var(--space-md);
    justify-content: flex-end;
}

.financiera-modal-actions--start {
    justify-content: flex-start;
}

.financiera-modal-actions--tight-top {
    margin-top: var(--space-sm);
}

.financiera-modal-actions--negative-top {
    margin-top: calc(-1 * var(--space-sm));
    margin-bottom: var(--space-md);
}

.financiera-deudas-head {
    align-items: flex-start;
    gap: var(--space-md);
}

.financiera-deudas-head .financiera-subsection-title {
    margin: 0 0 var(--space-xs);
}

.financiera-deudas-hint {
    margin: 0;
}

.fin-consumo-pager {
    margin-top: var(--space-sm);
}

.fin-consumo-truncated {
    margin-top: var(--space-sm);
    margin-bottom: 0;
    font-size: var(--text-sm);
}

.financiera-modal-consumo-producto-inner {
    max-width: min(96vw, 920px);
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    max-height: min(92dvh, 880px);
}

.fin-consumo-modal-head {
    flex-shrink: 0;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-sm);
}

.fin-consumo-modal-head-main {
    min-width: 0;
    flex: 1;
}

.fin-consumo-sheet-handle,
.fin-consumo-modal-close,
.fin-consumo-dates-toggle {
    display: none;
}

.fin-consumo-toolbar-dates-wrap {
    display: block;
}

.fin-consumo-modal-head h2 {
    margin: 0;
    line-height: 1.25;
}

.fin-consumo-modal-sub {
    margin: var(--space-xs) 0 0;
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    line-height: 1.45;
}

.fin-consumo-toolbar {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    padding: var(--space-md);
    background: var(--color-surface-muted, rgba(255, 255, 255, 0.03));
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}

.fin-consumo-toolbar-search {
    width: 100%;
}

.fin-consumo-buscar-input {
    width: 100%;
    margin: 0;
}

.fin-consumo-search-hint {
    margin: var(--space-xs) 0 0;
    font-size: var(--text-xs, 0.75rem);
    color: var(--color-text-muted);
    line-height: 1.35;
}

.fin-consumo-search-hint--warn {
    color: var(--color-warning, #e67e22);
}

.fin-consumo-toolbar-modes {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-xs);
    width: 100%;
}

.fin-consumo-toolbar-modes .btn {
    min-height: 40px;
    padding-left: var(--space-sm);
    padding-right: var(--space-sm);
    font-size: var(--text-sm);
    white-space: normal;
    line-height: 1.2;
    text-align: center;
}

.fin-consumo-toolbar-dates {
    display: grid;
    grid-template-columns: 1fr auto 1fr auto;
    align-items: end;
    gap: var(--space-sm);
    padding-top: var(--space-xs);
    border-top: 1px dashed var(--color-border);
}

.fin-consumo-date-field {
    min-width: 0;
    margin: 0;
}

.fin-consumo-date-field label {
    font-size: var(--text-xs, 0.75rem);
}

.fin-consumo-date-sep {
    align-self: center;
    color: var(--color-text-muted);
    padding-bottom: 0.65rem;
    user-select: none;
}

.fin-consumo-date-apply {
    white-space: nowrap;
    min-height: 40px;
}

.fin-consumo-results {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.fin-consumo-empty {
    margin: 0;
    padding: var(--space-lg);
    border: 1px dashed var(--color-border);
    border-radius: var(--radius-md);
}

.fin-consumo-modal-foot {
    flex-shrink: 0;
    justify-content: flex-end;
    margin-top: 0;
    padding-top: var(--space-md);
    border-top: 1px solid var(--color-border);
}

.fin-consumo-list-wrap {
    min-width: 0;
    flex: 1;
    min-height: 12rem;
    max-height: min(42vh, 400px);
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg);
}

.fin-consumo-factura-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    padding: var(--space-md);
}

.fin-consumo-list-message {
    margin: var(--space-lg);
    text-align: center;
}

.fin-consumo-factura-card {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--color-bg-card, var(--color-bg));
}

.fin-consumo-factura-card__head {
    padding: var(--space-md);
    background: var(--color-surface-muted, rgba(255, 255, 255, 0.04));
    border-bottom: 1px solid var(--color-border);
}

.fin-consumo-factura-card__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-md);
    margin-bottom: var(--space-sm);
}

.fin-consumo-factura-card__ref {
    min-width: 0;
    flex: 1;
}

.fin-consumo-factura-card__ref .credits-factura-link,
.fin-consumo-factura-card__ref .btn-link {
    display: inline-block;
    font-size: var(--text-base);
    font-weight: 700;
    padding: 0;
    text-align: left;
    word-break: break-word;
}

.fin-consumo-factura-card__aside {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: var(--space-xs);
    flex-shrink: 0;
    max-width: 45%;
}

.fin-consumo-factura-card__saldo {
    font-size: var(--text-sm);
    font-weight: 700;
    color: var(--color-danger, #e74c3c);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.fin-consumo-factura-card__saldo::before {
    content: 'Saldo ';
    font-weight: 500;
    color: var(--color-text-muted);
    font-size: var(--text-xs, 0.75rem);
}

.fin-consumo-factura-card__meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
}

.fin-consumo-meta-chip {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-xs) var(--space-sm);
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm, 6px);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-text);
}

.fin-consumo-meta-chip__lbl {
    font-size: var(--text-xs, 0.75rem);
    font-weight: 500;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.fin-consumo-factura-card__body {
    padding: 0;
    overflow-x: auto;
}

.fin-consumo-items-table {
    width: 100%;
    min-width: 320px;
    border-collapse: separate;
    border-spacing: 0;
    font-size: var(--text-sm);
    table-layout: fixed;
}

.fin-consumo-col-prod {
    width: 40%;
}

.fin-consumo-col-qty {
    width: 12%;
}

.fin-consumo-col-sub {
    width: 26%;
}

.fin-consumo-col-alm {
    width: 22%;
}

.fin-consumo-items-table thead th {
    padding: var(--space-xs) var(--space-sm);
    text-align: left;
    font-size: var(--text-xs, 0.75rem);
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    border-bottom: 1px solid var(--color-border);
    background: transparent;
    overflow: hidden;
    text-overflow: ellipsis;
}

.fin-consumo-items-table tbody td {
    padding: var(--space-sm);
    vertical-align: top;
    border-bottom: 1px solid var(--color-border);
    overflow: hidden;
}

.fin-consumo-items-table thead th.fin-consumo-item-num,
.fin-consumo-items-table tbody td.fin-consumo-item-num {
    padding-left: var(--space-md);
    padding-right: var(--space-md);
}

.fin-consumo-items-table tbody tr:last-child td {
    border-bottom: none;
}

.fin-consumo-items-table tbody tr:nth-child(even) {
    background: rgba(255, 255, 255, 0.02);
}

.fin-consumo-item-prod {
    word-break: break-word;
    overflow-wrap: anywhere;
}

.fin-consumo-item-code {
    color: var(--color-text-muted);
    font-weight: 400;
}

.fin-consumo-item-num {
    text-align: right;
    white-space: nowrap;
}

.fin-consumo-item-qty {
    width: 3.75rem;
}

.fin-consumo-item-sub {
    min-width: 7rem;
    font-variant-numeric: tabular-nums;
}

.fin-consumo-item-alm {
    word-break: break-word;
    overflow-wrap: anywhere;
    padding-right: var(--space-md) !important;
}

.fin-consumo-items-table th.fin-consumo-item-num {
    text-align: right;
}

    @media (max-width: 767px) {
    .fin-consumo-toolbar-dates-wrap {
        display: none;
    }

    .fin-consumo-toolbar-dates-wrap:not([hidden]) {
        display: block;
    }

    .fin-consumo-modal.credits-modal {
        padding: 0;
        align-items: flex-end;
    }

    .financiera-modal-consumo-producto-inner {
        max-width: 100%;
        width: 100%;
        max-height: min(96dvh, 100%);
        height: min(96dvh, 100%);
        margin: 0;
        border-radius: var(--radius-lg) var(--radius-lg) 0 0;
        overflow: hidden;
        overflow-y: hidden;
        gap: var(--space-xs);
        padding: var(--space-xs) var(--space-md) 0;
    }

    .financiera-modal-consumo-producto-inner.credits-modal-content {
        overflow: hidden;
        overflow-y: hidden;
        max-height: min(96dvh, 100%);
    }

    .fin-consumo-sheet-handle {
        display: block;
        width: 2.5rem;
        height: 0.25rem;
        margin: var(--space-xs) auto var(--space-xs);
        border-radius: 999px;
        background: var(--color-border);
        flex-shrink: 0;
    }

    .fin-consumo-modal-close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        min-width: 2.25rem;
        min-height: 2.25rem;
        padding: 0;
        font-size: 1rem;
        line-height: 1;
    }

    .fin-consumo-modal-head h2 {
        font-size: var(--text-base);
        line-height: 1.2;
    }

    .fin-consumo-modal-sub {
        font-size: var(--text-xs, 0.75rem);
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .fin-consumo-toolbar {
        padding: var(--space-sm);
        gap: var(--space-xs);
    }

    .fin-consumo-buscar-input {
        min-height: 40px;
        font-size: 16px;
    }

    .fin-consumo-search-hint {
        display: none;
        margin-top: var(--space-xs);
    }

    .fin-consumo-toolbar-search:focus-within .fin-consumo-search-hint,
    .fin-consumo-search-hint--warn {
        display: block;
    }

    .fin-consumo-toolbar-modes {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .fin-consumo-toolbar-modes #fin-consumo-pendientes {
        grid-column: auto;
    }

    .fin-consumo-toolbar-modes .btn {
        min-height: 36px;
        padding: var(--space-xs) var(--space-xs);
        font-size: 0.75rem;
        line-height: 1.2;
    }

    .fin-consumo-dates-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        min-height: 36px;
        margin: 0;
        padding: var(--space-xs) var(--space-sm);
        font-size: var(--text-sm);
        color: var(--color-text-muted);
        border: 1px dashed var(--color-border);
        border-radius: var(--radius-sm);
        background: transparent;
    }

    .fin-consumo-dates-toggle.is-active {
        color: var(--color-primary);
        border-color: color-mix(in srgb, var(--color-primary) 45%, var(--color-border));
        background: color-mix(in srgb, var(--color-primary) 8%, transparent);
    }

    .fin-consumo-toolbar-dates-wrap[hidden] {
        display: none !important;
    }

    .fin-consumo-toolbar-dates {
        grid-template-columns: 1fr 1fr;
        padding-top: var(--space-xs);
        border-top: none;
    }

    .fin-consumo-date-sep {
        display: none;
    }

    .fin-consumo-date-apply {
        grid-column: 1 / -1;
        width: 100%;
        min-height: 40px;
    }

    .fin-consumo-results {
        flex: 1;
        min-height: 0;
        overflow: hidden;
        padding-bottom: var(--space-xs);
    }

    .fin-consumo-list-wrap {
        max-height: none;
        flex: 1;
        min-height: 10rem;
    }

    .fin-consumo-factura-card__meta-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        flex-direction: row;
        align-items: stretch;
    }

    .fin-consumo-meta-chip {
        justify-content: space-between;
    }

    .fin-consumo-factura-card__head {
        padding: var(--space-sm);
    }

    .fin-consumo-factura-list {
        padding: var(--space-sm);
        gap: var(--space-sm);
    }

    .fin-consumo-producto-summary {
        font-size: var(--text-xs, 0.75rem);
        padding: var(--space-xs) var(--space-sm);
    }

    .fin-consumo-producto-summary-amt {
        font-size: 1.05rem;
    }

    .fin-consumo-modal-foot {
        position: sticky;
        bottom: 0;
        z-index: 2;
        margin: 0 calc(-1 * var(--space-md));
        padding: var(--space-sm) var(--space-md);
        padding-bottom: max(var(--space-sm), env(safe-area-inset-bottom));
        background: var(--color-bg-card);
        border-top: 1px solid var(--color-border);
        box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.12);
    }

    .fin-consumo-modal-foot .btn {
        width: 100%;
        min-height: 44px;
        justify-content: center;
    }

    .fin-consumo-factura-card__body {
        overflow-x: visible;
    }

    .fin-consumo-items-table {
        min-width: 0;
        table-layout: auto;
    }

    .fin-consumo-items-table colgroup {
        display: none;
    }

    .fin-consumo-items-table thead {
        display: none;
    }

    .fin-consumo-items-table tbody tr {
        display: flex;
        flex-direction: column;
        gap: var(--space-xs);
        padding: var(--space-sm) var(--space-md);
        border-bottom: 1px solid var(--color-border);
    }

    .fin-consumo-items-table tbody tr:last-child {
        border-bottom: none;
    }

    .fin-consumo-items-table tbody td {
        display: flex;
        justify-content: space-between;
        align-items: baseline;
        gap: var(--space-md);
        padding: 0;
        border: none;
        overflow: visible;
        width: 100%;
        min-width: 0;
    }

    .fin-consumo-item-prod {
        flex-direction: column;
        align-items: stretch;
        font-weight: 500;
        padding-bottom: var(--space-xs);
        margin-bottom: var(--space-xs);
        border-bottom: 1px dashed var(--color-border);
    }

    .fin-consumo-item-qty::before,
    .fin-consumo-item-sub::before,
    .fin-consumo-item-alm::before {
        content: attr(data-label);
        flex-shrink: 0;
        font-size: var(--text-xs, 0.75rem);
        font-weight: 500;
        color: var(--color-text-muted);
        text-transform: uppercase;
        letter-spacing: 0.03em;
    }

    .fin-consumo-item-val {
        flex-shrink: 0;
        min-width: 0;
        text-align: right;
        font-variant-numeric: tabular-nums;
        word-break: normal;
        overflow-wrap: normal;
    }

    .fin-consumo-item-alm .fin-consumo-item-val {
        text-align: right;
        max-width: 65%;
        word-break: break-word;
        overflow-wrap: anywhere;
    }
}

.fin-consumo-producto-summary {
    margin-top: 0;
    padding: var(--space-sm) var(--space-md);
    background: var(--color-surface-muted);
    border-radius: var(--radius-sm);
    font-size: var(--text-sm);
    border: 1px solid var(--color-border);
    line-height: 1.45;
}

.fin-consumo-producto-summary-label {
    color: var(--color-text-muted);
}

.fin-consumo-producto-summary-totals {
    display: inline;
}

.fin-consumo-producto-summary-amt {
    font-size: 1.125rem;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    color: var(--color-text);
}

.fin-consumo-producto-summary-mon {
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-text-muted);
}

.cfp-btn-consumo-producto {
    flex-shrink: 0;
}

.financiera-card-compact {
    padding: var(--space-md);
    margin-top: var(--space-sm);
}

.financiera-table .btn-sm {
    min-height: 44px;
    min-width: 44px;
    padding-left: 0.65rem;
    padding-right: 0.65rem;
}

/* WhatsApp — finanzas */
.fin-btn-wa {
    color: var(--color-brand-whatsapp);
    border-color: var(--color-brand-whatsapp);
}
.fin-btn-wa:hover:not(:disabled) {
    background: color-mix(in srgb, var(--color-brand-whatsapp) 14%, var(--color-surface));
    color: var(--color-brand-whatsapp-hover);
}
.fin-btn-wa:disabled {
    opacity: 0.45;
}

.fin-wa-overlay {
    position: fixed;
    inset: 0;
    z-index: 10050;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-md);
    background: color-mix(in srgb, var(--color-text) 45%, transparent);
}
.fin-wa-modal {
    width: min(100%, 22rem);
    padding: var(--space-lg);
    border-radius: var(--radius-lg);
    background: var(--color-surface);
    box-shadow: var(--shadow-lg);
}
.fin-wa-title {
    margin: 0 0 var(--space-sm);
    font-size: 1.1rem;
}
.fin-wa-hint {
    margin: 0 0 var(--space-md);
    font-size: 0.875rem;
    color: var(--color-text-muted);
}
.fin-wa-input-wrap {
    margin-bottom: var(--space-md);
}
.fin-wa-actions {
    display: flex;
    gap: var(--space-sm);
    justify-content: flex-end;
}
.fin-wa-btn-send {
    background: var(--color-brand-whatsapp);
    border-color: var(--color-brand-whatsapp);
    color: #fff;
}
.fin-wa-btn-send:hover {
    background: var(--color-brand-whatsapp-hover);
    border-color: var(--color-brand-whatsapp-hover);
}

/* Tabla amortización */
.fin-amort-table th,
.fin-amort-table td {
    white-space: nowrap;
}
.fin-amort-estado {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    border-radius: var(--radius-sm);
    font-size: 0.75rem;
    font-weight: 600;
}
.fin-amort-estado--pagada {
    background: color-mix(in srgb, var(--color-success) 18%, transparent);
    color: var(--color-success);
}
.fin-amort-estado--pendiente {
    background: color-mix(in srgb, var(--color-warning) 18%, transparent);
    color: var(--color-warning);
}
.fin-amort-estado--vencida {
    background: color-mix(in srgb, var(--color-danger) 18%, transparent);
    color: var(--color-danger);
}
.fin-amort-estado--parcial {
    background: color-mix(in srgb, var(--color-info, #3b82f6) 18%, transparent);
    color: var(--color-info, #2563eb);
}
.fin-amort-row--vencida td {
    background: color-mix(in srgb, var(--color-danger) 6%, transparent);
}
.cfp-row-actions .fin-btn-wa {
    font-size: 0.72rem;
    padding-left: 0.45rem;
    padding-right: 0.45rem;
}

@media (max-width: 640px) {
    .financiera-panel-head {
        flex-direction: column;
        align-items: flex-start;
    }
    .financiera-row-actions {
        justify-content: flex-start;
    }
}

/* —— Modal nuevo préstamo (mobile-first sheet → centered dialog) —— */
.fin-prestamo-modal {
    align-items: flex-end;
    padding: 0;
}

.fin-prestamo-modal__panel {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 720px;
    max-height: min(92dvh, 900px);
    background: var(--color-surface-elevated);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg, 12px) var(--radius-lg, 12px) 0 0;
    box-shadow: 0 -8px 32px color-mix(in srgb, var(--color-bg) 50%, transparent);
    overflow: hidden;
    min-width: 0;
}

.fin-prestamo-modal__handle {
    flex-shrink: 0;
    width: 2.5rem;
    height: 0.25rem;
    margin: 0.5rem auto 0;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-text-muted) 45%, transparent);
}

.fin-prestamo-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-sm);
    padding: var(--space-md) var(--space-md) var(--space-sm);
    border-bottom: none;
    flex-shrink: 0;
}

.fin-prestamo-modal__header-main {
    min-width: 0;
    flex: 1;
}

.fin-prestamo-modal__header h2 {
    margin: 0;
    font-size: var(--text-base, 1rem);
    font-weight: 700;
    line-height: 1.25;
}

.fin-prestamo-modal__cliente {
    margin: 0.25rem 0 0;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: 1.35;
}

.fin-prestamo-modal__cliente strong {
    display: block;
    margin-top: 0.1rem;
    color: var(--color-text);
    font-size: clamp(1.05rem, 4.5vw, 1.25rem);
    font-weight: 700;
    line-height: 1.25;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}

.fin-prestamo-modal__close {
    flex-shrink: 0;
    min-width: 44px;
    min-height: 44px;
    padding: 0;
    line-height: 1;
}

.fin-prestamo-modal__form {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
}

.fin-prestamo-modal__scroll {
    flex: 1;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    padding: var(--space-sm) var(--space-md) var(--space-md);
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    min-width: 0;
}

/* Etiquetas del formulario: texto muted (no azul info global) */
.fin-prestamo-modal .input-group label,
.fin-prestamo-modal .fin-prestamo-field-label {
    color: var(--color-text-muted);
    font-weight: 500;
    letter-spacing: 0.01em;
}

.fin-prestamo-modal .input-group {
    margin-bottom: var(--space-sm);
}

.fin-prestamo-modal .input-group:last-child {
    margin-bottom: 0;
}

.fin-prestamo-modal .input,
.fin-prestamo-modal select.input {
    background: var(--color-surface);
    border-color: var(--color-border);
}

.fin-prestamo-modal .input:hover:not(:disabled) {
    border-color: color-mix(in srgb, var(--color-primary) 35%, var(--color-border));
}

.fin-prestamo-modal .input:focus {
    border-color: var(--color-primary);
}

.fin-prestamo-modal .input:focus-visible {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 22%, transparent);
}

.fin-prestamo-modal .fin-prestamo-input-lg,
.fin-prestamo-modal .fin-prestamo-amount-input__field {
    font-size: var(--text-base, 1rem);
    font-weight: 600;
    letter-spacing: 0.01em;
    text-align: right;
    min-height: 48px;
    border-width: 1px;
}

.fin-prestamo-hero {
    padding: var(--space-md);
    border-radius: var(--radius-md, 8px);
    background: color-mix(in srgb, var(--color-primary) 6%, var(--color-surface));
    border: 1px solid color-mix(in srgb, var(--color-primary) 14%, var(--color-border));
}

.fin-prestamo-amount-input {
    display: flex;
    align-items: stretch;
    min-height: 48px;
    height: 48px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md, 8px);
    background: var(--color-surface);
    overflow: hidden;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.fin-prestamo-amount-input:focus-within {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 20%, transparent);
}

.fin-prestamo-amount-input__prefix {
    display: flex;
    align-items: center;
    padding: 0 var(--space-sm);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-text-muted);
    background: color-mix(in srgb, var(--color-bg) 40%, var(--color-surface));
    border-right: 1px solid var(--color-border);
    flex-shrink: 0;
}

.fin-prestamo-amount-input__field {
    flex: 1;
    min-width: 0;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding-right: var(--space-md);
    background: transparent;
}

.fin-prestamo-amount-input__field:focus,
.fin-prestamo-amount-input__field:focus-visible {
    outline: none;
    box-shadow: none !important;
}

.fin-prestamo-card--amount {
    padding-top: var(--space-sm);
    gap: var(--space-md);
}

.fin-prestamo-card--plan {
    gap: var(--space-sm);
}

.fin-prestamo-modal .fin-prestamo-segment {
    margin-bottom: var(--space-sm);
}

.fin-prestamo-modal .fin-prestamo-field-hint {
    margin-top: var(--space-xs);
}

.fin-prestamo-card .input-group:has(.fin-prestamo-field-hint) {
    margin-bottom: var(--space-md);
}

.fin-prestamo-card {
    padding: var(--space-sm) 0;
    border-radius: 0;
    border: none;
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 85%, transparent);
    background: transparent;
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.fin-prestamo-card:last-of-type {
    border-bottom: none;
}

.fin-prestamo-card__title {
    margin: 0 0 var(--space-xs);
    padding-bottom: 0;
    border-bottom: none;
    font-size: var(--text-xs, 0.75rem);
    font-weight: 600;
    line-height: 1.3;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    display: block;
}

.fin-prestamo-card--flat {
    padding: 0;
    border: none;
    background: transparent;
    gap: 0;
}

.fin-prestamo-card--optional .fin-prestamo-card__head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-sm);
    margin-bottom: var(--space-xs);
    padding-bottom: 0;
    border-bottom: none;
}

.fin-prestamo-card__head .fin-prestamo-card__title {
    margin: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.fin-prestamo-card__step {
    display: none;
}

.fin-prestamo-segment--plan {
    margin-top: 0;
    margin-bottom: var(--space-sm);
}

.fin-prestamo-card__optional {
    font-size: var(--text-xs, 0.75rem);
    font-weight: 500;
    color: var(--color-text-muted);
    text-transform: none;
    letter-spacing: 0;
}

.fin-prestamo-field-label {
    display: block;
    margin: 0 0 var(--space-1);
    min-height: 1.25rem;
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-text-muted);
}

.fin-prestamo-amount-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
    margin-bottom: 0;
    align-items: end;
}

.fin-prestamo-amount-row .input-group {
    margin-bottom: 0;
    display: flex;
    flex-direction: column;
}

.fin-prestamo-amount-row .input-group label,
.fin-prestamo-amount-row .fin-prestamo-field-label {
    min-height: 1.25rem;
    margin-bottom: var(--space-1);
}

.fin-prestamo-amount-row .fin-prestamo-amount-input,
.fin-prestamo-amount-row .fin-prestamo-input-lg,
.fin-prestamo-amount-row .fin-prestamo-segment--compact {
    min-height: 48px;
    height: 48px;
    box-sizing: border-box;
}

.fin-prestamo-amount-row .fin-prestamo-segment--compact {
    margin-bottom: 0;
    padding: 0.2rem;
    align-self: stretch;
}

.fin-prestamo-amount-row .fin-prestamo-segment--compact .fin-prestamo-segment__btn {
    min-height: 100%;
    font-size: var(--text-sm);
    font-weight: 600;
}

/* Moneda: colores distintos NIO (verde) vs USD (azul) */
.fin-prestamo-segment--moneda .fin-prestamo-segment__btn[data-value='NIO'].is-active {
    color: #fff;
    background: linear-gradient(180deg, #3d9a62 0%, #2d7a4e 100%);
    border-color: #256b42;
    box-shadow: 0 1px 4px rgba(45, 122, 78, 0.35);
}

.fin-prestamo-segment--moneda .fin-prestamo-segment__btn[data-value='USD'].is-active {
    color: #fff;
    background: linear-gradient(180deg, #4a8fd4 0%, #2f6fad 100%);
    border-color: #285f94;
    box-shadow: 0 1px 4px rgba(47, 111, 173, 0.35);
}

.fin-prestamo-segment--moneda .fin-prestamo-segment__btn[data-value='NIO']:not(.is-active):hover {
    color: #3d9a62;
    background: color-mix(in srgb, #3d9a62 12%, transparent);
    border-color: color-mix(in srgb, #3d9a62 35%, var(--color-border));
}

.fin-prestamo-segment--moneda .fin-prestamo-segment__btn[data-value='USD']:not(.is-active):hover {
    color: #4a8fd4;
    background: color-mix(in srgb, #4a8fd4 12%, transparent);
    border-color: color-mix(in srgb, #4a8fd4 35%, var(--color-border));
}

.fin-prest-plazo-row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    align-items: stretch;
}

.fin-prest-plazo-row #fin-prest-plazo {
    flex: 1 1 5rem;
    min-width: 4.5rem;
}

.fin-prest-plazo-row .fin-prest-plazo-unidad {
    flex: 1 1 8.5rem;
    max-width: 11rem;
    margin-bottom: 0;
}

.fin-prestamo-segment {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.35rem;
    padding: 0.25rem;
    margin-bottom: var(--space-md);
    border-radius: var(--radius-md, 8px);
    border: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--color-bg) 35%, transparent);
}

.fin-prestamo-segment--compact {
    margin-bottom: 0;
}

.fin-prestamo-segment__btn {
    min-height: 44px;
    padding: 0.5rem 0.65rem;
    border: 1px solid transparent;
    border-radius: calc(var(--radius-md, 8px) - 2px);
    background: transparent;
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    font-weight: 500;
    line-height: 1.25;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.fin-prestamo-segment__btn:hover:not(.is-active) {
    color: var(--color-text);
    background: var(--hover-overlay-strong);
    border-color: var(--color-border);
}

.fin-prestamo-segment__btn.is-active {
    color: var(--color-primary-contrast);
    background: var(--color-primary);
    border-color: var(--color-primary);
    font-weight: 600;
    box-shadow: var(--shadow-sm);
}

.fin-prestamo-segment__btn.is-active:hover {
    background: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
    color: var(--color-primary-contrast);
}

.fin-prestamo-segment__btn:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 1px;
}

.fin-prestamo-select-native {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.fin-prestamo-tasa-block {
    margin-top: var(--space-xs);
    padding-top: var(--space-md);
    border-top: 1px dashed color-mix(in srgb, var(--color-border) 90%, transparent);
}

#fin-prest-tasa-row[hidden],
#fin-prest-tc-row[hidden],
#fin-pago-caja-wrap[hidden],
.fin-prestamo-tasa-block--off {
    display: none !important;
}

.fin-prestamo-grid--tasa {
    gap: var(--space-md);
}

.fin-prestamo-plan-box {
    padding: var(--space-sm) var(--space-md);
    margin-bottom: 0;
    border-radius: var(--radius-md, 8px);
    border: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--color-bg) 25%, var(--color-surface));
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.fin-prestamo-plan-box__row {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.fin-prestamo-plan-date {
    margin: 0;
    padding: 0;
    border: none;
}

#fin-prest-n-cuotas-wrap[hidden] ~ .fin-prestamo-plan-date {
    grid-column: 1 / -1;
}

.fin-prestamo-plan-box__row:has(#fin-prest-n-cuotas-wrap[hidden]) {
    grid-template-columns: 1fr;
}

.fin-prestamo-optional-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    width: 100%;
    min-height: 48px;
    padding: var(--space-md);
    border: 1px dashed var(--color-border);
    border-radius: var(--radius-md, 8px);
    background: transparent;
    color: var(--color-text);
    font-size: var(--text-sm);
    cursor: pointer;
    text-align: left;
}

.fin-prestamo-optional-toggle.is-open {
    border-style: solid;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    margin-bottom: 0;
}

.fin-prestamo-optional-toggle__title {
    font-weight: 600;
}

.fin-prestamo-optional-toggle__hint {
    font-size: var(--text-xs, 0.75rem);
    color: var(--color-text-muted);
}

.fin-prestamo-optional-body {
    padding: 0 var(--space-md) var(--space-md);
    border: 1px solid var(--color-border);
    border-top: none;
    border-radius: 0 0 var(--radius-md, 8px) var(--radius-md, 8px);
    background: color-mix(in srgb, var(--color-surface) 92%, var(--color-bg));
}

.fin-prestamo-section {
    margin-bottom: var(--space-lg);
}

.fin-prestamo-section:last-child {
    margin-bottom: 0;
}

.fin-prestamo-section__title {
    margin: 0 0 var(--space-sm);
    font-size: var(--text-sm);
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-text-muted);
}

.fin-prestamo-section__head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-sm);
    margin-bottom: var(--space-xs);
}

.fin-prestamo-section__head .fin-prestamo-section__title {
    margin: 0;
}

.fin-prestamo-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.fin-prestamo-field--full {
    grid-column: 1 / -1;
}

.fin-prestamo-input-lg {
    font-size: var(--text-lg, 1.125rem);
    font-weight: 600;
    min-height: 48px;
}

.fin-prestamo-textarea {
    resize: vertical;
    min-height: 4.5rem;
}

.fin-prestamo-field-hint {
    margin: 0.35rem 0 0;
    font-size: var(--text-xs, 0.75rem);
    line-height: 1.45;
    color: var(--color-text-muted);
}

.fin-prestamo-tasa-equiv {
    color: var(--color-primary);
    font-weight: 500;
}

.fin-prestamo-tasa-meta {
    margin-top: calc(-1 * var(--space-xs));
}

.fin-prestamo-preview {
    margin-top: var(--space-sm);
    padding: var(--space-md);
    border-radius: var(--radius-md, 8px);
    border: 1px solid var(--color-border);
    background: var(--color-surface);
    min-width: 0;
}

.fin-prestamo-preview--empty {
    border-style: dashed;
    border-color: color-mix(in srgb, var(--color-border) 90%, transparent);
    background: color-mix(in srgb, var(--color-bg) 30%, var(--color-surface));
    padding: var(--space-md);
}

.fin-prestamo-preview--empty .fin-prestamo-preview__hero,
.fin-prestamo-preview--empty .fin-prestamo-preview__details,
.fin-prestamo-preview--empty .fin-prestamo-preview-actions {
    display: none !important;
}

.fin-prestamo-preview__empty {
    margin: 0;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: 1.45;
    text-align: center;
}

.fin-prestamo-preview:not(.fin-prestamo-preview--empty) .fin-prestamo-preview__empty {
    display: none;
}

.fin-prestamo-preview__hero {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-sm);
    margin-bottom: var(--space-sm);
}

.fin-prestamo-preview__hero-stat {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    padding: var(--space-sm);
    border-radius: var(--radius-md, 8px);
    background: color-mix(in srgb, var(--color-bg) 35%, var(--color-surface));
    border: 1px solid var(--color-border);
    min-width: 0;
}

.fin-prestamo-preview__hero-stat--total {
    background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface));
    border-color: color-mix(in srgb, var(--color-primary) 28%, var(--color-border));
}

.fin-prestamo-preview__hero-label {
    font-size: var(--text-xs, 0.75rem);
    color: var(--color-text-muted);
    line-height: 1.3;
}

.fin-prestamo-preview__hero-stat strong {
    font-size: clamp(1rem, 4.5vw, 1.2rem);
    font-weight: 700;
    line-height: 1.2;
    color: var(--color-text);
    overflow: hidden;
    text-overflow: ellipsis;
}

.fin-prestamo-preview__hero-stat--total strong {
    color: var(--color-primary);
    font-size: clamp(1.05rem, 5vw, 1.35rem);
}

.fin-prestamo-preview__details {
    margin: 0;
}

.fin-prestamo-preview__details > summary {
    cursor: pointer;
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-primary);
    list-style: none;
    padding: var(--space-xs) 0;
    user-select: none;
}

.fin-prestamo-preview__details > summary::-webkit-details-marker {
    display: none;
}

.fin-prestamo-preview__details > summary::after {
    content: ' ▾';
    font-size: 0.85em;
    opacity: 0.8;
}

.fin-prestamo-preview__details[open] > summary::after {
    content: ' ▴';
}

.fin-prestamo-preview__item--hero-ref {
    display: none;
}

.fin-prestamo-preview__list {
    margin: 0;
    display: grid;
    gap: var(--space-sm);
}

.fin-prestamo-preview__item {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: var(--space-md);
    font-size: var(--text-sm);
}

.fin-prestamo-preview__item dt {
    margin: 0;
    color: var(--color-text-muted);
    font-weight: normal;
}

.fin-prestamo-preview__item dd {
    margin: 0;
    font-weight: 600;
    text-align: right;
}

.fin-prestamo-preview__item--highlight dd {
    color: var(--color-primary);
    font-size: var(--text-base);
}

.fin-prestamo-preview-actions {
    margin-top: var(--space-md);
    padding-top: var(--space-sm);
    border-top: 1px dashed color-mix(in srgb, var(--color-primary) 32%, var(--color-border));
}

.fin-prestamo-preview--empty .fin-prestamo-preview-actions {
    display: none;
}

.fin-prestamo-preview__plan-hint {
    margin: 0;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: 1.45;
    text-align: center;
}

.fin-prestamo-preview-actions__buttons {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: var(--space-xs);
}

.fin-prestamo-preview-actions__buttons .btn {
    flex: 1 1 auto;
    min-width: min(100%, 9rem);
    font-size: var(--text-sm);
}

@media (min-width: 480px) {
    .fin-prestamo-preview-actions__buttons {
        justify-content: flex-end;
    }

    .fin-prestamo-preview-actions__buttons .btn {
        flex: 0 1 auto;
        min-width: 0;
    }

    .fin-prestamo-preview__plan-hint {
        text-align: right;
    }
}

.fin-prestamo-preview .fin-prest-plan-panel {
    margin-top: 0;
    border: none;
    padding: 0;
    background: transparent;
}

.fin-prestamo-preview--plan-open .fin-prest-plan-panel {
    margin-top: var(--space-sm);
    padding-top: var(--space-sm);
    border-top: 1px dashed var(--color-border);
    border-radius: 0;
}

.fin-prest-plan-estimado-btn,
.fin-prest-plan-full-btn {
    font-size: inherit;
}

.fin-prest-plan-btn-label--desktop {
    display: none;
}

.fin-prest-plan-btn-label--mobile {
    display: inline;
}

@media (min-width: 640px) {
    .fin-prest-plan-btn-label--desktop {
        display: inline;
    }

    .fin-prest-plan-btn-label--mobile {
        display: none;
    }
}

/* Ocultar resumen duplicado cuando el cronograma está abierto */
.fin-prestamo-modal--plan-open #fin-prest-footer-bar {
    display: none !important;
}

.fin-prestamo-preview--plan-open #fin-prest-preview-hero {
    display: none !important;
}

.fin-prestamo-preview--plan-open .fin-prestamo-preview__details {
    display: none !important;
}

.fin-prest-plan-panel {
    margin-top: var(--space-sm);
    padding: var(--space-md);
    border-radius: var(--radius-md, 8px);
    border: 1px solid var(--color-border);
    background: var(--color-surface-muted);
    min-width: 0;
}

.fin-prest-plan-panel__head {
    margin-bottom: var(--space-sm);
}

.fin-prest-plan-panel__title {
    margin: 0 0 var(--space-xs);
    font-size: var(--text-sm);
    font-weight: 600;
}

.fin-prest-plan-panel__hint {
    margin: 0;
    line-height: 1.45;
}

.fin-prest-plan-panel__scroll {
    min-width: 0;
    max-height: min(280px, 40dvh);
    overflow: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm, 6px);
    background: var(--color-surface);
}

.fin-prest-plan-panel__scroll .fin-prest-plan-table {
    width: max-content;
    min-width: 100%;
    table-layout: auto;
    margin: 0;
}

.fin-prest-plan-panel__scroll .fin-prest-plan-table thead th {
    position: sticky;
    top: 0;
    z-index: 2;
    background: color-mix(in srgb, var(--color-surface-muted) 92%, var(--color-bg));
    box-shadow: 0 1px 0 var(--color-border);
}

.fin-prest-plan-table {
    font-size: var(--text-sm);
}

.fin-prest-plan-table th,
.fin-prest-plan-table td {
    white-space: nowrap;
    padding: 0.45rem 0.65rem;
}

.fin-prest-plan-table td.financiera-num,
.fin-prest-plan-table th.financiera-num {
    font-variant-numeric: tabular-nums;
}

.fin-prest-plan-col-num {
    width: 2.25rem;
}

.fin-prest-plan-col-fecha {
    width: 5.75rem;
}

.fin-prest-plan-col-cuota {
    width: 6.75rem;
}

.fin-prest-plan-col-capital,
.fin-prest-plan-col-interes,
.fin-prest-plan-col-saldo {
    width: 6.5rem;
}

.fin-prest-plan-col-estado {
    width: 7.5rem;
}

@media (max-width: 639px) {
    .fin-prest-plan-panel__table-wrap {
        display: none !important;
    }

    .fin-prest-plan-cards {
        display: flex;
        flex-direction: column;
        gap: var(--space-xs);
        max-height: min(320px, 45dvh);
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        padding: 1px;
    }

    .fin-prest-plan-cards[hidden] {
        display: none !important;
    }

    .fin-prest-plan-card {
        padding: var(--space-sm) var(--space-md);
        border: 1px solid var(--color-border);
        border-radius: var(--radius-md, 8px);
        background: var(--color-surface);
    }

    .fin-prest-plan-card--balloon {
        border-color: color-mix(in srgb, var(--color-primary) 35%, var(--color-border));
        background: color-mix(in srgb, var(--color-primary) 8%, var(--color-surface));
    }

    .fin-prest-plan-card__head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        flex-wrap: wrap;
        gap: var(--space-sm);
        margin-bottom: var(--space-xs);
        padding-bottom: var(--space-xs);
        border-bottom: 1px solid color-mix(in srgb, var(--color-border) 80%, transparent);
    }

    .fin-prest-plan-card__num {
        font-size: var(--text-sm);
        font-weight: 600;
        color: var(--color-text);
    }

    .fin-prest-plan-card__fecha {
        font-size: var(--text-sm);
        color: var(--color-text-muted);
        font-variant-numeric: tabular-nums;
    }

    .fin-prest-plan-card__stats {
        margin: 0;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--space-sm);
    }

    .fin-prest-plan-card__stat {
        display: flex;
        flex-direction: column;
        gap: 0.15rem;
        min-width: 0;
    }

    .fin-prest-plan-card__stat dt {
        margin: 0;
        font-size: var(--text-xs, 0.75rem);
        font-weight: 500;
        color: var(--color-text-muted);
    }

    .fin-prest-plan-card__stat dd {
        margin: 0;
        font-size: var(--text-sm);
        font-weight: 700;
        font-variant-numeric: tabular-nums;
        color: var(--color-text);
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .fin-prest-plan-card__stat--saldo dd {
        color: var(--color-primary);
    }

    .fin-prestamo-preview-actions__buttons {
        flex-direction: column;
    }

    .fin-prestamo-preview-actions__buttons .btn {
        width: 100%;
        min-width: 0;
    }

    .fin-prestamo-preview--plan-open .fin-prestamo-preview-actions {
        margin-top: 0;
        padding-top: 0;
        border-top: none;
    }
}

@media (min-width: 640px) {
    .fin-prest-plan-cards {
        display: none !important;
    }
}

@media (max-width: 639px) {
    .fin-prest-plan-table .fin-prest-plan-col--optional {
        visibility: collapse;
    }
}

.fin-prest-plan-row--balloon td {
    background: color-mix(in srgb, var(--color-primary) 10%, transparent);
}

.fin-prest-plan-row--balloon .fin-prest-plan-cuota-cell {
    font-weight: 600;
    color: var(--color-primary);
}

.fin-prest-plan-balloon-tag {
    display: inline-block;
    margin-left: 0.35rem;
    padding: 0.05rem 0.35rem;
    border-radius: 999px;
    font-size: 0.65rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    background: color-mix(in srgb, var(--color-primary) 22%, transparent);
    color: var(--color-primary);
    vertical-align: middle;
}

.fin-prest-plan-panel .fin-amort-row--vencida td {
    color: var(--color-danger, #c0392b);
}

.fin-amort-modal--preview .fin-amort-col-pay {
    display: none;
}

.fin-amort-row--preview.fin-amort-row--vencida td {
    color: var(--color-danger, #c0392b);
}

.fin-prestamo-switch {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: var(--text-sm);
    cursor: pointer;
    user-select: none;
    line-height: 1.4;
}

.fin-prestamo-switch input {
    margin-top: 0.15rem;
    flex-shrink: 0;
    width: 1.1rem;
    height: 1.1rem;
}

.fin-prestamo-switch--sub {
    margin-top: var(--space-md);
}

.fin-prestamo-collapsible {
    margin-top: var(--space-md);
    padding-top: var(--space-md);
    border-top: 1px dashed var(--color-border);
}

.fin-prestamo-collapsible--nested {
    margin-top: var(--space-sm);
    padding: var(--space-md);
    border-radius: var(--radius-md, 8px);
    border: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--color-bg) 40%, transparent);
}

.fin-prestamo-error {
    margin: 0;
}

.fin-prestamo-switch--pill {
    padding: 0.35rem 0.65rem;
    border-radius: 999px;
    border: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--color-bg) 30%, transparent);
    font-size: var(--text-xs, 0.75rem);
    font-weight: 600;
}

.fin-prestamo-switch--footer {
    width: auto;
    flex: 1;
    min-width: 0;
    padding: 0;
    margin: 0;
    color: var(--color-text-secondary);
    font-size: var(--text-sm);
    border-bottom: none;
}

.fin-prestamo-switch--caja-blocked {
    cursor: pointer;
}

.fin-prestamo-footer-bar {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    margin: 0;
    border-radius: var(--radius-md, 8px);
    background: color-mix(in srgb, var(--color-primary) 8%, var(--color-surface-elevated));
    border: 1px solid color-mix(in srgb, var(--color-primary) 22%, var(--color-border));
}

.fin-prestamo-footer-bar__stat {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    min-width: 0;
}

.fin-prestamo-footer-bar__label {
    font-size: var(--text-xs, 0.75rem);
    color: var(--color-text-muted);
}

.fin-prestamo-footer-bar__stat strong {
    font-size: var(--text-sm);
    font-weight: 700;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.fin-prestamo-footer-bar__stat--total strong {
    color: var(--color-primary);
    font-size: var(--text-base, 1rem);
}

.fin-prestamo-modal__footer-toolbar {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    width: 100%;
}

.fin-prestamo-modal__footer-actions {
    display: flex;
    flex-direction: column-reverse;
    gap: var(--space-sm);
    width: 100%;
}

.fin-prestamo-modal__footer-actions .btn-primary {
    width: 100%;
}

.fin-prestamo-modal__footer-actions .btn-ghost {
    align-self: center;
    min-height: 40px;
    color: var(--color-text-muted);
}

.fin-prestamo-modal__footer {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    padding: var(--space-md);
    padding-bottom: max(var(--space-md), env(safe-area-inset-bottom, 0px));
    border-top: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--color-surface-elevated) 96%, var(--color-bg));
    flex-shrink: 0;
    box-shadow: 0 -4px 16px color-mix(in srgb, var(--color-bg) 35%, transparent);
}

.fin-prestamo-modal__footer .btn {
    min-height: 48px;
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

@media (min-width: 480px) {
    .fin-prestamo-amount-row {
        grid-template-columns: 1fr minmax(10rem, 12rem);
        gap: var(--space-md) var(--space-lg);
    }

    .fin-prestamo-moneda-wrap {
        min-width: 10rem;
    }

    .fin-prestamo-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fin-prestamo-grid--tasa {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fin-prestamo-plan-box__row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 640px) {
    .fin-prestamo-modal {
        align-items: center;
        padding: var(--space-md);
    }

    .fin-prestamo-modal__handle {
        display: none;
    }

    .fin-prestamo-modal__panel {
        border-radius: var(--radius-lg, 12px);
        max-height: min(88dvh, 820px);
        box-shadow: 0 12px 40px color-mix(in srgb, var(--color-bg) 55%, transparent);
    }

    .fin-prestamo-modal__header {
        padding: var(--space-lg) var(--space-lg) var(--space-sm);
    }

    .fin-prestamo-modal__header h2 {
        font-size: var(--text-lg, 1.125rem);
    }

    .fin-prestamo-modal__scroll {
        padding: var(--space-md) var(--space-lg) var(--space-lg);
        gap: var(--space-lg);
    }

    .fin-prestamo-card {
        padding: var(--space-sm) 0 var(--space-md);
    }

    .fin-prestamo-card__title {
        font-size: var(--text-sm);
        letter-spacing: 0.04em;
    }

    .fin-prestamo-modal__footer {
        padding: var(--space-md) var(--space-lg) max(var(--space-lg), env(safe-area-inset-bottom, 0px));
        gap: var(--space-md);
    }

    .fin-prestamo-modal__footer-toolbar {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: var(--space-md);
    }

    .fin-prestamo-modal__footer-actions {
        flex-direction: row;
        flex-wrap: nowrap;
        width: auto;
    }

    .fin-prestamo-modal__footer-actions .btn-primary {
        width: auto;
        min-width: 11rem;
    }

    .fin-prestamo-footer-bar {
        margin: 0 0 var(--space-xs);
    }

    .fin-prestamo-modal__footer-actions .btn {
        flex: 0 1 auto;
        min-width: 8rem;
    }

    .fin-prestamo-preview__list {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .fin-prestamo-preview__item {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.15rem;
    }

    .fin-prestamo-preview__item dd {
        text-align: left;
    }
}

@media (max-width: 639px) {
    .fin-prestamo-modal__panel--scrollable .fin-prestamo-modal__footer--sticky-mobile {
        position: sticky;
        bottom: 0;
        z-index: 4;
        margin-top: auto;
        backdrop-filter: blur(8px);
        -webkit-backdrop-filter: blur(8px);
        background: color-mix(in srgb, var(--color-surface-elevated) 92%, transparent);
        box-shadow: 0 -6px 20px color-mix(in srgb, var(--color-bg) 45%, transparent);
    }

    .fin-prestamo-modal__panel--scrollable .fin-prestamo-modal__footer--sticky-mobile.fin-prestamo-modal__footer--is-scrolled {
        box-shadow: 0 -10px 28px color-mix(in srgb, var(--color-bg) 60%, transparent);
    }

    .fin-prestamo-modal__panel--scrollable .fin-prestamo-modal__scroll {
        scroll-padding-bottom: var(--space-md);
    }
}

@media (min-width: 900px) {
    .fin-prestamo-grid--tasa {
        grid-template-columns: 1fr 1fr;
    }
}

[data-theme="dark"] .fin-prestamo-segment__btn.is-active {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}

[data-theme="dark"] .fin-prestamo-preview--empty {
    background: var(--color-bg-elevated, var(--color-surface-muted));
}
