/* ═════════════════════════════════════════════════════════════════════════════
   js/leads-redesign.css — WIP-UI-LEADS-01
   Compact header + triage strip + structured source typing + quality pulse
   for the Sales CRM Leads page. Lift target: spartan-leads-redesign-v2.html.

   All new classes are `ll-*` prefixed to avoid collision with the existing
   leads renderer's inline styles + with jobs-list-redesign's `jl-*`.

   Pulse channels:
     • Red (stale)  — .is-overdue-row / .pill-overdue (shared from
                      jobs-list-redesign.css)
     • Green (hot)  — .av.is-hot ring + .ll-qual-hot .ll-dot dot

   prefers-reduced-motion kills both, keeps borders/colours.
   ═════════════════════════════════════════════════════════════════════════════ */

/* ── Source palette (additive — only used inside .ll-page) ──────────────── */
.ll-page {
  --src-fb:#1877F2;    --src-fb-bg:#EBF3FE;
  --src-google:#EA4335;--src-google-bg:#FEEDEB;
  --src-web:#0A0A0A;   --src-web-bg:#F5F5F4;
  --src-phone:#C41230; --src-phone-bg:#FBF3F4;
  --src-ref:#15803D;   --src-ref-bg:#DCFCE7;
  --src-trade:#6D28D9; --src-trade-bg:#F3E8FF;
  --q-hot:#15803D;     --q-warm:#D97706; --q-cold:#78716C;
}

/* ── Green pulse (hot lead) ────────────────────────────────────────────── */
@keyframes pulse-hot-ring {
  0%, 100% { box-shadow: 0 0 0 0 rgba(21,128,61,.55), 0 0 0 2px #15803D; }
  70%      { box-shadow: 0 0 0 7px rgba(21,128,61,0), 0 0 0 2px #15803D; }
}
@keyframes pulse-hot-dot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(21,128,61,.55); }
  70%      { box-shadow: 0 0 0 6px rgba(21,128,61,0); }
}
.ll-page .av.is-hot { animation: pulse-hot-ring 2.0s ease-in-out infinite; }
.ll-page .ll-qual-hot .ll-dot { animation: pulse-hot-dot 1.8s infinite; }
@media (prefers-reduced-motion: reduce) {
  .ll-page .av.is-hot { animation: none !important; box-shadow: 0 0 0 2px #15803D; }
  .ll-page .ll-qual-hot .ll-dot { animation: none !important; }
}

/* ── Page container + layout ──────────────────────────────────────────── */
.ll-page { padding: 4px 0 48px; }
.ll-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 20px;
  align-items: start;
}
@media (max-width: 1280px) {
  .ll-layout { grid-template-columns: 1fr; }
}

