/* ============================================================
   Dashboard (shared role-aware home) page.
   Structure in @layer layout, paint in @layer design. Content-named
   classes only — no legacy/appearance names, no hardcoded color.
   Reuses .app-screen and .btn/.btn--outline/.btn--primary/.btn--block
   from elements.css.

   SHARED page: every desk role (system_admin / prosecutor /
   senior_prosecutor / recovery_coach / case_manager / officer, light)
   and participants (citizen dark) render their own branch of this same
   class vocabulary. This stylesheet only references --t-* semantic
   tokens, which app/theme.css rebinds per theme, so the page reskins
   without any role-specific color rules here. The donut/trend/caseload
   chart sizes and the progress-meter width are written via CSSOM from
   data (the documented dynamic exception); everything else is a class.
   See docs/FRONTEND-ARCHITECTURE.md.
   ============================================================ */

@layer layout {
  /* Page intro — heading + subtitle. */
  .dashboard__intro { display: grid; gap: var(--mea-space-1); }

  /* ── Participant: program progress meter ── */
  .program-progress { display: grid; gap: var(--mea-space-4);
                      padding: var(--mea-space-5); border-radius: var(--mea-radius-2xl); }
  .program-progress__header { display: flex; flex-wrap: wrap; align-items: flex-start;
                              justify-content: space-between; gap: var(--mea-space-3); }
  .program-progress__headline { display: grid; gap: var(--mea-space-1); }
  .program-progress__caption, .program-progress__pct,
  .program-progress__deadline, .program-progress__counts { margin: 0; }
  .program-progress__track { block-size: var(--mea-space-2); border-radius: var(--mea-radius-pill);
                             overflow: hidden; }
  .program-progress__fill { block-size: 100%; inline-size: 0; border-radius: var(--mea-radius-pill);
                            transition: inline-size var(--mea-dur-smooth, var(--mea-dur-normal)); }
  .program-progress__counts { display: flex; justify-content: space-between; gap: var(--mea-space-3); }

  /* ── Participant: active task timer ── */
  .active-timer { display: grid; grid-template-columns: auto 1fr auto; align-items: center;
                  gap: var(--mea-space-3); padding: var(--mea-space-4);
                  border-radius: var(--mea-radius-xl); }
  .active-timer__pulse { inline-size: .75rem; block-size: .75rem; border-radius: var(--mea-radius-circle); }
  .active-timer__info { display: grid; gap: var(--mea-space-1); min-inline-size: 0; }
  .active-timer__label, .active-timer__task, .active-timer__provider,
  .active-timer__value, .active-timer__elapsed { margin: 0; }
  .active-timer__readout { display: grid; gap: var(--mea-space-1); justify-items: end; text-align: end; }

  /* ── Generic block: header + a list ── */
  .dashboard-block { display: grid; gap: var(--mea-space-3); }
  .dashboard-block__header { display: flex; flex-wrap: wrap; align-items: center;
                             justify-content: space-between; gap: var(--mea-space-2); }
  .dashboard-block__title, .dashboard-block__link { margin: 0; }
  .dashboard-block__link { text-decoration: none; }

  /* ── Participant: upcoming task list ── */
  .upcoming-list { display: flex; gap: var(--mea-space-3); margin: 0; padding: 0; list-style: none;
                   overflow-x: auto; scroll-snap-type: x proximity; }
  .upcoming-list__empty { margin: 0; padding: var(--mea-space-4); }
  .upcoming-task { flex: 0 0 auto; inline-size: 11rem; display: grid; gap: var(--mea-space-2);
                  align-content: start; padding: var(--mea-space-4); border-radius: var(--mea-radius-xl);
                  scroll-snap-align: start; }
  .upcoming-task__icon { font-size: var(--mea-text-xl); line-height: 1; }
  .upcoming-task__title, .upcoming-task__date { margin: 0; }

  /* ── Participant: quick actions ── */
  .dashboard-actions { display: grid; gap: var(--mea-space-3);
                       padding: var(--mea-space-5); border-radius: var(--mea-radius-xl); }
  .dashboard-actions__header { display: grid; gap: var(--mea-space-1); }
  .dashboard-actions__title { margin: 0; }
  .dashboard-actions__list { display: grid; gap: var(--mea-space-3); margin: 0; padding: 0; list-style: none; }

  /* ── Officer: profile header ── */
  .officer-profile { display: grid; grid-template-columns: auto 1fr auto; align-items: center;
                     gap: var(--mea-space-4); padding: var(--mea-space-5);
                     border-radius: var(--mea-radius-xl); }
  .officer-profile__avatar { display: inline-flex; align-items: center; justify-content: center;
                             inline-size: 3rem; block-size: 3rem; border-radius: var(--mea-radius-circle); }
  .officer-profile__info { display: grid; gap: var(--mea-space-1); min-inline-size: 0; }
  .officer-profile__name, .officer-profile__badge { margin: 0; }
  .officer-profile__actions { display: flex; align-items: center; gap: var(--mea-space-2); }
  .officer-profile__search { display: inline-flex; align-items: center; justify-content: center;
                             min-height: var(--t-target-min, 44px); inline-size: var(--t-target-min, 44px);
                             border: 0; border-radius: var(--mea-radius-circle); cursor: pointer; }
  @container (max-width: 30rem) {
    .officer-profile { grid-template-columns: auto 1fr; }
    .officer-profile__actions { grid-column: 1 / -1; justify-content: flex-end; }
  }

  /* ── Metric figures row (desk stats) ── */
  .metric-row { display: grid; gap: var(--mea-space-4);
                grid-template-columns: repeat(2, minmax(0, 1fr)); }
  @container (min-width: 48rem) {
    .metric-row--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .metric-row--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  }
  @container (max-width: 30rem) { .metric-row { grid-template-columns: 1fr; } }

  .metric { display: grid; gap: var(--mea-space-1); align-content: start;
            padding: var(--mea-space-4); border-radius: var(--mea-radius-xl); }
  .metric--clickable { cursor: pointer;
                       transition: box-shadow var(--mea-dur-fast), transform var(--mea-dur-fast); }
  .metric__label, .metric__value, .metric__sub { margin: 0; }

  /* ── Panels (cards with a header + body) ── */
  .dashboard-panel { display: grid; align-content: start; border-radius: var(--mea-radius-xl);
                     overflow: hidden; }
  .dashboard-panel__header { display: flex; flex-wrap: wrap; align-items: center;
                             justify-content: space-between; gap: var(--mea-space-2);
                             padding: var(--mea-space-4) var(--mea-space-5); }
  .dashboard-panel__title, .dashboard-panel__meta { margin: 0; }
  .dashboard-panel__body { padding: var(--mea-space-5); }
  .dashboard-panel__body--flush { padding: 0; }
  .dashboard-panel__body--centered { display: grid; justify-items: center; gap: var(--mea-space-4); }
  .dashboard-panel__empty { margin: 0; padding: var(--mea-space-2) 0; }

  /* Two-column desk layout that stacks when narrow. */
  .dashboard-columns { display: grid; gap: var(--mea-space-6);
                       grid-template-columns: 1fr; align-items: start; }
  .dashboard-columns__col { display: grid; gap: var(--mea-space-6); align-content: start; }
  @container (min-width: 52rem) {
    .dashboard-columns { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  }

  /* ── Panel empty state ── */
  .panel-empty { display: grid; gap: var(--mea-space-2); justify-items: center; text-align: center;
                 padding: var(--mea-space-8) var(--mea-space-4); }
  .panel-empty__icon, .panel-empty__title { margin: 0; }

  /* ── Case table ── */
  .case-table { inline-size: 100%; border-collapse: collapse; }
  .case-table th, .case-table td { padding: var(--mea-space-3) var(--mea-space-5);
                                   text-align: start; vertical-align: middle; }
  .case-table__row { cursor: pointer; }

  .person-cell { display: flex; align-items: center; gap: var(--mea-space-3); min-inline-size: 0; }
  .person-cell__avatar { display: inline-flex; align-items: center; justify-content: center;
                         flex: 0 0 auto; inline-size: 2.25rem; block-size: 2.25rem;
                         border-radius: var(--mea-radius-circle); }
  .person-cell__detail { display: grid; gap: var(--mea-space-1); min-inline-size: 0; }
  .person-cell__name, .person-cell__sub { margin: 0; }

  /* ── Officer: grouped issue list ── */
  .issue-group__heading { margin: 0; padding: var(--mea-space-3) var(--mea-space-5) var(--mea-space-1); }
  .issue-list { display: grid; margin: 0; padding: 0; list-style: none; }
  .issue-row { display: grid; grid-template-columns: 1fr auto; align-items: center;
               gap: var(--mea-space-3); padding: var(--mea-space-3) var(--mea-space-5); cursor: pointer; }
  .issue-row__main { display: grid; gap: var(--mea-space-1); min-inline-size: 0; }
  .issue-row__name, .issue-row__detail { margin: 0; }

  /* ── Prosecutor: court tabs + info ── */
  .court-tabs { display: flex; flex-wrap: wrap; gap: var(--mea-space-2);
                margin-block-end: var(--mea-space-4); }
  .court-tab { display: inline-flex; align-items: center; min-height: var(--t-target-min, 44px);
               padding: var(--mea-space-2) var(--mea-space-4); border: 0;
               border-radius: var(--mea-radius-pill); cursor: pointer; white-space: nowrap; }
  .court-info { display: flex; flex-wrap: wrap; gap: var(--mea-space-5); margin: 0; }
  .court-info__pair { display: flex; align-items: baseline; gap: var(--mea-space-2); }
  .court-info__label, .court-info__value { margin: 0; }

  /* ── Charts: donut ── */
  .chart-donut { position: relative; display: grid; place-items: center; margin: 0; }
  .chart-donut svg { transform: rotate(-90deg); }
  .chart-donut__center { position: absolute; display: grid; gap: var(--mea-space-1);
                         justify-items: center; text-align: center; }
  .chart-donut__value, .chart-donut__label { margin: 0; }

  .chart-legend { display: grid; gap: var(--mea-space-2); inline-size: 100%;
                  margin: 0; padding: 0; list-style: none; }
  .chart-legend__item { display: flex; align-items: center; gap: var(--mea-space-2); }
  .chart-legend__item--wide { inline-size: 100%; }
  .chart-legend__dot { flex: 0 0 auto; inline-size: .75rem; block-size: .75rem;
                       border-radius: var(--mea-radius-circle); }
  .chart-legend__label { min-inline-size: 0; }
  .chart-legend__label--grow { flex: 1; }
  .chart-legend__value { margin-inline-start: auto; }

  /* ── Charts: 7-day trend bars ── */
  .trend-chart { display: flex; align-items: flex-end; gap: var(--mea-space-3); }
  .trend-chart__col { flex: 1; display: grid; gap: var(--mea-space-2); justify-items: center; align-content: end; }
  .trend-bar { display: flex; flex-direction: column; inline-size: 100%;
               border-radius: var(--mea-radius-sm); overflow: hidden; }
  .trend-bar__seg { inline-size: 100%; }
  .trend-chart__label { margin: 0; }
  .trend-legend { display: flex; flex-wrap: wrap; gap: var(--mea-space-4);
                  margin: var(--mea-space-3) 0 0; padding: 0; list-style: none; }
  .trend-legend__item { display: inline-flex; align-items: center; gap: var(--mea-space-2); }

  /* ── Charts: caseload bars ── */
  .caseload-chart { display: grid; gap: var(--mea-space-3); margin: 0; padding: var(--mea-space-5);
                    list-style: none; }
  .caseload-bar { display: grid; grid-template-columns: 8rem 1fr auto; align-items: center;
                  gap: var(--mea-space-3); }
  .caseload-bar__label { min-inline-size: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .caseload-bar__track { block-size: var(--mea-space-2); border-radius: var(--mea-radius-pill); overflow: hidden; }
  .caseload-bar__fill { display: block; block-size: 100%; inline-size: 0; border-radius: var(--mea-radius-pill); }
  .caseload-bar__value { margin: 0; }
  @container (max-width: 30rem) { .caseload-bar { grid-template-columns: 6rem 1fr auto; } }

  /* ── Senior prosecutor: savings hero ── */
  .savings-hero { display: grid; grid-template-columns: auto 1fr; align-items: center;
                  gap: var(--mea-space-6); padding: var(--mea-space-6);
                  border-radius: var(--mea-radius-2xl); }
  .savings-hero__headline { display: grid; gap: var(--mea-space-1); }
  .savings-hero__amount, .savings-hero__label, .savings-hero__basis { margin: 0; }
  .savings-hero__detail { display: grid; gap: var(--mea-space-2); min-inline-size: 0; }
  .savings-hero__metrics { display: flex; flex-wrap: wrap; gap: var(--mea-space-6); margin: 0; }
  .savings-hero__metric { display: grid; gap: var(--mea-space-1); }
  .savings-hero__metric-value, .savings-hero__metric-label { margin: 0; }
  @container (max-width: 34rem) { .savings-hero { grid-template-columns: 1fr; } }

  /* ── Senior prosecutor: cost analysis ── */
  .cost-list { display: grid; gap: var(--mea-space-3); margin: 0; }
  .cost-row { display: grid; grid-template-columns: auto 1fr auto; align-items: center;
              gap: var(--mea-space-3); }
  .cost-row--savings { padding-block-start: var(--mea-space-3); border-block-start: 1px solid transparent; }
  .cost-row__icon { font-size: var(--mea-text-lg); line-height: 1; }
  .cost-row__label, .cost-row__value { margin: 0; }

  /* ── System admin: provider summary ── */
  .provider-summary { display: flex; flex-wrap: wrap; gap: var(--mea-space-4); margin: 0; }
  .provider-summary__stat { display: grid; gap: var(--mea-space-1);
                            padding: var(--mea-space-4); border-radius: var(--mea-radius-lg); }
  .provider-summary__label, .provider-summary__value { margin: 0; }

  /* ── Case manager: upcoming session list ── */
  .session-list { display: grid; gap: var(--mea-space-3); margin: 0; padding: 0; list-style: none; }
  .session-item { display: grid; grid-template-columns: 1fr auto; align-items: center;
                  gap: var(--mea-space-3); padding: var(--mea-space-3) var(--mea-space-4);
                  border-radius: var(--mea-radius-lg); }
  .session-item__info { display: grid; gap: var(--mea-space-1); min-inline-size: 0; }
  .session-item__name, .session-item__type, .session-item__time { margin: 0; }

  /* ── Recent messages (participant) ── */
  .message-item { display: grid; gap: var(--mea-space-1);
                  padding-block: var(--mea-space-3); }
  .message-item__sender, .message-item__body, .message-item__time { margin: 0; }

  /* ── Audit / event list ── */
  .event-list { display: grid; margin: 0; padding: 0; list-style: none; }
  .event { display: grid; gap: var(--mea-space-1); padding: var(--mea-space-3) var(--mea-space-5); }
  .event__time, .event__actor, .event__action { margin: 0; }

  /* ── Drill-down modal ── */
  .dash-modal-overlay { position: fixed; inset: 0; display: grid; place-items: center;
                        padding: var(--mea-space-4); z-index: var(--mea-z-modal); }
  .drill-modal { inline-size: 100%; max-inline-size: 34rem; max-block-size: 85vh; display: grid;
                 grid-template-rows: auto 1fr; border-radius: var(--mea-radius-2xl); overflow: hidden; }
  .drill-modal__header { display: flex; align-items: center; justify-content: space-between;
                         gap: var(--mea-space-3); padding: var(--mea-space-4) var(--mea-space-5); }
  .drill-modal__title { margin: 0; }
  .drill-modal__close { border: 0; background: transparent; cursor: pointer; line-height: 1;
                        padding: var(--mea-space-1) var(--mea-space-2); }
  .drill-modal__body { display: grid; gap: var(--mea-space-2); align-content: start;
                       padding: var(--mea-space-4) var(--mea-space-5); overflow-y: auto; }

  .drill-row { display: grid; grid-template-columns: 1fr auto; align-items: center;
               gap: var(--mea-space-3); padding: var(--mea-space-3) 0; }
  .drill-row__main { display: grid; gap: var(--mea-space-1); min-inline-size: 0; }
  .drill-row__name, .drill-row__meta, .drill-row__time, .drill-empty { margin: 0; }
}

@layer design {
  /* Page intro. */
  .dashboard__title { font-family: var(--mea-font-citizen); font-size: var(--mea-text-2xl);
                      font-weight: var(--mea-w-bold); color: var(--t-text); }
  .dashboard__subtitle { font-size: var(--mea-text-md); color: var(--t-text-secondary); }

  /* Participant: program progress (the dashboard hero card). */
  .program-progress { background: var(--t-hero-bg); border: 1px solid var(--t-card-border);
                      box-shadow: var(--t-hero-shadow); }
  .program-progress__caption { font-size: var(--mea-text-sm); color: var(--t-text-muted); }
  .program-progress__pct { font-family: var(--mea-font-citizen); font-size: var(--mea-text-3xl);
                           font-weight: var(--mea-w-extrabold); color: var(--t-text);
                           line-height: var(--mea-lh-tight); }
  .program-progress__deadline { font-size: var(--mea-text-sm); color: var(--t-text-muted); }
  .program-progress__track { background: var(--t-track); }
  .program-progress__fill { background: var(--t-accent); }
  .program-progress__counts { font-size: var(--mea-text-sm); color: var(--t-text-muted); }

  /* Participant: active timer. */
  .active-timer { background: var(--t-card-bg); border: 1px solid var(--t-card-border);
                  box-shadow: var(--mea-shadow-sm); }
  .active-timer__pulse { background: var(--t-success); }
  .active-timer__label { font-size: var(--mea-text-xs); font-weight: var(--mea-w-semibold);
                         color: var(--t-text-muted); text-transform: uppercase;
                         letter-spacing: var(--mea-ls-wide); }
  .active-timer__task { font-size: var(--mea-text-md); font-weight: var(--mea-w-semibold); color: var(--t-text); }
  .active-timer__provider { font-size: var(--mea-text-sm); color: var(--t-text-muted); }
  .active-timer__value { font-family: var(--mea-font-mono); font-size: var(--mea-text-xl);
                         font-weight: var(--mea-w-bold); color: var(--t-text); }
  .active-timer__elapsed { font-size: var(--mea-text-xs); color: var(--t-text-muted); }

  /* Generic block header. */
  .dashboard-block__title { font-family: var(--mea-font-citizen); font-size: var(--mea-text-lg);
                            font-weight: var(--mea-w-bold); color: var(--t-text); }
  .dashboard-block__link { font-size: var(--mea-text-sm); color: var(--t-link); }
  .dashboard-block__link:hover { color: var(--t-link-hover); }

  /* Participant: upcoming task. */
  .upcoming-list__empty { font-size: var(--mea-text-md); color: var(--t-text-muted); }
  .upcoming-task { background: var(--t-card-bg); border: 1px solid var(--t-card-border);
                   box-shadow: var(--mea-shadow-sm); }
  .upcoming-task__title { font-size: var(--mea-text-md); font-weight: var(--mea-w-semibold); color: var(--t-text); }
  .upcoming-task__date { font-size: var(--mea-text-xs); color: var(--t-text-muted); }

  /* Participant: quick actions. */
  .dashboard-actions { background: var(--t-card-bg); border: 1px solid var(--t-card-border);
                       box-shadow: var(--mea-shadow-sm); }
  .dashboard-actions__title { font-family: var(--mea-font-citizen); font-size: var(--mea-text-md);
                              font-weight: var(--mea-w-bold); color: var(--t-text); }

  /* Officer: profile header. */
  .officer-profile { background: var(--t-card-bg); border: 1px solid var(--t-card-border);
                     box-shadow: var(--mea-shadow-sm); }
  .officer-profile__avatar { background: var(--t-accent); color: var(--t-accent-text);
                             font-size: var(--mea-text-lg); font-weight: var(--mea-w-bold); }
  .officer-profile__name { font-family: var(--mea-font-citizen); font-size: var(--mea-text-lg);
                           font-weight: var(--mea-w-bold); color: var(--t-text); }
  .officer-profile__badge { font-size: var(--mea-text-sm); color: var(--t-text-muted); }
  .officer-profile__search { background: var(--t-bg-recessed); color: var(--t-text-secondary);
                             font-size: var(--mea-text-md);
                             transition: background var(--mea-dur-fast); }
  .officer-profile__search:hover { background: var(--t-bg-active); }

  /* Metric figures. */
  .metric { background: var(--t-card-bg); border: 1px solid var(--t-card-border);
            box-shadow: var(--mea-shadow-sm); }
  .metric--clickable:hover { box-shadow: var(--mea-shadow-md); transform: translateY(-1px); }
  .metric__label { font-size: var(--mea-text-sm); font-weight: var(--mea-w-semibold); color: var(--t-text-muted); }
  .metric__value { font-size: var(--mea-text-3xl); font-weight: var(--mea-w-extrabold);
                   line-height: var(--mea-lh-tight); color: var(--t-text); }
  .metric__value--blue { color: var(--t-accent); }
  .metric__value--green { color: var(--t-success-text); }
  .metric__value--amber { color: var(--t-warning-text); }
  .metric__value--red { color: var(--t-error-text); }
  .metric__value--loading { color: var(--t-text-muted); }
  .metric__sub { font-size: var(--mea-text-xs); color: var(--t-text-muted); }

  /* Panels. */
  .dashboard-panel { background: var(--t-card-bg); border: 1px solid var(--t-card-border);
                     box-shadow: var(--mea-shadow-sm); }
  .dashboard-panel__header { border-block-end: 1px solid var(--t-border); }
  .dashboard-panel__title { font-family: var(--mea-font-citizen); font-size: var(--mea-text-lg);
                            font-weight: var(--mea-w-bold); color: var(--t-text); }
  .dashboard-panel__meta { font-size: var(--mea-text-sm); color: var(--t-text-muted); }
  .dashboard-panel__empty { font-size: var(--mea-text-md); color: var(--t-text-muted); }

  /* Panel empty state. */
  .panel-empty__icon { font-size: var(--mea-text-3xl); line-height: 1; }
  .panel-empty__title { font-size: var(--mea-text-md); color: var(--t-text-muted); }

  /* Case table. */
  .case-table th { font-size: var(--mea-text-xs); font-weight: var(--mea-w-semibold);
                   color: var(--t-text-muted); text-transform: uppercase;
                   letter-spacing: var(--mea-ls-wide); border-block-end: 1px solid var(--t-border); }
  .case-table td { font-size: var(--mea-text-sm); color: var(--t-text);
                   border-block-end: 1px solid var(--t-border); }
  .case-table__row:hover { background: var(--t-bg-recessed); }
  .case-table__meta { color: var(--t-text-muted); }

  .person-cell__avatar { background: var(--t-bg-active); color: var(--t-text-secondary);
                         font-size: var(--mea-text-sm); font-weight: var(--mea-w-bold); }
  .person-cell__name { font-size: var(--mea-text-sm); font-weight: var(--mea-w-semibold); color: var(--t-text); }
  .person-cell__sub { font-size: var(--mea-text-xs); color: var(--t-text-muted); }

  /* Officer: issue list. */
  .issue-group__heading { font-size: var(--mea-text-xs); font-weight: var(--mea-w-semibold);
                          color: var(--t-text-muted); text-transform: uppercase;
                          letter-spacing: var(--mea-ls-wide); }
  .issue-row { border-block-end: 1px solid var(--t-border); }
  .issue-row:hover { background: var(--t-bg-recessed); }
  .issue-row__name { font-size: var(--mea-text-md); font-weight: var(--mea-w-semibold); color: var(--t-text); }
  .issue-row__detail { font-size: var(--mea-text-sm); color: var(--t-text-muted); }

  /* Prosecutor: court tabs + info. */
  .court-tab { background: var(--t-bg-recessed); color: var(--t-text-secondary);
               font-size: var(--mea-text-sm); font-weight: var(--mea-w-semibold);
               transition: background var(--mea-dur-fast), color var(--mea-dur-fast); }
  .court-tab:hover { background: var(--t-bg-active); }
  .court-tab.is-active { background: var(--t-accent); color: var(--t-accent-text); }
  .court-info__label { font-size: var(--mea-text-md); color: var(--t-text-secondary); }
  .court-info__value { font-size: var(--mea-text-md); font-weight: var(--mea-w-bold); color: var(--t-text); }

  /* Charts: donut. */
  .chart-donut__value { font-size: var(--mea-text-xl); font-weight: var(--mea-w-extrabold); color: var(--t-text); }
  .chart-donut__label { font-size: var(--mea-text-xs); color: var(--t-text-muted); }

  .chart-legend__dot--green { background: var(--t-success); }
  .chart-legend__dot--red { background: var(--t-error); }
  .chart-legend__dot--amber { background: var(--t-warning); }
  .chart-legend__dot--blue, .chart-legend__dot--baby-blue { background: var(--t-accent); }
  .chart-legend__dot--gray { background: var(--t-text-muted); }
  .chart-legend__label { font-size: var(--mea-text-sm); color: var(--t-text-secondary); }
  .chart-legend__value { font-size: var(--mea-text-sm); font-weight: var(--mea-w-bold); color: var(--t-text); }

  /* Charts: trend bars. */
  .trend-bar__seg--approved { background: var(--t-success); }
  .trend-bar__seg--deferred { background: var(--t-warning); }
  .trend-bar__seg--denied { background: var(--t-error); }
  .trend-bar__seg--empty { background: var(--t-bg-recessed); }
  .trend-chart__label { font-size: var(--mea-text-xs); color: var(--t-text-muted); }
  .trend-legend__item { font-size: var(--mea-text-sm); color: var(--t-text-secondary); }

  /* Charts: caseload bars. */
  .caseload-bar__label { font-size: var(--mea-text-sm); color: var(--t-text-secondary); }
  .caseload-bar__track { background: var(--t-bg-recessed); }
  .caseload-bar__fill { background: var(--t-accent); }
  .caseload-bar__value { font-size: var(--mea-text-sm); font-weight: var(--mea-w-bold); color: var(--t-text); }

  /* Senior prosecutor: savings hero. */
  .savings-hero { background: var(--t-card-bg); border: 1px solid var(--t-card-border);
                  box-shadow: var(--mea-shadow-sm); }
  .savings-hero__amount { font-family: var(--mea-font-citizen); font-size: var(--mea-text-hero);
                          font-weight: var(--mea-w-black); color: var(--t-success-text);
                          line-height: var(--mea-lh-tight); }
  .savings-hero__label { font-size: var(--mea-text-sm); font-weight: var(--mea-w-semibold);
                         color: var(--t-text-muted); }
  .savings-hero__basis { font-size: var(--mea-text-sm); color: var(--t-text-secondary); }
  .savings-hero__metric-value { font-size: var(--mea-text-2xl); font-weight: var(--mea-w-bold); color: var(--t-text); }
  .savings-hero__metric-label { font-size: var(--mea-text-xs); color: var(--t-text-muted); }

  /* Senior prosecutor: cost analysis. */
  .cost-row__icon { color: var(--t-text-secondary); }
  .cost-row__label { font-size: var(--mea-text-sm); color: var(--t-text-secondary); }
  .cost-row__value { font-size: var(--mea-text-md); font-weight: var(--mea-w-bold); color: var(--t-text); }
  .cost-row__value--diversion { color: var(--t-accent); }
  .cost-row--savings { border-block-start-color: var(--t-border); }
  .cost-row__label--savings { font-weight: var(--mea-w-semibold); color: var(--t-text); }
  .cost-row__value--savings { color: var(--t-success-text); }

  /* System admin: provider summary. */
  .provider-summary__stat { background: var(--t-bg-recessed); }
  .provider-summary__label { font-size: var(--mea-text-sm); color: var(--t-text-muted); }
  .provider-summary__value { font-size: var(--mea-text-2xl); font-weight: var(--mea-w-bold); }
  .provider-summary__value--active { color: var(--t-success-text); }
  .provider-summary__value--inactive { color: var(--t-text-muted); }

  /* Case manager: session list. */
  .session-item { background: var(--t-bg-recessed); }
  .session-item__name { font-size: var(--mea-text-md); font-weight: var(--mea-w-semibold); color: var(--t-text); }
  .session-item__type { font-size: var(--mea-text-sm); color: var(--t-text-muted); }
  .session-item__time { font-size: var(--mea-text-sm); color: var(--t-text-secondary); }

  /* Recent messages. */
  .message-item { border-block-end: 1px solid var(--t-border); }
  .message-item__sender { font-size: var(--mea-text-md); font-weight: var(--mea-w-semibold); color: var(--t-text); }
  .message-item__body { font-size: var(--mea-text-sm); color: var(--t-text-secondary);
                        line-height: var(--mea-lh-snug); }
  .message-item__time { font-size: var(--mea-text-xs); color: var(--t-text-muted); }

  /* Audit / event list. */
  .event { border-block-end: 1px solid var(--t-border); }
  .event__time { font-size: var(--mea-text-xs); color: var(--t-text-muted); }
  .event__actor { font-size: var(--mea-text-sm); font-weight: var(--mea-w-semibold); color: var(--t-text); }
  .event__action { font-size: var(--mea-text-sm); color: var(--t-text-secondary); }
  .event__resource { font-weight: var(--mea-w-semibold); color: var(--t-text); }

  /* Drill-down modal. */
  .dash-modal-overlay { background: var(--t-bg-active); }
  .drill-modal { background: var(--t-card-bg); border: 1px solid var(--t-card-border);
                 box-shadow: var(--mea-shadow-lg); }
  .drill-modal__header { border-block-end: 1px solid var(--t-border); }
  .drill-modal__title { font-family: var(--mea-font-citizen); font-size: var(--mea-text-lg);
                        font-weight: var(--mea-w-bold); color: var(--t-text); }
  .drill-modal__close { color: var(--t-text-muted); font-size: var(--mea-text-xl); }
  .drill-modal__close:hover { color: var(--t-text); }
  .drill-row { border-block-end: 1px solid var(--t-border); }
  .drill-row__name { font-size: var(--mea-text-sm); font-weight: var(--mea-w-semibold); color: var(--t-text); }
  .drill-row__meta { font-size: var(--mea-text-xs); color: var(--t-text-muted); }
  .drill-row__time { font-size: var(--mea-text-sm); font-weight: var(--mea-w-bold); color: var(--t-text); }
  .drill-empty { font-size: var(--mea-text-md); color: var(--t-text-muted); text-align: center;
                 padding: var(--mea-space-4); }

  /* Charge tags — category-tinted, theme-aware. */
  .charge-tag { display: inline-flex; align-items: center; padding: var(--mea-space-1) var(--mea-space-3);
                border-radius: var(--mea-radius-pill); font-size: var(--mea-text-xs);
                font-weight: var(--mea-w-semibold); background: var(--t-bg-recessed); color: var(--t-text-secondary); }
  .charge-tag--drug { color: var(--t-warning-text); }
  .charge-tag--theft, .charge-tag--property { color: var(--t-accent); }
  .charge-tag--dui, .charge-tag--assault { color: var(--t-error-text); }
  .charge-tag--conduct, .charge-tag--trespass { color: var(--t-text-secondary); }

  /* Case status badges. */
  .case-badge { display: inline-flex; align-items: center; padding: var(--mea-space-1) var(--mea-space-3);
                border-radius: var(--mea-radius-pill); font-size: var(--mea-text-xs);
                font-weight: var(--mea-w-semibold); background: var(--t-bg-recessed); color: var(--t-text-secondary); }
  .case-badge--approved, .case-badge--accepted, .case-badge--completed,
  .case-badge--active { color: var(--t-success-text); }
  .case-badge--pending, .case-badge--new, .case-badge--review,
  .case-badge--in_progress, .case-badge--deferred { color: var(--t-warning-text); }
  .case-badge--denied, .case-badge--closed, .case-badge--failed,
  .case-badge--overdue { color: var(--t-error-text); }
}
