*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --p:#2563eb;--pd:#1d4ed8;--pl:#3b82f6;--p-tint:#eff6ff;--p-border:#bfdbfe;
  --bg:#eef2f7;--card:#ffffff;--card2:#f8fafc;--card3:#f1f5f9;
  --txt:#0d1117;--txt2:#4b5563;--txt3:#9ca3af;
  --bdr:#e2e8f0;--bdr2:#cbd5e1;
  --ok:#10b981;--ok-bg:#ecfdf5;--ok-txt:#065f46;
  --warn:#f59e0b;--warn-bg:#fffbeb;--warn-txt:#78350f;
  --err:#ef4444;--err-bg:#fef2f2;--err-txt:#991b1b;
  --r:10px;--r2:14px;--r3:20px;
}
[data-theme="dark"]{
  --p:#3b82f6;--pd:#2563eb;--pl:#60a5fa;--p-tint:#0f2040;--p-border:#2d5fa8;
  --bg:#0b1220;--card:#111d2e;--card2:#162336;--card3:#1c2d42;
  --txt:#e8f0fc;--txt2:#94aecf;--txt3:#5a7898;
  --bdr:#1e3248;--bdr2:#2a4460;
  --ok:#10b981;--ok-bg:#052a1c;--ok-txt:#34d399;
  --warn:#f59e0b;--warn-bg:#1f1400;--warn-txt:#fbbf24;
  --err:#f87171;--err-bg:#200a0a;--err-txt:#fca5a5;
}
html,body{height:100%;font-family:'Inter',-apple-system,sans-serif;font-size:13px;line-height:1.5;background:var(--bg);color:var(--txt);overflow:hidden}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bdr2);border-radius:2px}

.gh{display:flex;align-items:center;height:50px;padding:0 14px;background:var(--card);border-bottom:1px solid var(--bdr);flex-shrink:0;z-index:100;position:relative}
.logo-text{font-size:15px;font-weight:800;color:var(--txt);letter-spacing:-.3px;padding-right:14px}
.logo-text span{color:var(--p)}
.h-sep{width:1px;height:20px;background:var(--bdr);flex-shrink:0}
.h-spacer{flex:1}
.nav-tabs{display:flex;align-items:center;gap:2px;padding-left:16px}
.ntab{padding:6px 12px;border-radius:var(--r);font-size:12px;font-weight:600;color:var(--txt3);cursor:pointer;border:none;background:transparent;font-family:inherit;transition:all .15s}
.ntab.active{background:var(--p-tint);color:var(--p)}
.ntab:hover:not(.active){background:var(--card2);color:var(--txt2)}
.h-actions{display:flex;align-items:center;gap:4px;padding-right:12px}
.hb{width:32px;height:32px;border-radius:var(--r);border:1px solid var(--bdr);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--txt2);transition:all .15s;flex-shrink:0}
.hb:hover{background:var(--p-tint);color:var(--p);border-color:var(--p-border)}
.hb svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}
.h-agent{position:relative;flex-shrink:0;padding-left:12px}
.h-pill{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:10px;border:1px solid transparent;cursor:pointer;user-select:none;transition:all .15s}
.h-pill:hover{background:var(--card2);border-color:var(--bdr)}
.h-av{width:30px;height:30px;border-radius:50%;background:var(--p);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:11px;flex-shrink:0;position:relative}
.h-av-dot{position:absolute;bottom:-1px;right:-1px;width:9px;height:9px;border-radius:50%;background:var(--ok);border:2px solid var(--card)}
.h-info{display:flex;flex-direction:column}
.h-name{font-size:12px;font-weight:700;color:var(--txt);white-space:nowrap;line-height:1.3}
.h-sub{font-size:10px;color:var(--txt3);white-space:nowrap}
.h-chev svg{width:13px;height:13px;stroke:var(--txt3);fill:none;stroke-width:2.5}
.h-drop{position:absolute;top:calc(100% + 8px);right:0;min-width:196px;background:var(--card);border:1px solid var(--bdr);border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,.18);z-index:400;overflow:hidden;display:none;animation:fadeDown .16s ease}
.h-agent.open .h-drop{display:block}
.h-drop-head{padding:13px 15px;background:var(--card2);border-bottom:1px solid var(--bdr)}
.h-drop-name{font-size:13px;font-weight:700;color:var(--txt)}
.h-drop-role{font-size:11px;color:var(--txt3);margin-top:2px}
.ditem{display:flex;align-items:center;gap:10px;padding:10px 15px;font-size:12px;font-weight:500;color:var(--txt2);cursor:pointer;transition:background .1s}
.ditem:hover{background:var(--card2)}
.ditem svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.ditem.danger{color:var(--err)}
.ditem.danger:hover{background:var(--err-bg)}
.h-drop-sep{height:1px;background:var(--bdr);margin:3px 0}

/* Page is now a scroll container — no fixed/sticky chrome.
   Header and toolbar scroll away naturally with the lead table. */
.page{display:flex;flex-direction:column;min-height:calc(100vh - 50px);overflow-y:auto;overflow-x:hidden}

/* Header row — floating style (no card bg, no border) for clean modern look */
.lead-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px 10px;gap:12px;flex-wrap:wrap;
  flex-shrink:0;
}
.lead-title{
  font-size:18px;font-weight:700;color:var(--txt);
  letter-spacing:-.2px;margin:0;
}

/* ── Slim inline stats strip ─────────────────────────────── */
.stats-row{display:flex;align-items:center;gap:2px;flex-shrink:0;overflow-x:auto;scrollbar-width:none}
.stats-row::-webkit-scrollbar{display:none}
.stat-cell{display:inline-flex;align-items:center;gap:6px;padding:0 10px;height:28px;border-radius:7px;cursor:pointer;white-space:nowrap;transition:all .12s;border:none;background:transparent;font-family:inherit;color:var(--txt3)}
.stat-cell:hover{background:var(--card2);color:var(--txt)}
.stat-cell.active{background:var(--p-tint);color:var(--p)}
.stat-cell.active .stat-num{color:var(--p)}
.stat-lbl{font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:5px;letter-spacing:.01em}
.stat-lbl::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--dot,transparent);flex-shrink:0}
.stat-cell.total .stat-lbl::before{display:none}
.stat-num{font-size:13px;font-weight:800;color:var(--txt);font-variant-numeric:tabular-nums;line-height:1}
.stat-cell.total .stat-num{font-size:14px}
.stat-sep{width:1px;height:16px;background:var(--bdr);margin:0 4px;flex-shrink:0}
@media(max-width:640px){
  .stats-row{padding:0 8px;gap:0}
  .stat-cell{padding:0 8px;gap:5px}
}

