/* ═══════════════════════════════════════════════════════════
   DRIP STORYBOARD — Shared follow-up sequence widget styles

   Extracted from sales/agenticagencydemo/index.html. The inline
   <style> block (lines ~2750-3438) was scoped to the sales-page
   design tokens; here we declare local tokens on .drip-root so
   the widget renders identically when dropped on any page.
   ═══════════════════════════════════════════════════════════ */

.drip-root {
  /* Local tokens — match the editorial bureau palette */
  --ds-ink:           #1c1917;
  --ds-ink-soft:      #4a4540;
  --ds-mute:          #8B7B6E;
  --ds-cream:         #fbf6ee;
  --ds-paper:         #fffdf7;
  --ds-surface:       #f4ebd8;
  --ds-hairline:      rgba(28, 25, 23, 0.10);
  --ds-hairline-str:  rgba(28, 25, 23, 0.18);
  --ds-brand:         #5432f5;
  --ds-brand-soft:    #6e54f6;
  --ds-coral:         #E84848;
  --ds-coral-ghost:   rgba(232, 72, 72, 0.12);
  --ds-green:         #2C6E49;
  --ds-green-ghost:   rgba(44, 110, 73, 0.10);

  font-family: 'Inter', 'Poppins', system-ui, sans-serif;
  color: var(--ds-ink);
  line-height: 1.55;
}
.drip-root *, .drip-root *::before, .drip-root *::after { box-sizing: border-box; }

/* ── Intro ──────────────────────────────────────────────────── */
.drip-intro { text-align: center; margin-bottom: 22px; }
.drip-intro-label {
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ds-mute); font-weight: 700; margin-bottom: 6px;
}
.drip-intro-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 22px; font-weight: 600; line-height: 1.3;
  margin: 0 0 6px;
}
.drip-intro-title em { color: var(--ds-coral); font-style: italic; }
.drip-intro-sub {
  font-size: 14px; color: var(--ds-mute); max-width: 460px; margin: 0 auto;
}

/* ── Context strip ──────────────────────────────────────────── */
.drip-context {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  background: var(--ds-paper);
  border-left: 3px solid var(--ds-coral);
  border: 1px solid var(--ds-hairline);
  border-left-width: 3px;
  margin-bottom: 20px;
}
.drip-context-mono {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Playfair Display', Georgia, serif; font-weight: 600;
  font-size: 13px; color: #fff; flex-shrink: 0;
  background: var(--ds-brand);
}
.drip-context-mono.c-1 { background: var(--ds-brand); }
.drip-context-mono.c-2 { background: #2a70c0; }
.drip-context-mono.c-3 { background: #8b6bb8; }
.drip-context-mono.c-4 { background: #3a9f6f; }
.drip-context-mono.c-5 { background: #c97544; }
.drip-context-mono.c-6 { background: #6b6b6b; }
.drip-context-label {
  font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ds-mute); margin-bottom: 2px; font-weight: 700;
}
.drip-context-biz {
  font-family: 'Playfair Display', Georgia, serif; font-weight: 500;
  font-size: 16px; letter-spacing: -0.005em;
}
.drip-context-outcome {
  margin-left: auto;
  font-size: 10px; color: var(--ds-ink-soft);
  letter-spacing: 0.08em; text-align: right;
}
.drip-context-outcome strong { color: var(--ds-coral); font-weight: 700; }
.drip-context-outcome.compliance strong { color: var(--ds-green); }

/* ── Shell ──────────────────────────────────────────────────── */
.drip-shell {
  background: var(--ds-paper);
  border: 1px solid var(--ds-hairline-str);
  padding: 28px 24px 30px;
  position: relative;
  box-shadow:
    10px 10px 0 -2px var(--ds-coral-ghost),
    10px 10px 0 -1px var(--ds-hairline);
}
.drip-shell::before {
  content: ''; position: absolute;
  top: -10px; left: -1px;
  width: 200px; height: 28px;
  background: var(--ds-brand);
  clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 100%, 0 100%);
}
.drip-shell.compliance::before { background: var(--ds-green); }
.drip-shell-tab {
  position: absolute; top: -6px; left: 14px;
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.14em; color: var(--ds-cream); z-index: 2;
}
.drip-header {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 14px; padding-bottom: 18px;
  border-bottom: 1px solid var(--ds-hairline);
  margin-bottom: 26px;
  gap: 20px; flex-wrap: wrap;
}
.drip-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 500; font-size: 20px; letter-spacing: -0.012em;
}
.drip-title em { color: var(--ds-coral); font-style: italic; }
.drip-shell.compliance .drip-title em { color: var(--ds-green); }
.drip-stats {
  display: flex; gap: 18px;
  font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ds-mute); flex-shrink: 0;
}
.drip-stats strong { color: var(--ds-ink); font-weight: 700; }

/* ── Day rail ───────────────────────────────────────────────── */
.drip-rail {
  position: relative; display: grid; gap: 0;
  margin-bottom: 28px; padding: 0 0 8px;
}
.drip-rail::before {
  content: ''; position: absolute;
  top: 17px; left: 22px; right: 22px;
  height: 1.5px;
  background: repeating-linear-gradient(to right, var(--ds-ink) 0 6px, transparent 6px 12px);
  z-index: 1;
}
.drip-node {
  display: flex; flex-direction: column; align-items: center;
  cursor: pointer; position: relative; z-index: 2;
  padding: 0 6px;
  background: none; border: none;
  font-family: inherit; color: inherit;
}
.drip-dot {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--ds-surface);
  border: 1.5px solid var(--ds-hairline-str);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Playfair Display', Georgia, serif; font-weight: 600;
  font-size: 13px; color: var(--ds-ink-soft);
  transition: all 0.2s ease;
  margin-bottom: 10px;
}
.drip-node:hover .drip-dot {
  background: var(--ds-coral-ghost); color: var(--ds-coral);
  transform: scale(1.06);
}
.drip-shell.compliance .drip-node:hover .drip-dot {
  background: var(--ds-green-ghost); color: var(--ds-green);
}
.drip-node.has-event .drip-dot {
  background: var(--ds-brand); color: #fff; border-color: var(--ds-brand);
}
.drip-node.active .drip-dot {
  background: var(--ds-coral); color: var(--ds-cream);
  border-color: var(--ds-coral);
  transform: scale(1.15);
  box-shadow: 0 0 0 4px var(--ds-coral-ghost);
}
.drip-shell.compliance .drip-node.active .drip-dot {
  background: var(--ds-green); border-color: var(--ds-green);
  box-shadow: 0 0 0 4px var(--ds-green-ghost);
}
.drip-day-label {
  font-size: 8px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ds-mute); text-align: center; line-height: 1.3;
}
.drip-node.active .drip-day-label { color: var(--ds-coral); font-weight: 700; }
.drip-shell.compliance .drip-node.active .drip-day-label { color: var(--ds-green); }
.drip-date {
  font-size: 9px; letter-spacing: 0.08em;
  color: var(--ds-ink-soft); margin-top: 2px; font-weight: 500;
}
.drip-dot .ch-icon { width: 16px; height: 16px; display: inline-flex; align-items: center; justify-content: center; }
.drip-dot .ch-icon svg { width: 16px; height: 16px; stroke: currentColor; stroke-width: 1.8; fill: none; }

