/* Shared styles for disbursement account document pages.
   Used by both the web preview (auto-included via Dir.glob)
   and the PDF layout (inlined via File.read in the ERB template). */

/* ── Reset browser/Bootstrap defaults so preview matches PDF ── */
.da-document-page p { margin: 0; }

/* ── Table baseline ── */
.da-document-page table { width: 100%; border-collapse: collapse; }

/* ── Header section ── */
.da-document-page__header td { vertical-align: top; padding: 2px 0; }
.da-document-page__agent-info { font-size: 9pt; }
.da-document-page__invoice-info { text-align: right; font-size: 9pt; }
.da-document-page__invoice-details { width: auto !important; margin-left: auto; }
.da-document-page__invoice-details td { padding: 0 0 1px; font-size: 9pt; border: none; white-space: nowrap; }
.da-document-page__invoice-details td:first-child { text-align: left; padding-right: 2px; }
.da-document-page__invoice-details td:last-child { text-align: right; padding-left: 2px; }

.da-document-page__reference { font-weight: bold; font-size: 11pt; margin: 15px 0 5px; }
.da-document-page__dates { font-size: 10pt; margin-bottom: 10px; }
.da-document-page__cargo { font-size: 10pt; margin-bottom: 15px; }

/* ── Services table (bordered) ── */
.da-document-page__services-table { margin: 6px 0; border-collapse: collapse; }
.da-document-page__services-table th {
  border: 1px solid #000;
  padding: 3px 6px;
  font-size: 9pt;
  text-align: center;
  font-weight: bold;
}
.da-document-page__services-table-empty-header {
  border: none !important;
  background: transparent;
}
.da-document-page__services-table td {
  border-left: 1px solid #000;
  border-right: 1px solid #000;
  padding: 1px 5px;
  font-size: 9pt;
}
.da-document-page__services-table td:first-child { text-align: left; }
.da-document-page__amount { text-align: right; font-variant-numeric: tabular-nums; }

.da-document-page__compulsory-cell { text-align: center; font-size: 9pt; }

/* First data row gets a top border to close off the header */
.da-document-page__services-table tbody tr:first-child td { border-top: 1px solid #000; }

/* Light separator between voucher rows */
.da-document-page__services-table tbody tr td { border-bottom: 1px solid #e0e0e0; }

.da-document-page__group-subtotal td { border-top: 1px solid #000; border-bottom: 1px solid #000; font-weight: bold; font-size: 8pt; padding-top: 2px; background: #e8f0fe; }
.da-document-page__total-row td { border-top: 2px solid #000; border-bottom: 1px solid #000; font-weight: bold; font-size: 9pt; padding-top: 3px; background: #e0e0e0; }
.da-document-page__balance-row td { border-top: 1px solid #000; border-bottom: 2px solid #000; font-weight: bold; font-size: 9pt; padding-top: 2px; background: #e0e0e0; }

/* ── Bank details ── */
.da-document-page__bank-details { margin-top: 0; font-size: 9pt; line-height: 1.3; }

/* ── Cover letter ── */
.da-document-page__letter-date { margin-bottom: 20px; }
.da-document-page__letter-client { margin-bottom: 20px; line-height: 1.6; }
.da-document-page__letter-body { margin: 15px 0; line-height: 1.6; }
.da-document-page__letter-summary { margin: 15px 0; }
.da-document-page__letter-summary td { padding: 4px 6px; font-size: 11pt; vertical-align: middle; }
.da-document-page__letter-summary td.da-document-page__label-cell { padding-right: 10px; }

/* Letter summary — bordered amount cells */
.da-document-page__letter-summary .da-document-page__amount-cell {
  border: 1px solid #000;
  border-right: none;
  padding: 4px 2px 4px 6px;
  text-align: left;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.da-document-page__letter-summary .da-document-page__value-cell {
  border: 1px solid #000;
  border-left: none;
  padding: 4px 8px 4px 4px;
  text-align: right;
  font-variant-numeric: tabular-nums;
  width: 90px;
  white-space: nowrap;
}
.da-document-page__letter-summary .da-document-page__balance-amount-cell {
  border: 1px solid #000;
  border-right: none;
  padding: 4px 2px 4px 6px;
  text-align: left;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  font-weight: bold;
  background: #e0e0e0;
}
.da-document-page__letter-summary .da-document-page__balance-value-cell {
  border: 1px solid #000;
  border-left: none;
  padding: 4px 8px 4px 4px;
  text-align: right;
  font-variant-numeric: tabular-nums;
  width: 90px;
  white-space: nowrap;
  font-weight: bold;
  background: #e0e0e0;
}

/* ── Voucher detail ── */
.da-document-page__voucher-header { font-weight: bold; border-bottom: 1px solid #000; padding-bottom: 4px; margin: 20px 0 15px; }
.da-document-page__voucher-header td { padding: 4px 6px; }
.da-document-page__service-name { font-weight: bold; font-size: 12pt; margin: 20px 0 15px; text-decoration: underline; }
.da-document-page__service-description { margin: 10px 0; line-height: 1.6; }
.da-document-page__service-amount td { padding: 3px 6px; }
.da-document-page__roe { margin-top: 30px; font-size: 9pt; }
.da-document-page__compulsory { text-align: center; font-size: 9pt; }

/* ── Logo header ── */
.da-document-page__logo-header { margin-bottom: 15px; }
.da-document-page__logo-header td { vertical-align: middle; }
.da-document-page__logo-cell { background: var(--bs-primary); padding: 10px; border-radius: 4px; width: 75px; text-align: center; }
.da-document-page__logo-img { width: 55px; height: auto; display: block; }
.da-document-page__logo-company-name { font-size: 16pt; font-weight: normal; letter-spacing: 0.5px; padding-left: 12px; }

/* ── Signature block ── */
.da-document-page__signature-block { margin-top: 20px; }
.da-document-page__signature-block td { vertical-align: middle; }

/* ── Company document header ── */
.da-document-page__company-header {
  text-align: center;
  font-size: 14pt;
  font-weight: normal;
  margin-bottom: 30px;
  letter-spacing: 0.5px;
}

/* ── Voucher bordered table ── */
.da-document-page__voucher-table { width: 100%; border-collapse: collapse; margin: 15px 0; }
.da-document-page__voucher-table th { border: 1px solid #000; padding: 6px 10px; font-weight: bold; font-size: 11pt; }
.da-document-page__voucher-table th:first-child { text-align: center; }
.da-document-page__voucher-table td { border-left: 1px solid #000; border-right: 1px solid #000; padding: 4px 10px; font-size: 10pt; vertical-align: top; }
.da-document-page__voucher-table tr.da-document-page__voucher-total td { border-top: 1px solid #000; border-bottom: 1px solid #000; font-weight: bold; padding-top: 6px; }
.da-document-page__voucher-table tr:last-child td { border-bottom: 1px solid #000; }

/* ── Reference styling ── */
.da-document-page__reference-line { font-style: italic; text-decoration: underline; font-weight: bold; }

/* ── Signature area ── */
.da-document-page__signature { text-align: center; margin-top: 30px; font-size: 11pt; }

/* ── Info row ── */
.da-document-page__info-row { margin: 4px 0; }
.da-document-page__info-row td { font-size: 9pt; padding: 1px 0; }

/* ── Footer ── */
.da-document-page__footer {
  text-align: center;
  font-size: 8pt;
  color: #000;
  padding-top: 10px;
  border-top: 1px solid #ccc;
  line-height: 1.5;
}
