/* ── MyDebtLens Design System v1.0 ──────────────────────────
   Applies to: dashboard, debt-overview, scenarios, calendar,
               full-report, setup
   ─────────────────────────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,500;1,400;1,500&family=Outfit:wght@300;400;500&family=Syne:wght@700&display=swap');

/* ── Tokens ─────────────────────────────────────────────────── */
:root {
  --ds-cream:       #FAF7F2;
  --ds-white:       #FFFFFF;
  --ds-navy:        #0D1E30;
  --ds-navy2:       #142035;
  --ds-ink:         #2A3545;
  --ds-muted:       #7A8899;
  --ds-border:      rgba(20,32,53,0.09);
  --ds-surface:     #FAFAF7;

  --ds-teal:        #1D8F6A;
  --ds-teal-bg:     rgba(29,143,106,0.09);
  --ds-amber:       #B87D1A;
  --ds-amber-bg:    rgba(184,125,26,0.09);
  --ds-red:         #B03A3A;
  --ds-red-bg:      rgba(176,58,58,0.08);
  --ds-blue:        #4A9EE8;

  /* hero band */
  --ds-t1:          rgba(255,255,255,0.93);
  --ds-t2:          rgba(255,255,255,0.55);
  --ds-t3:          rgba(255,255,255,0.30);
  --ds-line-dark:   rgba(255,255,255,0.09);
  --ds-line-dark2:  rgba(255,255,255,0.16);
  --ds-teal-hero:   #4DD4A8;
  --ds-red-hero:    #F26B6B;
  --ds-amber-hero:  #F5C04A;
}

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
body { margin: 0; background: var(--ds-cream); font-family: 'Outfit', sans-serif; color: var(--ds-ink); font-size: 13px; line-height: 1.5; }

/* ── Topbar (supplement existing nav) ─────────────────────────
   The existing mdl-nav-root renders the topbar. This just
   ensures the body has correct top spacing.                    */
.ds-page-body { padding-top: 0; }

/* ── Analysis band ────────────────────────────────────────────*/
.ds-band {
  background: var(--ds-navy);
  padding: 28px 28px 26px;
  width: 100%;
}
.ds-band-greet-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 16px;
  flex-wrap: wrap;
  gap: 12px;
}
.ds-band-time {
  font-size: 11px;
  color: var(--ds-t3);
  letter-spacing: 0.08em;
  margin-bottom: 4px;
}
.ds-band-name {
  font-family: 'Syne', sans-serif;
  font-size: 21px;
  font-weight: 700;
  color: var(--ds-t1);
}
.ds-band-name-accent { color: var(--ds-teal-hero); }

.ds-stat-pills { display: flex; gap: 8px; flex-wrap: wrap; }
.ds-stat-pill {
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--ds-line-dark2);
  border-radius: 6px;
  padding: 7px 13px;
  text-align: right;
}
.ds-stat-pill-label {
  font-size: 9px; color: var(--ds-t3);
  text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: 2px;
}
.ds-stat-pill-val {
  font-family: 'Syne', sans-serif;
  font-size: 15px; font-weight: 500; color: var(--ds-t1);
}
.ds-stat-pill-val.red { color: var(--ds-red-hero); }
.ds-stat-pill-val.teal { color: var(--ds-teal-hero); }
.ds-stat-pill-val.amber { color: var(--ds-amber-hero); }
.ds-stat-pill-sub { font-size: 10px; color: var(--ds-t3); margin-top: 1px; }

.ds-analysis-block {
  border-left: 2px solid var(--ds-blue);
  padding-left: 16px;
}
.ds-analysis-kicker {
  font-size: 9px; color: var(--ds-blue);
  letter-spacing: 0.18em; text-transform: uppercase;
  font-weight: 500; margin-bottom: 9px;
}
.ds-analysis-text {
  font-size: 12.5px; color: var(--ds-t2); line-height: 1.82;
}
.ds-analysis-text b { color: var(--ds-t1); font-weight: 500; }
.ds-hi-r { color: var(--ds-red-hero); font-weight: 500; }
.ds-hi-g { color: var(--ds-teal-hero); font-weight: 500; }
.ds-hi-a { color: var(--ds-amber-hero); font-weight: 500; }

.ds-cta-row { display: flex; gap: 10px; margin-top: 14px; align-items: center; flex-wrap: wrap; }
.ds-cta-primary {
  display: inline-flex; align-items: center;
  font-size: 12px; font-weight: 500;
  background: rgba(255,255,255,0.9); color: var(--ds-navy);
  padding: 8px 15px; border-radius: 6px; cursor: pointer;
  text-decoration: none; border: none;
}
.ds-cta-primary:hover { background: white; }
.ds-cta-secondary {
  font-size: 12px; color: var(--ds-t2);
  cursor: pointer; padding: 8px 0;
  text-decoration: none; background: none; border: none;
}
.ds-cta-secondary:hover { color: var(--ds-t1); }

