/* ══════════════════════════════════════════════════════════════
   OUTREACH CENTER — Styles
   Uses existing CSS variables from variables.css.
   Matches visual patterns from components.css and views.css.
══════════════════════════════════════════════════════════════ */

/* ── Dashboard strip ── */
.oc-dash{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px;}

/* ── Cost tracker panel ── */
.oc-cost-panel{display:none;margin-bottom:16px;padding:14px 16px;background:var(--s1);border:1px solid rgba(var(--accent-rgb),.1);border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.2);}
.oc-cost-panel.open{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
.oc-cost-toggle{font-size:11px;font-weight:600;color:var(--muted);cursor:pointer;padding:4px 10px;border-radius:6px;border:1px solid var(--border);background:transparent;transition:all .15s;white-space:nowrap;}
.oc-cost-toggle:hover{border-color:rgba(var(--accent-rgb),.3);color:var(--text);}

/* ── Tab bar ── */
.oc-tabs{display:flex;gap:2px;margin-bottom:16px;background:var(--s1);border-radius:10px;padding:3px;border:1px solid rgba(var(--accent-rgb),.08);}
.oc-tab{padding:8px 18px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;border-radius:8px;transition:all .15s;border:none;background:transparent;font-family:inherit;white-space:nowrap;}
.oc-tab:hover{color:var(--text);background:rgba(var(--accent-rgb),.06);}
.oc-tab.active{color:var(--text);background:rgba(var(--accent-rgb),.12);box-shadow:0 1px 4px rgba(0,0,0,.15);}
.oc-tab-body{display:none;}
.oc-tab-body.active{display:block;}

/* ── Campaigns layout ── */
.oc-campaigns{display:grid;grid-template-columns:240px 1fr;gap:16px;min-height:400px;}
@media(max-width:900px){.oc-campaigns{grid-template-columns:1fr;}}

/* ── Campaign list (left panel) ── */
.oc-camp-list{background:var(--s1);border:1px solid rgba(var(--accent-rgb),.1);border-radius:12px;padding:0;overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 260px);}
.oc-camp-list-hdr{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border);}
.oc-camp-list-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-family:'JetBrains Mono',monospace;}
.oc-camp-items{overflow-y:auto;flex:1;padding:4px;}
.oc-camp-item{padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .1s;display:flex;flex-direction:column;gap:4px;border:1px solid transparent;}
.oc-camp-item:hover{background:rgba(var(--accent-rgb),.06);}
.oc-camp-item.active{background:rgba(var(--accent-rgb),.1);border-color:rgba(var(--accent-rgb),.2);}
.oc-camp-item-name{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.oc-camp-item-meta{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--muted);}

/* ── Campaign builder (center panel) ── */
.oc-builder{background:var(--s1);border:1px solid rgba(var(--accent-rgb),.1);border-radius:12px;padding:0;overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 260px);}
.oc-builder-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);gap:10px;}
.oc-builder-body{overflow-y:auto;flex:1;padding:16px;}
.oc-builder-empty{display:flex;align-items:center;justify-content:center;height:300px;color:var(--muted);font-size:13px;}

