/*
  CodideX Finance Core
  Day 5A UI extensions for fees, invoices, collections, dues, payroll, expenses, and transport fees.
*/

.cdx-finance-metrics,
.cdx-finance-grid,
.cdx-fee-breakdown-grid,
.cdx-finance-card-grid,
.cdx-route-grid,
.cdx-payroll-grid {
  display: grid;
  gap: var(--cdx-space-4);
}

.cdx-finance-metrics > *,
.cdx-finance-grid > *,
.cdx-fee-breakdown-grid > *,
.cdx-finance-card-grid > *,
.cdx-route-grid > *,
.cdx-payroll-grid > * {
  min-width: 0;
}

.cdx-finance-metrics {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: var(--cdx-space-5);
}

.cdx-finance-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  align-items: start;
}

.cdx-finance-span-8 {
  grid-column: span 8;
}

.cdx-finance-span-7 {
  grid-column: span 7;
}

.cdx-finance-span-6 {
  grid-column: span 6;
}

.cdx-finance-span-5 {
  grid-column: span 5;
}

.cdx-finance-span-4 {
  grid-column: span 4;
}

.cdx-finance-span-12 {
  grid-column: span 12;
}

.cdx-money {
  color: var(--cdx-heading);
  font-family: var(--cdx-font-display);
  font-variant-numeric: tabular-nums;
  font-weight: 900;
  letter-spacing: 0;
  white-space: nowrap;
}

.cdx-money.is-credit {
  color: var(--cdx-success);
}

.cdx-money.is-due {
  color: var(--cdx-danger);
}

.cdx-money.is-muted {
  color: var(--cdx-text-muted);
}

.cdx-finance-toolbar {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto;
  gap: var(--cdx-space-3);
  align-items: center;
}

.cdx-finance-filter-set {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cdx-space-2);
  align-items: center;
  justify-content: flex-end;
}

.cdx-finance-widget,
.cdx-fee-breakdown-card,
.cdx-finance-transaction,
.cdx-finance-category,
.cdx-route-card,
.cdx-payroll-card {
  padding: var(--cdx-space-4);
  border: 1px solid var(--cdx-border);
  border-radius: var(--cdx-radius-lg);
  background: var(--cdx-surface);
  box-shadow: var(--cdx-shadow-xs);
  transition: transform var(--cdx-transition-fast), box-shadow var(--cdx-transition-fast), border-color var(--cdx-transition-fast), background var(--cdx-transition-fast);
}

.cdx-finance-widget:hover,
.cdx-fee-breakdown-card:hover,
.cdx-finance-transaction:hover,
.cdx-finance-category:hover,
.cdx-route-card:hover,
.cdx-payroll-card:hover {
  border-color: rgba(47, 128, 237, 0.28);
  box-shadow: var(--cdx-shadow-sm);
  transform: translateY(-2px);
}

.cdx-finance-widget strong,
.cdx-fee-breakdown-card strong,
.cdx-finance-category strong,
.cdx-route-card strong,
.cdx-payroll-card strong {
  display: block;
  color: var(--cdx-heading);
}

.cdx-finance-widget span,
.cdx-fee-breakdown-card span,
.cdx-finance-category span,
.cdx-route-card span,
.cdx-payroll-card span {
  color: var(--cdx-text-muted);
  font-size: var(--cdx-font-size-xs);
  font-weight: 850;
}

.cdx-finance-card-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cdx-fee-breakdown-grid,
.cdx-payroll-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cdx-route-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cdx-finance-summary {
  display: grid;
  gap: var(--cdx-space-3);
}

.cdx-finance-summary-row,
.cdx-breakdown-row,
.cdx-ledger-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--cdx-space-3);
  padding-bottom: var(--cdx-space-3);
  border-bottom: 1px solid var(--cdx-border);
}

.cdx-finance-summary-row:last-child,
.cdx-breakdown-row:last-child,
.cdx-ledger-row:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.cdx-breakdown-list,
.cdx-ledger-list {
  display: grid;
  gap: var(--cdx-space-3);
}

.cdx-finance-transaction {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  gap: var(--cdx-space-3);
  align-items: center;
}

.cdx-transaction-icon {
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--cdx-primary-50);
  color: var(--cdx-primary-700);
}

.cdx-finance-timeline {
  position: relative;
  display: grid;
  gap: var(--cdx-space-4);
}

.cdx-finance-step {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: var(--cdx-space-3);
  align-items: start;
}

