/* ── PBCCD Dashboard local styles ──────────────────────────────── */

/* dash-header, dash-eyebrow, dash-title, dash-sub,
   meta-strip, meta-cell, meta-label, meta-value → platform-header.css */

/* Layout */
.dash-body { padding-top: var(--sp4); max-width: 1280px; }

/* ── Section nav tiles (top navigation) ───────────────────────── */
.sections-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--sp3);
  margin-bottom: var(--sp5);
}
.sec-card {
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: var(--tile-radius);
  padding: var(--sp4) var(--sp4) var(--sp3);
  position: relative;
  cursor: pointer;
  transition: transform var(--trans), box-shadow var(--trans), border-color var(--trans), background var(--trans);
  box-shadow: var(--shadow-tile-mini);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  gap: var(--sp1);
}
.sec-card:hover {
  transform: translate(-1px, -1px);
  box-shadow: var(--shadow-tile);
  border-color: var(--brand-teal);
  background: var(--surface2);
}
.sec-card.active {
  border-color: var(--brand-teal);
  background: var(--surface2);
  box-shadow: var(--shadow-tile);
}
.sec-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: var(--sp3);
  bottom: var(--sp3);
  width: 3px;
  background: var(--brand-teal);
  border-radius: 0 var(--tile-radius) var(--tile-radius) 0;
  opacity: 1;
}

/* Section-specific handle colours */
.sec-card[data-section="profile_of_body"]::before        { background: var(--brand-teal); }
.sec-card[data-section="governance"]::before             { background: var(--brand-amber); }
.sec-card[data-section="emissions_and_projects"]::before { background: var(--brand-green); }
.sec-card[data-section="adaptation"]::before             { background: var(--brand-soft); }
.sec-card[data-section="procurement"]::before            { background: var(--brand-sand); }
.sec-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.sec-label {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--brand-teal);
  font-weight: 700;
}
.sec-arrow {
  font-size: 10px;
  color: var(--text-f);
  transition: transform var(--trans), color var(--trans);
}
.sec-card:hover .sec-arrow,
.sec-card.active .sec-arrow { color: var(--brand-teal); transform: translateX(2px); }
.sec-name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.01em;
  line-height: 1.25;
}
.sec-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp3);
  margin-top: var(--sp1);
}
.sec-meta-item {
  font-size: 10px;
  color: var(--text-f);
}
.sec-meta-item.has-pending { color: var(--amber); font-weight: 500; }
.sec-meta-item.has-intel { color: var(--brand-teal); }

/* ── Section detail container ─────────────────────────────────── */
#sections-detail { margin-top: var(--sp6); }

/* ── Section accordion (below chart) ──────────────────────────── */

.pbccd-section {
  border: 1px solid var(--divider);
  border-radius: var(--tile-radius);
  margin-bottom: var(--card-gap);
  overflow: hidden;
  background: var(--surface);
  box-shadow: var(--shadow-tile-mini);
  transition: box-shadow var(--trans), border-color var(--trans);
}
.pbccd-section.open {
  border-color: var(--brand-teal);
  box-shadow: var(--shadow-tile);
}
.pbccd-section-head {
  display: flex;
  align-items: center;
  gap: var(--sp4);
  padding: var(--sp4) var(--sp5);
  cursor: pointer;
  user-select: none;
  border-left: 3px solid transparent;
  transition: background var(--trans), border-color var(--trans);
}
.pbccd-section.open .pbccd-section-head {
  background: var(--surface2);
  border-left-color: var(--brand-teal);
}
.pbccd-section-head:hover { background: var(--surface2); }
.pbs-code {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--brand-teal);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  min-width: 2rem;
}
.pbs-name {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text);
  flex: 1;
  letter-spacing: -0.01em;
}
.pbs-meta {
  display: flex;
  align-items: center;
  gap: var(--sp4);
  font-size: var(--text-xs);
}
.pbs-cells { color: var(--text-m); }
.pbs-evidence { color: var(--text-f); }
.pbs-evidence.has-items { color: var(--brand-teal); font-weight: 500; }
.pbs-pending { display: none; }
.pbs-pending.has-pending {
  display: inline;
  color: var(--amber);
  font-weight: 500;
  cursor: pointer;
}
.pbs-pending.has-pending:hover { text-decoration: underline; text-underline-offset: 2px; }
.pbs-chevron {
  font-size: var(--text-xs);
  color: var(--text-f);
  transition: transform var(--trans);
  flex-shrink: 0;
}
.pbccd-section.open .pbs-chevron { transform: rotate(90deg); }
.pbccd-section-body {
  display: none;
  border-top: 1px solid var(--divider);
}
.pbccd-section.open .pbccd-section-body { display: block; }

