/**
 * card-design-system.css — RepOS Contact Intelligence Card
 * LOCKED — do not modify without explicit instruction
 *
 * Source of truth for all contact card styling.
 * Recovery dashboard drawer inherits these styles.
 * Font: DM Sans throughout.
 *
 * Design tokens from contact_card_v4_final mockup.
 * Last updated: 2026-03-28
 */

/* ═══════════════════════════════════════════
   DESIGN TOKENS
   ═══════════════════════════════════════════ */
:root {
  /* Backgrounds */
  --card-bg-page: #0a0f1a;
  --card-bg-surface: #111827;
  --card-bg-elevated: #1e293b;
  --card-bg-input: #0f172a;

  /* Borders */
  --card-border: #1e2d45;
  --card-border-subtle: rgba(255,255,255,0.06);

  /* Text */
  --card-text-primary: #f0f4f8;
  --card-text-secondary: #94a3b8;
  --card-text-muted: #6b7a8e;
  --card-text-inverse: #111827;

  /* Accent colors */
  --card-accent: #3b82f6;
  --card-green: #22c55e;
  --card-green-dark: #059669;
  --card-amber: #f59e0b;
  --card-amber-light: #fcd34d;
  --card-red: #ef4444;
  --card-red-dark: #dc2626;
  --card-purple: #a78bfa;
  --card-teal: #14b8a6;
  --card-orange: #f97316;

  /* Badge colors */
  --badge-hot-bg: #dc2626;
  --badge-hot-text: #fff;
  --badge-elite-bg: #FF6B2C;
  --badge-elite-text: #fff;
  --badge-graft-bg: #059669;
  --badge-graft-text: #fff;
  --badge-convert-bg: #d97706;
  --badge-convert-text: #fff;
  --badge-debride-bg: #374151;
  --badge-debride-text: #e5e7eb;
  --badge-competitor-bg: #7f1d1d;
  --badge-competitor-text: #fca5a5;
  --badge-org-npi-bg: #1e293b;
  --badge-org-npi-text: #94a3b8;

  /* Score ring */
  --ring-elite: #FF6B2C;
  --ring-hot: #f97316;
  --ring-warm: #f59e0b;
  --ring-watch: #6b7280;
  --ring-track: #1e293b;

  /* Metric bars */
  --bar-recovery: #a78bfa;
  --bar-volume: #14b8a6;
  --bar-upgrade: #f97316;
  --bar-convert: #ef4444;
  --bar-track: #1e293b;

  /* Split panel */
  --split-green-bg: #052e16;
  --split-green-border: #166534;
  --split-green-text: #4ade80;
  --split-amber-bg: #1a1400;
  --split-amber-border: #78350f;
  --split-amber-text: #fbbf24;

  /* Font */
  --card-font: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --card-font-mono: 'Fira Code', 'SF Mono', monospace;

  /* Radius */
  --card-radius-sm: 6px;
  --card-radius-md: 10px;
  --card-radius-lg: 14px;
  --card-radius-pill: 100px;

  /* Spacing */
  --card-gap-xs: 4px;
  --card-gap-sm: 8px;
  --card-gap-md: 16px;
  --card-gap-lg: 20px;
}

/* ═══════════════════════════════════════════
   DRAWER SHELL
   ═══════════════════════════════════════════ */
.ci-drawer {
  font-family: var(--card-font);
  background: var(--card-bg-page);
  color: var(--card-text-primary);
}

/* ═══════════════════════════════════════════
   BADGES
   ═══════════════════════════════════════════ */
