/* =============================================================================
   Controls — styles for the VanJS control library (public/js/controls/).
   One section per control group. Colour comes only from tokens.
   ========================================================================== */

/* ── primitives ──────────────────────────────────────────────────────────── */

.mark { color: var(--logo-color); display: block; }

.eyebrow,
.kicker {
  font-family: var(--font-mono);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}
.eyebrow { font-size: var(--text-caption); }
.kicker { font-size: 0.6875rem; letter-spacing: 0.1em; }
.caption { font-size: var(--text-caption); color: var(--text-muted); }

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-family: var(--font-mono);
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.2em 0.6em;
  border-radius: var(--radius-pill);
  border: 1px solid currentColor;
  white-space: nowrap;
  line-height: 1.4;
}
.badge--neutral { color: var(--text-muted); }
.badge--accent  { color: var(--accent-emphasis); }
.badge--orange  { color: var(--cta); }
.badge--red     { color: var(--status-danger); }
.badge--sand    { color: var(--gold-300); }
.badge--blue    { color: var(--status-info); }
.badge--violet  { color: var(--plum-300); }

/* severity */
.severity {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.severity__dot { width: 8px; height: 8px; border-radius: var(--radius-pill); background: currentColor; }
.severity--info     { color: var(--status-info); }
.severity--low      { color: var(--status-success); }
.severity--material { color: var(--status-warning); }
.severity--critical { color: var(--status-danger); }

/* status */
.status {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-caption);
  font-weight: 500;
}
.status__dot { width: 9px; height: 9px; border-radius: var(--radius-pill); background: currentColor; }
.status__icon { font-size: 0.75rem; }
.status--done    { color: var(--status-success); }
.status--review  { color: var(--status-warning); }
.status--pending { color: var(--text-muted); }
.status--bare { gap: 0; }

/* delta */
.delta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-family: var(--font-mono);
  font-size: var(--text-caption);
  font-weight: 600;
}
.delta__icon { font-size: 0.625rem; }
.delta--up   { color: var(--status-success); }
.delta--down { color: var(--status-danger); }
.delta--flat { color: var(--text-muted); }

/* bar */
.bar { display: flex; align-items: center; gap: var(--space-3); }
.bar__track {
  flex: 1;
  height: 6px;
  border-radius: var(--radius-pill);
  background: var(--hairline);
  overflow: hidden;
}
.bar__fill { height: 100%; border-radius: var(--radius-pill); }
.bar__fill--accent  { background: var(--accent); }
.bar__fill--cta     { background: var(--cta); }
.bar__fill--info    { background: var(--status-info); }
.bar__fill--success { background: var(--status-success); }
.bar__fill--warning { background: var(--status-warning); }
.bar__fill--danger  { background: var(--status-danger); }
.bar__label {
  font-family: var(--font-mono);
  font-size: var(--text-caption);
  color: var(--text-secondary);
  min-width: 2.5rem;
  text-align: right;
}

/* dial */
.dial__track { stroke: var(--hairline); }
.dial__value { stroke: var(--accent); transition: stroke-dashoffset var(--dur) var(--ease); }
.dial--cta .dial__value { stroke: var(--cta); }
.dial--warning .dial__value { stroke: var(--status-warning); }
.dial__num {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.75rem;
  fill: var(--text-primary);
}
.dial__suffix {
  font-family: var(--font-mono);
  font-size: 0.625rem;
  fill: var(--text-muted);
}

/* doc-chip — document reference card */
.doc-chip {
  display: grid;
  grid-template-columns: 32px 1fr auto;
  gap: var(--space-3);
  align-items: center;
  padding: var(--space-4);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-md);
  background: var(--card-bg);
  transition: border-color var(--dur) var(--ease);
}
.doc-chip:hover { border-color: var(--accent-emphasis); }
.doc-chip__icon {
  width: 32px;
  height: 36px;
  display: grid;
  place-items: center;
  background: var(--accent);
  color: var(--white);
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 0.5625rem;
  letter-spacing: 0.04em;
}
.doc-chip__text { min-width: 0; }
.doc-chip__name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-body-sm);
  color: var(--text-primary);
  word-break: break-word;
}
.doc-chip__meta {
  margin-top: var(--space-1);
  font-family: var(--font-mono);
  font-size: 0.625rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.doc-chip__action {
  font-family: var(--font-mono);
  font-size: 0.625rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-emphasis);
  background: none;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--dur-fast) var(--ease);
}
.doc-chip__action:hover { color: var(--text-primary); }

