/* ============================================================
   Resto AI · Social Media Command Center
   Sibling of the SEO Command Center: reuses the shared shell
   styles from seo-command-center.css (.seo-card, .seo-cli,
   .seo-brief, .seo-toolbar, .seo-seg, .seo-grid, .seo-d-head,
   .seo-kpis, score ring, health chips) and adds ONLY the
   social-specific soc-* components (handoff_social port) plus
   the phase-1 additions: driver breakdown, metric popovers,
   connect states. Theme tokens only — no literal page colors.
   ============================================================ */

.soc-page { padding: 30px 36px 80px; max-width: 1320px; margin: 0 auto; }
.soc-detail { padding: 26px 36px 90px; max-width: 1180px; margin: 0 auto; }

/* RepCharts text tokens inside the social pages (same alias as the SEO CC) */
.soc-page, .soc-detail {
  --fg-1: var(--seo-fg);
  --fg-2: var(--seo-fg2);
  --fg-3: var(--seo-fg3);
  --fg-muted: var(--seo-mut);
  --surface-page: var(--seo-card);
}

.soc-loading { text-align: center; color: var(--seo-fg3); padding: 60px 20px; font-size: 14px; }
.soc-grid-empty { text-align: center; padding: 60px 20px; color: var(--seo-fg3); font-size: 14px; }

/* ---------- platform chips ---------- */
.soc-plats { display: inline-flex; align-items: center; gap: 5px; }
.soc-plat { display: inline-flex; align-items: center; justify-content: center; }
.soc-plat.future { color: var(--seo-mut) !important; opacity: .5; }
.soc-plat.none { color: var(--seo-mut); opacity: .6; }

/* ---------- control bar ---------- */
.soc-controls { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 18px; }
.soc-ctrl-group { display: flex; align-items: center; gap: 7px; }
.soc-ctrl-lbl { font-size: 10.5px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--seo-mut); }
.soc-select { height: 36px; background: var(--seo-card); border: 1px solid var(--seo-line); border-radius: 10px;
  color: var(--seo-fg2); font: 500 12.5px Inter, sans-serif; padding: 0 12px; cursor: pointer; }
.soc-select:hover { border-color: var(--border-strong, #5a4d3b); }
.soc-spacer { flex: 1; }

/* ---------- health summary strip ---------- */
.soc-healthbar { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 22px; }
.soc-hcell { background: var(--seo-card); border: 1px solid var(--seo-line); border-radius: 12px; padding: 16px 18px;
  position: relative; overflow: hidden; cursor: pointer; transition: border-color .16s var(--seo-ease), transform .16s var(--seo-ease); }
.soc-hcell:hover { border-color: var(--border-strong, #5a4d3b); transform: translateY(-2px); }
.soc-hcell.active { border-color: var(--hc); }
.soc-hcell::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--hc); }
.soc-hcell .hc-top { display: flex; align-items: center; gap: 8px; }
.soc-hcell .hc-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--hc); }
.soc-hcell .hc-lbl { font-size: 12.5px; font-weight: 600; color: var(--seo-fg); }
.soc-hcell .hc-n { font: 600 30px var(--font-mono, monospace); letter-spacing: -.03em; color: var(--seo-fg);
  font-variant-numeric: tabular-nums; margin-top: 12px; line-height: 1; }
.soc-hcell .hc-note { font-size: 11px; color: var(--seo-fg3); margin-top: 8px; line-height: 1.4; }

/* ---------- alert feed ---------- */
.soc-alert-row { display: flex; align-items: flex-start; gap: 12px; padding: 12px 20px; border-bottom: 1px solid var(--seo-line-soft);
  cursor: pointer; transition: background .14s var(--seo-ease); }
.soc-alert-row:last-child { border-bottom: 0; }
.soc-alert-row:hover { background: var(--seo-card-2); }
.soc-alert-ic { flex: none; width: 30px; height: 30px; border-radius: 8px; display: flex; align-items: center; justify-content: center; }
.soc-alert-main { flex: 1; min-width: 0; }
.soc-alert-name { font-size: 13px; font-weight: 600; color: var(--seo-fg); display: flex; align-items: center; gap: 7px; }
.soc-alert-name .d { width: 6px; height: 6px; border-radius: 50%; }
.soc-alert-text { font-size: 12.5px; color: var(--seo-fg3); line-height: 1.45; margin-top: 2px; }
.soc-alert-go { flex: none; color: var(--seo-mut); display: flex; align-items: center; }
.soc-alert-row:hover .soc-alert-go { color: var(--brand, #FB5F2C); }
.soc-alert-empty { padding: 24px 20px; font-size: 13px; color: var(--seo-fg3); }

/* two-column overview row: briefing + alerts */
.soc-two { display: grid; grid-template-columns: 1.25fr 1fr; gap: 22px; margin-bottom: 22px; align-items: start; }
@media (max-width: 1080px) { .soc-two { grid-template-columns: 1fr; } }

/* ---------- client card additions ---------- */
.seo-cli .soc-cli-meta { display: flex; align-items: center; gap: 8px; margin-top: 7px; font-size: 11.5px; color: var(--seo-fg3); flex-wrap: wrap; }
.seo-cli .soc-cli-meta .sep { width: 3px; height: 3px; border-radius: 50%; background: var(--seo-mut); }
.soc-cli-foot { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin-top: 14px; padding-top: 13px; border-top: 1px solid var(--seo-line-soft); }
.soc-cli-foot .ff { display: flex; flex-direction: column; gap: 3px; padding-right: 8px; }
.soc-cli-foot .ff .fl { font-size: 10px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--seo-mut); }
.soc-cli-foot .ff .fv { font: 600 13.5px var(--font-mono, monospace); color: var(--seo-fg2); font-variant-numeric: tabular-nums; display: flex; align-items: center; gap: 5px; }
.soc-cli-foot .ff .fv.up { color: var(--h-great); } .soc-cli-foot .ff .fv.down { color: var(--h-risk); }
.soc-bench-mini { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; color: var(--seo-fg3); margin-top: 5px; }
.soc-bench-mini .bm-dot { width: 6px; height: 6px; border-radius: 50%; }

/* card cadence row */
.soc-cli-freq { display: flex; align-items: center; gap: 10px; margin-top: 12px; padding: 9px 11px; border-radius: 9px;
  background: var(--seo-card-2); border: 1px solid var(--seo-line-soft); }
.soc-cli-freq .cf-pair { display: flex; align-items: baseline; gap: 5px; }
.soc-cli-freq .cf-v { font: 600 14px var(--font-mono, monospace); color: var(--seo-fg); font-variant-numeric: tabular-nums; }
.soc-cli-freq .cf-l { font-size: 10.5px; color: var(--seo-fg3); }
.soc-cli-freq .cf-sep { width: 1px; height: 18px; background: var(--seo-line); }
.soc-cli-freq .cf-tag { margin-left: auto; font-size: 9.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; padding: 3px 8px; border-radius: 999px; }
.soc-cli-freq .cf-tag[data-tone="great"] { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 13%, transparent); }
.soc-cli-freq .cf-tag[data-tone="watch"] { color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 13%, transparent); }
.soc-cli-freq .cf-tag[data-tone="risk"] { color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 13%, transparent); }
.soc-cli-stale { display: inline-flex; align-items: center; gap: 5px; font-size: 10.5px; font-weight: 600; padding: 3px 8px; border-radius: 999px;
  color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 13%, transparent); }
.soc-connect-chip { display: inline-flex; align-items: center; gap: 4px; color: var(--seo-fg3) !important; font-size: 11px !important; }
.soc-connect-chip.big { font: 600 11px Inter, sans-serif; color: var(--seo-fg3); padding: 4px 10px; border-radius: 999px; background: var(--seo-card-2); display: inline-flex; align-items: center; gap: 6px; }

/* ============================================================
   POSTING-GAP (STALE) STRIP
   ============================================================ */
.soc-stale { margin-bottom: 22px; border: 1px solid color-mix(in srgb, var(--h-risk) 35%, var(--seo-line)); border-radius: 14px;
  overflow: hidden; background: var(--seo-card); }
.soc-stale-h { display: flex; align-items: center; gap: 11px; padding: 14px 20px; border-bottom: 1px solid var(--seo-line-soft);
  background: radial-gradient(620px 120px at 0% 0%, color-mix(in srgb, var(--h-risk) 9%, transparent), transparent 60%); }
