/* =========================================================================
   Studio OS — A1 Prototype styles
   "Linear for artists": calm, dense, editorial. Off-white canvas, anthracite
   ink, one restrained petrol accent, muted semantic status colors.
   Local system fonts only — no network, no remote fonts.
   ========================================================================= */

:root {
  /* Type */
  --font-sans: ui-sans-serif, "Segoe UI Variable Text", "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
  --font-mono: ui-monospace, "Cascadia Mono", "Cascadia Code", "Consolas", "SFMono-Regular", "Menlo", monospace;
  --font-serif: ui-serif, Georgia, "Iowan Old Style", "Palatino Linotype", "Times New Roman", serif;

  /* Canvas + ink (from design handoff) */
  --canvas:      #FAFAF9;
  --surface:     #FFFFFF;
  --surface-2:   #F4F4F2;
  --ink:         #1A1A1A;
  --ink-2:       #44423E;
  --ink-3:       #6E6B65;
  --ink-4:       #98948C;
  --line:        #E6E4DF;
  --line-2:      #D8D5CE;

  /* One signature accent: deep petrol */
  --accent:      #0F5C5B;
  --accent-ink:  #0A4948;
  --accent-soft: #E3EEED;
  --accent-line: #BCD8D6;

  /* Muted semantic status */
  --ok:        #3F6B4B;   --ok-bg:   #E9F0EA;   --ok-line:  #CADBCD;
  --warn:      #8A6A22;   --warn-bg: #F5EEDD;   --warn-line:#E4D6B4;
  --bad:       #8C4A3F;   --bad-bg:  #F3E6E2;   --bad-line: #E1C8C0;
  --mute:      #6E6B65;   --mute-bg: #EEEDEA;   --mute-line:#DCD9D2;
  --info:      #355B7A;   --info-bg: #E7EEF4;   --info-line:#C7D7E3;

  /* Geometry */
  --r-sm: 5px; --r: 8px; --r-lg: 12px;
  --rail-w: 224px;
  --shadow-1: 0 1px 2px rgba(26,26,26,.05), 0 1px 1px rgba(26,26,26,.04);
  --shadow-2: 0 6px 22px -10px rgba(26,26,26,.22);
  --ring: 0 0 0 2px var(--canvas), 0 0 0 4px var(--accent);
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  background: var(--canvas);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }
kbd {
  font-family: var(--font-mono); font-size: 10px; color: var(--ink-4);
  border: 1px solid var(--line-2); border-radius: 4px; padding: 0 4px; line-height: 14px;
  background: var(--surface);
}
.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
:focus-visible { outline: none; box-shadow: var(--ring); border-radius: var(--r-sm); }

/* ---- Skip link (keyboard navigation): visually hidden until focused ---- */
.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 100;
  background: var(--accent); color: #fff; font-weight: 600; font-size: 13px;
  padding: 9px 16px; border-radius: 0 0 var(--r-sm) 0;
}
.skip-link:focus, .skip-link:focus-visible {
  left: 0; outline: none; box-shadow: var(--ring);
}

/* ---- Keyboard focus states for interactive elements that only had :hover ---- */
.rail__link:focus-visible { background: var(--accent-soft); color: var(--accent-ink); box-shadow: var(--ring); }
.stat:focus-visible { box-shadow: var(--ring); background: var(--surface-2); }
.df-tile:focus-visible { box-shadow: var(--ring); border-color: var(--accent-line); }
.row[tabindex]:focus-visible,
.optable tbody tr:focus-visible {
  outline: 2px solid var(--accent); outline-offset: -2px; box-shadow: none; background: var(--surface-2);
}

/* ---- Form placeholder contrast (WCAG AA) ---- */
select::placeholder, .input::placeholder, .textarea::placeholder { color: var(--ink-3); opacity: 1; }