/* Page header (non-analysis pages) */
.ds-page-header {
  background: var(--ds-white);
  border-bottom: 1px solid var(--ds-border);
  padding: 18px 24px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.ds-page-eyebrow {
  font-size: 10px; color: var(--ds-muted);
  text-transform: uppercase; letter-spacing: 0.13em; margin-bottom: 5px;
}
.ds-page-title {
  font-family: 'Lora', serif;
  font-size: 22px; color: var(--ds-navy); font-weight: 400;
}
.ds-page-sub { font-size: 12px; color: var(--ds-muted); margin-top: 3px; }

/* ── Column layout ──────────────────────────────────────────── */
.ds-columns {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 16px;
  padding: 18px 20px 32px;
}
.ds-columns.single { grid-template-columns: 1fr; }
.ds-columns.three { grid-template-columns: 1fr 1fr 1fr; }

/* ── Cards ──────────────────────────────────────────────────── */
.ds-card {
  background: var(--ds-white);
  border: 1px solid var(--ds-border);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 14px;
}
.ds-card:last-child { margin-bottom: 0; }
.ds-card-head {
  padding: 11px 16px;
  border-bottom: 1px solid var(--ds-border);
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
.ds-card-label {
  font-size: 10px; color: var(--ds-muted);
  text-transform: uppercase; letter-spacing: 0.12em;
}
.ds-card-link {
  font-size: 11px; color: var(--ds-teal);
  cursor: pointer; text-decoration: none;
}
.ds-card-link:hover { opacity: 0.75; }
.ds-card-body { padding: 16px; }

/* ── Buttons ────────────────────────────────────────────────── */
.ds-btn {
  font-size: 11px; font-weight: 500;
  padding: 7px 13px; border-radius: 6px; cursor: pointer;
  font-family: 'Outfit', sans-serif; letter-spacing: 0.02em;
  display: inline-flex; align-items: center; gap: 5px;
  text-decoration: none;
}
.ds-btn-primary { background: var(--ds-navy); color: white; border: none; }
.ds-btn-primary:hover { background: var(--ds-navy2); }
.ds-btn-secondary { background: transparent; color: var(--ds-muted); border: 1px solid var(--ds-border); }
.ds-btn-secondary:hover { background: var(--ds-surface); color: var(--ds-ink); }

/* ── Lora headline ──────────────────────────────────────────── */
.ds-lora { font-family: 'Lora', serif; font-weight: 400; }

/* ── Pills ──────────────────────────────────────────────────── */
.ds-pill {
  display: inline-block; font-size: 9px; font-weight: 500;
  padding: 2px 6px; border-radius: 3px;
}
.ds-pill-red    { background: var(--ds-red-bg);    color: var(--ds-red);   }
.ds-pill-amber  { background: var(--ds-amber-bg);  color: var(--ds-amber); }
.ds-pill-teal   { background: var(--ds-teal-bg);   color: var(--ds-teal);  }
.ds-pill-muted  { background: #F0EDE8;              color: var(--ds-muted); }

/* ── Progress bars ──────────────────────────────────────────── */
.ds-meter { margin-bottom: 9px; }
.ds-meter-labels {
  display: flex; justify-content: space-between;
  font-size: 10px; color: var(--ds-muted); margin-bottom: 4px;
}
.ds-meter-track {
  height: 3px; background: #EDE9E2;
  border-radius: 2px; overflow: hidden;
}
.ds-meter-fill { height: 100%; border-radius: 2px; }

/* ── Insight rows ───────────────────────────────────────────── */
.ds-insight {
  background: var(--ds-surface);
  border: 1px solid var(--ds-border);
  border-radius: 5px;
  padding: 9px 11px;
  display: flex; gap: 8px;
  margin-bottom: 7px;
}
.ds-insight-dot {
  width: 6px; height: 6px; border-radius: 50%;
  margin-top: 4px; flex-shrink: 0;
}
.ds-insight-text { font-size: 11px; color: var(--ds-muted); line-height: 1.65; }
.ds-insight-text b { color: var(--ds-ink); font-weight: 500; }

/* ── Stat strip ─────────────────────────────────────────────── */
.ds-stat-strip { display: grid; grid-template-columns: repeat(3,1fr); }
.ds-stat-cell {
  padding: 13px 16px;
  border-right: 1px solid var(--ds-border);
}
.ds-stat-cell:last-child { border-right: none; }
.ds-stat-label { font-size: 10px; color: var(--ds-muted); text-transform: uppercase; letter-spacing: 0.10em; margin-bottom: 3px; }
.ds-stat-val { font-family: 'Lora', serif; font-size: 19px; color: var(--ds-ink); }
.ds-stat-val.red { color: var(--ds-red); }
.ds-stat-val.amber { color: var(--ds-amber); }
.ds-stat-val.teal { color: var(--ds-teal); }
.ds-stat-sub { font-size: 10px; color: var(--ds-muted); margin-top: 2px; }

/* ── Quality strip (4-col) ──────────────────────────────────── */
.ds-quality-strip {
  display: grid; grid-template-columns: repeat(4,1fr);
  background: var(--ds-white);
  border: 1px solid var(--ds-border);
  border-radius: 10px; overflow: hidden;
  margin-bottom: 16px;
}
.ds-quality-cell {
  padding: 14px 16px;
  border-right: 1px solid var(--ds-border);
}
.ds-quality-cell:last-child { border-right: none; }
.ds-quality-val { font-family: 'Lora', serif; font-size: 20px; color: var(--ds-ink); margin-bottom: 2px; }
.ds-quality-sub { font-size: 11px; color: var(--ds-muted); }

/* ── Debt table ─────────────────────────────────────────────── */
.ds-dt-head {
  display: grid;
  grid-template-columns: 4px 1fr 58px 76px 68px 36px;
  gap: 8px; padding: 8px 16px;
  border-bottom: 1px solid var(--ds-border);
  align-items: center;
}
.ds-dt-hcell { font-size: 9px; color: var(--ds-muted); text-transform: uppercase; letter-spacing: 0.10em; }
.ds-dt-hcell.r { text-align: right; }
.ds-dt-row-wrap { border-bottom: 1px solid var(--ds-border); }
.ds-dt-row-wrap:last-child { border-bottom: none; }
.ds-dt-row {
  display: grid;
  grid-template-columns: 4px 1fr 58px 76px 68px 36px;
  gap: 8px; padding: 11px 16px;
  align-items: center; cursor: pointer;
  transition: background 0.12s;
}
.ds-dt-row:hover { background: var(--ds-surface); }
.ds-dt-ind { width: 3px; height: 28px; border-radius: 2px; justify-self: center; }
.ds-dt-name { font-size: 12px; font-weight: 500; color: var(--ds-ink); }
.ds-dt-meta { display: flex; align-items: center; gap: 5px; margin-top: 2px; }
.ds-dt-apr { font-size: 12px; color: var(--ds-ink); text-align: right; }
.ds-dt-bal { font-size: 12px; font-weight: 500; color: var(--ds-ink); text-align: right; }
.ds-dt-int { font-size: 11px; color: var(--ds-muted); text-align: right; }
.ds-dt-toggle { text-align: center; color: var(--ds-muted); font-size: 14px; transition: transform 0.2s; }
.ds-dt-toggle.open { transform: rotate(180deg); }

.ds-dt-detail {
  display: none; background: var(--ds-surface);
  border-top: 1px solid var(--ds-border);
  padding: 14px 16px 14px 28px;
}
.ds-dt-detail.open { display: block; }
.ds-dt-detail-grid {
  display: grid; grid-template-columns: repeat(4,1fr);
  gap: 12px; margin-bottom: 12px;
}
.ds-dt-detail-label { font-size: 10px; color: var(--ds-muted); text-transform: uppercase; letter-spacing: 0.10em; margin-bottom: 3px; }
.ds-dt-detail-val { font-size: 13px; font-weight: 500; color: var(--ds-ink); }
.ds-dt-detail-sub { font-size: 10px; color: var(--ds-muted); margin-top: 1px; }

/* ── Calendar ───────────────────────────────────────────────── */
.ds-cal-grid {
  display: grid; grid-template-columns: repeat(7,1fr); gap: 2px;
}
.ds-cal-dhdr { font-size: 9px; color: var(--ds-muted); text-align: center; padding: 2px 0; }
.ds-cal-day {
  height: 22px; border-radius: 3px;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; color: var(--ds-muted);
  cursor: default;
}
.ds-cal-day.past { color: #CCC; }
.ds-cal-day.today { background: var(--ds-navy); color: white; font-weight: 600; }
.ds-cal-day.due { background: var(--ds-red-bg); color: var(--ds-red); font-weight: 500; }
.ds-cal-day.check { background: var(--ds-teal-bg); color: var(--ds-teal); }
.ds-cal-day.income { background: rgba(74,158,232,0.10); color: var(--ds-blue); }
.ds-cal-day.expense { background: var(--ds-amber-bg); color: var(--ds-amber); }
.ds-cal-day.has-event { cursor: pointer; }
.ds-cal-day.has-event:hover { filter: brightness(0.92); }

.ds-cal-legend { display: flex; gap: 10px; margin-top: 8px; flex-wrap: wrap; }
.ds-cal-legend-item { display: flex; align-items: center; gap: 4px; font-size: 10px; color: var(--ds-muted); }
.ds-cal-legend-dot { width: 7px; height: 7px; border-radius: 50%; }

/* ── Sidebar aside blocks ───────────────────────────────────── */
.ds-aside-block { padding: 12px 14px; border-bottom: 1px solid var(--ds-border); }
.ds-aside-block:last-child { border-bottom: none; }
.ds-aside-label { font-size: 10px; color: var(--ds-muted); text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: 4px; }
.ds-aside-val { font-family: 'Lora', serif; font-size: 17px; color: var(--ds-ink); }
.ds-aside-val.amber { color: var(--ds-amber); }
.ds-aside-val.teal { color: var(--ds-teal); }
.ds-aside-val.red { color: var(--ds-red); }
.ds-aside-desc { font-size: 11px; color: var(--ds-muted); line-height: 1.62; margin-top: 3px; }
.ds-aside-link { font-size: 11px; color: var(--ds-teal); margin-top: 5px; cursor: pointer; display: inline-block; text-decoration: none; }
.ds-aside-link:hover { opacity: 0.75; }

/* ── Sort/filter buttons ────────────────────────────────────── */
.ds-filter-btn {
  font-size: 10px; padding: 3px 9px;
  border-radius: 20px; border: 1px solid var(--ds-border);
  background: transparent; color: var(--ds-muted);
  cursor: pointer; font-family: 'Outfit', sans-serif;
}
.ds-filter-btn.active { background: var(--ds-navy); color: white; border-color: var(--ds-navy); }

/* ── Scenario path cards ─────────────────────────────────────  */
.ds-path-card {
  background: var(--ds-white);
  border: 1px solid var(--ds-border);
  border-radius: 10px;
  padding: 16px;
  flex: 1;
  cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.ds-path-card:hover { border-color: var(--ds-blue); }
.ds-path-card.selected { border-color: var(--ds-blue); box-shadow: 0 0 0 2px rgba(74,158,232,0.15); }
.ds-path-card-label { font-size: 9px; color: var(--ds-muted); text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: 6px; }
.ds-path-card-name { font-family: 'Lora', serif; font-size: 15px; color: var(--ds-ink); margin-bottom: 5px; }
.ds-path-card-date { font-family: 'Syne', sans-serif; font-size: 18px; color: var(--ds-navy); font-weight: 700; margin-bottom: 3px; }
.ds-path-card-sub { font-size: 11px; color: var(--ds-muted); }
.ds-path-card.selected .ds-path-card-date { color: var(--ds-teal); }

/* ── Form elements ──────────────────────────────────────────── */
.ds-form-section { margin-bottom: 24px; }
.ds-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.ds-form-row.single { grid-template-columns: 1fr; }
.ds-form-row.triple { grid-template-columns: 1fr 1fr 1fr; }
.ds-label { font-size: 11px; color: var(--ds-muted); margin-bottom: 4px; display: block; }
.ds-input {
  width: 100%; font-size: 13px; font-family: 'Outfit', sans-serif;
  padding: 8px 10px; border-radius: 6px;
  border: 1px solid var(--ds-border); background: var(--ds-white); color: var(--ds-ink);
  outline: none;
}
.ds-input:focus { border-color: var(--ds-blue); box-shadow: 0 0 0 2px rgba(74,158,232,0.12); }
.ds-select {
  width: 100%; font-size: 13px; font-family: 'Outfit', sans-serif;
  padding: 8px 10px; border-radius: 6px;
  border: 1px solid var(--ds-border); background: var(--ds-white); color: var(--ds-ink);
  cursor: pointer; outline: none;
}
.ds-select:focus { border-color: var(--ds-blue); }

/* ── Show-more row ──────────────────────────────────────────── */
.ds-show-more {
  padding: 10px 16px; text-align: center;
  font-size: 11px; color: var(--ds-teal); cursor: pointer;
  background: var(--ds-surface);
  border-top: 1px solid var(--ds-border);
}
.ds-show-more:hover { background: #F0EDE8; }

/* ── Disclaimer note ────────────────────────────────────────── */
.ds-note {
  background: var(--ds-white);
  border: 1px solid var(--ds-border);
  border-radius: 10px;
  padding: 14px 18px;
  margin-top: 16px;
  display: flex; align-items: flex-start; gap: 12px;
}
.ds-note-icon {
  width: 32px; height: 32px; border-radius: 6px;
  background: rgba(74,158,232,0.10);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; color: var(--ds-blue); font-size: 16px;
}
.ds-note-text { font-size: 12px; color: var(--ds-muted); line-height: 1.7; }
.ds-note-text b { color: var(--ds-ink); font-weight: 500; }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 900px) {
  .ds-columns { grid-template-columns: 1fr; }
  .ds-quality-strip { grid-template-columns: 1fr 1fr; }
  .ds-stat-strip { grid-template-columns: 1fr 1fr; }
  .ds-band-greet-row { flex-direction: column; }
  .ds-dt-detail-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .ds-band { padding: 20px 16px; }
  .ds-columns { padding: 12px 12px 24px; }
  .ds-quality-strip { grid-template-columns: 1fr; }
  .ds-dt-head, .ds-dt-row { grid-template-columns: 4px 1fr 58px 72px; }
  .ds-dt-head :nth-child(5), .ds-dt-row :nth-child(5) { display: none; }
}


/* ── MAY10-16 contrast hierarchy polish ───────────────────────
   Reserve muted tones for labels/metadata and keep body copy
   more legible on the warm cream surface. */
:root {
  --ds-primary-text: #1A2535;
  --ds-body-text: #2A3545;
  --ds-helper-text: #3D4A5C;
  --ds-tertiary-text: #7A8899;
  --ds-disabled-text: #B0BAC4;
  --ds-ink: var(--ds-primary-text);
}
body { color: var(--ds-body-text); }
.ds-card-body,
.ds-note-text,
.ds-insight-text { color: var(--ds-body-text); }
.ds-card-body b,
.ds-note-text b,
.ds-insight-text b { color: var(--ds-primary-text); font-weight: 600; }
.ds-card-label,
.ds-stat-label,
.ds-quality-sub,
.ds-meter-labels,
.ds-stat-pill-label { color: var(--ds-tertiary-text); }
.ds-analysis-text { color: rgba(255,255,255,0.78); }
.ds-analysis-text b { color: rgba(255,255,255,0.96); font-weight: 700; }
.ds-btn-secondary { color: var(--ds-helper-text); }

/* ── MAY10-17 global contrast + semantic tint polish ───────────
   Apply the dashboard readability treatment across the v3 app:
   keep normal body copy readable, reserve muted tones for labels,
   and tint only containers with a clear semantic meaning. */
:root {
  --ds-primary-text: #1A2535;
  --ds-body-text: #2A3545;
  --ds-helper-text: #3D4A5C;
  --ds-tertiary-text: #7A8899;
  --ds-disabled-text: #B0BAC4;
  --ds-payoff-wash: rgba(176,58,58,.045);
  --ds-payoff-wash-strong: rgba(176,58,58,.065);
  --ds-warning-wash: rgba(184,125,26,.075);
  --ds-success-wash: rgba(29,143,106,.055);
  --ds-blue-wash: rgba(74,158,232,.055);
  --ds-ink: var(--ds-primary-text);
}
body,
.ds-card-body,
.ds-card-body p,
.ds-note-text,
.ds-insight-text,
.ds-page-sub,
.ds-path-card-sub,
.ds-dt-row,
.ds-aside-desc,
.ds-stat-sub,
.ds-empty,
.ds-form-help,
.ds-help-text {
  color: var(--ds-body-text);
}
.ds-card-body b,
.ds-note-text b,
.ds-insight-text b,
.ds-page-sub b,
.ds-path-card-sub b,
.ds-aside-desc b,
.ds-stat-sub b {
  color: var(--ds-primary-text);
  font-weight: 700;
}
.ds-page-eyebrow,
.ds-card-label,
.ds-stat-label,
.ds-quality-label,
.ds-quality-sub,
.ds-meter-labels,
.ds-dt-head,
.ds-dt-hcell,
.ds-label,
.ds-path-card-label,
.ds-stat-pill-label,
.ds-stat-pill-sub,
.ds-show-more-note,
.ds-meta,
.ds-muted {
  color: var(--ds-tertiary-text);
}
.ds-btn-secondary,
.ds-filter-btn,
.ds-show-more {
  color: var(--ds-helper-text);
}
.ds-btn-secondary:hover,
.ds-filter-btn:hover,
.ds-show-more:hover {
  color: var(--ds-primary-text);
}
.ds-input::placeholder,
textarea::placeholder,
input::placeholder {
  color: var(--ds-disabled-text);
}
.ds-disabled,
[disabled] {
  color: var(--ds-disabled-text);
}

/* Existing semantic pills stay as the primary color-key. These
   container washes are deliberately quiet and only used where the
   content has one clear signal. */
.ds-card.semantic-payoff,
.ds-card.ds-card-payoff,
.ds-payoff-wash {
  background: linear-gradient(180deg,var(--ds-payoff-wash),rgba(255,255,255,.98) 48%);
  border-color: rgba(176,58,58,.16);
}
.ds-card.semantic-warning,
.ds-warning-wash {
  background: linear-gradient(180deg,var(--ds-warning-wash),rgba(255,255,255,.98) 48%);
  border-color: rgba(184,125,26,.18);
}
.ds-card.semantic-success,
.ds-success-wash {
  background: linear-gradient(180deg,var(--ds-success-wash),rgba(255,255,255,.98) 48%);
  border-color: rgba(29,143,106,.16);
}

/* Debt Overview: role summaries and payoff-target debt cards. */
body[data-page="debt-overview"] .do-story-copy,
body[data-page="debt-overview"] .do-path-desc,
body[data-page="debt-overview"] .do-top-intro,
body[data-page="debt-overview"] .do-top-reason,
body[data-page="debt-overview"] .do-table-intro,
body[data-page="debt-overview"] .do-step-text,
body[data-page="debt-overview"] .do-role-text,
body[data-page="debt-overview"] .do-help-popover {
  color: var(--ds-body-text);
}
body[data-page="debt-overview"] .do-emphasis-text,
body[data-page="debt-overview"] .do-top-meta,
body[data-page="debt-overview"] .do-empty {
  color: var(--ds-helper-text);
}
body[data-page="debt-overview"] .do-top-debt {
  background: linear-gradient(90deg,var(--ds-payoff-wash),rgba(255,255,255,.98) 46%);
  border-color: rgba(176,58,58,.13);
}
body[data-page="debt-overview"] #do-quality .do-quality-payoff {
  background: linear-gradient(180deg,var(--ds-payoff-wash-strong),rgba(255,255,255,.98));
  border-color: rgba(176,58,58,.14);
}
body[data-page="debt-overview"] #do-quality .do-quality-scheduled {
  background: linear-gradient(180deg,rgba(122,136,153,.06),rgba(255,255,255,.98));
}
body[data-page="debt-overview"] #do-quality .do-quality-longterm {
  background: linear-gradient(180deg,var(--ds-success-wash),rgba(255,255,255,.98));
  border-color: rgba(29,143,106,.13);
}
body[data-page="debt-overview"] #do-quality .do-quality-outside {
  background: linear-gradient(180deg,rgba(13,30,48,.04),rgba(255,255,255,.98));
}

/* Scenario Lab: payoff allocation cards are all payoff-target cards,
   so they receive the same quiet urgency wash. */
body[data-page="scenarios"] .sc-strategy-note,
body[data-page="scenarios"] .sc-split-total,
body[data-page="scenarios"] .sc-tradeoff-note,
body[data-page="scenarios"] .sc-whatif-row,
body[data-page="scenarios"] .sc-budget-note,
body[data-page="scenarios"] .sc-split-placeholder {
  color: var(--ds-body-text);
}
body[data-page="scenarios"] .sc-split-meta,
body[data-page="scenarios"] .sc-impact-label {
  color: var(--ds-tertiary-text);
}
body[data-page="scenarios"] .sc-allocation-card {
  background: linear-gradient(180deg,var(--ds-payoff-wash),rgba(255,255,255,.98) 44%);
  border-color: rgba(176,58,58,.13);
}
body[data-page="scenarios"] .sc-allocation-card .sc-split-name,
body[data-page="scenarios"] .sc-impact-val,
body[data-page="scenarios"] .sc-split-value {
  color: var(--ds-primary-text);
}
body[data-page="scenarios"] .sc-budget-note,
body[data-page="scenarios"] .sc-split-placeholder {
  background: var(--ds-warning-wash);
  border-color: rgba(184,125,26,.24);
}

/* Calendar: keep the calendar neutral but darken descriptions and
   make event chips more legible without coloring the whole card. */
body[data-page="calendar"] .cal-modal-sub,
body[data-page="calendar"] .cal-day-meta,
body[data-page="calendar"] .cal-muted-box,
body[data-page="calendar"] .cal-form-help,
body[data-page="calendar"] .cal-empty-day,
body[data-page="calendar"] .cal-more-chip,
body[data-page="calendar"] .cal-cal-sub,
body[data-page="calendar"] .cal-cockpit .ds-card-body,
body[data-page="calendar"] .cal-cockpit .ds-stat-sub {
  color: var(--ds-body-text);
}
body[data-page="calendar"] .cal-week-grid .ds-cal-dhdr,
body[data-page="calendar"] .cal-day-num,
body[data-page="calendar"] .cal-event-chip {
  color: var(--ds-helper-text);
}
body[data-page="calendar"] .cal-event-chip {
  border-color: rgba(13,30,48,.11);
  box-shadow: 0 1px 3px rgba(13,30,48,.055);
}
body[data-page="calendar"] .cal-event-due { background: rgba(176,58,58,.035); }
body[data-page="calendar"] .cal-event-income { background: rgba(74,158,232,.035); }
body[data-page="calendar"] .cal-event-expense { background: rgba(184,125,26,.04); }
body[data-page="calendar"] .cal-event-check { background: rgba(29,143,106,.04); }

/* Setup: form help and list metadata should be readable, while
   section labels remain quiet. */
body[data-page="setup"] .setup-status,
body[data-page="setup"] .setup-form-help,
body[data-page="setup"] .setup-mini-note,
body[data-page="setup"] .setup-state-note,
body[data-page="setup"] .setup-expense-group-note,
body[data-page="setup"] .setup-expense-item-meta,
body[data-page="setup"] .setup-expense-empty,
body[data-page="setup"] .setup-debt-meta,
body[data-page="setup"] .setup-optional,
body[data-page="setup"] .setup-checkbox-row,
body[data-page="setup"] .setup-inline-pill {
  color: var(--ds-helper-text);
}
body[data-page="setup"] .setup-debt-title,
body[data-page="setup"] .setup-expense-group-title,
body[data-page="setup"] .setup-expense-item-title,
body[data-page="setup"] .setup-drawer-title {
  color: var(--ds-primary-text);
}
body[data-page="setup"] .setup-rent-guidance,
body[data-page="setup"] .setup-expense-placeholder {
  color: #5F400F;
  background: var(--ds-warning-wash);
  border-color: rgba(184,125,26,.24);
}
body[data-page="setup"] .setup-expense-group-head,
body[data-page="setup"] .setup-expense-list-head,
body[data-page="setup"] .setup-edit-panel {
  background: #FCFAF6;
}

/* Reports: make saved report labels and empty states easier to read. */
body[data-page="reports"] #rpt-viewer,
body[data-page="reports"] #rpt-list,
body[data-page="reports"] .ds-card-body,
body[data-page="reports"] .ds-card-body div[style*="color:#7A8899"],
body[data-page="reports"] .ds-card-body div[style*="color: #7A8899"] {
  color: var(--ds-body-text) !important;
}
body[data-page="reports"] #rpt-viewer .ds-lora,
body[data-page="reports"] .ds-card-body .ds-lora {
  color: var(--ds-primary-text) !important;
}
body[data-page="reports"] iframe {
  background: #fff;
}

/* ── MAY11-04 Layer 3 mobile/responsive QA hardening ───────────
   Keeps the approved v2 visual language while making the six
   user-facing pages safer at phone and tablet widths. */
html,
body {
  max-width: 100%;
  overflow-x: hidden;
}
#ds-content,
.ds-band,
.ds-page-header,
.ds-columns,
.ds-card,
.ds-card-head,
.ds-card-body,
.ds-stat-strip,
.ds-quality-strip,
.ds-dt-row,
.ds-dt-detail,
.ds-note {
  min-width: 0;
}
.ds-card-body,
.ds-note-text,
.ds-insight-text,
.ds-page-sub,
.ds-dt-name,
.ds-dt-detail-val,
.ds-dt-detail-sub {
  overflow-wrap: anywhere;
}
.ds-card-head,
.ds-page-header,
.ds-cta-row,
.ds-stat-pills,
.ds-cal-legend {
  max-width: 100%;
}
.ds-card-head {
  flex-wrap: wrap;
}
.ds-btn,
.ds-cta-primary,
.ds-cta-secondary,
.ds-filter-btn,
button,
input,
select,
textarea {
  max-width: 100%;
}
.ds-btn,
.ds-cta-primary,
.ds-cta-secondary {
  min-height: 36px;
}
.ds-dt-detail-grid > div,
.ds-quality-cell,
.ds-stat-cell {
  min-width: 0;
}
.ds-dt-detail div[style*="display:flex"] {
  flex-wrap: wrap !important;
}

/* Sticky Ask bar: mobile-safe collapsed handle and scrollable panel. */
body[data-page="dashboard"],
body[data-page="scenarios"],
body[data-page="setup"],
body[data-page="reports"] {
  padding-bottom: 72px !important;
}
#ai-sticky-bar {
  max-height: 78vh !important;
  overflow: hidden !important;
}
#ai-bar-panel {
  max-height: calc(78vh - 48px) !important;
  overflow: auto !important;
}
#chat-history {
  max-height: min(240px, 30vh) !important;
}
#chat-prompts {
  max-width: 100% !important;
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch;
}
#chat-prompts button {
  flex: 0 0 auto !important;
}
#chat-input {
  min-width: 0 !important;
}

