  :root {
    --bg:         #fbf7f1;
    --bg-elev:    #f5f0e7;
    --bg-card:    #ffffff;
    --border:     #e8e0d2;
    --border-hi:  #d0c5b2;
    --text:       #1a1a1a;
    --text-dim:   #5a5a5a;
    --text-faint: #9a9280;

    --accent:     #2d5a3d;
    --accent-dim: #6b8e7a;
    --accent-soft: #d6e0d0;

    /* user-defined status colors */
    --pos:        #18E418;
    --pos-soft:   #cbf5cb;
    --pos-dim:    #0fa80f;
    --neg:        #FF1212;
    --neg-soft:   #ffd4d4;
    --neg-dim:    #c00000;
    --warn:       #E2F062;
    --warn-soft:  #f4f8d0;
    --warn-dim:   #8a9a1a;

    --info:       #5a7a8a;
    --grid:       #eee7d9;
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  html, body {
    background: var(--bg);
    color: var(--text);
    font-family: 'Manrope', sans-serif;
    font-size: 15px;
    line-height: 1.5;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
  }

  /* ============ TOP BAR ============ */
  .topbar {
    padding: 32px 40px 24px;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }
  .brand { display: flex; flex-direction: column; }
  .wordmark {
    font-family: 'Manrope', sans-serif;
    font-weight: 800;
    font-size: 30px;
    letter-spacing: -0.025em;
    line-height: 1;
  }
  .wordmark .dot { color: var(--accent); margin: 0 6px; }
  .sub {
    font-family: 'Manrope', sans-serif;
    font-weight: 500;
    font-size: 12px;
    color: var(--text-faint);
    margin-top: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
  }
  .topbar-right { display: flex; gap: 20px; align-items: center; }
  .period-select {
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text);
    padding: 10px 16px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    letter-spacing: 0.05em;
    cursor: pointer;
    border-radius: 8px;
    font-weight: 500;
  }
  /* ── Tab 07 Daily Flow · filter/sort strips (07·E counterparty + Phase 3 lists) ── */
  .t7d-filter { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; padding: 2px 0 16px; }
  .t7d-search {
    background: var(--bg-card); border: 1px solid var(--border); color: var(--text);
    padding: 9px 14px; font-family: 'JetBrains Mono', monospace; font-size: 12px;
    letter-spacing: 0.04em; border-radius: 8px; flex: 1 1 200px; min-width: 160px;
  }
  .t7d-search::placeholder { color: var(--text-faint); }
  .t7d-toggle { display: inline-flex; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
  .t7d-toggle button {
    background: var(--bg-card); border: none; border-left: 1px solid var(--border);
    color: var(--text-dim); padding: 9px 13px; font-family: 'JetBrains Mono', monospace;
    font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; cursor: pointer;
  }
  .t7d-toggle button:first-child { border-left: none; }
  .t7d-toggle button.active { background: var(--accent); color: #fff; font-weight: 600; }
  .t7d-showall {
    font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--accent);
    letter-spacing: 0.06em; cursor: pointer; padding: 12px 0 4px; display: inline-block;
  }
  .t7d-showall:hover { text-decoration: underline; }
  /* 07·P Reconciliation Check · status dot + text */
  .t7p-dot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; margin-right: 7px; vertical-align: middle; }
  .t7p-status-green  .t7p-dot { background: var(--pos);  box-shadow: 0 0 6px var(--pos); }
  .t7p-status-yellow .t7p-dot { background: var(--warn); box-shadow: 0 0 6px var(--warn); }
  .t7p-status-red    .t7p-dot { background: var(--neg);  box-shadow: 0 0 6px var(--neg); }
  .t7p-status-green  .t7p-status-text { color: var(--pos-dim); }
  .t7p-status-yellow .t7p-status-text { color: var(--warn-dim); }
  .t7p-status-red    .t7p-status-text { color: var(--neg-dim); }
  /* Settlement Reconciliation · MEF biweekly audit accordion (demoted · Pivot B) */
  .t7-mef-accordion { border: 1px solid var(--border); border-radius: 10px; background: var(--bg-card); margin-top: 24px; overflow: hidden; }
  .t7-mef-accordion-header { display: flex; align-items: center; gap: 12px; padding: 16px 20px; cursor: pointer; user-select: none; }
  .t7-mef-accordion-header:hover { background: var(--bg-elev); }
  .t7-mef-accordion-chevron { font-size: 11px; color: var(--text-faint); transition: transform 0.2s ease; flex: 0 0 auto; }
  .t7-mef-accordion[data-expanded="true"] .t7-mef-accordion-chevron { transform: rotate(90deg); }
  .t7-mef-accordion-titles { flex: 1 1 auto; min-width: 0; }
  .t7-mef-accordion-title { font-family: 'Manrope', sans-serif; font-weight: 700; font-size: 15px; color: var(--text); letter-spacing: -0.01em; }
  .t7-mef-accordion-sub { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-faint); letter-spacing: 0.08em; text-transform: uppercase; margin-top: 4px; }
  .t7-mef-accordion-affordance { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--accent); letter-spacing: 0.06em; flex: 0 0 auto; }
  .t7-mef-accordion-content { display: none; padding: 8px 20px 20px; border-top: 1px solid var(--border); }
  .t7-mef-accordion[data-expanded="true"] .t7-mef-accordion-content { display: block; }
  /* Muted-warning for stale MEF source date (subtle, not alarming) — Phase 6 freshness */
  .freshness-stale { color: var(--warn-dim); font-weight: 600; }
  .source-tag {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: var(--text-faint);
    letter-spacing: 0.1em;
    padding: 6px 12px;
    border: 1px solid var(--border);
    background: var(--bg-card);
    border-radius: 6px;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .source-tag .dot-pulse {
    display: inline-block;
    width: 6px; height: 6px;
    background: var(--pos);
    border-radius: 50%;
    box-shadow: 0 0 6px var(--pos);
    animation: pulse 2s infinite;
  }
  @keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }
  .meta {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: var(--text-faint);
    text-align: right;
    letter-spacing: 0.04em;
    line-height: 1.6;
  }

  /* ============ HERO BAND ============ */
  .hero-band {
    padding: 8px 40px 36px;
    background: var(--bg);
    position: relative;
  }
  .hero-band-tag {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    color: var(--accent);
    letter-spacing: 0.18em;
    font-weight: 600;
    padding: 0 0 16px 2px;
  }
  .hero-grid {
    display: grid;
    grid-template-columns: 1.45fr 1fr 1fr;
    gap: 20px;
  }
  .hero-block {
    background: var(--bg-card);
    border-radius: 12px;
    padding: 24px 28px 26px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.03), 0 0 0 1px var(--border);
  }
  .hero-block-title {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 16px;
    color: var(--text);
    margin-bottom: 20px;
    display: flex;
    justify-content: space-between;
    align-items: baseline;
  }
  .hero-block-title .range {
    font-family: 'JetBrains Mono', monospace;
    font-weight: 500;
    font-size: 10px;
    color: var(--text-faint);
    letter-spacing: 0.06em;
  }
  .hero-metrics { display: grid; gap: 2px; }
  .hero-metrics.cols-6 { grid-template-columns: repeat(6, 1fr); }
  .hero-metrics.cols-5 { grid-template-columns: repeat(5, 1fr); }
  .hero-metrics.cols-3 { grid-template-columns: repeat(3, 1fr); }
  .hero-metrics.cols-4 { grid-template-columns: repeat(4, 1fr); }
  .hero-metric { padding: 0 10px 0 0; }
  .hero-metric-label {
    font-weight: 600;
    font-size: 11px;
    color: var(--text-faint);
    margin-bottom: 10px;
    min-height: 28px;
    line-height: 1.3;
    letter-spacing: 0.02em;
  }
  .hero-metric-value {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 32px;
    line-height: 1;
    letter-spacing: -0.03em;
    font-variant-numeric: tabular-nums;
  }
  .hero-metric-value.big { font-size: 40px; }
  .hero-metric-value.pos { color: var(--pos-dim); }
  .hero-metric-value.neg { color: var(--neg-dim); }
  .hero-metric-value.warn { color: var(--warn-dim); }
  .hero-metric-value.accent { color: var(--accent); }
  .hero-metric-value .unit { font-size: 16px; color: var(--text-dim); font-weight: 600; }
  .hero-metric-sub { font-size: 9px; color: var(--text-faint); margin-top: 2px; letter-spacing: 0.03em; }

  /* pace badges */
  .pace {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    margin-top: 10px;
    padding: 4px 9px;
    border-radius: 6px;
  }
  .pace.ahead  { background: var(--pos-soft);  color: var(--pos-dim); }
  .pace.behind { background: var(--neg-soft);  color: var(--neg-dim); }
  .pace.flat   { background: var(--bg-elev);   color: var(--text-faint); }
  .pace.warn   { background: var(--warn-soft); color: var(--warn-dim); }
  .pace .bench { color: var(--text-faint); font-size: 9px; margin-left: 2px; font-weight: 500; }
  .pace .arrow { font-size: 10px; line-height: 1; }

  /* ============ TABS ============ */
  .tabs {
    display: flex;
    padding: 0 40px;
    gap: 6px;
    background: var(--bg);
    margin-top: -4px;
  }
  .tab {
    padding: 13px 22px;
    font-family: 'Manrope', sans-serif;
    font-weight: 600;
    font-size: 13px;
    color: var(--text-faint);
    cursor: pointer;
    border-radius: 8px 8px 0 0;
    letter-spacing: 0.04em;
    user-select: none;
    transition: color 0.15s, background 0.15s;
  }
  .tab:hover { color: var(--text-dim); }
  .tab.active {
    background: var(--bg-card);
    color: var(--text);
    box-shadow: 0 -1px 3px rgba(0,0,0,0.02), 1px 0 0 var(--border), -1px 0 0 var(--border), 0 -1px 0 var(--border);
  }
  .tab-num {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: var(--accent-dim);
    margin-right: 8px;
    font-weight: 500;
  }
  .tab.active .tab-num { color: var(--accent); }

  /* ============ MAIN ============ */
  main {
    padding: 24px 40px 48px;
    background: var(--bg);
    border-top: 1px solid var(--border);
  }
  .panel-grid { display: grid; gap: 20px; }
  .panel-grid.g-2 { grid-template-columns: 1fr 1fr; }
  .panel-grid.g-3 { grid-template-columns: repeat(3, 1fr); }
  .panel-grid.g-4 { grid-template-columns: repeat(4, 1fr); }
  .panel-grid.g-2-1 { grid-template-columns: 2fr 1fr; }
  .panel-grid.g-1-2 { grid-template-columns: 1fr 2fr; }
  .panel-grid.g-3-2 { grid-template-columns: 3fr 2fr; }
  @media (max-width: 1100px) {
    .panel-grid.g-3-2 { grid-template-columns: 1fr; }
  }

  /* Hire cohort retention list */
  .cohort-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 8px 0;
  }
  .cohort-row {
    display: grid;
    grid-template-columns: 70px 1fr 110px;
    align-items: center;
    gap: 12px;
  }
  .cohort-label {
    font-family: 'Manrope', sans-serif;
    font-weight: 600;
    font-size: 12px;
    color: var(--text-dim);
    letter-spacing: 0.02em;
  }
  .cohort-bar-wrap {
    height: 14px;
    background: var(--bg-elev);
    border-radius: 3px;
    overflow: hidden;
    position: relative;
  }
  .cohort-bar {
    height: 100%;
    border-radius: 3px;
    transition: width 0.6s ease;
    min-width: 2px;
  }
  .cohort-value {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    font-weight: 600;
    color: var(--text-dim);
    text-align: right;
    letter-spacing: 0.02em;
  }
  .cohort-value span {
    font-weight: 700;
  }

  /* Stepping-stone visualization for monthly milestones */
  .milestone-path {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
  }
  .milestone-path-label {
    font-family: 'Manrope', sans-serif;
    font-weight: 600;
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-faint);
    margin-bottom: 10px;
  }
  .milestone-steps {
    display: flex;
    align-items: center;
    gap: 2px;
  }
  .milestone-step {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    padding: 0 1px;
  }
  .milestone-step-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--bg-elev);
    border: 1.5px solid var(--border-hi);
    z-index: 2;
    position: relative;
  }
  .milestone-step.done .milestone-step-dot {
    background: var(--pos);
    border-color: var(--pos-dim);
  }
  .milestone-step.now .milestone-step-dot {
    background: var(--pos-dim);
    border-color: var(--pos-dim);
    width: 14px;
    height: 14px;
    box-shadow: 0 0 0 3px rgba(24, 228, 24, 0.2);
  }
  .milestone-step.future .milestone-step-dot {
    background: #fff;
    border-color: var(--border-hi);
  }
  .milestone-step.goal .milestone-step-dot {
    width: 12px;
    height: 12px;
    background: #fff;
    border: 2px solid var(--accent);
  }
  .milestone-step-line {
    position: absolute;
    top: 5px;
    left: 50%;
    right: -50%;
    height: 2px;
    background: var(--border);
    z-index: 1;
  }
  .milestone-step.done .milestone-step-line {
    background: var(--pos);
  }
  .milestone-step:last-child .milestone-step-line { display: none; }
  .milestone-step-month {
    font-family: 'JetBrains Mono', monospace;
    font-size: 8px;
    color: var(--text-faint);
    margin-top: 6px;
    letter-spacing: 0.05em;
    text-align: center;
    font-weight: 500;
  }
  .milestone-step.now .milestone-step-month {
    color: var(--pos-dim);
    font-weight: 700;
  }
  .milestone-step.goal .milestone-step-month {
    color: var(--accent);
    font-weight: 700;
  }
  .milestone-legend {
    display: flex;
    justify-content: space-between;
    margin-top: 12px;
    font-family: 'Manrope', sans-serif;
    font-size: 11px;
  }
  .milestone-legend-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
  }
  .milestone-legend-item .lbl {
    font-size: 9px;
    color: var(--text-faint);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-weight: 600;
  }
  .milestone-legend-item .val {
    font-family: 'JetBrains Mono', monospace;
    font-weight: 600;
    font-size: 13px;
    color: var(--text);
    font-variant-numeric: tabular-nums;
  }
  .milestone-legend-item.current .val { color: var(--pos-dim); }
  .milestone-legend-item.end-goal .val { color: var(--accent); }

  /* Primary goals grid — compact vertical layout for 4-across */
  .goals-primary-grid .goal-card {
    padding: 18px 18px 20px;
  }
  .goals-primary-grid .goal-card-header {
    margin-bottom: 14px;
    padding-bottom: 10px;
  }
  .goals-primary-grid .goal-card-name {
    font-size: 12px;
  }
  .goals-primary-grid .goal-card-target-chip {
    font-size: 10px;
    padding: 3px 8px;
  }
  .goals-primary-grid .goal-card-body {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }
  .goals-primary-grid .goal-card-ring {
    width: 110px;
    height: 110px;
    margin: 0 auto;
  }
  .goals-primary-grid .goal-card-ring-value {
    font-size: 26px;
  }
  .goals-primary-grid .goal-card-ring-pct {
    font-size: 10px;
  }
  .goals-primary-grid .goal-detail-line {
    padding: 5px 0;
    font-size: 12px;
  }
  .goals-primary-grid .goal-action-line {
    padding: 10px 12px;
    font-size: 12px;
    line-height: 1.45;
    margin-top: 12px;
  }

  .panel {
    background: var(--bg-card);
    border-radius: 12px;
    padding: 24px 26px 26px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.02), 0 0 0 1px var(--border);
  }
  .panel-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--border);
  }
  .panel-title {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 16px;
    letter-spacing: -0.01em;
  }
  .panel-title .num {
    font-family: 'JetBrains Mono', monospace;
    font-weight: 500;
    color: var(--accent);
    margin-right: 10px;
    font-size: 11px;
  }
  .panel-sub {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    color: var(--text-faint);
    letter-spacing: 0.06em;
  }
  .chart-wrap { position: relative; height: 260px; }
  .chart-wrap.tall { height: 340px; }
  .chart-wrap.short { height: 160px; }

  /* stat cards */
  .stat-row {
    display: grid;
    gap: 12px;
    margin-bottom: 20px;
  }
  .stat-row.s-3 { grid-template-columns: repeat(3, 1fr); }
  .stat-row.s-4 { grid-template-columns: repeat(4, 1fr); }
  .stat-row.s-5 { grid-template-columns: repeat(5, 1fr); }
  .stat {
    background: var(--bg-elev);
    padding: 14px 16px;
    border-radius: 8px;
  }
  .stat-label {
    font-family: 'Manrope', sans-serif;
    font-weight: 600;
    font-size: 11px;
    color: var(--text-faint);
    margin-bottom: 8px;
    letter-spacing: 0.02em;
  }
  .stat-val {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 24px;
    letter-spacing: -0.02em;
    font-variant-numeric: tabular-nums;
  }
  .stat-val .sub { font-size: 12px; color: var(--text-dim); margin-left: 4px; font-weight: 500; }
  .stat-caption {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10.5px;
    color: var(--text-faint);
    margin-top: 4px;
    letter-spacing: 0.01em;
  }
  .pos-text { color: var(--pos-dim); }
  .neg-text { color: var(--neg-dim); }
  .warn-text { color: var(--warn-dim); }
  .accent-text { color: var(--accent); }

  /* ============ PHASE 2B · recal strip + SVG rings + tracking grid ============ */
  .recal-strip {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 10px 16px;
    margin: 10px 0 18px;
    background: #f6efe3;
    border: 1px solid var(--border);
    border-left: 3px solid var(--accent);
    border-radius: 8px;
    font-size: 12.5px;
    color: var(--text-dim);
  }
  .recal-strip-meta {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    color: var(--text-faint);
    white-space: nowrap;
  }

  /* SVG ring (Section A milestone cards) */
  .svg-ring {
    position: relative;
    width: 160px;
    height: 160px;
    flex: 0 0 auto;
  }
  .svg-ring svg { width: 100%; height: 100%; transform: rotate(-90deg); }
  .svg-ring .ring-bg {
    fill: none;
    stroke: #eee7d9;
    stroke-width: 10;
  }
  .svg-ring .ring-fg {
    fill: none;
    stroke: var(--pos);
    stroke-width: 10;
    stroke-linecap: round;
    transition: stroke-dashoffset 800ms cubic-bezier(.22,.61,.36,1);
  }
  .svg-ring .ring-fg.empty { stroke: #dad3c2; }
  .svg-ring .ring-fg.warn  { stroke: var(--warn); }
  .svg-ring .ring-fg.neg   { stroke: var(--neg); }
  .svg-ring .ring-center {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 0 8px;
  }
  .svg-ring .ring-main {
    font-family: 'JetBrains Mono', monospace;
    font-weight: 700;
    font-size: 24px;
    color: var(--text);
    letter-spacing: -0.01em;
    line-height: 1.05;
  }
  .svg-ring .ring-pct {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: var(--text-faint);
    letter-spacing: 0.1em;
    margin-top: 4px;
    text-transform: uppercase;
  }
  .svg-ring .ring-pct strong { color: var(--text); font-weight: 700; }
  .svg-ring .ring-subscript {
    margin-top: 6px;
    padding: 4px 8px;
    background: #f4ecd9;
    border: 1px solid var(--border);
    border-radius: 4px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 9.5px;
    color: var(--text-dim);
    line-height: 1.25;
    max-width: 145px;
  }
  .goal-card.primary .svg-ring .ring-subscript {
    border-color: var(--pos-dim);
    background: #ecf5e3;
    color: var(--pos-dim);
  }

  /* Section B ops card */
  .ops-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .ops-card.primary { border: 2px solid var(--pos); }
  .ops-card.blocked { opacity: 0.62; background: repeating-linear-gradient(-45deg, #faf7f0, #faf7f0 10px, #f1ead7 10px, #f1ead7 20px); }
  .ops-card-head { display: flex; justify-content: space-between; align-items: center; }
  .ops-card-title { font-weight: 700; font-size: 14px; color: var(--text); }
  .ops-card-meta  { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-faint); }
  .ops-card-value { font-family: 'JetBrains Mono', monospace; font-weight: 800; font-size: 32px; color: var(--text); line-height: 1; }
  .ops-card-value .slash { font-size: 14px; color: var(--text-faint); font-weight: 500; }
  .ops-bar { height: 6px; background: #eee7d9; border-radius: 3px; overflow: hidden; }
  .ops-bar-fill { height: 100%; background: var(--pos); border-radius: 3px; transition: width 500ms ease; }
  .ops-bar-fill.close { background: var(--warn); }
  .ops-bar-fill.miss  { background: var(--neg); }
  .ops-detail-row {
    display: flex;
    justify-content: space-between;
    font-size: 11.5px;
    color: var(--text-dim);
    font-family: 'JetBrains Mono', monospace;
  }
  .ops-north-star-pill {
    background: var(--pos);
    color: #fff;
    font-family: 'JetBrains Mono', monospace;
    font-size: 9.5px;
    letter-spacing: 0.15em;
    padding: 3px 8px;
    border-radius: 10px;
    text-transform: uppercase;
    font-weight: 700;
  }
  .blocked-badge {
    display: inline-block;
    background: var(--text-faint);
    color: #fff;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    padding: 2px 7px;
    border-radius: 3px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
  }

  /* Section C tracking grid */
  .tracking-wrap { overflow-x: auto; margin-top: 12px; }
  .tracking-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 2px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
  }
  .tracking-table thead th {
    font-size: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-faint);
    padding: 6px 8px;
    text-align: center;
    font-weight: 600;
  }
  .tracking-table thead th.metric-col { text-align: left; padding-left: 12px; min-width: 150px; }
  .tracking-table thead th.avg-col    { color: var(--accent); }
  .tracking-table tbody td {
    padding: 8px 6px;
    text-align: center;
    border-radius: 4px;
    color: var(--text);
    font-weight: 600;
    background: #faf7f0;
    white-space: nowrap;
  }
  .tracking-table tbody td.metric-name {
    text-align: left;
    background: transparent;
    color: var(--text);
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 12.5px;
    padding-left: 12px;
  }
  .tracking-table td.cell-hit       { background: var(--pos-tint, #EAF3DE); color: var(--pos-deep, #173404); }
  .tracking-table td.cell-close     { background: var(--warn-tint, #FDE9CC); color: var(--warn-deep, #412402); }
  .tracking-table td.cell-miss      { background: var(--neg-tint, #FCDFDF); color: var(--neg-deep, #501313); }
  .tracking-table td.cell-no-target,
  .tracking-table td.cell-no-data    { background: #f1ebd9; color: var(--text-faint); }
  .tracking-table td.cell-neutral   { background: #f6efe3; color: var(--text-dim); }
  .tracking-table td.cell-current   { outline: 2px solid var(--accent); outline-offset: -1px; }
  .tracking-table td.avg-cell       { background: #fff; color: var(--accent); font-weight: 700; border-left: 1px solid var(--border); }
  .tracking-footnote {
    margin-top: 10px;
    font-size: 11px;
    color: var(--text-faint);
    font-style: italic;
  }
  .grid-legend {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    padding: 8px 0 2px;
    font-size: 11px;
    color: var(--text-dim);
  }
  .grid-legend .legend-item { display: inline-flex; align-items: center; gap: 6px; }
  .grid-legend .legend-swatch {
    width: 12px; height: 12px; border-radius: 3px; display: inline-block;
  }
  .grid-legend .legend-swatch.cell-hit       { background: var(--pos-tint, #EAF3DE); border: 1px solid var(--pos); }
  .grid-legend .legend-swatch.cell-close     { background: var(--warn-tint, #FDE9CC); border: 1px solid var(--warn); }
  .grid-legend .legend-swatch.cell-miss      { background: var(--neg-tint, #FCDFDF); border: 1px solid var(--neg); }
  .grid-legend .legend-swatch.cell-no-target { background: #f1ebd9; border: 1px dashed var(--text-faint); }

  /* Hero pace-pill helpers (Phase 2A data) */
  .pace.blocked,
  .pace.nodata {
    color: var(--text-faint);
    font-style: italic;
  }
  .hero-metric-value.blocked-value,
  .hero-metric-value.nodata-value {
    color: var(--text-faint);
    opacity: 0.55;
  }

  /* Tint/deep color palette for DECISION-019 (if not already declared) */
  :root {
    --pos-tint:  #EAF3DE;
    --pos-deep:  #173404;
    --warn-tint: #FDE9CC;
    --warn-deep: #412402;
    --neg-tint:  #FCDFDF;
    --neg-deep:  #501313;
  }

  /* ============ GOALS TAB · full detail ============ */
  .goals-manifesto {
    background: linear-gradient(135deg, #ffffff 0%, #f0f8f0 100%);
    border: 1px solid var(--pos);
    border-left: 4px solid var(--pos);
    border-radius: 12px;
    padding: 28px 32px;
    margin-bottom: 24px;
    position: relative;
  }
  .goals-manifesto-label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: var(--pos-dim);
    letter-spacing: 0.2em;
    font-weight: 600;
    margin-bottom: 10px;
  }
  .goals-manifesto-headline {
    font-family: 'Manrope', sans-serif;
    font-weight: 800;
    font-size: 30px;
    letter-spacing: -0.025em;
    line-height: 1.15;
    color: var(--text);
    margin-bottom: 8px;
  }
  .goals-manifesto-headline .hit { color: var(--pos-dim); }
  .goals-manifesto-sub {
    font-family: 'Manrope', sans-serif;
    font-weight: 500;
    font-size: 14px;
    color: var(--text-dim);
    line-height: 1.5;
  }

  .goal-card {
    background: var(--bg-card);
    border-radius: 12px;
    padding: 22px 24px 24px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.02), 0 0 0 1px var(--border);
    position: relative;
  }
  .goal-card.primary {
    border: 2px solid var(--pos);
    box-shadow: 0 4px 16px rgba(24, 228, 24, 0.12), 0 0 0 1px var(--pos);
  }
  .goal-card-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
  }
  .goal-card-name {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 14px;
    letter-spacing: 0.04em;
    color: var(--text);
    text-transform: uppercase;
  }
  .goal-card-target-chip {
    font-family: 'Manrope', sans-serif;
    font-size: 14px;
    font-weight: 800;
    color: var(--pos-dim);
    letter-spacing: 0.02em;
    background: var(--pos-soft);
    padding: 8px 14px;
    border-radius: 6px;
    border: 1px solid rgba(24, 228, 24, 0.3);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
  }
  .goal-card.primary .goal-card-target-chip {
    background: var(--pos);
    color: #0a3d0a;
    border-color: var(--pos-dim);
  }
  .goal-card-body {
    display: flex;
    gap: 20px;
    align-items: center;
  }
  .goal-card-ring {
    position: relative;
    width: 120px;
    height: 120px;
    flex-shrink: 0;
  }
  .goal-card-ring-label {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
  }
  .goal-card-ring-value {
    font-family: 'Manrope', sans-serif;
    font-weight: 800;
    font-size: 30px;
    color: var(--text);
    line-height: 1;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
  }
  .goal-card-ring-pct {
    font-family: 'JetBrains Mono', monospace;
    font-weight: 600;
    font-size: 11px;
    color: var(--text-faint);
    letter-spacing: 0.08em;
    margin-top: 4px;
  }
  .goal-card-details { flex: 1; }
  .goal-detail-line {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-size: 13px;
    border-bottom: 1px solid var(--grid);
  }
  .goal-detail-line:last-child { border-bottom: none; }
  .goal-detail-line .lbl { color: var(--text-faint); }
  .goal-detail-line .val {
    font-family: 'JetBrains Mono', monospace;
    font-weight: 600;
    color: var(--text);
    font-variant-numeric: tabular-nums;
  }
  .goal-detail-line .val.pos { color: var(--pos-dim); }
  .goal-detail-line .val.neg { color: var(--neg-dim); }
  .goal-action-line {
    margin-top: 14px;
    padding: 12px 14px;
    background: var(--bg-elev);
    border-left: 3px solid var(--pos);
    border-radius: 4px;
    font-size: 13px;
    color: var(--text-dim);
    line-height: 1.5;
  }
  .goal-action-line strong { color: var(--text); }
  .goal-action-line.behind { border-left-color: var(--neg); }
  .goal-action-line.warn   { border-left-color: var(--warn-dim); }

  /* Streak chips */
  .streak-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
  }
  .streak-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: 'Manrope', sans-serif;
    font-weight: 600;
    font-size: 11px;
    padding: 5px 10px;
    background: var(--bg-elev);
    border-radius: 20px;
    color: var(--text-dim);
    letter-spacing: 0.02em;
  }
  .streak-chip::before { content: '●'; font-size: 8px; }
  .streak-chip.pos { background: var(--pos-soft); color: var(--pos-dim); }
  .streak-chip.pos::before { color: var(--pos-dim); }
  .streak-chip.warn { background: var(--warn-soft); color: var(--warn-dim); }
  .streak-chip.milestone { background: #1a2b1a; color: var(--pos); }
  .streak-chip.milestone::before { content: '★'; }

  /* Fix 5: small inline freshness signal for column headers / section subs. */
  .freshness-badge {
    font-size: 10px;
    font-weight: 500;
    color: var(--text-faint);
    letter-spacing: 0.04em;
    text-transform: none;
    margin-left: 4px;
  }

  /* revenue hero — for the P&M headline number */
  .rev-hero-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .rev-hero {
    background: linear-gradient(135deg, #ffffff 0%, #f0f8f0 100%);
    border: 2px solid var(--pos);
    border-radius: 12px;
    padding: 28px 32px;
    position: relative;
    overflow: hidden;
  }
  .rev-hero::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 6px; height: 100%;
    background: var(--pos);
  }
  .rev-hero::after {
    /* badge label set by per-card modifier below */
    position: absolute;
    top: 12px; right: 20px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: var(--pos-dim);
    font-weight: 600;
    letter-spacing: 0.15em;
  }
  .rev-hero--home-eft::after { content: 'HOME EFT · OPERATIONAL TRUTH'; }
  .rev-hero--pkg-mem::after  { content: 'PKG+MEM · MEF SCORECARD'; color: var(--accent); }
  .rev-hero--pkg-mem        { border-color: var(--accent);
                               background: linear-gradient(135deg, #ffffff 0%, #f4f0e6 100%); }
  .rev-hero--pkg-mem::before { background: var(--accent); }
  .rev-hero--pkg-mem .rev-hero-value { color: var(--accent); }
  .rev-hero-source {
    margin-top: 14px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: var(--text-faint);
    letter-spacing: 0.06em;
    border-top: 1px dashed var(--border);
    padding-top: 10px;
  }
  .rev-hero-label {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 14px;
    color: var(--text-dim);
    letter-spacing: 0.04em;
    margin-bottom: 10px;
  }
  .rev-hero-value {
    font-family: 'Manrope', sans-serif;
    font-weight: 800;
    font-size: 64px;
    letter-spacing: -0.03em;
    line-height: 1;
    color: var(--pos-dim);
    font-variant-numeric: tabular-nums;
  }
  .rev-hero-foot {
    display: flex;
    gap: 30px;
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid rgba(24, 228, 24, 0.25);
  }
  .rev-hero-foot-item {
    display: flex;
    flex-direction: column;
    gap: 3px;
  }
  .rev-hero-foot-lbl {
    font-family: 'Manrope', sans-serif;
    font-weight: 600;
    font-size: 10px;
    color: var(--text-faint);
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }
  .rev-hero-foot-val {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 16px;
    color: var(--text);
    font-variant-numeric: tabular-nums;
  }
  .rev-hero-foot-val.pos { color: var(--pos-dim); }
  .rev-hero-foot-val.neg { color: var(--neg-dim); }

  /* secondary revenue cards */
  .rev-second-grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr;
    gap: 16px;
    margin-top: 20px;
  }
  .rev-card {
    background: var(--bg-card);
    border-radius: 12px;
    padding: 20px 24px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.02), 0 0 0 1px var(--border);
  }
  .rev-card-label {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 12px;
    color: var(--text-dim);
    letter-spacing: 0.04em;
    margin-bottom: 12px;
  }
  .rev-card-value {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 36px;
    letter-spacing: -0.02em;
    line-height: 1;
    color: var(--text);
    font-variant-numeric: tabular-nums;
  }
  .rev-card-value.info { color: var(--info); }
  .rev-card-foot {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    color: var(--text-faint);
    margin-top: 10px;
    letter-spacing: 0.04em;
  }

  /* small multiples for member states */
  .sm-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
  }
  .sm-card {
    background: var(--bg-elev);
    border-radius: 10px;
    padding: 14px 16px 12px;
    border-top: 3px solid var(--border);
  }
  .sm-card.sm-active  { border-top-color: var(--pos); }
  .sm-card.sm-fp      { border-top-color: var(--info); }
  .sm-card.sm-frozen  { border-top-color: var(--warn); }
  .sm-card.sm-susp    { border-top-color: var(--neg); }
  .sm-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 8px;
  }
  .sm-label {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 12px;
    color: var(--text);
    letter-spacing: 0.02em;
  }
  .sm-latest {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 18px;
    color: var(--text);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.01em;
  }
  .sm-delta {
    font-family: 'JetBrains Mono', monospace;
    font-weight: 500;
    font-size: 10px;
    margin-left: 6px;
    letter-spacing: 0.02em;
  }
  .sm-chart {
    position: relative;
    height: 90px;
  }

  /* tables */
  table.data {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
  }
  table.data th {
    text-align: left;
    font-family: 'Manrope', sans-serif;
    font-weight: 600;
    font-size: 11px;
    letter-spacing: 0.04em;
    color: var(--text-faint);
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
  }
  table.data th.num, table.data td.num {
    text-align: right;
    font-family: 'JetBrains Mono', monospace;
    font-variant-numeric: tabular-nums;
  }
  table.data td {
    padding: 11px 12px;
    border-bottom: 1px solid var(--grid);
    color: var(--text-dim);
  }
  table.data td.name { color: var(--text); }
  table.data tr:hover td { background: var(--bg-elev); color: var(--text); }
  table.data tr.emph td { color: var(--text); font-weight: 600; }
  table.data tr.emph td.num { color: var(--accent); }

  /* hour rows */
  .hour-row {
    display: grid;
    grid-template-columns: 1fr auto auto;
    padding: 10px 0;
    border-bottom: 1px solid var(--grid);
    align-items: baseline;
    gap: 16px;
    font-size: 14px;
  }
  .hour-row:last-child { border-bottom: none; }
  .hour-row .lbl { color: var(--text-dim); }
  .hour-row.emph .lbl { color: var(--text); font-weight: 600; }
  .hour-row .val {
    font-family: 'JetBrains Mono', monospace;
    color: var(--text);
    font-size: 15px;
    font-weight: 500;
    min-width: 80px; text-align: right;
    font-variant-numeric: tabular-nums;
  }
  .hour-row .pct {
    font-family: 'JetBrains Mono', monospace;
    color: var(--text-faint);
    font-size: 12px;
    min-width: 56px; text-align: right;
  }

  /* base pill */
  .base-pill {
    display: flex;
    height: 40px;
    background: var(--bg-elev);
    border-radius: 8px;
    overflow: hidden;
    margin: 14px 0 18px;
  }
  .base-pill .seg {
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Manrope', sans-serif;
    font-size: 12px;
    font-weight: 600;
    color: var(--text);
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
    letter-spacing: 0.02em;
  }

  /* section ribbon */
  .section-ribbon {
    display: flex;
    align-items: baseline;
    gap: 16px;
    margin: 34px 0 18px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border);
  }
  .section-ribbon .letter {
    font-family: 'Manrope', sans-serif;
    font-weight: 800;
    font-size: 22px;
    color: var(--accent);
    line-height: 1;
    letter-spacing: -0.02em;
  }
  .section-ribbon h3 {
    font-family: 'Manrope', sans-serif;
    font-weight: 700;
    font-size: 16px;
    color: var(--text);
    letter-spacing: -0.01em;
  }
  .section-ribbon .ribbon-sub {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    color: var(--text-faint);
    letter-spacing: 0.08em;
    margin-left: auto;
  }

  .tab-content { display: none; animation: fade 0.3s ease; }
  .tab-content.active { display: block; }
  @keyframes fade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

  .footer {
    text-align: center;
    padding: 24px;
    color: var(--text-faint);
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    letter-spacing: 0.12em;
    border-top: 1px solid var(--border);
    margin-top: 20px;
  }

  /* ════════ STAGE D.2 · HISTORY RETROFIT ════════ */
  .hist-row { display: flex; align-items: center; gap: 8px; margin-top: 7px; min-height: 26px; }
  .hist-spark { width: 100px; height: 26px; flex: 0 0 auto; }
  .hist-dly {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.04em;
    white-space: nowrap;
    cursor: help;
  }
  .hist-dly.pos  { color: var(--pos-dim); }
  .hist-dly.neg  { color: var(--neg-dim); }
  .hist-dly.flat { color: var(--text-faint); }