.toolbar{display:flex;align-items:center;gap:8px;padding:10px 20px;flex-shrink:0;flex-wrap:wrap}
.toolbar-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0;flex-wrap:wrap}
.toolbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.desktop-filters{display:flex;align-items:center;gap:8px}
.search-wrap{position:relative;flex:1;min-width:160px;max-width:280px}
.search-wrap svg{position:absolute;left:9px;top:50%;transform:translateY(-50%);width:13px;height:13px;stroke:var(--txt3);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}
.search-inp{width:100%;height:32px;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r);padding:0 10px 0 30px;font-family:inherit;font-size:12px;color:var(--txt);outline:none;transition:border-color .15s}
.search-inp:focus{border-color:var(--p);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.search-inp::placeholder{color:var(--txt3)}

/* ── Global search dropdown ─────────────────────────────────────
   Anchored under .search-wrap, extends wider than the input so
   long lines (email subjects, note bodies) don't truncate awkwardly. */
.gs-dropdown{position:absolute;top:calc(100% + 6px);left:0;width:520px;max-width:calc(100vw - 24px);max-height:70vh;overflow-y:auto;background:var(--card);border:1px solid var(--bdr);border-radius:var(--r2);box-shadow:0 12px 32px rgba(0,0,0,.18);z-index:550;animation:gsFade .14s ease;display:none}
.gs-dropdown.open{display:block}
[data-theme="dark"] .gs-dropdown{box-shadow:0 12px 32px rgba(0,0,0,.5)}
@keyframes gsFade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.gs-loading,.gs-empty{padding:16px;font-size:12px;color:var(--txt3);text-align:center}
.gs-group{border-bottom:1px solid var(--bdr)}
.gs-group:last-child{border-bottom:none}
.gs-group-head{padding:8px 12px 6px;font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.6px;background:var(--card2);position:sticky;top:0;z-index:1}
.gs-group-head .gs-count{color:var(--txt3);font-weight:600;margin-left:6px}
.gs-row{display:flex;align-items:flex-start;gap:10px;padding:9px 12px;cursor:pointer;border-bottom:1px solid var(--bdr);transition:background .12s}
.gs-row:last-child{border-bottom:none}
.gs-row:hover,.gs-row.active{background:var(--card2)}
.gs-ico{width:22px;height:22px;border-radius:6px;background:var(--card2);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.gs-row:hover .gs-ico,.gs-row.active .gs-ico{background:var(--card3)}
.gs-ico svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;color:var(--txt3)}
.gs-body{flex:1;min-width:0}
.gs-title{font-size:12px;font-weight:600;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gs-sub{font-size:11px;color:var(--txt3);margin-top:2px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.gs-meta{font-size:10px;color:var(--txt3);margin-top:3px;display:flex;align-items:center;gap:6px}
.gs-meta-dot{width:2px;height:2px;border-radius:50%;background:var(--txt3)}
.gs-row mark{background:var(--p-tint);color:var(--p);padding:0 1px;border-radius:2px;font-weight:600}
.fsel{height:30px;background:var(--bg);border:1px solid var(--bdr);border-radius:7px;padding:0 26px 0 10px;font-family:inherit;font-size:11px;font-weight:600;color:var(--txt2);outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235a7898' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 7px center;background-size:11px;transition:all .15s}
.fsel:hover{background:var(--card2);color:var(--txt);border-color:var(--bdr2)}
.fsel:focus{border-color:var(--p);box-shadow:0 0 0 2px rgba(37,99,235,.12);color:var(--txt)}
.fsel option{background:var(--card);color:var(--txt)}
.btn{height:32px;padding:0 14px;border-radius:var(--r);font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px;border:1px solid var(--bdr);background:var(--card);color:var(--txt2);white-space:nowrap}
.btn:hover{background:var(--card2);color:var(--txt)}
.btn.primary{background:var(--p);border-color:var(--p);color:#fff}
.btn.primary:hover{background:var(--pd)}
.btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.btn:active{transform:scale(.97)}

/* Table sits in a card so it stands apart from the floating header above */
.table-wrap{
  flex:1;overflow:visible;
  margin:0 20px 20px;
  background:var(--card);
  border:1px solid var(--bdr);
  border-radius:var(--r2);
}
table{width:100%;border-collapse:collapse;font-size:12px}
thead{position:sticky;top:0;z-index:10;background:var(--card2);border-bottom:1px solid var(--bdr);border-radius:var(--r2) var(--r2) 0 0}
th{padding:12px 14px;text-align:left;font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;user-select:none}
th:first-child{border-top-left-radius:var(--r2)}
th:last-child{border-top-right-radius:var(--r2)}
tbody tr{border-bottom:1px solid var(--bdr);transition:background .1s;cursor:pointer}
tbody tr:hover{background:var(--card2)}
tbody tr.selected{background:var(--p-tint);box-shadow:inset 2px 0 0 var(--p)}
td{padding:8px 14px;vertical-align:top}
.td-co{font-weight:700;color:var(--txt);font-size:12px;line-height:1.4}
.td-name{color:var(--txt2);font-size:12px;line-height:1.4}
.row-sub{display:flex;align-items:center;gap:6px;margin-top:4px;flex-wrap:nowrap;width:100%}
.rs-item{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:var(--txt3);white-space:nowrap}
.rs-item svg{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.rs-sep{color:var(--bdr2);font-size:10px}
.rs-summary{font-size:10px;color:var(--txt3);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}
.rs-pill{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:700;padding:1px 6px;border-radius:20px}
.rs-hot{background:var(--err-bg);color:var(--err-txt)}
.rs-warm{background:var(--warn-bg);color:var(--warn-txt)}
.rs-cold{background:var(--card3);color:var(--txt3)}
.rs-pos{background:var(--ok-bg);color:var(--ok-txt)}
.rs-neu{background:var(--warn-bg);color:var(--warn-txt)}
.rs-neg{background:var(--err-bg);color:var(--err-txt)}
.rs-note-btn,.rs-email-btn{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;color:var(--txt3);padding:1px 6px;border-radius:6px;border:1px solid var(--bdr);background:transparent;cursor:pointer;transition:all .15s;font-family:inherit}
.rs-note-btn:hover{background:var(--p-tint);color:var(--p);border-color:var(--p-border)}
.rs-email-btn:hover{background:var(--p-tint);color:var(--p);border-color:var(--p-border)}
.rs-note-btn svg,.rs-email-btn svg{width:9px;height:9px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--r3);font-size:10px;font-weight:700;white-space:nowrap}
.b-demo{background:#f5f3ff;color:#6d28d9}
.b-quote{background:#eff6ff;color:#1d4ed8}
.b-support{background:#fef3c7;color:#92400e}
.b-contact{background:#ecfdf5;color:#065f46}
[data-theme="dark"] .b-demo{background:#1e1040;color:#a78bfa}
[data-theme="dark"] .b-quote{background:#0f2040;color:#60a5fa}
[data-theme="dark"] .b-support{background:#1f1400;color:#fbbf24}
[data-theme="dark"] .b-contact{background:#052a1c;color:#34d399}
.stage-mini{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--r);font-size:11px;font-weight:600;border:1px solid;white-space:nowrap}

.picker-popup{position:fixed;background:var(--card);border:1px solid var(--bdr);border-radius:var(--r2);box-shadow:0 8px 32px rgba(0,0,0,.22);z-index:600;min-width:210px;overflow:hidden;animation:fadeDown .15s ease;display:none}
.picker-popup.open{display:block}
.pp-head{padding:8px 12px;font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--bdr);background:var(--card2)}
.pp-item{display:flex;align-items:center;gap:10px;padding:9px 12px;cursor:pointer;transition:background .1s;font-size:12px;font-weight:500;color:var(--txt)}
.pp-item:hover{background:var(--card2)}
.pp-item.active{background:var(--p-tint);color:var(--p)}
.pp-item.active .pp-check{opacity:1}
.pp-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.pp-check{width:14px;height:14px;stroke:var(--p);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;margin-left:auto;opacity:0;flex-shrink:0}
.picker-btn{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:var(--r);border:1.5px solid var(--bdr);background:var(--card2);cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;color:var(--txt);transition:all .15s;user-select:none}
.picker-btn:hover{border-color:var(--bdr2)}
.picker-btn .pb-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.picker-btn .pb-chev{width:12px;height:12px;stroke:var(--txt3);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;margin-left:2px;flex-shrink:0}

.cards-wrap{display:none;flex:1;overflow:visible;padding:12px}
.lead-card{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r2);padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:all .15s;animation:fadeIn .2s ease}
.lead-card.selected{background:var(--p-tint);border-color:var(--p-border);box-shadow:inset 2px 0 0 var(--p)}
.lead-card:hover{border-color:var(--bdr2);background:var(--card2)}
.lc-av{width:34px;height:34px;border-radius:50%;background:var(--p);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:11px;flex-shrink:0}
.lc-name{font-size:13px;font-weight:700;color:var(--txt);line-height:1.2}
.lc-co{font-size:11px;color:var(--txt2);margin-top:1px}
.lc-strip{display:flex;align-items:center;gap:6px;padding-top:8px;border-top:1px solid var(--bdr);flex-wrap:nowrap}
.lc-summary{font-size:10px;color:var(--txt3);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}

.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:200;opacity:0;pointer-events:none;transition:opacity .2s}
.drawer-overlay.open{opacity:1;pointer-events:all}
.drawer{position:fixed;top:0;right:0;height:100%;width:500px;max-width:100%;background:var(--card);border-left:1px solid var(--bdr);z-index:201;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.2)}
.drawer.open{transform:translateX(0)}
.drawer-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--bdr);flex-shrink:0}
.drawer-title{font-size:13px;font-weight:700;color:var(--txt);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.drawer-tabs{display:flex;gap:2px;background:var(--bg);padding:3px;border-radius:var(--r);flex-shrink:0}
.dtab{padding:4px 10px;border-radius:8px;font-size:11px;font-weight:600;color:var(--txt3);cursor:pointer;transition:all .15s;border:none;background:transparent;font-family:inherit;white-space:nowrap}
.dtab.active{background:var(--card);color:var(--p);box-shadow:0 1px 3px rgba(0,0,0,.1)}
.close-btn{width:28px;height:28px;border-radius:8px;border:1px solid var(--bdr);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--txt3);transition:all .15s;flex-shrink:0}
.close-btn:hover{background:var(--err-bg);color:var(--err-txt);border-color:var(--err)}
.close-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.drawer-body{flex:1;overflow-y:auto;padding:16px}
.drawer-panel{display:none}
.drawer-panel.active{display:block}

.lead-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--bdr)}
.lead-av{width:46px;height:46px;border-radius:50%;background:var(--p);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:15px;flex-shrink:0}
.lead-name{font-size:15px;font-weight:700;color:var(--txt);line-height:1.3}
.lead-co{font-size:12px;color:var(--txt2);margin-top:2px}
.lead-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.lmi{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--txt3)}
.lmi svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.pickers-row{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.picker-wrap{display:flex;flex-direction:column;gap:4px}
.picker-lbl{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px}
.sent-row{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.sent-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:var(--r3);font-size:11px;font-weight:700}
.sent-pos{background:var(--ok-bg);color:var(--ok-txt)}
.sent-neu{background:var(--warn-bg);color:var(--warn-txt)}
.sent-neg{background:var(--err-bg);color:var(--err-txt)}
.score-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--r3);font-size:11px;font-weight:700}
.sc-hot{background:var(--err-bg);color:var(--err-txt)}
.sc-warm{background:var(--warn-bg);color:var(--warn-txt)}
.sc-cold{background:var(--card3);color:var(--txt3)}
.ai-box{background:var(--p-tint);border:1px solid var(--p-border);border-radius:var(--r2);padding:12px;margin-bottom:16px}
.ai-box-head{display:flex;align-items:center;gap:7px;margin-bottom:7px}
.ai-ico{width:22px;height:22px;border-radius:7px;background:var(--p);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ai-ico svg{width:11px;height:11px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ai-lbl{font-size:11px;font-weight:700;color:var(--pl)}
.ai-txt{font-size:12px;color:var(--txt2);line-height:1.6}
.sec-lbl{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}
.fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.field-item{background:var(--card2);border:1px solid var(--bdr);border-radius:var(--r);padding:8px 10px}
.field-key{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px}
.field-val{font-size:12px;font-weight:600;color:var(--txt)}

.notes-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.note-item{background:var(--card2);border:1px solid var(--bdr);border-radius:var(--r);padding:10px 12px}
.note-item:hover .note-del{opacity:1}
.note-body{font-size:12px;color:var(--txt);line-height:1.55;margin-bottom:6px}
.note-foot{display:flex;align-items:center;justify-content:space-between}
.note-meta{font-size:10px;color:var(--txt3)}
.note-del{width:22px;height:22px;border-radius:6px;border:1px solid var(--bdr);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--txt3);opacity:0;transition:all .15s}
.note-del:hover{background:var(--err-bg);color:var(--err-txt);border-color:var(--err)}
.note-del svg{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.add-note-ta{width:100%;background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--r);padding:9px 11px;font-family:inherit;font-size:12px;color:var(--txt);resize:none;outline:none;transition:border-color .15s;min-height:80px}
.add-note-ta:focus{border-color:var(--p);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.add-note-ta::placeholder{color:var(--txt3)}
.note-footer{display:flex;justify-content:flex-end;margin-top:6px}

.tpl-row{display:flex;gap:8px;align-items:center;margin-bottom:12px}
.tpl-lbl{font-size:11px;font-weight:600;color:var(--txt3);white-space:nowrap;flex-shrink:0}
/* Email editor tabs */
.em-tabs{display:flex;gap:2px;background:var(--bg);padding:3px;border-radius:var(--r);width:fit-content;margin-bottom:8px}
.emtab{padding:4px 11px;border-radius:7px;font-size:11px;font-weight:600;color:var(--txt3);cursor:pointer;border:none;background:transparent;font-family:inherit;transition:all .15s}
.emtab.active{background:var(--card);color:var(--p);box-shadow:0 1px 3px rgba(0,0,0,.12)}
.emtab:hover:not(.active){color:var(--txt2)}
/* Email preview pane */
.email-preview-pane{min-height:160px;max-height:280px;overflow-y:auto;background:#fff;border:1px solid var(--bdr);border-radius:var(--r);padding:16px;font-family:'Inter',-apple-system,sans-serif;font-size:13px;color:#111;line-height:1.6}
[data-theme="dark"] .email-preview-pane{background:#1a2535;color:#e8f0fc}
.ef{margin-bottom:10px}
.ef label{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:4px}
.email-inp{width:100%;height:34px;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r);padding:0 10px;font-family:inherit;font-size:12px;color:var(--txt);outline:none;transition:border-color .15s}
.email-inp:focus{border-color:var(--p)}
.rich-toolbar{display:flex;gap:2px;padding:5px 8px;background:var(--card2);border:1px solid var(--bdr);border-radius:var(--r) var(--r) 0 0;border-bottom:none;flex-wrap:wrap;align-items:center}
.etool{width:26px;height:26px;border-radius:6px;border:none;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--txt2);font-size:11px;font-weight:700;transition:all .15s;font-family:inherit;flex-shrink:0}
.etool:hover{background:var(--bdr);color:var(--txt)}
.etool svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}
.etool-sep{width:1px;height:16px;background:var(--bdr);margin:0 2px;flex-shrink:0}
.email-rte{width:100%;background:var(--bg);border:1px solid var(--bdr);border-radius:0 0 var(--r) var(--r);padding:9px 10px;font-family:inherit;font-size:12px;color:var(--txt);outline:none;min-height:140px;max-height:260px;overflow-y:auto;line-height:1.6;transition:border-color .15s}
.email-rte:focus{border-color:var(--p);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.email-rte a{color:var(--p)}
.email-body-ta{width:100%;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r);padding:9px 10px;font-family:'Fira Code','Consolas',monospace;font-size:11px;color:var(--txt);outline:none;resize:none;min-height:160px;max-height:260px;transition:border-color .15s;line-height:1.6;tab-size:2}
.email-body-ta:focus{border-color:var(--p);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.email-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}
.divider{display:flex;align-items:center;gap:10px;margin:16px 0;color:var(--txt3);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--bdr)}
.email-hist-item{background:var(--card2);border:1px solid var(--bdr);border-radius:var(--r);padding:10px 12px;margin-bottom:8px;cursor:pointer;transition:all .15s}
.email-hist-item:hover{border-color:var(--bdr2);background:var(--card3)}
.email-hist-item.open{border-color:var(--p-border);background:var(--p-tint)}
.email-hist-subj{font-size:12px;font-weight:600;color:var(--txt);margin-bottom:3px}
.email-hist-meta{display:flex;align-items:center;justify-content:space-between}
.email-hist-time{font-size:10px;color:var(--txt3)}
.email-hist-body{display:none;margin-top:10px;padding-top:10px;border-top:1px solid var(--bdr);font-size:12px;color:var(--txt2);line-height:1.6;max-height:260px;overflow-y:auto}
.email-hist-item.open .email-hist-body{display:block}
/* Compose form hidden by default */
.email-compose{display:none}
.email-compose.open{display:block}
.compose-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.compose-title{font-size:12px;font-weight:700;color:var(--txt)}
.compose-close{width:22px;height:22px;border-radius:6px;border:1px solid var(--bdr);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--txt3);transition:all .15s;flex-shrink:0}
.compose-close:hover{background:var(--err-bg);color:var(--err);border-color:var(--err)}
.compose-close svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}
.sent-ok{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;color:var(--ok-txt)}
.sent-ok::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--ok);display:inline-block}
.sent-fail{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;color:var(--err-txt)}