@media (max-width: 1180px) {
  body[data-page="dashboard"] .ds-dashboard-cockpit,
  body[data-page="scenarios"] .sc-lab-grid,
  body[data-page="calendar"] .cal-cockpit {
    width: 100% !important;
    max-width: 100% !important;
  }
  body[data-page="dashboard"] .ds-dashboard-left,
  body[data-page="dashboard"] .ds-dashboard-right,
  body[data-page="scenarios"] .sc-left-rail,
  body[data-page="scenarios"] .sc-right-rail,
  body[data-page="calendar"] .cal-left-rail,
  body[data-page="calendar"] .cal-right-rail {
    min-width: 0 !important;
  }
}

@media (max-width: 900px) {
  .ds-page-header {
    padding: 16px !important;
  }
  .ds-page-header > div {
    min-width: 0 !important;
  }
  .ds-page-header > div:last-child {
    width: 100% !important;
    justify-content: flex-start !important;
    flex-wrap: wrap !important;
  }
  .ds-page-header .ds-btn {
    flex: 1 1 150px;
    justify-content: center;
  }
  .ds-band-greet-row {
    align-items: flex-start !important;
  }
  .ds-stat-pills {
    width: 100%;
  }
  .ds-stat-pill {
    flex: 1 1 136px;
    text-align: left;
  }
  .ds-columns {
    grid-template-columns: 1fr !important;
  }
  body[data-page="reports"] .ds-columns {
    grid-template-columns: 1fr !important;
  }
  body[data-page="reports"] #rpt-list {
    max-height: 260px !important;
  }
  body[data-page="reports"] #rpt-viewer {
    padding: 22px 16px !important;
  }
  body[data-page="setup"] .setup-progress-head {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 12px !important;
  }
  body[data-page="setup"] .setup-progress-head .ds-btn {
    width: 100% !important;
    justify-content: center !important;
  }
}

