/* ─────────────────────────────────────────────
   Cadence Tracker — design tokens + wizard chrome
   Adapted from the SalesHQ Light cadence-wizard design system
   (paper / ink / red editorial theme).
   ───────────────────────────────────────────── */

:root {
  --paper: #FFFFFF;
  --paper-2: #F7F6F4;
  --paper-3: #EEEDEA;
  --ink: #15171C;
  --ink-2: #22252D;
  --ink-3: #3A3E48;
  --muted: #6A6E78;
  --muted-2: #8E929B;
  --hair: #E8E7E3;
  --hair-2: #D5D3CE;

  --red: #C81E1E;
  --red-deep: #9E1717;
  --red-soft: #FBEAEA;
  --sage: #3F8F5F;
  --sage-soft: #EAF5EE;
  --amber: #B8860B;
  --amber-soft: #FBF3E1;
  --amber-border: #E4C878;
  --sky: #2B6CB0;
  --violet: #7C3AED;
  --teal: #0E9488;

  --f-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", "Inter Tight", Roboto, "Helvetica Neue", Arial, sans-serif;
  --f-mono: ui-monospace, "JetBrains Mono", "SF Mono", Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  --f-serif: ui-serif, "Source Serif 4", Georgia, "Times New Roman", serif;
}

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0; min-height: 100%;
  background: var(--paper-2); color: var(--ink);
  font-family: var(--f-ui);
}

/* ─── Page shell ─── */
.bp-main { max-width: 1120px; margin: 0 auto; padding: 32px 24px 80px; }

.bp-page-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  padding-bottom: 20px; margin-bottom: 22px;
  border-bottom: 1px solid var(--hair); gap: 16px; flex-wrap: wrap;
}
.bp-page-title {
  font-family: var(--f-serif); font-weight: 600;
  font-size: 28px; letter-spacing: -0.02em; color: var(--ink); margin: 0;
}
.bp-page-sub { font-size: 13px; color: var(--muted); margin-top: 4px; }
.bp-page-actions { display: flex; gap: 8px; }

/* ─── Buttons ─── */
.bp-btn {
  height: 34px; padding: 0 14px; border-radius: 6px;
  border: 1px solid var(--hair-2); background: var(--paper);
  color: var(--ink); font: inherit; font-size: 13px; font-weight: 500;
  display: inline-flex; align-items: center; gap: 7px;
  cursor: pointer; transition: background .15s, border-color .15s;
}
.bp-btn:hover { background: var(--paper-2); }
.bp-btn.bp-btn-dark { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.bp-btn.bp-btn-dark:hover { background: var(--ink-2); }
.bp-btn.bp-btn-red { background: var(--red); color: #fff; border-color: var(--red-deep); }
.bp-btn.bp-btn-red:hover { background: var(--red-deep); }
.bp-btn.bp-btn-ghost { border-color: transparent; background: transparent; }
.bp-btn.bp-btn-ghost:hover { background: var(--paper-3); }
.bp-btn.bp-btn-sm { height: 26px; padding: 0 10px; font-size: 12px; }
.bp-btn:disabled { opacity: .45; cursor: not-allowed; }
.bp-btn svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 1.8; flex-shrink: 0; }

/* ─── KPI strip ─── */
.bp-kpi-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  border: 1px solid var(--hair); border-radius: 8px; overflow: hidden;
  background: var(--paper); margin-bottom: 24px;
}
.bp-kpi { padding: 15px 18px; border-right: 1px solid var(--hair); }
.bp-kpi:last-child { border-right: none; }
.bp-kpi-label {
  font-family: var(--f-mono); font-size: 9.5px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--muted-2); font-weight: 500;
}
.bp-kpi-value {
  font-family: var(--f-mono); font-size: 24px; font-weight: 500;
  letter-spacing: -0.02em; color: var(--ink); line-height: 1.3; margin-top: 4px;
}

/* ─── Cards ─── */
.bp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: start; }
@media (max-width: 860px) { .bp-grid { grid-template-columns: 1fr; } }

.bp-card { background: var(--paper); border: 1px solid var(--hair); border-radius: 8px; overflow: hidden; margin-bottom: 20px; }
.bp-card-hd {
  display: flex; align-items: center; gap: 10px; padding: 13px 16px;
  border-bottom: 1px solid var(--hair);
}
.bp-card-title { font-size: 14px; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; }
.bp-card-sub { font-size: 11.5px; color: var(--muted); margin-left: auto; }
.bp-card-body { padding: 6px 8px; }
.bp-card-empty { padding: 26px 16px; text-align: center; color: var(--muted); font-size: 13px; }

