/* ============================================================
   LEAD INTELLIGENCE MODULE -- leads.css
   All classes prefixed with li- to avoid conflicts
   ============================================================ */

/* --- Page layout --- */
.li-page { padding-bottom: 40px; }
.li-greeting { font-size: 24px; font-weight: 700; margin-bottom: 2px; }
.li-subtitle { font-size: 14px; color: var(--text-muted); margin-bottom: 24px; }

/* --- Stats row --- */
.li-stats-row {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 12px; margin-bottom: 24px;
}
.li-stat-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 16px; text-align: center;
}
.li-stat-value { font-size: 28px; font-weight: 700; }
.li-stat-label { font-size: 12px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; margin-top: 4px; }
.li-stat-hot .li-stat-value { color: #ef4444; }
.li-stat-warm .li-stat-value { color: #f59e0b; }
.li-stat-sent .li-stat-value { color: #3b82f6; }
.li-stat-replies .li-stat-value { color: #22c55e; }

/* --- Controls (filters + sort) --- */
.li-controls {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px; gap: 12px; flex-wrap: wrap;
}
.li-filters { display: flex; gap: 6px; flex-wrap: wrap; }
.li-pill {
  padding: 6px 14px; border-radius: 20px; font-size: 13px;
  cursor: pointer; background: var(--bg-card); border: 1px solid var(--border);
  color: var(--text-secondary); transition: all 0.15s; font-family: inherit;
}
.li-pill:hover { background: var(--accent-light); border-color: var(--accent); color: var(--accent); }
.li-pill.active { background: var(--accent); border-color: var(--accent); color: #fff; }

.li-sort-wrap { flex-shrink: 0; }
.li-sort-select {
  padding: 6px 12px; border-radius: var(--radius-sm); font-size: 13px;
  background: var(--bg-card); border: 1px solid var(--border);
  color: var(--text-primary); font-family: inherit; cursor: pointer;
}

/* --- Lead cards --- */
.li-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); margin-bottom: 8px;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.li-card:hover { border-color: var(--accent); }
.li-card.expanded { border-color: var(--accent); box-shadow: 0 2px 16px rgba(255,89,0,0.08); }

.li-card-header {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 14px 18px; cursor: pointer;
}
.li-card-score { flex-shrink: 0; padding-top: 2px; }
.li-card-main { flex: 1; min-width: 0; }
.li-card-chevron { flex-shrink: 0; color: var(--text-muted); font-size: 12px; padding-top: 4px; }

.li-card-name-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 2px; }
.li-card-name { font-size: 16px; font-weight: 600; }
.li-card-socials { display: flex; gap: 4px; }
.li-card-title { font-size: 14px; color: var(--text-secondary); margin-bottom: 4px; }
.li-card-title strong { color: var(--text-primary); font-weight: 600; }
.li-card-rationale { font-size: 13px; color: var(--accent); margin-bottom: 6px; font-style: italic; }
.li-card-meta { display: flex; gap: 12px; flex-wrap: wrap; font-size: 12px; color: var(--text-muted); }
.li-card-meta span { white-space: nowrap; }

/* --- Score badge --- */
.li-score-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: 50%; font-size: 14px; font-weight: 700;
  border: 2px solid; line-height: 1;
}
.li-badge-hot { background: rgba(239,68,68,0.15); color: #ef4444; border-color: #ef4444; }
.li-badge-warm { background: rgba(245,158,11,0.15); color: #f59e0b; border-color: #f59e0b; }
.li-badge-cool { background: rgba(59,130,246,0.15); color: #3b82f6; border-color: #3b82f6; }

/* --- Tier labels --- */
.li-tier {
  display: inline-block; padding: 1px 8px; border-radius: 10px;
  font-size: 10px; font-weight: 700; letter-spacing: 0.5px;
}
.li-tier-hot { background: rgba(239,68,68,0.15); color: #ef4444; }
.li-tier-warm { background: rgba(245,158,11,0.15); color: #f59e0b; }
.li-tier-cool { background: rgba(59,130,246,0.15); color: #3b82f6; }

/* --- Social icons --- */
.li-social {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 4px; font-size: 11px; font-weight: 700;
  background: var(--bg-hover); color: var(--text-muted); text-decoration: none;
  transition: all 0.15s; font-family: inherit;
}
.li-social:hover { background: var(--accent); color: #fff; text-decoration: none; }

/* --- Expanded card body --- */
.li-card-body {
  padding: 0 18px 18px; border-top: 1px solid var(--border); margin-top: 0;
  padding-top: 16px;
}

.li-card-actions-bar {
  display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap;
}
.li-btn-discard { color: var(--danger); border-color: var(--danger); }
.li-btn-discard:hover { background: rgba(239,68,68,0.1); }
.li-btn-confirm-discard { background: var(--danger); }
.li-btn-confirm-discard:hover { background: #dc2626; }

/* --- Draft section --- */
.li-draft-section {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 14px; margin-bottom: 16px;
}
.li-draft-subject { margin-bottom: 0; }
.li-draft-body {
  min-height: 80px; padding: 10px 12px; border: 1px solid var(--border);
  border-radius: var(--radius-sm); background: var(--bg-input);
  color: var(--text-primary); font-size: 14px; font-family: inherit;
  line-height: 1.6; white-space: pre-wrap; outline: none;
}
.li-draft-body:focus { border-color: var(--border-focus); }

/* --- Detail grid --- */
.li-detail-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px;
}
.li-detail-label {
  font-size: 12px; font-weight: 700; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 8px;
}
.li-detail-value { font-size: 14px; color: var(--text-secondary); margin-bottom: 4px; }
.li-detail-value a { color: var(--accent); }

/* --- Score breakdown bars --- */
.li-score-row {
  display: flex; align-items: center; gap: 8px; margin-bottom: 6px;
}
.li-score-factor { font-size: 12px; color: var(--text-secondary); width: 80px; text-transform: capitalize; flex-shrink: 0; }
.li-score-bar-wrap {
  flex: 1; height: 6px; background: var(--bg-hover); border-radius: 3px; overflow: hidden;
}
.li-score-bar { height: 100%; background: var(--accent); border-radius: 3px; transition: width 0.4s ease; }
.li-score-val { font-size: 12px; font-weight: 600; color: var(--text-primary); width: 28px; text-align: right; flex-shrink: 0; }

/* --- Engagement signals --- */
.li-signals { margin-bottom: 16px; }
.li-signal-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.li-signal-chip {
  display: inline-block; padding: 4px 10px; border-radius: 12px;
  font-size: 12px; background: var(--accent-light); color: var(--accent);
  border: 1px solid rgba(255,89,0,0.2);
}

/* --- Discard panel --- */
.li-discard-panel {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 14px; margin-top: 16px;
}
.li-discard-reasons {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 4px; margin-bottom: 10px;
}
.li-check {
  display: flex; align-items: center; gap: 6px; font-size: 13px;
  color: var(--text-secondary); cursor: pointer; padding: 4px 6px;
  border-radius: 4px;
}
.li-check:hover { background: var(--bg-hover); }
.li-check input[type="checkbox"] { accent-color: var(--accent); }
.li-discard-note { min-height: 50px; }

/* --- Pagination --- */
.li-pagination {
  display: flex; align-items: center; justify-content: center; gap: 12px;
  margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border);
}
.li-page-info { font-size: 13px; color: var(--text-muted); }

/* --- Responsive --- */
@media (max-width: 640px) {
  .li-stats-row { grid-template-columns: repeat(2, 1fr); }
  .li-stat-value { font-size: 24px; }
  .li-greeting { font-size: 20px; }
  .li-controls { flex-direction: column; align-items: flex-start; }
  .li-card-header { padding: 12px 14px; gap: 10px; }
  .li-card-body { padding: 0 14px 14px; }
  .li-detail-grid { grid-template-columns: 1fr; }
  .li-card-name { font-size: 15px; }
  .li-discard-reasons { grid-template-columns: 1fr 1fr; }
  .li-score-badge { width: 38px; height: 38px; font-size: 12px; }
}


/* AI Action Buttons */
.li-ai-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 12px 16px 0;
}
.li-ai-btn {
  padding: 6px 12px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 8px;
  background: white;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
  display: flex;
  align-items: center;
  gap: 5px;
  color: var(--text, #1e293b);
}
.li-ai-btn:hover {
  border-color: var(--primary, #2563eb);
  color: var(--primary, #2563eb);
  background: var(--primary-light, #dbeafe);
}
.li-ai-btn.loading {
  opacity: 0.7;
  cursor: wait;
}
.li-ai-btn:disabled {
  opacity: 0.5;
  cursor: wait;
}
.li-ai-icon { font-size: 14px; }
.li-ai-spinner {
  display: inline-block;
  width: 12px;
  height: 12px;
  border: 2px solid var(--border, #e2e8f0);
  border-top-color: var(--primary, #2563eb);
  border-radius: 50%;
  animation: li-spin 0.6s linear infinite;
}
@keyframes li-spin { to { transform: rotate(360deg); } }

/* AI Result Panel */
.li-ai-result {
  margin: 8px 16px;
  padding: 12px 16px;
  background: #f8fafc;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 10px;
  font-size: 13px;
  line-height: 1.6;
}
.li-ai-result-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
  font-size: 12px;
  color: var(--text-muted, #64748b);
}
.li-ai-close {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 14px;
  color: var(--text-muted, #64748b);
  opacity: 0.6;
  padding: 0 4px;
}
.li-ai-close:hover { opacity: 1; }
.li-ai-result-body {
  color: var(--text, #1e293b);
}

/* Gmail connection banner */
.li-gmail-banner {
  background: #fef3c7;
  border: 1px solid #f59e0b;
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 16px;
  font-size: 14px;
  color: #92400e;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.li-gmail-banner a {
  color: #d97706;
  font-weight: 600;
  text-decoration: underline;
}
.li-gmail-banner a:hover {
  color: #b45309;
}