/* flag-card — bordered card with a left tone-border */
.flag-card {
  display: block;
  width: 100%;
  text-align: left;
  background: var(--card-bg);
  border: 1px solid var(--hairline);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.flag-card--info   { border-left-color: var(--status-info); }
.flag-card--warn   { border-left-color: var(--status-warning); }
.flag-card--danger { border-left-color: var(--status-danger); }
.flag-card--interactive { cursor: pointer; }
.flag-card--interactive:hover {
  border-color: var(--accent-emphasis);
  box-shadow: var(--glow-hover);
}
.flag-card--interactive.flag-card--info:hover   { border-left-color: var(--status-info); }
.flag-card--interactive.flag-card--warn:hover   { border-left-color: var(--status-warning); }
.flag-card--interactive.flag-card--danger:hover { border-left-color: var(--status-danger); }
.flag-card__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-body-sm);
  color: var(--text-primary);
  margin-bottom: var(--space-2);
}
.flag-card__body { font-size: var(--text-body-sm); color: var(--text-secondary); line-height: 1.6; }

/* cite */
.cite {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-1);
  font-family: var(--font-mono);
  font-size: 0.625rem;
  color: var(--accent-emphasis);
  vertical-align: super;
}
.cite__icon { font-size: 0.5rem; }

/* spinner */
.spinner { display: inline-flex; align-items: center; gap: var(--space-2); color: var(--text-muted); }
.spinner__icon { animation: spin 0.7s linear infinite; }
.spinner__label { font-family: var(--font-mono); font-size: var(--text-caption); }
@keyframes spin { to { transform: rotate(360deg); } }

/* divider */
.divider { height: 1px; background: var(--hairline); margin: var(--space-5) 0; }
.divider--labelled {
  height: auto;
  background: none;
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.divider--labelled::before,
.divider--labelled::after { content: ""; flex: 1; height: 1px; background: var(--hairline); }
.divider__label {
  font-family: var(--font-mono);
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}

/* ── topbar ──────────────────────────────────────────────────────────────── */

.topbar {
  position: sticky;
  top: 0;
  z-index: var(--z-topbar);
  display: flex;
  align-items: center;
  gap: var(--space-6);
  height: var(--topbar-h);
  padding: 0 var(--space-6);
  background: color-mix(in srgb, var(--menu-bg) 92%, transparent);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--hairline);
}
.topbar__brand { flex: 0 0 auto; display: flex; align-items: center; gap: var(--space-2); }
/* Deal Intelligence lockup (jack + wordmark) — CSS mask so it themes via --logo-color. */
.topbar__lockup {
  display: block;
  height: 24px;
  width: calc(24px * 2379 / 256);
  background-color: var(--logo-color);
  -webkit-mask: url("/assets/logos/deal-intelligence-lockup.svg") no-repeat left center / contain;
  mask: url("/assets/logos/deal-intelligence-lockup.svg") no-repeat left center / contain;
}
.topbar__by {
  font-size: var(--text-body-xs);
  color: var(--text-muted);
  margin-left: var(--space-1);
  margin-right: calc(-1 * var(--space-1));
}
/* "Vela" wordmark — masked to the same muted colour as the "by" text. */
.topbar__vela {
  display: block;
  height: 12px;
  width: calc(12px * 2498 / 700);
  background-color: var(--text-muted);
  -webkit-mask: url("/assets/logos/vela-wordmark.svg") no-repeat center / contain;
  mask: url("/assets/logos/vela-wordmark.svg") no-repeat center / contain;
}
.topbar__beta { margin-left: var(--space-1); }
.topbar__nav { flex: 1 1 auto; display: flex; justify-content: center; gap: var(--space-5); }
.topbar__link {
  font-family: var(--font-mono);
  font-size: var(--text-caption);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: var(--space-2) 0;
  border-bottom: 2px solid transparent;
  transition: color var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
}
.topbar__link:hover { color: var(--text-secondary); }
.topbar__link.is-active { color: var(--text-primary); border-bottom-color: var(--accent); }
.topbar__right { flex: 0 0 auto; display: flex; align-items: center; gap: var(--space-4); }
.topbar__mode {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  border: 1px solid var(--hairline);
  transition: color var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease),
    background var(--dur-fast) var(--ease);
}
.topbar__mode:hover {
  color: var(--text-primary);
  border-color: var(--hairline-strong);
  background: color-mix(in srgb, var(--text-primary) 6%, transparent);
}
.topbar__user {
  font-family: var(--font-mono);
  font-size: var(--text-caption);
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--text-secondary);
}