/* Cell list */
.cells-panel {
  margin-top: var(--sp5);
  display: none;
}
.cells-panel.open { display: block; }
.cells-panel-header {
  padding: var(--sp4) var(--sp5);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.cells-panel-title {
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--text);
  margin: 0;
}
.cells-panel-close {
  background: none;
  border: none;
  color: var(--text-m);
  font-size: var(--text-sm);
  cursor: pointer;
  padding: var(--sp2) var(--sp3);
}
.cells-panel-close:hover { color: var(--text); }

.cell-row {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: var(--sp3);
  padding: var(--sp3) var(--sp4);
  border-bottom: 1px solid var(--divider);
  align-items: start;
}
.cell-row:last-child { border-bottom: none; }
.cell-row:hover { background: var(--surface2); }
.cell-id {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-m);
  text-transform: uppercase;
  padding-top: 2px;
}
.cell-main { min-width: 0; }
.cell-title {
  font-size: var(--text-sm);
  color: var(--text);
  font-weight: 600;
  margin-bottom: var(--sp1);
}
.cell-preview {
  font-size: var(--text-xs);
  color: var(--text-m);
  line-height: 1.5;
  max-height: 4.5em;
  overflow: hidden;
  position: relative;
}
.cell-preview.empty { font-style: italic; color: var(--text-f); }
.cell-preview-metrics {
  display: flex;
  gap: var(--sp4);
  flex-wrap: wrap;
}
.cell-metric {
  font-size: var(--text-xs);
  color: var(--text-m);
}
.cell-metric strong {
  color: var(--text);
  font-weight: 500;
}
.cell-badges {
  display: flex;
  flex-direction: column;
  gap: var(--sp2);
  align-items: flex-end;
  min-width: 110px;
}
.cb {
  display: inline-block;
  padding: 2px var(--sp3);
  border-radius: var(--r-full);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-family: var(--font-body);
  font-weight: 500;
  white-space: nowrap;
}
.cb-type-scalar    { background: rgba(74, 143, 163, .15); color: var(--primary); }
.cb-type-rich_text { background: rgba(74, 143, 163, .15); color: var(--primary); }
.cb-type-metrics   { background: rgba(146, 189, 57, .15); color: var(--green); }
.cb-type-register  { background: rgba(226, 175, 71, .15); color: var(--amber); }

.cb-status-from_pbccd     { background: var(--primary-s); color: var(--primary); }
.cb-status-officer_update { background: var(--green-s); color: var(--green); }
.cb-status-derived        { background: rgba(107, 180, 177, .15); color: var(--brand-soft); }
.cb-status-empty          { background: rgba(72, 79, 88, .2); color: var(--text-f); }
.cb-status-needs_review   { background: var(--amber-s); color: var(--amber); }

/* ── Review intelligence signal strip (ADR-0007) ─────────────── */
.cell-enrich-strip {
  margin-top: var(--sp1);
  padding: var(--sp1) var(--sp2);
  border-radius: var(--r-sm);
  border: 1px solid var(--divider);
  background: var(--surface2);
  font-size: var(--text-xs);
  color: var(--text-f);
  display: flex;
  align-items: center;
  gap: var(--sp2);
  font-family: var(--font-body);
}
.cell-enrich-strip.has-items {
  border-color: color-mix(in srgb, var(--brand-teal) 35%, transparent);
  background: color-mix(in srgb, var(--brand-teal) 6%, var(--surface));
  color: var(--brand-teal);
  cursor: pointer;
  transition: background var(--trans), border-color var(--trans);
}
.cell-enrich-strip.has-items:hover {
  background: color-mix(in srgb, var(--brand-teal) 12%, var(--surface));
  border-color: var(--brand-teal);
}
.ces-count {
  font-weight: 700;
  font-size: var(--text-xs);
  font-feature-settings: "tnum";
}
.ces-label { font-weight: 400; }
.ces-empty { font-style: italic; color: var(--text-f); }