/* ── Stage ──────────────────────────────────────────────────── */
.drip-stage {
  min-height: 260px; position: relative; margin-bottom: 24px;
}
.drip-empty {
  text-align: center; padding: 40px 20px;
  color: var(--ds-mute); font-style: italic; font-size: 15px;
}
.drip-empty-hint {
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ds-coral); margin-top: 10px; font-style: normal; font-weight: 700;
}
.drip-shell.compliance .drip-empty-hint { color: var(--ds-green); }

/* ── Event card ─────────────────────────────────────────────── */
.drip-event {
  display: grid; grid-template-columns: 56px 1fr;
  gap: 18px; padding: 18px;
  background: var(--ds-surface);
  border: 1px solid var(--ds-hairline-str);
  animation: ds-slide 0.35s ease;
}
@keyframes ds-slide {
  from { opacity: 0; transform: translateX(-10px); }
  to   { opacity: 1; transform: translateX(0); }
}
.drip-event-channel {
  width: 48px; height: 48px;
  border: 1.5px solid var(--ds-hairline-str);
  background: var(--ds-paper);
  display: flex; align-items: center; justify-content: center;
  color: var(--ds-coral);
}
.drip-shell.compliance .drip-event-channel { color: var(--ds-green); }
.drip-event-channel svg { width: 20px; height: 20px; stroke: currentColor; stroke-width: 1.8; fill: none; }
.drip-event-body { min-width: 0; }
.drip-event-meta {
  display: flex; gap: 10px; align-items: center;
  margin-bottom: 8px;
  font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ds-mute); flex-wrap: wrap;
}
.drip-event-time { color: var(--ds-ink); font-weight: 700; }
.drip-event-status {
  padding: 3px 8px;
  background: var(--ds-paper);
  border: 1px solid var(--ds-hairline);
  font-size: 9px;
}
.drip-event-status.delivered { color: var(--ds-ink-soft); }
.drip-event-status.opened    { color: var(--ds-green); border-color: rgba(44,110,73,0.3); }
.drip-event-status.replied   { color: var(--ds-coral); border-color: var(--ds-coral); }
.drip-event-status.logged    { color: var(--ds-green); border-color: rgba(44,110,73,0.3); }
.drip-event-status.scheduled { color: var(--ds-ink-soft); border-color: var(--ds-hairline-str); }
.drip-event-sender {
  font-size: 10px; color: var(--ds-ink-soft);
  letter-spacing: 0.06em; margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px dashed var(--ds-hairline);
}
.drip-event-sender strong { color: var(--ds-ink); font-weight: 700; }
.drip-event-subject {
  font-family: 'Playfair Display', Georgia, serif; font-weight: 500;
  font-size: 17px; letter-spacing: -0.008em;
  line-height: 1.25; margin-bottom: 8px;
}
.drip-event-subject em { color: var(--ds-brand-soft); font-style: italic; }
.drip-event-preview {
  font-size: 14.5px; line-height: 1.5;
  color: var(--ds-ink-soft);
}