/* ── page shell ──────────────────────────────────────────────────────────── */

.app { min-height: 100%; display: flex; flex-direction: column; }
.shell__body { flex: 1; display: flex; }
.shell__sidebar {
  flex: 0 0 var(--sidebar-w);
  border-right: 1px solid var(--hairline);
  padding: var(--space-6) var(--space-5);
  background: color-mix(in srgb, var(--surface-deep) 40%, transparent);
}
.shell__main { flex: 1; min-width: 0; }
.shell__inner { max-width: var(--content-max); margin: 0 auto; padding: var(--space-7) var(--space-6); }

/* ── page header ─────────────────────────────────────────────────────────── */

.page-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-6);
  margin-bottom: var(--space-6);
}
.page-header__text { display: flex; flex-direction: column; gap: var(--space-2); }
.page-header__title { font-size: var(--text-h1); max-width: 22ch; }
.page-header__lede { color: var(--text-secondary); max-width: 56ch; line-height: 1.6; }
.page-header__actions { display: flex; gap: var(--space-3); flex: 0 0 auto; }

/* ── panel ───────────────────────────────────────────────────────────────── */

.panel {
  background: var(--card-bg);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}
/* tone variants — left tone-border / alternate surface / dashed border */
.panel--accent { border-left: 3px solid var(--accent); }
.panel--warn   { border-left: 3px solid var(--status-warning); }
.panel--danger { border-left: 3px solid var(--status-danger); }
.panel--cta    { border-left: 3px solid var(--cta); }
.panel--soft   { background: color-mix(in srgb, var(--card-bg) 60%, transparent); }
.panel--flat   { background: var(--card-bg); }
.panel--deep,
.panel--focal  { background: var(--surface-deep); }
.panel--dashed { border-style: dashed; }
.panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5) var(--space-4);
  border-bottom: 1px solid var(--hairline);
}
.panel__head-text { display: flex; flex-direction: column; gap: var(--space-1); }
.panel__title { font-size: var(--text-h3); }
.panel__actions { display: flex; gap: var(--space-2); }
.panel__body { padding: var(--space-5); }

/* ── card ────────────────────────────────────────────────────────────────── */

.card {
  display: block;
  width: 100%;
  text-align: left;
  background: var(--card-bg);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
}
.card--interactive { cursor: pointer; transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.card--interactive:hover { border-color: var(--accent-emphasis); box-shadow: var(--glow-hover); }

/* ── stat tile / block ───────────────────────────────────────────────────── */

.stat-block { display: grid; grid-template-columns: repeat(var(--stat-cols, 4), 1fr); gap: var(--space-4); }
.stat-tile {
  background: var(--card-bg);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.stat-tile__label {
  font-family: var(--font-mono);
  font-size: var(--text-caption);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
}
.stat-tile__value-row { display: flex; align-items: baseline; gap: var(--space-3); }
.stat-tile__value {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 2.5rem;
  line-height: 1;
  color: var(--text-primary);
}
.stat-tile--cta .stat-tile__value { color: var(--cta); }
.stat-tile--accent .stat-tile__value { color: var(--accent-emphasis); }
.stat-tile__sub { font-size: var(--text-caption); color: var(--text-muted); }

/* ── buttons ─────────────────────────────────────────────────────────────── */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--text-caption);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease),
    color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.btn--md { padding: 0.625rem 1rem; }
