/* ============================================================================
   SISCREDI - SUBMIT MODAL STYLES
   ============================================================================
   Estilos para el componente SubmitModal (modal unificado in-place).
   Extiende los estilos de alert-modal.css y modal.css existentes.
   ============================================================================ */

/* ============================================================================
   SPINNER DE PROCESAMIENTO
   ============================================================================ */

.submit-modal-spinner {
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    animation: iconBounce 0.6s ease-out;
}

/* ============================================================================
   ANIMACIÓN DE TRANSICIÓN ENTRE ESTADOS
   ============================================================================ */

/* Transición suave del contenido durante cambios de estado */
.submit-modal .modal-body {
    transition: opacity 0.1s ease;
}

.submit-modal-fading {
    opacity: 0;
    pointer-events: none;
}

/* Transición suave del tamaño del dialog */
.submit-modal .modal-dialog {
    transition: max-width 0.25s ease;
}

/* ============================================================================
   FOOTER OCULTO DURANTE PROCESSING
   ============================================================================ */

.submit-modal-footer-hidden {
    display: none !important;
}

/* ============================================================================
   DETALLES TÉCNICOS EN ESTADO ERROR
   ============================================================================ */

.submit-modal-technical {
    margin-top: 1rem;
}

/* ============================================================================
   SUMMARY CARDS - Sistema unificado para contenido de confirmación
   ============================================================================
   Clases reutilizables para todos los módulos (Clientes, Préstamos, Pagos).
   Usa variables CSS de tokens.css para consistencia con el sistema.
   ============================================================================ */

/* Grid contenedor del resumen */
.sm-summary {
    text-align: left;
}

.sm-summary .row { margin: 0; }

/* Card individual dentro del resumen */
.sm-summary-card {
    background: var(--bs-secondary-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: var(--bs-border-radius);
    box-shadow: var(--bs-box-shadow-sm);
    overflow: hidden;
}

/* Header de la card con color temático */
.sm-summary-card-header {
    padding: 0.5rem 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    border-bottom: 1px solid var(--bs-border-color);
    background: var(--bs-primary-bg-subtle);
}

.sm-summary-card-header i {
    font-size: 0.95rem;
}

.sm-summary-card-header h6 {
    margin: 0;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

/* Variantes de color del header */
.sm-summary-card-header.sm-header-primary {
    background: var(--bs-primary-bg-subtle);
    color: var(--bs-primary-text-emphasis);
}
.sm-summary-card-header.sm-header-primary i { color: var(--bs-primary); }

.sm-summary-card-header.sm-header-success {
    background: var(--bs-success-bg-subtle);
    color: var(--bs-success-text-emphasis);
}
.sm-summary-card-header.sm-header-success i { color: var(--bs-success); }

.sm-summary-card-header.sm-header-info {
    background: var(--bs-info-bg-subtle);
    color: var(--bs-info-text-emphasis);
}
.sm-summary-card-header.sm-header-info i { color: var(--bs-info); }

.sm-summary-card-header.sm-header-warning {
    background: var(--bs-warning-bg-subtle);
    color: var(--bs-warning-text-emphasis);
}
.sm-summary-card-header.sm-header-warning i { color: var(--bs-warning); }

.sm-summary-card-header.sm-header-danger {
    background: var(--bs-danger-bg-subtle);
    color: var(--bs-danger-text-emphasis);
}
.sm-summary-card-header.sm-header-danger i { color: var(--bs-danger); }

.sm-summary-card-header.sm-header-secondary {
    background: var(--bs-secondary-bg-subtle);
    color: var(--bs-secondary-text-emphasis);
}
.sm-summary-card-header.sm-header-secondary i { color: var(--bs-secondary); }

.sm-summary-card-header.sm-header-purple {
    background: var(--bs-purple-bg-subtle);
    color: var(--bs-purple-text-emphasis);
}
.sm-summary-card-header.sm-header-purple i { color: var(--bs-purple); }

/* Body de la card */
.sm-summary-card-body {
    padding: 0.625rem 0.75rem;
}

/* Par label-value dentro de las cards */
.sm-field {
    margin-bottom: 0.25rem;
}

.sm-field-label {
    display: block;
    font-size: 0.7rem;
    color: var(--bs-secondary-color);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-weight: 500;
}

.sm-field-value {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--bs-body-color);
    word-break: break-word;
}

.sm-field-value.sm-value-highlight {
    font-size: 1rem;
    color: var(--bs-success);
}

.sm-field-value.sm-value-currency {
    font-size: 0.95rem;
    color: var(--bs-success);
}

/* Tabla de distribución (Pagos) */
.sm-dist-table {
    width: 100%;
    font-size: 0.85rem;
    margin-bottom: 0;
}

.sm-dist-table thead th {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--bs-secondary-color);
    border-bottom-width: 1px;
    padding: 0.375rem 0.5rem;
}

.sm-dist-table tbody td {
    padding: 0.375rem 0.5rem;
    vertical-align: middle;
}

.sm-dist-table tbody tr:not(:last-child) td {
    border-bottom-color: var(--bs-border-color-translucent);
}

/* Badge para montos */
.sm-amount-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    border-radius: var(--bs-border-radius);
    font-size: 0.8rem;
    font-weight: 600;
    background: var(--bs-primary-bg-subtle);
    color: var(--bs-primary-text-emphasis);
}

/* Alerta de condonaciones */
.sm-condonation-alert {
    margin-top: 0.75rem;
    padding: 0.625rem 0.75rem;
    border-radius: var(--bs-border-radius);
    background: var(--bs-success-bg-subtle);
    border: 1px solid var(--bs-success-border-subtle);
    font-size: 0.85rem;
}

.sm-condonation-alert h6 {
    font-size: 0.8rem;
    font-weight: 700;
    margin-bottom: 0.375rem;
    color: var(--bs-success-text-emphasis);
}

.sm-condonation-alert ul {
    font-size: 0.8rem;
    margin-bottom: 0.25rem;
}

/* Info footer */
.sm-info-footer {
    margin-top: 0.75rem;
    padding: 0.5rem 0.75rem;
    border-radius: var(--bs-border-radius);
    background: var(--bs-info-bg-subtle);
    border: 1px solid var(--bs-info-border-subtle);
    font-size: 0.8rem;
    color: var(--bs-info-text-emphasis);
}

.sm-info-footer i {
    color: var(--bs-info);
}

/* Gap entre cards en grid */
.sm-summary .sm-row + .sm-row {
    margin-top: 0.5rem;
}

/* Dark mode */
[data-bs-theme="dark"] .sm-summary-card {
    background: var(--bs-tertiary-bg);
}

[data-bs-theme="dark"] .sm-summary-card-header.sm-header-purple {
    background: var(--bs-purple-bg-subtle);
}

/* ============================================================================
   RESPONSIVE
   ============================================================================ */

@media (max-width: 576px) {
    .submit-modal-spinner {
        width: 60px;
        height: 60px;
    }

    .submit-modal-spinner .spinner-border {
        width: 2rem !important;
        height: 2rem !important;
    }

    .sm-field-value {
        font-size: 0.8rem;
    }

    .sm-summary-card-header h6 {
        font-size: 0.75rem;
    }
}

/* ============================================================================
   ACCESSIBILITY
   ============================================================================ */

@media (prefers-reduced-motion: reduce) {
    .submit-modal-spinner {
        animation: none;
    }

    .submit-modal-fading {
        transition: none;
    }
}