@media (max-width: 760px) {
  .ds-page-title {
    font-size: 20px !important;
    line-height: 1.25 !important;
  }
  .ds-page-sub {
    line-height: 1.6 !important;
  }
  .ds-band {
    padding: 20px 16px 18px !important;
  }
  .ds-band-name {
    font-size: 19px !important;
  }
  .ds-analysis-text {
    font-size: 12px !important;
    line-height: 1.72 !important;
  }
  .ds-columns {
    padding: 14px 12px 96px !important;
  }
  body[data-page="dashboard"] .ds-dashboard-cockpit,
  body[data-page="scenarios"] .sc-lab-grid,
  body[data-page="calendar"] .cal-cockpit {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  body[data-page="dashboard"] .ds-dashboard-left,
  body[data-page="dashboard"] .ds-dashboard-right,
  body[data-page="scenarios"] .sc-left-rail,
  body[data-page="scenarios"] .sc-right-rail,
  body[data-page="calendar"] .cal-left-rail,
  body[data-page="calendar"] .cal-right-rail {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
  }
  body[data-page="dashboard"] .ds-dashboard-story-text {
    max-width: 100% !important;
    font-size: 12.5px !important;
  }

  /* Debt rows become a compact mobile card: name + balance + toggle. */
  body[data-page="dashboard"] .ds-dt-head,
  body[data-page="debt-overview"] .ds-dt-head {
    display: none !important;
  }
  body[data-page="dashboard"] .ds-dt-row,
  body[data-page="debt-overview"] .ds-dt-row {
    grid-template-columns: 4px minmax(0,1fr) auto 24px !important;
    gap: 8px !important;
    padding: 12px 14px !important;
  }
  body[data-page="dashboard"] .ds-dt-apr,
  body[data-page="dashboard"] .ds-dt-int,
  body[data-page="debt-overview"] .ds-dt-apr,
  body[data-page="debt-overview"] .ds-dt-int {
    display: none !important;
  }
  body[data-page="dashboard"] .ds-dt-bal,
  body[data-page="debt-overview"] .ds-dt-bal {
    grid-column: 3 !important;
    grid-row: 1 !important;
    white-space: nowrap !important;
    align-self: start !important;
  }
  body[data-page="dashboard"] .ds-dt-toggle,
  body[data-page="debt-overview"] .ds-dt-toggle {
    grid-column: 4 !important;
    grid-row: 1 !important;
    align-self: start !important;
  }
  .ds-dt-detail {
    padding: 13px 14px 14px 22px !important;
  }
  .ds-dt-detail-grid {
    grid-template-columns: 1fr !important;
  }

  body[data-page="scenarios"] .sc-chart-wrap,
  body[data-page="scenarios"] .sc-allocation-panel,
  body[data-page="scenarios"] .sc-right-rail {
    grid-column: 1 !important;
  }
  body[data-page="scenarios"] #sc-chart-scroll {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
  }
  body[data-page="scenarios"] #sc-chart {
    height: 360px !important;
    max-width: none !important;
  }
  body[data-page="scenarios"] .sc-allocation-strip {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  body[data-page="scenarios"] .sc-allocation-slider {
    grid-template-columns: minmax(0,1fr) 44px !important;
  }
  body[data-page="scenarios"] .sc-split-name {
    white-space: normal !important;
  }

  body[data-page="calendar"] .cal-calendar-surface {
    padding: 8px !important;
    border-radius: 12px !important;
  }
  body[data-page="calendar"] .cal-month-grid .ds-cal-day {
    min-height: 48px !important;
    padding: 5px !important;
  }
  body[data-page="calendar"] .cal-day-num {
    width: 18px !important;
    height: 18px !important;
    font-size: 10px !important;
  }
  body[data-page="calendar"] .cal-action-row .ds-btn {
    flex: 1 1 145px !important;
  }
  body[data-page="calendar"] #ds-content > div[style*="padding:0 20px"],
  body[data-page="reports"] #ds-content > div[style*="padding:0 20px"] {
    padding: 0 12px !important;
  }
  body[data-page="calendar"] .ds-note,
  body[data-page="reports"] .ds-note {
    margin: 0 0 96px !important;
  }

  body[data-page="setup"] .setup-debt-row,
  body[data-page="setup"] .setup-expense-item {
    grid-template-columns: 4px minmax(0,1fr) !important;
  }
  body[data-page="setup"] .setup-debt-actions,
  body[data-page="setup"] .setup-expense-item > div:last-child {
    grid-column: 2 !important;
    justify-content: flex-start !important;
  }
  body[data-page="setup"] .setup-expense-group-head,
  body[data-page="setup"] .setup-expense-list-head,
  body[data-page="setup"] .setup-undo-row {
    flex-direction: column !important;
    align-items: flex-start !important;
  }
  body[data-page="setup"] .setup-drawer {
    width: 100vw !important;
  }
  body[data-page="setup"] .setup-drawer-head {
    padding: 18px 16px 14px !important;
  }
  body[data-page="setup"] .setup-drawer-title {
    font-size: 22px !important;
  }
  body[data-page="setup"] .setup-drawer-body {
    padding: 16px 16px 96px !important;
  }
  body[data-page="setup"] .setup-drawer-foot {
    padding: 12px 16px !important;
  }
  body[data-page="setup"] .setup-drawer-foot .ds-btn {
    flex: 1 1 130px !important;
    justify-content: center !important;
  }

  body[data-page="reports"] .ds-columns {
    padding-bottom: 96px !important;
  }
  body[data-page="reports"] .ds-page-header > div:last-child .ds-btn {
    width: 100% !important;
  }

  #ai-sticky-bar {
    max-height: 82vh !important;
  }
  #ai-bar-handle {
    min-height: 46px !important;
    padding: 10px 12px !important;
    gap: 8px !important;
  }
  #ai-bar-idle-hint {
    display: none !important;
  }
  #ai-bar-panel {
    max-height: calc(82vh - 46px) !important;
  }
  #chat-history {
    max-height: 26vh !important;
    padding: 10px 12px !important;
  }
  #chat-prompts {
    padding: 8px 12px 4px !important;
    flex-wrap: nowrap !important;
  }
  #ai-bar-panel > div[style*="align-items:flex-end"] {
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding: 10px 12px !important;
  }
  #chat-input {
    flex: 1 1 100% !important;
    width: 100% !important;
  }
  #chat-btn {
    flex: 1 1 120px !important;
  }
}