/* ─── Task list ─── */
.ct-task {
  display: flex; align-items: flex-start; gap: 11px; padding: 11px 10px;
  border-radius: 6px;
}
.ct-task:hover { background: var(--paper-2); }
.ct-task-check {
  width: 19px; height: 19px; border-radius: 5px; border: 1.5px solid var(--hair-2);
  background: var(--paper); flex-shrink: 0; margin-top: 1px; cursor: pointer;
  display: grid; place-items: center; transition: background .12s, border-color .12s;
}
.ct-task-check.done { background: var(--sage); border-color: var(--sage); }
.ct-task-check svg { width: 11px; height: 11px; stroke: #fff; fill: none; stroke-width: 2.6; opacity: 0; }
.ct-task-check.done svg { opacity: 1; }
.ct-task-main { flex: 1; min-width: 0; }
.ct-task-text { font-size: 13.5px; color: var(--ink); line-height: 1.4; }
.ct-task.done .ct-task-text { color: var(--muted); text-decoration: line-through; }
.ct-task-meta { display: flex; gap: 6px; margin-top: 4px; }
.ct-task-del, .ct-icon-btn {
  width: 24px; height: 24px; border-radius: 5px; border: none; background: transparent;
  color: var(--muted-2); cursor: pointer; display: grid; place-items: center; flex-shrink: 0;
}
.ct-task-del:hover, .ct-icon-btn:hover { background: var(--red-soft); color: var(--red-deep); }
.ct-task-del svg, .ct-icon-btn svg { width: 13px; height: 13px; stroke: currentColor; fill: none; stroke-width: 1.8; }

/* ─── Pills / badges ─── */
.bp-pill {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: var(--f-mono); font-size: 10px; font-weight: 500; letter-spacing: 0.02em;
  padding: 2px 7px; border-radius: 999px;
  background: var(--paper-2); color: var(--ink-3); border: 1px solid var(--hair);
  white-space: nowrap;
}
.bp-pill.red { background: var(--red-soft); color: var(--red-deep); border-color: transparent; }
.bp-pill.sage { background: var(--sage-soft); color: var(--sage); border-color: transparent; }
.bp-pill.amber { background: var(--amber-soft); color: var(--amber); border-color: transparent; }

.cw-renewal-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 11px 5px 8px; border-radius: 999px;
  border: 1px solid var(--amber-border); background: var(--amber-soft); color: #8A6A16;
  font-family: var(--f-mono); font-size: 10.5px; font-weight: 700; letter-spacing: 0.04em;
}
.cw-renewal-badge.past { border-color: var(--hair-2); background: var(--paper-3); color: var(--muted); }
.cw-renewal-badge svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2; }

/* ─── Prospect / cadence cards (landing page) ─── */
.ct-prospect { display: flex; align-items: center; gap: 12px; padding: 12px 12px; border-radius: 6px; cursor: pointer; }
.ct-prospect:hover { background: var(--paper-2); }
.ct-prospect + .ct-prospect { border-top: 1px solid var(--hair); }
.ct-prospect-av {
  width: 36px; height: 36px; border-radius: 50%; background: var(--ink); color: #fff;
  display: grid; place-items: center; font-size: 13px; font-weight: 600; letter-spacing: -0.02em; flex-shrink: 0;
}
.ct-prospect-main { flex: 1; min-width: 0; }
.ct-prospect-name { font-size: 13.5px; font-weight: 600; color: var(--ink); }
.ct-prospect-sub { font-size: 11.5px; color: var(--muted); margin-top: 2px; }
.ct-prospect-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

/* ─── Activity feed ─── */
.ct-activity { padding: 11px 12px; border-radius: 6px; }
.ct-activity:hover { background: var(--paper-2); }
.ct-activity + .ct-activity { border-top: 1px solid var(--hair); }
.ct-activity-top { display: flex; align-items: center; gap: 8px; }
.ct-activity-who { font-size: 13px; font-weight: 600; color: var(--ink); }
.ct-activity-ts { margin-left: auto; font-family: var(--f-mono); font-size: 10.5px; color: var(--muted); white-space: nowrap; }
.ct-activity-step { font-size: 12px; color: var(--muted); margin-top: 3px; }
.ct-activity-notes { font-size: 12px; color: var(--ink-3); margin-top: 3px; line-height: 1.4; }

/* ─── Access gate ─── */
.ct-gate {
  position: fixed; inset: 0; z-index: 200;
  background: var(--paper-2); display: grid; place-items: center; padding: 20px;
}
.ct-gate-card {
  width: 340px; max-width: 100%; text-align: center;
  background: var(--paper); border: 1px solid var(--hair); border-radius: 12px;
  padding: 28px 26px; box-shadow: 0 20px 60px rgba(8,12,22,0.12);
}
.ct-gate-title { font-family: var(--f-serif); font-weight: 600; font-size: 20px; color: var(--ink); margin: 0 0 6px; }
.ct-gate-sub { font-size: 12.5px; color: var(--muted); margin: 0 0 16px; line-height: 1.5; }
.ct-gate-error { font-size: 12px; color: var(--red-deep); margin-top: 10px; min-height: 14px; }
.ct-gate-tabs { display: flex; gap: 4px; padding: 3px; border-radius: 7px; background: var(--paper-2); border: 1px solid var(--hair); margin-bottom: 16px; }
.ct-gate-tab {
  flex: 1; height: 30px; border: none; border-radius: 5px; background: transparent;
  font: inherit; font-size: 12.5px; font-weight: 600; color: var(--muted); cursor: pointer;
}
.ct-gate-tab.sel { background: var(--paper); color: var(--ink); box-shadow: 0 1px 3px rgba(8,12,22,0.1); }
.ct-whoami { font-size: 12px; color: var(--muted); margin-right: 4px; align-self: center; white-space: nowrap; }

