/* ═══════════════════════════════════════════════════════════════════
   print.css — Print layout matching the original paper timesheet

   Target: US Letter (8.5 × 11), single page, tight margins.
   ═══════════════════════════════════════════════════════════════════ */

@media print {

  /* ─── Page Setup ───────────────────────────────────────────────── */
  @page {
    size: letter portrait;
    margin: 0.45in 0.55in;
  }

  /* ─── Hide screen-only elements ─────────────────────────────────  */
  .no-print,
  .no-print * {
    display: none !important;
  }

  /* ─── Show print-only elements ──────────────────────────────────  */
  .print-only {
    display: block !important;
  }

  /* ─── Base reset ─────────────────────────────────────────────────  */
  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }

  html,
  body {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    background: white !important;
    color: black !important;
    font-family: 'Times New Roman', Times, serif !important;
    font-size: 10.5pt !important;
    line-height: 1.25 !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  #app,
  .main-content {
    background: white !important;
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
    gap: 0 !important;
  }

  /* ─── Print Header ──────────────────────────────────────────────  */
  .print-header {
    text-align: center !important;
    margin-bottom: 8pt !important;
    padding: 0 !important;
    background: white !important;
  }

  .print-title {
    font-family: 'Arial Black', Arial, sans-serif !important;
    font-style: italic !important;
    font-weight: bold !important;
    font-size: 16pt !important;
    margin-bottom: 4pt !important;
    color: black !important;
    display: block !important;
  }

  .print-fields {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    line-height: 1.65 !important;
  }

  .print-field {
    display: flex !important;
    align-items: baseline !important;
    gap: 0.05in !important;
    font-size: 10.5pt !important;
    line-height: 1.6 !important;
    width: 4.2in !important;
  }

  .print-field:last-child {
    margin-bottom: 20px;
  }

  .print-label {
    font-weight: normal !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    width: 1.6in !important;
    text-align: right !important;
  }

  .print-value {
    font-weight: normal !important;
    border-bottom: 1pt solid black !important;
    display: inline-block !important;
    padding-right: 100px;
  }

  /* ─── Cards / Wrappers ──────────────────────────────────────────  */
  .card {
    background: white !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .grid-card {
    display: block !important;
    margin-bottom: 6pt !important;
    overflow: visible !important;
  }

  /* Critical: override the max-height scrollable container for print */
  .table-wrapper {
    overflow: visible !important;
    max-height: none !important;
  }

  /* ─── Timesheet Table ───────────────────────────────────────────  */
  .timesheet-table {
    width: 100% !important;
    border-collapse: collapse !important;
    font-family: 'Times New Roman', Times, serif !important;
    font-size: 9.5pt !important;
    border: 1.5pt solid black !important;
    table-layout: auto !important;
    page-break-inside: avoid !important;
    background: white !important;
  }

  .timesheet-table thead {
    display: table-header-group !important;
  }

  .timesheet-table th {
    background: white !important;
    color: black !important;
    font-size: 9pt !important;
    font-weight: bold !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    padding: 2pt 3pt !important;
    border: 1.5pt solid black !important;
    position: static !important;
    text-align: center !important;
    box-shadow: none !important;
  }

  .timesheet-table td {
    background: white !important;
    border: 1pt solid black !important;
    padding: 1pt 2pt !important;
    font-size: 9.5pt !important;
    text-align: center !important;
    height: 0.255in !important;
    vertical-align: middle !important;
    overflow: hidden !important;
  }

  /* Hide screen-only columns */
  .col-check,
  .col-presets {
    display: none !important;
  }

  /* Column width hints for print */
  .col-date {
    width: 18% !important;
  }

  .col-time {
    width: 14% !important;
  }

  .col-reason {
    width: 22% !important;
  }

  .col-hours {
    width: 12% !important;
  }

  /* Date cell */
  .date-cell {
    text-align: left !important;
    padding-left: 3pt !important;
  }

  .day-name {
    font-weight: bold !important;
    font-size: 9.5pt !important;
    display: block !important;
    line-height: 1.2 !important;
  }

  .day-date {
    font-size: 9.5pt !important;
    color: black !important;
    display: block !important;
    line-height: 1.2 !important;
  }

  /* Inputs → plain text in print */
  .time-input,
  .reason-input,
  .lunch-select {
    border: none !important;
    background: transparent !important;
    font-family: 'Times New Roman', Times, serif !important;
    font-size: 9.5pt !important;
    text-align: center !important;
    padding: 0 !important;
    margin: 0 !important;
    color: black !important;
    font-weight: normal !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    box-shadow: none !important;
    outline: none !important;
    width: 100% !important;
  }

  /* Guarantee dropdown arrow is gone */
  select.lunch-select {
    color: transparent !important;
    text-shadow: 0 0 0 black !important;
  }

  select.lunch-select::-ms-expand {
    display: none !important;
  }

  .reason-input.is-holiday {
    background: transparent !important;
    color: black !important;
    font-weight: normal !important;
  }

  /* Hours display */
  .hours-display {
    font-weight: bold !important;
    font-size: 9.5pt !important;
    color: black !important;
  }

  /* Strip all row background colors for print */
  .row-weekend,
  .row-holiday,
  .row-selected,
  .timesheet-table tbody tr {
    background: white !important;
    box-shadow: none !important;
  }

  .row-holiday .day-name::after,
  .holiday-badge,
  .btn-unlock {
    display: none !important;
  }

  /* ─── Totals Section ────────────────────────────────────────────  */
  .totals-card {
    display: block !important;
    background: white !important;
    max-width: 100% !important;
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    page-break-inside: avoid !important;
  }

  .totals-grid {
    padding: 6pt 0 4pt 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 2pt !important;
  }

  .totals-row {
    display: flex !important;
    justify-content: flex-end !important;
    align-items: baseline !important;
    width: 3.5in !important;
    gap: 6pt !important;
    padding: 0 !important;
  }

  .totals-label {
    font-family: 'Times New Roman', Times, serif !important;
    font-size: 10.5pt !important;
    color: black !important;
    font-weight: normal !important;
    text-align: right !important;
    flex: 1 !important;
  }

  .totals-value {
    font-family: 'Times New Roman', Times, serif !important;
    font-size: 10.5pt !important;
    font-weight: normal !important;
    color: black !important;
    min-width: 1.2in !important;
    text-align: left !important;
    padding-left: 4pt !important;
    border: none !important;
    border-bottom: 1pt solid black !important;
  }

  .totals-row-total {
    border-top: none !important;
    padding-top: 0 !important;
    margin-top: 2pt !important;
  }

  .totals-row-total .totals-label,
  .totals-row-total .totals-value {
    font-weight: normal !important;
    color: black !important;
    font-size: 10.5pt !important;
  }

  .totals-row-total .totals-value {
    border-bottom: 1pt solid black !important;
  }

  /* ─── Signature Section ─────────────────────────────────────────  */
  .signature-section {
    margin-top: 10pt !important;
    padding-left: 50px !important;
    page-break-inside: avoid !important;
  }

  .signature-line {
    display: flex !important;
    align-items: flex-end !important;
    margin-bottom: 10pt !important;
    gap: 0.2in !important;
    width: 80% !important;
  }

  .signature-field {
    display: flex !important;
    align-items: flex-end !important;
    flex: 1 !important;
    gap: 0 !important;
  }

  .signature-date-field {
    display: flex !important;
    align-items: flex-end !important;
    gap: 0 !important;
    min-width: 1.6in !important;
    flex-shrink: 0 !important;
  }

  .signature-label {
    font-family: 'Times New Roman', Times, serif !important;
    font-size: 10.5pt !important;
    font-weight: bold !important;
    white-space: nowrap !important;
    padding-right: 2pt !important;
  }

  .signature-underline {
    flex: 1 !important;
    border-bottom: 1pt solid black !important;
    min-width: 0.8in !important;
    height: 1em !important;
    display: block !important;
  }

  .signature-role {
    text-align: left !important;
    font-family: 'Times New Roman', Times, serif !important;
    font-size: 10pt !important;
    font-weight: bold !important;
    margin-top: -6pt !important;
    padding-left: 160px;
  }
}