/* Phase 1 — chrome.
   Re-skins the existing top bar, side rail, page-header, buttons, cards,
   chips, table, and outcome surfaces using v2 tokens. Targets BOTH the
   legacy class names rendered by today's templates (`.tc-topbar`,
   `.tc-sidebar`, `.outcome-pill`, …) AND the new `tc-c-*` component
   classes documented in `04_component_patterns.md`, so future templates
   can migrate one surface at a time. */


/* =========================================================================
 * Body shell + grid
 * ========================================================================= */

html { background: var(--tc-bg); }

body.tc-layout {
  background: var(--tc-bg);
  color: var(--tc-ink);
  font: 400 var(--tc-fs-14)/1.5 var(--tc-font-sans);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;

  display: grid;
  grid-template-rows: 44px 1fr;
  grid-template-columns: 184px 1fr;
  grid-template-areas:
    "rail topbar"
    "rail main";
  min-height: 100vh;
  margin: 0;
}

@media (max-width: 1279px) {
  body.tc-layout {
    grid-template-columns: 48px 1fr;
  }
}

.tc-topbar  { grid-area: topbar; }
.tc-sidebar { grid-area: rail; }
.tc-main    { grid-area: main; overflow-y: auto; background: var(--tc-bg); }

.tc-content { padding: var(--tc-s-5) var(--tc-s-6); }

.tc-footer {
  padding: var(--tc-s-6);
  margin-top: var(--tc-s-8);
  border-top: 1px solid var(--tc-rule);
  color: var(--tc-ink-3);
}
.tc-footer p, .tc-footer .text-muted { color: var(--tc-ink-3) !important; }


/* =========================================================================
 * Top bar — canonical (`tc-c-topbar`) and legacy (`tc-topbar`) skin
 * ========================================================================= */

.tc-c-topbar {
  grid-area: topbar;
  background: var(--tc-panel);
  border-bottom: 1px solid var(--tc-rule);
  display: flex;
  align-items: center;
  gap: var(--tc-s-3);
  padding: 0 var(--tc-s-4);
  height: 44px;
}

.tc-c-topbar__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--tc-s-2);
  text-decoration: none;
  color: var(--tc-ink);
  font: 700 var(--tc-fs-13)/1 var(--tc-font-mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.tc-c-topbar__brand:hover { color: var(--tc-brand); }

.tc-c-logo {
  display: inline-block;
  width: 18px;
  height: 18px;
  border-radius: var(--tc-r-1);
  background: var(--tc-brand);
}
[data-theme="stencil"] .tc-c-logo { border-radius: 0; }

.tc-c-topbar__org {
  font: 500 var(--tc-fs-11)/1 var(--tc-font-mono);
  letter-spacing: 0.06em;
  text-transform: lowercase;
  color: var(--tc-ink-3);
  margin-left: var(--tc-s-1);
}

.tc-c-topbar__crumb {
  display: flex;
  align-items: center;
  gap: var(--tc-s-1);
  font: 500 var(--tc-fs-12)/1 var(--tc-font-mono);
  color: var(--tc-ink-3);
}
.tc-c-topbar__crumb > * { color: inherit; }
.tc-c-topbar__crumb .is-current { color: var(--tc-ink); }

.tc-c-topbar__actions {
  display: flex;
  align-items: center;
  gap: var(--tc-s-2);
  margin-left: auto;
}

.tc-c-search-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--tc-s-2);
  height: 30px;
  padding: 0 var(--tc-s-2) 0 var(--tc-s-3);
  width: 360px;
  max-width: 40vw;
  border: 1px solid var(--tc-rule-2);
  border-radius: var(--tc-r-2);
  background: var(--tc-bg);
  color: var(--tc-ink-3);
}
.tc-c-search-wrap:focus-within {
  border-color: var(--tc-link);
  box-shadow: var(--tc-focus);
  background: var(--tc-panel);
}
.tc-c-search-input {
  flex: 1;
  min-width: 0;
  border: 0;
  background: transparent;
  outline: none;
  font: 500 var(--tc-fs-13)/1 var(--tc-font-mono);
  color: var(--tc-ink);
  height: 100%;
  padding: 0;
}
.tc-c-search-input::placeholder { color: var(--tc-ink-3); }
.tc-c-search-wrap kbd {
  padding: 1px 5px;
  background: var(--tc-panel);
  border: 1px solid var(--tc-rule);
  border-bottom-width: 2px;
  border-radius: var(--tc-r-1);
  font: 500 var(--tc-fs-11)/1 var(--tc-font-mono);
  color: var(--tc-ink-2);
}
.tc-c-search-wrap .tc-c-icon { color: var(--tc-ink-3); }
.tc-c-search-wrap .tc-search__results {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--tc-panel);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-2);
  box-shadow: var(--tc-elev-2);
  z-index: 1000;
  max-height: 60vh;
  overflow-y: auto;
}
.tc-c-search-wrap .tc-search__results:empty { display: none; }
[data-theme="stencil"] .tc-c-search-wrap,
[data-theme="stencil"] .tc-c-search-wrap kbd { border-radius: 0; }


/* =========================================================================
 * Top bar — legacy (`tc-topbar`) skin
 * ========================================================================= */

.tc-topbar {
  background: var(--tc-panel);
  border-bottom: 1px solid var(--tc-rule);
  display: flex;
  align-items: center;
  gap: var(--tc-s-3);
  padding: 0 var(--tc-s-4);
  height: 44px;
  box-shadow: none;
}

.tc-topbar-tenant {
  font: 600 var(--tc-fs-13)/1 var(--tc-font-mono);
  color: var(--tc-ink);
  letter-spacing: 0.02em;
}

.tc-topbar-spacer { flex: 1; }


/* =========================================================================
 * Search
 * ========================================================================= */

.tc-search {
  position: relative;
  width: 360px;
  max-width: 40vw;
}

.tc-search__input {
  height: 30px;
  padding: 0 var(--tc-s-3);
  border-radius: var(--tc-r-2);
  border: 1px solid var(--tc-rule-2);
  background: var(--tc-bg);
  color: var(--tc-ink);
  font: 500 var(--tc-fs-13)/1 var(--tc-font-mono);
}
.tc-search__input::placeholder { color: var(--tc-ink-3); }
.tc-search__input:focus {
  outline: none;
  border-color: var(--tc-link);
  box-shadow: var(--tc-focus);
  background: var(--tc-panel);
}

.tc-search__results {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--tc-panel);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-2);
  box-shadow: var(--tc-elev-2);
  z-index: 1000;
  max-height: 60vh;
  overflow-y: auto;
}
.tc-search__results:empty { display: none; }


/* =========================================================================
 * Side rail — canonical (`tc-c-rail`)
 * ========================================================================= */