/* ─── Workspace switcher ─── */
.ws-row {
  display: flex; align-items: center; gap: 12px; padding: 11px 10px; border-radius: 6px; cursor: pointer;
}
.ws-row:hover { background: var(--paper-2); }
.ws-row + .ws-row { border-top: 1px solid var(--hair); }
.ws-row-av {
  width: 34px; height: 34px; border-radius: 8px; background: var(--paper-2); border: 1px solid var(--hair);
  display: grid; place-items: center; font-size: 12px; font-weight: 600; color: var(--ink-2); flex-shrink: 0;
}
.ws-row.current .ws-row-av { background: var(--ink); color: #fff; border-color: var(--ink); }
.ws-row-main { flex: 1; min-width: 0; }
.ws-row-name { font-size: 13.5px; font-weight: 600; color: var(--ink); }
.ws-row-sub { font-size: 11.5px; color: var(--muted); margin-top: 2px; font-family: var(--f-mono); display: flex; align-items: center; gap: 6px; }
.ws-row-copy {
  border: 1px solid var(--hair-2); background: var(--paper); border-radius: 4px; padding: 1px 6px;
  font-family: var(--f-mono); font-size: 10px; color: var(--ink-3); cursor: pointer;
}
.ws-row-copy:hover { background: var(--paper-2); }

.ws-role-pill {
  display: inline-flex; align-items: center; font-family: var(--f-mono); font-size: 9.5px; font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase; padding: 1px 6px; border-radius: 999px;
  background: var(--paper-3); color: var(--muted); border: 1px solid var(--hair);
}
.ws-role-pill.admin { background: var(--sage-soft); color: var(--sage); border-color: transparent; }
.ws-role-pill.clickable { cursor: pointer; }
.ws-role-pill.clickable:hover { border-color: var(--ink-3); box-shadow: 0 0 0 1px var(--ink-3); }
.ws-role-pill.clickable.admin:hover { box-shadow: 0 0 0 1px var(--sage); }

.ws-member-item + .ws-member-item { border-top: 1px solid var(--hair); }
.ws-member-row { display: flex; align-items: center; gap: 10px; padding: 8px 4px; }
.ws-member-name { font-size: 13px; font-weight: 600; color: var(--ink); flex: 1; min-width: 0; }
.ws-member-remove, .ws-member-action {
  width: 24px; height: 24px; border-radius: 5px; border: none; background: transparent;
  color: var(--muted-2); cursor: pointer; display: grid; place-items: center; flex-shrink: 0;
}
.ws-member-remove:hover { background: var(--red-soft); color: var(--red-deep); }
.ws-member-action:hover { background: var(--sky-soft, var(--paper-3)); color: var(--sky); }
.ws-member-remove svg, .ws-member-action svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 1.8; }
.ws-member-reset-form { display: flex; align-items: center; gap: 8px; padding: 4px 4px 10px; }
.ws-reset-success { font-size: 12px; color: var(--sage); padding: 4px; display: block; }

/* ─── Due today ─── */
.ct-due-row { display: flex; align-items: center; gap: 12px; padding: 11px 12px; cursor: pointer; }
.ct-due-row:hover { background: var(--paper-2); }
.ct-due-row + .ct-due-row { border-top: 1px solid var(--hair); }
.ct-due-main { flex: 1; min-width: 0; }
.ct-due-title { font-size: 13.5px; font-weight: 600; color: var(--ink); }
.ct-due-sub { font-size: 12px; color: var(--muted); margin-top: 2px; }

/* ─── Workspace color dots — same color = same workspace, everywhere ─── */
.ws-dot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.ws-dot-0 { background: var(--red); }
.ws-dot-1 { background: var(--sage); }
.ws-dot-2 { background: var(--sky); }
.ws-dot-3 { background: var(--amber); }
.ws-dot-4 { background: var(--violet); }
.ws-dot-5 { background: var(--teal); }
.ws-row-av .ws-dot { width: 8px; height: 8px; }
#workspace-label { display: inline-flex; align-items: center; gap: 6px; }
.ct-page-ws { display: inline-flex; align-items: center; gap: 5px; }

/* explicit "you're adding this to <workspace>" banner inside wizards */
.cw-ws-banner {
  display: flex; align-items: center; gap: 8px; padding: 9px 26px; margin: -24px -26px 18px;
  background: var(--paper-2); border-bottom: 1px solid var(--hair); font-size: 12px; color: var(--ink-2);
}
.cw-ws-banner b { font-weight: 600; color: var(--ink); }

/* ─── Search ─── */
.ct-search {
  height: 30px; padding: 0 10px; margin: 8px 8px 4px;
  border: 1px solid var(--hair-2); border-radius: 5px; background: var(--paper);
  color: var(--ink); font: inherit; font-size: 12.5px; width: calc(100% - 16px);
}
.ct-search:focus { outline: 2px solid var(--red-soft); outline-offset: -1px; border-color: var(--red-deep); }

/* ═══════════════════════════════════════════
   Wizard modal (cw-*) — ported from SalesHQ Light
   cadence-wizard-preview / "Run cadence" chrome
   ═══════════════════════════════════════════ */
.cw-stage {
  position: fixed; inset: 0; z-index: 100;
  background: radial-gradient(120% 90% at 50% -10%, rgba(15,17,22,0.30), rgba(15,17,22,0.55));
  display: none; place-items: center;
  font-family: var(--f-ui); padding: 20px;
}
.cw-stage.open { display: grid; }

.cw-modal {
  width: 760px; max-width: 100%;
  max-height: calc(100vh - 40px);
  background: var(--paper);
  border: 1px solid var(--hair-2);
  border-radius: 12px;
  box-shadow: 0 32px 90px rgba(8,12,22,0.42), 0 4px 14px rgba(8,12,22,0.18);
  display: flex; flex-direction: column; overflow: hidden;
}