/* Enrichment panel (ADR-0007) */
/* The panel is inserted immediately after its source cell-row.
   A teal left rail joins source cell + panel into one visual unit.
   The 2px bottom border closes the group and separates it from the next cell. */
.enrichment-panel {
  border-left: 3px solid var(--brand-teal);
  border-bottom: 2px solid var(--brand-teal);
  background: color-mix(in srgb, var(--brand-teal) 8%, var(--surface));
  padding: var(--sp3) var(--sp5);
  max-height: 480px;
  overflow-y: auto;
}
/* Source cell: left rail continues and the divider between cell and panel is removed */
.cell-row.has-intel-panel {
  border-left: 3px solid var(--brand-teal);
  border-bottom-color: transparent;
}
.enrichment-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--text-xs);
  color: var(--text-m);
  margin-bottom: var(--sp3);
  padding-bottom: var(--sp2);
  border-bottom: 1px solid var(--divider);
}
.enrichment-panel-item {
  padding: var(--sp2) 0;
  border-bottom: 1px solid var(--divider);
}
.enrichment-panel-item:last-child { border-bottom: none; }
.enrichment-item-head {
  display: flex;
  align-items: center;
  gap: var(--sp2);
  margin-bottom: 4px;
}
.enrichment-ob-id {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  color: var(--primary);
  background: var(--primary-s);
  padding: 1px 5px;
  border-radius: 3px;
}
.enrichment-channel {
  font-size: 10px;
  color: var(--text-m);
  font-weight: 600;
  text-transform: capitalize;
}
.ev-weight {
  font-size: 10px;
  font-weight: 600;
  font-family: var(--font-body);
  padding: 1px 5px;
  border-radius: 3px;
  background: var(--surface2);
  color: var(--text-m);
  text-transform: capitalize;
  border: 1px solid var(--divider);
}
.ev-weight-high   { background: rgba(186,73,73,0.1);  color: var(--red);   border-color: rgba(186,73,73,0.25); }
.ev-weight-medium { background: rgba(226,175,71,0.1); color: var(--amber); border-color: rgba(226,175,71,0.25); }
.ev-weight-low    { background: rgba(50,104,122,0.1); color: var(--primary); border-color: rgba(50,104,122,0.25); }
.ev-date {
  font-size: 10px;
  color: var(--text-f);
  margin-left: auto;
}
.enrich-ch-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp2);
  margin-top: var(--sp2);
}
.enrich-ch-badge {
  font-size: 10px;
  font-family: var(--font-body);
  font-weight: 600;
  padding: 1px var(--sp2);
  border-radius: var(--r-full);
  background: color-mix(in srgb, var(--brand-teal) 12%, var(--surface2));
  color: var(--brand-teal);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.enrich-ob-group {
  border-bottom: 1px solid var(--divider);
  padding-bottom: var(--sp2);
  margin-bottom: var(--sp2);
}
.enrich-ob-group:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.enrich-ob-head {
  display: flex;
  align-items: baseline;
  gap: var(--sp3);
  padding: var(--sp2) 0 var(--sp2) var(--sp3);
}
.enrich-ob-title {
  font-size: var(--text-xs);
  color: var(--text-m);
  font-weight: 500;
}
.enrichment-finding {
  font-size: var(--text-xs);
  color: var(--text-m);
  line-height: 1.5;
  margin: 0;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
}

.cell-source {
  font-size: 10px;
  color: var(--text-f);
  font-family: var(--font-mono);
  text-align: right;
}

/* Question group blocks */
.q-group {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: var(--tile-radius);
  margin: var(--card-gap) var(--sp5);
  overflow: hidden;
  transition: transform var(--trans), box-shadow var(--trans), border-color var(--trans);
  box-shadow: var(--shadow-tile-mini);
}
.q-group::before {
  content: '';
  position: absolute;
  top: 0; left: var(--sp6); right: var(--sp6);
  height: 4px; border-radius: var(--tile-radius);
  background: var(--brand-teal);
  z-index: 1;
}
.q-group:hover { transform: translate(-1px, -1px); box-shadow: var(--shadow-tile-mini-hover); border-color: var(--primary); }
.q-group-head {
  padding: calc(var(--sp4) + 4px) var(--sp5) var(--sp3);
  display: flex;
  align-items: baseline;
  gap: var(--sp2);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--brand-teal);
  font-weight: 600;
  font-family: var(--font-body);
  border-bottom: 1px solid var(--divider);
}
.q-group-num  { color: var(--brand-teal); }
.q-group-sep  { color: var(--text-f); font-weight: 400; letter-spacing: 0; }
.q-group-title { color: var(--text-m); font-weight: 500; letter-spacing: 0.04em; }

