/* Shared layout layer.
   Keep reusable grid/filter/card/detail rules here so future modules do not
   patch one-off mobile overrides into styles.css. */

.service-charge-copy {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.service-charge-copy small {
  color: var(--muted);
  font-weight: 800;
}

.customer-payment-service-charge-row,
body.mobile-preview-mode .customer-payment-service-charge-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  width: min(360px, 100%);
  justify-content: stretch;
}

.customer-payment-service-charge-row > summary {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  place-items: initial;
  width: auto;
  min-width: min(260px, 100%);
  height: auto;
  min-height: 42px;
  padding: 8px 12px;
  border-radius: 14px;
  font-size: 14px;
  line-height: 1.15;
}

.customer-payment-service-charge-row:not([open]),
body.mobile-preview-mode .customer-payment-service-charge-row:not([open]) {
  width: auto;
  max-width: 100%;
  grid-template-columns: minmax(0, 1fr);
}

body.mobile-preview-mode .customer-payment-service-charge-row > summary {
  width: auto;
  min-width: min(260px, 100%);
}

.service-charge-plus {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  flex: 0 0 auto;
  border-radius: 999px;
  background: #f6e2e9;
  color: var(--brand);
  font-weight: 950;
}

.customer-payment-service-charge-field {
  max-width: 100%;
}

.customer-payment-row-card,
#editRecordForm [data-edit-customer-payment-row].customer-payment-row-card {
  display: grid;
  grid-template-columns: minmax(68px, .34fr) minmax(170px, 1fr) minmax(150px, .78fr) minmax(220px, 1fr) minmax(220px, 1fr);
  gap: 10px;
  align-items: end;
  overflow: hidden;
}

.customer-payment-row-card .customer-payment-row-card-fields,
#editRecordForm [data-edit-customer-payment-row] .customer-payment-row-card-fields {
  grid-column: 2 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(160px, 1fr));
  gap: 10px;
  min-width: 0;
}

.customer-payment-row-card .customer-payment-row-card-fields [data-row-other-bank-field]:not(.is-hidden),
#editRecordForm [data-edit-customer-payment-row] .customer-payment-row-card-fields [data-edit-row-other-bank-field]:not(.is-hidden) {
  grid-column: 1 / -1;
}

.customer-payment-amount-field,
.customer-payment-amount-field .amount-number-control,
.customer-payment-amount-field .amount-digit-wrap,
.customer-payment-amount-field .amount-digit-row {
  min-width: 0;
  max-width: 100%;
}

.customer-payment-amount-field .amount-digit-row,
#editRecordForm [data-edit-customer-payment-row] .customer-payment-amount-field .amount-digit-row {
  display: grid;
  grid-template-columns: repeat(5, minmax(22px, 1fr)) 6px repeat(2, minmax(22px, .82fr));
  gap: 3px;
  overflow: hidden;
}

.customer-payment-amount-field .amount-lock-window .amount-digit,
.customer-payment-amount-field .amount-lock-window .amount-cent-digit,
#editRecordForm [data-edit-customer-payment-row] .customer-payment-amount-field .amount-lock-window .amount-digit,
#editRecordForm [data-edit-customer-payment-row] .customer-payment-amount-field .amount-lock-window .amount-cent-digit {
  min-width: 0;
  width: 100%;
}

.task-board.task-summary-grid,
#taskResults .task-board.task-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(260px, 1fr));
  gap: 16px;
  align-items: start;
}

.task-board.task-summary-grid > .task-summary-card {
  min-width: 0;
}

.task-payment-rows {
  display: grid;
  gap: 10px;
}

.task-payment-row-detail {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 10px;
  background: #fffdfa;
  min-width: 0;
}

.task-payment-row-detail > b {
  display: block;
  margin-bottom: 8px;
  color: var(--brand);
}

.task-payment-row-detail dl {
  display: grid;
  grid-template-columns: repeat(3, minmax(118px, 1fr));
  gap: 8px;
  margin: 0;
}

.task-payment-row-detail div,
.task-payment-row-detail dd,
.task-payment-row-detail dt {
  min-width: 0;
  overflow-wrap: break-word;
  word-break: normal;
  white-space: normal;
}

.task-view-details .task-detail-items,
.task-view-details .task-payment-rows {
  min-width: 0;
  max-width: 100%;
  overflow-x: hidden;
}

.payment-confirm-scope {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px dashed var(--line-strong, var(--line));
  border-radius: 12px;
  background: #fffaf2;
}

.payment-confirm-row-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 8px;
}

.payment-confirm-row-list label {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2px 8px;
  align-items: center;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  min-width: 0;
}