.cw-head { display: flex; align-items: flex-start; gap: 14px; padding: 18px 20px; border-bottom: 1px solid var(--hair); flex-shrink: 0; }
.cw-head-mark {
  width: 34px; height: 34px; border-radius: 8px; background: var(--red); color: #fff;
  display: grid; place-items: center; flex-shrink: 0;
}
.cw-head-mark svg { width: 17px; height: 17px; stroke: #fff; fill: none; stroke-width: 1.6; }
.cw-head-titles { min-width: 0; }
.cw-head-title { font-family: var(--f-serif); font-weight: 600; font-size: 18px; letter-spacing: -0.01em; color: var(--ink); line-height: 1.1; }
.cw-head-sub { font-size: 12px; color: var(--muted); margin-top: 3px; }
.cw-head-sub b { color: var(--ink-2); font-weight: 600; }
.cw-head-badge-row { margin-top: 9px; }
.cw-head-right { margin-left: auto; display: flex; align-items: center; gap: 8px; flex-shrink: 0; padding-top: 1px; }
.cw-step-count { font-family: var(--f-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.02em; white-space: nowrap; }
.cw-close {
  width: 30px; height: 30px; border-radius: 6px; border: 1px solid var(--hair);
  background: var(--paper); color: var(--ink-3); cursor: pointer; display: grid; place-items: center;
}
.cw-close:hover { background: var(--paper-2); color: var(--ink); }
.cw-close svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 1.6; }

.cw-progress { display: flex; align-items: center; gap: 0; padding: 16px 22px; border-bottom: 1px solid var(--hair); flex-shrink: 0; background: var(--paper-2); }
.cw-pstep { display: flex; align-items: center; gap: 10px; }
.cw-pstep-node {
  width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; flex-shrink: 0;
  font-family: var(--f-mono); font-size: 12px; font-weight: 600;
  background: var(--paper-3); color: var(--muted); border: 1px solid var(--hair-2);
}
.cw-pstep.done .cw-pstep-node { background: var(--red); color: #fff; border-color: var(--red-deep); }
.cw-pstep.current .cw-pstep-node { background: var(--ink); color: #fff; border-color: var(--ink); }
.cw-pstep-node svg { width: 12px; height: 12px; stroke: #fff; fill: none; stroke-width: 2.2; }
.cw-pstep-text { line-height: 1.15; }
.cw-pstep-k { font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted-2); }
.cw-pstep-l { font-size: 13px; font-weight: 600; color: var(--ink-3); margin-top: 1px; }
.cw-pstep.current .cw-pstep-l { color: var(--ink); }
.cw-pstep.done .cw-pstep-l { color: var(--ink-2); }
.cw-pconn { flex: 1; height: 2px; background: var(--hair-2); margin: 0 16px; border-radius: 2px; }
.cw-pconn.done { background: var(--red); opacity: 0.45; }

.cw-content { flex: 1; min-height: 0; overflow: auto; padding: 24px 26px; }
.cw-content::-webkit-scrollbar { width: 9px; }
.cw-content::-webkit-scrollbar-thumb { background: var(--hair-2); border-radius: 9px; border: 2px solid var(--paper); }

.cw-step-head { margin-bottom: 16px; }
.cw-step-eyebrow { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--red-deep); font-weight: 600; margin-bottom: 6px; }
.cw-step-title { font-family: var(--f-serif); font-weight: 600; font-size: 21px; letter-spacing: -0.015em; color: var(--ink); margin: 0; line-height: 1.15; }
.cw-step-lede { font-size: 13px; color: var(--muted); margin-top: 6px; max-width: 60ch; line-height: 1.5; }

.cw-foot { display: flex; align-items: center; gap: 12px; padding: 14px 20px; border-top: 1px solid var(--hair); background: var(--paper-2); flex-shrink: 0; }
.cw-foot-hint { font-size: 12px; color: var(--muted); display: flex; align-items: center; gap: 7px; }
.cw-foot-hint svg { width: 13px; height: 13px; stroke: currentColor; fill: none; stroke-width: 1.6; flex-shrink: 0; }
.cw-foot-right { margin-left: auto; display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

/* form fields inside wizard */
.cw-field-row { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.cw-field-row .lab { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted-2); font-weight: 500; }
.bp-input, .bp-select, .bp-textarea {
  width: 100%; padding: 0 10px; border: 1px solid var(--hair-2); border-radius: 5px;
  background: var(--paper); color: var(--ink); font: inherit; font-size: 13.5px;
}
.bp-input, .bp-select { height: 36px; }
.bp-textarea { padding: 9px 10px; min-height: 60px; resize: vertical; line-height: 1.5; }
.bp-input:focus, .bp-select:focus, .bp-textarea:focus { outline: 2px solid var(--red-soft); outline-offset: -1px; border-color: var(--red-deep); }

.cw-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.cw-divider { border: none; border-top: 1px solid var(--hair); margin: 18px 0; }
.cw-toggle-row { display: flex; align-items: center; gap: 9px; cursor: pointer; user-select: none; margin-bottom: 4px; }
.cw-toggle-row input { width: 15px; height: 15px; accent-color: var(--red); }
.cw-toggle-row span { font-size: 12.5px; color: var(--ink-2); font-weight: 500; }

/* option chips */
.cw-opts { display: flex; gap: 8px; flex-wrap: wrap; }
.cw-opt {
  padding: 8px 13px; border: 1px solid var(--hair-2); border-radius: 7px; cursor: pointer;
  font-size: 12.5px; font-weight: 500; color: var(--ink-2); background: var(--paper);
  display: inline-flex; align-items: center; gap: 6px;
}
.cw-opt:hover { border-color: var(--ink-3); }
.cw-opt.sel { border-color: var(--red); background: var(--red-soft); color: var(--red-deep); }
.cw-opt.sm { padding: 5px 10px; font-size: 11.5px; border-radius: 6px; }

/* ── live preview: contact card ── */
.cw-preview-label { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted-2); margin: 22px 0 10px; }
.cw-contact {
  display: flex; align-items: center; gap: 14px; padding: 16px;
  border: 1px solid var(--hair); border-radius: 9px; background: var(--paper);
}
.cw-contact-av {
  width: 46px; height: 46px; border-radius: 50%;
  background: var(--ink); color: #fff; display: grid; place-items: center;
  font-size: 16px; font-weight: 600; letter-spacing: -0.02em; flex-shrink: 0;
}
.cw-contact-name { font-size: 16px; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; }
.cw-contact-meta { font-size: 12px; color: var(--muted); margin-top: 2px; }
.cw-contact-switch { margin-left: auto; display: flex; flex-direction: column; align-items: flex-end; gap: 6px; flex-shrink: 0; }

.cw-intel {
  border: 1px solid var(--hair); border-radius: 10px; overflow: hidden;
  border-left: 3px solid var(--red); margin-top: 16px;
}
.cw-intel-hd {
  display: flex; align-items: center; gap: 10px; padding: 12px 16px;
  background: var(--red-soft); border-bottom: 1px solid var(--hair);
}
.cw-intel-hd .ttl { font-size: 13px; font-weight: 600; color: var(--ink); display: flex; align-items: center; gap: 8px; }
.cw-intel-hd svg { width: 14px; height: 14px; stroke: var(--red-deep); fill: none; stroke-width: 1.6; flex-shrink: 0; }
.cw-intel-out { margin-left: auto; font-family: var(--f-mono); font-size: 12px; font-weight: 600; color: var(--red-deep); white-space: nowrap; }
.cw-intel-body { padding: 16px; }
.cw-field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 18px; }
.cw-field .k { font-family: var(--f-mono); font-size: 9.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted-2); font-weight: 500; display: flex; align-items: center; gap: 5px; }
.cw-field .v { font-size: 13px; color: var(--ink); font-weight: 600; margin-top: 3px; line-height: 1.3; }
.cw-fchk {
  width: 12px; height: 12px; border-radius: 50%; display: inline-grid; place-items: center;
  background: var(--sage-soft); color: var(--sage); font-size: 8px; font-weight: 700; flex-shrink: 0;
}
.cw-fchk.pending { background: var(--amber-soft); color: var(--amber); }