.btn--sm { padding: 0.4rem 0.7rem; font-size: 0.6875rem; }
.btn--block { width: 100%; }
.btn__icon { font-size: 0.8em; }
.btn:disabled { opacity: 0.45; cursor: not-allowed; }

.btn--cta {
  background: var(--cta);
  color: var(--white);
  box-shadow: var(--glow-cta);
}
.btn--cta:not(:disabled):hover { background: var(--brand-accent-300); }

.btn--primary {
  background: color-mix(in srgb, var(--text-primary) 12%, transparent);
  border-color: var(--hairline-strong);
  color: var(--text-primary);
}
.btn--primary:not(:disabled):hover { background: color-mix(in srgb, var(--text-primary) 18%, transparent); }

.btn--secondary { border-color: var(--hairline-strong); color: var(--text-secondary); }
.btn--secondary:not(:disabled):hover { border-color: var(--text-secondary); color: var(--text-primary); }

.btn--ghost { color: var(--text-secondary); }
.btn--ghost:not(:disabled):hover {
  background: color-mix(in srgb, var(--text-primary) 8%, transparent);
  color: var(--text-primary);
}

.btn--danger { border-color: var(--status-danger); color: var(--status-danger); }
.btn--danger:not(:disabled):hover {
  background: color-mix(in srgb, var(--status-danger) 14%, transparent);
}

.icon-btn {
  display: grid;
  place-items: center;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  color: var(--text-secondary);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease),
    border-color var(--dur-fast) var(--ease);
}
.icon-btn--md { width: 36px; height: 36px; }
.icon-btn--sm { width: 30px; height: 30px; font-size: 0.85rem; }
.icon-btn--ghost:hover { background: color-mix(in srgb, var(--text-primary) 8%, transparent); color: var(--text-primary); }
.icon-btn--secondary { border-color: var(--hairline-strong); }
.icon-btn--secondary:hover { color: var(--text-primary); border-color: var(--text-secondary); }
.icon-btn:disabled { opacity: 0.45; cursor: not-allowed; }

.btn-group { display: inline-flex; gap: var(--space-2); }

/* ── form controls ───────────────────────────────────────────────────────── */

.field { display: flex; flex-direction: column; gap: var(--space-2); }
.field__label {
  font-family: var(--font-mono);
  font-size: var(--text-caption);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-secondary);
}
.field__req { color: var(--status-danger); margin-left: 0.25em; }
.field__msg { font-size: var(--text-caption); color: var(--text-muted); }
.field__msg--error { color: var(--status-danger); }

.input {
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--text-body-sm);
  color: var(--text-primary);
  background: color-mix(in srgb, var(--surface-deep) 55%, transparent);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-md);
  padding: 0.6rem 0.75rem;
  transition: border-color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease);
}
.input::placeholder { color: var(--text-muted); }
.input:focus { outline: none; border-color: var(--accent); }
.input:disabled { opacity: 0.5; cursor: not-allowed; }
.input--textarea { resize: vertical; line-height: 1.6; }
.field--error .input { border-color: var(--status-danger); }

.input-wrap { position: relative; }
.input-wrap__icon {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  font-size: 0.85rem;
}
.input-wrap .input { padding-left: 2.25rem; }

.select-wrap { position: relative; }
.input--select { appearance: none; padding-right: 2.25rem; cursor: pointer; }
.select-wrap__chevron {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--text-muted);
  font-size: 0.75rem;
}

.search {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  background: color-mix(in srgb, var(--surface-deep) 55%, transparent);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-md);
  padding: 0 0.75rem;
  transition: border-color var(--dur-fast) var(--ease);
}
.search:focus-within { border-color: var(--accent); }
.search__icon { color: var(--text-muted); font-size: 0.85rem; }
.search__input {
  flex: 1;
  border: none;
  background: none;
  padding: 0.55rem 0;
  font-size: var(--text-body-sm);
  color: var(--text-primary);
}
.search__input:focus { outline: none; }
.search__input::placeholder { color: var(--text-muted); }

