/**
 * Estilos de impresión para Kreditzen
 * Estrictamente basados en las capturas de pantalla proporcionadas
 */

@media print {
    /* Reset general y limpieza */
    body, html {
        margin: 0 !important;
        padding: 0 !important;
        background: white !important;
        color: #333333 !important;
        font-family: Arial, sans-serif !important;
        font-size: 12pt !important;
        line-height: 1.3 !important;
        width: 100% !important;
    }
    
    /* Ocultar elementos de navegación y UI */
    header, nav, .sidebar, footer, 
    .navbar, .btn, .no-print, 
    #navbarNav, #sidebar, 
    .form-section, #smart-payment-form, #no-cards-message,
    .btn:not(.print-only-btn), 
    .collapse:not(.show) {
        display: none !important;
    }
    
    /* Ocultar botones y controles que no deberían imprimirse */
    button, .btn, input, select, .form-control, 
    .card-checkbox, .nav-item,
    .form-check-input, .form-select, 
    .calculator-section input, .calculator-section select,
    .calculator-section button {
        display: none !important;
    }
    
    /* Eliminación de estilos dinámicos que no deberían aparecer en la impresión */
    .shadow, .shadow-sm, .transition, .hover-effect {
        box-shadow: none !important;
        transition: none !important;
        transform: none !important;
    }
    
    /* Configuración de página */
    @page {
        size: letter portrait;
        margin: 1.5cm 1cm;
    }
    
    /* Encabezado y estilo base */
    .print-header {
        display: block !important;
        margin-bottom: 15mm !important;
        width: 100% !important;
    }
    
    .print-date {
        font-size: 10pt !important;
        color: #666 !important;
        text-align: right !important;
        margin-bottom: 5mm !important;
    }
    
    .report-title {
        font-size: 24pt !important;
        color: #444 !important;
        text-align: center !important;
        margin-bottom: 0 !important;
        font-weight: normal !important;
    }
    
    .report-subtitle {
        font-size: 12pt !important;
        color: #666 !important;
        text-align: center !important;
        margin-bottom: 5mm !important;
    }
    
    hr {
        border: none !important;
        border-top: 1px solid #ddd !important;
        margin: 5mm 0 !important;
    }
    
    /* Contenedores y secciones */
    .container, .container-fluid, main, .content-area, .content {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        background: white !important;
    }
    
    /* Títulos e iconografía */
    h4, h5, h6 {
        page-break-after: avoid !important;
        font-size: 16pt !important;
        margin-bottom: 5mm !important;
        color: #333 !important;
        font-weight: normal !important;
    }
    
    h4 i, h5 i, h6 i {
        margin-right: 2mm !important;
    }
    
    /* ESTILO EXACTO PARA TABLA DE COMPARACIÓN DE TARJETAS */
    table {
        width: 100% !important;
        border-collapse: collapse !important;
        margin-bottom: 8mm !important;
        page-break-inside: avoid !important;
    }
    
    th {
        background-color: #f5f5f5 !important;
        color: #333 !important;
        border: 1px solid #ddd !important;
        padding: 2mm !important;
        font-weight: bold !important;
        text-align: center !important;
        font-size: 10pt !important;
    }
    
    td {
        border: 1px solid #ddd !important;
        padding: 2mm !important;
        text-align: center !important;
        font-size: 10pt !important;
        color: #333 !important;
    }
    
    /* SECCIÓN DE CALCULADORA DE PAGOS - EXACTAMENTE COMO EN LA IMAGEN */
    .calculator-print-section {
        margin-bottom: 8mm !important;
        page-break-inside: avoid !important;
        border: none !important;
        padding: 0 !important;
    }
    
    .calculator-print-section h4 {
        font-size: 16pt !important;
        margin-bottom: 3mm !important;
        color: #333 !important;
    }
    
    /* COMPARACIÓN DE ESTRATEGIAS */
    #strategy-comparison-container {
        margin-bottom: 8mm !important;
        page-break-inside: avoid !important;
    }
    
    /* Caja verde de recomendación */
    .recommended-strategy {
        border: 1px solid #ddd !important;
        background-color: #f9f9f9 !important;
        padding: 3mm !important;
        margin-bottom: 3mm !important;
        page-break-inside: avoid !important;
    }
    
    .recommended-strategy i.fa-check-circle {
        color: #4CAF50 !important;
    }
    
    /* Distribución de pagos */
    #payment-distribution-table {
        width: 100% !important;
        margin-top: 3mm !important;
        margin-bottom: 8mm !important;
    }
    
    #payment-distribution-table th {
        background-color: #f5f5f5 !important;
        color: #333 !important;
        font-weight: bold !important;
        border: 1px solid #ddd !important;
        text-align: center !important;
    }
    
    #payment-distribution-table td {
        border: 1px solid #ddd !important;
        text-align: center !important;
    }
    
    /* INDICADORES DE ESTADO - EXACTAMENTE COMO EN LAS CAPTURAS */
    .status-liquidado, .status-liquidated, .status-badge-liquidated {
        display: inline-block !important;
        background-color: #e8f5e9 !important;
        color: #388e3c !important;
        border-radius: 4px !important;
        padding: 1mm 2mm !important;
        font-size: 9pt !important;
        font-weight: normal !important;
    }
    
    .status-foco, .status-focus, .status-badge-focus {
        display: inline-block !important;
        background-color: #e3f2fd !important;
        color: #1976d2 !important;
        border-radius: 4px !important;
        padding: 1mm 2mm !important;
        font-size: 9pt !important;
        font-weight: normal !important;
    }
    
    .status-regular, .status-badge-regular {
        display: inline-block !important;
        background-color: #f5f5f5 !important;
        color: #616161 !important;
        border-radius: 4px !important;
        padding: 1mm 2mm !important;
        font-size: 9pt !important;
        font-weight: normal !important;
    }
    
    /* Forzar que las tablas se vean exactamente como en las capturas */
    .distribution-table {
        border: 1px solid #ddd !important;
        width: 100% !important;
    }
    
    /* VISUALIZACIÓN DE GRÁFICAS - EXACTAMENTE COMO EN LAS CAPTURAS */
    .chart-container {
        width: 100% !important;
        height: auto !important;
        max-height: 100mm !important;
        margin: 0 auto 8mm auto !important;
        page-break-inside: avoid !important;
    }
    
    canvas {
        max-width: 100% !important;
        height: auto !important;
    }
    
    /* Forzar pie de página */
    .print-footer {
        text-align: center !important;
        font-size: 9pt !important;
        color: #666 !important;
        margin-top: 10mm !important;
        border-top: 1px solid #ddd !important;
        padding-top: 2mm !important;
        position: fixed !important;
        bottom: 5mm !important;
        width: 100% !important;
    }
    
    /* Paginación */
    .page-url {
        text-align: left !important;
        font-size: 8pt !important;
        color: #666 !important;
        position: fixed !important;
        bottom: 5mm !important;
        left: 5mm !important;
    }
    
    .page-number {
        text-align: right !important;
        font-size: 8pt !important;
        color: #666 !important;
        position: fixed !important;
        bottom: 5mm !important;
        right: 5mm !important;
    }
    
    .page-number:after {
        content: counter(page) "/" counter(pages);
    }
    
    /* ASEGURAR ESTILOS DE ALERTA COMO EN LA CAPTURA */
    .alert-info {
        border: 1px solid #ddd !important;
        background-color: #f9f9f9 !important;
        padding: 3mm !important;
        margin-bottom: 5mm !important;
        color: #333 !important;
    }
    
    /* REMEDIAR PROBLEMAS COMUNES DE IMPRESIÓN */
    @page :first {
        margin-top: 0 !important;
    }
    
    /* Eliminar elementos que puedan aparecer en medio de la impresión */
    html, body {
        overflow: visible !important;
    }
    
    /* Para garantizar que la página se rompa correctamente */
    .page-break-before {
        page-break-before: always !important;
    }
    
    .page-break-after {
        page-break-after: always !important;
    }
    
    .avoid-break-inside {
        page-break-inside: avoid !important;
    }
}