.cw-callout {
  margin-top: 12px; padding: 11px 13px; border-radius: 8px;
  background: var(--amber-soft); border: 1px solid transparent;
  font-size: 12.5px; color: var(--ink-2); display: flex; gap: 9px; align-items: flex-start; line-height: 1.45;
}
.cw-callout svg { width: 15px; height: 15px; flex-shrink: 0; margin-top: 1px; stroke: var(--amber); fill: none; stroke-width: 1.6; }
.cw-callout b { color: var(--ink); }

/* ── touch timeline (Step 2) ── */
.cw-seq { position: relative; }
.cw-seq::before { content: ''; position: absolute; left: 19px; top: 8px; bottom: 30px; width: 2px; background: var(--hair-2); }
.cw-touch {
  position: relative; display: grid; grid-template-columns: 40px 1fr auto; gap: 14px;
  align-items: center; padding: 10px 0;
}
.cw-touch-node {
  width: 40px; height: 40px; border-radius: 50%; z-index: 1;
  display: grid; place-items: center; background: var(--paper);
  border: 2px solid var(--hair-2); color: var(--muted);
}
.cw-touch-node svg { width: 17px; height: 17px; stroke: currentColor; fill: none; stroke-width: 1.5; }
.cw-touch.done .cw-touch-node { border-color: var(--sage); color: #fff; background: var(--sage); }
.cw-touch-card {
  border: 1px solid var(--hair); border-radius: 9px; padding: 11px 14px; background: var(--paper);
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  transition: border-color .12s, box-shadow .12s;
}
.cw-touch.done .cw-touch-card { border-color: color-mix(in oklab, var(--sage) 30%, var(--hair)); background: var(--sage-soft); }
.cw-touch-main { min-width: 0; flex: 1; }
.cw-touch-grip {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2.5px; width: 12px; flex-shrink: 0;
  cursor: grab; padding: 4px; margin: -4px 0; border-radius: 4px;
}
.cw-touch-grip:hover { background: var(--paper-2); }
.cw-touch-grip span { width: 3px; height: 3px; border-radius: 50%; background: var(--muted-2); }
.cw-touch.dragging { opacity: 0.4; }
.cw-touch.drag-over .cw-touch-card { border-color: var(--red); box-shadow: 0 0 0 1px var(--red); }
.cw-touch-title { font-size: 13.5px; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; }
.cw-touch-hint { font-size: 11.5px; color: var(--muted); margin-top: 2px; line-height: 1.4; }
.cw-touch-right { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.cw-touch-date { font-family: var(--f-mono); font-size: 10.5px; color: var(--muted); white-space: nowrap; }
.cw-touch-act {
  height: 26px; padding: 0 9px; border-radius: 6px; border: 1px solid var(--hair); background: var(--paper);
  display: inline-flex; align-items: center; gap: 5px; cursor: pointer; color: var(--ink-2); font-size: 11px; font-weight: 500;
}
.cw-touch-act:hover { background: var(--paper-2); }
.cw-touch-act.primary { background: var(--ink); color: #fff; border-color: var(--ink); }
.cw-touch-act.primary:hover { background: var(--ink-2); }
.cw-touch-act.overdue { background: var(--red-soft); color: var(--red-deep); border-color: transparent; }
.cw-touch-act.due-today { background: var(--amber-soft); color: var(--amber); border-color: var(--amber-border); }
.cw-touch-act svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2; }
.cw-touch-del { width: 26px; height: 26px; border-radius: 6px; border: 1px solid var(--hair); background: var(--paper); display: grid; place-items: center; cursor: pointer; color: var(--muted); flex-shrink: 0; }
.cw-touch-del:hover { background: var(--red-soft); color: var(--red-deep); }
.cw-touch-del svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 1.8; }
.cw-touch-notes-edit { grid-column: 1 / -1; width: 100%; margin-top: 8px; display: flex; gap: 8px; }
.cw-touch-notes-edit textarea { flex: 1; }

.cw-add-touch { margin-top: 10px; padding: 12px 14px; border: 1px dashed var(--hair-2); border-radius: 9px; }
.cw-add-touch-row { display: flex; gap: 8px; margin-top: 8px; }
.cw-add-touch-row input { flex: 1; }

.cw-input-error { border-color: var(--red-deep) !important; animation: cw-shake .3s; }
@keyframes cw-shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-4px); }
  75% { transform: translateX(4px); }
}