.ci-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: var(--card-radius-pill);
  font-size: 11px;
  font-weight: 800;
  font-family: var(--card-font);
  white-space: nowrap;
  letter-spacing: 0.02em;
}
.ci-badge-hot     { background: var(--badge-hot-bg); color: var(--badge-hot-text); }
.ci-badge-elite   { background: var(--badge-elite-bg); color: var(--badge-elite-text); }
.ci-badge-graft   { background: var(--badge-graft-bg); color: var(--badge-graft-text); }
.ci-badge-convert { background: var(--badge-convert-bg); color: var(--badge-convert-text); }
.ci-badge-debride { background: var(--badge-debride-bg); color: var(--badge-debride-text); }
.ci-badge-comp    { background: var(--badge-competitor-bg); color: var(--badge-competitor-text); }
.ci-badge-org     { background: var(--badge-org-npi-bg); color: var(--badge-org-npi-text); border: 1px solid var(--card-border); }

/* ═══════════════════════════════════════════
   SCORE RING (SVG-based, 90×90)
   ═══════════════════════════════════════════ */
.ci-score-ring {
  position: relative;
  width: 90px;
  height: 90px;
  flex-shrink: 0;
}
.ci-score-ring svg { display: block; }
.ci-score-ring .ci-ring-track { fill: none; stroke: var(--ring-track); stroke-width: 6; }
.ci-score-ring .ci-ring-value { fill: none; stroke-width: 6; stroke-linecap: round; transition: stroke-dasharray 0.6s ease; }
.ci-score-ring .ci-ring-center {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
}
.ci-score-ring .ci-ring-number { font-size: 24px; font-weight: 800; color: #fff; line-height: 1; }
.ci-score-ring .ci-ring-label { font-size: 10px; font-weight: 700; margin-top: 1px; }

/* ═══════════════════════════════════════════
   METRIC BARS
   ═══════════════════════════════════════════ */
.ci-metrics { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.ci-metric-row { display: flex; flex-direction: column; gap: 2px; }
.ci-metric-header { display: flex; justify-content: space-between; align-items: baseline; }
.ci-metric-label { font-size: 11px; color: var(--card-text-secondary); }
.ci-metric-value { font-size: 12px; font-weight: 700; font-family: var(--card-font-mono); }
.ci-metric-track { background: var(--bar-track); border-radius: 3px; height: 6px; width: 100%; }
.ci-metric-fill { height: 6px; border-radius: 3px; transition: width 0.4s ease; }
.ci-metric-fill.recovery { background: var(--bar-recovery); }
.ci-metric-fill.volume   { background: var(--bar-volume); }
.ci-metric-fill.upgrade  { background: var(--bar-upgrade); }
.ci-metric-fill.convert  { background: var(--bar-convert); }

/* ═══════════════════════════════════════════
   SPLIT PANEL (Customer Gets / PDX Earns)
   ═══════════════════════════════════════════ */
.ci-split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--card-gap-sm); margin: var(--card-gap-md) 0; }
.ci-split-card {
  border-radius: var(--card-radius-md);
  padding: var(--card-gap-md);
  text-align: center;
  cursor: pointer;
  transition: transform 0.1s;
}
.ci-split-card:active { transform: scale(0.97); }
.ci-split-green { background: var(--split-green-bg); border: 1px solid var(--split-green-border); }
.ci-split-amber { background: var(--split-amber-bg); border: 1px solid var(--split-amber-border); }
.ci-split-title { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px; }
.ci-split-green .ci-split-title { color: #6ee7b7; }
.ci-split-amber .ci-split-title { color: var(--card-amber-light); }
.ci-split-amount { font-size: clamp(18px, 5vw, 28px); font-weight: 800; font-family: var(--card-font-mono); }
.ci-split-green .ci-split-amount { color: var(--split-green-text); }
.ci-split-amber .ci-split-amount { color: var(--split-amber-text); }
.ci-split-sub { font-size: 10px; color: var(--card-text-muted); margin-top: 3px; }

/* Breakdown pills (MIC + Clinix) */
.ci-breakdown { display: flex; gap: var(--card-gap-xs); flex-wrap: wrap; justify-content: center; margin-top: 6px; }
.ci-pill { display: inline-block; padding: 2px 8px; border-radius: var(--card-radius-pill); font-size: 10px; font-weight: 600; }
.ci-pill-purple { background: rgba(167,139,250,0.15); color: var(--card-purple); }
.ci-pill-teal   { background: rgba(20,184,166,0.15); color: var(--card-teal); }
.ci-pill-amber  { background: rgba(245,158,11,0.15); color: var(--card-amber); }
.ci-pill-green  { background: rgba(34,197,94,0.15); color: var(--card-green); }

/* ═══════════════════════════════════════════
   STRATEGY CARD
   ═══════════════════════════════════════════ */
.ci-strategy {
  background: var(--card-bg-surface);
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius-md);
  padding: var(--card-gap-md);
  margin-bottom: var(--card-gap-md);
}
.ci-strategy-title { font-size: 14px; font-weight: 800; }
.ci-strategy-desc { font-size: 13px; color: #cbd5e1; margin-top: 4px; line-height: 1.4; }

/* ═══════════════════════════════════════════
   DOCTOR CARD
   ═══════════════════════════════════════════ */
.ci-doc-card {
  background: var(--card-bg-surface);
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius-md);
  padding: var(--card-gap-md);
  margin-bottom: var(--card-gap-sm);
}
.ci-doc-name { font-size: 18px; font-weight: 800; color: #fff; }
.ci-doc-meta { font-size: 14px; color: #cbd5e1; margin-top: 4px; line-height: 1.4; }
.ci-doc-codes-label { font-size: 10px; color: var(--card-text-muted); text-transform: uppercase; letter-spacing: 0.06em; margin: 8px 0 4px; }
.ci-doc-codes { display: flex; flex-wrap: wrap; gap: 4px; }
.ci-doc-code {
  background: var(--card-bg-elevated);
  color: #cbd5e1;
  padding: 4px 8px;
  border-radius: 5px;
  font-size: 12px;
  font-family: var(--card-font-mono);
}
.ci-doc-code-comp { border: 1px solid var(--card-red); color: #fca5a5; }
.ci-doc-comp { color: var(--card-red); font-size: 14px; font-weight: 700; margin-top: 6px; }

/* ═══════════════════════════════════════════
   CHARLIE INTEL
   ═══════════════════════════════════════════ */
.ci-charlie {
  background: var(--card-bg-surface);
  border: 1px solid var(--card-border);
  border-left: 3px solid var(--card-amber);
  border-radius: var(--card-radius-md);
  padding: 12px;
  margin-bottom: 12px;
}
.ci-charlie-title { font-size: 11px; font-weight: 800; color: var(--card-amber); letter-spacing: 0.06em; margin-bottom: 8px; }
.ci-charlie-item { display: flex; gap: 8px; align-items: flex-start; padding: 4px 0; font-size: 13px; color: #cbd5e1; line-height: 1.4; }
.ci-charlie-icon { font-size: 16px; flex-shrink: 0; }

/* ═══════════════════════════════════════════
   CALL SCRIPT
   ═══════════════════════════════════════════ */
.ci-call-script {
  background: var(--split-amber-bg);
  border: 1px solid #3d2e00;
  border-left: 4px solid var(--card-amber);
  border-radius: var(--card-radius-md);
  padding: 16px;
  font-size: 16px;
  line-height: 1.6;
  color: var(--card-amber-light);
  margin-top: 10px;
}

/* ═══════════════════════════════════════════
   OBJECTION / OPERATOR CARDS
   ═══════════════════════════════════════════ */
.ci-objection {
  background: var(--card-bg-surface);
  border-radius: var(--card-radius-md);
  padding: 10px;
  margin-bottom: 6px;
  font-size: 13px;
  line-height: 1.4;
}
.ci-objection-q { font-weight: 700; margin-bottom: 4px; }
.ci-objection-a { color: #cbd5e1; }

/* ═══════════════════════════════════════════
   COMMS BUTTONS
   ═══════════════════════════════════════════ */
.ci-comms-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 6px; margin-bottom: 10px; }
.ci-comm-btn {
  background: var(--card-bg-elevated);
  border: none;
  border-radius: var(--card-radius-sm);
  padding: 10px;
  font-size: 14px;
  font-weight: 600;
  font-family: var(--card-font);
  cursor: pointer;
  text-align: center;
  transition: background 0.15s;
}
.ci-comm-btn:active { background: #334155; }
.ci-comm-call  { color: #60a5fa; }
.ci-comm-sms   { color: #22c55e; }
.ci-comm-email { color: #fbbf24; }

/* ═══════════════════════════════════════════
   SMS / EMAIL TEMPLATES
   ═══════════════════════════════════════════ */
.ci-template {
  background: var(--card-bg-surface);
  border-radius: var(--card-radius-md);
  padding: 10px;
  margin-bottom: 6px;
}
.ci-template-label { font-size: 11px; color: var(--card-text-muted); font-weight: 700; margin-bottom: 4px; }
.ci-template-body { font-size: 13px; color: #cbd5e1; line-height: 1.4; }
.ci-template-copy {
  background: var(--card-green-dark);
  color: #fff;
  border: none;
  border-radius: var(--card-radius-sm);
  padding: 6px 12px;
  font-size: 12px;
  font-weight: 600;
  font-family: var(--card-font);
  cursor: pointer;
  margin-top: 6px;
}

/* ═══════════════════════════════════════════
   DRAWER TABS
   ═══════════════════════════════════════════ */
.ci-tabs {
  display: flex;
  border-bottom: 1px solid var(--card-border);
  position: sticky;
  top: 0;
  background: var(--card-bg-page);
  z-index: 3;
}
.ci-tab {
  flex: 1;
  padding: 12px;
  text-align: center;
  font-size: 15px;
  font-weight: 700;
  font-family: var(--card-font);
  color: var(--card-text-muted);
  cursor: pointer;
  border-bottom: 3px solid transparent;
  height: 48px;
  background: none;
  border-top: none;
  border-left: none;
  border-right: none;
}
.ci-tab.active { color: #fff; border-bottom-color: var(--card-accent); }

/* ═══════════════════════════════════════════
   DRAWER ACTIONS (sticky bottom)
   ═══════════════════════════════════════════ */
.ci-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding: 12px 16px 28px;
  border-top: 2px solid #1e3a5f;
  position: sticky;
  bottom: 0;
  background: #0d1b2e;
  z-index: 10;
}
.ci-action-btn {
  padding: 16px;
  font-size: 18px;
  font-weight: 700;
  font-family: var(--card-font);
  border: none;
  border-radius: var(--card-radius-md);
  cursor: pointer;
  height: 56px;
}

/* ═══════════════════════════════════════════
   SECTION HEADERS
   ═══════════════════════════════════════════ */
.ci-section-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--card-text-muted);
  margin-bottom: 8px;
}

/* ═══════════════════════════════════════════
   COLLAPSIBLE SECTIONS
   ═══════════════════════════════════════════ */
.ci-collapse summary {
  cursor: pointer;
  font-size: 13px;
  font-weight: 700;
  color: var(--card-text-secondary);
  padding: 8px 0;
  list-style: none;
}
.ci-collapse summary::-webkit-details-marker { display: none; }

/* ═══════════════════════════════════════════
   END MARKER
   ═══════════════════════════════════════════ */
.ci-end-marker {
  height: 20px;
  text-align: center;
  color: var(--card-text-muted);
  font-size: 12px;
  margin-bottom: 10px;
}

/* ═══════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════ */
@media (max-width: 900px) {
  .ci-split-amount { font-size: clamp(16px, 4.5vw, 24px); }
  .ci-doc-name { font-size: 16px; }
  .ci-action-btn { height: 52px; font-size: 16px; }
}