@media (max-width: 520px) {
  .ds-form-row,
  .ds-form-row.triple {
    grid-template-columns: 1fr !important;
  }
  .ds-stat-strip,
  .ds-quality-strip {
    grid-template-columns: 1fr !important;
  }
  .ds-stat-cell,
  .ds-quality-cell {
    border-right: 0 !important;
    border-bottom: 1px solid var(--ds-border) !important;
  }
  .ds-stat-cell:last-child,
  .ds-quality-cell:last-child {
    border-bottom: 0 !important;
  }
  body[data-page="dashboard"] .ds-dt-row,
  body[data-page="debt-overview"] .ds-dt-row {
    grid-template-columns: 4px minmax(0,1fr) 24px !important;
  }
  body[data-page="dashboard"] .ds-dt-bal,
  body[data-page="debt-overview"] .ds-dt-bal {
    grid-column: 2 !important;
    grid-row: 2 !important;
    text-align: left !important;
    margin-top: 4px !important;
  }
  body[data-page="dashboard"] .ds-dt-toggle,
  body[data-page="debt-overview"] .ds-dt-toggle {
    grid-column: 3 !important;
  }
  body[data-page="calendar"] .cal-week-grid .ds-cal-dhdr {
    font-size: 9px !important;
    padding-left: 2px !important;
    padding-right: 2px !important;
    text-align: center !important;
  }
  body[data-page="calendar"] .cal-month-grid .ds-cal-day {
    min-height: 42px !important;
  }
  body[data-page="calendar"] .cal-event-chip span:last-child {
    display: none !important;
  }
}