.cdx-finance-step-icon {
  display: inline-flex;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(47, 128, 237, 0.1);
  color: var(--cdx-primary-700);
}

.cdx-aging-chip {
  display: inline-grid;
  min-width: 68px;
  place-items: center;
  padding: 0.42rem 0.6rem;
  border-radius: var(--cdx-radius-pill);
  background: var(--cdx-surface-muted);
  color: var(--cdx-heading);
  font-size: var(--cdx-font-size-xs);
  font-weight: 950;
  font-variant-numeric: tabular-nums;
}

.cdx-aging-chip.is-warning {
  background: rgba(245, 158, 11, 0.14);
  color: #b45309;
}

.cdx-aging-chip.is-danger {
  background: rgba(220, 38, 38, 0.12);
  color: var(--cdx-danger);
}

.cdx-finance-illustration {
  width: min(180px, 44vw);
  display: block;
  margin-inline: auto;
}

.cdx-finance-sparkline {
  height: 70px;
  border-radius: var(--cdx-radius-md);
  background:
    linear-gradient(135deg, transparent 12%, rgba(22, 163, 74, 0.18) 12% 21%, transparent 21% 35%, rgba(47, 128, 237, 0.2) 35% 44%, transparent 44% 58%, rgba(245, 158, 11, 0.18) 58% 66%, transparent 66%),
    repeating-linear-gradient(0deg, transparent 0 22px, var(--cdx-border) 23px),
    var(--cdx-surface-soft);
}

.cdx-amount-cell,
.cdx-table-card .cdx-money {
  text-align: right;
}

.cdx-category-accent {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--cdx-radius-md);
  background: rgba(47, 128, 237, 0.1);
  color: var(--cdx-primary-700);
}

/*
  Finance Print System
  Screen preview styles for receipts, invoices, salary slips, acknowledgements,
  transport receipts, and multi-document print showcases.
*/

.cdx-finance-print-page .cdx-content {
  max-width: 1500px;
}

.cdx-finance-print-stage {
  display: grid;
  gap: var(--cdx-space-5);
}

.cdx-finance-print-preview {
  overflow: auto;
  padding: clamp(1rem, 2vw, 1.5rem);
  border: 1px solid var(--cdx-border);
  border-radius: var(--cdx-radius-lg);
  background:
    linear-gradient(135deg, rgba(47, 128, 237, 0.09), transparent 34%),
    linear-gradient(315deg, rgba(32, 169, 139, 0.08), transparent 32%),
    var(--cdx-surface-soft);
}

.cdx-finance-print-document {
  color: #111827;
  font-size: 0.82rem;
  font-variant-numeric: tabular-nums;
}

.cdx-finance-print-document::after {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 0;
  color: rgba(17, 24, 39, 0.035);
  content: "CodideX";
  font-family: var(--cdx-font-display);
  font-size: clamp(3rem, 9vw, 7.5rem);
  font-weight: 900;
  letter-spacing: 0.03em;
  pointer-events: none;
  text-transform: uppercase;
  transform: translate(-50%, -50%) rotate(-24deg);
}

.cdx-finance-print-document > * {
  position: relative;
  z-index: 1;
}

.cdx-finance-print-document p {
  margin-bottom: 0;
}

.cdx-finance-document-meta {
  display: grid;
  gap: 0.35rem;
  justify-items: end;
  text-align: right;
}

.cdx-finance-document-meta strong {
  color: #111827;
  font-family: var(--cdx-font-display);
  font-size: 1.05rem;
  font-weight: 900;
}

.cdx-finance-document-meta span,
.cdx-finance-small-label {
  color: #6b7280;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.cdx-finance-print-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(260px, 0.85fr);
  gap: 1rem;
  align-items: start;
}

