/* ============================================================
   expert-detail.css — shared page styles for /app/expert.php and
   its four type-specific layouts (fund, congress, insider, activist).
   Copied verbatim from design-system/ui_kits/web/expert-fund.html
   (the embedded <style> block).
   ============================================================ */

.full-rule { border-top: 1px solid var(--cream-400); }
.ink-rule  { border-top: 1px solid var(--ink-900); }

/* Section heads — serif h3 + small mono caption right */
.sec-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  border-bottom: 1px solid var(--ink-900);
  padding: 28px 0 10px;
  margin: 32px 0 16px;
}
.sec-head h3 {
  font: 500 26px/1.05 var(--serif);
  letter-spacing: -0.022em;
  color: var(--ink-900);
  margin: 0;
  white-space: nowrap;
}
.sec-head h3 .ac { font-style: italic; font-weight: 500; color: var(--accent); }
.sec-head .cap {
  font: 500 11px var(--mono);
  text-transform: uppercase;
  letter-spacing: var(--tr-caps);
  color: var(--ink-500);
  white-space: nowrap;
}

.ed-cap {
  font: 400 italic 13px/1.5 var(--serif);
  color: var(--ink-500);
  margin: 12px 0 0;
  max-width: 56ch;
}

.pro-link {
  font: 500 12px var(--sans);
  text-transform: uppercase;
  letter-spacing: var(--tr-caps);
  color: var(--ink-900);
  text-decoration: underline;
  text-decoration-color: var(--accent);
  text-underline-offset: 4px;
  display: inline-block;
  margin-top: 18px;
}
.pro-link:hover { color: var(--accent); }

.source-attrib {
  font: 400 12px/1.4 var(--sans);
  color: var(--ink-500);
  text-align: center;
  padding: 18px 0 24px;
  margin-top: 24px;
  border-top: 1px solid var(--cream-300);
  font-variant-numeric: tabular-nums;
}

/* On expert-detail pages the source-attrib serves as the page-end signpost.
   The global main padding-bottom (64px) + footer margin-top (80px) stack
   leaves a sparse cream band of ~180px below source-attrib before the
   footer — reads as a layout bug. Tighten on these pages only. */
.app-main:has(.source-attrib) { padding-bottom: var(--s-6); }
.app-main:has(.source-attrib) + .app-footer { margin-top: var(--s-6); }

/* ============================================================
   Expert header — 72×72 avatar, serif h1, sans meta line, follow button
   ============================================================ */
