/* Marketing CRM — components.
 * Built on the shared design tokens (tokens.css). Purposefully small: a
 * header, cards, a form, a table, badges and a pager. Not the Brieflings
 * components.css (7k lines of app-specific UI we don't need here).
 */

/* ── Layout ─────────────────────────────────────────────────────────── */
.container {
  max-inline-size: var(--container-wide);
  margin-inline: auto;
  padding: var(--space-6) var(--space-4) var(--space-9);
}

.app-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  border-block-end: 1px solid var(--border-subtle);
  background: var(--bg-card);
}

.brand {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  letter-spacing: var(--tracking-tight);
}

.app-header__nav {
  display: flex;
  gap: var(--space-4);
}

.app-header__user {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-sm);
}

/* ── Login page ─────────────────────────────────────────────────────── */
.login-page {
  min-block-size: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-5);
}
.login-card {
  inline-size: 100%;
  max-inline-size: var(--container-narrow);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  align-items: center;
}
.login-card__brand {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 600;
  letter-spacing: var(--tracking-tight);
}
.login-card__cta { margin-block-start: var(--space-2); }

.nav-link {
  color: var(--text-muted);
  font-weight: 500;
  padding-block: var(--space-1);
  border-block-end: 2px solid transparent;
}
.nav-link:hover { color: var(--text-body); }
.nav-link.is-active {
  color: var(--text-body);
  border-block-end-color: var(--text-body);
}

/* ── Headings ───────────────────────────────────────────────────────── */
.page-head { margin-block-end: var(--space-5); }
.page-head h1 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 600;
  letter-spacing: var(--tracking-tight);
}
.page-head--row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-4);
}
.muted { color: var(--text-muted); }
.mono { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: var(--text-sm); }

/* ── Cards ──────────────────────────────────────────────────────────── */
.card {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  padding: var(--space-5);
  margin-block-end: var(--space-5);
}
.card--flush { padding: 0; overflow: hidden; }
.card__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  margin-block-end: var(--space-3);
}

/* ── Forms ──────────────────────────────────────────────────────────── */
.form { display: flex; flex-direction: column; gap: var(--space-4); }
.form-row--split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}
.field { display: flex; flex-direction: column; gap: var(--space-2); }
.field__label { font-weight: 500; font-size: var(--text-sm); }
.field__hint { color: var(--text-muted); font-size: var(--text-xs); }
.field input {
  inline-size: 100%;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  background: var(--bg-page);
  color: var(--text-body);
}
.field input:focus-visible { outline: 2px solid var(--text-body); outline-offset: 1px; }

.form-actions { display: flex; gap: var(--space-3); align-items: center; }

/* ── Buttons ────────────────────────────────────────────────────────── */
.button {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-pill);
  font-weight: 600;
  font-size: var(--text-sm);
  border: 1px solid transparent;
  cursor: pointer;
}
.button--primary { background: var(--text-body); color: var(--bg-card); }
.button--primary:hover { opacity: 0.9; }
.button--ghost { background: transparent; border-color: var(--border-subtle); color: var(--text-body); }
.button--ghost:hover { background: var(--bg-page); }
.button--danger { background: transparent; border-color: var(--color-error); color: var(--color-error); }
.button--danger:hover { background: color-mix(in srgb, var(--color-error) 12%, var(--bg-card)); }
.button.is-disabled { opacity: 0.4; pointer-events: none; }

/* ── Alerts ─────────────────────────────────────────────────────────── */
.alert {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  margin-block-end: var(--space-4);
}
.alert--error {
  background: color-mix(in srgb, var(--color-error) 12%, var(--bg-card));
  border: 1px solid var(--color-error);
  color: var(--text-body);
}
.alert--ok {
  background: color-mix(in srgb, var(--color-success) 14%, var(--bg-card));
  border: 1px solid var(--color-success);
  color: var(--text-body);
}

/* ── Campaign chips ─────────────────────────────────────────────────── */
.chip-group { display: inline-flex; flex-wrap: wrap; gap: var(--space-2); }
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 2px var(--space-2);
  border-radius: var(--radius-pill);
  background: var(--accent-monthly-bg);
  color: var(--text-body);
  font-size: var(--text-xs);
  font-weight: 600;
  border: 1px solid transparent;
}
a.chip:hover { border-color: var(--accent-monthly); }
.chip__remove-form { display: inline; }
.chip__remove {
  font-size: var(--text-sm);
  line-height: 1;
  color: var(--text-muted);
  padding: 0 2px;
}
.chip__remove:hover { color: var(--color-error); }
.campaigns-row { margin-block-end: var(--space-4); }

/* Inline label+input+button row (add tag, tag-all). */
.inline-form { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }
.inline-form input {
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  background: var(--bg-page);
  color: var(--text-body);
  min-inline-size: 220px;
}
.inline-form--tight { gap: var(--space-2); }
.inline-form--tight input { min-inline-size: 150px; }

/* Campaign overview actions cell — rename form + delete button side by side. */
.actions-cell { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }

/* Bulk "tag selected" bar above the leads table. */
.bulk-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-block-end: var(--space-3);
  flex-wrap: wrap;
}
.bulk-bar__hint { color: var(--text-muted); font-size: var(--text-sm); }
.bulk-bar input {
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  background: var(--bg-card);
  color: var(--text-body);
}
.col-check { inline-size: 1%; white-space: nowrap; }

