/* ============================================================================
   ZERAVA CRM — components.css
   Cards, buttons, badges, forms, tables, modals
   ============================================================================ */

/* Card */
.card {
  background: var(--navy2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--s5);
}
.card--tight { padding: var(--s4); }
.card__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-bottom: var(--s2);
}
.card__value {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--white);
}
.card__sub {
  margin-top: var(--s2);
  font-size: 12px;
  color: var(--muted);
}

/* KPI accent dot */
.kpi-accent {
  display: inline-block;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--blue);
  margin-right: var(--s2);
  vertical-align: middle;
}
.kpi-accent--ig { background: var(--purple); }
.kpi-accent--email { background: var(--blue); }
.kpi-accent--whatsapp { background: var(--green); }
.kpi-accent--total { background: var(--orange); }

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--s2);
  padding: 9px 14px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  background: var(--navy3);
  color: var(--white);
  font-size: 13px;
  font-family: var(--font-mono);
  cursor: pointer;
  transition: background 120ms ease, border-color 120ms ease, transform 80ms ease;
}
.btn:hover { background: var(--navy2); border-color: var(--blue2); }
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

.btn--primary {
  background: var(--blue);
  border-color: var(--blue);
  color: var(--navy);
  font-weight: 600;
}
.btn--primary:hover { background: var(--blue2); border-color: var(--blue2); color: var(--navy); }

.btn--green { background: var(--green); border-color: var(--green); color: var(--navy); font-weight: 600; }
.btn--green:hover { background: #00a884; border-color: #00a884; color: var(--navy); }

.btn--reeng {
  background: var(--orange);
  border-color: var(--orange);
  color: var(--navy);
  font-weight: 600;
}
.btn--reeng:hover { background: #e2640f; border-color: #e2640f; color: var(--navy); }

.btn--danger { background: transparent; border-color: var(--red); color: var(--red); }
.btn--danger:hover { background: rgba(239,68,68,0.1); }

.btn--ghost { background: transparent; }
.btn--ghost:hover { background: var(--navy3); }

.btn--sm { padding: 6px 10px; font-size: 12px; }
.btn--block { width: 100%; justify-content: center; }

/* Forms */
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--s4); }
.field label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}
.input, .textarea, .select {
  width: 100%;
  padding: 10px 12px;
  background: var(--navy);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--white);
  font-family: var(--font-mono);
  font-size: 13px;
  outline: none;
  transition: border-color 120ms ease, background 120ms ease;
}
.input:focus, .textarea:focus, .select:focus {
  border-color: var(--blue);
  background: var(--navy2);
}
.textarea { resize: vertical; min-height: 90px; line-height: 1.5; }

/* Badges */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-family: var(--font-mono);
  background: var(--navy3);
  color: var(--white);
  border: 1px solid var(--border);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.badge--queued { background: rgba(74,98,128,0.15); color: var(--muted); border-color: var(--border); }
.badge--pre_engaged { background: rgba(124,58,237,0.15); color: var(--purple); border-color: rgba(124,58,237,0.3); }
.badge--sent { background: rgba(46,170,226,0.15); color: var(--blue); border-color: rgba(46,170,226,0.3); }
.badge--replied { background: rgba(0,184,148,0.15); color: var(--green); border-color: rgba(0,184,148,0.3); }
.badge--in_conversation { background: rgba(0,184,148,0.2); color: var(--green); border-color: rgba(0,184,148,0.4); }
.badge--followed_up { background: rgba(234,179,8,0.15); color: var(--yellow); border-color: rgba(234,179,8,0.3); }
.badge--dropped { background: rgba(239,68,68,0.12); color: var(--red); border-color: rgba(239,68,68,0.3); }
.badge--call_booked { background: rgba(249,115,22,0.15); color: var(--orange); border-color: rgba(249,115,22,0.3); }
.badge--qualified { background: rgba(0,184,148,0.25); color: var(--green); border-color: var(--green); }
.badge--closed_won { background: var(--green); color: var(--navy); border-color: var(--green); }
.badge--closed_lost { background: rgba(239,68,68,0.2); color: var(--red); border-color: var(--red); }
.badge--no_reply { background: rgba(74,98,128,0.18); color: var(--muted); border-color: var(--border); }
.badge--eligible_for_reengagement { background: rgba(46,170,226,0.15); color: var(--blue); border-color: rgba(46,170,226,0.3); }
.badge--source-manual { background: rgba(124,58,237,0.15); color: var(--purple); border-color: rgba(124,58,237,0.3); }
.badge--source-auto { background: rgba(46,170,226,0.15); color: var(--blue); border-color: rgba(46,170,226,0.3); }