.q-group .cell-row { padding: var(--sp2) var(--sp4); }
.q-group .cell-row:last-child { border-bottom: none; }

.loading, .error-box {
  padding: var(--sp6);
  text-align: center;
  color: var(--text-m);
}
.error-box { color: var(--red); }

.empty-spine {
  padding: var(--sp8);
  background: var(--surface);
  border: 1px dashed var(--divider);
  border-radius: var(--tile-radius);
  text-align: center;
  color: var(--text-m);
}
.empty-spine strong { color: var(--text); display: block; margin-bottom: var(--sp2); font-weight: 500; }

/* Register table within cell preview */
.reg-table {
  font-size: 11px;
  width: 100%;
  border-collapse: collapse;
  margin-top: var(--sp2);
}
.reg-table td {
  padding: 3px var(--sp2);
  border-bottom: 1px solid var(--divider);
  color: var(--text-m);
  vertical-align: top;
}
.reg-table td:first-child { color: var(--text); font-weight: 500; }
.reg-more {
  font-size: 10px;
  color: var(--text-f);
  margin-top: var(--sp2);
  font-style: italic;
}

/* ── Officer edit UI ──────────────────────────────────────────── */
.cell-header-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp2);
  margin-bottom: var(--sp1);
}
.cell-header-row .cell-title { margin-bottom: 0; }
.cell-actions {
  display: flex;
  flex-shrink: 0;
  gap: var(--sp2);
}
.cell-action-btn {
  background: none;
  border: 1px solid var(--divider);
  color: var(--text-m);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  padding: 4px var(--sp3);
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: border-color var(--trans), color var(--trans);
}
.cell-action-btn:hover { border-color: var(--brand-teal); color: var(--brand-teal); }
.cell-action-btn.primary {
  border-color: var(--brand-teal);
  color: var(--brand-teal);
}
.cell-action-btn.primary:hover {
  background: var(--primary-s);
}
.cell-action-btn:disabled {
  opacity: 0.5;
  cursor: wait;
}
.cell-edit-wrap {
  margin-top: var(--sp2);
}
.cell-edit-input,
.cell-edit-textarea {
  width: 100%;
  background: var(--surface2);
  border: 1px solid var(--divider);
  border-radius: var(--r-sm);
  padding: var(--sp3);
  color: var(--text);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.5;
  box-sizing: border-box;
}
.cell-edit-input:focus,
.cell-edit-textarea:focus {
  outline: none;
  border-color: var(--brand-teal);
}
.cell-edit-textarea {
  min-height: 320px;
  resize: vertical;
  font-size: var(--text-xs);
}
.cell-show-more {
  display: inline-block;
  background: none;
  border: none;
  color: var(--brand-teal);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  cursor: pointer;
  padding: var(--sp1) 0 0 0;
  line-height: 1.4;
}
.cell-show-more:hover { opacity: 0.75; }
.cell-preview-rt {
  font-size: var(--text-xs);
  color: var(--text-m);
  line-height: 1.5;
  white-space: pre-wrap;
  max-height: 4.5em;
  overflow: hidden;
  transition: max-height .25s ease;
}
.cell-preview-rt.expanded {
  max-height: 40em;
}
.cell-edit-status {
  font-size: var(--text-xs);
  color: var(--text-m);
  padding: var(--sp2) 0;
}
.cell-edit-status.error { color: var(--red); }
.cell-edit-status.success { color: var(--green); }
.cell-readonly-note {
  font-size: 10px;
  color: var(--text-f);
  font-style: italic;
  margin-top: var(--sp2);
  text-align: right;
}

/* ── Net zero trajectory year callout ───────────────────────── */
.nz-year-callout { text-align: right; flex-shrink: 0; }
.nz-year-callout .nyc-label { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--text-f); margin-bottom: 2px; }
.nz-year-callout .nyc-year { font-size: 2.4rem; font-weight: 700; letter-spacing: -.03em; line-height: 1; font-feature-settings: "tnum"; }
.nz-year-callout.on-track .nyc-year  { color: var(--green); }
.nz-year-callout.off-track .nyc-year { color: var(--red); }
.nz-year-callout .nyc-gap { font-size: var(--text-xs); margin-top: var(--sp1); }
.nz-year-callout.on-track .nyc-gap  { color: var(--green); }
.nz-year-callout.off-track .nyc-gap { color: var(--red); }

