/* ─── Candidatos (curación de scrape) ───────────────────────── */
#tab-candidates { background: var(--bg0); }
.cand-wrap { padding: 10px 16px; display: flex; flex-direction: column; height: 100%; box-sizing: border-box; min-width: 0; max-width: 100%; }
/* Let flex-column children shrink to the container instead of forcing the page
   wider than the viewport (default min-width:auto = min-content of the table). */
.cand-wrap > * { min-width: 0; max-width: 100%; }

/* Compact 2-row header: row1 = title+filters+refresh+ext-pill; row2 = sel+actions */
.cand-bar { display: flex; align-items: center; gap: 8px; margin-bottom: 7px; flex-wrap: nowrap; }
.cand-titlesm { font-size: 0.875rem; font-weight: 700; color: var(--text); white-space: nowrap; flex: none; }
.cand-titlesm b { color: var(--text3); font-weight: 600; font-size: 0.8125rem; }
.cand-in {
  padding: 6px 10px; border: 1px solid var(--line2, var(--line)); border-radius: 7px;
  background: var(--bg1); color: var(--text); font-size: 0.8125rem; font-family: var(--sans);
}
.cand-in:focus { outline: none; border-color: var(--accent); }
#candSearch { flex: 1; min-width: 140px; }
.cand-sel { cursor: pointer; }
.cand-num { width: 78px; }
.cand-minf { display: flex; align-items: center; gap: 5px; font-size: 0.75rem; color: var(--text2); white-space: nowrap; flex: none; }
.cand-chk { display: flex; align-items: center; gap: 5px; font-size: 0.75rem; color: var(--text2); cursor: pointer; white-space: nowrap; flex: none; }
.cand-chk input { width: 14px; height: 14px; cursor: pointer; }
.cand-extpill { align-items: center; padding: 3px 9px; border-radius: 999px; font-size: 0.6875rem; font-weight: 600; white-space: nowrap; flex: none; cursor: default; }
.cand-extpill.ok { background: rgba(34,197,94,.12); color: #34d399; }
.cand-extpill.warn { background: rgba(245,158,11,.14); color: #fbbf24; }

.cand-btn {
  padding: 6px 12px; border: 1px solid var(--line2, var(--line)); border-radius: 7px;
  background: var(--bg2); color: var(--text); font-size: 0.8125rem; font-weight: 600;
  font-family: var(--sans); cursor: pointer; transition: all .15s; white-space: nowrap; flex: none;
}
.cand-btn.sm { padding: 6px 9px; }
.cand-btn:hover { border-color: var(--accent); }
.cand-btn.primary { background: var(--accent); color: #000; border-color: var(--accent); }
.cand-btn.primary:hover { filter: brightness(1.08); }
.cand-btn.danger { color: var(--red); border-color: rgba(239,68,68,.4); }
.cand-btn.danger:hover { background: rgba(239,68,68,.1); }
.cand-btn.ghost { color: var(--text3); }

.cand-msg { display: none; margin-bottom: 8px; padding: 8px 12px; border-radius: 8px; font-size: 0.8125rem; }
.cand-msg.show { display: block; }
.cand-msg.ok { background: rgba(34,197,94,.12); color: #34d399; }
.cand-msg.err { background: rgba(239,68,68,.12); color: #f87171; }

.cand-table-wrap { flex: 1; overflow-y: auto; overflow-x: hidden; border: 1px solid var(--line); border-radius: 10px; background: var(--bg1); }
/* Fixed layout = columns NEVER overflow the viewport (no infinite right-scroll);
   the Bio column absorbs the remaining width and truncates with ellipsis. */
.cand-table { width: 100%; table-layout: fixed; border-collapse: collapse; font-size: 0.8125rem; }
.cand-table thead th {
  position: sticky; top: 0; z-index: 1; background: var(--bg2); color: var(--text2);
  text-align: left; font-weight: 600; padding: 9px 12px; border-bottom: 1px solid var(--line);
  font-size: 0.6875rem; text-transform: uppercase; letter-spacing: .4px; white-space: nowrap;
}
.cand-table th.sortable { cursor: pointer; user-select: none; }
.cand-table th.sortable:hover { color: var(--accent); }
.cand-table th.num, .cand-table td.num { text-align: right; }
.cand-row { border-bottom: 1px solid var(--line); cursor: pointer; }
.cand-row:hover { background: var(--bg2); }
.cand-row.sel { background: rgba(240,180,41,.08); }
.cand-table td { padding: 4px 12px; color: var(--text); vertical-align: middle; overflow: hidden; line-height: 1.3; }
.cand-cb { width: 14px; height: 14px; cursor: pointer; }
.cand-av {
  width: 28px; height: 28px; border-radius: 50%;
  background-color: var(--bg3); background-size: cover; background-position: center;
  border: 1px solid var(--line); display: flex;
  align-items: center; justify-content: center; color: var(--text3);
  font-size: 0.6875rem; font-weight: 700; overflow: hidden;
}
.cand-uname { display: flex; align-items: center; gap: 4px; min-width: 0; }
.cand-user { font-weight: 600; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 0.8125rem; cursor: pointer; }
.cand-row:hover .cand-user { color: var(--accent); }
.cand-vb { color: #3b82f6; font-size: 0.6875rem; flex: none; }
.cand-iglink { color: var(--text3); text-decoration: none; font-size: 0.75rem; flex: none; opacity: .6; }
.cand-iglink:hover { color: var(--accent); opacity: 1; }
.cand-name { font-size: 0.6875rem; color: var(--text3); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cand-bio { color: var(--text2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cand-noenrich { color: var(--text3); font-style: italic; margin-left: 6px; font-size: 0.6875rem; }
.cand-empty { padding: 40px 20px; text-align: center; color: var(--text3); font-size: 0.875rem; line-height: 1.6; }

/* ─── Platform selector — inline in the search toolbar row (keeps header 2 rows) ── */
.search-plat-bar { display: flex; align-items: center; gap: 6px; margin-right: 6px; flex: none; }
.search-plat {
  padding: 6px 13px; border: 1px solid var(--line2, var(--line)); border-radius: 999px;
  background: var(--bg1); color: var(--text2); font-size: 0.75rem; font-weight: 600;
  font-family: var(--sans); cursor: pointer; transition: all .15s; white-space: nowrap;
}
.search-plat:hover { border-color: var(--accent); color: var(--text); }
.search-plat.on { background: var(--accent); color: #000; border-color: var(--accent); }
/* In IG/X mode the candidates spreadsheet fills the search tab */
#searchCandidates { display: flex; flex-direction: column; }

/* Extension-version reminder banner inside the candidates view */
.cand-extnote { margin-bottom: 10px; padding: 9px 13px; border-radius: 8px; font-size: 0.8125rem; line-height: 1.45; }
.cand-extnote.warn { background: rgba(245,158,11,.12); color: #fbbf24; border: 1px solid rgba(245,158,11,.3); }
.cand-extnote.ok { background: rgba(34,197,94,.1); color: #34d399; border: 1px solid rgba(34,197,94,.25); }