.tc-c-rail {
  grid-area: rail;
  background: var(--tc-panel);
  border-right: 1px solid var(--tc-rule);
  color: var(--tc-ink-2);
  padding: 0 0 var(--tc-s-3);
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.tc-c-rail__brand {
  display: flex;
  align-items: center;
  gap: var(--tc-s-2);
  padding: var(--tc-s-3) var(--tc-s-4);
  border-bottom: 1px solid var(--tc-rule);
  margin-bottom: var(--tc-s-2);
  text-decoration: none;
  color: var(--tc-ink);
  height: 44px;
  box-sizing: border-box;
}
.tc-c-rail__brand:hover { color: var(--tc-brand); }
.tc-c-rail__brand .tc-c-logo {
  display: inline-block;
  width: 18px;
  height: 18px;
  border-radius: var(--tc-r-1);
  background: var(--tc-brand);
  flex-shrink: 0;
}
[data-theme="stencil"] .tc-c-rail__brand .tc-c-logo { border-radius: 0; }
.tc-c-rail__brand-text {
  display: flex;
  flex-direction: column;
  font: 700 var(--tc-fs-13)/1.1 var(--tc-font-mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  min-width: 0;
}
.tc-c-rail__org {
  font-weight: 500;
  font-size: var(--tc-fs-10);
  letter-spacing: 0.06em;
  text-transform: lowercase;
  color: var(--tc-ink-3);
}

@media (max-width: 1279px) {
  .tc-c-rail__brand-text { display: none; }
  .tc-c-rail__brand { justify-content: center; padding: var(--tc-s-3) 0; }
}

.tc-c-rail__item {
  display: flex;
  align-items: center;
  gap: var(--tc-s-2);
  padding: 6px var(--tc-s-4);
  color: var(--tc-ink-2);
  text-decoration: none;
  font: 500 var(--tc-fs-13)/1.4 var(--tc-font-sans);
  border-left: 2px solid transparent;
  transition: background var(--tc-dur-fast) var(--tc-ease),
              border-color var(--tc-dur-fast) var(--tc-ease),
              color var(--tc-dur-fast) var(--tc-ease);
}
.tc-c-rail__item:hover {
  background: var(--tc-panel-2);
  color: var(--tc-ink);
}
.tc-c-rail__item.is-current,
.tc-c-rail__item[aria-current="page"] {
  background: var(--tc-panel-2);
  border-left-color: var(--tc-brand);
  color: var(--tc-ink);
  font-weight: 600;
}
.tc-c-rail__item:focus-visible { outline: none; box-shadow: var(--tc-focus); }

.tc-c-rail__label { min-width: 0; }

.tc-c-rail[data-density="dense"] .tc-c-rail__item { padding: 4px var(--tc-s-3); font-size: var(--tc-fs-12); }
.tc-c-rail[data-density="cozy"]  .tc-c-rail__item { padding: 8px var(--tc-s-4); }

@media (max-width: 1279px) {
  .tc-c-rail { width: 48px; padding-left: 0; padding-right: 0; }
  .tc-c-rail__item { padding: 6px 0; justify-content: center; }
  .tc-c-rail__label { display: none; }
}


/* =========================================================================
 * Side rail — legacy (`tc-sidebar`)
 * ========================================================================= */

.tc-sidebar {
  background: var(--tc-panel);
  border-right: 1px solid var(--tc-rule);
  color: var(--tc-ink-2);
  padding: var(--tc-s-3) 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.tc-rail-header {
  padding: var(--tc-s-3) var(--tc-s-4) var(--tc-s-2);
  font: 700 var(--tc-fs-12)/1 var(--tc-font-mono);
  color: var(--tc-ink);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--tc-rule);
  margin-bottom: var(--tc-s-2);
}

.tc-nav-section-label {
  font: 700 var(--tc-fs-10)/1 var(--tc-font-mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tc-ink-3);
  padding: var(--tc-s-3) var(--tc-s-4) var(--tc-s-1);
}

.tc-sidebar .tc-nav-link {
  display: flex;
  align-items: center;
  gap: var(--tc-s-2);
  padding: 6px var(--tc-s-4);
  color: var(--tc-ink-2);
  text-decoration: none;
  font: 500 var(--tc-fs-13)/1.4 var(--tc-font-sans);
  border-left: 2px solid transparent;
  transition: background var(--tc-dur-fast) var(--tc-ease),
              border-color var(--tc-dur-fast) var(--tc-ease),
              color var(--tc-dur-fast) var(--tc-ease);
}

.tc-sidebar .tc-nav-link:hover {
  background: var(--tc-panel-2);
  color: var(--tc-ink);
}

.tc-sidebar .tc-nav-link.active {
  background: var(--tc-panel-2);
  border-left-color: var(--tc-brand);
  color: var(--tc-ink);
  font-weight: 600;
}

.tc-rail-footer {
  margin-top: auto;
  padding: var(--tc-s-3) var(--tc-s-4);
  border-top: 1px solid var(--tc-rule);
}

.tc-rail-help {
  width: 28px;
  height: 28px;
  border-radius: var(--tc-r-pill);
  border: 1px solid var(--tc-rule-2);
  background: transparent;
  color: var(--tc-ink-2);
  font: 600 var(--tc-fs-12)/1 var(--tc-font-mono);
  cursor: pointer;
}
.tc-rail-help:hover { background: var(--tc-panel-2); color: var(--tc-ink); }
.tc-rail-help:focus-visible { outline: none; box-shadow: var(--tc-focus); }


/* =========================================================================
 * Progress bar (htmx page transitions)
 * ========================================================================= */

#tc-progress-bar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: transparent;
  z-index: 2000;
  pointer-events: none;
}
#tc-progress-bar[data-state="loading"] {
  background: linear-gradient(90deg, transparent, var(--tc-brand), transparent);
  animation: tc-progress 1.2s linear infinite;
}
@keyframes tc-progress {
  0%   { background-position:  -200% 0; }
  100% { background-position:   200% 0; }
}


/* =========================================================================
 * Page header (legacy class) + breadcrumb
 * ========================================================================= */

.tc-page-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--tc-s-4);
  padding: var(--tc-s-5) var(--tc-s-6) var(--tc-s-4);
  border-bottom: 1px solid var(--tc-rule);
  background: var(--tc-bg);
  min-height: 64px;
}

.tc-page-header__main {
  display: flex;
  flex-direction: column;
  gap: var(--tc-s-1);
  min-width: 0;
}

.tc-page-header__title {
  font: 600 var(--tc-fs-22)/1.2 var(--tc-font-sans);
  letter-spacing: -0.01em;
  color: var(--tc-ink);
  margin: 0;
}
[data-theme="stencil"] .tc-page-header__title {
  font-family: var(--tc-font-serif);
  font-weight: 400;
  font-size: var(--tc-fs-28);
  letter-spacing: -0.01em;
}
.tc-page-header__title .tc-mono {
  font-family: var(--tc-font-mono);
  font-weight: 600;
}

.tc-page-header__subtitle {
  font: 500 var(--tc-fs-12)/1.4 var(--tc-font-mono);
  color: var(--tc-ink-3);
}

.tc-page-header__actions {
  display: flex;
  gap: var(--tc-s-2);
  flex-shrink: 0;
  align-items: center;
}

.tc-page-header .tc-breadcrumb {
  font: 700 var(--tc-fs-10)/1 var(--tc-font-mono);
  color: var(--tc-ink-3);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin: 0;
}
.tc-page-header .tc-breadcrumb a { color: var(--tc-ink-3); text-decoration: none; }
.tc-page-header .tc-breadcrumb a:hover { color: var(--tc-ink); }
.tc-breadcrumb__sep, .tc-breadcrumb-sep { margin: 0 var(--tc-s-1); opacity: 0.5; }


/* =========================================================================
 * Bootstrap component skin (variables + targeted overrides)
 * ========================================================================= */