/* ── Compact page header ───────────────────────────────────────────────── */
.ll-ph {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--s200, #E7E5E4);
}
.ll-ph-l { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.ll-ph-eyebrow {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--s400, #A8A29E);
  line-height: 1;
}
.ll-ph-h1-row {
  display: flex;
  align-items: baseline;
  gap: 14px;
  flex-wrap: wrap;
}
.ll-ph-h1 {
  font-size: 30px;
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--ink, #0A0A0A);
  line-height: 1;
  margin: 0;
  font-family: var(--ff-sans, 'Archivo', system-ui, sans-serif);
}
.ll-ph-h1-meta {
  font-size: 13px;
  color: var(--s500, #78716C);
  font-weight: 600;
}
.ll-ph-h1-meta b { color: var(--ink, #0A0A0A); font-weight: 800; }
.ll-ph-h1-meta .ll-red   { color: var(--red, #C41230); font-weight: 800; }
.ll-ph-h1-meta .ll-green { color: #15803D; font-weight: 800; }
.ll-ph-r { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }

/* ── Triage strip (5 tiles) ─────────────────────────────────────────────── */
.ll-triage {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  margin-bottom: 14px;
}
.ll-tcard {
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 12px;
  padding: 13px 15px;
  cursor: pointer;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  box-shadow: var(--shadow-rest, 0 1px 2px rgba(10,10,10,.03));
  position: relative;
  text-align: left;
  font-family: inherit;
  color: inherit;
}
.ll-tcard:hover {
  border-color: var(--s300, #D6D3D1);
  box-shadow: var(--shadow-hover, 0 1px 2px rgba(10,10,10,.04), 0 12px 28px -12px rgba(10,10,10,.18));
  transform: translateY(-2px);
}
.ll-tcard.ll-on {
  background: var(--ink, #0A0A0A);
  border-color: var(--ink, #0A0A0A);
  color: #fff;
}
.ll-tcard.ll-on .ll-tcard-label,
.ll-tcard.ll-on .ll-tcard-sub { color: rgba(255,255,255,.65); }
.ll-tcard.ll-alert {
  border-color: rgba(196,18,48,.3);
  background: var(--pale-red, #FBF3F4);
}
.ll-tcard.ll-alert .ll-tcard-val,
.ll-tcard.ll-alert .ll-tcard-label { color: var(--red, #C41230); }
.ll-tcard.ll-hot {
  border-color: rgba(21,128,61,.3);
  background: #DCFCE7;
}
.ll-tcard.ll-hot .ll-tcard-val,
.ll-tcard.ll-hot .ll-tcard-label { color: #15803D; }
.ll-tcard-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 5px;
}
.ll-tcard-label {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--s500, #78716C);
}
.ll-tcard-ico {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: var(--s100, #F5F5F4);
  color: var(--s500, #78716C);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
}
.ll-tcard.ll-on .ll-tcard-ico { background: rgba(255,255,255,.12); color: #fff; }
.ll-tcard.ll-alert .ll-tcard-ico { background: rgba(196,18,48,.12); color: var(--red, #C41230); }
.ll-tcard.ll-hot .ll-tcard-ico { background: rgba(21,128,61,.12); color: #15803D; }
.ll-tcard-val {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--ink, #0A0A0A);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.ll-tcard.ll-on .ll-tcard-val { color: #fff; }
.ll-tcard-sub {
  font-size: 10.5px;
  color: var(--s500, #78716C);
  margin-top: 3px;
  font-weight: 600;
}
@media (max-width: 1100px) { .ll-triage { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 680px)  { .ll-triage { grid-template-columns: repeat(2, 1fr); } }

/* ── Filter bar (status segments + source chips + search) ──────────────── */
.ll-fbar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 0 12px;
  flex-wrap: wrap;
}
.ll-seg {
  display: flex;
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 10px;
  padding: 3px;
  gap: 2px;
  box-shadow: var(--shadow-rest);
}
.ll-seg button {
  padding: 7px 11px;
  font-size: 12.5px;
  font-weight: 700;
  color: var(--s500, #78716C);
  border-radius: 7px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
}
.ll-seg button:hover { color: var(--ink, #0A0A0A); }
.ll-seg button.ll-on { background: var(--ink, #0A0A0A); color: #fff; }
.ll-seg-count {
  font-size: 10px;
  font-weight: 800;
  padding: 1px 6px;
  border-radius: 5px;
  background: var(--s100, #F5F5F4);
  color: var(--s600, #57534E);
}
.ll-seg button.ll-on .ll-seg-count { background: rgba(255,255,255,.18); color: #fff; }
.ll-seg button:hover .ll-seg-count { background: var(--s200, #E7E5E4); color: var(--ink, #0A0A0A); }

.ll-chips { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.ll-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  color: var(--s700, #44403C);
  cursor: pointer;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  box-shadow: var(--shadow-rest);
  font-family: inherit;
}
.ll-chip:hover {
  border-color: var(--ink, #0A0A0A);
  color: var(--ink, #0A0A0A);
  transform: translateY(-1px);
  box-shadow: var(--shadow-hover);
}
.ll-chip.ll-on {
  background: var(--ink, #0A0A0A);
  color: #fff;
  border-color: var(--ink, #0A0A0A);
}
.ll-chip-c {
  font-size: 10px;
  font-weight: 800;
  padding: 1px 6px;
  border-radius: 5px;
  background: var(--s100, #F5F5F4);
  color: var(--s600, #57534E);
}
.ll-chip.ll-on .ll-chip-c { background: rgba(255,255,255,.2); color: #fff; }
.ll-chip-src {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 4px;
  font-weight: 800;
  font-size: 10px;
  letter-spacing: -0.02em;
}
.ll-page .src-ico-fb, .ll-chip-src.ll-src-fb         { background: var(--src-fb-bg); color: var(--src-fb); }
.ll-page .src-ico-google, .ll-chip-src.ll-src-google { background: var(--src-google-bg); color: var(--src-google); }
.ll-page .src-ico-web, .ll-chip-src.ll-src-web       { background: var(--src-web-bg); color: var(--src-web); }
.ll-page .src-ico-phone, .ll-chip-src.ll-src-phone   { background: var(--src-phone-bg); color: var(--src-phone); }
.ll-page .src-ico-ref, .ll-chip-src.ll-src-ref       { background: var(--src-ref-bg); color: var(--src-ref); }
.ll-page .src-ico-trade, .ll-chip-src.ll-src-trade   { background: var(--src-trade-bg); color: var(--src-trade); }

.ll-fbar-r {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 10px;
}
.ll-fbar-search { position: relative; }
.ll-fbar-search input {
  padding: 8px 12px 8px 34px;
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 10px;
  font-size: 12.5px;
  min-width: 240px;
  box-shadow: var(--shadow-rest);
  font-family: inherit;
  color: var(--ink, #0A0A0A);
}
.ll-fbar-search input:focus {
  outline: none;
  border-color: var(--ink, #0A0A0A);
  box-shadow: 0 0 0 3px rgba(10,10,10,.05);
}
.ll-fbar-search .ico {
  position: absolute;
  left: 11px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--s400, #A8A29E);
  pointer-events: none;
}

/* ── Lead table ────────────────────────────────────────────────────────── */
.ll-tbl-wrap {
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: var(--shadow-rest);
}
.ll-tbl {
  width: 100%;
  border-collapse: collapse;
}
.ll-tbl thead {
  background: var(--s50, #FAFAF9);
  border-bottom: 1px solid var(--s200, #E7E5E4);
}
.ll-tbl th {
  padding: 11px 14px;
  text-align: left;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--s500, #78716C);
  white-space: nowrap;
}
.ll-tbl th.ll-r { text-align: right; }
.ll-tbl td {
  padding: 13px 14px;
  font-size: 13px;
  border-bottom: 1px solid var(--s100, #F5F5F4);
  vertical-align: middle;
}
.ll-tbl tbody tr {
  transition: background 180ms cubic-bezier(.4,0,.2,1);
  cursor: pointer;
  position: relative;
}
.ll-tbl tbody tr:hover { background: var(--s50, #FAFAF9); }
.ll-tbl tbody tr:last-child td { border-bottom: 0; }
.ll-tbl tbody tr td:first-child { padding-left: 16px; }
.ll-tbl tbody tr td:last-child  { padding-right: 14px; }

/* Lead cell */
.ll-lead-cell {
  display: flex;
  align-items: center;
  gap: 11px;
  min-width: 0;
}
.ll-page .av {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 800;
  color: #fff;
  flex-shrink: 0;
  position: relative;
  letter-spacing: -0.01em;
}
.ll-lead-name {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--ink, #0A0A0A);
  letter-spacing: -0.005em;
  line-height: 1.2;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.ll-lead-meta {
  font-size: 11.5px;
  color: var(--s500, #78716C);
  margin-top: 3px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.ll-lead-meta b { color: var(--s700, #44403C); font-weight: 700; }
.ll-lead-meta .sep { color: var(--s300, #D6D3D1); }

/* Source cell */
.ll-src { display: inline-flex; align-items: center; gap: 8px; min-width: 0; }
.ll-src-ico {
  width: 24px;
  height: 24px;
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 13px;
  flex-shrink: 0;
  letter-spacing: -0.02em;
}
.ll-src-label {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--ink, #0A0A0A);
  letter-spacing: -0.005em;
  line-height: 1.2;
}
.ll-src-sub {
  font-size: 10.5px;
  color: var(--s500, #78716C);
  font-weight: 600;
  margin-top: 2px;
  letter-spacing: 0.02em;
}

/* Quality pill */
.ll-qual {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 9px;
  border-radius: 6px;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.ll-qual .ll-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: currentColor;
}
.ll-qual-hot  { background: #DCFCE7; color: #15803D; box-shadow: inset 0 0 0 1px rgba(21,128,61,.18); }
.ll-qual-hot .ll-dot { background: #15803D; }
.ll-qual-warm { background: #FEF3C7; color: #D97706; box-shadow: inset 0 0 0 1px rgba(146,64,14,.18); }
.ll-qual-warm .ll-dot { background: #D97706; }
.ll-qual-cold { background: var(--s100, #F5F5F4); color: var(--s500, #78716C); box-shadow: inset 0 0 0 1px var(--s200, #E7E5E4); }
.ll-qual-cold .ll-dot { background: var(--s400, #A8A29E); }
.ll-qual-none { color: var(--s400, #A8A29E); font-weight: 600; font-size: 14px; }

/* Time cell (Created / Next Activity) */
.ll-t-cell { display: flex; flex-direction: column; gap: 1px; }
.ll-t-val {
  font-size: 12px;
  font-weight: 700;
  color: var(--ink, #0A0A0A);
  font-variant-numeric: tabular-nums;
}
.ll-t-val.ll-red { color: var(--red, #C41230); }
.ll-t-val.ll-muted { color: var(--s400, #A8A29E); font-weight: 500; }
.ll-t-sub {
  font-size: 10px;
  color: var(--s400, #A8A29E);
  font-weight: 600;
  letter-spacing: 0.02em;
}
.ll-t-sub.ll-red { color: var(--red, #C41230); }

/* Owner cell */
.ll-owner-cell { display: inline-flex; align-items: center; gap: 8px; }
.ll-owner-cell .av { width: 26px; height: 26px; font-size: 10px; }
.ll-owner-name { font-size: 12px; font-weight: 700; color: var(--s700, #44403C); }
.ll-owner-unassigned {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: var(--pale-red, #FBF3F4);
  color: var(--red, #C41230);
  border-radius: 7px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: inset 0 0 0 1px rgba(196,18,48,.18);
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  border: none;
  font-family: inherit;
}
.ll-owner-unassigned:hover {
  background: var(--red, #C41230);
  color: #fff;
}

/* Quick-action cluster — fades in on row hover */
.ll-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  justify-content: flex-end;
  opacity: 0;
  transform: translateX(8px);
  transition: all 180ms cubic-bezier(.4,0,.2,1);
}
.ll-tbl tbody tr:hover .ll-actions {
  opacity: 1;
  transform: translateX(0);
}
.ll-qa-btn {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  color: var(--s600, #57534E);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  cursor: pointer;
  padding: 0;
  font-family: inherit;
}
.ll-qa-btn:hover {
  background: var(--ink, #0A0A0A);
  color: #fff;
  border-color: var(--ink, #0A0A0A);
  transform: translateY(-1px);
}
.ll-qa-btn.ll-green:hover { background: #15803D; border-color: #15803D; }
.ll-qa-btn.ll-red:hover   { background: var(--red, #C41230); border-color: var(--red, #C41230); }

/* Table footer */
.ll-tbl-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 18px;
  background: var(--s50, #FAFAF9);
  border-top: 1px solid var(--s200, #E7E5E4);
  font-size: 12px;
  color: var(--s500, #78716C);
  font-weight: 600;
}
.ll-tbl-foot b { color: var(--ink, #0A0A0A); }
.ll-tbl-foot .ll-red { color: var(--red, #C41230); }
.ll-tbl-foot .ll-green { color: #15803D; }
.ll-tbl-foot-r { display: flex; align-items: center; gap: 6px; }
.ll-tbl-foot-r button {
  padding: 5px 10px;
  border-radius: 7px;
  border: 1px solid var(--s200, #E7E5E4);
  background: #fff;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--s600, #57534E);
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  cursor: pointer;
  font-family: inherit;
}

/* ── Pagination controls (top + bottom of leads table) ──────────────── */
.ll-tbl-foot-pager {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.ll-tbl-head-pager {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 11px 18px;
  background: #fff;
  border-bottom: 1px solid var(--s200, #E7E5E4);
  flex-wrap: wrap;
}
.ll-pager-summary {
  font-size: 12px;
  font-weight: 600;
  color: var(--s500, #78716C);
}
.ll-pager-summary b { color: var(--ink, #0A0A0A); font-weight: 800; font-variant-numeric: tabular-nums; }
.ll-pager-controls-top { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.ll-pager-size {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--s500, #78716C);
}
.ll-pager-size-label { font-size: 10.5px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; }
.ll-pager-size select {
  padding: 5px 9px;
  border-radius: 7px;
  border: 1px solid var(--s200, #E7E5E4);
  background: #fff;
  font-size: 12px;
  font-weight: 700;
  color: var(--ink, #0A0A0A);
  cursor: pointer;
  font-family: inherit;
  outline: none;
  transition: border-color 180ms cubic-bezier(.4,0,.2,1);
}
.ll-pager-size select:hover { border-color: var(--ink, #0A0A0A); }
.ll-pager-size select:focus { border-color: var(--red, #C41230); box-shadow: 0 0 0 3px rgba(196,18,48,.1); }
.ll-pager-nav-group {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 8px;
  padding: 3px;
}
.ll-pager-nums {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 0 3px;
  border-left: 1px solid var(--s100, #F5F5F4);
  border-right: 1px solid var(--s100, #F5F5F4);
}
.ll-pager-btn {
  padding: 5px 9px;
  border: none;
  background: none;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--s600, #57534E);
  cursor: pointer;
  font-family: inherit;
  border-radius: 5px;
  min-width: 28px;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  font-variant-numeric: tabular-nums;
}
.ll-pager-btn:hover:not([disabled]) {
  background: var(--s100, #F5F5F4);
  color: var(--ink, #0A0A0A);
}
.ll-pager-btn[disabled] {
  opacity: 0.4;
  cursor: not-allowed;
}
.ll-pager-btn.ll-on {
  background: var(--red, #C41230);
  color: #fff;
}
.ll-pager-btn.ll-on:hover {
  background: var(--red, #C41230);
  color: #fff;
}
.ll-pager-nav {
  font-weight: 700;
  padding: 5px 11px;
}
.ll-pager-ellipsis {
  padding: 0 4px;
  font-size: 12px;
  color: var(--s400, #A8A29E);
  font-weight: 700;
  user-select: none;
}
@media (max-width: 720px) {
  .ll-tbl-head-pager { padding: 10px 14px; }
  .ll-pager-summary { width: 100%; }
  .ll-pager-controls-top { width: 100%; justify-content: space-between; }
  .ll-tbl-foot { flex-direction: column; align-items: stretch; gap: 10px; }
  .ll-tbl-foot-pager { justify-content: space-between; }
}
.ll-tbl-foot-r button:hover { border-color: var(--ink, #0A0A0A); color: var(--ink, #0A0A0A); }
.ll-tbl-foot-r button.ll-on { background: var(--ink, #0A0A0A); color: #fff; border-color: var(--ink, #0A0A0A); }

/* ── Rail (Map + Smart Cluster Suggestions) ────────────────────────────── */
.ll-rail {
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: sticky;
  top: 96px;
}
.ll-rcard {
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: var(--shadow-rest);
  transition: all 180ms cubic-bezier(.4,0,.2,1);
}
.ll-rcard:hover {
  border-color: var(--s300, #D6D3D1);
  box-shadow: var(--shadow-hover);
}
.ll-rcard-h {
  padding: 14px 16px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.ll-rcard-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--s500, #78716C);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.ll-rcard-link {
  font-size: 11px;
  font-weight: 700;
  color: var(--s500, #78716C);
  cursor: pointer;
  padding: 3px 6px;
  border-radius: 6px;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  display: inline-flex;
  align-items: center;
  gap: 3px;
}
.ll-rcard-link:hover {
  color: var(--ink, #0A0A0A);
  background: var(--s100, #F5F5F4);
}

/* Rep legend (top-left of map card) */
.ll-rep-legend {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 10px 14px 14px;
  font-size: 11.5px;
  font-weight: 700;
  border-top: 1px solid var(--s100, #F5F5F4);
}
.ll-rep-legend-row {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--s700, #44403C);
}
.ll-rep-legend-row .ll-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}
.ll-rep-legend-row .ll-ct {
  color: var(--s400, #A8A29E);
  font-weight: 600;
  margin-left: auto;
  font-size: 10.5px;
}
.ll-rep-legend-empty {
  font-size: 11.5px;
  color: var(--s400, #A8A29E);
  font-weight: 500;
  font-style: italic;
}

/* Smart Cluster cards */
.ll-cluster {
  padding: 14px 16px;
  border-bottom: 1px solid var(--s100, #F5F5F4);
  transition: background 180ms cubic-bezier(.4,0,.2,1);
}
.ll-cluster:last-child { border-bottom: 0; }
.ll-cluster:hover { background: var(--s50, #FAFAF9); }
.ll-cluster-h {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  gap: 8px;
}
.ll-cluster-name {
  font-size: 13px;
  font-weight: 800;
  color: var(--ink, #0A0A0A);
  letter-spacing: -0.015em;
  display: flex;
  align-items: center;
  gap: 8px;
}
.ll-cluster-pin {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--red, #C41230);
  box-shadow: 0 0 0 3px var(--pale-red, #FBF3F4);
  flex-shrink: 0;
}
.ll-quality-mix {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 10.5px;
  font-weight: 700;
}
.ll-quality-mix-item {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--s600, #57534E);
}
.ll-quality-mix-item .ll-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
}
.ll-quality-mix-item.hot .ll-dot  { background: #15803D; animation: pulse-hot-dot 1.8s infinite; }
.ll-quality-mix-item.warm .ll-dot { background: #D97706; }
.ll-quality-mix-item.cold .ll-dot { background: var(--s400, #A8A29E); }
@media (prefers-reduced-motion: reduce) {
  .ll-page .ll-quality-mix-item.hot .ll-dot { animation: none !important; }
}

.ll-cluster-stats {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10.5px;
  color: var(--s500, #78716C);
  font-weight: 700;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.ll-cluster-stat {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 7px;
  background: var(--s100, #F5F5F4);
  border-radius: 5px;
}
.ll-cluster-stat .ico { color: var(--s500, #78716C); }
.ll-cluster-stat.ll-save {
  background: #DCFCE7;
  color: #15803D;
}
.ll-cluster-stat.ll-save .ico { color: #15803D; }
.ll-cluster-stat.ll-rep {
  background: #DBEAFE;
  color: #1D4ED8;
}
.ll-cluster-stat.ll-rep .ico { color: #1D4ED8; }

.ll-cluster-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 12px;
  background: var(--ink, #0A0A0A);
  color: #fff;
  border-radius: 9px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: -0.005em;
  cursor: pointer;
  margin-bottom: 10px;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  box-shadow: 0 4px 12px -4px rgba(10,10,10,.3);
  border: none;
  font-family: inherit;
  width: 100%;
}
.ll-cluster-cta:hover {
  background: var(--red, #C41230);
  box-shadow: 0 4px 12px -4px rgba(196,18,48,.5);
  transform: translateY(-1px);
}
.ll-cluster-cta .ico { transition: transform 180ms cubic-bezier(.4,0,.2,1); }
.ll-cluster-cta:hover .ico { transform: translateX(2px); }

.ll-cluster-leads {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.ll-cl-lead {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 6px 8px;
  border-radius: 7px;
  cursor: pointer;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  font-size: 12px;
}
.ll-cl-lead:hover {
  background: #fff;
  box-shadow: var(--shadow-rest);
}
.ll-cl-lead .av { width: 22px; height: 22px; font-size: 9.5px; }
.ll-cl-lead-mid {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.ll-cl-lead-top {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}
.ll-cl-lead-q {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.ll-cl-lead-q.hot  { background: #15803D; animation: pulse-hot-dot 1.8s infinite; }
.ll-cl-lead-q.warm { background: #D97706; }
.ll-cl-lead-q.cold { background: var(--s400, #A8A29E); }
@media (prefers-reduced-motion: reduce) {
  .ll-page .ll-cl-lead-q.hot { animation: none !important; }
}
.ll-cl-lead-name {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--ink, #0A0A0A);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ll-cl-lead-sub {
  font-size: 9.5px;
  color: var(--s500, #78716C);
  font-weight: 600;
  letter-spacing: 0.01em;
  margin-left: 13px;
  line-height: 1.3;
}
.ll-cl-lead-sub b { color: var(--s700, #44403C); font-weight: 700; }

.ll-cluster-foot {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--s200, #E7E5E4);
}
.ll-cluster-foot button {
  padding: 5px 10px;
  border: 1px solid var(--s200, #E7E5E4);
  background: #fff;
  border-radius: 7px;
  font-size: 11px;
  font-weight: 700;
  color: var(--s600, #57534E);
  cursor: pointer;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  font-family: inherit;
}
.ll-cluster-foot button:hover {
  border-color: var(--ink, #0A0A0A);
  color: var(--ink, #0A0A0A);
}

.ll-cluster-empty {
  padding: 30px 16px;
  text-align: center;
  font-size: 12.5px;
  color: var(--s500, #78716C);
  font-weight: 600;
}

/* Pill overdue (shared with jobs list — but ensure available here) */
.ll-page .pill-overdue {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--pale-red, #FBF3F4);
  color: var(--red, #C41230);
  padding: 2px 7px 2px 6px;
  border-radius: 5px;
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  box-shadow: inset 0 0 0 1px rgba(196,18,48,.25);
  white-space: nowrap;
}
.ll-page .pill-overdue .dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--red, #C41230);
}

/* Compact density toggle */
.ll-tbl.ll-dense td { padding: 9px 14px; }

/* ── Sortable column headers ───────────────────────────────────────────── */
.ll-tbl thead th.ll-th-sortable {
  cursor: pointer;
  user-select: none;
  transition: background 180ms cubic-bezier(.4,0,.2,1),
              color 180ms cubic-bezier(.4,0,.2,1);
}
.ll-tbl thead th.ll-th-sortable:hover {
  background: var(--s100, #F5F5F4);
  color: var(--ink, #0A0A0A);
}
.ll-tbl thead th.ll-th-sortable.ll-sorted {
  color: var(--ink, #0A0A0A);
  background: var(--s100, #F5F5F4);
}
.ll-sort-arrow {
  color: var(--red, #C41230);
  font-size: 8px;
  letter-spacing: 0;
  margin-left: 3px;
  display: inline-block;
  vertical-align: middle;
}

/* Email/SMS as <a> need the same look as the button qa-btns */
.ll-actions a.ll-qa-btn { text-decoration: none; }

/* ══════════════════════════════════════════════════════════════════════════
   Smart Cluster Planner — Phoenix request 2026-05-21
   Full-page view showing a rep's week with day-by-day appointments,
   recommended slots for the cluster leads, drive + downtime gaps, and
   a cluster map. Classes prefixed `cp-` to avoid collisions.
   ══════════════════════════════════════════════════════════════════════════ */

.cp-page {
  padding: 4px 0 48px;
  --cp-red: #C41230;
  --cp-q-hot: #15803D;
  --cp-q-warm: #D97706;
}

.cp-empty {
  text-align: center;
  padding: 80px 24px;
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 14px;
  margin-top: 24px;
}
.cp-empty-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--ink, #0A0A0A);
  letter-spacing: -0.015em;
}
.cp-empty-desc {
  font-size: 13px;
  color: var(--s500, #78716C);
  margin-top: 8px;
  font-weight: 500;
}

/* Header */
.cp-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  padding-bottom: 16px;
  margin-bottom: 18px;
  border-bottom: 1px solid var(--s200, #E7E5E4);
  flex-wrap: wrap;
}
.cp-header-l { display: flex; align-items: center; gap: 16px; }
.cp-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  border: 1px solid var(--s200, #E7E5E4);
  background: #fff;
  border-radius: 9px;
  font-size: 12px;
  font-weight: 700;
  color: var(--s700, #44403C);
  cursor: pointer;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  font-family: inherit;
  box-shadow: var(--shadow-rest, 0 1px 2px rgba(10,10,10,.03));
}
.cp-back-btn:hover {
  border-color: var(--ink, #0A0A0A);
  color: var(--ink, #0A0A0A);
  transform: translateX(-2px);
  box-shadow: var(--shadow-hover, 0 8px 24px -8px rgba(10,10,10,.18));
}
.cp-eyebrow {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--s400, #A8A29E);
  margin-bottom: 4px;
}
.cp-title {
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--ink, #0A0A0A);
  margin: 0;
  font-family: var(--ff-sans, 'Archivo', system-ui, sans-serif);
  line-height: 1;
}
.cp-rep-name { color: var(--cp-red); }
.cp-rep-suffix { color: var(--s500, #78716C); font-weight: 600; margin-left: 8px; font-size: 22px; }
.cp-subtitle {
  font-size: 12.5px;
  color: var(--s500, #78716C);
  font-weight: 600;
  margin-top: 6px;
  letter-spacing: -0.005em;
}
.cp-header-r {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.cp-rep-select {
  padding: 7px 12px;
  border: 1px solid var(--s200, #E7E5E4);
  background: #fff;
  border-radius: 9px;
  font-size: 12px;
  font-weight: 700;
  color: var(--s700, #44403C);
  cursor: pointer;
  font-family: inherit;
  min-width: 200px;
  box-shadow: var(--shadow-rest);
}
.cp-rep-select:hover { border-color: var(--ink, #0A0A0A); }
.cp-week-nav {
  display: inline-flex;
  align-items: center;
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 9px;
  padding: 3px;
  gap: 2px;
  box-shadow: var(--shadow-rest);
}
.cp-week-btn {
  padding: 5px 9px;
  background: none;
  border: none;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 700;
  color: var(--s600, #57534E);
  cursor: pointer;
  font-family: inherit;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
}
.cp-week-btn:hover { color: var(--ink, #0A0A0A); background: var(--s100, #F5F5F4); }
.cp-week-today { padding: 5px 11px; }

/* Layout */
.cp-layout {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 20px;
  align-items: start;
}
@media (max-width: 1180px) {
  .cp-layout { grid-template-columns: 1fr; }
}

/* Rail (map + lead list) */
.cp-rail {
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: sticky;
  top: 96px;
}
.cp-rcard {
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: var(--shadow-rest);
}
.cp-rcard-h {
  padding: 12px 16px 8px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--s500, #78716C);
  border-bottom: 1px solid var(--s100, #F5F5F4);
}

/* Map card */
.cp-map-card {
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: var(--shadow-rest);
}
.cp-map-header {
  padding: 11px 14px;
  border-bottom: 1px solid var(--s100, #F5F5F4);
}
.cp-map-title {
  font-size: 12px;
  font-weight: 800;
  color: var(--ink, #0A0A0A);
  letter-spacing: -0.005em;
}
.cp-map-svg-wrap {
  background: linear-gradient(135deg, #E8F0E5 0%, #DDE9D8 100%);
  position: relative;
  height: 200px;
  overflow: hidden;
}
.cp-map-svg {
  width: 100%;
  height: 100%;
  display: block;
}
.cp-map-route {
  fill: none;
  stroke: var(--cp-red, #C41230);
  stroke-width: .8;
  stroke-dasharray: 1.2 1;
  opacity: .65;
}
.cp-map-pin {
  fill: var(--cp-red, #C41230);
  stroke: #fff;
  stroke-width: .8;
}
.cp-map-pin-hot {
  fill: var(--cp-q-hot, #15803D);
}
.cp-map-label {
  font-size: 3px;
  font-weight: 800;
  fill: var(--ink, #0A0A0A);
  text-anchor: middle;
  font-family: var(--ff-sans, 'Archivo', sans-serif);
}
.cp-map-legend {
  padding: 8px 12px 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 200px;
  overflow-y: auto;
}
.cp-map-legend-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
}
.cp-map-num {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--cp-red, #C41230);
  color: #fff;
  font-weight: 800;
  font-size: 9px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cp-map-num.cp-hot { background: var(--cp-q-hot, #15803D); }
.cp-map-legend-name {
  flex: 1;
  font-weight: 700;
  color: var(--ink, #0A0A0A);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cp-map-legend-suburb {
  color: var(--s400, #A8A29E);
  font-weight: 600;
  font-size: 10px;
}

/* Cluster lead list (rail) */
.cp-cl-list {
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cp-cl-lead {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 9px;
  cursor: pointer;
  transition: background 180ms cubic-bezier(.4,0,.2,1);
}
.cp-cl-lead:hover { background: var(--s100, #F5F5F4); }
.cp-cl-num {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--s200, #E7E5E4);
  color: var(--s700, #44403C);
  font-weight: 800;
  font-size: 10.5px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cp-cl-num.cp-hot { background: var(--cp-q-hot, #15803D); color: #fff; }
.cp-cl-lead-body { flex: 1; min-width: 0; }
.cp-cl-lead-name {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--ink, #0A0A0A);
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.cp-cl-qual {
  font-size: 8.5px;
  font-weight: 800;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 1px 6px;
  border-radius: 4px;
}
.cp-cl-qual-hot  { background: #DCFCE7; color: #15803D; }
.cp-cl-qual-warm { background: #FEF3C7; color: #D97706; }
.cp-cl-qual-cold { background: var(--s100, #F5F5F4); color: var(--s500, #78716C); }
.cp-cl-lead-meta {
  font-size: 10.5px;
  color: var(--s500, #78716C);
  font-weight: 600;
  margin-top: 2px;
}
.cp-cl-lead-meta b { color: var(--s700, #44403C); font-weight: 700; }

/* Week grid (Mon-Sun) */
.cp-week {
  display: flex;
  flex-direction: column;
}
.cp-week-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 10px;
}
@media (max-width: 1340px) { .cp-week-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 900px)  { .cp-week-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .cp-week-grid { grid-template-columns: 1fr; } }

.cp-day {
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 12px;
  padding: 12px;
  box-shadow: var(--shadow-rest);
  display: flex;
  flex-direction: column;
  min-height: 240px;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
}
.cp-day:hover {
  border-color: var(--s300, #D6D3D1);
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px);
}
.cp-day-weekend { background: var(--s50, #FAFAF9); }
.cp-day-empty { min-height: 160px; }
.cp-day-today {
  border-color: var(--cp-red, #C41230);
  box-shadow: 0 0 0 2px rgba(196,18,48,.08), var(--shadow-rest);
}
.cp-day-today .cp-day-dom { color: var(--cp-red, #C41230); }

.cp-day-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.cp-day-date {
  display: flex;
  align-items: baseline;
  gap: 5px;
}
.cp-day-dow {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--s400, #A8A29E);
}
.cp-day-dom {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--ink, #0A0A0A);
  line-height: 1;
}
.cp-day-mon {
  font-size: 11px;
  font-weight: 700;
  color: var(--s500, #78716C);
}
.cp-day-flag {
  font-size: 8.5px;
  font-weight: 800;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--pale-red, #FBF3F4);
  color: var(--cp-red, #C41230);
}

.cp-day-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cp-day-empty-msg {
  font-size: 11px;
  color: var(--s400, #A8A29E);
  font-style: italic;
  font-weight: 500;
  text-align: center;
  padding: 20px 0;
}

/* Appointment row inside a day card */
.cp-apt {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 9px;
  background: var(--s50, #FAFAF9);
  border: 1px solid var(--s100, #F5F5F4);
  border-radius: 8px;
  transition: background 180ms cubic-bezier(.4,0,.2,1);
}
.cp-apt:hover { background: #fff; box-shadow: var(--shadow-rest); }
.cp-apt-suggested {
  background: var(--pale-red, #FBF3F4);
  border-color: rgba(196,18,48,.18);
  border-style: dashed;
}
.cp-apt-suggested:hover { background: #fff; border-style: solid; }
.cp-apt-time {
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--ink, #0A0A0A);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  min-width: 38px;
  display: flex;
  flex-direction: column;
}
.cp-apt-time-end {
  font-size: 9px;
  color: var(--s400, #A8A29E);
  font-weight: 600;
  letter-spacing: 0;
}
.cp-apt-body {
  flex: 1;
  min-width: 0;
}
.cp-apt-client {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--ink, #0A0A0A);
  display: flex;
  align-items: center;
  gap: 5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cp-hot-badge {
  font-size: 8px;
  font-weight: 800;
  letter-spacing: 0.10em;
  padding: 1px 4px;
  background: var(--cp-q-hot, #15803D);
  color: #fff;
  border-radius: 3px;
}
.cp-apt-meta {
  font-size: 10px;
  color: var(--s500, #78716C);
  font-weight: 600;
  margin-top: 1px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cp-apt-status {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px 6px;
  background: #DCFCE7;
  color: #15803D;
  border-radius: 4px;
}
.cp-book-btn {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 4px 8px;
  background: var(--cp-red, #C41230);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  font-family: inherit;
  white-space: nowrap;
}
.cp-book-btn:hover {
  background: #A60F28;
  transform: translateY(-1px);
  box-shadow: 0 2px 6px -2px rgba(196,18,48,.5);
}

/* Gap row between appointments — shows drive + downtime */
.cp-gap {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 12px;
  margin-left: 12px;
}
.cp-gap-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--s300, #D6D3D1);
}
.cp-gap-detail {
  font-size: 10px;
  color: var(--s500, #78716C);
  font-weight: 600;
  letter-spacing: 0.01em;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.cp-gap-downtime {
  color: var(--cp-q-warm, #D97706);
  font-weight: 700;
}

/* Day summary footer */
.cp-day-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px dashed var(--s200, #E7E5E4);
}
.cp-summary-item {
  font-size: 9.5px;
  font-weight: 700;
  color: var(--s600, #57534E);
  padding: 3px 7px;
  background: var(--s100, #F5F5F4);
  border-radius: 5px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  letter-spacing: 0.01em;
}
.cp-summary-item .ico { color: var(--s500, #78716C); }
.cp-summary-down {
  background: var(--warn-bg, #FEF3C7) !important;
  color: var(--warn-fg, #92400E) !important;
}

/* ── Static Maps image (replaces SVG when Google key is set) ─────────────── */
.cp-map-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.cp-map-source {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--s400, #A8A29E);
  margin-left: 8px;
}
.cp-map-keyhint {
  position: absolute;
  left: 8px;
  bottom: 8px;
  right: 8px;
  background: rgba(255, 255, 255, .94);
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 7px;
  padding: 6px 10px;
  font-size: 10.5px;
  color: var(--s700, #44403C);
  font-weight: 600;
  line-height: 1.3;
}
.cp-map-svg-wrap { position: relative; }

/* ── Sequential call queue modal ─────────────────────────────────────────── */
.cp-call-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 10, .55);
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  animation: cp-call-fade-in 180ms cubic-bezier(.4,0,.2,1);
}
@keyframes cp-call-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}
.cp-call-modal {
  width: 420px;
  max-width: calc(100vw - 32px);
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 24px 72px -16px rgba(10, 10, 10, .55);
  overflow: hidden;
  animation: cp-call-slide-up 220ms cubic-bezier(.4,0,.2,1);
}
@keyframes cp-call-slide-up {
  from { transform: translateY(20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.cp-call-modal-h {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px 10px;
  border-bottom: 1px solid var(--s100, #F5F5F4);
}
.cp-call-eyebrow {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--s500, #78716C);
}
.cp-call-close {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: none;
  border: 1px solid var(--s200, #E7E5E4);
  color: var(--s500, #78716C);
  font-size: 18px;
  font-weight: 400;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  padding: 0;
  font-family: inherit;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
}
.cp-call-close:hover { background: var(--s100, #F5F5F4); color: var(--ink, #0A0A0A); }
.cp-call-progress {
  height: 3px;
  background: var(--s100, #F5F5F4);
}
.cp-call-progress-fill {
  height: 100%;
  background: var(--cp-red, #C41230);
  transition: width 220ms cubic-bezier(.4,0,.2,1);
}
.cp-call-body {
  padding: 22px 24px 18px;
  text-align: center;
}
.cp-call-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--ink, #0A0A0A);
  color: #fff;
  font-weight: 800;
  font-size: 22px;
  letter-spacing: -0.01em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}
.cp-call-avatar.is-hot {
  background: var(--cp-q-hot, #15803D);
  box-shadow: 0 0 0 4px rgba(21,128,61,.12);
}
.cp-call-name {
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.015em;
  color: var(--ink, #0A0A0A);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}
.cp-call-qual {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: 5px;
}
.cp-call-phone {
  font-size: 14px;
  font-weight: 700;
  color: var(--s700, #44403C);
  font-variant-numeric: tabular-nums;
  margin-top: 8px;
  letter-spacing: -0.005em;
}
.cp-call-brief {
  font-size: 12px;
  color: var(--s500, #78716C);
  margin-top: 6px;
  font-weight: 600;
  line-height: 1.4;
}
.cp-call-brief b { color: var(--s700, #44403C); font-weight: 700; }
.cp-call-actions {
  padding: 14px 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cp-call-btn {
  padding: 11px 16px;
  border-radius: 10px;
  font-size: 13.5px;
  font-weight: 700;
  letter-spacing: -0.005em;
  cursor: pointer;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  font-family: inherit;
  border: 1px solid transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.cp-call-btn-primary {
  background: var(--cp-red, #C41230);
  color: #fff;
  box-shadow: 0 4px 12px -4px rgba(196,18,48,.5);
}
.cp-call-btn-primary:hover:not(:disabled) {
  background: #A60F28;
  transform: translateY(-1px);
  box-shadow: 0 8px 20px -6px rgba(196,18,48,.6);
}
.cp-call-btn-skip {
  background: #fff;
  color: var(--s700, #44403C);
  border-color: var(--s200, #E7E5E4);
}
.cp-call-btn-skip:hover {
  border-color: var(--ink, #0A0A0A);
  color: var(--ink, #0A0A0A);
}
.cp-call-btn-end {
  background: none;
  color: var(--s500, #78716C);
  font-size: 12px;
  padding: 8px 16px;
}
.cp-call-btn-end:hover { color: var(--red, #C41230); }
@media (prefers-reduced-motion: reduce) {
  .cp-call-overlay, .cp-call-modal { animation: none; }
}

/* ══════════════════════════════════════════════════════════════════════════
   WIP-UI-CLUSTER-WIRE-01 — Inline notes panel + booking modal + email preview
   Classes are cw-* prefixed (cluster-wire) to keep the existing cp-* call
   queue + leads `ll-*` namespaces clean.
   ══════════════════════════════════════════════════════════════════════════ */

/* Inline notes panel on each day card — collapsed by default */
.cw-notes-card {
  margin-top: 10px;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 10px;
  background: var(--s50, #FAFAF9);
  overflow: hidden;
  transition: border-color 180ms cubic-bezier(.4,0,.2,1);
}
.cw-notes-card.cw-open { background: #fff; border-color: var(--s300, #D6D3D1); }
.cw-notes-h {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  cursor: pointer;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--s500, #78716C);
}
.cw-notes-card.cw-open .cw-notes-h { border-bottom: 1px solid var(--s100, #F5F5F4); color: var(--ink, #0A0A0A); }
.cw-notes-h-l { display: inline-flex; align-items: center; gap: 8px; }
.cw-notes-count {
  font-size: 9.5px;
  font-weight: 800;
  padding: 1px 6px;
  border-radius: 4px;
  background: var(--s200, #E7E5E4);
  color: var(--s700, #44403C);
  letter-spacing: 0.04em;
}
.cw-notes-card.cw-open .cw-notes-count { background: var(--ink, #0A0A0A); color: #fff; }
.cw-notes-chev {
  width: 14px;
  height: 14px;
  color: var(--s400, #A8A29E);
  transition: transform 180ms cubic-bezier(.4,0,.2,1);
}
.cw-notes-card.cw-open .cw-notes-chev { transform: rotate(180deg); color: var(--ink, #0A0A0A); }
.cw-notes-body {
  display: none;
  padding: 11px 12px 12px;
}
.cw-notes-card.cw-open .cw-notes-body { display: block; }
.cw-notes-list {
  display: flex;
  flex-direction: column;
  gap: 7px;
  max-height: 160px;
  overflow-y: auto;
  padding-right: 4px;
  margin-bottom: 10px;
}
.cw-notes-empty {
  font-size: 11px;
  color: var(--s400, #A8A29E);
  font-style: italic;
  font-weight: 500;
  padding: 6px 0;
}
.cw-note {
  padding: 8px 11px;
  background: var(--s50, #FAFAF9);
  border-radius: 7px;
  border-left: 2px solid var(--s300, #D6D3D1);
  transition: background 180ms cubic-bezier(.4,0,.2,1);
}
.cw-note:hover {
  background: #fff;
  box-shadow: var(--shadow-rest, 0 1px 2px rgba(10,10,10,.03));
}
.cw-note.cw-fresh {
  border-left-color: var(--red, #C41230);
  background: var(--pale-red, #FBF3F4);
}
.cw-note.cw-system { border-left-color: var(--s400, #A8A29E); }
.cw-note.cw-call   { border-left-color: var(--red, #C41230); }
.cw-note.cw-inbound{ border-left-color: var(--info-fg, #1D4ED8); background: var(--info-bg, #DBEAFE); }
.cw-note-h {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4px;
  gap: 8px;
}
.cw-note-author {
  font-size: 10px;
  font-weight: 800;
  color: var(--ink, #0A0A0A);
  letter-spacing: 0.04em;
}
.cw-note-kind {
  font-size: 8.5px;
  font-weight: 800;
  letter-spacing: 0.12em;
  padding: 1px 5px;
  border-radius: 4px;
  text-transform: uppercase;
  background: var(--s200, #E7E5E4);
  color: var(--s600, #57534E);
  margin-left: 6px;
}
.cw-note.cw-call .cw-note-kind   { background: var(--pale-red, #FBF3F4); color: var(--red, #C41230); }
.cw-note.cw-system .cw-note-kind { background: var(--s200, #E7E5E4); color: var(--s600, #57534E); }
.cw-note.cw-inbound .cw-note-kind{ background: #BAE6FD; color: var(--info-fg, #1D4ED8); }
.cw-note-time {
  font-size: 9.5px;
  color: var(--s400, #A8A29E);
  font-weight: 600;
  letter-spacing: 0.02em;
}
.cw-note-body {
  font-size: 11.5px;
  color: var(--s700, #44403C);
  line-height: 1.5;
  font-weight: 500;
  white-space: pre-wrap;
}

.cw-notes-input-row {
  display: flex;
  gap: 7px;
  align-items: flex-start;
}
.cw-notes-input {
  flex: 1;
  background: var(--s50, #FAFAF9);
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 8px;
  padding: 8px 11px;
  font-size: 12px;
  line-height: 1.4;
  min-height: 38px;
  color: var(--ink, #0A0A0A);
  resize: vertical;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
  font-family: inherit;
}
.cw-notes-input:focus {
  outline: none;
  background: #fff;
  border-color: var(--ink, #0A0A0A);
  box-shadow: 0 0 0 3px rgba(10,10,10,.05);
}
.cw-notes-input::placeholder { color: var(--s400, #A8A29E); }
.cw-notes-savestate {
  font-size: 10px;
  font-weight: 700;
  margin-top: 6px;
  letter-spacing: 0.02em;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.cw-notes-savestate.cw-saving { color: var(--s500, #78716C); }
.cw-notes-savestate.cw-saved  { color: var(--q-hot, #15803D); }
.cw-notes-savestate.cw-failed { color: var(--red, #C41230); }
.cw-notes-savestate .cw-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.cw-notes-savestate.cw-saving .cw-dot { animation: pulse-hot-dot 1s infinite; }

/* ── Booking modal ────────────────────────────────────────────────────── */
.cw-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 10, .55);
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  padding: 32px;
  animation: cw-modal-in 200ms cubic-bezier(.4,0,.2,1);
}
@keyframes cw-modal-in { from { opacity: 0; } to { opacity: 1; } }
.cw-modal {
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 24px 72px -16px rgba(10, 10, 10, .55);
  width: 920px;
  max-width: 100%;
  max-height: calc(100vh - 64px);
  overflow: hidden;
  display: grid;
  grid-template-columns: 540px 1fr;
  animation: cw-modal-slide 220ms cubic-bezier(.4,0,.2,1);
}
@media (max-width: 900px) { .cw-modal { grid-template-columns: 1fr; } }
@keyframes cw-modal-slide { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.cw-modal-form {
  padding: 20px 22px 22px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 14px;
  border-right: 1px solid var(--s100, #F5F5F4);
}
.cw-modal-h {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--s100, #F5F5F4);
}
.cw-modal-eyebrow {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--s400, #A8A29E);
}
.cw-modal-title {
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--ink, #0A0A0A);
  margin-top: 4px;
}
.cw-modal-close {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: none;
  border: 1px solid var(--s200, #E7E5E4);
  color: var(--s500, #78716C);
  font-size: 18px;
  font-weight: 400;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: inherit;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
}
.cw-modal-close:hover { background: var(--s100, #F5F5F4); color: var(--ink, #0A0A0A); }

.cw-field { display: flex; flex-direction: column; gap: 5px; }
.cw-field-lbl {
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--s500, #78716C);
}
.cw-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.cw-field-row.cw-three { grid-template-columns: 1fr 1fr 1fr; }
.cw-input,
.cw-modal select,
.cw-modal textarea {
  padding: 9px 11px;
  background: #fff;
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink, #0A0A0A);
  font-family: inherit;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
}
.cw-modal textarea { resize: vertical; min-height: 60px; line-height: 1.4; }
.cw-input:focus,
.cw-modal select:focus,
.cw-modal textarea:focus {
  outline: none;
  border-color: var(--ink, #0A0A0A);
  box-shadow: 0 0 0 3px rgba(10,10,10,.05);
}
.cw-title-preview {
  padding: 11px 12px;
  background: var(--s50, #FAFAF9);
  border: 1px dashed var(--s300, #D6D3D1);
  border-radius: 9px;
  font-size: 12px;
  font-weight: 700;
  color: var(--ink, #0A0A0A);
  letter-spacing: -0.005em;
}
.cw-title-preview .cw-title-lbl {
  display: block;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--s400, #A8A29E);
  margin-bottom: 4px;
}

.cw-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--s50, #FAFAF9);
  border: 1px solid var(--s200, #E7E5E4);
  border-radius: 9px;
  cursor: pointer;
  transition: all 180ms cubic-bezier(.4,0,.2,1);
}
.cw-toggle:hover { background: #fff; border-color: var(--s300, #D6D3D1); }
.cw-toggle.cw-on {
  background: #fff;
  border-color: var(--ink, #0A0A0A);
  box-shadow: 0 0 0 1px var(--ink, #0A0A0A);
}
.cw-toggle input { margin: 0; cursor: pointer; }
.cw-toggle-l { flex: 1; min-width: 0; }
.cw-toggle-title {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--ink, #0A0A0A);
  letter-spacing: -0.005em;
}
.cw-toggle-sub {
  font-size: 10.5px;
  color: var(--s500, #78716C);
  font-weight: 600;
  margin-top: 2px;
}
.cw-toggle:has(input:disabled) {
  opacity: .55;
  cursor: not-allowed;
}

.cw-conflict {
  padding: 10px 12px;
  border-radius: 9px;
  font-size: 12px;
  font-weight: 700;
  display: flex;
  align-items: flex-start;
  gap: 8px;
  line-height: 1.4;
}
.cw-conflict.cw-none {
  background: var(--ok-bg, #DCFCE7);
  color: var(--ok-fg, #15803D);
  box-shadow: inset 0 0 0 1px var(--ok-border, rgba(21,128,61,.18));
}
.cw-conflict.cw-soft {
  background: var(--warn-bg, #FEF3C7);
  color: var(--warn-fg, #92400E);
  box-shadow: inset 0 0 0 1px var(--warn-border, rgba(146,64,14,.18));
}
.cw-conflict.cw-hard {
  background: var(--pale-red, #FBF3F4);
  color: var(--red, #C41230);
  box-shadow: inset 0 0 0 1px rgba(196,18,48,.25);
}
.cw-conflict .ico { flex-shrink: 0; margin-top: 1px; }

.cw-modal-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
  padding-top: 14px;
  border-top: 1px solid var(--s100, #F5F5F4);
}
.cw-modal-actions .btn { flex: 1; justify-content: center; }
.cw-modal-actions .cw-cancel { flex: 0 0 auto; padding: 10px 14px; }

/* Email preview pane (right side of the modal) */
.cw-preview {
  background: var(--s50, #FAFAF9);
  display: flex;
  flex-direction: column;
}
.cw-preview-h {
  padding: 14px 18px;
  border-bottom: 1px solid var(--s200, #E7E5E4);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #fff;
}
.cw-preview-title {
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--s500, #78716C);
}
.cw-preview-body {
  padding: 18px;
  overflow-y: auto;
  flex: 1;
}
.cw-preview-subject {
  font-size: 13px;
  font-weight: 800;
  color: var(--ink, #0A0A0A);
  padding-bottom: 10px;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--s200, #E7E5E4);
  letter-spacing: -0.005em;
}
.cw-preview-email {
  background: #fff;
  padding: 22px 24px;
  border-radius: 10px;
  border: 1px solid var(--s200, #E7E5E4);
  font-size: 12.5px;
  color: var(--s900, #1C1917);
  line-height: 1.6;
}
.cw-preview-email h2 {
  font-size: 14px;
  font-weight: 800;
  color: var(--ink, #0A0A0A);
  margin: 14px 0 8px;
  letter-spacing: -0.01em;
}
.cw-preview-email p { margin: 0 0 11px; }
.cw-preview-email ul { margin: 8px 0 14px; padding-left: 18px; }
.cw-preview-email li { margin-bottom: 8px; }
.cw-preview-email a { color: var(--info-fg, #1D4ED8); text-decoration: underline; }
.cw-preview-error {
  padding: 12px;
  background: var(--pale-red, #FBF3F4);
  color: var(--red, #C41230);
  border-radius: 8px;
  font-size: 11.5px;
  font-weight: 700;
  border: 1px solid rgba(196,18,48,.2);
}

@media (prefers-reduced-motion: reduce) {
  .cw-modal-overlay, .cw-modal { animation: none; }
}
