/* =========================================================================
 * Print document — condiviso da view-order e carrello
 *
 * Due cose:
 *  1) Pulsante stampa (ordine + carrello) e riga IVA dei totali su schermo.
 *  2) `@media print`: nasconde tutto il body e mostra SOLO il blocco
 *     `.mz-print-doc` riformattato come documento fattura A4. Stessa grafica
 *     per ordine e carrello: cambia solo cosa il PHP popola nel markup.
 * ========================================================================= */

/* =========================================================================
 *  SCHERMO
 * ========================================================================= */

/* --- Pulsante stampa: stessa estetica nei due contesti. --- */
.mz-order__print,
.mz-cart-totals__print {
  width: 100%;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  background: transparent;
  color: var(--ink-1);
  border: 1px solid var(--border);
  border-radius: var(--r-2);
  font: inherit;
  font-weight: 600;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease, color .15s ease, transform .05s ease;
}
.mz-order__print:hover,
.mz-cart-totals__print:hover  { background: var(--paper-1); border-color: var(--ink-1); }
.mz-order__print:active,
.mz-cart-totals__print:active { transform: translateY(1px); }
.mz-order__print:focus-visible,
.mz-cart-totals__print:focus-visible { outline: 2px solid var(--ink-1); outline-offset: 2px; }
.mz-order__print-icon,
.mz-cart-totals__print-icon  { width: 18px; height: 18px; flex: 0 0 18px; color: currentColor; }

/* --- Riga IVA (rientro sottile dal grand total) --- */
.mz-order__totals-row--iva dt,
.mz-order__totals-row--iva dd {
  color: var(--ink-2);
}

/* --- Documento print: nascosto su schermo --- */
.mz-print-doc { display: none; }

/* =========================================================================
 *  STAMPA — reset bestiale + documento
 * ========================================================================= */