.soc-stale-h .pulse { width: 9px; height: 9px; border-radius: 50%; background: var(--h-risk); box-shadow: 0 0 0 0 color-mix(in srgb, var(--h-risk) 60%, transparent); animation: soc-pulse 2s infinite; }
@keyframes soc-pulse { 0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--h-risk) 55%, transparent); } 70% { box-shadow: 0 0 0 8px transparent; } 100% { box-shadow: 0 0 0 0 transparent; } }
.soc-stale-h h3 { margin: 0; font-size: 14px; font-weight: 600; color: var(--seo-fg); }
.soc-stale-h .sub { font-size: 11.5px; color: var(--seo-fg3); margin-top: 1px; }
.soc-stale-h .count { margin-left: auto; font: 600 12px var(--font-mono, monospace); color: var(--h-risk); padding: 4px 10px; border-radius: 999px; background: color-mix(in srgb, var(--h-risk) 12%, transparent); }
.soc-stale-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 0; }
.soc-stale-item { display: flex; align-items: center; gap: 11px; padding: 12px 20px; border-top: 1px solid var(--seo-line-soft); border-right: 1px solid var(--seo-line-soft); cursor: pointer; transition: background .14s var(--seo-ease); }
.soc-stale-item:hover { background: var(--seo-card-2); }
.soc-stale-plat { flex: none; width: 30px; height: 30px; border-radius: 8px; display: flex; align-items: center; justify-content: center; background: var(--seo-card-2); }
.soc-stale-main { flex: 1; min-width: 0; }
.soc-stale-name { font-size: 13px; font-weight: 600; color: var(--seo-fg); }
.soc-stale-meta { font-size: 11px; color: var(--seo-fg3); margin-top: 1px; }
.soc-stale-days { flex: none; font: 700 13px var(--font-mono, monospace); padding: 4px 9px; border-radius: 8px; }
.soc-stale-days[data-sev="risk"] { color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 13%, transparent); }
.soc-stale-days[data-sev="watch"] { color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 13%, transparent); }

/* ============================================================
   CLIENT DETAIL
   ============================================================ */
.soc-d-bench { margin-left: auto; flex: none; display: flex; align-items: center; gap: 22px; }
.soc-bench-card { text-align: right; }
.soc-bench-card .bl { font-size: 10.5px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--seo-fg3); margin-bottom: 6px; }
.soc-bench-card .bv { font: 600 22px var(--font-mono, monospace); font-variant-numeric: tabular-nums; color: var(--seo-fg); }
.soc-bench-card .bs { font-size: 11.5px; margin-top: 4px; }
.soc-bench-card .bs.up { color: var(--h-great); } .soc-bench-card .bs.down { color: var(--h-risk); }
.soc-coverage-tag { display: inline-flex; align-items: center; margin-left: 8px; font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
  color: var(--seo-fg3); background: var(--seo-card-2); padding: 3px 9px; border-radius: 999px; }

/* scorecards */
.soc-scorecards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.soc-sc { background: var(--seo-card); border: 1px solid var(--seo-line); border-radius: 14px; padding: 17px 19px; }
.soc-sc .sc-top { display: flex; align-items: center; justify-content: space-between; }
.soc-sc .sc-lbl { font-size: 11.5px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--seo-fg3); }
.soc-sc .sc-ic { color: var(--seo-mut); }
.soc-sc .sc-val { font: 600 28px var(--font-mono, monospace); letter-spacing: -.03em; color: var(--seo-fg);
  font-variant-numeric: tabular-nums; margin-top: 12px; line-height: 1; display: flex; align-items: baseline; gap: 6px; }
.soc-sc .sc-foot { display: flex; align-items: center; gap: 8px; margin-top: 10px; font-size: 12px; color: var(--seo-fg3); }
.soc-sc .sc-delta { font: 600 12px var(--font-mono, monospace); }
.soc-sc .sc-delta.up { color: var(--h-great); } .soc-sc .sc-delta.down { color: var(--h-risk); }
.soc-sc-note { display: flex; align-items: flex-start; gap: 7px; margin-top: 12px; padding: 9px 12px;
  border: 1px solid var(--seo-line-soft, var(--seo-line)); border-radius: 10px; background: var(--seo-card-2);
  font-size: 11.5px; line-height: 1.5; color: var(--seo-mut); }
.soc-sc-note svg { flex: 0 0 auto; margin-top: 1px; color: var(--seo-fg3); }
.soc-sc-note strong { color: var(--seo-fg3); font-weight: 600; }
@media (max-width: 1080px) { .soc-scorecards { grid-template-columns: repeat(2, 1fr); } .soc-healthbar { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px) { .soc-scorecards, .soc-healthbar { grid-template-columns: 1fr; } }

/* score badge in card header (reused from handoff strategy layer) */
.soc-freq-score { display: flex; align-items: baseline; gap: 4px; flex-wrap: wrap; justify-content: flex-end; }
.soc-freq-score .v { font: 600 26px var(--font-mono, monospace); letter-spacing: -.03em; color: var(--fc); font-variant-numeric: tabular-nums; line-height: 1; }
.soc-freq-score .d { font-size: 12px; color: var(--seo-mut); }
.soc-freq-score .l { width: 100%; text-align: right; font-size: 10px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--seo-fg3); margin-top: 3px; }

/* ---------- driver breakdown (the WHY panel) ---------- */
.soc-drivers { padding: 16px 20px 18px; display: grid; grid-template-columns: 1fr 1fr; gap: 14px 26px; }
@media (max-width: 900px) { .soc-drivers { grid-template-columns: 1fr; } }
.soc-driver { min-width: 0; }
.soc-driver.unavail { opacity: .62; }
.soc-driver .dr-head { display: flex; align-items: baseline; gap: 9px; }
.soc-driver .dr-name { font-size: 13px; font-weight: 600; color: var(--seo-fg); display: inline-flex; align-items: center; gap: 5px; }
.soc-driver .dr-w { font-size: 10.5px; color: var(--seo-mut); }
.soc-driver .dr-conf { font-size: 9.5px; font-weight: 600; line-height: 1; padding: 2px 6px; border-radius: 5px;
  text-transform: uppercase; letter-spacing: .04em; white-space: nowrap; }
.soc-driver .dr-score { margin-left: auto; font: 600 14px var(--font-mono, monospace); font-variant-numeric: tabular-nums; }
.soc-driver .dr-score .den { font-size: 10.5px; color: var(--seo-mut); font-weight: 500; }
.soc-driver .dr-score.mut { color: var(--seo-mut); font: 600 11px Inter, sans-serif; text-transform: uppercase; letter-spacing: .05em; }
.soc-driver .dr-track { height: 7px; border-radius: 5px; background: var(--seo-card-2); overflow: hidden; margin-top: 8px; }
.soc-driver .dr-fill { height: 100%; border-radius: 5px; transition: width .5s var(--seo-ease); }
.soc-driver .dr-detail { font-size: 11.5px; color: var(--seo-fg3); line-height: 1.45; margin-top: 7px; }
.soc-driver .dr-detail strong { color: var(--seo-fg2); font-weight: 600; }
.soc-cap-note { display: flex; align-items: center; gap: 8px; margin: 0 20px 16px; padding: 10px 13px; border-radius: 10px;
  font-size: 12px; line-height: 1.45; color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 10%, transparent); }

/* per-driver basis chip: graded vs our portfolio band vs the industry fallback */
.soc-driver .dr-basis { font-size: 9.5px; font-weight: 600; line-height: 1; padding: 2px 6px; border-radius: 5px;
  letter-spacing: .01em; white-space: nowrap; }

/* ---------- Health Score v2: expert layer (transparency · assessment · why) ---------- */
/* transparency line: metric core · expert adjustment -> final score */
.soc-score-transparency { display: flex; align-items: center; flex-wrap: wrap; gap: 6px 10px;
  margin: 0 20px; padding: 11px 14px; border-radius: 11px; background: var(--seo-card-2);
  border: 1px solid var(--seo-line-soft); }
.soc-score-transparency .st-seg { display: inline-flex; align-items: baseline; gap: 7px; }
.soc-score-transparency .st-k { font-size: 10px; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; color: var(--seo-mut); }
.soc-score-transparency .st-v { font: 600 16px var(--font-mono, monospace); color: var(--seo-fg); font-variant-numeric: tabular-nums; line-height: 1; }
.soc-score-transparency .st-v.up { color: var(--h-great); } .soc-score-transparency .st-v.down { color: var(--h-risk); }
.soc-score-transparency .st-v.flat { color: var(--seo-fg3); }
.soc-score-transparency .st-op { color: var(--seo-mut); font-size: 13px; }
.soc-score-transparency .st-arrow { display: inline-flex; color: var(--seo-mut); }
.soc-score-transparency .st-seg.final .st-v { font-size: 18px; }
.soc-score-transparency.pending { justify-content: space-between; }
.soc-score-transparency .st-pending { display: inline-flex; align-items: center; gap: 5px; font-size: 11.5px; font-style: italic; color: var(--seo-mut); }
.soc-score-transparency .st-pending svg { color: var(--seo-mut); }

