/* ============================================
   FACILITAME - Print stylesheet
   Aplica solo en @media print: oculta UI/chrome,
   deja contenido principal con márgenes A4 y monocromo.
   ============================================ */

@media print {
    /* Tamaño y márgenes A4 */
    @page {
        size: A4;
        margin: 1.6cm 1.4cm;
    }

    /* Reset general: quitar fondos y sombras (los colores no imprimen bien) */
    *,
    *::before,
    *::after {
        background: transparent !important;
        color: #000 !important;
        box-shadow: none !important;
        text-shadow: none !important;
        border-color: #000 !important;
    }

    html, body {
        background: #fff !important;
        color: #000 !important;
        font-size: 11pt;
        line-height: 1.4;
        margin: 0 !important;
        padding: 0 !important;
        width: 100% !important;
    }

    /* ---- OCULTAR UI / CHROME ---- */
    .app-sidebar,
    #app_sidebar,
    .sidebar-toggle-btn,
    .facilitame-header,
    #kt_app_header,
    .navbar,
    .topbar,
    .app-header-mobile-drawer,
    .bottom-nav,
    #facilitame-bottom-nav,
    .mobile-toggle-btn,
    .mobile-menu,
    #kt_scrolltop,
    #pwa-install-banner,
    #gsearch-overlay,
    .gsearch-overlay,
    .gsearch-trigger,
    #gsearch-trigger-mobile,
    .skip-link,
    .toast,
    .swal2-container,
    .modal-backdrop,
    /* Acciones, controles y elementos interactivos */
    .btn,
    button,
    .btn-icon,
    .btn-pagination,
    .pagination,
    .pagination-container,
    .filters-bar,
    .filter-container,
    .search-wrapper,
    .header-icon-btn,
    .theme-toggle-btn,
    .dropdown,
    .dropdown-menu,
    .menu-sub,
    .nav-tabs,
    [data-bs-toggle],
    .badge-status.cursor-pointer,
    .list-card-actions,
    .card-actions,
    .actions,
    .footer,
    .app-footer,
    .empty-state-illustration,
    .empty-state-illustrated .btn {
        display: none !important;
        visibility: hidden !important;
    }

    /* Permitir que botones reaparezcan si llevan clase .print-show */
    .print-show {
        display: initial !important;
        visibility: visible !important;
    }

    /* ---- CONTENIDO PRINCIPAL ---- */
    .app-wrapper,
    .app-main,
    #kt_app_main,
    .container-fluid,
    #facilita-app,
    main,
    #main-content {
        margin: 0 !important;
        padding: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        background: #fff !important;
        color: #000 !important;
        display: block !important;
    }

    .card,
    .card-body,
    .modal-content {
        background: #fff !important;
        border: none !important;
        padding: 0 !important;
        margin: 0 0 0.6cm 0 !important;
        page-break-inside: avoid;
    }

    /* Headings */
    h1, h2, h3, h4, h5, h6 {
        color: #000 !important;
        page-break-after: avoid;
        page-break-inside: avoid;
    }

    h1 { font-size: 18pt; margin-bottom: 0.5cm; }
    h2 { font-size: 15pt; margin-bottom: 0.4cm; }
    h3 { font-size: 13pt; margin-bottom: 0.3cm; }
    h4, h5, h6 { font-size: 11pt; margin-bottom: 0.2cm; }

    p, li, td, th {
        color: #000 !important;
    }

    /* Tablas: bordes negros sin fondos */
    table {
        width: 100% !important;
        border-collapse: collapse !important;
        page-break-inside: auto;
    }
    table, th, td {
        border: 1px solid #000 !important;
        background: #fff !important;
        color: #000 !important;
    }
    th, td {
        padding: 4pt 6pt !important;
        vertical-align: top;
    }
    thead {
        display: table-header-group; /* repetir cabecera al cambiar de página */
    }
    tr, td, th {
        page-break-inside: avoid;
        page-break-after: auto;
    }
    /* Quitar zebra striping */
    tr:nth-child(odd),
    tr:nth-child(even) {
        background: #fff !important;
    }

    /* Badges → texto plano con borde fino */
    .badge,
    .badge-status {
        background: #fff !important;
        border: 1px solid #000 !important;
        color: #000 !important;
        padding: 1pt 4pt !important;
        font-weight: normal !important;
    }

    /* Imágenes: limitar al ancho de página */
    img {
        max-width: 100% !important;
        height: auto !important;
        page-break-inside: avoid;
    }

    /* Logos pequeños permitidos */
    .print-logo,
    .header-logo,
    .sidebar-logo-img {
        max-height: 1.5cm !important;
        display: inline-block !important;
        visibility: visible !important;
    }

    /* Forzar links a mostrar URL completa al imprimir */
    a {
        color: #000 !important;
        text-decoration: underline;
        word-wrap: break-word;
    }
    a[href]:not([href^="#"]):not([href^="javascript:"]):after {
        content: " (" attr(href) ")";
        font-size: 9pt;
        color: #555 !important;
        word-break: break-all;
    }
    /* No mostrar URL en mailto/tel cortos: ya son legibles */
    a[href^="mailto:"]:after,
    a[href^="tel:"]:after {
        content: "";
    }

    /* Inputs en print: mostrar valor como texto normal */
    input, select, textarea {
        border: none !important;
        background: transparent !important;
        color: #000 !important;
        padding: 0 !important;
        -webkit-appearance: none;
        appearance: none;
    }

    /* Forzar saltos de página útiles */
    .page-break-before { page-break-before: always; }
    .page-break-after  { page-break-after: always; }
    .no-page-break     { page-break-inside: avoid; }
}