/* ── Stats ──────────────────────────────────────────────────────────── */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  margin-block-end: var(--space-5);
}
.stat {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  text-align: center;
}
.stat__value { display: block; font-size: var(--text-3xl); font-weight: 600; font-family: var(--font-display); }
.stat__label { display: block; color: var(--text-muted); font-size: var(--text-sm); }

/* ── Table ──────────────────────────────────────────────────────────── */
.table { inline-size: 100%; border-collapse: collapse; }
.table th, .table td {
  text-align: start;
  padding: var(--space-3) var(--space-4);
  border-block-end: 1px solid var(--border-subtle);
}
.table th {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--text-muted);
}
.table tbody tr:last-child td { border-block-end: 0; }
.row-link { cursor: pointer; }
.row-link:hover { background: var(--bg-page); }
.table a { font-weight: 600; }
.table a:hover { text-decoration: underline; }

/* ── Status badges ──────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 2px var(--space-2);
  border-radius: var(--radius-pill);
  font-size: var(--text-xs);
  font-weight: 600;
  background: var(--border-subtle);
  color: var(--text-body);
  white-space: nowrap;
}
/* One colour per pipeline stage: neutral → blue → amber → green, with the
   loss states muted/red. */
.badge--new          { background: var(--border-subtle); color: var(--text-muted); }
.badge--contacted    { background: var(--accent-weekly-bg); color: var(--text-body); }
.badge--replied      { background: color-mix(in srgb, var(--color-warning) 24%, var(--bg-card)); color: var(--text-body); }
.badge--converted    { background: color-mix(in srgb, var(--color-success) 24%, var(--bg-card)); color: var(--text-body); }
.badge--disqualified { background: var(--border-subtle); color: var(--text-faint); }
.badge--opted_out    { background: color-mix(in srgb, var(--color-error) 18%, var(--bg-card)); color: var(--text-body); }

/* ── Status filter tabs (leads list) ────────────────────────────────── */
.status-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-block-end: var(--space-4);
}
.status-tab {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-pill);
  border: 1px solid var(--border-subtle);
  color: var(--text-muted);
  font-size: var(--text-sm);
  font-weight: 500;
}
.status-tab:hover { color: var(--text-body); }
.status-tab.is-active {
  background: var(--text-body);
  color: var(--bg-card);
  border-color: var(--text-body);
}
.status-tab__count { font-size: var(--text-xs); opacity: 0.75; }

/* ── Status picker (lead detail) ────────────────────────────────────── */
.status-head { display: flex; align-items: center; gap: var(--space-3); margin-block-end: var(--space-2); }
.status-form { display: flex; flex-direction: column; gap: var(--space-3); margin-block-start: var(--space-3); }
.status-picker { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.status-pill {
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-pill);
  border: 1px solid var(--border-subtle);
  color: var(--text-muted);
  font-size: var(--text-sm);
  font-weight: 600;
}
.status-pill:hover { color: var(--text-body); border-color: var(--text-body); }
.status-pill.is-active {
  background: var(--text-body);
  color: var(--bg-card);
  border-color: var(--text-body);
}

/* ── Notes thread (lead detail) ─────────────────────────────────────── */
.note-input {
  inline-size: 100%;
  padding: var(--space-3);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  background: var(--bg-page);
  color: var(--text-body);
  font-family: inherit;
  resize: vertical;
}
.note-add { display: flex; flex-direction: column; gap: var(--space-2); margin-block-end: var(--space-4); }

.notes-thread { display: flex; flex-direction: column; gap: var(--space-3); }
.note {
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4);
  background: var(--bg-page);
}
.note__meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-block-end: var(--space-2);
}
.note__body { white-space: pre-wrap; }
.note__actions { display: flex; align-items: flex-start; gap: var(--space-3); margin-block-start: var(--space-2); }
.note__edit summary {
  cursor: pointer;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-muted);
}
.note__edit summary:hover { color: var(--text-body); }
.note__edit .note-add { margin-block: var(--space-2) 0; }

/* Divider + select inside the bulk action bar. */
.bulk-bar__divider {
  inline-size: 1px;
  align-self: stretch;
  background: var(--border-subtle);
  margin-inline: var(--space-1);
}
.bulk-bar select {
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  background: var(--bg-card);
  color: var(--text-body);
}

/* ── Detail list ────────────────────────────────────────────────────── */
.detail-list {
  display: grid;
  grid-template-columns: minmax(140px, max-content) 1fr;
  gap: var(--space-2) var(--space-5);
}
.detail-list dt { color: var(--text-muted); font-size: var(--text-sm); }
.detail-list dd { font-size: var(--text-base); }

.raw-json {
  margin-block-start: var(--space-3);
  padding: var(--space-4);
  background: var(--bg-page);
  border-radius: var(--radius-sm);
  overflow-x: auto;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: var(--text-sm);
  line-height: var(--leading-snug);
}

/* ── Pager + empty ──────────────────────────────────────────────────── */
.pager {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  margin-block-start: var(--space-5);
}
.pager__status { color: var(--text-muted); font-size: var(--text-sm); }
.empty { text-align: center; display: flex; flex-direction: column; gap: var(--space-3); align-items: center; }

@media (max-width: 640px) {
  .form-row--split { grid-template-columns: 1fr; }
  .stat-grid { grid-template-columns: 1fr 1fr; }
}