/* toggle */
.toggle { display: inline-flex; align-items: center; gap: var(--space-3); cursor: pointer; }
.toggle.is-disabled { opacity: 0.5; cursor: not-allowed; }
.toggle__input { position: absolute; opacity: 0; width: 0; height: 0; }
.toggle__track {
  width: 40px;
  height: 22px;
  border-radius: var(--radius-pill);
  background: var(--hairline-strong);
  position: relative;
  transition: background var(--dur-fast) var(--ease);
  flex: 0 0 auto;
}
.toggle__thumb {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  border-radius: var(--radius-pill);
  background: var(--white);
  transition: transform var(--dur-fast) var(--ease);
}
.toggle__input:checked + .toggle__track { background: var(--accent); }
.toggle__input:checked + .toggle__track .toggle__thumb { transform: translateX(18px); }
.toggle__input:focus-visible + .toggle__track { outline: 2px solid var(--accent-emphasis); outline-offset: 2px; }
.toggle__label { font-size: var(--text-body-sm); }

/* checkbox */
.check { display: inline-flex; align-items: center; gap: var(--space-2); cursor: pointer; }
.check.is-disabled { opacity: 0.5; cursor: not-allowed; }
.check__input { position: absolute; opacity: 0; width: 0; height: 0; }
.check__box {
  width: 18px;
  height: 18px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--hairline-strong);
  display: grid;
  place-items: center;
  transition: background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
}
.check__tick { font-size: 0.625rem; color: var(--white); opacity: 0; }
.check__input:checked + .check__box { background: var(--accent); border-color: var(--accent); }
.check__input:checked + .check__box .check__tick { opacity: 1; }
.check__input:focus-visible + .check__box { outline: 2px solid var(--accent-emphasis); outline-offset: 2px; }
.check__label { font-size: var(--text-body-sm); }

/* radio */
.radio { display: inline-flex; align-items: center; gap: var(--space-2); cursor: pointer; }
.radio.is-disabled { opacity: 0.5; cursor: not-allowed; }
.radio__input { position: absolute; opacity: 0; width: 0; height: 0; }
.radio__dot {
  width: 18px;
  height: 18px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--hairline-strong);
  position: relative;
  transition: border-color var(--dur-fast) var(--ease);
}
.radio__dot::after {
  content: "";
  position: absolute;
  inset: 4px;
  border-radius: var(--radius-pill);
  background: var(--accent);
  transform: scale(0);
  transition: transform var(--dur-fast) var(--ease);
}
.radio__input:checked + .radio__dot { border-color: var(--accent); }
.radio__input:checked + .radio__dot::after { transform: scale(1); }
.radio__input:focus-visible + .radio__dot { outline: 2px solid var(--accent-emphasis); outline-offset: 2px; }
.radio__label { font-size: var(--text-body-sm); }

/* ── tabs / seg / breadcrumb ─────────────────────────────────────────────── */

.tabs { display: flex; gap: var(--space-1); border-bottom: 1px solid var(--hairline); }
.tabs__tab {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--text-caption);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 0.7rem 0.9rem;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
}
.tabs__tab:hover { color: var(--text-secondary); }
.tabs__tab.is-active { color: var(--text-primary); border-bottom-color: var(--accent); }

/* seg — segmented control (mockup .segctl): a bordered inline group of options
   with hairline dividers; the active option is filled with the accent. */