/* ── MAY11-05 mobile responsive follow-up ─────────────────────
   Narrow correction pass based on live Firefox Responsive Design
   Mode screenshots. This only addresses visible phone/tablet layout
   issues and avoids backend or interaction rewiring. */

body[data-page] #ds-content {
  width: 100%;
  max-width: 100%;
}

/* Reports: never allow the private report viewer to remain a skinny
   desktop side rail on phone/tablet widths. */
body[data-page="reports"] .rpt-layout {
  display: grid;
  grid-template-columns: minmax(250px, 300px) minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}
body[data-page="reports"] .rpt-layout > div,
body[data-page="reports"] .rpt-layout > .ds-card,
body[data-page="reports"] #rpt-viewer,
body[data-page="reports"] #rpt-list {
  min-width: 0;
  width: 100%;
  max-width: 100%;
}
body[data-page="reports"] #rpt-viewer {
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none;
}
body[data-page="reports"] #rpt-viewer iframe {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
}

/* Calendar: make the month controls read like one mobile control group
   instead of wrapping into an orphaned “Viewing” label. */
body[data-page="calendar"] .cal-month-nav {
  min-width: 0;
}
body[data-page="calendar"] .cal-month-nav .ds-stat-pill {
  min-width: 0 !important;
}

/* Debt Overview: the headline should own the first row on mobile; the
   stat pills move below it instead of squeezing the intro column. */