.cdx-finance-print-grid.is-balanced {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cdx-finance-print-panel {
  padding: 0.85rem;
  border: 1px solid #cbd5e1;
  background: #ffffff;
}

.cdx-finance-print-panel.is-muted {
  background: #f8fafc;
}

.cdx-finance-print-panel-title {
  margin: 0 0 0.65rem;
  color: #111827;
  font-family: var(--cdx-font-display);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.cdx-finance-print-table {
  width: 100%;
  border-collapse: collapse;
  color: #111827;
  font-size: 0.78rem;
}

.cdx-finance-print-table th,
.cdx-finance-print-table td {
  padding: 0.46rem 0.55rem;
  border: 1px solid #cbd5e1;
  vertical-align: middle;
}

.cdx-finance-print-table th {
  background: #eef2f7;
  color: #111827;
  font-size: 0.66rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.cdx-finance-print-table tfoot td {
  background: #f8fafc;
  font-weight: 900;
}

.cdx-finance-print-table .cdx-amount {
  text-align: right;
}

.cdx-amount {
  color: #111827;
  font-family: var(--cdx-font-display);
  font-variant-numeric: tabular-nums;
  font-weight: 900;
  white-space: nowrap;
}

.cdx-amount.is-positive {
  color: #166534;
}

.cdx-amount.is-due {
  color: #991b1b;
}

.cdx-finance-total-band {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.65rem;
  margin-top: 1rem;
}

.cdx-finance-total-item {
  padding: 0.75rem;
  border: 1px solid #cbd5e1;
  background: #f8fafc;
}

.cdx-finance-total-item span {
  display: block;
  color: #6b7280;
  font-size: 0.66rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.cdx-finance-total-item strong {
  display: block;
  margin-top: 0.2rem;
  color: #111827;
  font-family: var(--cdx-font-display);
  font-size: 1rem;
  font-weight: 950;
}

.cdx-finance-total-item.is-grand {
  border-color: #111827;
  background: #111827;
}

.cdx-finance-total-item.is-grand span,
.cdx-finance-total-item.is-grand strong {
  color: #ffffff;
}

.cdx-finance-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 86px;
  padding: 0.34rem 0.62rem;
  border: 1px solid #111827;
  color: #111827;
  font-size: 0.66rem;
  font-weight: 950;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.cdx-finance-status.is-paid {
  border-color: #166534;
  background: #dcfce7;
  color: #166534;
}

.cdx-finance-status.is-pending,
.cdx-finance-status.is-partial {
  border-color: #92400e;
  background: #fef3c7;
  color: #92400e;
}

.cdx-finance-status.is-overdue {
  border-color: #991b1b;
  background: #fee2e2;
  color: #991b1b;
}

.cdx-finance-code-row {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 0.85rem;
  align-items: center;
}

.cdx-finance-qr-box,
.cdx-finance-barcode-box {
  display: grid;
  place-items: center;
  border: 1px solid #9ca3af;
  background: #ffffff;
  color: #111827;
  font-size: 0.62rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.cdx-finance-qr-box {
  width: 86px;
  height: 86px;
  background:
    linear-gradient(90deg, #111827 10px, transparent 10px),
    linear-gradient(#111827 10px, transparent 10px),
    repeating-linear-gradient(45deg, #111827 0 4px, #ffffff 4px 8px);
  color: transparent;
}

.cdx-finance-barcode-box {
  height: 42px;
  padding-top: 1.7rem;
  background:
    repeating-linear-gradient(90deg, #111827 0 2px, transparent 2px 5px, #111827 5px 8px, transparent 8px 13px),
    #ffffff;
}

.cdx-finance-terms {
  min-height: 72px;
  padding: 0.75rem;
  border: 1px dashed #9ca3af;
  background: #ffffff;
  color: #4b5563;
  font-size: 0.76rem;
}

.cdx-finance-signatures {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  align-items: end;
  margin-top: 1.45rem;
}

.cdx-finance-signature {
  min-height: 52px;
  display: grid;
  align-content: end;
  padding-top: 1.6rem;
  border-top: 1px solid #111827;
  color: #111827;
  font-size: 0.68rem;
  font-weight: 900;
  text-align: center;
  text-transform: uppercase;
}

.cdx-finance-stamp {
  display: grid;
  width: 104px;
  height: 104px;
  place-items: center;
  margin-inline: auto;
  border: 2px solid #111827;
  border-radius: 50%;
  color: #111827;
  font-size: 0.64rem;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-align: center;
  text-transform: uppercase;
}

.cdx-salary-net-card {
  padding: 1rem;
  border: 2px solid #111827;
  background: #f8fafc;
  text-align: center;
}

.cdx-salary-net-card span {
  display: block;
  color: #6b7280;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.cdx-salary-net-card strong {
  display: block;
  margin-top: 0.25rem;
  color: #111827;
  font-family: var(--cdx-font-display);
  font-size: 1.45rem;
  font-weight: 950;
}

.cdx-finance-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--cdx-space-4);
}

.cdx-finance-preview-card {
  overflow: hidden;
}

.cdx-finance-preview-thumb {
  min-height: 240px;
  padding: var(--cdx-space-4);
  border-bottom: 1px solid var(--cdx-border);
  background:
    linear-gradient(135deg, rgba(47, 128, 237, 0.1), transparent),
    var(--cdx-surface-soft);
}

.cdx-finance-mini-document {
  width: min(100%, 240px);
  min-height: 172px;
  margin-inline: auto;
  padding: 0.8rem;
  border: 1px solid #d1d5db;
  border-radius: var(--cdx-radius-sm);
  background: #ffffff;
  color: #111827;
  box-shadow: var(--cdx-shadow-sm);
  transform-origin: center;
  transition: transform var(--cdx-transition-base), box-shadow var(--cdx-transition-base);
}

.cdx-finance-preview-card:hover .cdx-finance-mini-document {
  box-shadow: var(--cdx-shadow-md);
  transform: translateY(-3px) scale(1.015);
}

.cdx-finance-mini-line {
  height: 7px;
  margin-bottom: 0.5rem;
  border-radius: var(--cdx-radius-pill);
  background: #cbd5e1;
}

.cdx-finance-mini-line.is-strong {
  width: 54%;
  background: #2f80ed;
}

.cdx-finance-mini-table {
  display: grid;
  gap: 0.34rem;
  margin-top: 0.85rem;
}

.cdx-finance-mini-table span {
  height: 9px;
  border-radius: var(--cdx-radius-pill);
  background: #e5e7eb;
}

.cdx-finance-mini-footer {
  display: flex;
  justify-content: space-between;
  gap: 0.55rem;
  margin-top: 1rem;
}

.cdx-finance-mini-footer span {
  width: 42%;
  height: 16px;
  border-top: 1px solid #111827;
}

.cdx-finance-print-asset {
  width: min(180px, 44vw);
  display: block;
  margin-inline: auto;
}

[data-theme="dark"] .cdx-transaction-icon,
[data-theme="dark"] .cdx-finance-step-icon,
[data-theme="dark"] .cdx-category-accent {
  background: rgba(47, 128, 237, 0.16);
  color: var(--cdx-primary-300);
}

[data-theme="dark"] .cdx-aging-chip.is-warning {
  color: #fbbf24;
}

[data-theme="dark"] .cdx-finance-print-preview,
[data-theme="dark"] .cdx-finance-preview-thumb {
  background:
    linear-gradient(135deg, rgba(47, 128, 237, 0.14), transparent 34%),
    linear-gradient(315deg, rgba(32, 169, 139, 0.12), transparent 32%),
    var(--cdx-surface-soft);
}

[data-theme="dark"] .cdx-finance-mini-document {
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.28);
}

@media (max-width: 1199.98px) {
  .cdx-finance-metrics,
  .cdx-finance-card-grid,
  .cdx-route-grid,
  .cdx-finance-preview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cdx-finance-span-8,
  .cdx-finance-span-7,
  .cdx-finance-span-6,
  .cdx-finance-span-5,
  .cdx-finance-span-4 {
    grid-column: span 12;
  }
}

@media (max-width: 767.98px) {
  .cdx-finance-metrics,
  .cdx-finance-grid,
  .cdx-finance-card-grid,
  .cdx-fee-breakdown-grid,
  .cdx-route-grid,
  .cdx-payroll-grid,
  .cdx-finance-toolbar,
  .cdx-finance-print-grid,
  .cdx-finance-print-grid.is-balanced,
  .cdx-finance-total-band,
  .cdx-finance-preview-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .cdx-finance-span-8,
  .cdx-finance-span-7,
  .cdx-finance-span-6,
  .cdx-finance-span-5,
  .cdx-finance-span-4,
  .cdx-finance-span-12 {
    grid-column: auto;
  }

  .cdx-finance-filter-set {
    justify-content: stretch;
  }

  .cdx-finance-filter-set > * {
    flex: 1 1 160px;
  }

  .cdx-finance-transaction {
    grid-template-columns: 42px minmax(0, 1fr);
  }

  .cdx-finance-transaction > .cdx-money,
  .cdx-amount-cell,
  .cdx-table-card .cdx-money {
    grid-column: 2;
    text-align: left;
  }

  .cdx-finance-print-document {
    font-size: 0.76rem;
  }

  .cdx-finance-code-row,
  .cdx-finance-signatures {
    grid-template-columns: minmax(0, 1fr);
  }

  .cdx-finance-document-meta {
    justify-items: start;
    text-align: left;
  }
}

@media (max-width: 575.98px) {
  .cdx-topbar-actions > .btn-outline-primary,
  .cdx-topbar-actions > .btn-gradient {
    display: none;
  }
}