.eh {
  max-width: var(--container);
  margin: 0 auto;
  padding: 44px 32px 28px;
}
.eh__grid {
  display: grid;
  grid-template-columns: 72px 1fr auto;
  column-gap: 24px;
  align-items: center;
}
.eh__avatar {
  width: 72px;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: -0.01em;
}
.eh__avatar--fund {
  background: var(--ink-900);
  color: var(--cream-50);
  font: 500 22px/1 var(--mono-brand);
}
.eh__avatar--insider {
  background: var(--cream-300);
  color: var(--ink-700);
  font: 500 26px/1 var(--serif);
}
.eh__avatar--politician {
  font: 500 26px/1 var(--serif);
}
.eh__avatar--politician.party--d { background: #DCE4F0; color: #1B3A6C; }
.eh__avatar--politician.party--r { background: #F0DCDC; color: #6F1B2E; }
/* kind="company" — square cream ground with ticker in mono-brand.
   Mirrors design-system company avatar: cream-200 + ink-900 + mono-brand. */
.eh__avatar--company {
  background: var(--cream-200);
  color: var(--ink-900);
  font: 500 20px/1 var(--mono-brand);
  letter-spacing: 0.02em;
}
.eh__avatar--politician.party--i { background: #E5DFD2; color: #4A3D2A; }

.eh__name {
  font: 500 36px/1.05 var(--serif);
  letter-spacing: -0.022em;
  color: var(--ink-900);
  margin: 0 0 6px;
}
.eh__meta {
  font: 400 13px/1.4 var(--sans);
  color: var(--ink-500);
  display: flex;
  flex-wrap: wrap;
  gap: 0 10px;
  align-items: center;
}
.eh__meta .sep { color: var(--ink-300); }
.eh__meta .lead { color: var(--ink-800); white-space: nowrap; }
.eh__meta span { white-space: nowrap; }

.eh__follow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font: 500 var(--t-body-s) var(--sans);
  padding: 8px 18px;
  border: 1px solid var(--ink-900);
  background: transparent;
  color: var(--ink-900);
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.eh__follow:hover { background: var(--ink-900); color: var(--cream-50); }
.eh__follow[aria-pressed="true"] { background: var(--ink-900); color: var(--cream-50); }
.eh__follow[aria-pressed="true"]:hover { background: var(--accent); border-color: var(--accent); }

/* ============================================================
   KPI strip — 6 cells across, hairline dividers, ink rules above/below
   ============================================================ */
.diq-kpi-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  border-top: 1px solid var(--ink-900);
  border-bottom: 1px solid var(--ink-900);
}
.diq-kpi-cell {
  padding: 22px 24px 22px 24px;
  border-left: 1px solid var(--cream-300);
  min-width: 0;
}
.diq-kpi-cell:first-child {
  border-left: 0;
  padding-left: 0;
}
.diq-kpi-cell:last-child { padding-right: 0; }
.diq-kpi-cell__label {
  font: 500 11px/1 var(--sans);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ink-500);
  margin-bottom: 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.diq-kpi-cell__row {
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: nowrap;
}
.diq-kpi-cell__value {
  font: 500 26px/1 var(--serif);
  letter-spacing: -0.02em;
  color: var(--ink-900);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.diq-kpi-cell__value--text  { font-size: 20px; line-height: 1.1; }
.diq-kpi-cell__value--accent { font-style: italic; color: var(--accent); font-size: 22px; line-height: 1.1; }
.diq-kpi-cell__value--pending { color: var(--ink-300); }
.diq-kpi-cell__delta {
  font: 500 11px/1 var(--mono);
  color: var(--ink-500);
  text-transform: uppercase;
  letter-spacing: var(--tr-caps);
  white-space: nowrap;
}

@media (max-width: 980px) {
  .diq-kpi-strip { grid-template-columns: repeat(3, 1fr); }
  .diq-kpi-cell:nth-child(n+4) { border-top: 1px solid var(--cream-300); }
  .diq-kpi-cell:nth-child(3n+1) { border-left: 0; padding-left: 0; }
}

/* ============================================================
   Holdings table — continuous list, hairline separators
   ============================================================ */
.diq-holdings__row {
  display: grid;
  grid-template-columns: 32px 90px 1fr 80px 100px;
  column-gap: 16px;
  align-items: center;
  padding: 14px 0;
  border-top: 1px solid var(--cream-300);
  transition: background 80ms var(--ease);
  text-decoration: none;
  color: inherit;
}
/* Variant used while the shares-ingest bug is unresolved: 4 cols, no shares. */
.diq-holdings__row--no-shares {
  grid-template-columns: 32px 90px 1fr 80px;
}
.diq-holdings__row:hover { background: var(--cream-50); }
.diq-holdings__rank {
  font: 400 12px var(--mono);
  color: var(--ink-400);
  font-variant-numeric: tabular-nums;
}
.diq-holdings__ticker {
  font: 500 18px var(--mono);
  color: var(--ink-900);
  font-variant-numeric: tabular-nums;
}
.diq-holdings__company {
  font: 500 16px/1.2 var(--serif);
  color: var(--ink-900);
  letter-spacing: -0.005em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.diq-holdings__weight {
  font: 400 14px var(--mono);
  color: var(--ink-700);
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.diq-holdings__shares {
  font: 400 11px var(--mono);
  color: var(--ink-500);
  font-variant-numeric: tabular-nums;
  text-align: right;
}
@media (max-width: 980px) {
  .diq-holdings__row { grid-template-columns: 28px 80px 1fr 70px; }
  .diq-holdings__shares { display: none; }
}

/* ============================================================
   Pending placeholder — applied to KPI cells / chart areas with no data.
   Baseline: visible dashed box that sizes to its content (eyebrow + h4 + p).
   No reserved empty area below the text and no implied stats column on the
   right — the box ends where the copy ends.
   ============================================================ */
.perf-pending {
  border: 1px solid var(--cream-300);
  background: var(--bg-elev);
  padding: var(--s-6) var(--s-6);
}
/* Chart-area pending block — centred, taller so it visually sits in the
   chart well. Only this variant gets the reserved height. */
[data-pending="metrics-pipeline"] .perf-pending {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--s-7) var(--s-7);
  min-height: 180px;
}
.perf-pending .eyebrow { color: var(--accent); margin-bottom: var(--s-3); }
.perf-pending h4 {
  font: 500 var(--t-display-s)/1.2 var(--serif);
  letter-spacing: -0.02em;
  color: var(--ink-900);
  margin: 0 0 var(--s-3);
  max-width: 32ch;
}
.perf-pending h4 i { font-style: italic; font-weight: 500; color: var(--accent); }
.perf-pending p { margin: 0; color: var(--ink-700); max-width: 64ch; }

/* Compact wrapping for sec-head when caption gets long */
@media (max-width: 720px) {
  .sec-head { flex-wrap: wrap; row-gap: 12px; }
}
/* G1 (Bundle #3): below 480px the long h3 ("Convergence · Pattern Engine
   ships in v1.1") was rendering on a single line because of `white-space:
   nowrap` higher up — driving horizontal overflow on Buffett/Akre/AAPL.
   Allow wrap + tighten font on narrow screens. */
@media (max-width: 480px) {
  .sec-head { flex-direction: column; align-items: flex-start; gap: 6px; }
  .sec-head h3 { white-space: normal; font-size: 22px; }
  .sec-head .cap { white-space: normal; }
}

/* ============================================================
   Context section — two-column grid, lede + facts table
   (used by expert-congress layout)
   ============================================================ */
.ctx-grid {
  display: grid;
  grid-template-columns: 60% 40%;
  gap: 48px;
}
.ctx-lede {
  font: 400 17px/1.65 var(--serif);
  color: var(--ink-800);
  margin: 0;
  max-width: 56ch;
}
.facts { border-top: 1px solid var(--ink-900); }
.fact-row {
  display: grid;
  grid-template-columns: 160px 1fr;
  column-gap: 16px;
  padding: 10px 0;
  border-bottom: 1px solid var(--cream-300);
  align-items: baseline;
}
.fact-row:last-child { border-bottom: 1px solid var(--ink-900); }
.fact-row .lab {
  font: 500 12px var(--sans);
  color: var(--ink-500);
  text-transform: uppercase;
  letter-spacing: var(--tr-caps);
}
.fact-row .val {
  font: 400 13px/1.45 var(--sans);
  color: var(--ink-900);
}
.fact-row .val--pending { color: var(--ink-300); }

@media (max-width: 980px) {
  .ctx-grid { grid-template-columns: 1fr; gap: 28px; }
}

/* Smaller pending block style used for in-section gaps */
.perf-pending--inline {
  padding: var(--s-5) var(--s-5);
}

/* ============================================================
   TransactionList — Form 4 chronological list (insider layout).
   Mirrors design-system/ui_kits/web/TransactionList.jsx exactly:
   six columns, hairline separators, mono numerics, code pill.
   ============================================================ */
.diq-tx-list { display: block; }
.diq-tx__row {
  display: grid;
  grid-template-columns: 100px 90px 80px 100px 90px 60px;
  column-gap: 16px;
  align-items: center;
  padding: 13px 0;
  border-top: 1px solid var(--cream-300);
  transition: background 80ms var(--ease);
}
.diq-tx__row:hover { background: var(--cream-50); }
.diq-tx__date {
  font: 400 12px var(--mono);
  color: var(--ink-500);
  font-variant-numeric: tabular-nums;
}
.diq-tx__verb {
  font: 500 12px var(--mono);
  text-transform: uppercase;
  letter-spacing: var(--tr-caps);
  color: var(--ink-700);
}
.diq-tx__verb--bought { color: var(--cat-fund); }
.diq-tx__verb--sold   { color: var(--cat-activist); }
.diq-tx__ticker {
  font: 500 16px var(--mono);
  color: var(--ink-900);
  letter-spacing: 0;
}
.diq-tx__shares,
.diq-tx__price {
  font: 400 13px var(--mono);
  color: var(--ink-700);
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.diq-tx__codecell { text-align: right; }
.diq-tx__codepill {
  font: 500 11px var(--mono);
  color: var(--ink-800);
  background: var(--cream-300);
  padding: 2px 7px;
  letter-spacing: 0;
}
@media (max-width: 720px) {
  .diq-tx__row { grid-template-columns: 88px 72px 1fr 80px 50px; column-gap: 10px; }
  .diq-tx__price { display: none; }
}

/* ============================================================
   Cluster context list — insider layout, "company's other insiders"
   panel. Self-row gets cream-50 background and a "this page" tag.
   ============================================================ */
.cluster-row {
  display: grid;
  grid-template-columns: 100px 1fr 1fr 90px 100px;
  column-gap: 16px;
  align-items: baseline;
  padding: 13px 16px 13px 0;
  border-top: 1px solid var(--cream-300);
}
.cluster-row.self {
  background: var(--cream-50);
  padding-left: 16px;
  margin: 0 -16px;
}
.cluster-row .cluster__date {
  font: 400 12px var(--mono);
  color: var(--ink-500);
  font-variant-numeric: tabular-nums;
}
.cluster-row .cluster__name {
  font: 500 14px/1.3 var(--serif);
  color: var(--ink-900);
  letter-spacing: -0.005em;
}
.cluster-row .cluster__role {
  font: 400 13px/1.3 var(--sans);
  color: var(--ink-500);
}
.cluster-row .cluster__verb {
  font: 500 12px var(--mono);
  color: var(--cat-fund);
  text-transform: uppercase;
  letter-spacing: var(--tr-caps);
}
.cluster-row .cluster__amount {
  font: 500 13px var(--mono);
  color: var(--ink-800);
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.cluster__selftag {
  font: 500 10px var(--mono);
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: var(--tr-caps);
  margin-left: 10px;
  vertical-align: 2px;
}
@media (max-width: 980px) {
  .cluster-row { grid-template-columns: 76px 1fr 76px; column-gap: 12px; }
  .cluster-row .cluster__role,
  .cluster-row .cluster__amount { display: none; }
}

/* ============================================================
   ed-context — editorial paragraph block (insider/activist layouts).
   ============================================================ */
.ed-context p {
  font: 400 17px/1.65 var(--serif);
  color: var(--ink-800);
  margin: 0;
  max-width: 60ch;
  letter-spacing: -0.003em;
}

/* ============================================================
   CampaignEntry — activist layout. Two-column block: editorial
   body on the left, 2×3 stats grid on the right. Mirrors
   design-system/ui_kits/web/CampaignEntry.jsx exactly.
   ============================================================ */
.campaign-entry {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
  column-gap: 56px;
  padding: 40px 0 44px;
  border-top: 1px solid var(--cream-300);
  align-items: start;
}
.campaign-entry__left { min-width: 0; }
.campaign-entry__eyebrow {
  font: 500 11px var(--mono);
  text-transform: uppercase;
  letter-spacing: var(--tr-caps);
  color: var(--ink-500);
  margin-bottom: 14px;
}
.campaign-entry__ticker {
  font: 500 28px/1 var(--mono);
  letter-spacing: 0;
  color: var(--ink-900);
  margin-bottom: 16px;
}
.campaign-entry__body {
  font: 400 17px/1.55 var(--serif);
  color: var(--ink-800);
  margin: 0 0 18px;
  max-width: 44ch;
  letter-spacing: -0.003em;
}
.campaign-entry__body .ac { color: var(--accent); font-weight: 500; }
.campaign-entry__cta {
  font: 500 12px var(--sans);
  text-transform: uppercase;
  letter-spacing: var(--tr-caps);
  color: var(--ink-900);
  text-decoration: underline;
  text-decoration-color: var(--accent);
  text-underline-offset: 4px;
}
.campaign-entry__cta:hover { color: var(--accent); }
.campaign-entry__right { min-width: 0; }
.campaign-entry__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--ink-900);
  border-bottom: 1px solid var(--ink-900);
}
.campaign-stat {
  padding: 14px 16px 14px 0;
  min-width: 0;
}
.campaign-stat--col2 {
  border-left: 1px solid var(--cream-300);
  padding-left: 16px;
  padding-right: 0;
}
.campaign-stat--row2,
.campaign-stat--row3 {
  border-top: 1px solid var(--cream-300);
}
.campaign-stat__label {
  font: 500 11px/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: var(--tr-caps);
  color: var(--ink-500);
  margin-bottom: 8px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.campaign-stat__value {
  font: 500 22px/1 var(--serif);
  letter-spacing: -0.015em;
  color: var(--ink-900);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.campaign-stat__value--pending { color: var(--ink-300); }
@media (max-width: 980px) {
  .campaign-entry { grid-template-columns: 1fr; column-gap: 0; row-gap: 28px; }
}

/* ============================================================
   Past campaigns — condensed closed-list rows (activist layout).
   Mirrors expert-activist.html .closed-row.
   ============================================================ */
.closed-row {
  display: grid;
  grid-template-columns: 110px 1fr 220px;
  column-gap: 24px;
  align-items: baseline;
  padding: 14px 0;
  border-top: 1px solid var(--cream-300);
}
.closed-row__tk {
  font: 500 17px var(--mono);
  color: var(--ink-900);
  letter-spacing: 0;
}
.closed-row__meta {
  font: 400 12px var(--mono);
  color: var(--ink-500);
  margin-left: 12px;
  font-variant-numeric: tabular-nums;
}
.closed-row__desc {
  font: 400 14px/1.4 var(--serif);
  color: var(--ink-700);
  letter-spacing: -0.003em;
}
.closed-row__peak {
  font: 500 13px var(--mono);
  color: var(--ink-700);
  font-variant-numeric: tabular-nums;
  text-align: right;
}

/* Past-campaigns in-development block (campaign-tracking marker) —
   reuses the .perf-pending visual treatment so the section reads as
   intentional and content-sized rather than empty cream. */
[data-pending="campaign-tracking"] .perf-pending {
  background: var(--bg-elev);
}