/* ── SMS bubble / call outcome / note card ──────────────────── */
.drip-sms-bubble {
  background: var(--ds-paper);
  border: 1px solid var(--ds-hairline);
  padding: 12px 14px;
  font-size: 14px; line-height: 1.45;
  color: var(--ds-ink);
  max-width: 420px;
  position: relative;
  margin-top: 6px;
}
.drip-sms-bubble::before {
  content: 'SMS';
  position: absolute; top: -8px; left: 14px;
  background: var(--ds-surface);
  padding: 0 6px;
  font-size: 9px; letter-spacing: 0.12em;
  color: var(--ds-mute);
}
.drip-call-outcome {
  background: var(--ds-paper);
  border-left: 2px solid var(--ds-coral);
  padding: 12px 14px;
  font-size: 14px; line-height: 1.5; color: var(--ds-ink);
}
.drip-call-outcome-label {
  font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ds-coral); font-weight: 700;
  margin-bottom: 6px;
}
.drip-shell.compliance .drip-call-outcome { border-left-color: var(--ds-green); }
.drip-shell.compliance .drip-call-outcome-label { color: var(--ds-green); }
.drip-note-card {
  font-size: 14px; color: var(--ds-ink-soft);
  padding: 12px 14px;
  background: var(--ds-paper);
  border: 1px dashed var(--ds-hairline);
}
.drip-note-label {
  font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ds-mute); font-weight: 700;
  margin-bottom: 6px;
}

/* ── Controls ───────────────────────────────────────────────── */
.drip-controls {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 18px;
  border-top: 1px solid var(--ds-hairline);
  gap: 14px;
}
.drip-nav { display: flex; gap: 8px; }
.drip-nav-btn {
  padding: 9px 14px;
  background: var(--ds-surface);
  border: 1px solid var(--ds-hairline);
  font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  cursor: pointer; color: var(--ds-ink-soft);
  font-weight: 500;
  font-family: inherit;
}
.drip-nav-btn:hover:not(:disabled) { color: var(--ds-coral); border-color: var(--ds-coral); }
.drip-shell.compliance .drip-nav-btn:hover:not(:disabled) { color: var(--ds-green); border-color: var(--ds-green); }
.drip-nav-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.drip-autoplay {
  padding: 9px 18px;
  background: var(--ds-brand); color: #fff;
  border: 1px solid var(--ds-brand);
  font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  cursor: pointer; font-weight: 700;
  display: inline-flex; align-items: center; gap: 8px;
  font-family: inherit;
  box-shadow: 0 6px 18px rgba(84,50,245,0.28);
}
.drip-autoplay:hover { background: var(--ds-coral); border-color: var(--ds-coral); }
.drip-shell.compliance .drip-autoplay:hover { background: var(--ds-green); border-color: var(--ds-green); }
.drip-autoplay svg { width: 11px; height: 11px; fill: currentColor; }
.drip-progress {
  margin-top: 12px;
  height: 2px;
  background: var(--ds-hairline);
  position: relative;
  display: none;
}
.drip-progress.active { display: block; }
.drip-progress-fill {
  position: absolute; inset: 0;
  background: var(--ds-coral);
  width: 0%;
}
.drip-shell.compliance .drip-progress-fill { background: var(--ds-green); }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 700px) {
  .drip-shell { padding: 22px 16px 24px; }
  .drip-header { flex-direction: column; gap: 8px; align-items: flex-start; }
  .drip-stats { gap: 12px; font-size: 9px; }
  .drip-dot { width: 30px; height: 30px; font-size: 11px; }
  .drip-day-label { font-size: 7px; }
  .drip-date { font-size: 8px; }
  .drip-event { grid-template-columns: 40px 1fr; gap: 12px; padding: 14px; }
  .drip-event-channel { width: 40px; height: 40px; }
  .drip-event-subject { font-size: 15px; }
  .drip-controls { flex-direction: column; align-items: stretch; }
  .drip-autoplay { justify-content: center; }
  .drip-context { flex-wrap: wrap; }
  .drip-context-outcome { margin-left: 0; margin-top: 6px; width: 100%; text-align: left; }
}