:root {
  --bs-body-bg: var(--tc-bg);
  --bs-body-color: var(--tc-ink);
  --bs-border-color: var(--tc-rule);
  --bs-link-color: var(--tc-link);
  --bs-link-hover-color: var(--tc-link);
  --bs-primary: var(--tc-brand);
  --bs-secondary: var(--tc-ink-2);
  --bs-success: var(--tc-pass);
  --bs-danger:  var(--tc-fail);
  --bs-warning: var(--tc-warn);
  --bs-info:    var(--tc-run);

  --bs-table-color: var(--tc-ink);
  --bs-table-bg: transparent;
  --bs-table-border-color: var(--tc-rule);
  --bs-table-hover-bg: var(--tc-panel-2);
  --bs-table-cell-padding-y: 6px;
  --bs-table-cell-padding-x: var(--tc-s-3);

  --bs-form-control-bg: var(--tc-panel);
  --bs-form-control-color: var(--tc-ink);

  --bs-card-bg: var(--tc-panel);
  --bs-card-border-color: var(--tc-rule);
  --bs-card-cap-bg: var(--tc-panel-2);
}

/* Buttons */
.btn {
  border-radius: var(--tc-r-2);
  font: 600 var(--tc-fs-12)/1 var(--tc-font-mono);
  letter-spacing: 0.02em;
  height: 30px;
  padding: 0 var(--tc-s-3);
  display: inline-flex;
  align-items: center;
  gap: var(--tc-s-2);
}
.btn-sm { height: 26px; padding: 0 var(--tc-s-2); font-size: var(--tc-fs-11); }
.btn-lg { height: 36px; padding: 0 var(--tc-s-4); font-size: var(--tc-fs-13); }

.btn-primary {
  background-color: var(--tc-brand);
  border-color: transparent;
  color: var(--tc-brand-fg);
}
.btn-primary:hover, .btn-primary:focus {
  background-color: var(--tc-brand-2);
  border-color: transparent;
  color: var(--tc-brand-fg);
}

.btn-secondary, .btn-outline-secondary {
  background-color: transparent;
  border-color: var(--tc-rule-2);
  color: var(--tc-ink);
}
.btn-secondary:hover, .btn-outline-secondary:hover {
  background-color: var(--tc-panel-2);
  border-color: var(--tc-rule-2);
  color: var(--tc-ink);
}

.btn-danger {
  background-color: var(--tc-fail);
  border-color: transparent;
  color: #fff;
}

.btn-link { color: var(--tc-link); text-decoration: none; }
.btn-link:hover { text-decoration: underline; }

.btn:focus-visible { outline: none; box-shadow: var(--tc-focus); }

[data-theme="stencil"] .btn { border-radius: 0; }

/* Cards */
.card {
  background: var(--tc-panel);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-2);
  box-shadow: none;
}
.card-header {
  background: var(--tc-panel-2);
  border-bottom: 1px solid var(--tc-rule);
  font: 600 var(--tc-fs-13)/1.3 var(--tc-font-sans);
  padding: var(--tc-s-3) var(--tc-s-4);
  color: var(--tc-ink);
}
[data-theme="stencil"] .card { border-radius: 0; }

/* Alerts */
.alert {
  border-radius: var(--tc-r-2);
  border: 1px solid var(--tc-rule);
  padding: var(--tc-s-3) var(--tc-s-4);
  font: 500 var(--tc-fs-13)/1.4 var(--tc-font-sans);
}
.alert-info    { background: var(--tc-run-soft);  color: var(--tc-ink); border-color: transparent; }
.alert-success { background: var(--tc-pass-soft); color: var(--tc-ink); border-color: transparent; }
.alert-warning { background: var(--tc-warn-soft); color: var(--tc-ink); border-color: transparent; }
.alert-danger  { background: var(--tc-fail-soft); color: var(--tc-ink); border-color: transparent; }

/* Forms */
.form-control, .form-select {
  height: 32px;
  padding: 4px var(--tc-s-3);
  border-radius: var(--tc-r-2);
  background: var(--tc-panel);
  color: var(--tc-ink);
  border: 1px solid var(--tc-rule-2);
  font: 500 var(--tc-fs-13)/1.3 var(--tc-font-sans);
}
.form-control:focus, .form-select:focus {
  border-color: var(--tc-link);
  box-shadow: var(--tc-focus);
  background: var(--tc-panel);
  color: var(--tc-ink);
}
.form-control::placeholder { color: var(--tc-ink-3); }

.form-label {
  font: 600 var(--tc-fs-12)/1.3 var(--tc-font-sans);
  color: var(--tc-ink-2);
  margin-bottom: 4px;
}

textarea.form-control { height: auto; min-height: 80px; }

/* Tables (Bootstrap + django_tables2) */
.table {
  --bs-table-bg: transparent;
  color: var(--tc-ink);
  margin-bottom: 0;
}
.table > :not(caption) > * > * { border-bottom-color: var(--tc-rule); }
.table thead th {
  font: 700 var(--tc-fs-10)/1.2 var(--tc-font-mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--tc-ink-3);
  border-bottom: 1px solid var(--tc-rule);
  padding: var(--tc-s-2) var(--tc-s-3);
  background: var(--tc-bg);
}
.table tbody td {
  font: 500 var(--tc-fs-13)/1.4 var(--tc-font-mono);
  height: var(--tc-row-h);
  vertical-align: middle;
  padding: 0 var(--tc-s-3);
}
.table tbody tr:hover { background: var(--tc-panel-2); }

.table.tc-c-table--cozy  tbody td { height: var(--tc-row-h-cozy); }
.table.tc-c-table--dense tbody td { height: var(--tc-row-h-dense); }

/* Modals */
.modal-content {
  background: var(--tc-panel);
  color: var(--tc-ink);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-2);
}
.modal-header { border-bottom-color: var(--tc-rule); }
.modal-footer { border-top-color: var(--tc-rule); }

/* Dropdowns */
.dropdown-menu {
  background: var(--tc-panel);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-2);
  box-shadow: var(--tc-elev-2);
  color: var(--tc-ink);
  padding: var(--tc-s-1) 0;
}
.dropdown-item {
  color: var(--tc-ink);
  padding: 6px var(--tc-s-3);
  font: 500 var(--tc-fs-13)/1.3 var(--tc-font-sans);
}
.dropdown-item:hover, .dropdown-item:focus {
  background: var(--tc-panel-2);
  color: var(--tc-ink);
}
.dropdown-divider { border-top-color: var(--tc-rule); }


/* =========================================================================
 * Outcome chips (legacy `.outcome-pill` + new `.tc-c-chip`)
 * Same semantic palette so both renderings agree.
 * ========================================================================= */

.outcome-pill, .tc-c-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--tc-s-1);
  padding: 1px 7px;
  border-radius: var(--tc-r-1);
  font: 600 var(--tc-fs-11)/1.4 var(--tc-font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
  border: 1px solid transparent;
}

.outcome-pill--passed,
.tc-c-chip[data-outcome="passed"]   { color: var(--tc-pass); background: var(--tc-pass-soft); }
.outcome-pill--failed,
.tc-c-chip[data-outcome="failed"]   { color: var(--tc-fail); background: var(--tc-fail-soft); }
.outcome-pill--errored,
.tc-c-chip[data-outcome="errored"]  { color: var(--tc-err);  background: var(--tc-err-soft); }
.outcome-pill--skipped,
.tc-c-chip[data-outcome="skipped"]  { color: var(--tc-skip); background: var(--tc-skip-soft); }
.outcome-pill--aborted,
.tc-c-chip[data-outcome="aborted"]  { color: var(--tc-abort); background: transparent; border: 1px dashed currentColor; }
.outcome-pill--xfailed,
.outcome-pill--xpassed,
.tc-c-chip[data-outcome="xfailed"],
.tc-c-chip[data-outcome="xpassed"]  { color: var(--tc-warn); background: var(--tc-warn-soft); }
.outcome-pill--running,
.tc-c-chip[data-outcome="running"]  { color: var(--tc-run); background: var(--tc-run-soft); }