/* ═══════════════════════════════════════════
   Due Today module (.dtm-*) — scoped design tokens,
   deliberately separate palette from the rest of the app.
   No Google Fonts: this app already had that removed once
   (ADP corporate networks block fonts.googleapis.com), so
   the "serif" here is a system stack, same policy as --f-serif.
   ═══════════════════════════════════════════ */
.dtm {
  --dtm-cream: #FAF8F3; --dtm-cream-2: #F1EEE5; --dtm-card: #FFFFFF;
  --dtm-navy: #0F1B3C; --dtm-navy-2: #1D2A48; --dtm-navy-3: #34425F;
  --dtm-slate: #6B6658; --dtm-slate-2: #9A9488;
  --dtm-line: rgba(60,60,67,.12); --dtm-line-2: rgba(60,60,67,.18); --dtm-fill: rgba(120,120,128,.08);
  --dtm-red: #DC2626; --dtm-red-ink: #B91C1C; --dtm-red-soft: #FBEBEB;
  --dtm-gold: #B8920A; --dtm-gold-ink: #7A6309; --dtm-gold-soft: #F6EFD7;
  --dtm-sage: #15803D; --dtm-sage-soft: #E5F1E9;
  --dtm-sky: #2563A8; --dtm-sky-soft: #E6EEF7;
  --dtm-amber: #D97706; --dtm-amber-soft: #FBF0E1;
  --dtm-f-serif: ui-serif, Georgia, "Times New Roman", serif;

  background: var(--dtm-cream); border: 1px solid var(--hair); border-radius: 12px;
  padding: 28px 28px 24px; margin-bottom: 20px; font-family: var(--f-ui); color: var(--dtm-navy);
  background-image: radial-gradient(circle at 92% -10%, rgba(184,146,10,.06), transparent 42%);
}
.dtm-ico { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }

.dtm-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 22px; margin-bottom: 22px; flex-wrap: wrap; }
.dtm-eyebrow { font-family: var(--f-mono); font-size: 11px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--dtm-gold-ink); margin-bottom: 8px; }
.dtm-h1 { font-family: var(--dtm-f-serif); font-size: 32px; font-weight: 700; letter-spacing: -.015em; margin: 0; line-height: 1; color: var(--dtm-navy); }
.dtm-subline { font-size: 14px; color: var(--dtm-slate); margin-top: 10px; }
.dtm-subline b { color: var(--dtm-navy); font-weight: 600; }
.dtm-head-r { display: flex; align-items: center; gap: 10px; flex-shrink: 0; flex-wrap: wrap; }

.dtm-seg { display: flex; background: var(--dtm-cream-2); border: 1px solid var(--dtm-line); border-radius: 11px; padding: 3px; gap: 2px; }
.dtm-seg button {
  display: inline-flex; align-items: center; gap: 6px; height: 34px; padding: 0 12px; border-radius: 8px;
  font-size: 12.5px; font-weight: 600; color: var(--dtm-slate); white-space: nowrap; transition: all .15s;
  font-family: inherit; border: none; background: none; cursor: pointer;
}
.dtm-seg button .dtm-ico { width: 14px; height: 14px; }
.dtm-seg button .n { font-family: var(--f-mono); font-size: 10.5px; color: var(--dtm-slate-2); }
.dtm-seg button.on { background: var(--dtm-card); color: var(--dtm-navy); box-shadow: 0 1px 3px rgba(15,27,60,.1); }
.dtm-seg button.on .n { color: var(--dtm-gold-ink); }

.dtm-focusbtn {
  display: inline-flex; align-items: center; gap: 8px; height: 40px; padding: 0 18px; border-radius: 11px;
  background: var(--dtm-navy); color: #fff; font-size: 13.5px; font-weight: 600; box-shadow: 0 8px 18px rgba(15,27,60,.24);
  transition: transform .12s; font-family: inherit; border: none; cursor: pointer;
}
.dtm-focusbtn:hover { transform: translateY(-1px); }
.dtm-focusbtn:active { transform: translateY(0); }
.dtm-focusbtn .dtm-ico { width: 16px; height: 16px; stroke: var(--dtm-gold); }