/* ── Officer identity indicator (header eyebrow) ─────────────── */
.officer-indicator {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: var(--sp2);
  padding: 2px var(--sp3);
  border: 1px solid var(--divider);
  border-radius: var(--r-full);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--text-m);
  text-transform: none;
  letter-spacing: 0;
}
.officer-indicator strong { color: var(--text); font-weight: 500; }
.officer-indicator[hidden] { display: none; }
.officer-change {
  background: none;
  border: none;
  color: var(--brand-teal);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  padding: 0;
  cursor: pointer;
  text-decoration: underline;
}
.officer-change:hover { color: var(--text); }

/* ── Civic Swiss popover ─────────────────────────────────────── */
.cdt-popover-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 200;
  padding: var(--sp6);
  box-sizing: border-box;
}
.cdt-popover-overlay.open { display: flex; }

.cdt-popover {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: var(--tile-radius);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.35);
  width: 100%;
  max-width: 440px;
  padding: var(--sp6) var(--sp5) var(--sp5) calc(var(--sp5) + 12px);
  font-family: var(--font-body);
  box-sizing: border-box;
  max-height: calc(100vh - var(--sp6) * 2);
  overflow-y: auto;
}
.cdt-popover::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--brand-teal);
  border-radius: var(--tile-radius) 0 0 var(--tile-radius);
}
.cdt-popover-eyebrow {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-m);
  margin: 0 0 var(--sp2) 0;
}
.cdt-popover-title {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  font-weight: 400;
  color: var(--text);
  margin: 0 0 var(--sp3) 0;
  letter-spacing: -0.01em;
}
.cdt-popover-lede {
  font-size: var(--text-sm);
  color: var(--text-m);
  line-height: 1.55;
  margin: 0 0 var(--sp4) 0;
}
.cdt-popover-input {
  width: 100%;
  background: var(--surface2);
  border: 1px solid var(--divider);
  border-radius: var(--r-sm);
  padding: var(--sp3);
  color: var(--text);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  box-sizing: border-box;
  margin-bottom: var(--sp4);
}
.cdt-popover-input:focus { outline: none; border-color: var(--brand-teal); }
.cdt-popover-actions {
  display: flex;
  gap: var(--sp3);
  justify-content: flex-end;
  align-items: center;
}
.cdt-popover-cancel {
  background: none;
  border: none;
  color: var(--text-m);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  padding: var(--sp2) var(--sp3);
  cursor: pointer;
}
.cdt-popover-cancel:hover { color: var(--text); }
.cdt-popover-primary {
  background: var(--brand-teal);
  color: #fff;
  border: none;
  border-radius: var(--r-sm);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 700;
  padding: 8px var(--sp4);
  cursor: pointer;
  letter-spacing: 0.02em;
}
.cdt-popover-primary:hover { opacity: 0.9; }
.cdt-popover-error {
  color: var(--red);
  font-size: var(--text-xs);
  margin: 0 0 var(--sp3) 0;
  min-height: 1em;
}