.payment-confirm-row-list em,
.payment-confirm-row-list strong {
  grid-column: 2;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cs-filter-bar {
  display: grid;
  grid-template-columns: minmax(220px, 1.35fr) repeat(5, minmax(132px, .72fr)) auto auto;
  align-items: stretch;
  gap: 10px;
}

.cs-filter-bar > input,
.cs-filter-bar .date-range-control,
.cs-filter-bar .cs-multi-filter,
.task-filters > *,
.record-filter-bar > * {
  min-width: 0;
}

.cs-multi-panel label span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.cs-heat-inline-detail,
.cs-heatmap-detail-outside,
.cs-document-panel,
.cs-document-detail,
.cs-section-body,
.cs-mini-details {
  min-width: 0;
  max-width: 100%;
  overflow-x: hidden;
}

.cs-mini-details {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 8px;
}

.cs-mini-details span,
.cs-mini-details div,
.cs-mini-details b,
.cs-mini-details dd {
  min-width: 0;
  overflow-wrap: anywhere;
}

.cs-payment-row-list {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 8px;
  min-width: 0;
}

.cs-payment-row-list article {
  display: grid;
  gap: 4px;
  padding: 8px 10px;
  border: 1px solid #f0dedb;
  border-radius: 12px;
  background: #fffdfa;
  min-width: 0;
}

.cs-payment-row-list b,
.cs-payment-row-list span {
  min-width: 0;
  overflow-wrap: break-word;
}

.cs-payment-row-list b {
  color: var(--brand);
  font-size: 12px;
}

.cs-payment-row-list span {
  color: var(--ink);
  font-size: 12px;
  line-height: 1.3;
}

.existing-customer-payment-preview {
  max-width: 100%;
  max-height: none;
  overflow: visible;
}

.existing-customer-payment-preview-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.existing-invoice-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  gap: 8px;
}

.existing-invoice-summary div,
.existing-invoice-summary dd {
  min-width: 0;
  overflow-wrap: break-word;
  word-break: normal;
  white-space: normal;
}

.existing-invoice-summary .wide {
  grid-column: 1 / -1;
}

@media (max-width: 1200px) {
  .task-board.task-summary-grid,
  #taskResults .task-board.task-summary-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .cs-filter-bar {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .cs-filter-bar > input,
  .cs-filter-bar .date-range-control {
    grid-column: span 2;
  }
}

@media (max-width: 760px) {
  .task-board.task-summary-grid,
  #taskResults .task-board.task-summary-grid {
    grid-template-columns: 1fr;
  }

  .task-filters,
  .record-filter-bar,
  .cs-filter-bar {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .task-filters > input,
  .record-filter-search,
  .cs-filter-bar > input,
  .task-filters .date-range-control,
  .record-filter-bar .date-range-control,
  .cs-filter-bar .date-range-control {
    grid-column: 1 / -1;
  }

  .customer-payment-row-card,
  #editRecordForm [data-edit-customer-payment-row].customer-payment-row-card {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .customer-payment-row-card .customer-payment-row-title,
  .customer-payment-row-card .customer-payment-style-stack,
  .customer-payment-row-card .customer-payment-type-field,
  .customer-payment-row-card .customer-payment-row-card-fields,
  #editRecordForm [data-edit-customer-payment-row] .customer-payment-row-card-fields {
    grid-column: 1 / -1;
  }

  .customer-payment-row-card .customer-payment-deposit-field:not(.is-hidden) {
    grid-column: 1;
  }

  .customer-payment-row-card .customer-payment-full-field {
    grid-column: 2;
  }

  .customer-payment-row-card .customer-payment-deposit-field.is-hidden + .customer-payment-full-field {
    grid-column: 1 / -1;
  }

  .customer-payment-row-card .customer-payment-row-card-fields,
  #editRecordForm [data-edit-customer-payment-row] .customer-payment-row-card-fields {
    grid-template-columns: 1fr;
  }

  .customer-payment-amount-field .amount-digit-row,
  #editRecordForm [data-edit-customer-payment-row] .customer-payment-amount-field .amount-digit-row {
    grid-template-columns: repeat(5, minmax(18px, 1fr)) 4px repeat(2, minmax(18px, .82fr));
    gap: 2px;
    padding: 3px;
  }

  .customer-payment-amount-field .amount-lock-window .amount-digit,
  .customer-payment-amount-field .amount-lock-window .amount-cent-digit,
  #editRecordForm [data-edit-customer-payment-row] .customer-payment-amount-field .amount-lock-window .amount-digit,
  #editRecordForm [data-edit-customer-payment-row] .customer-payment-amount-field .amount-lock-window .amount-cent-digit {
    min-height: 36px;
    height: 36px;
    font-size: 15px;
    padding: 0;
  }

  .existing-invoice-summary,
  .confirm-box .existing-invoice-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .confirm-box,
  .confirm-box .existing-customer-payment-preview {
    max-height: none;
    overflow: visible;
  }

  .confirm-box .existing-invoice-summary .wide,
  .confirm-box .existing-invoice-summary div:nth-last-child(1) {
    grid-column: 1 / -1;
  }

  .cs-mini-details,
  .cs-section-body,
  .cs-document-detail {
    grid-template-columns: 1fr !important;
  }

  .cs-payment-row-list {
    grid-template-columns: 1fr;
  }

  .task-payment-row-detail dl {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 430px) {
  .customer-payment-row-card .customer-payment-deposit-field:not(.is-hidden),
  #editRecordForm [data-edit-customer-payment-row] .customer-payment-deposit-field:not(.is-hidden) {
    grid-column: 1;
  }

  .customer-payment-row-card .customer-payment-full-field,
  #editRecordForm [data-edit-customer-payment-row] .customer-payment-full-field {
    grid-column: 2;
  }

  .customer-payment-row-card .customer-payment-deposit-field.is-hidden + .customer-payment-full-field,
  #editRecordForm [data-edit-customer-payment-row] .customer-payment-deposit-field.is-hidden + .customer-payment-full-field {
    grid-column: 1 / -1;
  }

  .existing-invoice-summary,
  .confirm-box .existing-invoice-summary {
    grid-template-columns: 1fr;
  }

  .task-payment-row-detail dl {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