/* ── Step editor ── */
.oc-steps{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;}
.oc-step{background:var(--s2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;position:relative;}
.oc-step-hdr{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.oc-step-num{width:22px;height:22px;border-radius:6px;background:rgba(var(--accent-rgb),.12);color:var(--accent);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;flex-shrink:0;}
.oc-step-type{font-size:11px;font-weight:600;color:var(--text);flex:1;}
.oc-step-day{font-size:10px;color:var(--muted);font-family:'JetBrains Mono',monospace;}
.oc-step-actions{display:flex;gap:3px;}
.oc-step-btn{width:22px;height:22px;border-radius:5px;border:none;background:transparent;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;transition:all .12s;padding:0;}
.oc-step-btn:hover{background:rgba(var(--accent-rgb),.1);color:var(--text);}
.oc-step-content{margin-top:6px;}
.oc-step-content textarea{width:100%;min-height:60px;background:var(--s3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:11px;padding:8px 10px;font-family:inherit;resize:vertical;}
.oc-step-content textarea:focus{border-color:rgba(var(--accent-rgb),.35);outline:none;}
.oc-step-content label{font-size:10px;color:var(--muted);font-weight:600;margin-bottom:3px;display:block;}
.oc-char-count{font-size:9px;color:var(--muted);text-align:right;font-family:'JetBrains Mono',monospace;margin-top:2px;}
.oc-char-count.warn{color:var(--red);}

/* ── Step type dropdown ── */
.oc-add-step{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;border:1px dashed rgba(var(--accent-rgb),.2);background:transparent;color:var(--muted);cursor:pointer;font-size:11px;font-weight:600;transition:all .15s;width:100%;justify-content:center;}
.oc-add-step:hover{border-color:rgba(var(--accent-rgb),.4);color:var(--text);background:rgba(var(--accent-rgb),.04);}
.oc-step-type-menu{position:absolute;top:100%;left:0;right:0;background:var(--s2);border:1px solid rgba(var(--accent-rgb),.15);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.5);padding:4px;z-index:100;margin-top:4px;}
.oc-step-type-opt{padding:7px 10px;border-radius:6px;cursor:pointer;font-size:11px;color:var(--text);transition:background .1s;display:flex;align-items:center;gap:8px;}
.oc-step-type-opt:hover{background:rgba(var(--accent-rgb),.1);}
.oc-step-type-icon{width:20px;text-align:center;font-size:13px;flex-shrink:0;}

/* ── Campaign settings section ── */
.oc-settings{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);}
.oc-section-title{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-family:'JetBrains Mono',monospace;margin-bottom:10px;}
.oc-field{margin-bottom:12px;}
.oc-field-label{font-size:10px;font-weight:600;color:var(--muted);margin-bottom:4px;display:block;}
.oc-field input[type="text"],
.oc-field input[type="number"],
.oc-field input[type="time"],
.oc-field select{width:100%;padding:7px 10px;background:var(--s3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:11px;font-family:inherit;}
.oc-field input:focus,.oc-field select:focus{border-color:rgba(var(--accent-rgb),.35);outline:none;}
.oc-field-row{display:flex;gap:10px;align-items:center;}
.oc-toggle{display:flex;align-items:center;gap:8px;padding:6px 0;cursor:pointer;font-size:11px;color:var(--text);}
.oc-toggle input[type="checkbox"]{width:14px;height:14px;accent-color:var(--accent);}

/* ── Day buttons ── */
.oc-day-btns{display:flex;gap:3px;flex-wrap:wrap;}
.oc-day-btn{padding:4px 8px;border-radius:5px;font-size:9px;font-weight:700;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--muted);transition:all .12s;font-family:'JetBrains Mono',monospace;}
.oc-day-btn.active{background:rgba(var(--accent-rgb),.15);border-color:rgba(var(--accent-rgb),.3);color:var(--accent);}
.oc-day-btn:hover{border-color:rgba(var(--accent-rgb),.25);}

/* ── Status badges ── */
.oc-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:10px;font-size:9px;font-weight:700;white-space:nowrap;letter-spacing:.02em;}
.oc-badge-dot{width:4px;height:4px;border-radius:50%;background:currentColor;}
.oc-badge-active{background:rgba(var(--accent-rgb),.1);color:var(--accent);border:1px solid rgba(var(--accent-rgb),.25);}
.oc-badge-paused{background:rgba(186,117,23,.1);color:var(--color-amber);border:1px solid rgba(186,117,23,.2);}
.oc-badge-draft{background:rgba(156,163,175,.1);color:var(--muted);border:1px solid rgba(156,163,175,.2);}
.oc-badge-completed{background:rgba(46,204,113,.1);color:var(--color-green);border:1px solid rgba(46,204,113,.25);}
.oc-badge-queued{background:rgba(156,163,175,.08);color:var(--muted);border:1px solid rgba(156,163,175,.15);}
.oc-badge-opted_out{background:rgba(234,134,143,.08);color:var(--color-red);border:1px solid rgba(234,134,143,.18);}
.oc-badge-unreachable{background:rgba(156,163,175,.06);color:var(--dim);border:1px solid rgba(156,163,175,.1);}

