/**
 * POS thermal receipt (58mm / 80mm ESC/POS browser print)
 * Load after print.css so logo rules override global `img { max-width: 60px }`.
 */

:root {
    --pos-thermal-logo-max-h-screen: 72px;
    --pos-thermal-logo-max-w-58-print: 42mm;
    --pos-thermal-logo-max-w-80-print: 54mm;
    --pos-thermal-logo-max-h-print: 15mm;
}

/* ─── Screen preview ─── */
.receipt-logo-thermal {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    margin: 0 auto 8px;
    color-scheme: only light;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
}

.receipt-logo-thermal-img {
    display: block;
    margin: 0 auto;
    padding: 0;
    border: 0;
    outline: none;
    box-shadow: none;
    background: #fff;
    max-width: min(54mm, 100%);
    max-height: var(--pos-thermal-logo-max-h-screen);
    width: auto;
    height: auto;
    object-fit: contain;
    object-position: center center;
    /* Monochrome + punch for thermal dots */
    filter: grayscale(1) contrast(1.3) brightness(1.03);
    -webkit-filter: grayscale(1) contrast(1.3) brightness(1.03);
    /* Sharper resampling when the browser scales the bitmap */
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
    -ms-interpolation-mode: nearest-neighbor;
}

.receipt-logo-fallback-text {
    font-family: "Courier New", Courier, monospace;
    font-size: 15px;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-align: center;
    line-height: 1.2;
    color: #000;
    max-width: 100%;
    padding: 6px 4px;
    margin: 0 auto;
}

/* 58mm roll: cap logo width */
.pos-receipt.thermal-receipt-58 .receipt-logo-thermal-img {
    max-width: min(42mm, 100%);
}

/* ─── Print: override global print.css img constraints ─── */
@media print {
    .receipt-logo-thermal {
        -webkit-print-color-adjust: exact !important;
        print-color-adjust: exact !important;
        color-adjust: exact !important;
        color-scheme: only light !important;
    }

    .receipt-logo-thermal-img {
        /* Beats print.css `img { max-width: 60px; height: 60px; }` */
        max-height: var(--pos-thermal-logo-max-h-print) !important;
        width: auto !important;
        height: auto !important;
        min-width: 0 !important;
        min-height: 0 !important;
        margin: 0 auto !important;
        padding: 0 !important;
        object-fit: contain !important;
        object-position: center center !important;
        background: #fff !important;
        filter: grayscale(1) contrast(1.5) brightness(1.06) !important;
        -webkit-filter: grayscale(1) contrast(1.5) brightness(1.06) !important;
        -webkit-print-color-adjust: exact !important;
        print-color-adjust: exact !important;
        image-rendering: -webkit-optimize-contrast !important;
        image-rendering: crisp-edges !important;
        -ms-interpolation-mode: nearest-neighbor !important;
        page-break-inside: avoid;
        break-inside: avoid;
    }

    .pos-receipt.thermal-receipt-80 .receipt-logo-thermal-img {
        max-width: var(--pos-thermal-logo-max-w-80-print) !important;
    }

    .pos-receipt.thermal-receipt-58 .receipt-logo-thermal-img {
        max-width: var(--pos-thermal-logo-max-w-58-print) !important;
    }

    .receipt-logo-fallback-text {
        color: #000 !important;
        -webkit-print-color-adjust: exact !important;
        print-color-adjust: exact !important;
    }

    /* Match roll width when POS receipt modal is printed (order list + POS screen) */
    body:has(.pos-rcpt-modal-overlay.thermal-print-58),
    body:has(.pos-modal-overlay.thermal-print-58) {
        width: 58mm !important;
        max-width: 58mm !important;
    }

    body:has(.pos-rcpt-modal-overlay.thermal-print-80),
    body:has(.pos-modal-overlay.thermal-print-80) {
        width: 80mm !important;
        max-width: 80mm !important;
    }

    .pos-rcpt-modal-overlay.thermal-print-58,
    .pos-rcpt-modal-overlay.thermal-print-58 .pos-rcpt-modal,
    .pos-rcpt-modal-overlay.thermal-print-58 .print-area,
    .pos-rcpt-modal-overlay.thermal-print-58 .pos-receipt,
    .pos-modal-overlay.thermal-print-58,
    .pos-modal-overlay.thermal-print-58 .pos-modal,
    .pos-modal-overlay.thermal-print-58 .print-area,
    .pos-modal-overlay.thermal-print-58 .pos-receipt {
        width: 58mm !important;
        max-width: 58mm !important;
    }

    .pos-rcpt-modal-overlay.thermal-print-80,
    .pos-rcpt-modal-overlay.thermal-print-80 .pos-rcpt-modal,
    .pos-rcpt-modal-overlay.thermal-print-80 .print-area,
    .pos-rcpt-modal-overlay.thermal-print-80 .pos-receipt,
    .pos-modal-overlay.thermal-print-80,
    .pos-modal-overlay.thermal-print-80 .pos-modal,
    .pos-modal-overlay.thermal-print-80 .print-area,
    .pos-modal-overlay.thermal-print-80 .pos-receipt {
        width: 80mm !important;
        max-width: 80mm !important;
    }
}