.seg {
  display: inline-flex;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.seg__opt {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 0.5rem 0.875rem;
  background: transparent;
  border: none;
  border-right: 1px solid var(--hairline);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.seg__opt:last-child { border-right: none; }
.seg__opt:hover:not(.is-active) { color: var(--accent-emphasis); }
.seg__opt.is-active { background: var(--accent); color: var(--white); }

.crumbs { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-caption); }
.crumbs__link { color: var(--text-muted); }
.crumbs__link:hover { color: var(--text-secondary); }
.crumbs__item { color: var(--text-muted); }
.crumbs__item.is-current { color: var(--text-primary); }
.crumbs__sep { font-size: 0.625rem; color: var(--text-muted); }

/* ── stage nav ───────────────────────────────────────────────────────────── */
/* Mirrors the mockup .stage-btn: mono number / name + sub stack / status text,
   with a left accent-border on the active row. */

.stage-nav { display: flex; flex-direction: column; }
.stage-nav__item {
  display: grid;
  grid-template-columns: 24px 1fr;
  align-items: start;
  column-gap: var(--space-3);
  width: 100%;
  padding: var(--space-3) var(--space-4) var(--space-3) 0;
  background: transparent;
  border: none;
  border-left: 2px solid transparent;
  cursor: pointer;
  text-align: left;
  position: relative;
  transition: border-color var(--dur-fast) var(--ease);
}
.stage-nav__item:hover .stage-nav__name { color: var(--text-primary); }
.stage-nav__item:hover .stage-nav__no { color: var(--accent-emphasis); }
.stage-nav__item.is-active {
  border-left-color: var(--accent-emphasis);
  padding-left: var(--space-2);
}
.stage-nav__item.is-active .stage-nav__no { color: var(--accent-emphasis); }
.stage-nav__item.is-active .stage-nav__name { color: var(--text-primary); }
.stage-nav__item.is-locked { opacity: 0.5; cursor: not-allowed; }
.stage-nav__no {
  font-family: var(--font-mono);
  font-size: var(--text-caption);
  letter-spacing: 0.08em;
  color: var(--text-muted);
  padding-top: 2px;
  transition: color var(--dur-fast) var(--ease);
}
.stage-nav__text { display: flex; flex-direction: column; gap: var(--space-1); min-width: 0; }
.stage-nav__name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-body-sm);
  color: var(--text-secondary);
  transition: color var(--dur-fast) var(--ease);
}
.stage-nav__sub {
  font-family: var(--font-mono);
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
}
/* Stage status — a colored dot at the right edge of the row. */
.stage-nav__dot {
  position: absolute;
  right: 0;
  top: calc(var(--space-4) + 0.35rem);
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: currentColor;
}
.stage-nav__dot--done    { color: var(--status-success); }
.stage-nav__dot--review  { color: var(--status-warning); }
.stage-nav__dot--pending { color: var(--hairline-strong); }
.stage-nav__dot--locked  { color: var(--hairline-strong); }
/* Skipped — a hollow ring: the stage did not run for this deal. */
.stage-nav__dot--skipped {
  color: var(--hairline-strong);
  background: transparent;
  box-shadow: inset 0 0 0 1.5px currentColor;
}

/* ── table ───────────────────────────────────────────────────────────────── */

.table-wrap {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--card-bg);
}
.table { width: 100%; border-collapse: collapse; }
.table__th {
  text-align: left;
  font-family: var(--font-mono);
  font-size: 0.625rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  padding: var(--space-5) var(--space-4) var(--space-3);
  border-bottom: 1px solid var(--hairline);
  background: color-mix(in srgb, var(--surface-deep) 35%, transparent);
}
.table__td {
  padding: var(--space-4);
  border-bottom: 1px solid var(--hairline);
  font-size: var(--text-body-sm);
  color: var(--text-secondary);
  vertical-align: middle;
}
.table--dense .table__td { padding: var(--space-2) var(--space-4); }
.table__tr:last-child .table__td { border-bottom: none; }
.table__tr.is-clickable { cursor: pointer; transition: background var(--dur-fast) var(--ease); }
.table__tr.is-clickable:hover { background: color-mix(in srgb, var(--accent-emphasis) 6%, transparent); box-shadow: inset 3px 0 0 var(--accent-emphasis); }
.table__tr.is-clickable:hover .table__td { color: var(--text-primary); }
.table__th.is-right, .table__td.is-right { text-align: right; }
.table__th.is-center, .table__td.is-center { text-align: center; }
.table__muted { color: var(--text-muted); }
.table__empty { padding: var(--space-7); text-align: center; color: var(--text-muted); }

/* ── overlays ────────────────────────────────────────────────────────────── */

.overlay {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  background: color-mix(in srgb, var(--brand-primary-950) 70%, transparent);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
}