.chat-messages{display:flex;flex-direction:column;gap:10px}
.chat-msg{display:flex;gap:8px;max-width:88%}
.chat-msg.agent-msg{flex-direction:row-reverse;align-self:flex-end;margin-left:auto}
.chat-mav{width:26px;height:26px;border-radius:50%;background:var(--card2);border:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--txt2);flex-shrink:0;margin-top:2px}
.chat-msg.agent-msg .chat-mav{background:var(--p);color:#fff;border-color:var(--p)}
.chat-mb{padding:8px 12px;font-size:12px;line-height:1.55;color:var(--txt);background:var(--card2);border:1px solid var(--bdr);border-radius:4px 12px 12px 12px}
.chat-msg.agent-msg .chat-mb{background:var(--p);color:#fff;border:none;border-radius:12px 4px 12px 12px}
.chat-mt{font-size:10px;color:var(--txt3);margin-top:3px}
.chat-msg.agent-msg .chat-mt{text-align:right}
.chat-sys{text-align:center;font-size:10px;color:var(--txt3);margin:4px 0;display:flex;align-items:center;gap:8px}
.chat-sys::before,.chat-sys::after{content:'';flex:1;height:1px;background:var(--bdr)}

.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center}
.empty-ico{width:44px;height:44px;border-radius:var(--r2);background:var(--card2);border:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.empty-ico svg{width:20px;height:20px;stroke:var(--txt3);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.empty-title{font-size:13px;font-weight:700;color:var(--txt);margin-bottom:4px}
.empty-sub{font-size:12px;color:var(--txt3)}

.loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--txt3);font-size:12px;gap:8px}
.spin{width:16px;height:16px;border:2px solid var(--bdr);border-top-color:var(--p);border-radius:50%;animation:spin .6s linear infinite}

@media(max-width:640px){
  .stats-row{display:none}.nav-tabs{display:none}.h-info{display:none}
  .table-wrap{display:none}.cards-wrap{display:block}
  .drawer{width:100%;border-left:none;top:auto;bottom:0;height:92%;transform:translateY(100%);border-radius:var(--r2) var(--r2) 0 0;border-top:1px solid var(--bdr)}
  .drawer.open{transform:translateY(0)}
  .fields-grid{grid-template-columns:1fr}
  /* Single row toolbar — no wrapping */
  .toolbar{padding:8px 10px;gap:6px;flex-wrap:nowrap}
  .toolbar-left{flex-wrap:nowrap;flex:1;min-width:0;gap:6px}
  .search-wrap{min-width:0;max-width:none;flex:1}
  /* Hide desktop filters, show filter icon */
  .desktop-filters{display:none !important}
  .mob-filter-btn{display:inline-flex !important}
  /* Icon-only buttons on mobile */
  .btn-label{display:none}
  .btn{padding:0;width:32px;justify-content:center}
  .btn.primary{padding:0 12px;width:auto}
  .btn.primary .btn-label{display:inline}
  .trash-btn{padding:0;width:32px;justify-content:center}
  .toolbar-right{gap:6px;flex-shrink:0}
  .toast-wrap{bottom:12px;right:12px;left:12px}
  .toast{min-width:0;width:100%}
}
/* Mobile filter button — hidden by default, shown via media query */
.mob-filter-btn{display:none;width:32px;height:32px;border-radius:var(--r);border:1px solid var(--bdr);background:var(--card);cursor:pointer;align-items:center;justify-content:center;color:var(--txt2);transition:all .15s;flex-shrink:0;position:relative}
.mob-filter-btn:hover,.mob-filter-btn.has-filters{background:var(--p-tint);color:var(--p);border-color:var(--p-border)}
.mob-filter-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}
.mob-filter-dot{position:absolute;top:-3px;right:-3px;width:8px;height:8px;border-radius:50%;background:var(--p);border:2px solid var(--card);display:none}
.mob-filter-dot.on{display:block}
/* Filter slide-up panel */
.fp-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:480;opacity:0;pointer-events:none;transition:opacity .2s}
.fp-overlay.open{opacity:1;pointer-events:all}
.fp-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--card);border-radius:var(--r2) var(--r2) 0 0;border-top:1px solid var(--bdr);z-index:481;transform:translateY(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);padding-bottom:env(safe-area-inset-bottom,16px)}
.fp-sheet.open{transform:translateY(0)}
.fp-handle{width:36px;height:4px;border-radius:2px;background:var(--bdr2);margin:10px auto 0}
.fp-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 8px}
.fp-title{font-size:14px;font-weight:700;color:var(--txt)}
.fp-clear{font-size:12px;font-weight:600;color:var(--p);cursor:pointer;background:none;border:none;font-family:inherit;padding:4px 0}
.fp-body{padding:4px 16px 8px;display:flex;flex-direction:column;gap:12px}
.fp-row label{display:block;font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.fp-row .fsel{width:100%;height:38px;font-size:13px}
@keyframes fadeDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* TOASTER */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--card);border:1px solid var(--bdr);border-radius:var(--r2);box-shadow:0 8px 32px rgba(0,0,0,.18);font-size:12px;font-weight:600;color:var(--txt);min-width:240px;max-width:340px;pointer-events:all;animation:toastIn .25s cubic-bezier(.4,0,.2,1);transition:opacity .2s,transform .2s}
.toast.hide{opacity:0;transform:translateY(8px)}
.toast-icon{width:22px;height:22px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.toast-icon svg{width:12px;height:12px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.toast.ok   .toast-icon{background:var(--ok)}
.toast.err  .toast-icon{background:var(--err)}
.toast.info .toast-icon{background:var(--p)}
.toast-msg{flex:1;line-height:1.4}
.toast-close{width:18px;height:18px;border-radius:5px;border:none;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--txt3);transition:all .15s;flex-shrink:0;padding:0}
.toast-close:hover{background:var(--card2);color:var(--txt)}
.toast-close svg{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.toast-bar{position:absolute;bottom:0;left:0;height:2px;border-radius:0 0 var(--r2) var(--r2);background:currentColor;animation:toastBar linear forwards}
@keyframes toastIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes toastBar{from{width:100%}to{width:0%}}

/* DRAWER wider */
.drawer{width:560px}

/* ACTIVITY TAB */
.act-filters{display:flex;align-items:center;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.act-pill{padding:4px 12px;border-radius:var(--r3);font-size:11px;font-weight:600;border:1px solid var(--bdr);background:transparent;color:var(--txt3);cursor:pointer;transition:all .15s;font-family:inherit}
.act-pill.active{background:var(--p-tint);color:var(--p);border-color:var(--p-border)}
.act-pill:hover:not(.active){background:var(--card2);color:var(--txt2)}
.act-timeline{display:flex;flex-direction:column}
.act-day{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.6px;padding:12px 0 6px;border-bottom:1px solid var(--bdr);margin-bottom:8px}
.act-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--bdr)}
.act-item:last-child{border-bottom:none}
.act-ico{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.act-ico svg{width:13px;height:13px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.act-ico.audit{background:var(--p)}
.act-ico.note{background:var(--warn)}
.act-ico.email{background:var(--ok)}
.act-ico.task-done{background:var(--ok)}
.act-ico.task-pending{background:var(--txt3)}

/* Secondary filter row — appears below the main pills when "Tasks" is active. */
.act-subfilters{display:flex;align-items:center;gap:4px;margin:-8px 0 14px 2px;padding-left:2px}
.act-subpill{padding:3px 10px;border-radius:var(--r3);font-size:10px;font-weight:600;border:1px solid transparent;background:transparent;color:var(--txt3);cursor:pointer;transition:all .15s;font-family:inherit}
.act-subpill.active{background:var(--card2);color:var(--txt);border-color:var(--bdr)}
.act-subpill:hover:not(.active){color:var(--txt2)}

/* Inline state badge inside task activity rows */
.act-task-badge{display:inline-block;margin-left:6px;padding:1px 7px;border-radius:var(--r3);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;vertical-align:middle}
.act-task-badge.done{background:var(--ok-bg);color:var(--ok)}
.act-task-badge.pending{background:var(--card2);color:var(--txt3);border:1px solid var(--bdr)}
.act-body{flex:1;min-width:0}
.act-title{font-size:12px;font-weight:600;color:var(--txt);line-height:1.4}
.act-title span{color:var(--txt2);font-weight:400}
.act-meta{font-size:10px;color:var(--txt3);margin-top:2px}
.act-arrow{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700}
.act-from{color:var(--txt3);text-decoration:line-through}
.act-to{color:var(--p)}
.act-arrow svg{width:10px;height:10px;stroke:var(--txt3);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* EDIT MODE */
.edit-inp{width:100%;height:34px;background:var(--bg);border:1.5px solid var(--p);border-radius:var(--r);padding:0 10px;font-family:inherit;font-size:12px;color:var(--txt);outline:none;transition:border-color .15s}
.edit-inp:focus{box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.edit-row{margin-bottom:8px}
.edit-lbl{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;display:block}
.edit-actions{display:flex;gap:8px;margin-top:12px}


/* ADD LEAD MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:700;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--card);border:1px solid var(--bdr);border-radius:20px;width:100%;max-width:480px;box-shadow:0 24px 64px rgba(0,0,0,.25);display:flex;flex-direction:column;max-height:90vh;animation:modalIn .2s cubic-bezier(.4,0,.2,1)}
.modal-header{display:flex;align-items:center;padding:18px 20px;border-bottom:1px solid var(--bdr);flex-shrink:0}
.modal-title{font-size:14px;font-weight:700;color:var(--txt);flex:1}
.modal-close{width:28px;height:28px;border-radius:8px;border:1px solid var(--bdr);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--txt3);transition:all .15s;flex-shrink:0}
.modal-close:hover{background:var(--err-bg);color:var(--err-txt);border-color:var(--err)}
.modal-close svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.modal-body{padding:20px;overflow-y:auto;flex:1}
.modal-footer{padding:14px 20px;border-top:1px solid var(--bdr);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}
.mf-row{margin-bottom:12px}
.mf-row label{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:4px}
.mf-inp{width:100%;height:36px;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r);padding:0 10px;font-family:inherit;font-size:12px;color:var(--txt);outline:none;transition:border-color .15s}
.mf-inp:focus{border-color:var(--p);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.mf-inp::placeholder{color:var(--txt3)}
.mf-row select.mf-inp{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%239ca3af'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;cursor:pointer}
.mf-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.mf-ta{width:100%;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r);padding:8px 10px;font-family:inherit;font-size:12px;color:var(--txt);outline:none;resize:none;min-height:64px;transition:border-color .15s;line-height:1.5}
.mf-ta:focus{border-color:var(--p)}
.mf-ta::placeholder{color:var(--txt3)}
@keyframes modalIn{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}

@media(max-width:640px){
  .drawer{width:100%}
  .mf-grid{grid-template-columns:1fr}
}

/* Settings hover dropdown */
.settings-nav{position:relative;display:inline-flex}
.settings-nav .ntab{display:flex;align-items:center;gap:4px}
.settings-nav .ntab svg{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;transition:transform .2s}
.settings-nav:hover .ntab svg{transform:rotate(180deg)}
.settings-drop{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--card);border:1px solid var(--bdr);border-radius:var(--r2);box-shadow:0 8px 32px rgba(0,0,0,.18);z-index:300;overflow:hidden;min-width:190px;opacity:0;pointer-events:none;transform:translateX(-50%) translateY(-4px);transition:opacity .15s,transform .15s}
.settings-nav:hover .settings-drop{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
.settings-drop-item{display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:12px;font-weight:600;color:var(--txt2);cursor:pointer;transition:background .1s;text-decoration:none}
.settings-drop-item:hover{background:var(--card2);color:var(--txt)}
.settings-drop-item svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;color:var(--txt3)}
.settings-drop-item:hover svg{color:var(--p)}
.settings-drop-divider{height:1px;background:var(--bdr);margin:3px 0}

/* All Chats drawer */
.chats-drawer{position:fixed;top:0;right:0;height:100%;width:560px;max-width:100%;background:var(--card);border-left:1px solid var(--bdr);z-index:202;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.25)}
.chats-drawer.open{transform:translateX(0)}
.chats-drawer-hdr{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--bdr);flex-shrink:0;background:var(--card2)}
.chats-drawer-title{font-size:14px;font-weight:700;color:var(--txt);flex:1}
.chats-filters{display:flex;align-items:center;gap:6px;padding:10px 14px;border-bottom:1px solid var(--bdr);flex-shrink:0;flex-wrap:wrap}
.chats-list{flex:1;overflow-y:auto}
.chat-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--bdr);cursor:pointer;transition:background .1s}
.chat-row:hover{background:var(--card2)}
.chat-row.selected{background:var(--p-tint)}
.chat-row.is-deleted{opacity:.4}
.chat-av{width:32px;height:32px;border-radius:50%;background:var(--p-tint);color:var(--p);font-weight:800;font-size:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.chat-info{flex:1;min-width:0}
.chat-name{font-size:12px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-sub{font-size:10px;color:var(--txt3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.chat-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0}
.chat-time{font-size:10px;color:var(--txt3)}
.chat-detail{flex:1;overflow-y:auto;display:none;flex-direction:column}
.chat-detail.visible{display:flex}
.cd-hdr{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--bdr);flex-shrink:0}
.cd-back{width:28px;height:28px;border-radius:8px;border:1px solid var(--bdr);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--txt3);transition:all .15s;flex-shrink:0}
.cd-back:hover{background:var(--card2);color:var(--txt)}
.cd-body{padding:14px;flex:1;overflow-y:auto}
.cd-section{margin-bottom:16px}
.cd-sec-lbl{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.cd-field{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.cd-field-lbl{font-size:11px;color:var(--txt3);width:60px;flex-shrink:0}
.cd-field-val{font-size:11px;color:var(--txt);flex:1}
.cd-inp{width:100%;height:28px;background:var(--bg);border:1px solid var(--bdr);border-radius:7px;padding:0 8px;font-family:inherit;font-size:11px;color:var(--txt);outline:none;transition:border-color .15s}
.cd-inp:focus{border-color:var(--p)}
.cd-actions{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--bdr);flex-shrink:0;flex-wrap:wrap}
.cd-msg{padding:6px 10px;border-radius:10px;font-size:11px;line-height:1.5;max-width:85%}
.cd-msg.user{background:var(--p);color:#fff;align-self:flex-end;border-radius:10px 10px 2px 10px}
.cd-msg.assistant{background:var(--card2);color:var(--txt);border-radius:10px 10px 10px 2px;border:1px solid var(--bdr)}
.cd-msg-wrap{display:flex;flex-direction:column;gap:6px;padding:10px 14px}
.del-confirm{background:var(--err-bg);border:1px solid var(--err);border-radius:var(--r);padding:10px 14px;margin:10px 14px;font-size:12px;color:var(--err-txt);display:none}
.del-confirm.visible{display:block}

/* ── TRASH / DELETE ── */
.trash-btn{display:flex;align-items:center;gap:5px;height:30px;padding:0 10px;border-radius:var(--r);border:1px solid var(--bdr);background:transparent;font-family:inherit;font-size:11px;font-weight:600;color:var(--txt3);cursor:pointer;transition:all .15s;white-space:nowrap}
.trash-btn:hover{border-color:var(--err);color:var(--err);background:var(--err-bg)}
.trash-btn.active{border-color:var(--err);color:var(--err);background:var(--err-bg)}
.trash-btn svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.trash-count{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;border-radius:8px;background:var(--err);color:#fff;font-size:9px;font-weight:800;padding:0 4px;line-height:1}
/* Deleted lead row styling */
tbody tr.is-deleted td{opacity:.45}
tbody tr.is-deleted:hover{background:var(--err-bg)}
.restore-btn{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:6px;border:1px solid var(--ok);background:transparent;font-family:inherit;font-size:10px;font-weight:700;color:var(--ok-txt);cursor:pointer;transition:all .15s;white-space:nowrap}
.restore-btn:hover{background:var(--ok-bg)}
/* Danger zone in drawer */
.drawer-danger{margin-top:20px;padding-top:16px;border-top:1px dashed var(--bdr)}
.drawer-danger-lbl{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.delete-lead-btn{display:flex;align-items:center;gap:6px;height:32px;padding:0 14px;border-radius:var(--r);border:1px solid var(--err-bg);background:transparent;font-family:inherit;font-size:12px;font-weight:600;color:var(--err);cursor:pointer;transition:all .15s}
.delete-lead-btn:hover{background:var(--err-bg);border-color:var(--err)}
.delete-lead-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.delete-confirm-strip{display:none;margin-top:10px;background:var(--err-bg);border:1px solid var(--err);border-radius:var(--r);padding:12px 14px}
.delete-confirm-strip.show{display:block}
.delete-confirm-strip p{font-size:12px;font-weight:600;color:var(--err-txt);margin-bottom:10px}
.delete-confirm-strip .dcs-btns{display:flex;gap:8px}
/* Undo toast special style */
.toast-undo{display:inline-flex;align-items:center;gap:5px;padding:2px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.15);font-size:11px;font-weight:700;color:#fff;cursor:pointer;transition:all .15s;margin-left:4px;flex-shrink:0}
.toast-undo:hover{background:rgba(255,255,255,.25)}
/* Empty trash banner */
.trash-banner{display:none;align-items:center;gap:10px;padding:8px 14px;background:var(--err-bg);border-bottom:1px solid var(--err);font-size:12px;color:var(--err-txt);flex-shrink:0}
.trash-banner.show{display:flex}
.trash-banner strong{font-weight:700}
.empty-trash-btn{margin-left:auto;height:26px;padding:0 12px;border-radius:7px;border:1px solid var(--err);background:transparent;font-family:inherit;font-size:11px;font-weight:700;color:var(--err);cursor:pointer;transition:all .15s}
/* Assignee avatar in grid sub-line */
.rs-assignee{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:var(--txt2);white-space:nowrap}
.rs-av{width:16px;height:16px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:8px;font-weight:800;color:#fff;flex-shrink:0}
/* Assign search dropdown */
.assign-dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:220px;background:var(--card);border:1px solid var(--bdr);border-radius:var(--r2);box-shadow:0 8px 32px rgba(0,0,0,.22);z-index:600;overflow:hidden;animation:fadeDown .15s ease}
.assign-search-inp{width:100%;height:32px;background:var(--bg);border:none;border-bottom:1px solid var(--bdr);padding:0 10px;font-family:inherit;font-size:12px;color:var(--txt);outline:none}
.assign-search-inp::placeholder{color:var(--txt3)}
.assign-list{max-height:200px;overflow-y:auto}
.assign-item{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;transition:background .1s;font-size:12px;color:var(--txt)}
.assign-item:hover{background:var(--card2)}
.assign-item.active{background:var(--p-tint);color:var(--p)}
.assign-item-av{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:#fff;flex-shrink:0}
.assign-item-name{font-size:12px;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.assign-item-role{font-size:10px;color:var(--txt3)}
.assign-unassign{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;font-size:11px;font-weight:600;color:var(--txt3);border-top:1px solid var(--bdr);transition:background .1s}
.assign-unassign:hover{background:var(--err-bg);color:var(--err)}

/* ── BELL ICON ── */
.bell-btn{position:relative;width:22px;height:22px;border-radius:6px;border:none;background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--txt3);padding:0;transition:all .15s;flex-shrink:0}
.bell-btn:hover{color:var(--txt);background:var(--card2)}
.bell-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}
/* Bell states */
.bell-btn.bell-pending{color:var(--err)}
.bell-btn.bell-pending svg{animation:bellPulse 2s ease-in-out infinite}
.bell-btn.bell-done{color:var(--ok)}
.bell-btn.bell-future{color:var(--txt2)}
/* Badge */
.bell-badge{position:absolute;top:-4px;right:-4px;min-width:14px;height:14px;border-radius:7px;background:var(--err);color:#fff;font-size:8px;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid var(--card);pointer-events:none;line-height:1}
/* Popover */
.bell-popover{position:fixed;background:var(--card);border:1px solid var(--bdr);border-radius:var(--r2);box-shadow:0 8px 32px rgba(0,0,0,.22);z-index:600;width:340px;overflow:hidden;animation:fadeDown .15s ease}
.bp-header{display:flex;align-items:center;padding:8px 12px;border-bottom:1px solid var(--bdr);background:var(--card2)}
.bp-header-title{font-size:11px;font-weight:700;color:var(--txt);text-transform:uppercase;letter-spacing:.5px}
.bp-empty{padding:14px 12px;font-size:12px;color:var(--txt3);text-align:center}
.bp-task{display:flex;align-items:flex-start;gap:8px;padding:8px 12px;border-bottom:1px solid var(--bdr)}
.bp-task:last-child{border-bottom:none}
.bp-task-icon{width:22px;height:22px;border-radius:6px;background:var(--card2);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.bp-task-icon svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.bp-task-info{flex:1;min-width:0}
.bp-task-type{font-size:10px;font-weight:700;color:var(--p);text-transform:uppercase;letter-spacing:.4px;margin-bottom:1px}
.bp-task-title{font-size:12px;font-weight:600;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bp-task-due{font-size:10px;color:var(--txt3);margin-top:2px}
.bp-task-due.overdue{color:var(--err);font-weight:600}
@keyframes bellPulse{0%,100%{transform:rotate(0deg)}20%{transform:rotate(-15deg)}40%{transform:rotate(15deg)}60%{transform:rotate(-8deg)}80%{transform:rotate(8deg)}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
/* ── BELL POPOVER QUICK-ADD ── */
.bp-actions{display:flex;align-items:center;gap:4px;padding:8px 12px;border-bottom:1px solid var(--bdr)}
.bp-actions-lbl{font-size:10px;font-weight:600;color:var(--txt3);margin-right:4px;white-space:nowrap}
.bp-action-btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;height:26px;padding:0 9px;border-radius:6px;border:none;background:transparent;cursor:pointer;font-family:inherit;font-size:11px;font-weight:600;color:var(--txt3);transition:all .15s;white-space:nowrap}
.bp-action-btn:hover{background:var(--card2);color:var(--txt)}
.bp-action-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.bp-action-btn.call:hover{color:var(--warn)}
.bp-action-btn.email:hover{color:var(--p)}
.bp-action-btn.note:hover{color:var(--ok)}
.bp-action-btn.custom:hover{color:var(--txt)}

/* ── ROW ACTION ICONS ── */
.row-actions{display:flex;align-items:center;gap:1px;flex-shrink:0;justify-content:flex-end}
.ra-btn{display:inline-flex;align-items:center;gap:4px;height:22px;padding:0 6px;border-radius:6px;border:none;background:transparent;cursor:pointer;font-family:inherit;font-size:11px;font-weight:500;color:var(--txt3);transition:all .15s;white-space:nowrap;flex-shrink:0}
.ra-btn svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.ra-btn:hover{background:var(--card2);color:var(--txt)}
.ra-btn.ra-call svg{color:var(--p)}
@media(max-width:640px){.ra-btn .ra-lbl{display:none}.ra-btn{padding:0 5px}}
.td-updated{width:220px;min-width:220px}
/* ── TASK FORM (inline popover) ── */
.tf-wrap{padding:12px}
.tf-contact{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--card2);border-radius:var(--r);margin-bottom:10px}
.tf-contact-av{width:28px;height:28px;border-radius:50%;background:var(--p);color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tf-contact-name{font-size:12px;font-weight:700;color:var(--txt)}
.tf-contact-phone{font-size:11px;color:var(--txt3);margin-top:1px}
.tf-lbl{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.tf-inp{width:100%;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--txt);outline:none;resize:none;transition:border-color .15s}
.tf-inp:focus{border-color:var(--p);box-shadow:0 0 0 2px rgba(37,99,235,.1)}
.tf-inp::placeholder{color:var(--txt3)}
.tf-due{display:flex;gap:4px;flex-wrap:nowrap;margin:8px 0;overflow-x:auto;scrollbar-width:none}
.tf-due::-webkit-scrollbar{display:none}
.tf-due-btn{height:22px;padding:0 8px;border-radius:var(--r3);border:1px solid var(--bdr);background:transparent;font-family:inherit;font-size:10px;font-weight:600;color:var(--txt3);cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}
.tf-due-btn:hover,.tf-due-btn.active{background:var(--p-tint);color:var(--p);border-color:var(--p-border)}
.tf-footer{display:flex;gap:6px;padding-top:10px;border-top:1px solid var(--bdr);margin-top:10px}
.tf-save{flex:1;height:30px;background:var(--p);border:none;border-radius:var(--r);font-family:inherit;font-size:12px;font-weight:700;color:#fff;cursor:pointer;transition:background .15s}
.tf-save:hover{background:var(--pd)}
.tf-save:disabled{opacity:.6;cursor:not-allowed}
.tf-cancel{height:30px;padding:0 12px;background:transparent;border:1px solid var(--bdr);border-radius:var(--r);font-family:inherit;font-size:12px;font-weight:600;color:var(--txt3);cursor:pointer;transition:all .15s}
.tf-cancel:hover{color:var(--txt);border-color:var(--bdr2)}

/* ── BELL TASK ACTION BUTTONS ── */
.bp-act-btn{width:24px;height:24px;border-radius:6px;border:1px solid var(--bdr);background:transparent;cursor:pointer;font-size:12px;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.bp-done:hover{background:var(--ok-bg);border-color:var(--ok);color:var(--ok-txt)}
.bp-snooze:hover{background:var(--p-tint);border-color:var(--p-border)}
/* Expand area inside task row — visually distinct sub-section.
   Negative margins break it out of the icon column so it spans the full
   popover width, centred within the popover (not the screen). Darker tint
   + top/bottom borders make it read as an inset drawer below the row. */
.bp-expand{
  margin:8px -12px -8px -42px;
  padding:12px 14px;
  background:var(--card2);
  border-top:1px solid var(--bdr);
  border-bottom:1px solid var(--bdr);
  box-shadow:inset 0 1px 0 rgba(0,0,0,.04);
  animation:bpExpandIn .18s ease;
}
[data-theme="dark"] .bp-expand{
  background:#0a1220;
  box-shadow:inset 0 2px 4px rgba(0,0,0,.3);
}
@keyframes bpExpandIn{from{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}

/* ── SNOOZE ANIMATION ── */
@keyframes snoozePop{0%{transform:scale(1)}30%{transform:scale(1.8)}65%{transform:scale(.85)}85%{transform:scale(1.1)}100%{transform:scale(1)}}
@keyframes snoozeSlide{0%{opacity:1;transform:translateX(0)}100%{opacity:0;transform:translateX(16px)}}
@keyframes snoozeFadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.snooze-pop{animation:snoozePop .7s cubic-bezier(.4,0,.2,1) forwards}
.snooze-slide{animation:snoozeSlide .5s ease forwards}
.snooze-fadein{animation:snoozeFadeIn .4s ease forwards}
/* ── EMAIL NOW/LATER form ── */
.email-nl-opts{display:flex;gap:8px;padding:12px}
.email-nl-btn{flex:1;height:36px;border-radius:var(--r);border:1px solid var(--bdr);background:var(--card2);font-family:inherit;font-size:12px;font-weight:700;color:var(--txt);cursor:pointer;transition:all .15s}
.email-nl-btn:hover{background:var(--p-tint);color:var(--p);border-color:var(--p-border)}
.email-nl-btn.primary{background:var(--p);color:#fff;border-color:var(--p)}
.email-nl-btn.primary:hover{background:var(--pd)}

/* ── Follow-up prompt (inside drawer after send) ── */
.followup-prompt{background:var(--p-tint);border:2px solid var(--p-border);border-radius:var(--r2);padding:14px 16px;margin:0 0 16px;animation:fadeDown .3s ease}
.followup-prompt-title{font-size:13px;font-weight:700;color:var(--txt);margin-bottom:10px}
.followup-prompt-pills{display:flex;gap:6px;flex-wrap:wrap}
@keyframes followupPulse{0%,100%{border-color:var(--p-border)}50%{border-color:var(--p);box-shadow:0 0 0 3px var(--p-tint)}}
.followup-pill{height:28px;padding:0 14px;border-radius:var(--r3);border:1px solid var(--bdr);background:transparent;font-family:inherit;font-size:11px;font-weight:600;color:var(--txt3);cursor:pointer;transition:all .15s}
.followup-pill:hover{background:var(--p-tint);color:var(--p);border-color:var(--p-border)}
.followup-pill.skip{color:var(--txt3)}
.followup-pill.skip:hover{background:var(--card);color:var(--txt);border-color:var(--bdr2)}
/* ═══════════════════════════════════════════════════════════
   NEXT BEST MOVE — append to bottom of leads.css
   ═══════════════════════════════════════════════════════════ */

/* ── NBM trigger button (next to score badge) ─────────────── */
.nbm-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 11px 4px 9px;
  border-radius: 20px;
  border: 1.5px solid var(--bdr2);
  background: transparent;
  font-family: inherit;
  font-size: 11px;
  font-weight: 700;
  color: var(--txt3);
  cursor: pointer;
  transition: all .18s ease;
  letter-spacing: .01em;
  white-space: nowrap;
  flex-shrink: 0;
}
.nbm-btn:hover {
  border-color: var(--purple, #a78bfa);
  color: var(--purple, #a78bfa);
  background: rgba(167,139,250,.08);
}
/* Active state: analysis exists — button glows */
.nbm-btn.has-analysis {
  border-color: var(--purple, #a78bfa);
  color: var(--purple, #a78bfa);
  background: rgba(167,139,250,.1);
  box-shadow: 0 0 0 3px rgba(167,139,250,.12);
}
.nbm-btn svg {
  flex-shrink: 0;
  transition: transform .2s ease;
}
.nbm-btn.loading svg {
  animation: nbmSpin .7s linear infinite;
}
@keyframes nbmSpin { to { transform: rotate(360deg); } }

/* ── NBM Card ─────────────────────────────────────────────── */
.nbm-card {
  margin: 10px 0 4px;
  border-radius: 12px;
  border: 1px solid rgba(167,139,250,.2);
  background: linear-gradient(145deg, rgba(167,139,250,.06), rgba(59,130,246,.04));
  overflow: hidden;
  animation: nbmSlideIn .25s cubic-bezier(.4,0,.2,1);
}
@keyframes nbmSlideIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Loading */
.nbm-loading {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 18px 16px;
}
.nbm-spinner {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid rgba(167,139,250,.25);
  border-top-color: var(--purple, #a78bfa);
  animation: nbmSpin .7s linear infinite;
  flex-shrink: 0;
}
.nbm-loading-txt {
  font-size: 12px;
  color: var(--txt3);
  font-weight: 500;
}
.nbm-dots span {
  animation: nbmDot 1.2s ease-in-out infinite;
  opacity: 0;
}
.nbm-dots span:nth-child(1) { animation-delay: 0s; }
.nbm-dots span:nth-child(2) { animation-delay: .2s; }
.nbm-dots span:nth-child(3) { animation-delay: .4s; }
@keyframes nbmDot { 0%,80%,100%{opacity:0} 40%{opacity:1} }

/* Result container */
.nbm-result { padding: 14px 15px 12px; }

/* Top row: gauge + meta */
.nbm-top {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
}
.nbm-gauge-wrap { flex-shrink: 0; }
.nbm-gauge-svg  { width: 72px; height: 72px; }
.nbm-gauge-track { stroke: rgba(255,255,255,.06); }
.nbm-gauge-arc {
  transition: stroke-dashoffset 1s cubic-bezier(.4,0,.2,1),
              stroke .4s ease;
}
/* Gauge arc colours set via JS: */
/* Cold  → #f87171  (red)   */
/* Warm  → #f59e0b  (amber) */
/* Hot   → #10b981  (green) */
.nbm-gauge-pct {
  font-family: 'Syne', 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 700;
  fill: var(--txt);
}
.nbm-top-right { flex: 1; min-width: 0; }
.nbm-label-row {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 2px;
}
.nbm-label {
  font-size: 13px;
  font-weight: 700;
  font-family: 'Syne', sans-serif;
}
/* Set colour via JS based on label */
.nbm-label.Cold  { color: #f87171; }
.nbm-label.Warm  { color: #f59e0b; }
.nbm-label.Hot   { color: #10b981; }
.nbm-ts {
  font-size: 10px;
  color: var(--txt4, #4a6a87);
  font-weight: 400;
}
.nbm-outlook-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--txt3);
  margin-bottom: 6px;
  letter-spacing: .02em;
}
.nbm-reanalyse {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 6px;
  border: 1px solid var(--bdr2);
  background: transparent;
  font-family: inherit;
  font-size: 10px;
  font-weight: 600;
  color: var(--txt3);
  cursor: pointer;
  transition: all .15s;
}
.nbm-reanalyse:hover {
  border-color: var(--purple, #a78bfa);
  color: var(--purple, #a78bfa);
}

/* Why: signal list */
.nbm-signals-head {
  font-size: 10.5px;
  font-weight: 600;
  color: var(--txt3);
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: 7px;
}
.nbm-signals {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 10px;
}
.nbm-signal {
  display: flex;
  align-items: flex-start;
  gap: 7px;
  font-size: 11.5px;
  line-height: 1.45;
  color: var(--txt2);
  animation: nbmSlideIn .2s ease both;
}
.nbm-signal-icon {
  font-size: 11px;
  flex-shrink: 0;
  margin-top: 1px;
  font-weight: 700;
}
.nbm-signal.pos .nbm-signal-icon { color: #10b981; }
.nbm-signal.neg .nbm-signal-icon { color: #f87171; }

/* Blocks: if-nothing / best-move */
.nbm-block {
  border-radius: 8px;
  padding: 9px 11px;
  margin-bottom: 7px;
  border: 1px solid;
}
.nbm-block:last-child { margin-bottom: 0; }
.nbm-block-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 4px;
}
.nbm-block-body {
  font-size: 12px;
  line-height: 1.55;
  font-weight: 500;
}
.nbm-block-warn {
  background: rgba(245,158,11,.07);
  border-color: rgba(245,158,11,.2);
}
.nbm-block-warn .nbm-block-label { color: #f59e0b; }
.nbm-block-warn .nbm-block-body  { color: var(--txt2); }
.nbm-block-action {
  background: rgba(59,130,246,.08);
  border-color: rgba(59,130,246,.2);
}
.nbm-block-action .nbm-block-label { color: var(--pl, #60a5fa); }
.nbm-block-action .nbm-block-body  { color: var(--txt); }

.filter-reset-btn {
  background: var(--bg2, #1e293b);
  border: 1px solid var(--brd, #334155);
  border-radius: 8px;
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--txt2, #94a3b8);
  cursor: pointer;
  transition: all 0.15s ease;
  opacity: 0.5;
  flex-shrink: 0;
}
.filter-reset-btn:hover {
  background: var(--bg3, #334155);
  color: var(--txt, #f8fafc);
  opacity: 1;
  transform: rotate(-45deg);
}
.filter-reset-btn.has-filters {
  opacity: 1;
  border-color: var(--p, #2563eb);
  color: var(--p, #2563eb);
}
  
/* ── Tab indicator dot (when research exists) ─────────────────────────── */
.dtab-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--cyan, #22d3ee);
  margin-left: 5px;
  vertical-align: middle;
  box-shadow: 0 0 0 2px rgba(34,211,238,.18);
}
 
/* ── Empty State ──────────────────────────────────────────────────────── */
.research-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 38px 20px 32px;
  gap: 10px;
}
.research-empty-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(34,211,238,.10);
  border: 1px solid rgba(34,211,238,.25);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cyan, #22d3ee);
  margin-bottom: 4px;
}
.research-empty-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--txt1);
  margin-top: 4px;
}
.research-empty-sub {
  font-size: 12px;
  line-height: 1.55;
  color: var(--txt3);
  max-width: 380px;
  margin-bottom: 8px;
}
.research-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  border-radius: 8px;
  border: 1px solid var(--cyan, #22d3ee);
  background: var(--cyan, #22d3ee);
  font-family: inherit;
  font-size: 12px;
  font-weight: 700;
  color: #06212a;
  cursor: pointer;
  transition: all .18s ease;
}
.research-cta-btn:hover:not(:disabled) {
  filter: brightness(1.1);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(34,211,238,.25);
}
.research-cta-btn:disabled {
  opacity: .55;
  cursor: not-allowed;
}
.research-empty-foot {
  font-size: 10px;
  color: var(--txt3);
  margin-top: 6px;
  letter-spacing: .02em;
}
 
/* ── Loading State ────────────────────────────────────────────────────── */
.research-loading {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 28px 20px;
  border-radius: 12px;
  border: 1px solid rgba(34,211,238,.18);
  background: linear-gradient(145deg, rgba(34,211,238,.06), rgba(59,130,246,.04));
}
.research-spinner {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid rgba(34,211,238,.25);
  border-top-color: var(--cyan, #22d3ee);
  animation: researchSpin .7s linear infinite;
  flex-shrink: 0;
}
@keyframes researchSpin { to { transform: rotate(360deg); } }
.research-loading-stack {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
.research-loading-txt {
  font-size: 13px;
  color: var(--txt2);
  font-weight: 600;
}
.research-loading-step {
  font-size: 11px;
  color: var(--txt3);
  font-weight: 500;
}
.research-dots span {
  animation: researchDot 1.2s ease-in-out infinite;
  opacity: 0;
}
.research-dots span:nth-child(1) { animation-delay: 0s; }
.research-dots span:nth-child(2) { animation-delay: .2s; }
.research-dots span:nth-child(3) { animation-delay: .4s; }
@keyframes researchDot {
  0%, 60%, 100% { opacity: 0; }
  30%           { opacity: 1; }
}
 
/* ── Error State ──────────────────────────────────────────────────────── */
.research-error {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 10px;
  border: 1px solid rgba(248,113,113,.3);
  background: rgba(248,113,113,.06);
}
.research-error-stack {
  flex: 1;
  min-width: 0;
}
.research-error-title {
  font-size: 12px;
  font-weight: 700;
  color: #f87171;
  margin-bottom: 2px;
}
.research-error-msg {
  font-size: 11px;
  color: var(--txt3);
  word-break: break-word;
}
.research-retry-btn {
  font-family: inherit;
  font-size: 11px;
  font-weight: 700;
  color: #f87171;
  background: transparent;
  border: 1px solid #f87171;
  border-radius: 6px;
  padding: 5px 12px;
  cursor: pointer;
  flex-shrink: 0;
}
.research-retry-btn:hover {
  background: rgba(248,113,113,.1);
}
 
/* ── Result: Header ───────────────────────────────────────────────────── */
.research-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(34,211,238,.2);
  background: linear-gradient(145deg, rgba(34,211,238,.07), rgba(59,130,246,.04));
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.research-header-left {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.research-header-icon {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: rgba(34,211,238,.15);
  border: 1px solid rgba(34,211,238,.3);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cyan, #22d3ee);
  flex-shrink: 0;
}
.research-header-text { min-width: 0; }
.research-header-title {
  font-size: 13px;
  font-weight: 800;
  color: var(--txt1);
  letter-spacing: .01em;
  word-break: break-word;
}
.research-header-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 2px;
  flex-wrap: wrap;
}
.research-confidence {
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 2px 6px;
  border-radius: 4px;
  border: 1px solid;
}
.research-confidence.conf-high   { color: #16a34a; border-color: rgba(22,163,74,.4);  background: rgba(22,163,74,.08); }
.research-confidence.conf-medium { color: #d97706; border-color: rgba(217,119,6,.4);  background: rgba(217,119,6,.08); }
.research-confidence.conf-low    { color: #dc2626; border-color: rgba(220,38,38,.4);  background: rgba(220,38,38,.08); }
.research-meta {
  font-size: 10px;
  font-weight: 600;
  color: var(--txt3);
}
 
.research-reanalyse-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: inherit;
  font-size: 10px;
  font-weight: 700;
  color: var(--txt3);
  background: transparent;
  border: 1px solid var(--bdr);
  border-radius: 6px;
  padding: 5px 11px;
  cursor: pointer;
  transition: all .15s ease;
  flex-shrink: 0;
}
.research-reanalyse-btn:hover {
  color: var(--cyan, #22d3ee);
  border-color: var(--cyan, #22d3ee);
  background: rgba(34,211,238,.08);
}
 
/* ── Result: section labels ───────────────────────────────────────────── */
.research-section-lbl {
  font-size: 9px;
  font-weight: 800;
  color: var(--txt3);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.research-src-tag {
  font-size: 9px;
  font-weight: 600;
  color: var(--txt3);
  text-transform: none;
  letter-spacing: 0;
  font-style: italic;
  opacity: .8;
}
 
/* ── Summary block ────────────────────────────────────────────────────── */
.research-summary-block { margin-bottom: 14px; }
.research-summary {
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--txt2);
  padding: 10px 12px;
  background: var(--card2, rgba(255,255,255,.025));
  border: 1px solid var(--bdr);
  border-radius: 8px;
}
 
/* ── Quick-facts grid ─────────────────────────────────────────────────── */
.research-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
  margin-bottom: 14px;
}
.research-cell {
  background: var(--card2, rgba(255,255,255,.03));
  border: 1px solid var(--bdr);
  border-radius: 8px;
  padding: 7px 9px;
  min-width: 0;
}
.research-cell-wide { grid-column: 1 / -1; }
.research-cell-lbl {
  font-size: 9px;
  font-weight: 800;
  color: var(--txt3);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: 3px;
}
.research-cell-val {
  font-size: 12px;
  font-weight: 600;
  color: var(--txt1);
  word-break: break-word;
}
 
/* ── Sections wrapper ─────────────────────────────────────────────────── */
.research-section { margin-bottom: 14px; }
 
/* ── Key People ───────────────────────────────────────────────────────── */
.research-people {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.research-person {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 7px 9px;
  background: var(--card2, rgba(255,255,255,.025));
  border: 1px solid var(--bdr);
  border-radius: 8px;
}
.research-person-avatar {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: rgba(34,211,238,.15);
  color: var(--cyan, #22d3ee);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 800;
  flex-shrink: 0;
}
.research-person-text {
  flex: 1;
  min-width: 0;
}
.research-person-name {
  font-size: 12px;
  font-weight: 700;
  color: var(--txt1);
}
.research-person-role {
  font-size: 11px;
  color: var(--txt3);
  font-weight: 500;
}
 
/* ── Recent News ──────────────────────────────────────────────────────── */
.research-news {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.research-news-item {
  display: block;
  padding: 8px 10px;
  background: var(--card2, rgba(255,255,255,.025));
  border: 1px solid var(--bdr);
  border-radius: 8px;
  text-decoration: none;
  transition: all .15s ease;
}
.research-news-item:hover {
  border-color: rgba(34,211,238,.4);
  background: rgba(34,211,238,.05);
}
.research-news-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--txt1);
  line-height: 1.4;
  margin-bottom: 3px;
}
.research-news-meta {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  color: var(--txt3);
  font-weight: 500;
}
.research-news-dot {
  width: 2px;
  height: 2px;
  border-radius: 50%;
  background: var(--txt3);
  display: inline-block;
}
 
/* ── Chips (products) ─────────────────────────────────────────────────── */
.research-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.research-chip {
  font-size: 11px;
  font-weight: 600;
  color: var(--txt2);
  background: rgba(34,211,238,.10);
  border: 1px solid rgba(34,211,238,.25);
  border-radius: 999px;
  padding: 2px 9px;
}
 
/* ── Signals ──────────────────────────────────────────────────────────── */
.research-signals {
  margin: 0;
  padding: 0 0 0 16px;
  font-size: 12px;
  line-height: 1.65;
  color: var(--txt2);
}
.research-signals li { margin-bottom: 3px; }
 
/* ── Social ───────────────────────────────────────────────────────────── */
.research-social {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.research-social-link {
  font-size: 11px;
  font-weight: 600;
  color: var(--cyan, #22d3ee);
  text-decoration: none;
  padding: 4px 10px;
  border: 1px solid rgba(34,211,238,.3);
  border-radius: 6px;
  transition: all .15s ease;
}
.research-social-link:hover {
  background: rgba(34,211,238,.1);
}
 
/* ── Generic link ─────────────────────────────────────────────────────── */
.research-link {
  color: var(--cyan, #22d3ee);
  text-decoration: none;
  font-weight: 600;
}
.research-link:hover { text-decoration: underline; }
 
/* ── Source badges (live / ai / both) ─────────────────────────────────── */
.research-src-badge {
  display: inline-block;
  font-size: 8.5px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 1px 6px;
  border-radius: 4px;
  margin-left: 6px;
  vertical-align: middle;
}
.research-src-badge.src-live { background: rgba(22,163,74,.12); color: #22c55e; border: 1px solid rgba(34,197,94,.3); }
.research-src-badge.src-ai   { background: rgba(167,139,250,.12); color: #a78bfa; border: 1px solid rgba(167,139,250,.3); }
.research-src-badge.src-both { background: rgba(34,211,238,.12); color: var(--cyan, #22d3ee); border: 1px solid rgba(34,211,238,.3); }
 
/* ── Sources panel (collapsible) ──────────────────────────────────────── */
.research-sources-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 9px 11px;
  background: transparent;
  border: 1px solid var(--bdr);
  border-radius: 8px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 700;
  color: var(--txt2);
  cursor: pointer;
  transition: all .15s ease;
}
.research-sources-toggle:hover {
  background: var(--card2, rgba(255,255,255,.025));
  border-color: var(--bdr2);
}
.research-sources-count {
  font-size: 10px;
  color: var(--txt3);
  font-weight: 600;
  margin-left: auto;
}
.research-sources-chev {
  transition: transform .2s ease;
  color: var(--txt3);
  flex-shrink: 0;
}
.research-sources-body {
  margin-top: 8px;
  padding: 11px 13px;
  background: var(--card2, rgba(255,255,255,.025));
  border: 1px solid var(--bdr);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 11px;
}
.research-src-group {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.research-src-group-lbl {
  font-size: 9px;
  font-weight: 800;
  color: var(--txt3);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: 2px;
}
.research-src-link {
  font-size: 11px;
  color: var(--cyan, #22d3ee);
  text-decoration: none;
  padding: 3px 0;
  border-bottom: 1px dashed transparent;
  word-break: break-word;
  line-height: 1.4;
}
.research-src-link:hover {
  border-bottom-color: rgba(34,211,238,.4);
}
.research-src-meta {
  font-size: 10px;
  color: var(--txt3);
  font-weight: 500;
}
.dtab-beta{display:inline-block;font-size:8.5px;font-weight:800;padding:1px 5px;margin-left:4px;border-radius:3px;background:#dc2626;color:#fff;vertical-align:middle;letter-spacing:.05em}