.outcome-pill--interrupted        { color: var(--tc-warn); background: var(--tc-warn-soft); }
.outcome-pill--internal_error,
.outcome-pill--usage_error        { color: var(--tc-fail); background: var(--tc-fail-soft); }
.outcome-pill--no_tests_collected { color: var(--tc-skip); background: var(--tc-skip-soft); }


/* =========================================================================
 * History strip — doc 06 contract.
 *   Telemetry: monospace glyphs aligned to the text grid (copies into Slack).
 *   Stencil:   mini histogram, bar height encodes severity.
 * Legacy `.tc-history` / `.tc-dot--*` still styled as colored squares for the
 * surfaces that haven't been ported yet.
 * ========================================================================= */

.tc-c-history {
  display: inline-flex;
  align-items: center;
  gap: 0;
  font: 600 var(--tc-fs-12)/1 var(--tc-font-mono);
}
.tc-c-history__cell {
  width: 1ch;
  height: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: inherit;
  cursor: default;
}
a.tc-c-history__cell { cursor: pointer; }
a.tc-c-history__cell:hover::before { filter: brightness(1.1); }
a.tc-c-history__cell:focus-visible {
  outline: none;
  box-shadow: var(--tc-focus);
  border-radius: 2px;
}
.tc-c-history__cell[data-outcome="passed"]::before  { content: "\2588"; color: var(--tc-pass); }
.tc-c-history__cell[data-outcome="failed"]::before  { content: "\2588"; color: var(--tc-fail); }
.tc-c-history__cell[data-outcome="errored"]::before { content: "\2573"; color: var(--tc-err); }
.tc-c-history__cell[data-outcome="skipped"]::before { content: "\00b7"; color: var(--tc-skip); }
.tc-c-history__cell[data-outcome="xfailed"]::before,
.tc-c-history__cell[data-outcome="xpassed"]::before { content: "\2592"; color: var(--tc-warn); }
.tc-c-history__cell[data-outcome="aborted"]::before { content: "\25ef"; color: var(--tc-abort); }
.tc-c-history__cell[data-outcome="running"]::before { content: "\25b6"; color: var(--tc-run); animation: tc-pulse 1.4s ease-in-out infinite; }
.tc-c-history__cell[data-blank]::before             { content: " "; }

@keyframes tc-pulse { 0%, 100% { opacity: 0.4 } 50% { opacity: 1 } }

[data-theme="stencil"] .tc-c-history {
  gap: 1px;
  padding: 0 2px;
  height: 14px;
  border-left: 1px solid var(--tc-rule);
  border-right: 1px solid var(--tc-rule);
  background: var(--tc-panel);
  align-items: flex-end;
}
[data-theme="stencil"] .tc-c-history__cell { width: 4px; padding: 0; }
[data-theme="stencil"] .tc-c-history__cell::before {
  content: "";
  display: block;
  width: 100%;
  background: transparent;
  color: transparent;
  animation: none;
}
[data-theme="stencil"] .tc-c-history__cell[data-outcome="passed"]::before  { height: 4px;  background: var(--tc-pass); }
[data-theme="stencil"] .tc-c-history__cell[data-outcome="failed"]::before  { height: 12px; background: var(--tc-fail); }
[data-theme="stencil"] .tc-c-history__cell[data-outcome="errored"]::before { height: 14px; background: var(--tc-err); }
[data-theme="stencil"] .tc-c-history__cell[data-outcome="xfailed"]::before,
[data-theme="stencil"] .tc-c-history__cell[data-outcome="xpassed"]::before { height: 6px;  background: var(--tc-warn); }
[data-theme="stencil"] .tc-c-history__cell[data-outcome="skipped"]::before { height: 2px;  background: var(--tc-skip); }
[data-theme="stencil"] .tc-c-history__cell[data-outcome="aborted"]::before { height: 8px;  background: transparent; border: 1px solid var(--tc-abort); }
[data-theme="stencil"] .tc-c-history__cell[data-outcome="running"]::before { height: 10px; background: repeating-linear-gradient(135deg, var(--tc-run) 0 2px, transparent 2px 4px); }
[data-theme="stencil"] .tc-c-history__cell[data-blank]::before             { height: 1px;  background: var(--tc-rule); }

@media (prefers-reduced-motion: reduce) {
  .tc-c-history__cell[data-outcome="running"]::before { animation: none; opacity: 1; }
}

/* Legacy dot strip — small filled squares, kept until pages port to v2 markup. */
.tc-history {
  display: inline-flex;
  align-items: center;
  gap: 3px;
}
.tc-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 2px;
  background: var(--tc-rule);
}
.tc-dot--passed   { background: var(--tc-pass); }
.tc-dot--failed   { background: var(--tc-fail); }
.tc-dot--errored  { background: var(--tc-err); }
.tc-dot--skipped  { background: var(--tc-skip); }
.tc-dot--aborted  { background: var(--tc-abort); }
.tc-dot--xfailed,
.tc-dot--xpassed  { background: var(--tc-warn); }
.tc-dot--running  { background: var(--tc-run); }
.tc-dot--current {
  box-shadow: 0 0 0 2px var(--tc-bg), 0 0 0 3px var(--tc-link);
}


/* =========================================================================
 * Row-tinting on the runs/results tables (legacy `.tc-row-outcome--*`)
 * ========================================================================= */

tr[class*="tc-row-outcome--"] > td:first-child {
  border-left-style: solid;
  border-left-width: 3px;
}
tr.tc-row-outcome--passed             > td:first-child { border-left-color: var(--tc-pass); }
tr.tc-row-outcome--failed             > td:first-child { border-left-color: var(--tc-fail); }
tr.tc-row-outcome--errored            > td:first-child { border-left-color: var(--tc-err); }
tr.tc-row-outcome--skipped            > td:first-child { border-left-color: var(--tc-skip); }
tr.tc-row-outcome--aborted            > td:first-child { border-left-color: var(--tc-abort); }
tr.tc-row-outcome--xfailed            > td:first-child { border-left-color: var(--tc-warn); }
tr.tc-row-outcome--xpassed            > td:first-child { border-left-color: var(--tc-warn); }
tr.tc-row-outcome--running            > td:first-child { border-left-color: var(--tc-run); }
tr.tc-row-outcome--interrupted        > td:first-child { border-left-color: var(--tc-warn); }
tr.tc-row-outcome--internal_error     > td:first-child,
tr.tc-row-outcome--usage_error        > td:first-child { border-left-color: var(--tc-fail); }
tr.tc-row-outcome--no_tests_collected > td:first-child { border-left-color: var(--tc-skip); }


/* =========================================================================
 * New tc-c-* component primitives (doc 04)
 * ========================================================================= */

.tc-c-card {
  background: var(--tc-panel);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-2);
}
[data-theme="stencil"] .tc-c-card { border-radius: 0; }
.tc-c-card__head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: var(--tc-s-3) var(--tc-s-4);
  border-bottom: 1px solid var(--tc-rule);
}
.tc-c-card__body { padding: var(--tc-s-4); }