.badge--no-reply {
  background: rgba(234,179,8,0.15);
  color: var(--yellow);
  border-color: rgba(234,179,8,0.3);
}
.badge--reengagement {
  background: rgba(124,58,237,0.15);
  color: var(--purple);
  border-color: rgba(124,58,237,0.3);
}

.badge--channel-instagram { background: rgba(124,58,237,0.15); color: var(--purple); border-color: rgba(124,58,237,0.3); }
.badge--channel-email { background: rgba(46,170,226,0.15); color: var(--blue); border-color: rgba(46,170,226,0.3); }
.badge--channel-whatsapp { background: rgba(0,184,148,0.15); color: var(--green); border-color: rgba(0,184,148,0.3); }

/* Table-style lead list */
.lead-list {
  background: var(--navy2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.lead-list__head, .lead-row {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) 100px minmax(0, 0.9fr) 130px 110px 80px;
  gap: var(--s3);
  padding: var(--s3) var(--s4);
  align-items: center;
}
.lead-list__head {
  background: var(--navy3);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 5;
}
.lead-list__th {
  cursor: pointer;
  user-select: none;
  transition: color 100ms ease;
}
.lead-list__th:hover { color: var(--white); }
.lead-list__th.is-sorted { color: var(--blue); }
.lead-row {
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 100ms ease;
}
.lead-row:last-child { border-bottom: none; }
.lead-row:hover { background: var(--navy3); }
.lead-row.is-selected { background: var(--navy3); border-left: 3px solid var(--blue); padding-left: calc(var(--s4) - 3px); }

.lead-row__name { font-weight: 500; color: var(--white); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lead-row__sub { color: var(--muted); font-size: 12px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lead-row__date { color: var(--muted); font-size: 12px; text-align: right; }

/* Detail panel */
.panel-detail {
  background: var(--navy2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--s5);
}
.panel-detail h3 {
  display: flex; align-items: center; gap: var(--s2);
  margin-bottom: var(--s4);
}
.kv {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--s2) var(--s3);
  font-size: 12px;
  margin-bottom: var(--s4);
}
.kv dt { color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; font-size: 11px; }
.kv dd { margin: 0; color: var(--white); word-break: break-word; }

/* Status row buttons */
.status-pills { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: var(--s4); }
.status-pills .pill {
  padding: 5px 10px;
  font-size: 11px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--navy);
  color: var(--white);
  cursor: pointer;
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.status-pills .pill.is-active { background: var(--blue); color: var(--navy); border-color: var(--blue); font-weight: 600; }
.status-pills .pill:hover { border-color: var(--blue); }

/* Mini dashboard (per-section status counts) */
.mini-dash {
  display: flex;
  gap: 8px;
  margin-bottom: var(--s4);
  flex-wrap: wrap;
}
.mini-card {
  background: var(--navy2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  min-width: 92px;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-mono);
  color: var(--white);
  transition: border-color 120ms ease, background 120ms ease;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.mini-card:hover { border-color: var(--blue); }
.mini-card.is-active {
  border-color: var(--blue);
  background: var(--navy3);
  box-shadow: inset 0 0 0 1px var(--blue);
}
.mini-card__count {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.02em;
}
.mini-card__label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}
.mini-card.is-active .mini-card__label { color: var(--blue); }

/* Status accents on mini cards */
.mini-card--queued .mini-card__count { color: var(--muted); }
.mini-card--sent .mini-card__count { color: var(--blue); }
.mini-card--replied .mini-card__count { color: var(--green); }
.mini-card--in_conversation .mini-card__count { color: var(--green); }
.mini-card--call_booked .mini-card__count { color: var(--orange); }
.mini-card--dropped .mini-card__count { color: var(--red); }
.mini-card--no-reply .mini-card__count { color: var(--yellow); }
.mini-card--no-reply { border-left: 2px solid var(--yellow); }
.mini-card--no-reply.is-active { border-color: var(--yellow); box-shadow: inset 0 0 0 1px var(--yellow); }

/* Filters bar */
.filters {
  display: flex;
  gap: var(--s3);
  margin-bottom: var(--s4);
  flex-wrap: wrap;
  align-items: center;
}
.filters .search { flex: 1; min-width: 220px; }

/* Modal */
.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(6,15,30,0.75);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  z-index: 100;
  padding: var(--s5);
}
.modal {
  background: var(--navy2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--s6);
  max-width: 480px;
  width: 100%;
  box-shadow: var(--shadow-lg);
  max-height: calc(100vh - 64px);
  overflow-y: auto;
}
.modal--wide { max-width: 720px; }

/* Toast */
.toast-stack {
  position: fixed; bottom: var(--s5); right: var(--s5);
  display: flex; flex-direction: column; gap: var(--s2);
  z-index: 200;
}
.toast {
  background: var(--navy3);
  border: 1px solid var(--border);
  border-left: 3px solid var(--blue);
  border-radius: var(--r-sm);
  padding: var(--s3) var(--s4);
  font-size: 13px;
  min-width: 280px;
  box-shadow: var(--shadow-md);
  animation: toast-in 200ms ease;
}
.toast--error { border-left-color: var(--red); }
.toast--success { border-left-color: var(--green); }
.toast--warn { border-left-color: var(--yellow); }
@keyframes toast-in {
  from { transform: translateY(8px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

/* Snapshot expand area */
.rep-snap-row { cursor: pointer; }
.rep-snap-row:hover { background: var(--navy3); }
.rep-snap-breakdown {
  background: var(--navy);
  border-bottom: 1px solid var(--border);
  padding: var(--s4) var(--s4) var(--s5);
}

/* Empty state */
.empty {
  padding: var(--s7) var(--s5);
  text-align: center;
  color: var(--muted);
  border: 1px dashed var(--border);
  border-radius: var(--r-md);
}
.empty h3 { color: var(--white); margin-bottom: var(--s2); }

/* Loader */
.loader {
  display: inline-block;
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 2px solid var(--border);
  border-top-color: var(--blue);
  animation: spin 700ms linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Skeleton loader (used by lead lists during fetch) */
.skel-list { padding: var(--s3) 0; }
.skel-row {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) 100px minmax(0, 0.9fr) 130px 110px 80px;
  gap: var(--s3);
  padding: var(--s3) var(--s4);
  align-items: center;
  border-bottom: 1px solid var(--border);
}
.skel-row > div {
  height: 14px;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--navy3) 0%, var(--border) 50%, var(--navy3) 100%);
  background-size: 200% 100%;
  animation: skel-shimmer 1.4s ease-in-out infinite;
}
.skel-row > div:nth-child(1) { width: 80%; }
.skel-row > div:nth-child(2) { width: 60%; }
.skel-row > div:nth-child(3) { width: 70%; }
.skel-row > div:nth-child(4) { width: 50%; }
.skel-row > div:nth-child(5) { width: 50%; }
.skel-row > div:nth-child(6) { width: 50%; justify-self: end; }
@keyframes skel-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Section header */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s5);
  flex-wrap: wrap;
  gap: var(--s3);
}
.section-header h2 { margin: 0; }
.section-header .meta { color: var(--muted); font-size: 12px; }

/* Message preview block */
.msg-preview {
  background: var(--navy);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: var(--s4);
  margin-top: var(--s3);
  white-space: pre-wrap;
  font-size: 13px;
  line-height: 1.6;
  max-height: 320px;
  overflow-y: auto;
}
.msg-preview .subject {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  margin-bottom: var(--s3);
  padding-bottom: var(--s2);
  border-bottom: 1px solid var(--border);
}

/* Notes auto-save indicator */
.notes-status {
  font-size: 11px;
  color: var(--muted);
  margin-top: 4px;
  height: 14px;
}
.notes-status.is-saved { color: var(--green); }

/* File input / import */
.import-zone {
  border: 1px dashed var(--border);
  border-radius: var(--r-md);
  padding: var(--s6);
  text-align: center;
  cursor: pointer;
  background: var(--navy2);
  transition: border-color 120ms ease, background 120ms ease;
}
.import-zone:hover { border-color: var(--blue); background: var(--navy3); }
.import-zone input { display: none; }