/* ── Queue tab ── */
.oc-queue-day{margin-bottom:12px;}
.oc-queue-day-hdr{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--s2);border-radius:8px;cursor:pointer;transition:background .1s;font-size:12px;font-weight:600;color:var(--text);}
.oc-queue-day-hdr:hover{background:var(--s3);}
.oc-queue-day-count{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted);}
.oc-queue-day-items{padding:4px 0;}

/* ── Activity tab ── */
.oc-activity-filters{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:12px;}
.oc-activity-filters select,
.oc-activity-filters input{padding:6px 10px;background:var(--s2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:11px;font-family:inherit;}
.oc-activity-filters select:focus,.oc-activity-filters input:focus{border-color:rgba(var(--accent-rgb),.35);outline:none;}

/* ── Unreachable tab ── */
.oc-unreach-actions{display:flex;gap:6px;justify-content:flex-end;}

/* ── Pagination ── */
.oc-pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 0;font-size:11px;color:var(--muted);}
.oc-page-btn{padding:5px 12px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer;font-size:11px;font-weight:600;transition:all .12s;}
.oc-page-btn:hover{border-color:rgba(var(--accent-rgb),.3);background:rgba(var(--accent-rgb),.06);}
.oc-page-btn:disabled{opacity:.4;cursor:default;pointer-events:none;}
.oc-page-info{font-family:'JetBrains Mono',monospace;font-size:10px;}

/* ── Bulk assign modal ── */
.oc-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(16px);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .18s;}
.oc-modal-overlay.open{opacity:1;pointer-events:all;}
.oc-modal{background:var(--s1);border:1px solid rgba(var(--accent-rgb),.14);border-radius:14px;width:min(94vw,520px);max-height:80vh;overflow-y:auto;box-shadow:0 24px 60px rgba(0,0,0,.55);transform:translateY(-6px) scale(.98);transition:transform .18s cubic-bezier(.34,1.2,.64,1);padding:0;}
.oc-modal-overlay.open .oc-modal{transform:translateY(0) scale(1);}
.oc-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);}
.oc-modal-title{font-size:14px;font-weight:700;color:var(--text);}
.oc-modal-close{width:28px;height:28px;border-radius:6px;border:none;background:rgba(var(--accent-rgb),.06);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .12s;}
.oc-modal-close:hover{background:rgba(var(--accent-rgb),.12);color:var(--text);}
.oc-modal-body{padding:16px 18px;}
.oc-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 18px;border-top:1px solid var(--border);}

/* ── Preview count ── */
.oc-preview-count{padding:10px 14px;background:rgba(var(--accent-rgb),.06);border-radius:8px;font-size:12px;color:var(--text);margin-top:12px;display:flex;align-items:center;justify-content:space-between;}
.oc-preview-num{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:16px;color:var(--accent);}

/* ── Empty / placeholder ── */
.oc-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--muted);font-size:13px;gap:8px;}
.oc-empty-icon{font-size:32px;opacity:.4;}

/* ══════════════════════════════════════════════════════════════
   OWNER CARD — OUTREACH PANEL
══════════════════════════════════════════════════════════════ */

/* ── Panel container ── */
.outreach-panel{background:var(--s1);border:1px solid rgba(var(--accent-rgb),.1);border-radius:12px;margin-top:12px;overflow:hidden;}
.outreach-panel-hdr{display:flex;align-items:center;gap:6px;padding:10px 14px;border-bottom:1px solid var(--border);font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;}
.outreach-panel-body{padding:12px 14px;}
.outreach-panel-loading{font-size:11px;color:var(--muted);text-align:center;padding:16px 0;}
.outreach-panel-empty{text-align:center;padding:12px 0;display:flex;flex-direction:column;align-items:center;gap:8px;}