.tc-c-btn {
  height: 30px;
  padding: 0 var(--tc-s-3);
  border-radius: var(--tc-r-2);
  border: 1px solid transparent;
  background: transparent;
  color: var(--tc-ink);
  font: 600 var(--tc-fs-12)/1 var(--tc-font-mono);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: var(--tc-s-2);
  transition: background var(--tc-dur-fast) var(--tc-ease);
}
.tc-c-btn--primary  { background: var(--tc-brand); color: var(--tc-brand-fg); }
.tc-c-btn--primary:hover { background: var(--tc-brand-2); }
.tc-c-btn--ghost    { border-color: var(--tc-rule-2); }
.tc-c-btn--ghost:hover { background: var(--tc-panel-2); }
.tc-c-btn--danger   { background: var(--tc-fail); color: #fff; }
.tc-c-btn:focus-visible { outline: none; box-shadow: var(--tc-focus); }
[data-theme="stencil"] .tc-c-btn { border-radius: 0; }

.tc-c-table { width: 100%; border-collapse: collapse; font: 500 var(--tc-fs-13)/1.4 var(--tc-font-mono); }
.tc-c-table th {
  font: 700 var(--tc-fs-10)/1 var(--tc-font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--tc-ink-3);
  padding: var(--tc-s-2) var(--tc-s-3);
  border-bottom: 1px solid var(--tc-rule);
  text-align: left;
}
.tc-c-table td {
  height: var(--tc-row-h);
  padding: 0 var(--tc-s-3);
  border-bottom: 1px solid var(--tc-rule);
  vertical-align: middle;
}
.tc-c-table td.num, .tc-c-table th.num { text-align: right; font-variant-numeric: tabular-nums; }
.tc-c-table tbody tr:hover { background: var(--tc-panel-2); }
.tc-c-table tbody tr[data-outcome="failed"]  { background: var(--tc-fail-soft); }
.tc-c-table tbody tr[data-outcome="errored"] { background: var(--tc-err-soft); }


/* =========================================================================
 * Inline SVG icon (chrome). Inherits color, no font dependency.
 * ========================================================================= */

.tc-c-icon {
  flex-shrink: 0;
  vertical-align: middle;
  color: currentColor;
}


/* =========================================================================
 * Skip link — first focusable element; lifts into view on focus
 * ========================================================================= */

.tc-c-skiplink {
  position: absolute;
  top: 0;
  left: 0;
  padding: var(--tc-s-2) var(--tc-s-3);
  background: var(--tc-brand);
  color: var(--tc-brand-fg);
  font: 600 var(--tc-fs-13)/1 var(--tc-font-sans);
  text-decoration: none;
  border-radius: 0 0 var(--tc-r-2) 0;
  transform: translateY(-200%);
  transition: transform var(--tc-dur-fast) var(--tc-ease);
  z-index: 1090;
}
.tc-c-skiplink:focus {
  transform: translateY(0);
  outline: none;
  box-shadow: var(--tc-focus);
  color: var(--tc-brand-fg);
}


/* =========================================================================
 * User menu (top bar action) — Bootstrap dropdown skinned + theme radios
 * ========================================================================= */

.tc-c-user-menu { position: relative; }

.tc-c-user-trigger {
  width: 30px;
  height: 30px;
  border-radius: var(--tc-r-pill);
  border: 1px solid var(--tc-rule-2);
  background: var(--tc-bg);
  color: var(--tc-ink);
  font: 600 var(--tc-fs-12)/1 var(--tc-font-mono);
  letter-spacing: 0.04em;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.tc-c-user-trigger:hover { border-color: var(--tc-link); }
.tc-c-user-trigger:focus-visible { outline: none; box-shadow: var(--tc-focus); }

.tc-c-user-dropdown {
  min-width: 260px;
  padding: var(--tc-s-2) 0;
  background: var(--tc-panel);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-2);
  box-shadow: var(--tc-elev-2);
  color: var(--tc-ink);
}
[data-theme="stencil"] .tc-c-user-dropdown { border-radius: 0; }

.tc-c-user-dropdown fieldset { border: 0; padding: 0; margin: 0 0 var(--tc-s-2); }
.tc-c-user-dropdown legend {
  font: 700 var(--tc-fs-10)/1 var(--tc-font-mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tc-ink-3);
  margin-bottom: var(--tc-s-1);
  padding: 0;
  width: auto;
}
.tc-c-user-dropdown label {
  display: flex;
  align-items: center;
  gap: var(--tc-s-2);
  padding: 4px 0;
  font: 500 var(--tc-fs-13)/1.4 var(--tc-font-sans);
  color: var(--tc-ink);
  cursor: pointer;
}
.tc-c-user-dropdown input[type="radio"] { accent-color: var(--tc-brand); }


/* =========================================================================
 * Tag pill (canonical `tc-c-tag`) — used by TCD list, run detail
 * ========================================================================= */

.tc-c-tag {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 1px var(--tc-s-2);
  border-radius: var(--tc-r-1);
  background: var(--tc-panel-2);
  border: 1px solid var(--tc-rule);
  color: var(--tc-ink-2);
  font: 500 var(--tc-fs-11)/1.4 var(--tc-font-mono);
  text-decoration: none;
  white-space: nowrap;
}
.tc-c-tag:hover { color: var(--tc-link); border-color: var(--tc-link); }
.tc-c-tag[data-removable] { padding-right: 4px; }
.tc-c-tag__remove {
  background: none; border: 0; padding: 0 2px;
  color: var(--tc-ink-3); cursor: pointer; line-height: 1;
}
.tc-c-tag__remove:hover { color: var(--tc-fail); }


/* =========================================================================
 * Command palette modal (doc 07)
 *   ⌘K / Ctrl+K opens; Esc closes (Bootstrap default).
 *   Markup is a Bootstrap modal; the .modal-content is sized + skinned.
 * ========================================================================= */

.tc-c-palette-modal .modal-dialog {
  max-width: 640px;
  margin-top: 12vh;
}
.tc-c-palette {
  background: var(--tc-panel);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-3);
  box-shadow: var(--tc-elev-3);
  overflow: hidden;
  color: var(--tc-ink);
}
[data-theme="stencil"] .tc-c-palette { border-radius: 0; }

.tc-c-palette__head {
  display: flex;
  align-items: center;
  gap: var(--tc-s-3);
  padding: var(--tc-s-3) var(--tc-s-4);
  border-bottom: 1px solid var(--tc-rule);
  background: var(--tc-bg);
}
.tc-c-palette__head .tc-c-icon { color: var(--tc-ink-3); flex-shrink: 0; }

.tc-c-palette__input {
  flex: 1;
  border: 0;
  outline: none;
  background: transparent;
  color: var(--tc-ink);
  font: 500 var(--tc-fs-16)/1.2 var(--tc-font-sans);
}
.tc-c-palette__input::placeholder { color: var(--tc-ink-3); }

.tc-c-palette__head kbd {
  padding: 2px 6px;
  background: var(--tc-panel);
  border: 1px solid var(--tc-rule);
  border-bottom-width: 2px;
  border-radius: var(--tc-r-1);
  font: 500 var(--tc-fs-11)/1 var(--tc-font-mono);
  color: var(--tc-ink-3);
  text-transform: uppercase;
}

