/* Print stylesheet for reliable mobile voucher printing */

@media print {
    /* Hide everything except the print root */
    body > *:not(#print-root) {
        display: none !important;
    }
    
    /* Show only the print root content */
    #print-root {
        display: block !important;
        visibility: visible !important;
    }
    
    /* Reset page margins and ensure proper layout */
    @page {
        margin: 12mm;
        size: A4 portrait;
    }
    
    /* Base print styling */
    body {
        margin: 0;
        padding: 0;
        font-family: Arial, sans-serif !important;
        background: white !important;
        color: black !important;
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }
    
    /* Print root container styling */
    #print-root {
        width: 100% !important;
        max-width: 480px !important;
        margin: 0 auto !important;
        padding: 16px !important;
        background: white !important;
        font-size: 12px !important;
        line-height: 1.4 !important;
    }
    
    /* Voucher card styling for print */
    #print-root .voucher-print-card {
        border: 2px solid #000 !important;
        background: white !important;
        padding: 16px !important;
        margin: 0 !important;
        box-shadow: none !important;
        border-radius: 0 !important;
    }
    
    /* Header styling */
    #print-root .voucher-print-header {
        text-align: center !important;
        margin-bottom: 16px !important;
        padding-bottom: 12px !important;
        border-bottom: 2px dashed #000 !important;
    }
    
    #print-root .voucher-print-header h1 {
        font-size: 16px !important;
        font-weight: bold !important;
        margin: 0 0 8px 0 !important;
        color: black !important;
        text-transform: uppercase !important;
    }
    
    #print-root .voucher-print-id {
        font-size: 12px !important;
        font-weight: normal !important;
        color: black !important;
        margin: 0 !important;
    }
    
    /* Body content styling */
    #print-root .voucher-print-body {
        margin-bottom: 16px !important;
    }
    
    #print-root .voucher-print-row {
        display: flex !important;
        justify-content: space-between !important;
        margin-bottom: 8px !important;
        padding: 6px 0 !important;
        border-bottom: 1px dotted #ccc !important;
        align-items: center !important;
    }
    
    #print-root .voucher-print-row:last-child {
        border-bottom: none !important;
    }
    
    #print-root .voucher-print-label {
        font-weight: bold !important;
        color: black !important;
        flex-shrink: 0 !important;
        margin-right: 8px !important;
    }
    
    #print-root .voucher-print-value {
        color: black !important;
        text-align: right !important;
        word-wrap: break-word !important;
    }
    
    #print-root .voucher-print-value.amount {
        font-weight: bold !important;
        font-size: 14px !important;
    }
    
    /* QR code styling for print */
    #print-root .voucher-print-qr {
        text-align: center !important;
        margin: 16px 0 !important;
        padding-top: 12px !important;
        border-top: 1px solid #ccc !important;
    }
    
    #print-root .voucher-print-qr img,
    #print-root .voucher-print-qr canvas {
        border: 1px solid #000 !important;
        max-width: 160px !important;
        max-height: 160px !important;
        display: block !important;
        margin: 0 auto !important;
        background: white !important;
    }
    
    #print-root .voucher-print-qr-label {
        font-size: 10px !important;
        color: #666 !important;
        margin-top: 4px !important;
        margin-bottom: 0 !important;
    }
    
    /* Ensure proper break behavior */
    #print-root .voucher-print-card {
        page-break-inside: avoid !important;
        break-inside: avoid !important;
    }
    
    /* Override any conflicting styles */
    #print-root * {
        box-sizing: border-box !important;
    }
}

/* Screen styling for print root (hidden by default) */
#print-root {
    display: none;
    position: absolute;
    left: -9999px;
    top: -9999px;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
}

/* Accessibility - ensure screen readers can understand print content */
#print-root[aria-hidden="false"] {
    position: static;
    left: auto;
    top: auto;
    visibility: visible;
    opacity: 1;
}