.modal {
  background: var(--menu-bg);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-pop);
  width: 100%;
  display: flex;
  flex-direction: column;
  max-height: 90vh;
}
.modal--sm { max-width: 420px; }
.modal--md { max-width: 600px; }
.modal--lg { max-width: 880px; }
.modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5);
  border-bottom: 1px solid var(--hairline);
}
.modal__title { font-size: var(--text-h3); }
.modal__close, .drawer__close {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-md);
  color: var(--text-muted);
}
.modal__close:hover, .drawer__close:hover { color: var(--text-primary); background: color-mix(in srgb, var(--text-primary) 8%, transparent); }
.modal__body { padding: var(--space-5); overflow-y: auto; }
.modal__foot {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--hairline);
}

.drawer {
  position: fixed;
  top: 0;
  bottom: 0;
  width: min(440px, 92vw);
  background: var(--menu-bg);
  border-left: 1px solid var(--hairline-strong);
  box-shadow: var(--shadow-pop);
  display: flex;
  flex-direction: column;
}
.drawer--right { right: 0; }
.drawer--left { left: 0; border-left: none; border-right: 1px solid var(--hairline-strong); }
.drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5);
  border-bottom: 1px solid var(--hairline);
}
.drawer__title {
  font-family: var(--font-mono);
  font-size: var(--text-caption);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-secondary);
}
.drawer__body { padding: var(--space-5); overflow-y: auto; flex: 1; }

/* tooltip */
.tooltip { position: relative; display: inline-flex; }
.tooltip::after {
  content: attr(data-tooltip);
  position: absolute;
  z-index: var(--z-tooltip);
  padding: 0.35rem 0.55rem;
  border-radius: var(--radius-sm);
  background: var(--brand-primary-950);
  border: 1px solid var(--hairline-strong);
  color: var(--text-primary);
  font-size: var(--text-caption);
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur-fast) var(--ease);
}
.tooltip:hover::after, .tooltip:focus-visible::after { opacity: 1; }
.tooltip--top::after { bottom: calc(100% + 6px); left: 50%; transform: translateX(-50%); }
.tooltip--bottom::after { top: calc(100% + 6px); left: 50%; transform: translateX(-50%); }
.tooltip--left::after { right: calc(100% + 6px); top: 50%; transform: translateY(-50%); }
.tooltip--right::after { left: calc(100% + 6px); top: 50%; transform: translateY(-50%); }

/* toast */
.toast-host {
  position: fixed;
  bottom: var(--space-5);
  right: var(--space-5);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.toast-host > div { display: flex; flex-direction: column; gap: var(--space-2); }
.toast {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  background: var(--menu-bg);
  border: 1px solid var(--hairline-strong);
  border-left: 3px solid var(--text-muted);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-pop);
  padding: var(--space-3) var(--space-4);
  min-width: 280px;
  max-width: 380px;
  animation: toast-in 0.2s var(--ease);
}
@keyframes toast-in { from { opacity: 0; transform: translateY(8px); } }
.toast__icon { font-size: 0.95rem; }
.toast__msg { flex: 1; font-size: var(--text-body-sm); color: var(--text-primary); }
.toast__close { color: var(--text-muted); }
.toast__close:hover { color: var(--text-primary); }
.toast--info { border-left-color: var(--status-info); }
.toast--info .toast__icon { color: var(--status-info); }
.toast--success { border-left-color: var(--status-success); }
.toast--success .toast__icon { color: var(--status-success); }
.toast--warning { border-left-color: var(--status-warning); }
.toast--warning .toast__icon { color: var(--status-warning); }
.toast--danger { border-left-color: var(--status-danger); }
.toast--danger .toast__icon { color: var(--status-danger); }

/* ── placeholder (transitional) ──────────────────────────────────────────── */

.placeholder { display: flex; flex-direction: column; gap: var(--space-3); padding: var(--space-8) 0; }
.placeholder h1 { font-size: var(--text-h1); }
.placeholder__note { font-family: var(--font-mono); font-size: var(--text-caption); color: var(--text-muted); }