.tc-c-palette__results {
  max-height: 60vh;
  overflow-y: auto;
  padding: var(--tc-s-2) 0;
}
.tc-c-palette__results .tc-search-group { padding: var(--tc-s-2) 0; }
.tc-c-palette__results .tc-search-group__label {
  padding: 0 var(--tc-s-4);
  font: 700 var(--tc-fs-10)/1 var(--tc-font-mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tc-ink-3);
  margin-bottom: 4px;
}
.tc-c-palette__results .tc-search-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 6px var(--tc-s-4);
  text-decoration: none;
  color: var(--tc-ink);
}
.tc-c-palette__results .tc-search-item:hover,
.tc-c-palette__results .tc-search-item:focus-visible {
  background: var(--tc-panel-2);
  outline: none;
}
.tc-c-palette__results .tc-search-item__primary {
  font: 500 var(--tc-fs-13)/1.4 var(--tc-font-mono);
  color: var(--tc-ink);
}
.tc-c-palette__results .tc-search-item__meta {
  font: 500 var(--tc-fs-11)/1.4 var(--tc-font-mono);
  color: var(--tc-ink-3);
  display: flex;
  gap: var(--tc-s-2);
  align-items: center;
}
.tc-c-palette__results .tc-search-empty {
  padding: var(--tc-s-4);
  color: var(--tc-ink-3);
  font: 500 var(--tc-fs-13)/1.4 var(--tc-font-mono);
}

.tc-c-palette__hint {
  padding: var(--tc-s-3) var(--tc-s-4);
  color: var(--tc-ink-3);
  font: 500 var(--tc-fs-12)/1.5 var(--tc-font-sans);
}
.tc-c-palette__hint p { margin: 4px 0 0; }
.tc-c-palette__hint kbd {
  padding: 1px 5px;
  background: var(--tc-bg);
  border: 1px solid var(--tc-rule);
  border-bottom-width: 2px;
  border-radius: var(--tc-r-1);
  font: 500 var(--tc-fs-11)/1 var(--tc-font-mono);
  color: var(--tc-ink-2);
}


/* =========================================================================
 * Empty-state primitive (`tc-c-empty`) — doc 05 universal pattern
 * vertical · 24px outlined icon · headline · hint · primary action OR
 * one-line CLI snippet (never both).
 * ========================================================================= */

.tc-c-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: var(--tc-s-2);
  padding: var(--tc-s-8) var(--tc-s-6);
  border: 1px dashed var(--tc-rule-2);
  border-radius: var(--tc-r-2);
  background: var(--tc-panel);
  color: var(--tc-ink-3);
}
[data-theme="stencil"] .tc-c-empty { border-radius: 0; }

.tc-c-empty__icon { color: var(--tc-ink-3); width: 24px; height: 24px; }
.tc-c-empty__title {
  font: 400 var(--tc-fs-22)/1.2 var(--tc-font-serif);
  color: var(--tc-ink);
  margin: 0;
  letter-spacing: -0.01em;
}
.tc-c-empty__hint {
  font: 500 var(--tc-fs-13)/1.5 var(--tc-font-sans);
  color: var(--tc-ink-2);
  max-width: 56ch;
  margin: 0;
}
.tc-c-empty__action { margin-top: var(--tc-s-3); display: inline-flex; gap: var(--tc-s-2); }
.tc-c-empty__cli {
  margin-top: var(--tc-s-3);
  padding: var(--tc-s-2) var(--tc-s-3);
  background: var(--tc-bg);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-2);
  font: 500 var(--tc-fs-12)/1.4 var(--tc-font-mono);
  color: var(--tc-ink);
  user-select: all;
}
[data-theme="stencil"] .tc-c-empty__cli { border-radius: 0; }


/* =========================================================================
 * Toast / banner (canonical `tc-c-toast`, `tc-c-banner`)
 *   - Toast: top-right floater, auto-dismiss in 6s.
 *   - Banner: full-width inside page body. data-tone scopes the accent.
 * ========================================================================= */

.tc-c-toast-stack {
  position: fixed;
  top: var(--tc-s-1);
  right: var(--tc-s-1);
  display: flex;
  flex-direction: column;
  gap: var(--tc-s-2);
  z-index: 1080;
  pointer-events: none;
}

.tc-c-toast {
  pointer-events: auto;
  background: var(--tc-panel);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-2);
  box-shadow: var(--tc-elev-2);
  padding: var(--tc-s-3) var(--tc-s-4);
  font: 500 var(--tc-fs-13)/1.4 var(--tc-font-sans);
  color: var(--tc-ink);
  min-width: 240px;
  max-width: 380px;
}
[data-theme="stencil"] .tc-c-toast { border-radius: 0; }

.tc-c-toast[data-tone="success"] { border-left: 3px solid var(--tc-pass); }
.tc-c-toast[data-tone="info"]    { border-left: 3px solid var(--tc-run); }
.tc-c-toast[data-tone="warn"]    { border-left: 3px solid var(--tc-warn); }
.tc-c-toast[data-tone="danger"]  { border-left: 3px solid var(--tc-fail); }

.tc-c-banner {
  display: flex;
  align-items: center;
  gap: var(--tc-s-3);
  padding: var(--tc-s-3) var(--tc-s-4);
  background: var(--tc-panel);
  border: 1px solid var(--tc-rule);
  border-left-width: 3px;
  border-radius: var(--tc-r-2);
  font: 500 var(--tc-fs-13)/1.4 var(--tc-font-sans);
  color: var(--tc-ink);
}
[data-theme="stencil"] .tc-c-banner { border-radius: 0; }
.tc-c-banner[data-tone="success"] { border-left-color: var(--tc-pass); background: var(--tc-pass-soft); }
.tc-c-banner[data-tone="info"]    { border-left-color: var(--tc-run);  background: var(--tc-run-soft); }
.tc-c-banner[data-tone="warn"]    { border-left-color: var(--tc-warn); background: var(--tc-warn-soft); }
.tc-c-banner[data-tone="danger"]  { border-left-color: var(--tc-fail); background: var(--tc-fail-soft); }


/* =========================================================================
 * Form: required dot (doc 04 — never an asterisk)
 * ========================================================================= */

.form-label.is-required::before,
label.is-required::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  margin-right: 6px;
  margin-bottom: 1px;
  border-radius: 50%;
  background: var(--tc-fail);
  vertical-align: middle;
}


/* =========================================================================
 * Misc legacy helpers re-skinned (kept minimal — full ports in later phases)
 * ========================================================================= */

.tc-section-label, .tc-nav-section-label {
  color: var(--tc-ink-3);
}

.tc-empty-state {
  padding: var(--tc-s-6);
  border: 1px dashed var(--tc-rule-2);
  border-radius: var(--tc-r-2);
  background: var(--tc-panel);
  color: var(--tc-ink);
}
.tc-empty-state code {
  font: 500 var(--tc-fs-12)/1.4 var(--tc-font-mono);
  background: var(--tc-bg);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-1);
  padding: 1px 4px;
  color: var(--tc-ink);
}

.tc-filter-row {
  display: flex;
  gap: var(--tc-s-2);
  align-items: end;
  padding: var(--tc-s-3) var(--tc-s-6);
  border-bottom: 1px solid var(--tc-rule);
  background: var(--tc-panel);
}

.tc-row-action      { color: var(--tc-ink-3); }
.tc-row-action:hover { color: var(--tc-ink); }
.tc-row-action--danger:hover { color: var(--tc-fail); }

.tc-count-link { color: var(--tc-link); text-decoration: none; }
.tc-count-link:hover { text-decoration: underline; }