/* assessment badge — 4 states, --ac set inline from D.HEALTH */
.soc-assess-badge { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 700;
  line-height: 1; padding: 4px 9px; border-radius: 999px; letter-spacing: .02em; white-space: nowrap;
  color: var(--ac); background: color-mix(in srgb, var(--ac) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--ac) 30%, transparent); }
.soc-assess-badge svg { width: 12px; height: 12px; }
.soc-assess-badge.mini { font-size: 9.5px; font-weight: 700; padding: 2px 7px; margin-top: 5px; }
.soc-assess-badge.mini svg { width: 10px; height: 10px; }

/* expert block: rationale (the autocrítica) + highlights / risks lists */
.soc-expert { margin: 12px 20px 4px; display: flex; flex-direction: column; gap: 12px; }
.soc-expert-rationale { display: flex; gap: 12px; padding: 13px 14px; border-radius: 12px;
  background: color-mix(in srgb, var(--brand, #FB5F2C) 5%, var(--seo-card-2));
  border: 1px solid var(--seo-line-soft); }
.soc-expert-rationale svg { flex: none; }
.soc-expert-rationale .er-body { flex: 1; min-width: 0; }
.soc-expert-rationale .er-h { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; margin-bottom: 6px; }
.soc-expert-rationale .er-h .nm { font-size: 11px; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; color: var(--seo-fg3); }
.soc-expert-rationale p { margin: 0; font-size: 13px; line-height: 1.55; color: var(--seo-fg); }
.soc-expert-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 20px; }
@media (max-width: 760px) { .soc-expert-cols { grid-template-columns: 1fr; } }
.soc-expert-col .ec-h { display: inline-flex; align-items: center; gap: 6px; font-size: 10.5px; font-weight: 700;
  letter-spacing: .05em; text-transform: uppercase; color: var(--seo-fg3); margin-bottom: 8px; }
.soc-expert-col[data-kind="highlight"] .ec-h svg { color: var(--h-great); }
.soc-expert-col[data-kind="risk"] .ec-h svg { color: var(--h-risk); }
.soc-expert-col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 7px; }
.soc-expert-col li { display: flex; align-items: flex-start; gap: 8px; font-size: 12.5px; line-height: 1.45; color: var(--seo-fg2); }
.soc-expert-col li .ec-dot { flex: none; width: 6px; height: 6px; border-radius: 50%; margin-top: 6px; }

/* ---------- content table ---------- */
.soc-content-table { width: 100%; border-collapse: collapse; }
.soc-content-table th { text-align: left; font-size: 10.5px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
  color: var(--seo-fg3); padding: 9px 16px; border-bottom: 1px solid var(--seo-line-soft); white-space: nowrap; }
.soc-content-table td { padding: 13px 16px; border-bottom: 1px solid var(--seo-line-soft); font-size: 13px; color: var(--seo-fg2); vertical-align: top; }
.soc-content-table tr:last-child td { border-bottom: 0; }
.soc-content-table tr.expandable { cursor: pointer; }
.soc-content-table tr.expandable:hover td { background: var(--seo-card-2); }

/* expanded Resty verdict row (handoff) */
.soc-verdict-row td { background: var(--seo-card-2); }
.soc-verdict-inner { display: flex; gap: 12px; padding: 4px 0 8px; }
.soc-verdict-inner .vbody { flex: 1; }
.soc-verdict-inner .vh { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; font-size: 11px; color: var(--seo-fg3); flex-wrap: wrap; }
.soc-verdict-inner .vh .nm { font-weight: 600; color: var(--seo-fg2); }
.soc-verdict-inner p { margin: 0; font-size: 13px; line-height: 1.55; color: var(--seo-fg2); }
.soc-thumb-meta { min-width: 0; max-width: 420px; }
.soc-thumb-hook { font-size: 13px; font-weight: 500; color: var(--seo-fg); line-height: 1.35; }
.soc-thumb-sub { display: flex; align-items: center; gap: 7px; margin-top: 5px; font-size: 11px; color: var(--seo-fg3); flex-wrap: wrap; }
.soc-thumb-sub .sep { width: 3px; height: 3px; border-radius: 50%; background: var(--seo-mut); }
.soc-fmt-tag { display: inline-flex; align-items: center; gap: 5px; font-size: 10.5px; font-weight: 600; padding: 2px 8px; border-radius: 999px; }
.soc-metric-cell { font: 600 13px var(--font-mono, monospace); color: var(--seo-fg); font-variant-numeric: tabular-nums; }
.soc-link { display: inline-flex; color: var(--seo-fg3); }
.soc-link:hover { color: var(--brand, #FB5F2C); }
.soc-reel-user { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 600; color: var(--seo-fg); }
.soc-reel-user svg { color: #FB5F2C; }

/* ---------- Meta Ads mini summary ---------- */
.soc-ads-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 0; padding: 16px 20px 18px; }
@media (max-width: 900px) { .soc-ads-grid { grid-template-columns: repeat(3, 1fr); row-gap: 16px; } }
.soc-ads-grid .ag { display: flex; flex-direction: column; gap: 5px; }
.soc-ads-grid .al { font-size: 10px; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; color: var(--seo-mut); }
.soc-ads-grid .av { font: 600 16px var(--font-mono, monospace); color: var(--seo-fg); font-variant-numeric: tabular-nums; }

/* ---------- connect / phase-2 cards ---------- */
.soc-connect-empty { display: flex; gap: 13px; align-items: flex-start; padding: 20px; font-size: 13px; line-height: 1.55; color: var(--seo-fg3); }
.soc-connect-empty svg { flex: none; color: var(--seo-mut); margin-top: 2px; }
.soc-connect-empty strong { color: var(--seo-fg2); }
.soc-connect-card .soc-connect-body { padding: 16px 20px 18px; }
.soc-connect-card .soc-connect-body p { margin: 0 0 10px; font-size: 13px; line-height: 1.6; color: var(--seo-fg2); }
.soc-connect-card .soc-connect-body p.how { color: var(--seo-fg3); font-size: 12.5px; }
.soc-connect-card .soc-connect-body code { font: 500 11.5px var(--font-mono, monospace); background: var(--seo-card-2); padding: 1px 6px; border-radius: 6px; color: var(--seo-fg2); }
.soc-phase2 .soc-phase2-list { margin: 0; padding: 14px 20px 18px; list-style: none; display: flex; flex-direction: column; gap: 9px; }
.soc-phase2 .soc-phase2-list li { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; line-height: 1.5; color: var(--seo-fg3); }
.soc-phase2 .soc-phase2-list li svg { flex: none; margin-top: 3px; color: var(--brand, #FB5F2C); }
.soc-chart-empty { padding: 20px; font-size: 13px; color: var(--seo-fg3); }

/* ---------- metric info popover (delivery minfo pattern, soc-scoped) ---------- */
.soc-minfo { position: relative; display: inline-flex; vertical-align: middle; }
.soc-minfo-trigger { appearance: none; border: 0; background: transparent; color: var(--seo-mut); cursor: pointer;
  display: inline-flex; align-items: center; padding: 0 2px; }
.soc-minfo-trigger:hover { color: var(--seo-fg2); }
.soc-minfo-pop { position: absolute; top: calc(100% + 8px); z-index: 60; width: 290px; text-align: left;
  background: var(--seo-card); border: 1px solid var(--seo-line); border-radius: 12px; padding: 13px 15px;
  box-shadow: 0 14px 34px -10px rgba(0, 0, 0, .55); }
.soc-minfo-pop.align-right { right: -6px; } .soc-minfo-pop.align-left { left: -6px; }
.soc-minfo-pop .mp-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 7px; }
.soc-minfo-pop .mp-title { font-size: 12.5px; font-weight: 600; color: var(--seo-fg); text-transform: none; letter-spacing: 0; }
.soc-minfo-pop .mp-close { appearance: none; border: 0; background: transparent; color: var(--seo-mut); cursor: pointer; display: inline-flex; padding: 2px; }
.soc-minfo-pop .mp-close:hover { color: var(--seo-fg); }
.soc-minfo-pop .mp-def { margin: 0; font-size: 12px; line-height: 1.55; color: var(--seo-fg3); text-transform: none; letter-spacing: 0; font-weight: 400; }
.soc-minfo-pop .mp-formula { display: flex; flex-direction: column; gap: 3px; margin-top: 9px; }
.soc-minfo-pop .mp-formula span { font-size: 9.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--seo-mut); }
.soc-minfo-pop .mp-formula code { font: 500 11.5px var(--font-mono, monospace); color: var(--seo-fg2); background: var(--seo-card-2); padding: 4px 8px; border-radius: 7px; }
.soc-minfo-bench { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 9px; align-items: center; }
.soc-minfo-bench .mb { font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 999px; letter-spacing: .02em; text-transform: none; }
.soc-minfo-bench .mb-ok { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 13%, transparent); }
.soc-minfo-bench .mb-warn { color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 13%, transparent); }
.soc-minfo-bench .mb-crit { color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 13%, transparent); }
.soc-minfo-bench .mb-label { font-size: 10.5px; color: var(--seo-mut); width: 100%; text-transform: none; letter-spacing: 0; font-weight: 500; }