@media print {
  @page { size: A4; margin: 14mm 14mm 16mm; }

  /* Neutralizza il dark mode in stampa: forziamo lo schema chiaro e
     riportiamo i token surface/ink ai valori light, così anche elementi
     che leggono `var(--paper-…)` o `var(--ink-…)` non trascinano colori
     scuri nel documento stampato. */
  :root,
  [data-theme="dark"],
  [data-theme="auto"] {
    color-scheme: light !important;
    --paper:     #fff !important;
    --paper-2:   #fff !important;
    --paper-3:   #fafafa !important;
    --paper-ink: #fff !important;
    --ink-1:     #111 !important;
    --ink-2:     #444 !important;
    --ink-3:     #777 !important;
  }

  html, body {
    background: #fff !important;
    color: #111 !important;
    font: 10.5pt/1.45 'Inter', system-ui, sans-serif !important;
    margin: 0 !important;
    padding: 0 !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  /* Nasconde TUTTO tranne il print-doc.
     ---
     Perche display:none e non visibility:hidden:
     visibility:hidden lascia gli elementi nel layout flow — Chrome/Safari
     in stampa paginano lo spazio verticale che quelle sezioni occupano
     on-screen, generando pagine bianche per pagine alte (es. thank-you
     con header + receipt + steps + items + indirizzi). display:none
     rimuove l'elemento dal flow, una sola pagina.
     ---
     Strategia: display:none di default su ogni descendant di body,
     poi :has() ri-mostra il print-doc + la sua intera catena di
     antenati (indipendentemente da quanti wrapper template ci sono
     in mezzo: #mz-content, .mz-page#primary, article.entry, ecc.).
     `display: revert` sui descendant fa tornare il default UA
     (table->table, dl->block, ecc.), e le regole successive in questo
     stesso @media print danno il display: grid/flex dove serve. */
  body * { display: none !important; }
  body :has(.mz-print-doc) {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #fff !important;
    border: 0 !important;
    box-shadow: none !important;
    max-width: none !important;
    width: auto !important;
  }
  .mz-print-doc,
  .mz-print-doc * {
    display: revert !important;
  }
  .mz-print-doc {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #fff !important;
    color: #111 !important;
  }

  /* --- HEAD: brand sx, identificativo dx --- */
  .mz-print-doc__head {
    display: grid !important;
    grid-template-columns: 1.2fr 1fr !important;
    gap: 10mm;
    align-items: start;
    padding-bottom: 6mm;
    margin-bottom: 7mm;
    border-bottom: 2pt solid #111;
  }
  .mz-print-doc__brand { display: flex; flex-direction: column; gap: 1.5mm; }
  .mz-print-doc__brand-logo {
    display: block !important;
    height: 10mm !important;
    width: auto !important;
    max-width: 30mm !important;
    margin-bottom: 0.5mm;
  }
  .mz-print-doc__brand-name {
    font-size: 20pt;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.015em;
    text-transform: uppercase;
    color: #111;
  }
  .mz-print-doc__brand-tag {
    font-size: 9pt;
    font-weight: 500;
    letter-spacing: 0.04em;
    color: #555;
    text-transform: uppercase;
  }
  .mz-print-doc__brand-lines {
    margin-top: 1.5mm;
    display: flex;
    flex-direction: column;
    gap: 1.5mm;
    font-size: 8.5pt;
    color: #444;
    line-height: 1.45;
    max-width: 85mm;
  }
  /* Ragione sociale + P.IVA + REA: blocco "legale" — leggermente piu
     pesato per distinguerlo dall'indirizzo. */
  .mz-print-doc__brand-legal {
    color: #222;
    font-weight: 500;
  }
  /* PEC / SDI Manzo: codici tecnici in mono, dimensione ridotta. */
  .mz-print-doc__brand-fiscal {
    font: 600 7.5pt/1.4 'IBM Plex Mono', monospace;
    letter-spacing: 0.02em;
    color: #333;
  }
  /* Linea contatti (tel + email): leggera, tono di chiusura. */
  .mz-print-doc__brand-contact {
    color: #666;
    font-size: 8pt;
  }

  .mz-print-doc__id {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    text-align: right;
    gap: 1mm;
  }
  .mz-print-doc__id-label {
    font-size: 8pt;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #777;
    font-weight: 600;
  }
  .mz-print-doc__id-num {
    font: 700 22pt/1 'IBM Plex Mono', ui-monospace, monospace;
    color: #111;
    margin-bottom: 2mm;
  }
  .mz-print-doc__id-meta {
    margin: 0;
    display: grid;
    grid-template-columns: auto auto;
    gap: 1mm 5mm;
    text-align: right;
  }
  .mz-print-doc__id-meta > div { display: contents; }
  .mz-print-doc__id-meta dt {
    font-size: 7.5pt;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #777;
    text-align: right;
  }
  .mz-print-doc__id-meta dd {
    margin: 0;
    font-size: 9pt;
    font-family: 'IBM Plex Mono', monospace;
    color: #111;
    text-align: right;
  }
  .mz-print-doc__id-status {
    font-weight: 700 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
  }

  /* --- PARTIES: spedizione | fatturazione --- */
  .mz-print-doc__parties {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8mm;
    margin-bottom: 7mm;
    page-break-inside: avoid;
  }
  .mz-print-doc__party {
    padding: 4mm 4.5mm;
    border: 0.5pt solid #ccc;
    border-radius: 1.5mm;
    background: #fafafa;
  }
  .mz-print-doc__party h3 {
    margin: 0 0 2mm;
    font-size: 7.5pt;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #666;
    font-weight: 700;
    padding-bottom: 1.5mm;
    border-bottom: 0.4pt solid #ccc;
  }
  .mz-print-doc__party address {
    font-style: normal;
    font-size: 9.5pt;
    line-height: 1.55;
    color: #111;
  }
  .mz-print-doc__party-extra {
    margin: 2.5mm 0 0;
    display: flex;
    gap: 5mm;
    padding-top: 2mm;
    border-top: 0.3pt dashed #aaa;
  }
  .mz-print-doc__party-extra > div { display: flex; flex-direction: column; gap: 0.5mm; }
  .mz-print-doc__party-extra dt {
    font-size: 7pt;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #777;
    margin: 0;
  }
  .mz-print-doc__party-extra dd {
    margin: 0;
    font: 600 9pt/1.2 'IBM Plex Mono', monospace;
    color: #111;
  }

  /* ---- Party full-width (quando l'altra parte manca) ----
     Il card occupa entrambe le colonne del grid 1fr 1fr, e il
     contenuto interno si splitta in 2 colonne: indirizzo a
     sinistra, dati fiscali a destra. Riduce a circa metà
     l'altezza del documento quando c'è solo Fatturazione. */
  .mz-print-doc__party--full {
    grid-column: 1 / -1;
    display: grid !important;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    column-gap: 8mm;
    align-items: start;
  }
  .mz-print-doc__party--full h3 {
    grid-column: 1 / -1;
  }
  .mz-print-doc__party--full address {
    grid-column: 1;
    grid-row: 2;
    margin: 0;
  }
  .mz-print-doc__party--full .mz-print-doc__party-extra {
    grid-column: 2;
    grid-row: 2;
    margin: 0;
    padding: 0;
    border-top: 0;
    flex-direction: column;
    gap: 1.8mm;
  }

  /* --- ITEMS: tabella fattura --- */
  .mz-print-doc__items {
    width: 100%;
    border-collapse: collapse;
    margin: 0 0 5mm;
    font-size: 9.5pt;
  }
  .mz-print-doc__items thead th {
    text-align: left;
    font-size: 7.5pt;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #fff;
    background: #111;
    padding: 2.2mm 3mm;
    font-weight: 700;
  }
  .mz-print-doc__items thead .mz-print-doc__col-qty,
  .mz-print-doc__items thead .mz-print-doc__col-total { text-align: right; }
  .mz-print-doc__items tbody td {
    padding: 2.5mm 3mm;
    border-bottom: 0.4pt solid #ddd;
    vertical-align: top;
    line-height: 1.45;
    page-break-inside: avoid;
  }
  .mz-print-doc__items tbody tr:nth-child(even) td { background: #fafafa; }

  .mz-print-doc__col-code  {
    width: 26mm;
    font: 600 9pt 'IBM Plex Mono', monospace;
    color: #111;
    white-space: nowrap;
  }
  .mz-print-doc__col-desc  { width: auto; color: #111; }
  /* Colonna marca: omessa dal documento stampato (richiesta business:
     il cliente non deve vedere la marca su carrello/ordine in stampa). */
  .mz-print-doc__items .mz-print-doc__col-brand { display: none !important; }
  .mz-print-doc__col-qty   {
    width: 14mm;
    text-align: right;
    font: 600 10pt 'IBM Plex Mono', monospace;
    color: #111;
  }
  .mz-print-doc__col-total {
    width: 24mm;
    text-align: right;
    font: 600 10pt 'IBM Plex Mono', monospace;
    color: #111;
    white-space: nowrap;
  }

  /* --- TOTALS: blocco a destra --- */
  .mz-print-doc__totals {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 6mm;
    page-break-inside: avoid;
  }
  .mz-print-doc__totals dl {
    width: 78mm;
    margin: 0;
    display: flex;
    flex-direction: column;
  }
  .mz-print-doc__totals-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 6mm;
    padding: 1.6mm 3mm;
    font-size: 9.5pt;
    border-bottom: 0.3pt solid #e0e0e0;
  }
  .mz-print-doc__totals-row dt { margin: 0; color: #444; }
  .mz-print-doc__totals-row dd { margin: 0; font-family: 'IBM Plex Mono', monospace; color: #111; }

  .mz-print-doc__totals-row.is-iva {
    color: #555;
    background: #f6f6f6;
    border-radius: 0;
  }
  .mz-print-doc__totals-row.is-iva dt::before {
    content: "↳ ";
    color: #999;
  }

  .mz-print-doc__totals-row.is-grand {
    margin-top: 1mm;
    padding: 2.5mm 3mm;
    background: #111;
    color: #fff;
    border-radius: 1.5mm;
    border-bottom: 0;
    font-size: 11.5pt;
    font-weight: 700;
  }
  .mz-print-doc__totals-row.is-grand dt { color: #fff; letter-spacing: 0.06em; text-transform: uppercase; font-size: 8.5pt; }
  .mz-print-doc__totals-row.is-grand dd { color: #fff; font-size: 13pt; font-weight: 700; }

  /* --- NOTES --- */
  .mz-print-doc__notes {
    margin-bottom: 6mm;
    padding: 3.5mm 4.5mm;
    border-left: 1.5pt solid #111;
    background: #fafafa;
    page-break-inside: avoid;
  }
  .mz-print-doc__notes h3 {
    margin: 0 0 2mm;
    font-size: 7.5pt;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #666;
    font-weight: 700;
  }
  .mz-print-doc__notes ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 1.5mm;
  }
  .mz-print-doc__notes li {
    display: grid;
    grid-template-columns: 30mm 1fr;
    gap: 3mm;
    font-size: 9pt;
  }
  .mz-print-doc__note-date {
    font: 500 8.5pt 'IBM Plex Mono', monospace;
    color: #666;
  }
  .mz-print-doc__note-body { color: #222; }

  /* --- FOOTER --- */
  .mz-print-doc__foot {
    margin-top: 8mm;
    padding-top: 4mm;
    border-top: 0.75pt solid #111;
    text-align: center;
  }
  .mz-print-doc__foot-legal {
    font-size: 7.5pt;
    line-height: 1.5;
    color: #555;
    margin-bottom: 2mm;
  }
  .mz-print-doc__foot-thanks {
    font-size: 8pt;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #111;
  }

  /* Spegne link blu / underline ovunque nel documento --- */
  .mz-print-doc a,
  .mz-print-doc a:link,
  .mz-print-doc a:visited {
    color: inherit !important;
    text-decoration: none !important;
  }
}