.dtm-grid { display: grid; grid-template-columns: 1fr 300px; gap: 22px; align-items: start; }

.dtm-empty { padding: 26px 16px; text-align: center; color: var(--dtm-slate); font-size: 13px; background: var(--dtm-card); border: 1px solid var(--dtm-line); border-radius: 16px; }

.dtm-acct { background: var(--dtm-card); border: 1px solid var(--dtm-line); border-radius: 16px; margin-bottom: 14px; overflow: hidden; box-shadow: 0 1px 3px rgba(15,27,60,.04); transition: opacity .3s; }
.dtm-acct.cleared { opacity: .55; }
.dtm-acct-hd { display: flex; align-items: center; gap: 14px; padding: 16px 20px; cursor: pointer; user-select: none; }
.dtm-acct-hd:hover { background: var(--dtm-fill); }
.dtm-av { width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center; flex-shrink: 0; font-family: var(--f-mono); font-size: 13.5px; font-weight: 600; color: #fff; }
.dtm-av.critical { background: var(--dtm-red); } .dtm-av.high { background: var(--dtm-gold); } .dtm-av.standard { background: var(--dtm-navy-3); }
.dtm-acct-idy { min-width: 0; flex: 1; }
.dtm-acct-co { font-size: 16.5px; font-weight: 700; letter-spacing: -.01em; line-height: 1.15; display: flex; align-items: center; gap: 8px; }
.dtm-tierdot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.dtm-tierdot.critical { background: var(--dtm-red); } .dtm-tierdot.high { background: var(--dtm-gold); } .dtm-tierdot.standard { background: var(--dtm-slate-2); }
.dtm-acct-who { font-size: 12.5px; color: var(--dtm-slate); margin-top: 3px; }
.dtm-acct-meta { display: flex; flex-direction: column; align-items: flex-end; gap: 7px; flex-shrink: 0; }
.dtm-renew { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; color: var(--dtm-slate); white-space: nowrap; }
.dtm-renew .dtm-ico { width: 13px; height: 13px; stroke: var(--dtm-slate-2); }
.dtm-renew b { font-family: var(--f-mono); font-weight: 600; color: var(--dtm-navy); }
.dtm-renew.hot b { color: var(--dtm-red-ink); }
.dtm-prog { display: flex; align-items: center; gap: 9px; }
.dtm-prog-track { width: 84px; height: 5px; border-radius: 99px; background: var(--dtm-cream-2); overflow: hidden; }
.dtm-prog-fill { height: 100%; border-radius: 99px; background: linear-gradient(90deg, var(--dtm-gold), var(--dtm-gold-ink)); transition: width .35s cubic-bezier(.4,0,.2,1); }
.dtm-acct.cleared .dtm-prog-fill { background: var(--dtm-sage); }
.dtm-prog-n { font-family: var(--f-mono); font-size: 11px; font-weight: 600; color: var(--dtm-slate); min-width: 26px; text-align: right; }
.dtm-acct-chev {
  margin-left: 2px; color: var(--dtm-slate-2); transition: transform .25s, background .15s, color .15s; flex-shrink: 0;
  display: grid; place-items: center; width: 28px; height: 28px; border-radius: 8px;
}
.dtm-acct-chev:hover { background: rgba(15,27,60,.08); color: var(--dtm-navy); }
.dtm-acct.collapsed .dtm-acct-chev { transform: rotate(-90deg); }
.dtm-acct.collapsed .dtm-steps { display: none; }

.dtm-steps { border-top: 1px solid var(--dtm-line); }
.dtm-acct.cleared .dtm-steps { display: none; }
.dtm-step { display: flex; align-items: center; gap: 13px; padding: 11px 20px 11px 18px; border-bottom: 1px solid var(--dtm-line); transition: background .15s; }
.dtm-step:last-child { border-bottom: none; }
.dtm-step:hover { background: var(--dtm-fill); }
.dtm-step.hiddench { display: none; }
.dtm-chk { width: 22px; height: 22px; border-radius: 50%; border: 2px solid var(--dtm-line-2); flex-shrink: 0; display: grid; place-items: center; transition: all .18s; background: var(--dtm-card); cursor: pointer; padding: 0; }
.dtm-chk:hover { border-color: var(--dtm-gold); }
.dtm-chk .dtm-ico { width: 13px; height: 13px; stroke: #fff; stroke-width: 2.8; opacity: 0; transform: scale(.5); transition: all .18s; }
.dtm-step.done .dtm-chk { background: var(--dtm-sage); border-color: var(--dtm-sage); }
.dtm-step.done .dtm-chk .dtm-ico { opacity: 1; transform: scale(1); }
.dtm-chnl { width: 34px; height: 34px; border-radius: 10px; display: grid; place-items: center; flex-shrink: 0; }
.dtm-chnl .dtm-ico { width: 17px; height: 17px; stroke-width: 1.8; }
.dtm-chnl.Email, .dtm-chnl.LinkedIn { background: var(--dtm-sky-soft); } .dtm-chnl.Email .dtm-ico, .dtm-chnl.LinkedIn .dtm-ico { stroke: var(--dtm-sky); }
.dtm-chnl.Call { background: var(--dtm-sage-soft); } .dtm-chnl.Call .dtm-ico { stroke: var(--dtm-sage); }
.dtm-chnl.Mail, .dtm-chnl.Other { background: var(--dtm-amber-soft); } .dtm-chnl.Mail .dtm-ico, .dtm-chnl.Other .dtm-ico { stroke: var(--dtm-amber); }
.dtm-step-tx { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.dtm-step-name { font-size: 14px; font-weight: 600; color: var(--dtm-navy); line-height: 1.2; }
.dtm-step-ch { font-size: 11.5px; color: var(--dtm-slate-2); margin-top: 2px; font-family: var(--f-mono); letter-spacing: .02em; }
.dtm-step.done .dtm-step-name { color: var(--dtm-slate-2); text-decoration: line-through; text-decoration-color: var(--dtm-line-2); }
.dtm-step.done .dtm-step-ch { opacity: .6; }
.dtm-step-tag { font-size: 10px; font-weight: 600; font-family: var(--f-mono); letter-spacing: .04em; text-transform: uppercase; color: var(--dtm-gold-ink); background: var(--dtm-gold-soft); padding: 3px 8px; border-radius: 6px; flex-shrink: 0; }
.dtm-step.overdue .dtm-step-tag { color: var(--dtm-red-ink); background: var(--dtm-red-soft); }
.dtm-step.done .dtm-step-tag { display: none; }
.dtm-step-act {
  display: inline-flex; align-items: center; gap: 6px; height: 32px; padding: 0 13px; border-radius: 8px;
  border: 1px solid var(--dtm-line-2); background: var(--dtm-card); font-size: 12.5px; font-weight: 600; color: var(--dtm-navy);
  opacity: 0; transition: opacity .15s; flex-shrink: 0; font-family: inherit; cursor: pointer;
}
.dtm-step:hover .dtm-step-act { opacity: 1; }
.dtm-step-act .dtm-ico { width: 14px; height: 14px; }
.dtm-step.done .dtm-step-act { display: none; }

.dtm-acct-clear { display: none; align-items: center; gap: 9px; padding: 13px 20px; font-size: 13px; color: var(--dtm-sage); font-weight: 600; }
.dtm-acct-clear .dtm-ico { width: 16px; height: 16px; stroke: var(--dtm-sage); stroke-width: 2.2; }
.dtm-acct.cleared .dtm-acct-clear { display: flex; }

.dtm-side { position: sticky; top: 20px; display: flex; flex-direction: column; gap: 14px; }
.dtm-panel { background: var(--dtm-card); border: 1px solid var(--dtm-line); border-radius: 16px; padding: 18px; box-shadow: 0 1px 3px rgba(15,27,60,.04); }
.dtm-panel-t { font-family: var(--f-mono); font-size: 10px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--dtm-slate-2); margin-bottom: 15px; }
.dtm-ring-wrap { display: flex; align-items: center; gap: 16px; }
.dtm-ring { position: relative; width: 84px; height: 84px; flex-shrink: 0; }
.dtm-ring svg { transform: rotate(-90deg); width: 84px; height: 84px; }
.dtm-ring-center { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.dtm-ring-center .v { font-family: var(--dtm-f-serif); font-size: 24px; font-weight: 700; line-height: 1; color: var(--dtm-navy); }
.dtm-ring-center .k { font-family: var(--f-mono); font-size: 8.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--dtm-slate-2); margin-top: 3px; }
.dtm-ring-legend { flex: 1; min-width: 0; }
.dtm-ring-legend .big { font-size: 13.5px; font-weight: 600; color: var(--dtm-navy); }
.dtm-ring-legend .small { font-size: 12px; color: var(--dtm-slate); margin-top: 4px; line-height: 1.4; }
.dtm-chbreak { display: flex; flex-direction: column; gap: 2px; }
.dtm-chrow { display: flex; align-items: center; gap: 11px; padding: 10px 0; border-bottom: 1px solid var(--dtm-line); }
.dtm-chrow:last-child { border-bottom: none; }
.dtm-chrow .dtm-chnl { width: 30px; height: 30px; border-radius: 9px; }
.dtm-chrow .dtm-chnl .dtm-ico { width: 15px; height: 15px; }
.dtm-chrow-name { flex: 1; font-size: 13px; font-weight: 500; color: var(--dtm-navy); }
.dtm-chrow-n { font-family: var(--f-mono); font-size: 13px; font-weight: 600; color: var(--dtm-navy); }
.dtm-chrow-n .done { color: var(--dtm-sage); }
.dtm-chrow-n .sep { color: var(--dtm-slate-2); }
.dtm-hint { font-size: 12px; color: var(--dtm-slate); line-height: 1.5; margin-top: 2px; }
.dtm-hint b { color: var(--dtm-navy); }

@media (max-width: 820px) {
  .dtm-grid { grid-template-columns: 1fr; }
  .dtm-side { position: static; flex-direction: row; flex-wrap: wrap; }
  .dtm-panel { flex: 1; min-width: 220px; }
  .dtm-head { flex-direction: column; align-items: flex-start; }
}
@keyframes dtm-flash {
  0% { box-shadow: 0 0 0 3px var(--dtm-gold); }
  100% { box-shadow: 0 1px 3px rgba(15,27,60,.04); }
}
.dtm-acct.flash { animation: dtm-flash .9s; }
@media (prefers-reduced-motion: reduce) { .dtm-acct.flash { animation: none; } }