body[data-page="debt-overview"] .do-hero-stats {
  min-width: 0;
}
body[data-page="debt-overview"] .do-hero-stats .ds-stat-pill {
  min-width: 0;
}

/* Setup: prevent long debt/expense metadata from stretching cards. */
body[data-page="setup"] .setup-debt-row,
body[data-page="setup"] .setup-expense-item,
body[data-page="setup"] .setup-debt-meta,
body[data-page="setup"] .setup-expense-item-meta,
body[data-page="setup"] .setup-checkbox-row,
body[data-page="setup"] .setup-rent-guidance,
body[data-page="setup"] .setup-expense-placeholder {
  min-width: 0;
  max-width: 100%;
  overflow-wrap: anywhere;
}
body[data-page="setup"] .setup-debt-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

@media (max-width: 900px) {
  body[data-page="reports"] .rpt-layout {
    grid-template-columns: 1fr !important;
    padding: 14px 12px 96px !important;
  }
  body[data-page="reports"] #rpt-list {
    max-height: 340px !important;
  }
  body[data-page="reports"] #rpt-viewer {
    min-height: 220px;
    padding: 22px 18px !important;
    text-align: center;
  }
  body[data-page="reports"] #rpt-viewer iframe {
    height: min(640px, 72vh) !important;
  }

  body[data-page="debt-overview"] .ds-page-header {
    display: block !important;
  }
  body[data-page="debt-overview"] .ds-page-header > div:first-child {
    width: 100% !important;
    max-width: 100% !important;
  }
  body[data-page="debt-overview"] .do-hero-stats {
    width: 100% !important;
    margin-top: 14px;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    justify-content: stretch !important;
  }
  body[data-page="debt-overview"] .do-hero-stats .ds-stat-pill {
    width: 100% !important;
    flex: none !important;
  }
}

@media (max-width: 760px) {
  /* Calendar month nav: label first, Prev/Next underneath. */
  body[data-page="calendar"] .cal-month-nav {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px !important;
    justify-content: stretch !important;
    align-items: stretch !important;
  }
  body[data-page="calendar"] .cal-month-nav .ds-stat-pill {
    grid-column: 1 / -1;
    order: -1;
    text-align: center !important;
    padding: 8px 10px;
  }
  body[data-page="calendar"] .cal-month-nav .ds-btn {
    width: 100%;
    justify-content: center;
  }
  body[data-page="calendar"] #cal-month-label {
    white-space: normal;
    line-height: 1.2;
  }

  /* Calendar grid should remain readable but not dominate the phone page. */
  body[data-page="calendar"] .cal-calendar-card .ds-card-head > div:first-child,
  body[data-page="calendar"] #cal-month-summary {
    min-width: 0;
    max-width: 100%;
  }
  body[data-page="calendar"] #cal-month-summary {
    flex-wrap: wrap;
    row-gap: 2px;
  }
  body[data-page="calendar"] .cal-month-grid .ds-cal-day {
    min-height: 44px !important;
    padding: 5px !important;
  }
  body[data-page="calendar"] .cal-cal-sub,
  body[data-page="calendar"] .cal-day-meta,
  body[data-page="calendar"] .cal-empty-day {
    overflow-wrap: anywhere;
  }

  /* Scenario Lab: phone chart stays scrollable but less vertically heavy. */
  body[data-page="scenarios"] #sc-chart {
    height: 300px !important;
  }
  body[data-page="scenarios"] .sc-chart-panel .ds-card-body,
  body[data-page="scenarios"] #sc-chart-scroll {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  body[data-page="scenarios"] .sc-allocation-strip {
    grid-template-columns: 1fr !important;
  }
  body[data-page="scenarios"] .sc-impact-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* Setup: tighten form cards without shrinking the actual input fields. */
  body[data-page="setup"] .ds-columns {
    grid-template-columns: 1fr !important;
    padding: 14px 10px 96px !important;
  }
  body[data-page="setup"] .setup-progress-head {
    align-items: stretch !important;
  }
  body[data-page="setup"] .setup-progress-head > div:first-child,
  body[data-page="setup"] .setup-debt-row > div,
  body[data-page="setup"] .setup-expense-item > div {
    min-width: 0;
  }
  body[data-page="setup"] .setup-debt-meta,
  body[data-page="setup"] .setup-expense-item-meta {
    line-height: 1.55;
  }
  body[data-page="setup"] .setup-debt-actions .ds-btn,
  body[data-page="setup"] .setup-expense-item .ds-btn {
    flex: 1 1 78px;
    justify-content: center;
  }
  body[data-page="setup"] .setup-drawer {
    max-width: 100vw !important;
  }
}

@media (max-width: 520px) {
  body[data-page="debt-overview"] .do-hero-stats {
    grid-template-columns: 1fr 1fr;
  }
  body[data-page="debt-overview"] .do-hero-stats .ds-stat-pill {
    padding: 8px 10px;
  }
  body[data-page="debt-overview"] .do-hero-stats .ds-stat-pill-label {
    font-size: 8.5px;
  }
  body[data-page="debt-overview"] .do-hero-stats .ds-stat-pill-val {
    font-size: 13px;
  }
  body[data-page="calendar"] .cal-month-grid .ds-cal-day {
    min-height: 40px !important;
  }
  body[data-page="reports"] #rpt-viewer {
    padding: 20px 14px !important;
  }
}

@media (max-width: 360px) {
  body[data-page="debt-overview"] .do-hero-stats {
    grid-template-columns: 1fr;
  }
}

/* ── MAY11-06 mobile responsive follow-up ─────────────────────
   Narrow correction pass after live Firefox Responsive Design Mode
   screenshots: calendar month label, Debt Overview header stacking,
   Setup mobile debt cards, and Reports mobile viewer sizing. */

/* Calendar: show the actual month in the top navigation instead of a
   label-only stat pill on white headers. */
body[data-page="calendar"] .cal-month-nav {
  min-width: 0;
}
body[data-page="calendar"] .cal-current-month {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 128px;
  min-height: 36px;
  padding: 8px 14px;
  border: 1px solid var(--ds-border);
  border-radius: 8px;
  background: #fff;
  color: var(--ds-navy);
  font-family: Lora, serif;
  font-size: 15px;
  line-height: 1.15;
  white-space: nowrap;
}
body[data-page="calendar"] #cal-month-label {
  color: var(--ds-navy) !important;
}

/* Debt Overview: force the mobile header to read as intro, stats, actions.
   This avoids the title and stat pills sharing the same cramped row. */