/* ---------- interactive chart focus (RepCharts opts.tip) ---------- */
.rai-social-cc .rc-focusable .rc-grp { transition: opacity .12s ease; }
.rai-social-cc svg.rc-focusable:hover .rc-grp { opacity: .28; }
.rai-social-cc svg.rc-focusable .rc-grp:hover { opacity: 1; }
.rai-social-cc .rc-pt .pt-dot, .rai-social-cc .rc-pt .pt-line { opacity: 0; transition: opacity .12s ease; }
.rai-social-cc .rc-pt:hover .pt-dot, .rai-social-cc .rc-pt:hover .pt-line { opacity: 1; }
/* DemoBar + Lollipop focus-dim (Audience demographics) — spotlight the hovered
   segment/row, dim the rest. Mirrors the reports CSS (reports.css ~7846). */
.rai-social-cc .demo-bar.rc-focusable .demo-seg { transition: opacity .12s ease; }
.rai-social-cc .demo-bar.rc-focusable:hover .demo-seg { opacity: .35; }
.rai-social-cc .demo-bar.rc-focusable .demo-seg:hover { opacity: 1; }
.rai-social-cc .lollipop.rc-focusable .lol-row { transition: opacity .12s ease; }
.rai-social-cc .lollipop.rc-focusable:hover .lol-row { opacity: .4; }
.rai-social-cc .lollipop.rc-focusable .lol-row:hover { opacity: 1; }

/* ---------- audience demographics section ---------- */
.rai-social-cc .soc-demo-grid { display: flex; flex-direction: column; gap: 18px; padding: 4px 2px 2px; }
.rai-social-cc .soc-demo-block { display: flex; flex-direction: column; gap: 8px; }
.rai-social-cc .soc-demo-h { font: 600 11px Inter, sans-serif; text-transform: uppercase; letter-spacing: .07em; color: var(--seo-mut); }
/* The DemoBar/Lollipop primitives come from reports/charts.js but their base
   layout CSS lives in reports.css (scoped .rai-reports). Re-declare the minimum
   here so they render correctly inside the Social CC container. */
.rai-social-cc .demo-bar-wrap { display: flex; flex-direction: column; gap: 10px; }
.rai-social-cc .demo-bar { display: flex; width: 100%; border-radius: 6px; overflow: hidden; background: var(--seo-card-2); }
.rai-social-cc .demo-seg { height: 100%; }
.rai-social-cc .demo-legend { display: flex; flex-wrap: wrap; gap: 6px 16px; }
.rai-social-cc .demo-l-item { display: inline-flex; align-items: center; gap: 7px; font: 500 12px Inter, sans-serif; color: var(--seo-fg); }
.rai-social-cc .demo-l-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.rai-social-cc .demo-l-label { color: var(--seo-fg3); }
.rai-social-cc .demo-l-val { font-variant-numeric: tabular-nums; }
.rai-social-cc .lollipop { display: flex; flex-direction: column; gap: 9px; }
.rai-social-cc .lol-row { display: grid; grid-template-columns: 120px 1fr 56px; align-items: center; gap: 12px; }
.rai-social-cc .lol-label { font: 500 12.5px Inter, sans-serif; color: var(--seo-fg); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rai-social-cc .lol-track { position: relative; height: 8px; background: var(--seo-card-2); border-radius: 5px; }
.rai-social-cc .lol-bar { position: absolute; left: 0; top: 0; height: 100%; border-radius: 5px; }
.rai-social-cc .lol-dot { position: absolute; top: 50%; width: 11px; height: 11px; border-radius: 50%; transform: translate(-50%, -50%); }
.rai-social-cc .lol-val { font: 600 12.5px var(--font-mono, monospace); text-align: right; font-variant-numeric: tabular-nums; }
@media (max-width: 560px) {
  .rai-social-cc .lol-row { grid-template-columns: 92px 1fr 48px; gap: 8px; }
}

@media (max-width: 720px) {
  .soc-page, .soc-detail { padding-left: 18px; padding-right: 18px; }
  .soc-d-bench { margin-left: 0; }
}

/* ════════════════════════════════════════════════════════════════════
   Phase 2 (2026-06-11) — page tabs, Content, Strategy, Agent
   ════════════════════════════════════════════════════════════════════ */

/* ---------- page tab bar (Overview · Content · Strategy · Agent) ---------- */
.soc-subnav { display: flex; gap: 4px; margin: 2px 0 18px; border-bottom: 1px solid var(--seo-line-soft); }
.soc-subnav button { appearance: none; border: 0; background: transparent; color: var(--seo-fg3); cursor: pointer;
  display: inline-flex; align-items: center; gap: 7px; padding: 9px 13px 11px;
  font: 600 12.5px Inter, sans-serif; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.soc-subnav button:hover { color: var(--seo-fg); }
.soc-subnav button.active { color: var(--seo-fg); border-bottom-color: var(--brand, #FB5F2C); }

.soc-mut { color: var(--seo-mut); }

/* ---------- benchmark meter (FreqMeter port) ---------- */
.soc-meter { flex: 1; min-width: 80px; }
.soc-meter-track { position: relative; height: 8px; border-radius: 5px; background: var(--seo-card-2); overflow: visible; }
.soc-meter-fill { height: 100%; border-radius: 5px; transition: width .5s var(--seo-ease, ease); }
.soc-meter-bench { position: absolute; top: -3px; width: 2px; height: 14px; background: var(--seo-fg); border-radius: 2px; }
.soc-meter-bench::after { content: ""; position: absolute; top: -4px; left: -2px; width: 6px; height: 6px; border-radius: 50%; background: var(--seo-fg); }

/* ---------- Content: cadence table ---------- */
.soc-metric-cell .ms { display: block; font: 500 10px var(--font-mono, monospace); color: var(--seo-mut); margin-top: 2px; }
.soc-cad-table tbody tr.soc-cad-row { cursor: pointer; }
.soc-cad-table tbody tr.soc-cad-row:hover { background: var(--seo-card-2); }
.soc-cad-name { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--seo-fg); }
.soc-cad-name .d { width: 7px; height: 7px; border-radius: 50%; flex: none; }
.soc-cad-meta { font-size: 11px; color: var(--seo-mut); margin-top: 3px; }
.soc-cad-meter { display: flex; align-items: center; gap: 10px; min-width: 240px; }
.soc-cad-nums { display: inline-flex; align-items: baseline; gap: 4px; white-space: nowrap; }
.soc-cad-nums .a { font: 600 12.5px var(--font-mono, monospace); color: var(--seo-fg); font-variant-numeric: tabular-nums; }
.soc-cad-nums .b { font-size: 10.5px; color: var(--seo-mut); }
.soc-cad-meter .cf-tag { flex: none; font-size: 9.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; padding: 3px 8px; border-radius: 999px; }
.soc-cad-meter .cf-tag[data-tone="great"] { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 13%, transparent); }
.soc-cad-meter .cf-tag[data-tone="watch"] { color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 13%, transparent); }
.soc-cad-meter .cf-tag[data-tone="risk"]  { color: var(--h-risk);  background: color-mix(in srgb, var(--h-risk) 13%, transparent); }

/* ---------- Content: drafts + recent feed rows ---------- */
.soc-feed-row { display: flex; align-items: flex-start; gap: 11px; padding: 11px 20px; border-bottom: 1px solid var(--seo-line-soft); }
.soc-feed-row:last-child { border-bottom: 0; }
.soc-feed-row[data-soc-open] { cursor: pointer; }
.soc-feed-row[data-soc-open]:hover { background: var(--seo-card-2); }
.soc-feed-ic { flex: none; width: 28px; height: 28px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center;
  color: var(--seo-fg3); background: var(--seo-card-2); margin-top: 1px; }
.soc-feed-main { flex: 1; min-width: 0; }
.soc-feed-title { font-size: 12.5px; font-weight: 600; color: var(--seo-fg); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.soc-feed-meta { font-size: 11px; color: var(--seo-mut); margin-top: 2px; }
.soc-feed-when { flex: none; font-size: 10.5px; color: var(--seo-mut); margin-top: 3px; white-space: nowrap; }

/* ---------- Strategy: config table ---------- */
.soc-strat-row { cursor: pointer; }
.soc-strat-row:hover, .soc-strat-row.open { background: var(--seo-card-2); }
.soc-cfg-meter { display: flex; align-items: center; gap: 10px; min-width: 130px; }
.soc-strat-check { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 6px; }
.soc-strat-check.on  { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 13%, transparent); }
.soc-strat-check.off { color: var(--seo-mut); background: var(--seo-card-2); }
.soc-strat-detail td { padding: 0 16px 14px !important; border-bottom: 1px solid var(--seo-line-soft); }
.soc-strat-open { display: flex; flex-direction: column; gap: 10px; padding: 12px 14px; background: var(--seo-card-2); border-radius: 10px; }
.soc-strat-open .gl { font-size: 9.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--seo-mut); margin-bottom: 5px; }
.soc-strat-open .gv { font-size: 12.5px; line-height: 1.55; color: var(--seo-fg2); }
.soc-pillars { display: flex; flex-wrap: wrap; gap: 6px; }
.soc-pillar { font-size: 11px; font-weight: 600; color: var(--seo-fg2); padding: 3px 10px; border-radius: 999px;
  border: 1px solid var(--seo-line); background: var(--seo-card); }