.tc-meta-label   { color: var(--tc-ink-3); text-transform: uppercase; letter-spacing: 0.04em; }
.tc-metadata-strip {
  background: var(--tc-panel);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-2);
  color: var(--tc-ink);
}
.tc-metadata-strip .tc-metadata-label { color: var(--tc-ink-3); }
.tc-metadata-strip .tc-metadata-name,
.tc-metadata-strip .tc-metadata-value { color: var(--tc-ink); }

.tc-chip {
  background: var(--tc-panel-2);
  border: 1px solid var(--tc-rule);
  color: var(--tc-ink-2);
  border-radius: var(--tc-r-1);
}
.tc-chip:hover { color: var(--tc-link); border-color: var(--tc-link); }


/* =========================================================================
 * Modal swap target — keep dialogs readable until Phase 3 ports them
 * ========================================================================= */

.modal-backdrop { background-color: rgba(11, 13, 18, 0.55); }
[data-scheme="dark"] .modal-backdrop { background-color: rgba(0, 0, 0, 0.7); }

.close, .btn-close { filter: none; }
[data-scheme="dark"] .btn-close { filter: invert(1) grayscale(1) brightness(2); }


/* =========================================================================
 * Stencil-only chrome
 *   - Drops every radius to 0 (paper feel; doc 02 + doc 04 contract).
 *   - Graph-paper background on the page body (cards remain solid panels
 *     so they contrast with the texture).
 *   - Heavier rule between rail / topbar so panels read like cuts in paper.
 * ========================================================================= */

[data-theme="stencil"] {
  --tc-r-1: 0;
  --tc-r-2: 0;
  --tc-r-3: 0;
  --tc-r-pill: 0;
}

[data-theme="stencil"] body.tc-layout,
[data-theme="stencil"] body.tc-share-layout {
  background-image: var(--tc-graph-paper);
  background-attachment: fixed;
}
[data-theme="stencil"] .tc-topbar,
[data-theme="stencil"] .tc-c-topbar,
[data-theme="stencil"] .tc-sidebar,
[data-theme="stencil"] .tc-c-rail,
[data-theme="stencil"] .tc-c-card,
[data-theme="stencil"] .card,
[data-theme="stencil"] .modal-content,
[data-theme="stencil"] .tc-c-toast,
[data-theme="stencil"] .tc-c-banner,
[data-theme="stencil"] .tc-c-palette,
[data-theme="stencil"] .tc-c-empty {
  background-image: none;
}

[data-theme="stencil"] .tc-c-topbar,
[data-theme="stencil"] .tc-topbar { border-bottom-width: 1px; border-bottom-color: var(--tc-rule-2); }
[data-theme="stencil"] .tc-c-rail,
[data-theme="stencil"] .tc-sidebar { border-right-width: 1px; border-right-color: var(--tc-rule-2); }

/* Slightly heavier hairlines on stencil tables so the row grid reads even
   on the graph-paper backdrop. */
[data-theme="stencil"] .tc-c-table td,
[data-theme="stencil"] .tc-c-table th,
[data-theme="stencil"] .table > :not(caption) > * > * {
  border-bottom-color: var(--tc-rule-2);
}

/* Stencil typography: reinforce serif display moments where the bundle uses
   Instrument Serif (page titles, KPI numbers, share receipt headline,
   empty-state titles all already serif by component). Suite chips + buttons
   stay mono. */
[data-theme="stencil"] .tc-c-rail__brand-text { letter-spacing: 0.16em; }
[data-theme="stencil"] .tc-c-topbar__brand,
[data-theme="stencil"] .tc-c-rail__brand,
[data-theme="stencil"] .tc-c-search-wrap kbd,
[data-theme="stencil"] .tc-c-palette__head kbd { letter-spacing: 0.06em; }

/* Don't pulse on stencil — paper aesthetic looks weird with attention pulses.
   Keep colour cue, drop animation. */
[data-theme="stencil"] .tc-flake-alert__pulse { animation: none; opacity: 0.9; }
[data-theme="stencil"] .tc-rule-row--breach .tc-rule-led { animation: none; }


/* =========================================================================
 * A11y polish
 *   - Universal :focus-visible ring on interactive surfaces.
 *   - Sortable header indicator from `aria-sort`.
 *   - Forced-colors fallback (Windows high-contrast).
 * ========================================================================= */

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible,
.tc-filter-chip:focus-visible,
.tc-c-tag:focus-visible,
.dropdown-item:focus-visible,
tr[data-href]:focus-visible {
  outline: none;
  box-shadow: var(--tc-focus);
  border-radius: var(--tc-r-2);
}

.table th[aria-sort="ascending"]::after,
.tc-c-table th[aria-sort="ascending"]::after { content: " ↑"; color: var(--tc-ink-2); }
.table th[aria-sort="descending"]::after,
.tc-c-table th[aria-sort="descending"]::after { content: " ↓"; color: var(--tc-ink-2); }
.table th[aria-sort],
.tc-c-table th[aria-sort] { cursor: pointer; }

@media (forced-colors: active) {
  /* Use the OS-provided palette for outcome cues so the strip is still
     readable when custom colors are stripped. */
  .tc-c-history__cell::before,
  .outcome-pill,
  .tc-c-chip { forced-color-adjust: none; }
  :focus-visible { outline: 2px solid Highlight !important; box-shadow: none !important; }
}


/* =========================================================================
 * TCD audit history timeline (FEAT-2)
 *   Secondary-weight panel on the TCD detail page. A thin guide rail with
 *   one node per revision; action chips reuse the semantic outcome palette.
 * ========================================================================= */

.tc-history {
  margin-top: var(--tc-s-8);
  padding-top: var(--tc-s-5);
  border-top: 1px solid var(--tc-rule);
}
.tc-history__head {
  display: flex;
  align-items: baseline;
  gap: var(--tc-s-3);
  margin-bottom: var(--tc-s-4);
}
.tc-history__title {
  margin: 0;
  font: 700 var(--tc-fs-11)/1 var(--tc-font-mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tc-ink-3);
}
.tc-history__count { font-size: var(--tc-fs-11); color: var(--tc-ink-3); }
.tc-history__empty { margin: 0; }

.tc-rev-timeline {
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
}
/* The guide rail runs through the node column. */
.tc-rev-timeline::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 4px;
  bottom: 4px;
  width: 1px;
  background: var(--tc-rule);
}

.tc-rev {
  position: relative;
  display: flex;
  gap: var(--tc-s-3);
  padding: var(--tc-s-2) 0 var(--tc-s-3) var(--tc-s-5);
}
.tc-rev__node {
  position: absolute;
  left: 1px;
  top: 9px;
  width: 9px;
  height: 9px;
  border-radius: var(--tc-r-pill);
  background: var(--tc-panel);
  border: 2px solid var(--tc-rule-2);
}
[data-theme="stencil"] .tc-rev__node { border-radius: 0; }
/* Tint the node by action so the rail reads at a glance. */
.tc-rev[data-action="created"]   .tc-rev__node,
.tc-rev[data-action="restored"]  .tc-rev__node { border-color: var(--tc-pass); }
.tc-rev[data-action="soft_deleted"]     .tc-rev__node,
.tc-rev[data-action="bulk_deactivated"] .tc-rev__node { border-color: var(--tc-fail); }
.tc-rev[data-action="imported"]  .tc-rev__node { border-color: var(--tc-run); }