@media (max-width: 900px) {
  body[data-page="debt-overview"] #ds-content > .ds-page-header {
    display: grid !important;
    grid-template-columns: 1fr !important;
    align-items: stretch !important;
    gap: 14px !important;
  }
  body[data-page="debt-overview"] #ds-content > .ds-page-header > div {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    flex: none !important;
  }
  body[data-page="debt-overview"] .do-hero-stats {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin-top: 0 !important;
    justify-content: stretch !important;
  }
  body[data-page="debt-overview"] .do-hero-stats .ds-stat-pill {
    width: 100% !important;
    min-width: 0 !important;
    padding: 9px 10px !important;
    text-align: left !important;
  }
  body[data-page="debt-overview"] .do-header-actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }
  body[data-page="debt-overview"] .do-header-actions .ds-btn {
    width: 100% !important;
    justify-content: center !important;
  }
}
@media (max-width: 360px) {
  body[data-page="debt-overview"] .do-hero-stats,
  body[data-page="debt-overview"] .do-header-actions {
    grid-template-columns: 1fr !important;
  }
}

/* Setup: keep debt rows compact on desktop but turn them into readable
   mobile mini-cards with stacked facts and actions underneath. */
body[data-page="setup"] .setup-debt-card {
  min-width: 0;
}
body[data-page="setup"] .setup-debt-bar {
  width: 4px;
  height: 42px;
  border-radius: 999px;
  align-self: stretch;
  min-height: 42px;
}
body[data-page="setup"] .setup-debt-info {
  min-width: 0;
}
body[data-page="setup"] .setup-debt-facts {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 10px;
  margin-top: 5px;
  font-size: 10.5px;
  line-height: 1.45;
  color: var(--ds-helper-text);
}
body[data-page="setup"] .setup-debt-facts span {
  min-width: 0;
  max-width: 100%;
  overflow-wrap: anywhere;
}
body[data-page="setup"] .setup-debt-facts b {
  display: inline-block;
  margin-right: 4px;
  color: var(--ds-tertiary-text);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
}
@media (max-width: 760px) {
  body[data-page="setup"] .setup-debt-card {
    grid-template-columns: 4px minmax(0, 1fr) !important;
    align-items: start !important;
    padding: 12px 14px !important;
    gap: 10px !important;
    background: #fff;
  }
  body[data-page="setup"] .setup-debt-card .setup-debt-actions {
    grid-column: 2 !important;
    width: 100% !important;
    justify-content: stretch !important;
    margin-top: 8px;
  }
  body[data-page="setup"] .setup-debt-card .setup-debt-actions .ds-btn {
    flex: 1 1 120px !important;
    min-height: 34px !important;
    justify-content: center !important;
  }
  body[data-page="setup"] .setup-debt-title {
    font-size: 12.5px !important;
    line-height: 1.35 !important;
  }
  body[data-page="setup"] .setup-debt-facts {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px 10px;
  }
  body[data-page="setup"] .setup-debt-facts span {
    border: 1px solid var(--ds-border);
    border-radius: 8px;
    background: #FAFAF7;
    padding: 6px 7px;
  }
}
@media (max-width: 420px) {
  body[data-page="setup"] .setup-debt-facts {
    grid-template-columns: 1fr !important;
  }
}

/* Reports: remove the oversized empty viewer on mobile and give selected
   PDF previews a controlled, scrollable phone viewport. */
body[data-page="reports"] .rpt-layout > div:nth-child(2) > .ds-card {
  min-width: 0;
}
@media (max-width: 900px) {
  body[data-page="reports"] .rpt-layout > div:nth-child(2) > .ds-card {
    min-height: 0 !important;
  }
  body[data-page="reports"] #rpt-viewer {
    min-height: 220px !important;
  }
  body[data-page="reports"] #rpt-viewer img {
    width: 64px !important;
    height: 64px !important;
  }
  body[data-page="reports"] #rpt-viewer iframe {
    height: min(560px, 62vh) !important;
    overflow: auto;
  }
}
@media (max-width: 760px) {
  body[data-page="calendar"] .cal-month-nav {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    width: 100% !important;
  }
  body[data-page="calendar"] .cal-current-month {
    grid-column: 1 / -1;
    order: -1;
    width: 100%;
    min-width: 0;
  }
  body[data-page="calendar"] .cal-month-nav .ds-btn {
    width: 100%;
    justify-content: center;
  }
}
body[data-page="reports"] #rpt-viewer.has-report-preview {
  padding: 0 !important;
  text-align: left !important;
  overflow: hidden;
}
body[data-page="reports"] #rpt-viewer.has-report-preview iframe {
  display: block;
}

/* ── Layer 5 launch-readiness states ──────────────────────────
   Shared empty/error/loading surfaces used when a page cannot get data,
   permission is missing, or a service temporarily fails. */
.mdl-state-card {
  width: min(520px, calc(100vw - 40px));
  margin: 72px auto;
  padding: 26px 24px;
  border: 1px solid var(--ds-border);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 16px 40px rgba(13, 30, 48, 0.06);
  text-align: center;
}
.mdl-state-eyebrow {
  margin: 0 0 8px;
  color: var(--ds-muted);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.mdl-state-title {
  margin: 0 0 10px;
  color: var(--ds-navy);
  font-family: Lora, serif;
  font-size: 23px;
  font-weight: 400;
  line-height: 1.25;
}
.mdl-state-body {
  margin: 0 auto 18px;
  max-width: 430px;
  color: var(--ds-muted);
  font-size: 13px;
  line-height: 1.7;
}
.mdl-state-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 18px;
}
.mdl-state-card.is-error {
  border-color: rgba(176,58,58,.22);
  background: linear-gradient(180deg,#fff 0%,#fffafa 100%);
}
.mdl-state-card.is-error .mdl-state-eyebrow,
.mdl-state-card.is-error .mdl-state-title { color: var(--ds-red); }
.mdl-state-card.is-locked {
  border-color: rgba(184,125,26,.24);
  background: linear-gradient(180deg,#fff 0%,#fffaf0 100%);
}
.mdl-state-card.is-locked .mdl-state-eyebrow,
.mdl-state-card.is-locked .mdl-state-title { color: var(--ds-amber); }
.mdl-inline-launch-status {
  display: none;
  margin: 10px 0 0;
  padding: 10px 12px;
  border: 1px solid var(--ds-border);
  border-radius: 10px;
  background: #fff;
  color: var(--ds-muted);
  font-size: 12px;
  line-height: 1.55;
}
.mdl-inline-launch-status.is-visible { display: block; }
.mdl-inline-launch-status.is-error {
  border-color: rgba(176,58,58,.26);
  background: rgba(176,58,58,.06);
  color: #8E2E2E;
}
.mdl-inline-launch-status.is-ok {
  border-color: rgba(29,143,106,.25);
  background: rgba(29,143,106,.08);
  color: #14674E;
}
@media (max-width: 760px) {
  .mdl-state-card {
    width: calc(100vw - 24px);
    margin: 46px auto;
    padding: 22px 18px;
  }
  .mdl-state-title { font-size: 21px; }
  .mdl-state-actions .ds-btn { width: 100%; justify-content: center; }
}