/* ---- Sample banner ---- */
.sample-banner {
  position: sticky; top: 0; z-index: 40;
  display: flex; align-items: center; gap: 8px;
  background: #1A1A1A; color: #F1EFEA;
  font-size: 12px; letter-spacing: .01em;
  padding: 7px 18px; border-bottom: 1px solid #000;
}
.sample-banner strong { color: #fff; font-weight: 600; }
.sample-banner__dot { width: 7px; height: 7px; border-radius: 50%; background: #E2B23A; box-shadow: 0 0 0 3px rgba(226,178,58,.22); }

/* ---- Shell ---- */
.shell { display: grid; grid-template-columns: var(--rail-w) 1fr; min-height: calc(100vh - 33px); }

/* ---- Rail ---- */
.rail {
  background: var(--surface);
  border-right: 1px solid var(--line);
  padding: 16px 12px; display: flex; flex-direction: column; gap: 4px;
  position: sticky; top: 33px; height: calc(100vh - 33px);
}
.rail__brand { display: flex; align-items: center; gap: 8px; padding: 6px 8px 14px; }
.rail__mark { color: var(--accent); font-size: 18px; line-height: 1; }
.rail__name { font-weight: 650; letter-spacing: -.01em; font-size: 15px; }
.rail__tag {
  font-family: var(--font-mono); font-size: 9px; text-transform: uppercase; letter-spacing: .08em;
  color: var(--accent-ink); background: var(--accent-soft); border: 1px solid var(--accent-line);
  padding: 1px 5px; border-radius: 4px; margin-left: auto;
}
.rail__nav { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.rail__nav--minor { margin-top: 2px; }
.rail__link {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 9px; border-radius: var(--r-sm); color: var(--ink-2);
  font-weight: 500; font-size: 13px; position: relative;
}
.rail__link .ico { width: 15px; height: 15px; flex: none; fill: none; stroke: currentColor; stroke-width: 1.4; stroke-linecap: round; stroke-linejoin: round; color: var(--ink-4); }
.rail__link kbd { margin-left: auto; }
.rail__link:hover { background: var(--surface-2); color: var(--ink); }
.rail__link.is-active { background: var(--accent-soft); color: var(--accent-ink); font-weight: 600; }
.rail__link.is-active .ico { color: var(--accent); }
.rail__nav--minor .rail__link { font-size: 12px; color: var(--ink-3); padding: 5px 9px; }
.rail__divider { height: 1px; background: var(--line); margin: 12px 8px; }
.rail__foot { margin-top: auto; padding: 8px; }
.rail__who { font-size: 11px; color: var(--ink-3); line-height: 1.45; }
.rail__who b { color: var(--ink); font-weight: 600; display: block; font-size: 12px; }

/* ---- Main / topbar ---- */
.main { min-width: 0; display: flex; flex-direction: column; }
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 28px; border-bottom: 1px solid var(--line);
  background: rgba(250,250,249,.86); backdrop-filter: blur(6px);
  position: sticky; top: 33px; z-index: 20;
}
.topbar__crumbs { font-weight: 600; font-size: 14px; letter-spacing: -.01em; }
.topbar__right { display: flex; align-items: center; gap: 12px; }
.topbar__date { font-family: var(--font-mono); font-size: 12px; color: var(--ink-3); }
.topbar__sample {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; color: var(--warn);
  background: var(--warn-bg); border: 1px solid var(--warn-line); border-radius: 4px; padding: 2px 6px;
}
.view { padding: 28px; max-width: 1140px; width: 100%; }

/* ---- Page header ---- */
.page-head { margin-bottom: 22px; }
.page-head h1 { font-size: 21px; font-weight: 650; letter-spacing: -.02em; margin: 0 0 4px; }
.page-head p { margin: 0; color: var(--ink-3); font-size: 13px; max-width: 60ch; }
.eyebrow { font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--accent); margin-bottom: 6px; }

/* ---- Animated reveal (single page-load orchestration on dashboard) ---- */
@keyframes rise { from { opacity: 0; transform: translateY(7px); } to { opacity: 1; transform: none; } }
.reveal { opacity: 0; animation: rise .5s cubic-bezier(.2,.7,.2,1) forwards; }
@media (prefers-reduced-motion: reduce) { .reveal { animation: none; opacity: 1; } }

/* ---- Cards / grid ---- */
.grid { display: grid; gap: 16px; }
.cols-2 { grid-template-columns: repeat(2, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  box-shadow: var(--shadow-1);
}
.card__h { display: flex; align-items: center; justify-content: space-between; padding: 13px 16px; border-bottom: 1px solid var(--line); }
.card__h h2 { font-size: 13px; font-weight: 600; margin: 0; letter-spacing: -.005em; }
.card__h .count { font-family: var(--font-mono); font-size: 11px; color: var(--ink-4); }
.card__b { padding: 6px 8px; }
.card__b--pad { padding: 16px; }

/* ---- Next best action (hero strip) ---- */
.nba {
  grid-column: 1 / -1;
  display: flex; align-items: center; gap: 16px;
  background: linear-gradient(100deg, #103F3E 0%, #0F5C5B 70%);
  color: #EAF3F2; border-radius: var(--r-lg); padding: 16px 20px; box-shadow: var(--shadow-2);
}
.nba__k { font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: #9DC6C3; }
.nba__t { font-size: 15px; font-weight: 600; margin-top: 2px; color: #fff; }
.nba__t b { color: #fff; }
.nba__meta { margin-left: auto; text-align: right; font-size: 12px; color: #BCDAD8; }
.nba__btn { background: #fff; color: var(--accent-ink); font-weight: 600; font-size: 13px; border: 0; border-radius: var(--r-sm); padding: 8px 14px; cursor: pointer; }
.nba__btn:hover { background: #EAF3F2; }

/* ---- Deadline rows ---- */
.row { display: flex; align-items: center; gap: 12px; padding: 9px 8px; border-radius: var(--r-sm); }
.row + .row { border-top: 1px solid var(--line); border-radius: 0; }
.row:hover { background: var(--surface-2); }
.row__main { min-width: 0; flex: 1; }
.row__title { font-weight: 550; font-size: 13px; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.row__sub { font-size: 11.5px; color: var(--ink-3); display: flex; gap: 8px; flex-wrap: wrap; margin-top: 1px; }
.row__when { font-family: var(--font-mono); font-size: 12px; text-align: right; flex: none; }
.dleft { font-weight: 600; }
.dleft.is-urgent { color: var(--bad); }
.dleft.is-soon { color: var(--warn); }
.dleft.is-ok { color: var(--ink-3); }

/* ---- Chips / labels ---- */
.chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 600; line-height: 1; padding: 3px 8px; border-radius: 999px;
  border: 1px solid var(--line-2); color: var(--ink-2); background: var(--surface-2); white-space: nowrap;
}
.chip .d { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.chip--ok   { color: var(--ok);   background: var(--ok-bg);   border-color: var(--ok-line); }
.chip--warn { color: var(--warn); background: var(--warn-bg); border-color: var(--warn-line); }
.chip--bad  { color: var(--bad);  background: var(--bad-bg);  border-color: var(--bad-line); }
.chip--mute { color: var(--mute); background: var(--mute-bg); border-color: var(--mute-line); }
.chip--info { color: var(--info); background: var(--info-bg); border-color: var(--info-line); }
.chip--accent { color: var(--accent-ink); background: var(--accent-soft); border-color: var(--accent-line); }
.chip--ghost { background: transparent; }

/* Label badges for opportunities */
.label { font-family: var(--font-mono); font-size: 10px; letter-spacing: .04em; text-transform: uppercase; padding: 2px 7px; border-radius: 4px; border: 1px solid; font-weight: 600; white-space: nowrap; }
.label--recommended { color: var(--ok);   background: var(--ok-bg);   border-color: var(--ok-line); }
.label--premium     { color: var(--accent-ink); background: var(--accent-soft); border-color: var(--accent-line); }
.label--newcomer    { color: var(--info); background: var(--info-bg); border-color: var(--info-line); }
.label--watch       { color: var(--warn); background: var(--warn-bg); border-color: var(--warn-line); }
.label--avoid       { color: var(--bad);  background: var(--bad-bg);  border-color: var(--bad-line); }

/* ---- Risk panel ---- */
.risk { border-color: var(--warn-line); }
.risk .card__h { background: var(--warn-bg); border-bottom-color: var(--warn-line); border-radius: var(--r-lg) var(--r-lg) 0 0; }
.risk .card__h h2 { color: var(--warn); }
.risk-item { padding: 10px 12px; border-top: 1px solid var(--line); }
.risk-item:first-child { border-top: 0; }
.risk-item__top { display: flex; align-items: center; gap: 8px; }
.risk-item__t { font-weight: 600; font-size: 13px; }
.risk-item__why { font-size: 12px; color: var(--ink-2); margin-top: 3px; }

/* ---- Status summary tiles ---- */
.stat-tiles { display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px; padding: 12px; }
.stat { border: 1px solid var(--line); border-radius: var(--r); padding: 10px; text-align: left; background: var(--surface); }
.stat__n { font-family: var(--font-mono); font-size: 22px; font-weight: 600; line-height: 1; }
.stat__l { font-size: 10.5px; color: var(--ink-3); margin-top: 5px; text-transform: capitalize; }
.stat--accepted .stat__n { color: var(--ok); }
.stat--awaiting .stat__n, .stat--submitted .stat__n { color: var(--warn); }
.stat--rejected .stat__n { color: var(--bad); }
.stat--prepared .stat__n { color: var(--accent); }
.stat--archived .stat__n { color: var(--mute); }

/* ---- Missing docs ---- */
.missing-item { display: flex; align-items: center; gap: 10px; padding: 9px 8px; }
.missing-item + .missing-item { border-top: 1px solid var(--line); }
.missing-item__t { font-size: 13px; font-weight: 550; }
.missing-item__s { font-size: 11.5px; color: var(--ink-3); }

/* ---- Toolbar / filters ---- */
.toolbar { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-bottom: 16px; }
.field { display: inline-flex; align-items: center; gap: 6px; }
.field label { font-size: 11px; color: var(--ink-3); font-weight: 500; }
select, .input {
  font-family: var(--font-sans); font-size: 12.5px; color: var(--ink);
  background: var(--surface); border: 1px solid var(--line-2); border-radius: var(--r-sm);
  padding: 6px 9px; cursor: pointer;
}
select:hover { border-color: var(--ink-4); }
.toolbar__count { margin-left: auto; font-family: var(--font-mono); font-size: 12px; color: var(--ink-3); }
.btn { font-family: var(--font-sans); font-size: 12.5px; font-weight: 600; border: 1px solid var(--line-2); background: var(--surface); color: var(--ink); border-radius: var(--r-sm); padding: 6px 11px; cursor: pointer; }
.btn:hover { border-color: var(--ink-4); background: var(--surface-2); }
.btn--ghost { border-color: transparent; color: var(--ink-3); }
.btn--accent { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn--accent:hover { background: var(--accent-ink); border-color: var(--accent-ink); }
.btn:disabled { opacity: .45; cursor: not-allowed; }

/* ---- Opportunity table ---- */
.optable { width: 100%; border-collapse: collapse; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-1); }
.optable thead th { text-align: left; font-size: 10.5px; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-4); font-weight: 600; padding: 10px 14px; border-bottom: 1px solid var(--line); background: var(--surface-2); }
.optable tbody td { padding: 12px 14px; border-bottom: 1px solid var(--line); vertical-align: middle; }
.optable tbody tr:last-child td { border-bottom: 0; }
.optable tbody tr { cursor: pointer; }
.optable tbody tr:hover { background: var(--surface-2); }
.optable tbody tr.is-open { background: var(--accent-soft); }
.op-name { font-weight: 600; font-size: 13px; }
.op-org { font-size: 11.5px; color: var(--ink-3); margin-top: 1px; }
.op-meta { font-family: var(--font-mono); font-size: 12px; color: var(--ink-2); white-space: nowrap; }
.fee0 { color: var(--ok); }
.feeN { color: var(--bad); }

/* ---- Score pill + bar ---- */
.score { display: inline-flex; align-items: baseline; gap: 3px; font-family: var(--font-mono); font-weight: 600; }
.score__n { font-size: 15px; }
.score__d { font-size: 10px; color: var(--ink-4); }
.score--hi .score__n { color: var(--ok); }
.score--mid .score__n { color: var(--warn); }
.score--lo .score__n { color: var(--bad); }

/* ---- Detail panel (inline expand under a row) ---- */
.detail td { background: var(--surface-2); padding: 0 !important; }
.detail__inner { padding: 18px; display: grid; grid-template-columns: 1.3fr 1fr; gap: 22px; }
.detail__reason { font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.detail__reason .q { font-family: var(--font-serif); font-size: 15px; color: var(--ink); font-style: italic; border-left: 2px solid var(--accent-line); padding-left: 12px; margin: 0 0 12px; }
.factor { margin-bottom: 9px; }
.factor__top { display: flex; justify-content: space-between; font-size: 11.5px; margin-bottom: 3px; }
.factor__top b { font-weight: 600; }
.factor__top .v { font-family: var(--font-mono); color: var(--ink-3); }
.bar { height: 6px; border-radius: 999px; background: var(--surface); border: 1px solid var(--line); overflow: hidden; }
.bar > i { display: block; height: 100%; background: var(--accent); }
.bar.is-low > i { background: var(--bad); }
.bar.is-mid > i { background: var(--warn); }
.detail__docs { margin-top: 4px; }
.detail__docs .h { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-4); margin: 14px 0 8px; }
.doc-need { display: flex; align-items: center; gap: 8px; font-size: 12.5px; padding: 4px 0; }

/* ---- Applications: kanban ---- */
.board { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; align-items: start; }
.lane { background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 10px; }
.lane__h { display: flex; align-items: center; gap: 7px; font-size: 12px; font-weight: 600; margin: 2px 4px 10px; }
.lane__h .n { margin-left: auto; font-family: var(--font-mono); font-size: 11px; color: var(--ink-4); }
.appcard { background: var(--surface); border: 1px solid var(--line); border-left: 3px solid var(--line-2); border-radius: var(--r); padding: 11px; margin-bottom: 9px; cursor: pointer; box-shadow: var(--shadow-1); }
.appcard:hover { border-left-color: var(--accent); }
.appcard.s-accepted { border-left-color: var(--ok); }
.appcard.s-awaiting, .appcard.s-submitted { border-left-color: var(--warn); }
.appcard.s-rejected { border-left-color: var(--bad); }
.appcard.s-prepared { border-left-color: var(--accent); }
.appcard.s-archived { border-left-color: var(--mute); }
.appcard__t { font-weight: 600; font-size: 12.5px; line-height: 1.35; }
.appcard__m { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); margin-top: 6px; display: flex; justify-content: space-between; }
.appcard__status { font-weight: 600; color: var(--ink-2); }
.appcard__na { font-size: 11.5px; color: var(--ink-2); margin-top: 7px; padding-top: 7px; border-top: 1px dashed var(--line-2); }
.appcard__na b { color: var(--accent-ink); font-weight: 600; }

/* Rejected: calm, supportive, never alarming */
.reassure { font-size: 11px; color: var(--ink-3); font-style: italic; margin: 2px 4px 8px; }

/* ---- App detail drawer ---- */
.drawer-mask { position: fixed; inset: 0; background: rgba(26,26,26,.28); z-index: 60; display: none; }
.drawer-mask.is-open { display: block; }
.drawer { position: fixed; top: 0; right: 0; height: 100vh; width: min(440px, 92vw); background: var(--surface); border-left: 1px solid var(--line); box-shadow: var(--shadow-2); z-index: 61; transform: translateX(100%); transition: transform .26s cubic-bezier(.2,.7,.2,1); display: flex; flex-direction: column; }
.drawer.is-open { transform: none; }
@media (prefers-reduced-motion: reduce) { .drawer { transition: none; } }
.drawer__h { padding: 18px 20px; border-bottom: 1px solid var(--line); }
.drawer__close { position: absolute; top: 14px; right: 16px; border: 0; background: transparent; font-size: 20px; color: var(--ink-3); cursor: pointer; line-height: 1; }
.drawer__b { padding: 18px 20px; overflow: auto; }
.drawer h3 { font-size: 16px; margin: 0 6px 2px 0; font-weight: 650; letter-spacing: -.01em; }
.drawer .sub { color: var(--ink-3); font-size: 12.5px; }
.kv { display: grid; grid-template-columns: 96px 1fr; gap: 6px 12px; font-size: 12.5px; margin: 16px 0; }
.kv dt { color: var(--ink-3); }
.kv dd { margin: 0; font-weight: 500; }
.timeline { list-style: none; padding: 0; margin: 8px 0 0; }
.timeline li { display: flex; gap: 12px; padding: 6px 0; font-size: 12.5px; line-height: 1.5; }
.timeline .t { font-family: var(--font-mono); color: var(--ink-4); flex: none; min-width: 84px; max-width: 45%; overflow-wrap: anywhere; }
.timeline li span:not(.t) { flex: 1 1 auto; min-width: 0; overflow-wrap: anywhere; }
/* Audit log: event types are long mono tokens (up to document_template_readiness);
   a stable wide label column keeps desktop rows aligned, mobile stacks. */
.timeline--audit .t { width: 168px; }
@media (max-width: 640px) {
  .timeline--audit li { flex-direction: column; gap: 2px; }
  .timeline--audit .t { width: auto; max-width: none; }
}
.section-h { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-4); margin: 18px 0 8px; }

/* ---- Documents list ---- */
.doclist { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-1); }
.docrow { display: flex; align-items: center; gap: 14px; padding: 14px 16px; border-bottom: 1px solid var(--line); }
.docrow:last-child { border-bottom: 0; }
.docrow__ic { width: 34px; height: 34px; border-radius: var(--r-sm); display: grid; place-items: center; background: var(--surface-2); border: 1px solid var(--line); color: var(--ink-3); flex: none; }
.docrow__ic svg { width: 17px; height: 17px; fill: none; stroke: currentColor; stroke-width: 1.4; }
.docrow__main { flex: 1; min-width: 0; }
.docrow__t { font-weight: 600; font-size: 13.5px; }
.docrow__s { font-size: 11.5px; color: var(--ink-3); margin-top: 2px; }
.docrow__v { font-family: var(--font-mono); font-size: 11px; color: var(--ink-4); }

/* portfolio placeholder tiles */
.thumbs { display: grid; grid-template-columns: repeat(6, 1fr); gap: 6px; margin-top: 10px; }
.thumb { aspect-ratio: 1; border-radius: var(--r-sm); border: 1px solid var(--line); background:
  repeating-linear-gradient(45deg, var(--surface-2), var(--surface-2) 7px, #EEEDEA 7px, #EEEDEA 14px);
  display: grid; place-items: center; color: var(--ink-4); font-family: var(--font-mono); font-size: 9px; }

/* ---- Bundle builder ---- */
.bundle { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-items: start; }
.picker { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.readiness { display: flex; align-items: center; gap: 14px; padding: 16px; }
.ring { --p: 0; width: 64px; height: 64px; border-radius: 50%; flex: none;
  background: conic-gradient(var(--accent) calc(var(--p) * 1%), var(--line) 0);
  display: grid; place-items: center; }
.ring::after { content: ""; width: 50px; height: 50px; border-radius: 50%; background: var(--surface); position: absolute; }
.ring span { position: relative; z-index: 1; font-family: var(--font-mono); font-weight: 600; font-size: 15px; }
.readiness__txt b { font-size: 14px; } .readiness__txt p { margin: 2px 0 0; font-size: 12px; color: var(--ink-3); }
.checklist { list-style: none; margin: 0; padding: 0; }
.checklist li { display: flex; align-items: flex-start; gap: 10px; padding: 9px 0; border-top: 1px solid var(--line); font-size: 13px; }
.checklist li:first-child { border-top: 0; }
.tick { width: 17px; height: 17px; border-radius: 5px; flex: none; display: grid; place-items: center; font-size: 11px; border: 1px solid var(--line-2); margin-top: 1px; }
.tick.ok { background: var(--ok-bg); border-color: var(--ok-line); color: var(--ok); }
.tick.no { background: var(--bad-bg); border-color: var(--bad-line); color: var(--bad); }
.tick.warn { background: var(--warn-bg); border-color: var(--warn-line); color: var(--warn); }
.li-sub { font-size: 11.5px; color: var(--ink-3); }
.export-list { font-family: var(--font-mono); font-size: 12px; background: #16201F; color: #C9DBDA; border-radius: var(--r); padding: 14px 16px; line-height: 1.7; }
.export-list .f { color: #EAF3F2; }
.export-list .x { color: #C99; }
.export-list .muted { color: #6E8584; }
.export-note { font-size: 11.5px; color: var(--ink-3); margin-top: 8px; }
.export-note--strong { color: var(--ink-1); font-weight: 600; }
.sanity { margin-top: 6px; }

/* ---- Bundle export result (A2 application-package builder) ---- */
.export-result { margin-top: 12px; }
.export-result__head { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 8px; align-items: baseline; padding: 10px 12px; background: var(--card-2, #1a2625); border: 1px solid var(--line); border-radius: var(--r); }
.export-result__head .f { font-family: var(--font-mono); font-size: 12px; }
.export-result__score { font-weight: 700; font-size: 13px; }
.export-result__body { margin-top: 10px; }
.export-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 10px; }
.export-block { border: 1px solid var(--line); border-radius: var(--r); padding: 10px 12px; }
.export-block h3 { font-size: 12.5px; margin: 0 0 6px; color: var(--ink-2); }
.export-files, .export-manifest { list-style: none; margin: 0; padding: 0; font-size: 12px; }
.export-files li { display: flex; gap: 8px; align-items: baseline; padding: 2px 0; border-bottom: 1px dotted var(--line-2); }
.export-files__name { font-family: var(--font-mono); flex: 1; word-break: break-all; }
.export-files__bytes { font-size: 11px; }
.export-manifest li { font-family: var(--font-mono); font-size: 11.5px; padding: 2px 0; word-break: break-all; }
.export-warn { font-size: 12px; padding: 3px 0; }
.export-warn b { text-transform: uppercase; font-size: 10px; letter-spacing: .04em; margin-right: 6px; }
.export-warn--danger b { color: var(--bad); }
.export-warn--warn b { color: var(--warn); }
.export-warn--info b { color: var(--ink-3); }
.tag { display: inline-block; font-size: 10px; padding: 1px 6px; border-radius: 999px; border: 1px solid var(--line-2); }
.tag--ph { color: var(--warn); border-color: var(--warn-line); background: var(--warn-bg); }
.export-actions { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
@media (max-width: 720px) { .export-grid { grid-template-columns: 1fr; } }

/* ---- About / pricing ---- */
.prose { max-width: 64ch; }
.prose h2 { font-size: 15px; margin: 22px 0 6px; }
.prose p { color: var(--ink-2); }
.prose .lead { font-family: var(--font-serif); font-size: 17px; line-height: 1.55; color: var(--ink); }
.cmp { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 8px; }
.tier { border: 1px solid var(--line); border-radius: var(--r-lg); padding: 18px; background: var(--surface); }
.tier.pro { border-color: var(--accent-line); box-shadow: var(--shadow-2); }
.tier__name { font-weight: 650; font-size: 14px; }
.tier__price { font-family: var(--font-mono); font-size: 24px; font-weight: 600; margin: 8px 0 2px; }
.tier__price small { font-size: 12px; color: var(--ink-3); font-weight: 400; }
.tier ul { list-style: none; padding: 0; margin: 12px 0 0; font-size: 12.5px; }
.tier li { padding: 5px 0; border-top: 1px solid var(--line); color: var(--ink-2); }
.tier li::before { content: "—  "; color: var(--accent); }

/* ---- A2 hardening: data-health banner + safe fallback states ---- */
.health {
  display: flex; align-items: center; flex-wrap: wrap; gap: 10px;
  padding: 10px 14px; border-radius: var(--r); margin-bottom: 18px;
  border: 1px solid var(--line); font-size: 12.5px;
}
.health.ok { background: var(--ok-bg); border-color: var(--ok-line); color: var(--ok); }
.health.warn { background: var(--warn-bg); border-color: var(--warn-line); color: var(--warn); }
.health.bad { background: var(--bad-bg); border-color: var(--bad-line); color: var(--bad); }
.health-label { font-weight: 600; }
.health-tag.hostile {
  background: var(--bad); color: #fff; font-weight: 700; font-size: 10px;
  padding: 2px 8px; border-radius: 4px; letter-spacing: .06em; font-family: var(--font-mono);
}
.health-list { list-style: none; width: 100%; margin: 8px 0 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.health-item { color: var(--ink-3); font-size: 11.5px; line-height: 1.5; word-break: break-word; }
.health-item .health-level { font-weight: 700; font-size: 9px; padding: 1px 5px; border-radius: 3px; margin-right: 6px; font-family: var(--font-mono); }
.health-item.error .health-level { background: var(--bad-bg); color: var(--bad); }
.health-item.warn .health-level { background: var(--warn-bg); color: var(--warn); }
.health-item.muted { color: var(--ink-4); font-style: italic; }

/* Safe fallback / contained-error states */
.error-panel { border-color: var(--bad-line); }
.error-detail {
  margin-top: 10px; padding: 10px 12px; background: var(--surface-2);
  border-radius: var(--r-sm); color: var(--bad); font-size: 12px;
  white-space: pre-wrap; word-break: break-word; font-family: var(--font-mono);
}
/* Neutral chip/label for unknown enum values (status/label/state) */
.label--unknown { color: var(--mute); background: var(--mute-bg); border-color: var(--mute-line); }

/* ---- Empty + misc ---- */
.empty { text-align: center; padding: 40px; color: var(--ink-3); font-size: 13px; }
.note-inline { font-size: 11.5px; color: var(--ink-4); }
.spacer { height: 16px; }

/* ---- Responsive ---- */
@media (max-width: 1080px) {
  .board { grid-template-columns: repeat(2, 1fr); }
  .detail__inner { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .shell { grid-template-columns: 1fr; }
  .rail { position: static; height: auto; flex-direction: row; flex-wrap: wrap; align-items: center; }
  .rail__nav { flex-direction: row; flex-wrap: wrap; }
  .rail__divider, .rail__foot, .rail__nav--minor, .rail__sectlabel { display: none; }
  .cols-2, .cols-3, .bundle { grid-template-columns: 1fr; }
  .stat-tiles { grid-template-columns: repeat(3, 1fr); }
  .board { grid-template-columns: 1fr; }
  .import-grid { grid-template-columns: 1fr; }
  .detail__inner--3 { grid-template-columns: 1fr; }
}

/* =========================================================================
   A2 data-foundation: rail section label, data-foundation card, provenance,
   confidence, risk flags, review states, import form, draft cards, sources.
   Calm, additive — uses existing tokens. No existing rule above was removed.
   ========================================================================= */

/* Rail section label */
.rail__sectlabel { font-family: var(--font-mono); font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-4); padding: 4px 9px 2px; }

/* Data-foundation dashboard card */
.df-tiles { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.df-tile { border: 1px solid var(--line); border-radius: var(--r); padding: 10px 12px; text-align: left; background: var(--surface); cursor: pointer; }
.df-tile:hover { border-color: var(--accent-line); background: var(--accent-soft); }
.df-tile__n { font-family: var(--font-mono); font-size: 20px; font-weight: 600; color: var(--accent-ink); line-height: 1; }
.df-tile__l { font-size: 11px; color: var(--ink-3); margin-top: 4px; }

/* Confidence indicator */
.conf { display: inline-flex; align-items: center; gap: 4px; font-family: var(--font-mono); font-size: 10px; font-weight: 600; padding: 1px 6px; border-radius: 999px; border: 1px solid var(--line-2); color: var(--ink-3); background: var(--surface-2); white-space: nowrap; }
.conf__dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.conf--hi { color: var(--ok); background: var(--ok-bg); border-color: var(--ok-line); }
.conf--mid { color: var(--warn); background: var(--warn-bg); border-color: var(--warn-line); }
.conf--lo { color: var(--bad); background: var(--bad-bg); border-color: var(--bad-line); }
.conf--none { color: var(--mute); background: var(--mute-bg); border-color: var(--mute-line); }
.conf-mini { display: inline-block; width: 7px; height: 7px; border-radius: 50%; margin-left: 6px; vertical-align: middle; background: var(--mute); }
.conf-mini.conf--hi { background: var(--ok); } .conf-mini.conf--mid { background: var(--warn); }
.conf-mini.conf--lo { background: var(--bad); } .conf-mini.conf--none { background: var(--mute); }

/* Risk flags (calm, not alarmist) */
.riskflags { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
.rf { font-family: var(--font-mono); font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 4px; border: 1px solid; white-space: nowrap; }
.rf--info { color: var(--info); background: var(--info-bg); border-color: var(--info-line); }
.rf--warn { color: var(--warn); background: var(--warn-bg); border-color: var(--warn-line); }
.rf--danger { color: var(--bad); background: var(--bad-bg); border-color: var(--bad-line); }
.risk-none { font-size: 11px; color: var(--ink-4); font-style: italic; }
.risk-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--bad); margin-left: 6px; vertical-align: middle; }

/* Review-state + recommendation badges */
.rstate { font-family: var(--font-mono); font-size: 9.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; padding: 2px 7px; border-radius: 4px; border: 1px solid var(--line-2); color: var(--ink-3); background: var(--surface-2); white-space: nowrap; }
.rstate--published { color: var(--ok); background: var(--ok-bg); border-color: var(--ok-line); }
.rstate--watch { color: var(--warn); background: var(--warn-bg); border-color: var(--warn-line); }
.rstate--needs_review, .rstate--extracted, .rstate--raw, .rstate--ready_to_publish { color: var(--info); background: var(--info-bg); border-color: var(--info-line); }
.rstate--rejected, .rstate--archived { color: var(--mute); background: var(--mute-bg); border-color: var(--mute-line); }
.rec { font-family: var(--font-mono); font-size: 9.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; padding: 2px 7px; border-radius: 4px; border: 1px solid; white-space: nowrap; }
.rec--recommended { color: var(--ok); background: var(--ok-bg); border-color: var(--ok-line); }
.rec--watch { color: var(--warn); background: var(--warn-bg); border-color: var(--warn-line); }
.rec--caution { color: var(--bad); background: var(--bad-bg); border-color: var(--bad-line); }
.rec--needs_review { color: var(--info); background: var(--info-bg); border-color: var(--info-line); }
.rec--rejected { color: var(--mute); background: var(--mute-bg); border-color: var(--mute-line); }

/* Provenance */
.op-prov { font-size: 10.5px; color: var(--ink-4); margin-top: 2px; }
.op-origin-tag { font-family: var(--font-mono); font-size: 9px; text-transform: uppercase; letter-spacing: .06em; color: var(--accent-ink); background: var(--accent-soft); border: 1px solid var(--accent-line); border-radius: 3px; padding: 0 4px; margin-left: 6px; }
.prov-kv dt { color: var(--ink-3); } .prov-kv dd { word-break: break-word; }
.prov-link { color: var(--accent-ink); text-decoration: underline; text-underline-offset: 2px; }
.prov-withheld { color: var(--bad); }
.prov-note { color: var(--ink-4); font-style: italic; }
.prov-block { background: var(--surface-2); border-radius: var(--r); padding: 14px; }
.rf-wrap { margin-top: 12px; } .rf-h { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-4); margin-bottom: 6px; }
.detail__inner--3 { grid-template-columns: 1.2fr 1fr 1fr; }

/* Import form */
.import-card { margin-bottom: 18px; }
.import-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.field--block { display: flex; flex-direction: column; align-items: stretch; gap: 4px; }
.field--block > label { font-size: 11px; color: var(--ink-3); font-weight: 600; }
.field--full { grid-column: 1 / -1; }
.input--full { width: 100%; }
.textarea { width: 100%; font-family: var(--font-mono); font-size: 12px; line-height: 1.5; resize: vertical; min-height: 120px; }
.import-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.mirror-status { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.mirror-status .note-inline { flex: 1 1 240px; }
.imp-msg { font-size: 12px; color: var(--ink-3); }
.imp-msg.is-ok { color: var(--ok); font-weight: 600; }
.imp-msg.is-err { color: var(--bad); font-weight: 600; }
.btn--sm { font-size: 11.5px; padding: 4px 9px; }

/* Draft cards */
.draft-card { border: 1px solid var(--line); border-radius: var(--r); padding: 12px 14px; margin-bottom: 10px; background: var(--surface); cursor: pointer; box-shadow: var(--shadow-1); }
.draft-card:hover { border-color: var(--accent-line); }
.draft-card__top { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.draft-card__t { font-weight: 600; font-size: 13.5px; margin-right: auto; }
.draft-card__org { font-size: 11.5px; color: var(--ink-3); margin-top: 2px; }
.draft-card__meta { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; font-size: 11.5px; color: var(--ink-2); margin-top: 8px; }
.draft-card__meta .sep { color: var(--ink-4); }
.dc-source { font-weight: 600; color: var(--ink-2); }
.draft-actions { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 10px; }

/* Mini rows (published / rejected history) */
.mini-row { display: flex; align-items: center; gap: 12px; padding: 9px 4px; border-top: 1px solid var(--line); }
.mini-row:first-child { border-top: 0; }
.mini-row__main { flex: 1; min-width: 0; }
.mini-row__t { font-weight: 600; font-size: 13px; display: flex; align-items: center; gap: 8px; }
.mini-row__s { font-size: 11.5px; color: var(--ink-3); margin-top: 2px; word-break: break-word; }
.mini-row--muted .mini-row__t { color: var(--ink-2); }

/* Drawer wide + raw excerpt */
.drawer--wide { width: min(520px, 94vw); }
.raw-excerpt { font-family: var(--font-mono); font-size: 11.5px; line-height: 1.5; background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 10px 12px; white-space: pre-wrap; word-break: break-word; color: var(--ink-2); max-height: 220px; overflow: auto; }

/* Sources registry */
.callout { background: var(--info-bg); border: 1px solid var(--info-line); color: var(--info); font-size: 12px; padding: 9px 13px; border-radius: var(--r); margin-bottom: 14px; }
.srctable .src-note { font-size: 11px; color: var(--ink-4); margin-top: 3px; }
.srctable .src-checked { font-family: var(--font-mono); font-size: 10px; color: var(--ink-4); margin-top: 3px; }
.srctable .src-review { font-size: 10px; color: var(--warn); margin-top: 2px; }
.mode { font-family: var(--font-mono); font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 4px; border: 1px solid; white-space: nowrap; }
.mode--mute { color: var(--mute); background: var(--mute-bg); border-color: var(--mute-line); }
.mode--info { color: var(--info); background: var(--info-bg); border-color: var(--info-line); }
.mode--warn { color: var(--warn); background: var(--warn-bg); border-color: var(--warn-line); }
.mode--accent { color: var(--accent-ink); background: var(--accent-soft); border-color: var(--accent-line); }
.trust { font-family: var(--font-mono); font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 4px; border: 1px solid var(--line-2); text-transform: capitalize; }
.trust--high { color: var(--ok); background: var(--ok-bg); border-color: var(--ok-line); }
.trust--medium { color: var(--warn); background: var(--warn-bg); border-color: var(--warn-line); }
.trust--low { color: var(--bad); background: var(--bad-bg); border-color: var(--bad-line); }
.trust--unknown { color: var(--mute); background: var(--mute-bg); border-color: var(--mute-line); }

/* A2 runtime adapter: workspace-backed summary panels (read from an ACTIVE user workspace).
   A subtle left accent marks the blocks that show the operator's own data, distinct from the
   sample-backed views rendered below them. Styling only; no behavior. */
.ws-backed { border-left: 3px solid var(--accent-line); padding-left: 10px; }

/* A2 RC v0.1: package-preparation draft block (read-only, next most urgent application). A subtle
   top divider separates the prep draft from the readiness preview above it. Styling only; no behavior. */
.ws-prep { margin-top: 10px; padding-top: 8px; border-top: 1px dashed var(--accent-line); }

/* Source Proof (A2 real-ingestion one-source proof) */
.callout--proof { background: var(--warn-bg); border-color: var(--warn-line); color: var(--warn); }
.bt-verdict { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); }
.bt-verdict--ok { color: var(--ok); }
.sp-hash { font-size: 10.5px; word-break: break-all; color: var(--ink-3); }
/* Source-proof snapshot selector (second-real-source phase) */
.proof-switch { display: flex; flex-wrap: wrap; gap: 8px; }
.proof-switch .btn { display: inline-flex; align-items: center; gap: 7px; }
.proof-switch__tag { font-family: var(--font-mono); font-size: 9.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; padding: 1px 6px; border-radius: 999px; border: 1px solid var(--line-2); }
.proof-switch__tag.is-real { color: var(--ok); background: var(--ok-bg); border-color: var(--ok-line); }
.proof-switch__tag.is-fixture { color: var(--ink-3); background: var(--surface-2); }
.proof-switch__tag.is-human { color: var(--accent-ink); background: var(--accent-soft); border-color: var(--accent-line); }

/* Human-supplied source intake (A2 license-clean path) */
.perm-badge { font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: .03em; padding: 2px 8px; border-radius: 4px; border: 1px solid var(--line-2); text-transform: uppercase; }
.perm-badge--ok { color: var(--ok); background: var(--ok-bg); border-color: var(--ok-line); }
.perm-badge--warn { color: var(--bad); background: var(--bad-bg); border-color: var(--bad-line); }
.perm-badge--private { color: var(--warn); background: var(--warn-bg); border-color: var(--warn-line); }
.tri-row { display: flex; flex-wrap: wrap; gap: 12px; }
.tri-row .field { flex: 1 1 150px; }
.hs-check { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--ink-2); }
.hs-check input { width: 15px; height: 15px; }
.bt-gate { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-bottom: 10px; }
.bt-gate__pill { font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: .03em; padding: 3px 8px; border-radius: 4px; border: 1px solid var(--line-2); text-transform: uppercase; }
.bt-gate__pill--no { color: var(--bad); background: var(--bad-bg); border-color: var(--bad-line); }
.bt-gate__pill--ok { color: var(--ok); background: var(--ok-bg); border-color: var(--ok-line); }
.bt-gate__pill--warn { color: var(--warn); background: var(--warn-bg); border-color: var(--warn-line); }
.bt-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 7px; }
.bt-item { display: flex; gap: 9px; align-items: flex-start; padding: 7px 9px; border: 1px solid var(--line); border-radius: var(--r); background: var(--surface-2); }
.bt-item--ok { border-color: var(--ok-line); background: var(--ok-bg); }
.bt-item--flag { border-color: var(--warn-line); background: var(--warn-bg); }
.bt-item--missing { border-color: var(--bad-line); background: var(--bad-bg); }
.bt-item__main { min-width: 0; }
.bt-item__label { font-size: 12px; font-weight: 700; color: var(--ink); }
.bt-item__msg { font-size: 11.5px; color: var(--ink-2); margin-top: 1px; }

/* ====================================================================
   A2 persistence + multi-source UI (additive)
   ==================================================================== */
.mono-sm { font-family: var(--font-mono); font-size: 11px; line-height: 1.45; }
.df-tile--static { cursor: default; }
.df-tile--static:hover { border-color: var(--line); background: var(--surface); }

/* Recommendation vs confidence */
.conf-block { margin-top: 14px; padding-top: 12px; border-top: 1px dashed var(--line-2); }
.cscore-row { display: flex; gap: 12px; flex-wrap: wrap; }
.cscore { flex: 1 1 120px; border: 1px solid var(--line); border-radius: var(--r); padding: 10px 12px; background: var(--surface-2); text-align: center; }
.cscore__n { font-family: var(--font-mono); font-size: 26px; font-weight: 700; line-height: 1; color: var(--accent-ink); }
.cscore__n.conf-score.conf--hi { color: var(--ok); }
.cscore__n.conf-score.conf--mid { color: var(--warn); }
.cscore__n.conf-score.conf--lo { color: var(--bad); }
.cscore__l { font-size: 11.5px; font-weight: 700; color: var(--ink-2); margin-top: 4px; }
.cscore__h { font-size: 10.5px; color: var(--ink-4); margin-top: 1px; }
.cscore-why { font-size: 12px; color: var(--ink-2); margin: 10px 0 4px; }
.cscore-why--warn { color: var(--bad); font-weight: 600; background: var(--bad-bg); border: 1px solid var(--bad-line); border-radius: var(--r); padding: 8px 10px; }
.conf-parts { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
.conf-part { font-family: var(--font-mono); font-size: 9.5px; padding: 1px 6px; border-radius: 999px; border: 1px solid var(--line-2); color: var(--ink-3); background: var(--surface); }
.conf-part--high { color: var(--ok); border-color: var(--ok-line); background: var(--ok-bg); }
.conf-part--medium { color: var(--warn); border-color: var(--warn-line); background: var(--warn-bg); }
.conf-part--low, .conf-part--none { color: var(--bad); border-color: var(--bad-line); background: var(--bad-bg); }

/* Duplicate warning */
.dup-warn { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 8px; padding: 6px 10px; border-radius: var(--r); font-size: 11.5px; border: 1px solid var(--warn-line); background: var(--warn-bg); color: var(--warn); }
.dup-warn--high { border-color: var(--bad-line); background: var(--bad-bg); color: var(--bad); }
.dup-warn__tag { font-family: var(--font-mono); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; }
.dup-warn__txt { color: var(--ink-2); }

/* Source-run rows */
.run-row { border: 1px solid var(--line); border-radius: var(--r); padding: 10px 12px; margin-bottom: 9px; background: var(--surface); }
.run-row__top { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.run-row__src { font-weight: 600; font-size: 13px; }
.run-row__meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 6px; font-size: 11.5px; color: var(--ink-2); }
.run-row__links { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 6px; }
.run-row__notes { font-size: 11.5px; color: var(--ink-3); margin-top: 6px; }

/* Snapshot rows */
.snap-row { border: 1px solid var(--line); border-radius: var(--r); padding: 10px 12px; margin-bottom: 9px; background: var(--surface); }
.snap-row__top { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.snap-row__meta { font-size: 11.5px; color: var(--ink-2); margin-top: 5px; }

/* =========================================================================
   A2 source-intelligence phase: vanity-risk scorecard, artist fit, source
   access registry, application pipeline, versioned documents, profile.
   Uses the existing token palette only. No remote resources.
   ========================================================================= */

/* fit + vanity inline chips */
.fitchip, .vanitychip {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 999px;
  border: 1px solid var(--line); white-space: nowrap;
}
.fit--strong   { background: var(--ok-bg);   color: var(--ok);   border-color: var(--ok-line); }
.fit--possible { background: var(--warn-bg); color: var(--warn); border-color: var(--warn-line); }
.fit--weak     { background: #F0EEE9; color: var(--ink-2); }
.fit--nogo     { background: var(--bad-bg);  color: var(--bad);  border-color: var(--bad-line); }
.vanity--safe    { background: var(--ok-bg);   color: var(--ok);   border-color: var(--ok-line); }
.vanity--review  { background: #F0EEE9; color: var(--ink-2); }
.vanity--caution { background: var(--warn-bg); color: var(--warn); border-color: var(--warn-line); }
.vanity--avoid   { background: var(--bad-bg);  color: var(--bad);  border-color: var(--bad-line); }
.detail__chips, .drawer-chips { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 8px; }

/* vanity scorecard */
.vrisk-head { display: flex; gap: 18px; align-items: flex-start; }
.vrisk-ring {
  --p: 0; flex: 0 0 auto; width: 86px; height: 86px; border-radius: 50%;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  background: conic-gradient(currentColor calc(var(--p) * 1%), var(--line) 0);
  position: relative;
}
.vrisk-ring::before { content: ""; position: absolute; inset: 9px; background: var(--bg, #fff); border-radius: 50%; }
.vrisk-ring__n, .vrisk-ring__d { position: relative; z-index: 1; font-family: var(--font-mono); color: var(--ink); }
.vrisk-ring__n { font-size: 24px; font-weight: 700; }
.vrisk-ring__d { font-size: 10px; color: var(--ink-2); }
.vrisk--safe    { color: var(--ok); }
.vrisk--review  { color: #9a9690; }
.vrisk--caution { color: var(--warn); }
.vrisk--avoid   { color: var(--bad); }
.vrisk-label { font-size: 15px; font-weight: 700; }
.vrisk-disclaimer { font-size: 11px; color: var(--ink-2); font-style: italic; }
.vrisk-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 14px; }
@media (max-width: 880px) { .vrisk-grid { grid-template-columns: 1fr; } }
.vrisk-signal { display: flex; gap: 8px; align-items: baseline; padding: 4px 0; border-bottom: 1px solid var(--line); }
.vrisk-signal__d { font-size: 12px; color: var(--ink-2); }
.vrisk-fee__note { font-size: 13px; }

/* source access registry */
.sa-panel { margin-bottom: 22px; }
.sa-chips { display: flex; gap: 8px; flex-wrap: wrap; margin: 8px 0; }
.sa-chip { font-size: 12px; padding: 3px 9px; border: 1px solid var(--line); border-radius: 999px; background: #F0EEE9; }
.sa-table .sa-may { font-size: 11px; color: var(--ink-2); max-width: 260px; }
.sa-access, .sa-handling, .sa-risk { font-size: 11px; font-weight: 600; padding: 2px 7px; border-radius: 4px; white-space: nowrap; }
.sa-access--public, .sa-access--api, .sa-access--rss { background: var(--ok-bg); color: var(--ok); }
.sa-access--human_summary { background: #F0EEE9; color: var(--ink-2); }
.sa-access--membership { background: var(--warn-bg); color: var(--warn); }
.sa-access--blocked { background: var(--bad-bg); color: var(--bad); }
.sa-access--partner, .sa-access--unknown { background: #EFEDE8; color: var(--ink-2); }
.sa-handling--blocked { background: var(--bad-bg); color: var(--bad); }
.sa-handling--membership_manual { background: var(--warn-bg); color: var(--warn); }
.sa-handling--official_api, .sa-handling--public_snapshot { background: var(--ok-bg); color: var(--ok); }
.sa-handling--human_summary, .sa-handling--partner_feed { background: #F0EEE9; color: var(--ink-2); }
.sa-risk--low { background: var(--ok-bg); color: var(--ok); }
.sa-risk--medium { background: var(--warn-bg); color: var(--warn); }
.sa-risk--high { background: var(--bad-bg); color: var(--bad); }

/* =========================================================================
   A2 deadline calendar + local reminder layer — calm, operational; not a dense
   calendar clone. Reuses the existing card/chip/btn system.
   ========================================================================= */
.cal-tiles { display: flex; flex-wrap: wrap; gap: 10px; margin: 4px 0 14px; }
.cal-tile { flex: 1 1 120px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); padding: 12px 14px; }
.cal-tile__n { display: block; font-size: 22px; font-weight: 650; color: var(--ink); line-height: 1.1; }
.cal-tile__l { font-size: 12px; color: var(--ink-3); }
.cal-exportbar { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap;
  background: var(--accent-soft); border: 1px solid var(--accent-line); border-radius: var(--r); padding: 10px 14px; margin: 0 0 16px; }
.cal-panelhead { font-size: 12px; color: var(--ink-3); padding: 2px 2px 8px; }
.cal-list { display: flex; flex-direction: column; gap: 10px; padding: 12px 14px; }
.cal-ev { border: 1px solid var(--line); border-left: 3px solid var(--line-2); border-radius: var(--r); background: var(--surface); }
.cal-ev--overdue, .cal-ev--blocked { border-left-color: var(--bad); }
.cal-ev--urgent { border-left-color: var(--warn); }
.cal-ev--due_soon { border-left-color: var(--accent); }
.cal-ev__top { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 8px 12px 0; }
.cal-ev__date { font-family: var(--font-mono); font-size: 12px; color: var(--ink-2); }
.cal-badge { font-size: 11px; padding: 1px 7px; border-radius: 999px; background: var(--surface-2); color: var(--ink-2); border: 1px solid var(--line); }
.cal-ev__b { padding: 6px 12px 10px; }
.cal-ev__title { font-size: 14px; font-weight: 600; color: var(--ink); margin: 2px 0; }
.cal-ev__meta { display: flex; flex-wrap: wrap; gap: 8px; font-size: 12px; color: var(--ink-3); }
.cal-ev__sc, .cal-ev__prec { font-family: var(--font-mono); }
.cal-ev__reason { font-size: 12px; color: var(--ink-2); margin: 4px 0 0; }
.cal-ev__next { font-size: 12px; color: var(--accent-ink); margin: 3px 0 0; }
.cal-ev__cta { display: flex; flex-wrap: wrap; gap: 6px; margin: 8px 0 0; }
.cal-checklist { display: flex; flex-direction: column; gap: 8px; padding: 12px 14px; }
.cal-cl { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
  border: 1px solid var(--line); border-radius: var(--r); padding: 8px 12px; background: var(--surface); }
.cal-cl.is-overdue { border-color: var(--bad-line); background: var(--bad-bg); }
.cal-cl__title { font-size: 13px; font-weight: 600; color: var(--ink); }
.cal-cl__meta { display: flex; flex-wrap: wrap; gap: 8px; font-size: 12px; color: var(--ink-3); margin-top: 2px; }
.cal-cl__a { display: flex; gap: 6px; flex-wrap: wrap; }
.cal-month { padding: 12px 14px; }
.cal-month__row { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal-month__row--head { margin-bottom: 4px; }
.cal-month__dow { font-size: 11px; color: var(--ink-4); text-align: center; padding: 2px 0; }
.cal-month__cell { position: relative; min-height: 46px; border: 1px solid var(--line); border-radius: var(--r-sm);
  padding: 4px 6px; background: var(--surface); }
.cal-month__cell--empty { background: transparent; border-color: transparent; }
.cal-month__cell.is-today { outline: 2px solid var(--accent); }
.cal-month__cell.has-ev { background: var(--surface-2); }
.cal-month__day { font-size: 11px; color: var(--ink-3); }
.cal-month__dot { position: absolute; right: 5px; bottom: 4px; font-size: 11px; min-width: 16px; height: 16px; line-height: 16px;
  text-align: center; border-radius: 999px; color: #fff; padding: 0 3px; }
.cal-month__dot--bad { background: var(--bad); }
.cal-month__dot--warn { background: var(--warn); }
.cal-month__dot--accent { background: var(--accent); }
.cal-month__dot--ok { background: var(--mute); }

/* application pipeline */
.board--pipe { overflow-x: auto; }
.board--pipe .lane { min-width: 180px; }
.appcard__fit { margin-top: 6px; }
.app-actions { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 8px; }
.btn--sm { padding: 4px 10px; font-size: 12px; }

/* versioned documents */
.docrow--v { align-items: flex-start; }
.docvers { display: flex; gap: 6px; flex-wrap: wrap; margin: 8px 0; }
.docver { font-size: 11px; padding: 2px 8px; border-radius: 4px; border: 1px solid var(--line); }
.docver--ready { background: var(--ok-bg); color: var(--ok); border-color: var(--ok-line); }
.docver--outdated { background: var(--warn-bg); color: var(--warn); border-color: var(--warn-line); }
.docver--draft { background: #F0EEE9; color: var(--ink-2); }
.docver--missing { background: var(--bad-bg); color: var(--bad); border-color: var(--bad-line); }
.docadd { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; margin-top: 6px; }
.input--sm { padding: 4px 8px; font-size: 12px; max-width: 160px; }

/* membership intake box */
.hs-membership-box { background: #F4F2EC; border: 1px solid var(--line); border-radius: 8px; padding: 12px; }

/* =========================================================================
   A2 — Source Radar + Link-Out Call Cards + risk-check wedge hero
   (no remote resources, no url() — local, file://-safe)
   ========================================================================= */
.radar-thesis { margin-bottom: 14px; }
.radar-section { margin: 18px 0 26px; }
.radar-section__h { display: grid; grid-template-columns: 1fr auto; align-items: baseline; gap: 4px 12px; margin-bottom: 10px; border-bottom: 1px solid var(--line); padding-bottom: 8px; }
.radar-section__eyebrow { grid-column: 1; font-size: 11px; letter-spacing: .06em; text-transform: uppercase; color: var(--accent); font-weight: 600; }
.radar-section__h h2 { grid-column: 1; margin: 2px 0 0; font-size: 17px; }
.radar-section__sub { grid-column: 1; margin: 2px 0 0; font-size: 12.5px; color: var(--ink-3); max-width: 70ch; }
.radar-section__count { grid-column: 2; grid-row: 1 / span 3; align-self: center; font-size: 11px; color: var(--ink-4); font-variant-numeric: tabular-nums; white-space: nowrap; }

.rcard-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 12px; }
.rcard { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 14px; box-shadow: var(--shadow-1); display: flex; flex-direction: column; gap: 8px; }
.rcard--blocked_source_card { border-color: var(--bad-line); background: linear-gradient(0deg, var(--bad-bg) 0%, var(--surface) 60%); }
.rcard--official_api_source_card { border-color: var(--info-line); }
.rcard__head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.rcard__name { font-weight: 600; font-size: 14.5px; }
.rcard-badge { font-size: 10px; letter-spacing: .04em; font-weight: 700; padding: 2px 7px; border-radius: 999px; background: var(--mute-bg); color: var(--ink-2); border: 1px solid var(--mute-line); white-space: nowrap; }
.rcard-badge--api { background: var(--info-bg); color: var(--info); border-color: var(--info-line); }
.rcard-badge--public { background: var(--ok-bg); color: var(--ok); border-color: var(--ok-line); }
.rcard-badge--linkout { background: var(--accent-soft); color: var(--accent-ink); border-color: var(--accent-line); }
.rcard-badge--member { background: var(--warn-bg); color: var(--warn); border-color: var(--warn-line); }
.rcard-badge--blocked { background: var(--bad-bg); color: var(--bad); border-color: var(--bad-line); }
.rcard-badge--human { background: #F0EEE9; color: var(--ink-2); }
.rcard-badge--risk { background: var(--bad-bg); color: var(--bad); border-color: var(--bad-line); margin-left: auto; }
.rcard__meta { display: grid; grid-template-columns: auto 1fr; gap: 2px 10px; margin: 0; font-size: 12px; }
.rcard__meta dt { color: var(--ink-3); }
.rcard__meta dd { margin: 0; color: var(--ink); }
.rcard__allowed { margin: 2px 0; font-size: 12px; color: var(--ink-2); background: var(--surface-2); border-radius: var(--r-sm); padding: 7px 9px; }
.rcard__chips { display: flex; gap: 6px; flex-wrap: wrap; }
.rcard__reason { margin: 0; font-size: 12px; color: var(--ink-3); }
.rcard__reason--nogo { color: var(--bad); font-weight: 600; }
.rcard__blocked { margin: 0; font-size: 12px; color: var(--bad); font-weight: 600; }
.rcard__ctas { display: flex; gap: 6px; flex-wrap: wrap; margin-top: auto; padding-top: 4px; }

.radar-notice { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 10px 14px; border-radius: var(--r); margin-bottom: 14px; font-size: 13px; }
.radar-notice--ok { background: var(--ok-bg); color: var(--ok); border: 1px solid var(--ok-line); }
.radar-notice--err { background: var(--bad-bg); color: var(--bad); border: 1px solid var(--bad-line); }

/* risk-check wedge hero — makes the checker visually dominant */
.risk-hero { display: flex; gap: 16px; align-items: flex-start; background: linear-gradient(120deg, var(--accent-soft) 0%, var(--surface) 70%); border: 1px solid var(--accent-line); border-radius: var(--r-lg); padding: 18px 20px; margin: 4px 0 16px; }
.risk-hero__icon { font-size: 34px; line-height: 1; color: var(--accent-ink); }
.risk-hero__h { margin: 0 0 4px; font-size: 19px; color: var(--accent-ink); }
.risk-hero__p { margin: 0; font-size: 13px; color: var(--ink-2); max-width: 78ch; }

/* =========================================================================
   A2 statement/bio template layer — Documents & Templates view
   ========================================================================= */
.tpl-section { margin: 4px 0 22px; }
.tpl-head { margin-bottom: 10px; }
.tpl-h2 { font-size: 18px; margin: 0 0 4px; color: var(--ink); }
.tpl-h3 { font-size: 15px; margin: 0 0 8px; color: var(--ink); }
.tpl-note { margin: 0 0 8px; font-size: 12.5px; color: var(--ink-2); max-width: 86ch; }
.tpl-summary { display: flex; gap: 6px; flex-wrap: wrap; margin: 6px 0 4px; }
.tpl-chip { white-space: nowrap; }
.tpl-chip--muted { color: var(--ink-3); }
.tpl-filter { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin: 6px 0; }
.tpl-filter__lbl { font-size: 11px; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-3); margin-right: 4px; }
.tpl-filter__a { font-size: 12px; padding: 3px 10px; border-radius: 999px; text-decoration: none; color: var(--ink-2); background: var(--mute-bg); border: 1px solid var(--mute-line); }
.tpl-filter__a.is-active { background: var(--accent-soft); color: var(--accent-ink); border-color: var(--accent-line); font-weight: 600; }
.tpl-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; margin-top: 10px; }
.tpl-card { display: flex; flex-direction: column; gap: 6px; border: 1px solid var(--line); border-radius: var(--r); padding: 12px 13px; background: var(--surface); }
.tpl-card--outdated { border-color: var(--warn-line); }
.tpl-card--missing { border-color: var(--bad-line); }
.tpl-card__top { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.tpl-card__title { font-weight: 600; font-size: 14px; color: var(--ink); }
.tpl-card__meta { font-size: 11.5px; color: var(--ink-3); }
.tpl-card__limits { font-size: 11.5px; color: var(--ink-2); }
.tpl-card__limit { white-space: nowrap; }
.tpl-card__preview { font-size: 12px; color: var(--ink-2); background: var(--surface-2); border-radius: var(--r-sm); padding: 7px 9px; white-space: pre-wrap; }
.tpl-card__notes { font-size: 11.5px; }
.tpl-card__use { margin-top: 2px; }
.tpl-badge { font-size: 10px; letter-spacing: .04em; font-weight: 700; padding: 2px 7px; border-radius: 999px; background: var(--mute-bg); color: var(--ink-2); border: 1px solid var(--mute-line); }
.tpl-badge--type { background: var(--accent-soft); color: var(--accent-ink); border-color: var(--accent-line); }
.tpl-badge--lang { background: var(--info-bg); color: var(--info); border-color: var(--info-line); }
.tpl-fit { border: 1px solid var(--accent-line); background: linear-gradient(120deg, var(--accent-soft) 0%, var(--surface) 70%); border-radius: var(--r-lg); padding: 14px 16px; margin: 8px 0 14px; }
.tpl-fit__picker { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-bottom: 8px; }
.tpl-fit__table { border-collapse: collapse; width: 100%; font-size: 12px; margin: 6px 0; }
.tpl-fit__table td, .tpl-fit__table th { border: 1px solid var(--line); padding: 5px 8px; text-align: left; }
.tpl-fit__report { margin-top: 6px; }
.tpl-warns { margin: 6px 0 0; padding-left: 18px; font-size: 12px; }
.tpl-warn--warn { color: var(--warn); }
.tpl-warn--danger { color: var(--bad); }
.tpl-warn--info { color: var(--ink-2); }
.doclib-section { margin-top: 22px; padding-top: 14px; border-top: 1px solid var(--line); }

/* RC v0.3 — workspace edit-draft editor (applications + reminders) */
.ws-edit { margin-top: 12px; padding-top: 10px; border-top: 1px dashed var(--accent-line); }
.ws-edit-list { display: flex; flex-direction: column; gap: 10px; margin: 8px 0; }
.ws-edit-row { border: 1px solid var(--line); border-radius: var(--r); padding: 10px 12px; background: var(--surface); }
.ws-edit-row.is-edited { border-color: var(--accent-line); background: var(--accent-soft); }
.ws-edit-rowhead { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 6px; font-size: 12.5px; }
.ws-edit-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 8px; }
.ws-edit-field { display: flex; flex-direction: column; gap: 3px; }
.ws-edit-label { font-size: 11px; color: var(--ink-3); letter-spacing: .02em; }
.ws-edit-input { width: 100%; }
.ws-edit-controls { margin-top: 10px; padding-top: 8px; border-top: 1px solid var(--line); }
.ws-edit-check { width: auto; transform: scale(1.1); margin-top: 2px; align-self: flex-start; }
.ws-fn-warn { color: var(--bad, #b42318); margin-top: 2px; }
.ws-assembly { margin-top: 10px; padding-top: 8px; border-top: 1px dashed var(--accent-line); }