.tc-rev__body { flex: 1; min-width: 0; }
.tc-rev__head {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--tc-s-2);
}
.tc-rev__no { font-size: var(--tc-fs-11); color: var(--tc-ink-3); }
.tc-rev__action {
  display: inline-flex;
  align-items: center;
  padding: 1px var(--tc-s-2);
  border-radius: var(--tc-r-1);
  font: 600 var(--tc-fs-11)/1.4 var(--tc-font-mono);
  background: var(--tc-panel-2);
  color: var(--tc-ink-2);
}
.tc-rev__action--created,
.tc-rev__action--restored { color: var(--tc-pass); background: var(--tc-pass-soft); }
.tc-rev__action--soft_deleted,
.tc-rev__action--bulk_deactivated { color: var(--tc-fail); background: var(--tc-fail-soft); }
.tc-rev__action--imported { color: var(--tc-run); background: var(--tc-run-soft); }

.tc-rev__meta {
  display: inline-flex;
  align-items: center;
  gap: var(--tc-s-1);
  font: 500 var(--tc-fs-11)/1.4 var(--tc-font-mono);
  color: var(--tc-ink-3);
  margin-left: auto;
}
.tc-rev__actor {
  max-width: 16rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tc-rev__changes {
  list-style: none;
  margin: var(--tc-s-2) 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.tc-rev__change {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: var(--tc-s-2);
  font-size: var(--tc-fs-12);
}
.tc-rev__field {
  flex: 0 0 auto;
  min-width: 5.5rem;
  color: var(--tc-ink-3);
  font: 500 var(--tc-fs-11)/1.4 var(--tc-font-mono);
}
.tc-rev__old, .tc-rev__new {
  font-size: var(--tc-fs-12);
  max-width: 22rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tc-rev__old { color: var(--tc-ink-3); text-decoration: line-through; }
.tc-rev__new { color: var(--tc-ink); }
.tc-rev__arrow { color: var(--tc-ink-3); }
.tc-rev__note { margin: var(--tc-s-1) 0 0; font-size: var(--tc-fs-12); color: var(--tc-ink-3); }

.tc-rev--more { padding-left: var(--tc-s-5); padding-top: var(--tc-s-2); }
.tc-rev--more .tc-c-btn { font-size: var(--tc-fs-11); }



/* =========================================================================
 * Saved filters (FEAT-3) — toolbar trigger + dropdown menu + save modal
 *   Lives in the list-page toolbar area; styled to feel native to the
 *   existing chip / dropdown language (same panel, rule, brand tokens).
 * ========================================================================= */

.tc-toolbar {
  display: flex;
  align-items: center;
  gap: var(--tc-s-2);
  padding: var(--tc-s-2) var(--tc-s-6);
  border-bottom: 1px solid var(--tc-rule);
  background: var(--tc-panel);
}

.tc-saved-filters {
  display: inline-flex;
  align-items: center;
  gap: var(--tc-s-2);
}

.tc-saved-filters__trigger {
  display: inline-flex;
  align-items: center;
  gap: var(--tc-s-1);
  padding: 4px var(--tc-s-2);
  border: 1px solid var(--tc-rule);
  border-radius: var(--tc-r-pill);
  background: var(--tc-panel-2);
  color: var(--tc-ink);
  font: 600 var(--tc-fs-12)/1 var(--tc-font-sans);
  cursor: pointer;
}
.tc-saved-filters__trigger:hover { border-color: var(--tc-link); color: var(--tc-ink); }
.tc-saved-filters__trigger.is-active {
  background: var(--tc-brand);
  color: var(--tc-brand-fg);
  border-color: transparent;
}
.tc-saved-filters__trigger.is-active:hover { background: var(--tc-brand-2); color: var(--tc-brand-fg); }
.tc-saved-filters__trigger .tc-c-icon { width: 14px; height: 14px; }
[data-theme="stencil"] .tc-saved-filters__trigger { border-radius: 0; }

.tc-saved-filters__count {
  min-width: 16px;
  padding: 0 5px;
  border-radius: var(--tc-r-pill);
  background: rgba(0, 0, 0, 0.10);
  font: 700 var(--tc-fs-10)/1.4 var(--tc-font-mono);
  text-align: center;
}
.tc-saved-filters__trigger.is-active .tc-saved-filters__count { background: rgba(255, 255, 255, 0.22); }
[data-scheme="dark"] .tc-saved-filters__count { background: rgba(255, 255, 255, 0.12); }

.tc-saved-filters__clear {
  color: var(--tc-ink-3);
  font: 500 var(--tc-fs-12)/1 var(--tc-font-sans);
  text-decoration: none;
}
.tc-saved-filters__clear:hover { color: var(--tc-link); text-decoration: underline; }

.tc-saved-filters__menu {
  min-width: 280px;
  max-width: 360px;
}
.tc-saved-filters__list {
  list-style: none;
  margin: 0;
  padding: 0;
  max-height: 320px;
  overflow-y: auto;
}
.tc-saved-filters__item {
  display: flex;
  align-items: center;
  gap: var(--tc-s-1);
  padding: 2px var(--tc-s-2) 2px var(--tc-s-3);
}
.tc-saved-filters__item:hover { background: var(--tc-panel-2); }
.tc-saved-filters__item.is-active { background: var(--tc-panel-2); }

.tc-saved-filters__apply {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  gap: var(--tc-s-2);
  min-width: 0;
  padding: 4px 0;
  color: var(--tc-ink);
  text-decoration: none;
  font: 500 var(--tc-fs-13)/1.3 var(--tc-font-sans);
}
.tc-saved-filters__name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tc-saved-filters__badge {
  flex: 0 0 auto;
  padding: 0 5px;
  border-radius: var(--tc-r-1);
  background: var(--tc-brand);
  color: var(--tc-brand-fg);
  font: 700 var(--tc-fs-10)/1.5 var(--tc-font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.tc-saved-filters__current { flex: 0 0 auto; color: var(--tc-pass); margin-left: auto; }

.tc-saved-filters__row-actions {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 2px;
}
.tc-saved-filters__star,
.tc-saved-filters__del {
  border: 0;
  background: transparent;
  color: var(--tc-ink-3);
  font-size: var(--tc-fs-13);
  line-height: 1;
  padding: 4px 5px;
  border-radius: var(--tc-r-1);
  cursor: pointer;
}
.tc-saved-filters__star:hover { color: var(--tc-warn); background: var(--tc-panel); }
.tc-saved-filters__star.is-on { color: var(--tc-warn); }
.tc-saved-filters__del:hover { color: var(--tc-fail); background: var(--tc-panel); }

.tc-saved-filters__empty {
  padding: var(--tc-s-3) var(--tc-s-3) var(--tc-s-2);
  color: var(--tc-ink-2);
}
.tc-saved-filters__empty-title {
  margin: 0 0 2px;
  font: 600 var(--tc-fs-13)/1.3 var(--tc-font-sans);
  color: var(--tc-ink);
}
.tc-saved-filters__empty-hint {
  margin: 0;
  font: 400 var(--tc-fs-12)/1.4 var(--tc-font-sans);
}

.tc-saved-filters__save {
  display: flex;
  align-items: center;
  gap: var(--tc-s-2);
  width: 100%;
  border: 0;
  background: transparent;
  color: var(--tc-link);
  font: 600 var(--tc-fs-13)/1.3 var(--tc-font-sans);
  padding: 6px var(--tc-s-3);
  cursor: pointer;
  text-align: left;
}
.tc-saved-filters__save:hover { background: var(--tc-panel-2); }
.tc-saved-filters__save .tc-c-icon { width: 14px; height: 14px; }



/* =========================================================================
 * Reduced motion
 * ========================================================================= */

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}
