:root {
  --bg: #09111f;
  --bg-soft: #101a2d;
  --panel: rgba(16, 26, 45, 0.9);
  --panel-strong: rgba(10, 18, 31, 0.95);
  --border: rgba(146, 174, 216, 0.16);
  --text: #f5f7ff;
  --muted: #91a3c4;
  --accent: #38bdf8;
  --accent-strong: #0ea5e9;
  --success: #22c55e;
  --danger: #f87171;
  --warning: #fbbf24;
  --shadow: 0 24px 70px rgba(3, 9, 19, 0.45);
  --radius-xl: 28px;
  --radius-lg: 22px;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Manrope", sans-serif;
  background:
    radial-gradient(
      circle at top left,
      rgba(14, 165, 233, 0.18),
      transparent 24%
    ),
    radial-gradient(
      circle at bottom right,
      rgba(34, 197, 94, 0.16),
      transparent 26%
    ),
    linear-gradient(145deg, #060d18 0%, #0a1324 42%, #0e1830 100%);
  color: var(--text);
}

h1,
h2,
h3,
.brand-title {
  font-family: "Space Grotesk", sans-serif;
  letter-spacing: -0.03em;
}

.auth-body,
.dashboard-body {
  padding: 24px;
}

.auth-shell {
  max-width: 1180px;
  margin: 0 auto;
  min-height: calc(100vh - 48px);
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 24px;
  align-items: stretch;
}

.auth-shell-register {
  grid-template-columns: 0.92fr 1.08fr;
}

.auth-panel {
  padding: 34px;
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
}

.auth-panel-copy {
  background:
    linear-gradient(180deg, rgba(12, 24, 43, 0.85), rgba(8, 16, 28, 0.94)),
    linear-gradient(135deg, rgba(56, 189, 248, 0.14), rgba(34, 197, 94, 0.06));
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.auth-panel-copy h1 {
  font-size: clamp(2.4rem, 5vw, 4.4rem);
  line-height: 0.98;
  max-width: 10ch;
  margin: 18px 0;
}

.auth-panel-copy p {
  max-width: 54ch;
  color: var(--muted);
  font-size: 1.05rem;
}

.auth-panel-form {
  background: rgba(9, 17, 31, 0.74);
  display: flex;
  align-items: center;
  justify-content: center;
}

.card-glass {
  background: linear-gradient(
    180deg,
    rgba(15, 24, 43, 0.9),
    rgba(10, 18, 31, 0.98)
  );
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  border-radius: var(--radius-lg);
}

.auth-card {
  width: 100%;
  max-width: 470px;
  padding: 34px;
}

.eyebrow {
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.72rem;
  font-weight: 700;
  color: #89d6ff;
}

.auth-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 32px;
}

.auth-metrics div,
.advisor-tile,
.target-card,
.budget-item {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 18px;
  padding: 16px;
}

.auth-metrics strong {
  display: block;
  font-size: 1.5rem;
}

.auth-metrics span,
.form-switcher,
.text-secondary,
.sidebar-copy,
.target-summary span,
.advisor-tile p,
.budget-item span,
.table .text-secondary,
.small.text-secondary {
  color: var(--muted) !important;
}

.auth-form .form-control,
.auth-form .form-select,
.stack-form .form-control,
.stack-form .form-select,
.stack-form textarea {
  background: rgba(7, 14, 26, 0.75);
  border: 1px solid rgba(145, 163, 196, 0.18);
  color: var(--text);
  border-radius: 14px;
  padding: 0.95rem 1rem;
}

.auth-form .form-control:focus,
.auth-form .form-select:focus,
.stack-form .form-control:focus,
.stack-form .form-select:focus,
.stack-form textarea:focus {
  background: rgba(7, 14, 26, 0.88);
  color: var(--text);
  border-color: rgba(56, 189, 248, 0.45);
  box-shadow: 0 0 0 0.2rem rgba(56, 189, 248, 0.15);
}

.btn-accent {
  background: linear-gradient(135deg, var(--accent), var(--accent-strong));
  border: none;
  color: #04101d;
  font-weight: 800;
  border-radius: 14px;
  padding: 0.9rem 1.2rem;
}

.btn-accent:hover {
  background: linear-gradient(135deg, #69d6ff, #38bdf8);
  color: #04101d;
}

.form-switcher {
  margin: 20px 0 0;
  text-align: center;
}

.form-switcher a {
  color: #9ce2ff;
  text-decoration: none;
}

.dashboard-shell {
  max-width: 1480px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 290px minmax(0, 1fr);
  gap: 24px;
}

.sidebar-panel {
  position: sticky;
  top: 24px;
  height: fit-content;
  padding: 28px;
  border-radius: var(--radius-xl);
  background: linear-gradient(
    180deg,
    rgba(9, 17, 31, 0.96),
    rgba(8, 15, 27, 0.94)
  );
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}

.brand-title {
  margin: 14px 0 10px;
  font-size: 2rem;
}

.sidebar-user,
.sidebar-rule {
  padding: 18px;
  margin-top: 22px;
}

.sidebar-menu {
  padding: 18px;
  margin-top: 22px;
}

.menu-title {
  display: block;
  margin-bottom: 12px;
  color: #99ddff;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dashboard-menu {
  display: grid;
  gap: 10px;
}

.dashboard-menu-btn {
  width: 100%;
  border: 1px solid rgba(145, 163, 196, 0.14);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text);
  border-radius: 14px;
  padding: 0.9rem 1rem;
  font-weight: 700;
  text-align: left;
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    transform 0.2s ease;
}

.dashboard-menu-btn:hover,
.dashboard-menu-btn:focus {
  background: rgba(56, 189, 248, 0.1);
  border-color: rgba(56, 189, 248, 0.3);
  color: var(--text);
}

.dashboard-menu-btn.is-active {
  background: linear-gradient(
    135deg,
    rgba(56, 189, 248, 0.24),
    rgba(14, 165, 233, 0.16)
  );
  border-color: rgba(56, 189, 248, 0.45);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.pwa-install-button {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 1200;
  border: 0;
  border-radius: 999px;
  padding: 0.95rem 1.3rem;
  background: linear-gradient(135deg, var(--accent), var(--accent-strong));
  color: #03111d;
  font-weight: 800;
  box-shadow: 0 18px 48px rgba(14, 165, 233, 0.28);
}

.pwa-install-prompt {
  position: fixed;
  right: 24px;
  bottom: 88px;
  z-index: 1199;
  width: min(380px, calc(100vw - 28px));
  padding: 20px;
  border-radius: 22px;
  border: 1px solid var(--border);
  background: linear-gradient(
    180deg,
    rgba(15, 24, 43, 0.96),
    rgba(8, 16, 28, 0.98)
  );
  box-shadow: var(--shadow);
}

.pwa-install-prompt__content h3 {
  margin: 10px 0 8px;
  font-size: 1.2rem;
}

.pwa-install-prompt__content p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.pwa-install-prompt__actions {
  display: flex;
  gap: 12px;
  margin-top: 18px;
  flex-wrap: wrap;
}

.pwa-install-prompt__actions .btn {
  flex: 1 1 140px;
}

.rule-item + .rule-item {
  margin-top: 14px;
}

.rule-item strong {
  display: block;
  font-size: 1.5rem;
}

.content-panel {
  min-width: 0;
}

.dashboard-panels {
  min-width: 0;
}

.dashboard-panel-section {
  display: none;
}

.dashboard-panel-section.is-active {
  display: block;
  animation: panelFade 0.22s ease;
}

@keyframes panelFade {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.hero-card,
.section-card,
.stat-card {
  padding: 24px;
}

.hero-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
}

.hero-chip {
  padding: 12px 18px;
  border-radius: 999px;
  font-weight: 700;
  white-space: nowrap;
}

.hero-chip.success {
  background: rgba(34, 197, 94, 0.16);
  color: #7ef0a4;
}

.hero-chip.warning {
  background: rgba(251, 191, 36, 0.16);
  color: #ffd978;
}

.stat-card span,
.advisor-tile span,
.section-heading h3,
.target-summary strong {
  display: block;
}

.stat-card strong {
  display: block;
  font-size: clamp(1.9rem, 4vw, 2.6rem);
  margin: 12px 0 4px;
}

.stat-card small {
  color: var(--muted);
}

.stat-card.income {
  background: linear-gradient(
    180deg,
    rgba(18, 54, 40, 0.95),
    rgba(9, 26, 22, 0.95)
  );
}

.stat-card.expense {
  background: linear-gradient(
    180deg,
    rgba(66, 23, 31, 0.95),
    rgba(29, 10, 14, 0.95)
  );
}

.stat-card.balance {
  background: linear-gradient(
    180deg,
    rgba(13, 43, 59, 0.95),
    rgba(9, 20, 30, 0.95)
  );
}

.section-heading {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}

.section-heading h3 {
  margin: 6px 0 0;
}

.advisor-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

.advisor-grid.compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.account-balance-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.account-balance-card {
  padding: 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.account-balance-card span,
.account-balance-card strong {
  display: block;
}

.account-balance-card strong {
  font-size: 1.7rem;
  margin: 10px 0 6px;
}

.account-balance-card small {
  color: var(--muted);
}

.account-ledger-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.ledger-filters {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.account-ledger-card {
  padding: 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.account-ledger-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}

.account-ledger-header span,
.ledger-date {
  color: var(--muted);
  font-size: 0.86rem;
}

.account-ledger-list {
  display: grid;
  gap: 12px;
  max-height: 520px;
  overflow-y: auto;
  padding-right: 4px;
}

.account-ledger-item {
  padding: 14px;
  border-radius: 16px;
  background: rgba(8, 16, 28, 0.62);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.ledger-empty-state {
  padding-top: 8px;
}

.ledger-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}

.ledger-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 0.28rem 0.7rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.ledger-badge.in,
.ledger-amount.in {
  color: #86efac;
}

.ledger-badge.in {
  background: rgba(34, 197, 94, 0.14);
}

.ledger-badge.out,
.ledger-amount.out {
  color: #fda4af;
}

.ledger-badge.out {
  background: rgba(248, 113, 113, 0.14);
}

.ledger-amount {
  font-weight: 800;
  white-space: nowrap;
}

.ledger-date {
  margin-top: 8px;
}

.chart-frame {
  position: relative;
  width: 100%;
}

.chart-frame-trend {
  height: 280px;
}

.chart-frame-pie {
  height: 250px;
}

.chart-frame canvas {
  width: 100% !important;
  height: 100% !important;
}

.advisor-tile strong {
  font-size: 1.6rem;
  margin: 10px 0;
}

.budget-item + .budget-item,
.target-card + .target-card {
  margin-top: 12px;
}

.budget-item.is-covered,
.target-card.is-covered {
  border-color: rgba(34, 197, 94, 0.5);
  background: rgba(34, 197, 94, 0.08);
}

.budget-item.is-overdue,
.target-card.is-overdue {
  border-color: rgba(248, 113, 113, 0.6);
  background: rgba(248, 113, 113, 0.08);
}

.budget-period-label {
  color: var(--muted);
  margin-top: 8px;
}

.budget-status {
  margin-top: 6px;
  font-weight: 700;
}

.budget-status.covered {
  color: #86efac;
}

.budget-status.overdue {
  color: #fda4af;
}

.overview-list,
.overview-focus-list {
  display: grid;
  gap: 12px;
}

.overview-focus-item {
  padding: 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.overview-focus-item.is-overdue {
  border-color: rgba(248, 113, 113, 0.6);
  background: rgba(248, 113, 113, 0.08);
}

.overview-warning-card strong {
  display: block;
  margin-bottom: 6px;
}

.lending-return-form {
  display: grid;
  gap: 10px;
}

.lending-history-stats {
  margin-bottom: 18px;
}

.savings-log {
  display: grid;
  gap: 12px;
}

.savings-log-item {
  padding: 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.budget-progress {
  margin-top: 10px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 999px;
  overflow: hidden;
  height: 10px;
}

.budget-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.budget-summary-card,
.budget-mini-report {
  padding: 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.budget-summary-card span,
.budget-summary-card strong {
  display: block;
}

.budget-summary-card strong {
  font-size: 1.4rem;
  margin: 10px 0 6px;
}

.budget-summary-card small,
.budget-mini-report p {
  color: var(--muted);
}

.stack-form {
  display: grid;
  gap: 14px;
}

.stack-form .btn-accent {
  margin-top: 6px;
}

.target-summary {
  padding: 16px;
  border-radius: 18px;
  background: rgba(56, 189, 248, 0.08);
}

.recent-table {
  --bs-table-bg: transparent;
  --bs-table-striped-bg: rgba(255, 255, 255, 0.02);
  --bs-table-color: var(--text);
  --bs-table-border-color: rgba(255, 255, 255, 0.06);
}

.recent-table thead th {
  color: #99ddff;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.alert {
  border-radius: 16px;
  border: 1px solid transparent;
}

.alert-success {
  background: rgba(34, 197, 94, 0.14);
  color: #bbf7d0;
  border-color: rgba(34, 197, 94, 0.18);
}

.alert-danger {
  background: rgba(248, 113, 113, 0.14);
  color: #fecaca;
  border-color: rgba(248, 113, 113, 0.18);
}

.alert-warning {
  background: rgba(251, 191, 36, 0.14);
  color: #fde68a;
  border-color: rgba(251, 191, 36, 0.18);
}

canvas {
  max-width: 100%;
}

.page-shell {
  align-items: start;
}

.page-links-card {
  padding: 18px;
  margin-top: 22px;
}

.program-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.program-card {
  padding: 20px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.program-card h4 {
  margin: 0 0 4px;
}

.program-card-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 18px;
}

.program-metrics,
.report-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.program-metrics div {
  padding: 14px;
  border-radius: 16px;
  background: rgba(8, 16, 28, 0.62);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.program-metrics span,
.program-metrics strong,
.report-meta span {
  display: block;
}

.program-metrics strong {
  margin-top: 6px;
  font-size: 1.05rem;
}

.program-meta {
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  padding-top: 14px;
}

.report-surface {
  padding-top: 30px;
}

.report-heading {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: flex-start;
  margin-bottom: 16px;
}

.report-meta {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  padding-bottom: 18px;
  margin-bottom: 20px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--muted);
}

.print-hidden {
  display: block;
}

@media (max-width: 1199px) {
  .dashboard-shell {
    grid-template-columns: 1fr;
  }

  .sidebar-panel {
    position: static;
  }

  .dashboard-menu {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .program-grid,
  .program-metrics,
  .report-stats-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 991px) {
  .auth-shell,
  .auth-shell-register {
    grid-template-columns: 1fr;
  }

  .auth-panel-copy {
    min-height: 320px;
  }

  .advisor-grid {
    grid-template-columns: 1fr;
  }

  .chart-frame-trend {
    height: 240px;
  }

  .chart-frame-pie {
    height: 220px;
  }

  .dashboard-menu {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .account-balance-grid {
    grid-template-columns: 1fr;
  }

  .account-ledger-grid {
    grid-template-columns: 1fr;
  }

  .ledger-filters {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .budget-summary-grid {
    grid-template-columns: 1fr;
  }

  .report-heading {
    flex-direction: column;
  }
}

@media (max-width: 767px) {
  .auth-body,
  .dashboard-body {
    padding: 14px;
  }

  .auth-panel,
  .sidebar-panel,
  .hero-card,
  .section-card,
  .stat-card,
  .auth-card {
    padding: 20px;
  }

  .hero-card {
    flex-direction: column;
    align-items: flex-start;
  }

  .auth-metrics {
    grid-template-columns: 1fr;
  }

  .dashboard-menu {
    grid-template-columns: 1fr;
  }

  .dashboard-menu-btn {
    text-align: center;
  }

  .advisor-grid.compact {
    grid-template-columns: 1fr;
  }

  .account-balance-card strong {
    font-size: 1.5rem;
  }

  .chart-frame-trend {
    height: 220px;
  }

  .chart-frame-pie {
    height: 200px;
  }

  .ledger-filters {
    grid-template-columns: 1fr;
  }

  .pwa-install-button {
    right: 14px;
    bottom: 14px;
    width: calc(100vw - 28px);
  }

  .pwa-install-prompt {
    right: 14px;
    bottom: 82px;
    width: calc(100vw - 28px);
  }

  .pwa-install-prompt__actions {
    flex-direction: column;
  }

  .account-ledger-header,
  .ledger-title-row {
    align-items: flex-start;
  }
}

@media print {
  @page {
    size: A4;
    margin: 14mm;
  }

  body {
    background: #ffffff !important;
    color: #111111 !important;
    padding: 0;
    font-family: "Times New Roman", Georgia, serif;
    line-height: 1.4;
    font-size: 11.5pt;
  }

  .print-hidden,
  .sidebar-panel,
  .btn,
  .alert,
  .pwa-install-button,
  .pwa-install-prompt {
    display: none !important;
  }

  .dashboard-shell,
  .page-shell,
  .content-panel {
    display: block;
    max-width: none;
    width: 100%;
    margin: 0;
    padding: 0;
    gap: 0;
  }

  .card-glass,
  .section-card,
  .stat-card,
  .program-card,
  .budget-item,
  .target-card,
  .account-balance-card {
    background: #ffffff !important;
    color: #111111 !important;
    border: 1px solid #d8dde6 !important;
    box-shadow: none !important;
  }

  .report-surface {
    border: 1px solid #cfd6e3 !important;
    padding: 0 !important;
    border-radius: 0 !important;
    overflow: visible !important;
  }

  .report-heading {
    display: block;
    margin: 0;
    padding: 0 0 12pt;
    border-bottom: 1px solid #cfd6e3;
  }

  .report-heading h2 {
    margin: 4pt 0 0;
    font-family: "Times New Roman", Georgia, serif;
    font-size: 18pt;
    letter-spacing: 0;
    font-weight: 700;
  }

  .report-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8pt 16pt;
    margin: 0;
    padding: 10pt 0 12pt;
    border-bottom: 1px solid #d9dfe8;
    font-size: 10pt;
  }

  .report-stats-grid,
  .budget-summary-grid,
  .account-balance-grid,
  .program-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10pt;
    margin: 12pt 0;
  }

  .program-grid {
    grid-template-columns: 1fr;
    gap: 10pt;
  }

  .stat-card,
  .budget-summary-card,
  .account-balance-card,
  .budget-item,
  .target-card,
  .program-card,
  .program-metrics div {
    border-radius: 0 !important;
    break-inside: avoid;
    page-break-inside: avoid;
  }

  .stat-card strong,
  .budget-summary-card strong,
  .account-balance-card strong {
    font-size: 13pt;
    margin: 4pt 0 0;
  }

  .recent-table {
    --bs-table-bg: #ffffff;
    --bs-table-color: #111111;
    --bs-table-border-color: #cfd6e3;
    margin-top: 10pt;
  }

  .table {
    width: 100%;
    border-collapse: collapse !important;
    font-size: 10.5pt;
  }

  .table thead th {
    background: #eef2f7 !important;
    color: #1d2430 !important;
    border: 1px solid #cfd6e3 !important;
    padding: 7pt 8pt !important;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: 9.5pt;
  }

  .table tbody td {
    border: 1px solid #d9dfe8 !important;
    padding: 6pt 8pt !important;
    vertical-align: top;
  }

  .table tbody tr:nth-child(even) td {
    background: #f8fafc !important;
  }

  .badge {
    border: 1px solid #c7cfdd !important;
    background: #f4f7fb !important;
    color: #253041 !important;
    font-weight: 700;
  }

  .budget-progress {
    height: 6pt;
    background: #edf1f7;
    border: 1px solid #d2d9e5;
  }

  .progress-bar,
  .bg-success,
  .bg-danger {
    background: #64748b !important;
  }

  h2,
  h3,
  h4,
  tr,
  td,
  th,
  .budget-item,
  .target-card,
  .program-card {
    break-inside: avoid;
    page-break-inside: avoid;
  }

  .text-secondary,
  .small.text-secondary,
  .program-meta,
  .report-meta,
  .budget-summary-card small,
  .budget-mini-report p {
    color: #5b6470 !important;
  }

  .report-meta span {
    color: #4f5a69 !important;
  }

  .table,
  .table * {
    color: #111111 !important;
  }
}