/* ---------- Agent: shell + rail + chat (SocialAgent.jsx port) ---------- */
.soc-agent-shell { display: grid; grid-template-columns: 250px 1fr; gap: 14px; align-items: start; }
@media (max-width: 860px) { .soc-agent-shell { grid-template-columns: 1fr; } }
.soc-agent-rail { background: var(--seo-card); border: 1px solid var(--seo-line); border-radius: 14px; padding: 12px; }
.soc-agent-rail-h { font-size: 9.5px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--seo-mut); margin: 12px 4px 6px; }
.soc-chat-new { appearance: none; width: 100%; border: 1px dashed var(--seo-line); background: transparent; color: var(--seo-fg2); cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 7px; padding: 9px 10px; border-radius: 10px; font: 600 12px Inter, sans-serif; }
.soc-chat-new:hover { border-color: var(--brand, #FB5F2C); color: var(--seo-fg); }
.soc-convo { display: flex; align-items: center; gap: 6px; padding: 8px 8px; border-radius: 9px; cursor: pointer; }
.soc-convo:hover { background: var(--seo-card-2); }
.soc-convo.active { background: var(--seo-card-2); box-shadow: inset 2px 0 0 var(--brand, #FB5F2C); }
.soc-convo-main { flex: 1; min-width: 0; }
.soc-convo-title { font-size: 12px; font-weight: 600; color: var(--seo-fg); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.soc-convo-meta { font-size: 10.5px; color: var(--seo-mut); margin-top: 1px; }
.soc-convo-del { appearance: none; border: 0; background: transparent; color: var(--seo-mut); cursor: pointer; display: none; padding: 4px; border-radius: 6px; flex: none; }
.soc-convo:hover .soc-convo-del { display: inline-flex; }
.soc-convo-del:hover { color: var(--h-risk); }

.soc-agent { background: var(--seo-card); border: 1px solid var(--seo-line); border-radius: 14px; overflow: hidden; }
.soc-agent-h { display: flex; align-items: center; gap: 12px; padding: 16px 20px; border-bottom: 1px solid var(--seo-line-soft); }
.soc-agent-h .who { display: flex; flex-direction: column; }
.soc-agent-h .who .nm { font-size: 13.5px; font-weight: 600; color: var(--seo-fg); }
.soc-agent-h .who .rl { font-size: 11.5px; color: var(--seo-fg3); }
.soc-agent-h .scope { margin-left: auto; font-size: 11px; color: var(--seo-mut); font-family: var(--font-mono, monospace); }
.soc-agent-tabs { display: flex; gap: 4px; padding: 12px 16px 0; border-bottom: 1px solid var(--seo-line-soft); }
.soc-agent-tabs button { appearance: none; border: 0; background: transparent; color: var(--seo-fg3);
  font: 500 12.5px Inter, sans-serif; padding: 8px 13px; border-radius: 8px 8px 0 0; cursor: pointer;
  display: inline-flex; align-items: center; gap: 7px; transition: all .14s var(--seo-ease, ease); border-bottom: 2px solid transparent; margin-bottom: -1px; }
.soc-agent-tabs button:hover { color: var(--seo-fg); }
.soc-agent-tabs button.active { color: var(--seo-fg); border-bottom-color: var(--brand, #FB5F2C); }
.soc-agent-body { padding: 18px 20px 20px; }

/* diagnosis */
.soc-diag p { margin: 0; font-size: 14px; line-height: 1.62; color: var(--seo-fg2); }

/* actions by impact */
.soc-actions { display: flex; flex-direction: column; gap: 10px; }
.soc-action { display: flex; gap: 12px; align-items: flex-start; padding: 13px 14px; border: 1px solid var(--seo-line-soft); border-radius: 11px; }
.soc-action .imp { flex: none; font-size: 9.5px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; padding: 3px 8px; border-radius: 999px; margin-top: 1px; }
.soc-action .imp.high { color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 13%, transparent); }
.soc-action .imp.med { color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 13%, transparent); }
.soc-action .imp.low { color: var(--h-good); background: color-mix(in srgb, var(--h-good) 13%, transparent); }
.soc-action .atext { flex: 1; font-size: 13px; line-height: 1.5; color: var(--seo-fg2); }
.soc-action .atext b { color: var(--seo-fg); font-weight: 600; }

/* content ideas */
.soc-ideas { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.soc-idea { padding: 13px 14px; border: 1px solid var(--seo-line-soft); border-radius: 11px; }
.soc-idea .ih { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.soc-idea .ih .fmt { font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; padding: 2px 7px; border-radius: 999px; }
.soc-idea .it { font-size: 13px; font-weight: 600; color: var(--seo-fg); line-height: 1.35; }
.soc-idea .ib { font-size: 12px; color: var(--seo-fg3); line-height: 1.45; margin-top: 5px; }
@media (max-width: 760px) { .soc-ideas { grid-template-columns: 1fr; } }

.soc-chat { display: flex; flex-direction: column; gap: 12px; }
.soc-chat-log { display: flex; flex-direction: column; gap: 12px; min-height: 240px; max-height: 52vh; overflow-y: auto; padding-right: 4px; }
.soc-msg { display: flex; gap: 10px; }
.soc-msg.user { flex-direction: row-reverse; }
.soc-msg .bub { max-width: 78%; padding: 11px 14px; border-radius: 13px; font-size: 13.5px; line-height: 1.55; }
.soc-msg.agent .bub { background: var(--seo-card-2); color: var(--seo-fg2); border-bottom-left-radius: 4px; }
.soc-msg.agent .bub.err { color: var(--h-risk); }
.soc-msg.agent .bub .li { display: block; padding-left: 14px; position: relative; }
.soc-msg.agent .bub .li::before { content: "•"; position: absolute; left: 2px; color: var(--seo-fg3); }
.soc-msg.user .bub { background: var(--brand, #FB5F2C); color: #fff; border-bottom-right-radius: 4px; }
.soc-msg .av { flex: none; width: 30px; height: 30px; }
.soc-chat-suggest { display: flex; gap: 7px; flex-wrap: wrap; }
.soc-chat-suggest button { appearance: none; border: 1px solid var(--seo-line); background: var(--seo-card); color: var(--seo-fg2); cursor: pointer;
  padding: 7px 12px; border-radius: 999px; font: 500 12px Inter, sans-serif; }
.soc-chat-suggest button:hover { border-color: var(--brand, #FB5F2C); color: var(--seo-fg); }
.soc-chat-input { display: flex; align-items: center; gap: 8px; height: 42px; padding: 0 6px 0 14px;
  border: 1px solid var(--seo-line); border-radius: 12px; background: var(--seo-card); }
.soc-chat-input input { flex: 1; background: transparent; border: 0; outline: 0; color: var(--seo-fg); font: 400 13.5px Inter, sans-serif; }
.soc-chat-input input::placeholder { color: var(--seo-mut); }
.soc-chat-send { width: 32px; height: 32px; border-radius: 8px; border: 0; background: var(--brand, #FB5F2C); color: #fff;
  display: inline-flex; align-items: center; justify-content: center; cursor: pointer; flex: none; }
.soc-chat-send:disabled { opacity: .4; cursor: default; }
.soc-chat-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; text-align: center;
  padding: 36px 24px; color: var(--seo-fg3); }
.soc-chat-empty .t { font-size: 14px; font-weight: 600; color: var(--seo-fg); }
.soc-chat-empty .s { font-size: 12.5px; line-height: 1.55; max-width: 420px; }
.soc-typing { display: inline-flex; gap: 4px; align-items: center; padding: 3px 0; }
.soc-typing span { width: 6px; height: 6px; border-radius: 50%; background: var(--seo-fg3); animation: socTyping 1.1s infinite; }
.soc-typing span:nth-child(2) { animation-delay: .18s; }
.soc-typing span:nth-child(3) { animation-delay: .36s; }
@keyframes socTyping { 0%, 60%, 100% { opacity: .25; transform: translateY(0); } 30% { opacity: 1; transform: translateY(-3px); } }

/* ── Real-posting integration (2026-06-11 final wave) ─────────────────────── */
/* posting-gap strip: per-platform dark chips + platform toggle */
.soc-dark-chips { display: inline-flex; gap: 5px; flex: none; align-items: center; }
.soc-dark-chip { display: inline-flex; align-items: center; gap: 4px; font: 700 11.5px var(--font-mono, monospace);
  padding: 4px 8px; border-radius: 8px; }
.soc-dark-chip[data-sev="risk"] { color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 13%, transparent); }
.soc-dark-chip[data-sev="watch"] { color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 13%, transparent); }
.soc-dark-chip[data-sev="ok"] { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 12%, transparent); }
.soc-dark-chip[data-sev="nodata"] { color: var(--seo-mut); background: var(--seo-card-2); }
/* "syncing": kept ONLY for the content.js page (per-platform "data as of <date>"
   chip). The Posting status board no longer uses it — that board shows a clean
   day-count from last_post_at with no stale-sync hedge (2026-06-18). */
.soc-dark-chip[data-sev="syncing"] { color: var(--seo-mut); background: var(--seo-card-2);
  border: 1px dashed color-mix(in srgb, var(--seo-mut) 40%, transparent); font-weight: 600;
  text-transform: none; letter-spacing: 0; }
/* coverage gaps: a real, actionable capture problem. "no handle" (needs_handle)
   is the stronger signal (warn tone); "no data" (needs_sync) is informational. */
.soc-dark-chip[data-sev="coverage"] { color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 12%, transparent);
  font-weight: 600; text-transform: none; letter-spacing: 0; }
.soc-dark-chip[data-sev="coverage_sync"] { color: var(--seo-fg3); background: var(--seo-card-2);
  border: 1px dashed color-mix(in srgb, var(--seo-mut) 40%, transparent); font-weight: 600;
  text-transform: none; letter-spacing: 0; }
.soc-stale-seg { margin-left: auto; }
.soc-stale-h .count { margin-left: 0; }

/* ── Posting status board (2026-06-18): every account of every squad, always,
   grouped by squad, each platform colour-coded by recency. Reuses .soc-stale
   shell + .soc-dark-chip chips; adds the green "fresh" chip + per-squad layout. */
.soc-dark-chip[data-sev="fresh"] { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 13%, transparent); }
/* "warn" (day 4) = the board's yellow band — sevFromTs emits 'warn' but the only
   yellow rule was data-sev="watch", so a 4-day chip rendered with no colour. */
.soc-dark-chip[data-sev="warn"] { color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 13%, transparent); }
/* When the whole board is fresh the header is calm: green pulse, not red. */
.soc-board.is-calm { border-color: color-mix(in srgb, var(--h-great) 32%, var(--seo-line)); }
.soc-board.is-calm .soc-stale-h { background: radial-gradient(620px 120px at 0% 0%, color-mix(in srgb, var(--h-great) 9%, transparent), transparent 60%); }
.soc-board.is-calm .soc-stale-h .pulse { background: var(--h-great); box-shadow: 0 0 0 0 color-mix(in srgb, var(--h-great) 60%, transparent); }
.soc-board.is-calm .soc-stale-h .count { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 12%, transparent); }
.soc-board .soc-stale-h .count { font-size: 11px; letter-spacing: .1px; white-space: nowrap; }
.soc-board-body { padding: 4px 0 6px; }
.soc-board-allfresh { display: flex; align-items: center; gap: 8px; margin: 8px 20px 4px;
  padding: 8px 12px; border-radius: 10px; font-size: 12px; font-weight: 500;
  color: var(--h-great); background: color-mix(in srgb, var(--h-great) 9%, transparent);
  border: 1px solid color-mix(in srgb, var(--h-great) 22%, transparent); }
.soc-board-allfresh svg { flex: none; }
.soc-board-squad { border-top: 1px solid var(--seo-line-soft); }
.soc-board-squad:first-child { border-top: none; }
.soc-board-squad-h { display: flex; align-items: center; gap: 8px; padding: 9px 20px 6px;
  font: 600 11px Inter, sans-serif; letter-spacing: .4px; text-transform: uppercase;
  color: var(--seo-fg3); }
.soc-board-squad-h .sq-n { font: 700 10px var(--font-mono, monospace); color: var(--seo-mut);
  padding: 1px 6px; border-radius: 999px; background: var(--seo-card-2); text-transform: none; letter-spacing: 0; }
/* compact rows so ~50 accounts stay scannable: two-up on wide, one-up narrow */
.soc-board-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 0; }
.soc-board-item { display: flex; align-items: center; gap: 11px; padding: 8px 20px;
  cursor: pointer; transition: background .14s var(--seo-ease); }
.soc-board-item:hover { background: var(--seo-card-2); }
.soc-board-item .soc-stale-main { flex: 1; min-width: 0; }
/* Truncate the account name with an ellipsis rather than letting it push the
   chips onto a second line — the chip row must always stay on ONE line. */
.soc-board-item .soc-stale-name { font-size: 12.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.soc-board-item .soc-stale-meta { margin-top: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
/* Chips ALWAYS on one line: no wrap, compact, never shrink. The live labels
   ("20h", "2d", "now") are short, but guarantee no wrap even for 3 platforms
   (ig+fb+tt). The chips container takes only the width it needs and never grows
   past its content, so the truncating name absorbs any overflow. */
.soc-board-item .soc-dark-chips { flex: none; flex-wrap: nowrap; white-space: nowrap; justify-content: flex-end; gap: 4px; }
.soc-board-item .soc-dark-chip { flex-shrink: 0; padding: 3px 6px; font-size: 11px; gap: 3px; }

/* per-platform posting cards (client detail) */
.soc-postplats { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 10px; }
.soc-postplat { border: 1px solid var(--seo-line-soft); border-radius: 11px; padding: 12px 14px; background: var(--seo-card-2); }
.soc-postplat[data-sev="watch"] { border-color: color-mix(in srgb, var(--h-watch) 45%, var(--seo-line)); }
.soc-postplat[data-sev="risk"] { border-color: color-mix(in srgb, var(--h-risk) 45%, var(--seo-line)); }
.soc-postplat .pp-head { display: flex; align-items: center; gap: 7px; font: 600 12.5px Inter, sans-serif; }
.soc-postplat .pp-head .pp-src { margin-left: auto; font: 600 10px Inter, sans-serif; color: var(--seo-fg3);
  padding: 2px 7px; border-radius: 999px; background: var(--seo-card); border: 1px solid var(--seo-line-soft); }
.soc-postplat .pp-days { margin-top: 7px; font: 700 13px var(--font-mono, monospace); color: var(--seo-fg); }
.soc-postplat[data-sev="watch"] .pp-days { color: var(--h-watch); }
.soc-postplat[data-sev="risk"] .pp-days { color: var(--h-risk); }
.soc-postplat .pp-days.mut, .soc-postplat.nodata .pp-days { color: var(--seo-mut); font-weight: 500; }
.soc-postplat .pp-sub { margin-top: 4px; font-size: 11.5px; color: var(--seo-fg3); }
.soc-postplat .pp-link { display: inline-flex; align-items: center; gap: 4px; margin-top: 7px; font-size: 11.5px; }

/* post thumbnails (detail table + content feed) */
.soc-thumb { width: 44px; height: 44px; border-radius: 8px; object-fit: cover; flex: none; background: var(--seo-card-2);
  display: inline-flex; align-items: center; justify-content: center; color: var(--seo-mut); }
.soc-thumb.lg { width: 56px; height: 56px; border-radius: 10px; }
.soc-post-cell { display: flex; align-items: center; gap: 11px; min-width: 0; }

/* content page: published-posts feed */
.soc-post-feed { display: flex; flex-direction: column; }
.soc-post-card { display: flex; gap: 12px; padding: 11px 16px; border-top: 1px solid var(--seo-line-soft); cursor: pointer;
  transition: background .14s var(--seo-ease); align-items: flex-start; }
.soc-post-card:first-child { border-top: 0; }
.soc-post-card:hover { background: var(--seo-card-2); }
.soc-post-main { flex: 1; min-width: 0; }
.soc-post-top { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.soc-post-client { font: 600 12.5px Inter, sans-serif; color: var(--seo-fg); }
.soc-post-type { font-size: 11px; color: var(--seo-fg3); }
.soc-post-top .soc-feed-when { margin-left: auto; }
.soc-post-cap { margin-top: 3px; font-size: 12px; color: var(--seo-fg2); line-height: 1.4; display: -webkit-box;
  -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.soc-post-stats { display: flex; align-items: center; gap: 13px; margin-top: 6px; font: 500 11.5px var(--font-mono, monospace); color: var(--seo-fg3); }
.soc-post-stats span { display: inline-flex; align-items: center; gap: 4px; }

/* Notion adherence pill */
.soc-adh-pill { display: inline-flex; align-items: center; font: 600 10.5px Inter, sans-serif; padding: 2px 8px; border-radius: 999px; }
.soc-adh-pill[data-m="matched"] { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 13%, transparent); }
.soc-adh-pill[data-m="unmatched"] { color: var(--seo-fg3); background: var(--seo-card-2); }
.soc-adh-pill[data-m="manual"] { color: var(--h-good); background: color-mix(in srgb, var(--h-good) 13%, transparent); }

/* strategy: bio audit */
.soc-bio-text { font-size: 12px; color: var(--seo-fg2); line-height: 1.45; max-width: 380px; white-space: pre-line;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

/* ============================================================
   CLIENT DETAIL — handoff parity (2026-06-12)
   Ported verbatim from handoff_social/reference/social.css so the
   detail page renders the EXACT handoff layout: platform toggle,
   trend legend + post markers, frequency grid, content table beat
   pills, reel analysis, bio compare + checks, insights, Notion
   adherence, competition table, scoped Resty panel.
   ============================================================ */

/* platform toggle — segmented with brand icons */
.soc-plattoggle { display: inline-flex; background: var(--seo-card); border: 1px solid var(--seo-line); border-radius: 10px; padding: 3px; gap: 2px; }
.soc-plattoggle button { appearance: none; border: 0; background: transparent; color: var(--seo-fg3);
  font: 500 12.5px Inter, sans-serif; padding: 6px 11px; border-radius: 7px; cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px; transition: all .14s var(--seo-ease); }
.soc-plattoggle button:hover { color: var(--seo-fg); }
.soc-plattoggle button.active { background: var(--seo-card-2); color: var(--seo-fg); }
.soc-plattoggle button.future { color: var(--seo-mut); opacity: .55; cursor: not-allowed; }
.soc-d-toggle { display: flex; align-items: center; gap: 10px; margin: 4px 0 20px; flex-wrap: wrap; }

/* trend chart legend + post markers */
.soc-trend-legend { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 12px; }
.soc-trend-legend .lg { display: flex; align-items: center; gap: 7px; font-size: 12px; color: var(--seo-fg3); }
.soc-trend-legend .lg .d { width: 8px; height: 8px; border-radius: 2px; }
.soc-postmark { cursor: default; }

/* content table: thumb wrap + beat pill + notion pill */
.soc-thumb-wrap { display: flex; gap: 12px; align-items: flex-start; min-width: 230px; }
.soc-beat { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 600; padding: 3px 8px; border-radius: 999px; }
.soc-beat.yes { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 13%, transparent); }
.soc-beat.no { color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 13%, transparent); }
.soc-notion-pill { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 600; padding: 3px 9px; border-radius: 7px; white-space: nowrap; }
.soc-notion-pill[data-st="on-time"] { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 12%, transparent); }
.soc-notion-pill[data-st="late"] { color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 12%, transparent); }
.soc-notion-pill[data-st="improvised"] { color: var(--seo-fg3); background: var(--seo-card-2); }
.soc-notion-pill[data-st="missed"] { color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 12%, transparent); }

/* reel / video analysis */
.soc-reels { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 14px; padding: 18px 20px; }
.soc-reel { border: 1px solid var(--seo-line-soft); border-radius: 12px; padding: 14px; background: var(--seo-card-2); }
.soc-reel-top { display: flex; gap: 12px; align-items: flex-start; }
.soc-reel-thumb { width: 48px; height: 62px; border-radius: 8px; position: relative; overflow: hidden; flex: none; background: var(--seo-card);
  border: 1px solid var(--seo-line-soft); display: flex; align-items: center; justify-content: center; }
.soc-reel-thumb::before { content: ""; position: absolute; inset: 0; background-image: repeating-linear-gradient(135deg, #FB5F2C 0 1px, transparent 1px 9px); opacity: .2; }
.soc-reel-thumb img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.soc-reel-hook { font-size: 13px; font-weight: 600; color: var(--seo-fg); line-height: 1.35; }
.soc-reel-stats { display: flex; gap: 12px; margin-top: 6px; font: 600 11.5px var(--font-mono, monospace); color: var(--seo-fg3); }
.soc-reel-stats .s { display: inline-flex; align-items: center; gap: 4px; }
.soc-retention { margin: 13px 0; }
.soc-retention-bars { display: flex; gap: 3px; align-items: flex-end; height: 40px; }
.soc-retention-bars .rb { flex: 1; border-radius: 3px 3px 0 0; background: var(--rc); min-height: 3px; }
.soc-retention-lbl { display: flex; justify-content: space-between; font-size: 9.5px; color: var(--seo-mut); margin-top: 5px; font-family: var(--font-mono, monospace); }
.soc-retention-empty { display: flex; align-items: center; justify-content: center; height: 40px; border: 1px dashed var(--seo-line); border-radius: 8px;
  font-size: 11px; color: var(--seo-mut); text-align: center; padding: 0 10px; }
.soc-reel-break { display: flex; flex-direction: column; gap: 7px; }
.soc-reel-break .br { display: flex; gap: 9px; font-size: 12px; line-height: 1.4; }
.soc-reel-break .br .bk { flex: none; width: 52px; font-size: 10px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--seo-mut); padding-top: 1px; }
.soc-reel-break .br .bt { flex: 1; color: var(--seo-fg3); }
.soc-reel-why { margin-top: 11px; padding-top: 11px; border-top: 1px solid var(--seo-line-soft); font-size: 12.5px; line-height: 1.5; }
.soc-reel-why.hit { color: var(--h-great); } .soc-reel-why.miss { color: var(--seo-fg2); }

/* notion adherence */
.soc-notion-grid { padding: 18px 20px; display: flex; gap: 28px; flex-wrap: wrap; align-items: center; }
.soc-notion-stat { text-align: center; }
.soc-notion-stat .ns-v { font: 600 32px var(--font-mono, monospace); letter-spacing: -.03em; color: var(--seo-fg); font-variant-numeric: tabular-nums; line-height: 1; }
.soc-notion-stat .ns-l { font-size: 11px; color: var(--seo-fg3); margin-top: 6px; }
.soc-notion-bar { flex: 1; min-width: 220px; }
.soc-notion-track { height: 14px; border-radius: 7px; background: var(--seo-card-2); overflow: hidden; display: flex; }
.soc-notion-track .seg { height: 100%; }
.soc-notion-legend { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 12px; font-size: 11.5px; color: var(--seo-fg3); }
.soc-notion-legend .lg { display: flex; align-items: center; gap: 6px; }
.soc-notion-legend .lg .d { width: 8px; height: 8px; border-radius: 2px; }

/* competition snapshot */
.soc-comp-table { width: 100%; border-collapse: collapse; }
.soc-comp-table th { text-align: right; font-size: 10.5px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
  color: var(--seo-fg3); padding: 9px 20px; border-bottom: 1px solid var(--seo-line-soft); }
.soc-comp-table th:first-child { text-align: left; }
.soc-comp-table td { padding: 13px 20px; border-bottom: 1px solid var(--seo-line-soft); font-size: 13px; text-align: right; }
.soc-comp-table td:first-child { text-align: left; }
.soc-comp-table tr:last-child td { border-bottom: 0; }
.soc-comp-table .cn { color: var(--seo-fg); font-weight: 600; display: flex; align-items: center; gap: 9px; }
.soc-comp-table .cn .tag { font-size: 9.5px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; padding: 2px 7px; border-radius: 999px; }
.soc-comp-table .cn .tag.us { color: var(--brand, #FB5F2C); background: var(--brand-soft, rgba(251,95,44,.14)); }
.soc-comp-table .cn .tag.lead { color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 12%, transparent); }
.soc-comp-table .num { font: 600 13px var(--font-mono, monospace); font-variant-numeric: tabular-nums; color: var(--seo-fg2); }
.soc-comp-table tr.is-us td { background: var(--brand-soft, rgba(251,95,44,.06)); }

/* shared verdict band (frequency / bio cards) */
.soc-strat-verdict { display: flex; gap: 13px; align-items: flex-start; padding: 16px 20px; border-bottom: 1px solid var(--seo-line-soft);
  background: radial-gradient(560px 130px at 0% 0%, rgba(251,95,44,.05), transparent 62%); }
.soc-strat-verdict p { margin: 0; font-size: 13.5px; line-height: 1.6; color: var(--seo-fg2); }

/* per-platform frequency grid */
.soc-freq-grid { padding: 18px 20px; display: grid; gap: 14px; grid-template-columns: repeat(2, 1fr); }
.soc-freq-grid[data-cols="1"] { grid-template-columns: 1fr; }
@media (max-width: 900px) { .soc-freq-grid, .soc-freq-grid[data-cols="1"] { grid-template-columns: 1fr; } }
.soc-freq-card { border: 1px solid var(--seo-line-soft); border-radius: 12px; padding: 14px 16px; background: var(--seo-card-2); }
.soc-freq-card.future { opacity: .82; border-style: dashed; }
.soc-freq-head { display: flex; align-items: center; gap: 9px; margin-bottom: 12px; }
.soc-freq-head .pi { display: inline-flex; }
.soc-freq-head .pn { font-size: 13.5px; font-weight: 600; color: var(--seo-fg); }
.soc-laststamp { margin-left: auto; display: inline-flex; align-items: center; gap: 5px; font: 600 11px var(--font-mono, monospace);
  color: var(--seo-fg3); padding: 3px 8px; border-radius: 999px; background: var(--seo-card); }
.soc-laststamp.stale { color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 13%, transparent); }
.soc-laststamp.future { color: var(--seo-mut); }
/* "syncing": OUR sync of this platform is stale (>40h). Neutral/dashed so it
   reads as "data as of <date>", never as a red "gone dark" penalty. */
.soc-laststamp.syncing { color: var(--seo-mut); background: var(--seo-card-2);
  border: 1px dashed color-mix(in srgb, var(--seo-mut) 40%, transparent); }
.soc-freq-row { display: grid; grid-template-columns: 92px 1fr auto auto; align-items: center; gap: 11px; padding: 8px 0; }
.soc-freq-l { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--seo-fg3); }
.soc-freq-nums { font: 600 12.5px var(--font-mono, monospace); color: var(--seo-fg); font-variant-numeric: tabular-nums; white-space: nowrap; }
.soc-freq-nums .b { color: var(--seo-mut); font-weight: 500; margin-left: 3px; }
.soc-freq-tag { font-size: 10px; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; padding: 3px 8px; border-radius: 999px; white-space: nowrap; }
.soc-freq-tag[data-tone="great"] { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 13%, transparent); }
.soc-freq-tag[data-tone="watch"] { color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 13%, transparent); }
.soc-freq-tag[data-tone="risk"] { color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 13%, transparent); }
.soc-freq-tag[data-tone="nodata"] { color: var(--seo-mut); background: var(--seo-card); }
.soc-freq-empty { font-size: 12.5px; line-height: 1.55; color: var(--seo-fg3); }
.soc-freq-empty b { color: var(--seo-fg2); }
@media (max-width: 520px) { .soc-freq-row { grid-template-columns: 80px 1fr; } .soc-freq-row .soc-freq-nums, .soc-freq-row .soc-freq-tag { grid-column: 2; justify-self: start; } }

