/**
 * Shared visual layer for “connected rows” UIs: linked-rows modal (VaultSideDtExchangeTable linked preview)
 * and order-lines composer — matches font size (0.75rem), spacing, header tone, and horizontal row rules.
 * Wrapper: **vault-dt-connected-rows** on modal grid host and order-lines table area.
 */

.vault-dt-connected-rows {
  --vault-dt-connected-font: 0.75rem;
  --vault-dt-connected-head-bg: color-mix(in srgb, var(--vault-bg-elevated, #1e293b) 92%, #fff 8%);
  --vault-dt-connected-border: var(--vault-border, #334155);
  /* Linked-rows exchange preview + order-lines composer: keep in sync (relation-col detail modals) */
  --vault-dt-connected-pad-y: 0.1rem;
  --vault-dt-connected-pad-x: 0.32rem;
  /* Room for .vault-dt-grid__th-resize (matches datatable.css: 12px / 24px coarse) */
  --vault-dt-connected-th-resize-gap: 12px;
}

@media (pointer: coarse) {
  .vault-dt-connected-rows {
    --vault-dt-connected-th-resize-gap: 24px;
  }
}

.vault-dt-connected-rows .vault-dt-exchange-table__above {
  width: 100%;
  box-sizing: border-box;
}

.vault-dt-connected-rows__above {
  width: 100%;
  box-sizing: border-box;
  padding: 0 0 0.35rem;
  margin-bottom: 0.1rem;
}

.vault-dt-connected-rows__meta {
  font-size: 0.75rem;
  line-height: 1.35;
  color: var(--vault-text-muted, #94a3b8);
  font-variant-numeric: tabular-nums;
}

/* Tasks modal: row count in <caption> (scrolls with the table); add bar matches main grid add-row */
.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table__caption {
  caption-side: top;
  text-align: left;
  padding: 0 0 0.4rem;
  margin: 0;
  font-size: 0.75rem;
  color: var(--vault-text-muted, #94a3b8);
  font-variant-numeric: tabular-nums;
}

.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table__linked-shell {
  display: flex;
  flex-direction: column;
  min-height: 0;
  min-width: 0;
  flex: 1 1 auto;
  width: 100%;
}

.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table__caption--outside {
  display: block;
  flex-shrink: 0;
  width: 100%;
  box-sizing: border-box;
  padding: 0 0 0.4rem;
  margin: 0;
  text-align: left;
  font-size: 0.75rem;
  color: var(--vault-text-muted, #94a3b8);
  font-variant-numeric: tabular-nums;
}

.vault-modal--linked-rows .vault-linked-rows-modal-body__grid .vault-dt-exchange-table__scroll--table-only.vault-dt-table-scroll {
  overflow-x: auto !important;
  overflow-y: auto !important;
}

.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table__linked-shell > .vault-dt-add-row-bar {
  flex-shrink: 0;
  width: 100%;
  box-sizing: border-box;
}

.vault-modal--linked-rows .vault-dt-add-row-bar--linked-tasks {
  padding-left: 0.75rem;
}

.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table__click-edit-display {
  min-height: 1.55rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.25rem;
  width: 100%;
  box-sizing: border-box;
}

.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview .vault-dt-exchange-table__data-td--editing .vault-input__field,
.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview .vault-dt-exchange-table__data-td--editing input.vault-dt__search-input:not([type='checkbox']),
.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview .vault-dt-exchange-table__data-td--editing .vault-decimal-input__field {
  background: #f3f4f6 !important;
  border-radius: 0.375rem;
}

.vault-dt-connected-rows__heading-row {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.35rem 0.75rem;
  width: 100%;
}

.vault-dt-connected-rows__pager-wrap {
  min-height: 0;
}

/* Compact pager (shared with vault-linked-rows-modal__pager) */
.vault-dt-connected-rows__pager--compact.vault-linked-rows-modal__pager {
  gap: 0.35rem 0.5rem;
  padding: 0.1rem 0 0.28rem;
}

.vault-dt-connected-rows__pager--compact .vault-linked-rows-modal__pager-btn {
  padding: 0.2rem 0.45rem;
  font-size: 0.6875rem;
}

.vault-dt-connected-rows__pager--compact .vault-linked-rows-modal__pager-label {
  font-size: 0.6875rem;
}

.vault-dt-connected-rows__pager--compact .vault-linked-rows-modal__pager-summary {
  font-size: 0.6875rem;
}

.vault-dt-connected-rows__pager--compact .vault-linked-rows-modal__pager-size {
  padding: 0.15rem 0.35rem;
  font-size: 0.6875rem;
}

/* Linked-rows modal: exchange preview — align with order-lines (0.75rem, header strip, body = horizontal rules only) */
.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview {
  font-size: var(--vault-dt-connected-font);
}

.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview .vault-dt-grid__th-label {
  font-size: var(--vault-dt-connected-font);
  font-weight: 600;
  text-align: left;
}

/* Body cells: padding on td only — header padding lives on .th-inner (+ resize gap) like main grid */
.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview .vault-dt-exchange-table__data-td {
  padding: var(--vault-dt-connected-pad-y) var(--vault-dt-connected-pad-x);
  font-size: var(--vault-dt-connected-font);
  text-align: left;
}

.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview .vault-dt-exchange-table__data-th {
  padding: 0;
  font-size: var(--vault-dt-connected-font);
  text-align: left;
  vertical-align: middle;
}

.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview .vault-dt-exchange-table__data-th .vault-dt-exchange-table__th-inner {
  padding: var(--vault-dt-connected-pad-y) calc(var(--vault-dt-connected-pad-x) + var(--vault-dt-connected-th-resize-gap)) var(--vault-dt-connected-pad-y) var(--vault-dt-connected-pad-x);
  min-height: 0;
  justify-content: flex-start;
  text-align: left;
}

/* Header row: light strip (overrides transparent head rules from datatable.css for this bundle) */
.vault-modal--linked-rows .vault-dt-connected-rows .vault-tools-page--datatable .vault-dt-exchange-table--linked-preview thead .vault-dt-exchange-table__data-th {
  background: var(--vault-dt-connected-head-bg) !important;
  background-color: var(--vault-dt-connected-head-bg) !important;
  border-bottom: 1px solid var(--vault-dt-connected-border);
  color: var(--vault-text-muted, #94a3b8);
}

.vault-modal--linked-rows .vault-dt-connected-rows .vault-tools-page--datatable .vault-dt-exchange-table--linked-preview thead .vault-dt-grid__th-inner,
.vault-modal--linked-rows .vault-dt-connected-rows .vault-tools-page--datatable .vault-dt-exchange-table--linked-preview thead .vault-dt-grid__th-label {
  background: transparent !important;
}

/* Body + header data cells: full grid (left + right + bottom); matches order-lines composer under .vault-dt-connected-rows */
.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview.vault-dt-grid--flat .vault-dt-exchange-table__data-th,
.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview.vault-dt-grid--flat .vault-dt-exchange-table__data-td {
  border-left: 1px solid var(--vault-dt-connected-border);
  border-right: 1px solid var(--vault-dt-connected-border);
  border-bottom: 1px solid var(--vault-dt-connected-border);
}

.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview .vault-dt-exchange-table__cell-control {
  margin: 0;
}

.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview .vault-input__field,
.vault-modal--linked-rows .vault-dt-connected-rows .vault-dt-exchange-table--linked-preview .vault-decimal-input__field {
  padding: var(--vault-dt-connected-pad-y) var(--vault-dt-connected-pad-x);
  min-height: 1.55rem;
  font-size: var(--vault-dt-connected-font);
}

/* Order lines composer: parity with linked-rows exchange preview (VaultSideDtExchangeTable linkedPreview) */
.vault-modal--order-lines-composer .vault-dt-connected-rows .vault-dt-order-lines-composer__table-scroll {
  touch-action: pan-x pan-y;
  overscroll-behavior: contain;
  min-width: 0;
  -webkit-overflow-scrolling: touch;
}

.vault-modal--order-lines-composer .vault-dt-connected-rows .vault-dt-order-lines-composer__tbl {
  font-size: var(--vault-dt-connected-font);
  table-layout: fixed;
  width: max-content;
  min-width: 100%;
  border-collapse: collapse;
}

.vault-modal--order-lines-composer .vault-dt-connected-rows .vault-dt-order-lines-composer__tbl th,
.vault-modal--order-lines-composer .vault-dt-connected-rows .vault-dt-order-lines-composer__tbl td {
  padding: var(--vault-dt-connected-pad-y) var(--vault-dt-connected-pad-x);
  font-size: var(--vault-dt-connected-font);
  border-left: 1px solid var(--vault-dt-connected-border);
  border-right: 1px solid var(--vault-dt-connected-border);
  border-bottom: 1px solid var(--vault-dt-connected-border);
  border-top: none;
  vertical-align: middle;
  box-sizing: border-box;
  text-align: left;
}

/* Header: extra right padding for column resize hit target (same idea as .vault-dt-grid__th-inner padding-right) */
.vault-modal--order-lines-composer .vault-dt-connected-rows .vault-dt-order-lines-composer__tbl thead th:not(.vault-dt-olc-actions-col) {
  padding-right: calc(var(--vault-dt-connected-pad-x) + var(--vault-dt-connected-th-resize-gap));
}

.vault-modal--order-lines-composer .vault-dt-connected-rows .vault-dt-order-lines-composer__tbl thead th {
  background: var(--vault-dt-connected-head-bg);
  color: var(--vault-text-muted, #94a3b8);
  font-weight: 600;
}

/* Override datatable.css numeric column right-align for relation-detail consistency */
.vault-modal--order-lines-composer .vault-dt-connected-rows .vault-dt-order-lines-composer__tbl th.vault-dt-order-lines-composer__tbl-num,
.vault-modal--order-lines-composer .vault-dt-connected-rows .vault-dt-order-lines-composer__tbl td.vault-dt-order-lines-composer__tbl-num {
  text-align: left;
}

/* Sticky delete column: same header/body tone as relation-detail exchange grid (not dark slate) */
.vault-modal--order-lines-composer .vault-dt-connected-rows .vault-dt-order-lines-composer__tbl thead th.vault-dt-olc-actions-col {
  position: sticky;
  left: 0;
  z-index: 3;
  width: 2.5rem;
  min-width: 2.5rem;
  max-width: 2.75rem;
  padding: var(--vault-dt-connected-pad-y) var(--vault-dt-connected-pad-x);
  text-align: center;
  vertical-align: middle;
  background: var(--vault-dt-connected-head-bg) !important;
  color: var(--vault-text-muted, #94a3b8) !important;
  box-shadow: none;
  border-left: 1px solid var(--vault-dt-connected-border);
  border-right: 1px solid var(--vault-dt-connected-border);
}

.vault-modal--order-lines-composer .vault-dt-connected-rows .vault-dt-order-lines-composer__tbl tbody td.vault-dt-olc-actions-col {
  position: sticky;
  left: 0;
  z-index: 2;
  width: 2.5rem;
  min-width: 2.5rem;
  max-width: 2.75rem;
  padding: var(--vault-dt-connected-pad-y) var(--vault-dt-connected-pad-x);
  text-align: center;
  vertical-align: middle;
  background: var(--vault-bg, #fff) !important;
  box-shadow: 1px 0 0 var(--vault-dt-connected-border);
  border-left: 1px solid var(--vault-dt-connected-border);
  border-right: 1px solid var(--vault-dt-connected-border);
}