/* ── Status row ── */
.outreach-status-row{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap;}
.outreach-status-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:9px;font-weight:700;white-space:nowrap;letter-spacing:.02em;}
.outreach-status-dnc{background:rgba(220,38,38,.12);color:var(--color-red);border:1px solid rgba(220,38,38,.25);}
.outreach-status-opted_out{background:rgba(234,134,143,.08);color:var(--color-red);border:1px solid rgba(234,134,143,.18);}
.outreach-campaign-link{font-size:11px;color:var(--accent);cursor:pointer;font-weight:600;text-decoration:underline;text-underline-offset:2px;}
.outreach-campaign-link:hover{opacity:.8;}

/* ── Step progress stepper ── */
.outreach-stepper{display:flex;align-items:center;margin:10px 0;gap:0;padding:0 4px;}
.outreach-step-dot{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;font-family:'JetBrains Mono',monospace;flex-shrink:0;transition:all .15s;}
.outreach-step-dot span{line-height:1;}
.outreach-step-done{background:var(--accent);color:#fff;border:2px solid var(--accent);}
.outreach-step-current{background:transparent;color:var(--accent);border:2px solid var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.15);}
.outreach-step-future{background:transparent;color:var(--muted);border:2px solid var(--border);}
.outreach-step-line{flex:1;height:2px;min-width:8px;max-width:24px;}
.outreach-step-line.done{background:var(--accent);}
.outreach-step-line:not(.done){background:var(--border);}

/* ── Next action ── */
.outreach-next-action{font-size:10px;color:var(--muted);margin-bottom:10px;padding:4px 0;}

/* ── Action buttons ── */
.outreach-panel-actions{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border);}

/* ── Attempt history ── */
.outreach-history-hdr{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;display:flex;align-items:center;gap:6px;}
.outreach-history-count{font-family:'JetBrains Mono',monospace;font-size:9px;background:rgba(var(--accent-rgb),.08);color:var(--accent);padding:1px 5px;border-radius:8px;}
.outreach-history{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto;}
.outreach-attempt{display:grid;grid-template-columns:auto 1fr auto;gap:6px;align-items:center;padding:5px 8px;border-radius:6px;background:var(--s2);font-size:10px;}
.outreach-attempt-fail{border-left:2px solid var(--color-red);}
.outreach-attempt-ok{border-left:2px solid var(--color-green);}
.outreach-attempt-date{color:var(--muted);font-family:'JetBrains Mono',monospace;font-size:9px;white-space:nowrap;}
.outreach-attempt-type{color:var(--text);font-weight:600;white-space:nowrap;}
.outreach-attempt-outcome{color:var(--muted);text-align:right;white-space:nowrap;}
.outreach-attempt-preview{grid-column:1/-1;font-size:9px;color:var(--dim);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;}
.outreach-attempt-preview.expanded{white-space:normal;word-break:break-word;}

/* ── DNC modal ── */
.oc-dnc-reasons{display:flex;flex-direction:column;gap:6px;margin-top:6px;}
.oc-dnc-reason{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text);cursor:pointer;padding:4px 0;}
.oc-dnc-reason input[type="radio"]{width:14px;height:14px;accent-color:var(--accent);margin:0;}

/* ── Responsive ── */
@media(max-width:768px){
  .oc-dash{grid-template-columns:repeat(2,1fr);}
  .oc-cost-panel.open{grid-template-columns:repeat(2,1fr);}
  .oc-tabs{flex-wrap:wrap;}
  .outreach-stepper{flex-wrap:wrap;gap:2px;}
}

/* ── Source tags for merged timeline ── */
.outreach-source-tag{display:inline-block;font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:1px 5px;border-radius:3px;margin-left:4px;vertical-align:middle}
.outreach-source-tag.manual{background:rgba(var(--accent-rgb),.08);color:var(--accent);border:1px solid rgba(var(--accent-rgb),.15)}
.outreach-source-tag.auto{background:rgba(156,163,175,.06);color:var(--muted);border:1px solid rgba(156,163,175,.1)}
.outreach-attempt-user{font-size:10px;color:var(--muted);margin-top:2px}