/* bio before/after */
.soc-bio-compare { display: grid; grid-template-columns: 1fr auto 1fr; gap: 14px; align-items: stretch; padding: 18px 20px; }
.soc-bio-col { border: 1px solid var(--seo-line-soft); border-radius: 12px; padding: 14px; background: var(--seo-card-2); display: flex; flex-direction: column; }
.soc-bio-col.opt { border-color: color-mix(in srgb, var(--brand, #FB5F2C) 40%, var(--seo-line)); background: var(--brand-soft, rgba(251,95,44,.05)); }
.soc-bio-tag { display: inline-flex; align-items: center; gap: 6px; align-self: flex-start; font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; padding: 3px 9px; border-radius: 999px; margin-bottom: 11px; }
.soc-bio-tag.now { color: var(--seo-fg3); background: var(--seo-card); }
.soc-bio-tag.opt { color: var(--brand, #FB5F2C); background: var(--brand-soft, rgba(251,95,44,.14)); }
.soc-bio-text { font: 400 13px Inter, sans-serif; line-height: 1.6; color: var(--seo-fg); white-space: pre-wrap; margin: 0; flex: 1; }
.soc-bio-namefield { margin-top: 12px; padding-top: 11px; border-top: 1px dashed var(--seo-line-soft); display: flex; flex-direction: column; gap: 3px; }
.soc-bio-namefield .nf-l { font-size: 9.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--seo-mut); }
.soc-bio-namefield .nf-v { font: 500 12.5px var(--font-mono, monospace); color: var(--seo-fg2); }
.soc-bio-namefield .nf-v.dim { color: var(--seo-mut); }
.soc-bio-arrow { display: flex; align-items: center; color: var(--seo-mut); }
@media (max-width: 760px) { .soc-bio-compare { grid-template-columns: 1fr; } .soc-bio-arrow { transform: rotate(90deg); justify-content: center; } }

/* bio checklist */
.soc-bio-checks { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-top: 1px solid var(--seo-line-soft); }
.soc-bio-check { display: flex; gap: 11px; align-items: flex-start; padding: 13px 20px; border-bottom: 1px solid var(--seo-line-soft); border-right: 1px solid var(--seo-line-soft); }
.soc-bio-checks .soc-bio-check:nth-child(2n) { border-right: 0; }
.soc-bio-check .ck-ic { flex: none; width: 24px; height: 24px; border-radius: 7px; display: flex; align-items: center; justify-content: center; margin-top: 1px; }
.soc-bio-check[data-tone="great"] .ck-ic { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 13%, transparent); }
.soc-bio-check[data-tone="watch"] .ck-ic { color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 13%, transparent); }
.soc-bio-check[data-tone="risk"] .ck-ic { color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 13%, transparent); }
.soc-bio-check .ck-main { flex: 1; min-width: 0; }
.soc-bio-check .ck-k { font-size: 13px; font-weight: 600; color: var(--seo-fg); }
.soc-bio-check .ck-d { font-size: 11.5px; color: var(--seo-fg3); line-height: 1.4; margin-top: 2px; }
.soc-bio-check .ck-st { flex: none; font-size: 10px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; padding: 3px 8px; border-radius: 999px; align-self: center; }
.soc-bio-check .ck-st[data-tone="great"] { color: var(--h-great); background: color-mix(in srgb, var(--h-great) 12%, transparent); }
.soc-bio-check .ck-st[data-tone="watch"] { color: var(--h-watch); background: color-mix(in srgb, var(--h-watch) 12%, transparent); }
.soc-bio-check .ck-st[data-tone="risk"] { color: var(--h-risk); background: color-mix(in srgb, var(--h-risk) 12%, transparent); }
/* check not verifiable from public data (name field, highlights, contact buttons) */
.soc-bio-check[data-tone="nodata"] .ck-ic { color: var(--seo-mut); background: var(--seo-card-2); }
.soc-bio-check .ck-st[data-tone="nodata"] { color: var(--seo-mut); background: var(--seo-card-2); }
@media (max-width: 700px) { .soc-bio-checks { grid-template-columns: 1fr; } .soc-bio-checks .soc-bio-check { border-right: 0; } }

/* algorithm insights */
.soc-insights { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.soc-insight { display: flex; gap: 13px; padding: 16px 20px; border-top: 1px solid var(--seo-line-soft); border-right: 1px solid var(--seo-line-soft); }
.soc-insights .soc-insight:nth-child(2n) { border-right: 0; }
.soc-insight-ic { flex: none; width: 32px; height: 32px; border-radius: 9px; display: flex; align-items: center; justify-content: center; }
.soc-insight-main { flex: 1; min-width: 0; }
.soc-insight-cat { font-size: 10px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--seo-fg3); }
.soc-insight-find { font-size: 13px; line-height: 1.5; color: var(--seo-fg2); margin-top: 5px; }
.soc-insight-act { display: flex; align-items: flex-start; gap: 6px; font-size: 12.5px; line-height: 1.45; color: var(--seo-fg); font-weight: 500; margin-top: 8px; }
.soc-insight-act svg { flex: none; margin-top: 2px; color: var(--brand, #FB5F2C); }
@media (max-width: 820px) { .soc-insights { grid-template-columns: 1fr; } .soc-insights .soc-insight { border-right: 0; } }
.soc-freq-head .pp-src { font-size: 9px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: var(--h-good); background: color-mix(in srgb, var(--h-good) 13%, transparent); padding: 2px 6px; border-radius: 999px; }