/* ── Register row expand + approve ───────────────────────────── */
.reg-rows-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--sp2);
  margin-top: var(--sp3);
}
.reg-row-card {
  border: 1px solid var(--divider);
  border-radius: var(--r-sm);
  background: var(--surface);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  overflow: hidden;
}
.reg-row-card.pending {
  position: relative;
  border-top: none;
  padding-top: 3px;
}
.reg-row-card.pending::before {
  content: '';
  position: absolute;
  top: 0;
  left: var(--sp3);
  right: var(--sp3);
  height: 3px;
  border-radius: 0 0 var(--tile-radius) var(--tile-radius);
  background: var(--amber);
}
.reg-row-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp3);
  padding: var(--sp3) var(--sp4);
  cursor: pointer;
}
.reg-row-head:hover { background: var(--surface2); }
.reg-row-topic {
  color: var(--text);
  font-weight: 500;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.reg-row-doc {
  color: var(--text-m);
  flex: 2;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.reg-row-flag {
  font-size: 10px;
  padding: 2px var(--sp3);
  border-radius: var(--r-full);
  background: var(--amber-s);
  color: var(--amber);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
  white-space: nowrap;
}
.reg-row-body {
  display: none;
  padding: var(--sp4);
  border-top: 1px solid var(--divider);
  background: var(--surface2);
  color: var(--text);
  line-height: 1.55;
}
.reg-row-card.open .reg-row-body { display: block; }
.reg-row-body dl {
  margin: 0;
  display: grid;
  grid-template-columns: minmax(140px, max-content) 1fr;
  gap: var(--sp2) var(--sp4);
}
.reg-row-body dt {
  color: var(--text-m);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding-top: 2px;
}
.reg-row-body dd {
  margin: 0;
  color: var(--text);
  font-size: var(--text-xs);
  word-break: break-word;
}
.reg-row-body dd a { color: var(--brand-teal); }
.reg-row-body .dd-empty { color: var(--text-f); font-style: italic; }
.reg-row-toggle {
  font-size: 10px;
  color: var(--brand-teal);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
  white-space: nowrap;
}
.reg-row-status {
  flex: 1;
  font-size: var(--text-xs);
  color: var(--text-m);
  font-style: italic;
}
.reg-row-status.error { color: var(--amber); font-style: normal; }

/* ── 5F.1 Approval logic ─────────────────────────────────────── */
.reg-row-badge {
  font-size: 10px;
  font-weight: 500;
  padding: 1px 6px;
  border-radius: var(--tile-radius);
  font-family: var(--font-body);
  white-space: nowrap;
  flex-shrink: 0;
}
.reg-row-badge.verified { background: rgba(50,104,122,0.15); color: var(--brand-teal); }
.reg-row-badge.caveat { background: rgba(226,175,71,0.15); color: var(--amber); }
.reg-row-badge.expired-ack { background: rgba(226,175,71,0.10); color: var(--amber); opacity: 0.8; }
.reg-row-badge.link-missing { background: var(--surface3); color: var(--text-f); }

.reg-approve-form {
  display: flex;
  flex-direction: column;
  gap: var(--sp3);
  width: 100%;
}
.reg-approve-label {
  font-size: var(--text-xs);
  color: var(--text-m);
  font-weight: 500;
}
.reg-approve-label .req { color: var(--amber); margin-left: 2px; }
.reg-approve-textarea {
  width: 100%;
  min-height: 72px;
  padding: var(--sp3);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--surface2);
  color: var(--text);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  resize: vertical;
  box-sizing: border-box;
}
.reg-approve-textarea:focus { outline: 2px solid var(--brand-teal); outline-offset: 1px; }
.reg-approve-expired-notice {
  background: rgba(226,175,71,0.08);
  border: 1px solid rgba(226,175,71,0.3);
  border-radius: var(--r-sm);
  padding: var(--sp3);
  font-size: var(--text-xs);
  color: var(--amber);
  display: flex;
  flex-direction: column;
  gap: var(--sp2);
}
.reg-approve-expired-notice label {
  display: flex;
  align-items: center;
  gap: var(--sp2);
  color: var(--text-m);
  cursor: pointer;
}
.reg-approve-link-notice {
  font-size: var(--text-xs);
  color: var(--text-f);
  font-style: italic;
}
.reg-approve-btns {
  display: flex;
  gap: var(--sp2);
  justify-content: flex-end;
  flex-wrap: wrap;
}
.cell-action-btn.caveat {
  background: rgba(226,175,71,0.1);
  color: var(--amber);
  border-color: rgba(226,175,71,0.3);
}
.cell-action-btn.caveat:hover { background: rgba(226,175,71,0.2); }
.cell-action-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.reg-pending-context { background: rgba(226,175,71,0.06); border: 1px solid rgba(226,175,71,0.2); border-radius: var(--r-sm); padding: var(--sp3) var(--sp4); margin-bottom: var(--sp3); font-size: var(--text-xs); color: var(--text-m); }
.reg-pending-context p { margin: var(--sp1) 0 0 0; line-height: 1.5; }
.reg-pending-why { font-weight: 600; color: var(--amber); font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; }
.reg-pending-meta { margin-top: var(--sp2); color: var(--text-f); display: flex; flex-wrap: wrap; gap: var(--sp2); }

.reg-row-actions {
  display: flex;
  gap: var(--sp2);
  align-items: center;
  justify-content: flex-end;
  margin-top: var(--sp4);
  padding-top: var(--sp3);
  border-top: 1px solid var(--divider);
}
