/* ═══════════════════════════════════════════════════════
   ShamrockLeads Intelligence Dashboard — Fortune 50 UI
   ═══════════════════════════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box}

/* ── Theme Variables ── */
[data-theme="dark"]{
  --bg:#06090f;--surface:#0d1117;--card:#131a27;--card-hover:#1a2436;
  --border:rgba(255,255,255,.06);--border-accent:rgba(16,185,129,.15);
  --text:#e2e8f0;--text-secondary:#94a3b8;--muted:#475569;
  --hover:rgba(16,185,129,.04);--chart-grid:rgba(255,255,255,.05);
  --table-stripe:rgba(255,255,255,.015);--toggle-bg:#1e293b;--toggle-knob:#e2e8f0;
  --glow:0 0 40px rgba(16,185,129,.08);--input-bg:#0d1117;
  --badge-bg:rgba(16,185,129,.1);--badge-text:#34d399;
  --profile-gradient:linear-gradient(135deg,rgba(16,185,129,.08),rgba(59,130,246,.06));
  --shadow-card:0 1px 3px rgba(0,0,0,.3),0 0 0 1px rgba(255,255,255,.03);
}
[data-theme="light"]{
  --bg:#f8fafc;--surface:#ffffff;--card:#ffffff;--card-hover:#f1f5f9;
  --border:rgba(0,0,0,.08);--border-accent:rgba(16,185,129,.2);
  --text:#0f172a;--text-secondary:#475569;--muted:#94a3b8;
  --hover:rgba(16,185,129,.04);--chart-grid:rgba(0,0,0,.06);
  --table-stripe:rgba(0,0,0,.015);--toggle-bg:#cbd5e1;--toggle-knob:#0f172a;
  --glow:0 0 40px rgba(16,185,129,.06);--input-bg:#f8fafc;
  --badge-bg:rgba(16,185,129,.08);--badge-text:#059669;
  --profile-gradient:linear-gradient(135deg,rgba(16,185,129,.04),rgba(59,130,246,.03));
  --shadow-card:0 1px 3px rgba(0,0,0,.08),0 0 0 1px rgba(0,0,0,.04);
}
:root{--accent:#10b981;--accent-light:#34d399;--gold:#f59e0b;--red:#ef4444;--blue:#3b82f6;--purple:#8b5cf6;--cyan:#06b6d4;--pink:#ec4899;--radius:14px;--radius-sm:10px;--transition:all .25s cubic-bezier(.4,0,.2,1)}

body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;transition:background .3s,color .3s;-webkit-font-smoothing:antialiased}

/* ── Header ── */
.header{background:linear-gradient(135deg,#064e3b 0%,#0a1628 40%,#1e1b4b 100%);padding:14px 28px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;position:sticky;top:0;z-index:100;backdrop-filter:blur(20px)}
[data-theme="light"] .header{background:linear-gradient(135deg,#059669 0%,#0284c7 50%,#4f46e5 100%)}
.header-left{display:flex;align-items:center;gap:14px}
.header-logo{height:38px;width:auto;border-radius:8px}
.header h1{font-size:18px;font-weight:700;color:#fff;letter-spacing:-.3px}
.header h1 small{display:block;font-size:10px;font-weight:400;color:rgba(255,255,255,.5);margin-top:2px;letter-spacing:.5px;text-transform:uppercase}
.header-right{display:flex;align-items:center;gap:14px}
.live{display:flex;align-items:center;gap:6px;color:var(--accent);font-size:12px;font-weight:600;letter-spacing:.5px}
.live::before{content:'';width:7px;height:7px;background:var(--accent);border-radius:50%;animation:pulse 2s infinite;box-shadow:0 0 8px var(--accent)}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.meta{color:rgba(255,255,255,.4);font-size:11px}
.refresh-btn{background:rgba(16,185,129,.15);color:var(--accent-light);border:1px solid rgba(16,185,129,.2);padding:7px 16px;border-radius:8px;font-weight:600;cursor:pointer;font-size:12px;transition:var(--transition);font-family:inherit;backdrop-filter:blur(8px)}
.refresh-btn:hover{background:rgba(16,185,129,.25);transform:translateY(-1px);box-shadow:0 4px 12px rgba(16,185,129,.2)}

/* ── Theme Toggle ── */
.theme-toggle{display:flex;align-items:center;gap:6px;cursor:pointer}
.theme-toggle span{font-size:13px}
.toggle-track{width:40px;height:22px;background:var(--toggle-bg);border-radius:11px;position:relative;transition:background .3s}
.toggle-knob{width:16px;height:16px;background:var(--toggle-knob);border-radius:50%;position:absolute;top:3px;left:3px;transition:transform .3s}
[data-theme="dark"] .toggle-knob{transform:translateX(18px)}

/* ── Tab Navigation ── */
.tab-bar{display:flex;gap:2px;padding:0 28px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:66px;z-index:99}
.tab-btn{padding:14px 24px;font-size:13px;font-weight:600;color:var(--muted);border:none;background:none;cursor:pointer;position:relative;font-family:inherit;transition:color .2s;display:flex;align-items:center;gap:8px}
.tab-btn:hover{color:var(--text-secondary)}
.tab-btn.active{color:var(--accent)}
.tab-btn.active::after{content:'';position:absolute;bottom:0;left:12px;right:12px;height:2px;background:var(--accent);border-radius:2px 2px 0 0}
.tab-btn .badge{background:var(--badge-bg);color:var(--badge-text);padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700}
.tab-content{display:none}
.tab-content.active{display:block}

/* ── Layout ── */
.container{max-width:1480px;margin:0 auto;padding:24px 28px}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:24px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden;transition:var(--transition);box-shadow:var(--shadow-card)}
.stat-card:hover{border-color:var(--border-accent);box-shadow:var(--glow)}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.stat-card:nth-child(1)::before{background:linear-gradient(90deg,var(--accent),var(--cyan))}
.stat-card:nth-child(2)::before{background:linear-gradient(90deg,var(--blue),var(--purple))}
.stat-card:nth-child(3)::before{background:linear-gradient(90deg,var(--gold),#fb923c)}
.stat-card:nth-child(4)::before{background:linear-gradient(90deg,var(--purple),var(--pink))}
.stat-card:nth-child(5)::before{background:linear-gradient(90deg,var(--red),#f97316)}
.stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:8px;font-weight:600}
.stat-value{font-size:28px;font-weight:800;letter-spacing:-1.5px;background:linear-gradient(135deg,var(--text),var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-sub{font-size:10px;color:var(--muted);margin-top:6px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:24px}
.grid-3{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-bottom:24px}
@media(max-width:900px){.grid-2,.grid-3{grid-template-columns:1fr}}

/* ── Panels ── */
.panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:var(--transition);box-shadow:var(--shadow-card)}
.panel:hover{border-color:var(--border-accent)}
.panel-title{font-size:14px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px;letter-spacing:-.2px}

/* ── County List ── */
.county-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}
.county-row:last-child{border:none}
.county-name{font-weight:600;font-size:13px}
.county-count{background:var(--badge-bg);color:var(--badge-text);padding:4px 10px;border-radius:20px;font-size:12px;font-weight:700}
.county-bond{color:var(--accent);font-size:12px;font-weight:600}

/* ── Tables ── */
.table-wrap{overflow-x:auto;margin-top:10px}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);color:var(--muted);font-weight:600;text-transform:uppercase;font-size:10px;letter-spacing:.8px;cursor:pointer;user-select:none;white-space:nowrap}
th:hover{color:var(--accent)}
td{padding:10px 12px;border-bottom:1px solid var(--border);white-space:nowrap}
tr:hover td{background:var(--hover)}
.bond-high{color:#f87171;font-weight:700}
.bond-mid{color:#fbbf24;font-weight:600}
.bond-low{color:var(--muted)}

/* ── Filters ── */
.filters{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
.filters select,.filters input{background:var(--input-bg);border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:var(--radius-sm);font-size:13px;font-family:inherit;transition:var(--transition)}
.filters select:focus,.filters input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(16,185,129,.1)}
.pagination{display:flex;gap:8px;align-items:center;justify-content:center;margin-top:16px}
.pagination button{background:var(--card);border:1px solid var(--border);color:var(--text);padding:7px 16px;border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-family:inherit;transition:var(--transition);font-weight:500}
.pagination button:hover{border-color:var(--accent);color:var(--accent)}
.pagination button:disabled{opacity:.25;cursor:not-allowed}
.pagination span{color:var(--muted);font-size:12px}

/* ── Misc ── */
canvas{max-height:280px}
.loading{text-align:center;padding:40px;color:var(--muted);font-size:13px}
.charges-list{list-style:none}
.charges-list li{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border);font-size:13px}
.charges-list li:last-child{border:none}

/* ═══════════════════════════════════════════════════════
   DEFENDANT PROFILES TAB
   ═══════════════════════════════════════════════════════ */
.defendant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(460px,1fr));gap:18px}
@media(max-width:520px){.defendant-grid{grid-template-columns:1fr}}

.def-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:var(--transition);box-shadow:var(--shadow-card);position:relative}
.def-card:hover{border-color:var(--border-accent);box-shadow:var(--glow);transform:translateY(-2px)}

.def-card-header{background:var(--profile-gradient);padding:18px 20px 14px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.def-name{font-size:17px;font-weight:800;letter-spacing:-.3px;line-height:1.2}
.def-booking{font-size:11px;color:var(--muted);margin-top:3px;font-family:'SF Mono',monospace,Consolas;letter-spacing:.3px}
.def-bond-pill{font-size:16px;font-weight:800;padding:6px 14px;border-radius:10px;white-space:nowrap;letter-spacing:-.5px}
.def-bond-pill.high{background:rgba(239,68,68,.12);color:#f87171;border:1px solid rgba(239,68,68,.15)}
.def-bond-pill.mid{background:rgba(251,191,36,.1);color:#fbbf24;border:1px solid rgba(251,191,36,.15)}
.def-bond-pill.low{background:rgba(100,116,139,.1);color:var(--muted);border:1px solid var(--border)}

.def-body{padding:16px 20px}
.def-section{margin-bottom:14px}
.def-section:last-child{margin-bottom:0}
.def-section-title{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--accent);font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.def-row{display:grid;grid-template-columns:1fr 1fr;gap:4px 16px;font-size:13px}
.def-row.wide{grid-template-columns:1fr}
.def-field{display:flex;flex-direction:column;padding:4px 0}
.def-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:500}
.def-value{font-weight:500;margin-top:1px;word-break:break-word;white-space:normal}
.def-value.mono{font-family:'SF Mono',monospace,Consolas;font-size:12px;letter-spacing:.3px}

.def-charges-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:6px}
.def-charges-table th{padding:6px 8px;text-align:left;font-size:10px;color:var(--muted);border-bottom:1px solid var(--border);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.def-charges-table td{padding:7px 8px;border-bottom:1px solid var(--border);vertical-align:top}
.def-charges-table tr:last-child td{border:none}

.def-status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.3px}
.def-status-badge.custody{background:rgba(239,68,68,.1);color:#f87171}
.def-status-badge.released{background:rgba(16,185,129,.1);color:#34d399}
.def-status-badge.other{background:rgba(100,116,139,.1);color:var(--text-secondary)}

.def-card-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;background:rgba(0,0,0,.02)}
[data-theme="dark"] .def-card-footer{background:rgba(0,0,0,.15)}

.btn-write-bond{display:flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--radius-sm);border:1px solid rgba(16,185,129,.3);background:rgba(16,185,129,.08);color:var(--accent-light);font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:var(--transition);letter-spacing:.2px}
.btn-write-bond:hover{background:rgba(16,185,129,.18);border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 16px rgba(16,185,129,.15)}
.btn-write-bond.active{background:var(--accent);color:#000;border-color:var(--accent)}

.btn-detail{display:flex;align-items:center;gap:5px;padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;transition:var(--transition)}
.btn-detail:hover{border-color:var(--text-secondary);color:var(--text)}

/* ── Contact Indemnitor Button ── */
.btn-contact-indem{display:flex;align-items:center;gap:5px;padding:8px 14px;border-radius:var(--radius-sm);border:1px solid rgba(59,130,246,.35);background:rgba(59,130,246,.08);color:#93c5fd;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:var(--transition);letter-spacing:.2px}
.btn-contact-indem:hover{background:rgba(59,130,246,.18);border-color:#3b82f6;transform:translateY(-1px);box-shadow:0 4px 12px rgba(59,130,246,.2)}

/* ── Spinner for send buttons ── */
.btn-spinner{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:4px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Contact Indemnitor Modal ── */
#contactIndemModal .modal{max-width:520px;width:95vw}
.ci-def-bar{display:flex;gap:16px;align-items:center;padding:10px 14px;background:var(--surface);border-radius:8px;margin-bottom:14px;font-size:13px;border:1px solid var(--border)}
.ci-def-bar .ci-name{font-weight:700;color:var(--text);flex:1}
.ci-def-bar .ci-county{color:var(--muted);font-size:12px}
.ci-def-bar .ci-bond{font-weight:700;color:var(--accent);font-size:13px}
.ci-field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.ci-field-row.single{grid-template-columns:1fr}
.ci-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.ci-input,.ci-select{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text);font-size:13px;font-family:inherit;box-sizing:border-box;transition:var(--transition)}
.ci-input:focus,.ci-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(16,185,129,.1)}
.ci-textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text);font-size:12px;font-family:inherit;resize:vertical;min-height:90px;box-sizing:border-box;line-height:1.5;transition:var(--transition)}
.ci-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(16,185,129,.1)}
.ci-lang-row{display:flex;gap:6px;margin-bottom:10px;align-items:center}
.ci-lang-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-right:4px}
.ci-lang-btn{padding:5px 14px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:12px;cursor:pointer;transition:var(--transition);font-family:inherit}
.ci-lang-btn.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:700}
.ci-send-status{font-size:12px;margin-top:8px;min-height:18px;text-align:center}

.mugshot{width:52px;height:52px;border-radius:10px;object-fit:cover;border:2px solid var(--border);background:var(--surface)}
.mugshot-placeholder{width:52px;height:52px;border-radius:10px;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--muted)}

/* ── Write Bond Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.show{display:flex}
.modal{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);max-width:600px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.modal-header h2{font-size:16px;font-weight:700}
.modal-close{background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:6px}
.modal-close:hover{color:var(--text);background:var(--hover)}
.modal-body{padding:24px}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}
.modal-lg{max-width:720px}
.btn-primary{padding:10px 24px;border-radius:var(--radius-sm);border:none;background:var(--accent);color:#000;font-weight:700;font-size:13px;cursor:pointer;font-family:inherit;transition:var(--transition)}
.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px)}
.btn-cancel{padding:10px 24px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-weight:500;font-size:13px;cursor:pointer;font-family:inherit;transition:var(--transition)}
.btn-cancel:hover{border-color:var(--text-secondary)}

/* ═══════════════════════════════════════════════════════
   WRITE BOND MODAL — Enhanced Sections
   ═══════════════════════════════════════════════════════ */

/* ── Section Layout ── */
.wb-section{margin-bottom:18px}
.wb-section:last-child{margin-bottom:0}
.wb-section-label{font-size:9px;text-transform:uppercase;letter-spacing:1.6px;color:var(--muted);font-weight:700;margin-bottom:8px}

/* ── Defendant Summary ── */
.wb-defendant-summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}
.wb-name{font-size:18px;font-weight:800;letter-spacing:-.4px;margin-bottom:10px;background:linear-gradient(135deg,var(--text),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.wb-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;font-size:13px}
.wb-meta-label{color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.4px;margin-right:4px;font-weight:500}

/* ── Charges Box ── */
.wb-charges-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}
.wb-charges-table{width:100%;border-collapse:collapse;font-size:13px}
.wb-charges-table td{padding:6px 0;border-bottom:1px solid var(--border)}
.wb-charges-table tr:last-child td{border:none}
.wb-charge-bond{text-align:right;font-weight:600;white-space:nowrap}
.wb-bond-total-row{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;border-top:2px solid var(--accent);font-weight:800;font-size:14px}
.wb-bond-total{color:var(--accent);font-size:20px;letter-spacing:-.5px}

/* ── Insurance Company Selector ── */
.insurer-selector{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.insurer-pill{display:flex;flex-direction:column;align-items:center;gap:4px;padding:18px 16px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);cursor:pointer;transition:var(--transition);font-family:inherit;color:var(--text)}
.insurer-pill:hover{border-color:rgba(16,185,129,.3);background:rgba(16,185,129,.03);transform:translateY(-1px)}
.insurer-pill.active{border-color:var(--accent);background:rgba(16,185,129,.08);box-shadow:0 0 20px rgba(16,185,129,.1),inset 0 0 0 1px rgba(16,185,129,.1)}
.insurer-pill-icon{font-size:28px;margin-bottom:2px}
.insurer-pill-name{font-size:16px;font-weight:800;letter-spacing:-.3px}
.insurer-pill.active .insurer-pill-name{color:var(--accent)}
.insurer-pill-full{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;font-weight:500}

/* ── Premium Calculation ── */
.wb-premium-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}
.wb-premium-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;color:var(--text-secondary)}
.wb-premium-row.total{border-top:2px solid var(--accent);padding-top:10px;margin-top:6px;font-size:15px;font-weight:800;color:var(--text)}
.wb-premium-value{font-weight:600;font-variant-numeric:tabular-nums}
.wb-premium-value.accent{color:var(--accent);font-size:20px;letter-spacing:-.5px}

/* ── POA Notice ── */
.wb-poa-notice{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;border-radius:var(--radius-sm);border:1px solid rgba(251,191,36,.15);background:rgba(251,191,36,.04);margin-top:18px}
.wb-poa-icon{font-size:20px;flex-shrink:0}
.wb-poa-title{font-size:12px;font-weight:700;color:var(--gold);margin-bottom:2px}
.wb-poa-text{font-size:11px;color:var(--text-secondary);line-height:1.5}

/* ── Button Spinner ── */
.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(0,0,0,.15);border-top-color:#000;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:4px}
@keyframes spin{to{transform:rotate(360deg)}}
.btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}

/* ═══════════════════════════════════════════════════════
   TOAST NOTIFICATION SYSTEM
   ═══════════════════════════════════════════════════════ */
.toast-notification{position:fixed;bottom:28px;right:28px;display:flex;align-items:center;gap:10px;padding:14px 22px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:'Inter',system-ui,sans-serif;z-index:300;transform:translateY(100px);opacity:0;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s;box-shadow:0 8px 32px rgba(0,0,0,.25);max-width:420px}
.toast-notification.show{transform:translateY(0);opacity:1}
.toast-success{background:linear-gradient(135deg,#064e3b,#065f46);color:#34d399;border:1px solid rgba(16,185,129,.2)}
.toast-error{background:linear-gradient(135deg,#450a0a,#7f1d1d);color:#fca5a5;border:1px solid rgba(239,68,68,.2)}
.toast-info{background:linear-gradient(135deg,#172554,#1e3a5f);color:#93c5fd;border:1px solid rgba(59,130,246,.2)}
.toast-icon{font-size:18px;flex-shrink:0}
.toast-message{line-height:1.4}

/* ═══════════════════════════════════════════════════════
   SCRAPER HEALTH TAB
   ═══════════════════════════════════════════════════════ */
.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:capitalize;letter-spacing:.3px}
.status-healthy{background:rgba(16,185,129,.12);color:#34d399}
.status-stale{background:rgba(245,158,11,.12);color:#fbbf24}
.status-warning{background:rgba(249,115,22,.12);color:#fb923c}
.status-offline{background:rgba(239,68,68,.12);color:#f87171}

.health-row{transition:var(--transition)}
.health-row:hover{background:var(--hover) !important;transform:none}
.health-row td{padding:10px 14px !important}

#countyDrillPanel{border:1px solid var(--border-accent);animation:slideIn .3s ease-out}
@keyframes slideIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ═══════════════════════════════════════════════════════
   MULTI-SELECT COUNTY DROPDOWN
   ═══════════════════════════════════════════════════════ */
.multi-select{position:relative;min-width:220px}
.multi-select-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 14px;background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--text);transition:var(--transition);font-family:inherit;min-height:38px}
.multi-select-trigger:hover{border-color:var(--accent)}
.multi-select-trigger.open{border-color:var(--accent);box-shadow:0 0 0 3px rgba(16,185,129,.1)}
.multi-select-trigger .arrow{font-size:10px;color:var(--muted);transition:transform .2s}
.multi-select-trigger.open .arrow{transform:rotate(180deg)}
.multi-select-count{background:var(--accent);color:#000;padding:1px 7px;border-radius:10px;font-size:11px;font-weight:700}
.multi-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 12px 40px rgba(0,0,0,.3);z-index:50;max-height:280px;overflow-y:auto;display:none}
.multi-select-dropdown.show{display:block;animation:fadeSlide .2s ease-out}
@keyframes fadeSlide{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.multi-select-option{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;font-size:13px;transition:background .15s}
.multi-select-option:hover{background:var(--hover)}
.multi-select-option input[type="checkbox"]{accent-color:var(--accent);width:15px;height:15px;cursor:pointer}
.multi-select-option.checked{background:rgba(16,185,129,.04)}
.multi-select-search{padding:8px 14px;border-bottom:1px solid var(--border)}
.multi-select-search input{width:100%;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:6px;font-size:12px;font-family:inherit}
.multi-select-search input:focus{outline:none;border-color:var(--accent)}

/* ── County Preset Buttons ── */
.preset-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.preset-btn{padding:5px 14px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:11px;font-weight:600;cursor:pointer;transition:var(--transition);font-family:inherit;letter-spacing:.3px}
.preset-btn:hover{border-color:var(--accent);color:var(--accent)}
.preset-btn.active{background:rgba(16,185,129,.12);color:var(--accent-light);border-color:var(--accent)}
.preset-btn .emoji{margin-right:3px}

/* ═══════════════════════════════════════════════════════
   DATE RANGE BUTTON GROUP
   ═══════════════════════════════════════════════════════ */
.btn-group{display:inline-flex;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}
.btn-group button{padding:7px 16px;border:none;background:var(--surface);color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:var(--transition);border-right:1px solid var(--border)}
.btn-group button:last-child{border-right:none}
.btn-group button:hover{background:var(--hover);color:var(--text)}
.btn-group button.active{background:rgba(16,185,129,.12);color:var(--accent-light)}

/* ═══════════════════════════════════════════════════════
   ACTIVE FILTER PILLS BAR
   ═══════════════════════════════════════════════════════ */
.filter-pills{display:flex;gap:6px;flex-wrap:wrap;align-items:center;padding:8px 0}
.filter-pills:empty{display:none}
.filter-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px 4px 12px;border-radius:20px;font-size:11px;font-weight:600;background:rgba(16,185,129,.08);color:var(--accent-light);border:1px solid rgba(16,185,129,.15);animation:pillIn .2s ease-out}
@keyframes pillIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
.filter-pill .pill-close{cursor:pointer;opacity:.5;font-size:13px;margin-left:2px;transition:opacity .15s}
.filter-pill .pill-close:hover{opacity:1}
.filter-clear-all{font-size:11px;color:var(--muted);cursor:pointer;font-weight:500;padding:4px 8px;transition:color .15s}
.filter-clear-all:hover{color:var(--red)}

/* ═══════════════════════════════════════════════════════
   SORT INDICATORS
   ═══════════════════════════════════════════════════════ */
th[data-sort]{cursor:pointer;user-select:none}
th[data-sort]:hover{color:var(--accent)}
th[data-sort]::after{content:'⇅';margin-left:4px;font-size:10px;opacity:.3}
th[data-sort].sort-asc::after{content:'▲';opacity:.8;color:var(--accent)}
th[data-sort].sort-desc::after{content:'▼';opacity:.8;color:var(--accent)}

/* ═══════════════════════════════════════════════════════
   LEAD SCORE PILLS (Enhanced)
   ═══════════════════════════════════════════════════════ */
.score-pill{display:inline-flex;align-items:center;gap:3px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.3px}
.score-hot{background:rgba(249,115,22,.12);color:#fb923c;border:1px solid rgba(249,115,22,.15)}
.score-warm{background:rgba(251,191,36,.1);color:#fbbf24;border:1px solid rgba(251,191,36,.15)}
.score-cold{background:rgba(100,116,139,.08);color:var(--muted);border:1px solid var(--border)}
.score-disq{background:rgba(239,68,68,.08);color:#f87171;border:1px solid rgba(239,68,68,.12)}

/* ═══════════════════════════════════════════════════════
   EXPORT & ACTION BUTTONS
   ═══════════════════════════════════════════════════════ */
.btn-export{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:var(--transition)}
.btn-export:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.btn-slack{border-color:rgba(74,21,75,.3);color:#e01e5a}
.btn-slack:hover{border-color:#e01e5a;background:rgba(224,30,90,.04)}

/* ═══════════════════════════════════════════════════════
   HOT LEAD AUDIO ALERT
   ═══════════════════════════════════════════════════════ */
.alert-pulse{animation:alertPulse 1.5s ease-in-out 3}
@keyframes alertPulse{0%,100%{box-shadow:0 0 0 0 rgba(249,115,22,.4)}50%{box-shadow:0 0 0 8px rgba(249,115,22,0)}}
.new-lead-badge{position:absolute;top:-4px;right:-4px;width:10px;height:10px;background:var(--red);border-radius:50%;border:2px solid var(--surface);animation:pulse 2s infinite}

/* ═══════════════════════════════════════════════════════
   COURT DATE PROXIMITY ALERTS
   ═══════════════════════════════════════════════════════ */
.court-soon{color:#f87171;font-weight:700}
.court-soon::before{content:'⚠ ';font-size:11px}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — MOBILE/TABLET
   ═══════════════════════════════════════════════════════ */
@media(max-width:768px){
  .header{padding:10px 16px;flex-direction:column;gap:8px}
  .tab-bar{padding:0 12px;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tab-btn{padding:12px 16px;font-size:12px;white-space:nowrap}
  .container{padding:16px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .filters{flex-direction:column;align-items:stretch}
  .multi-select{min-width:100%}
  .btn-group{width:100%;display:grid;grid-template-columns:repeat(5,1fr)}
  .defendant-grid{grid-template-columns:1fr}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .preset-bar{gap:4px}
  .preset-btn{padding:4px 10px;font-size:10px}
}

/* ── Write Bond Button ── */
.btn-write-bond{background:linear-gradient(135deg,var(--accent),#059669);color:#fff;border:none;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:4px}
.btn-write-bond:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(16,185,129,.3)}

/* ── Insurer Selector ── */
.insurer-selector{display:flex;gap:12px;margin-top:8px}
.insurer-pill{flex:1;background:var(--surface);border:2px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;text-align:center;transition:var(--transition)}
.insurer-pill:hover{border-color:var(--accent);background:var(--hover)}
.insurer-pill.active{border-color:var(--accent);background:rgba(16,185,129,.08);box-shadow:0 0 20px rgba(16,185,129,.1)}
.insurer-pill-icon{font-size:24px;display:block;margin-bottom:6px}
.insurer-pill-name{font-size:16px;font-weight:700;display:block;color:var(--text)}
.insurer-pill-full{font-size:11px;color:var(--muted);display:block;margin-top:2px}

/* ── Write Bond Modal Sections ── */
.wb-section{margin-bottom:20px}
.wb-section-label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);margin-bottom:10px;font-weight:600}
.wb-defendant-summary{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px}
.wb-name{font-size:18px;font-weight:700;margin-bottom:12px}
.wb-meta-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.wb-meta-label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:2px}
.wb-poa-notice{display:flex;gap:12px;align-items:flex-start;background:rgba(245,158,11,.06);border:1px solid rgba(245,158,11,.2);border-radius:10px;padding:14px}
.wb-poa-icon{font-size:20px}
.wb-poa-title{font-size:13px;font-weight:700;color:var(--gold)}
.wb-poa-text{font-size:12px;color:var(--text-secondary);margin-top:2px}

/* ── Defendant Cards ── */
.def-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;margin-top:16px}
.def-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}
.def-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--glow)}
.def-card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:16px 16px 12px;border-bottom:1px solid var(--border)}
.def-name{font-size:15px;font-weight:700}
.def-booking{font-size:11px;color:var(--muted);margin-top:2px}
.def-bond-pill{padding:4px 12px;border-radius:20px;font-size:13px;font-weight:700}
.def-bond-pill.high{background:rgba(239,68,68,.12);color:#f87171}
.def-bond-pill.mid{background:rgba(245,158,11,.12);color:#fbbf24}
.def-bond-pill.low{background:rgba(16,185,129,.12);color:#34d399}
.def-body{padding:12px 16px}
.def-section{margin-bottom:10px}
.def-section-title{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:6px;font-weight:600}
.def-row{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.def-row.wide{grid-template-columns:1fr}
.def-field{display:flex;flex-direction:column;gap:1px}
.def-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.def-value{font-size:13px;color:var(--text)}
.def-status-badge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600}
.def-status-badge.custody{background:rgba(245,158,11,.12);color:#fbbf24}
.def-status-badge.released{background:rgba(100,116,139,.12);color:#94a3b8}
.def-status-badge.other{background:rgba(59,130,246,.08);color:#60a5fa}
.def-card-footer{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border)}
.btn-detail{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);padding:6px 12px;border-radius:8px;font-size:12px;cursor:pointer;transition:var(--transition)}
.btn-detail:hover{border-color:var(--accent);color:var(--accent)}

/* ── Command Center Enhancements ── */
.accent-card{border:1px solid rgba(16,185,129,.3) !important;background:linear-gradient(135deg,rgba(16,185,129,.04),rgba(59,130,246,.02)) !important}
.bond-queue-table{width:100%;font-size:13px}
.bond-queue-table th{text-align:left;padding:8px 10px;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);border-bottom:1px solid var(--border)}
.bond-queue-table td{padding:8px 10px;border-bottom:1px solid var(--border)}
.county-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}
.county-row:last-child{border:none}
.county-name{font-weight:600;font-size:13px}
.court-soon{color:var(--red) !important;font-weight:700}

/* ═══════════════════════════════════════════════════════
   TEXT OUTREACH (BlueBubbles)
   ═══════════════════════════════════════════════════════ */
.outreach-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}
.outreach-label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:4px;font-weight:600}
.outreach-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin:0 4px;vertical-align:middle;flex-shrink:0}
.outreach-status-dot.online{background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse 2s infinite}
.outreach-status-dot.offline{background:var(--muted);opacity:.5}
.outreach-phone-wrap{display:flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--input-bg);overflow:hidden;transition:border-color .2s}
.outreach-phone-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(16,185,129,.1)}
.outreach-phone-prefix{padding:0 10px;font-size:13px;font-weight:600;color:var(--muted);background:rgba(0,0,0,.05);border-right:1px solid var(--border);user-select:none}
[data-theme="dark"] .outreach-phone-prefix{background:rgba(255,255,255,.03)}
.outreach-phone{flex:1;border:none;background:transparent;color:var(--text);padding:8px 10px;font-size:14px;font-family:'Inter',system-ui,sans-serif;outline:none}
.outreach-select{width:100%;background:var(--input-bg);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;font-family:inherit;transition:var(--transition);cursor:pointer}
.outreach-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(16,185,129,.1)}
.outreach-textarea{width:100%;background:var(--input-bg);border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:var(--radius-sm);font-size:13px;font-family:inherit;resize:vertical;min-height:80px;line-height:1.5;transition:border-color .2s}
.outreach-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(16,185,129,.1)}
.outreach-send-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 20px;border-radius:var(--radius-sm);border:1px solid rgba(16,185,129,.3);background:rgba(16,185,129,.1);color:var(--accent-light);font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:var(--transition);letter-spacing:.2px}
.outreach-send-btn:hover{background:rgba(16,185,129,.2);border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 16px rgba(16,185,129,.15)}
.outreach-send-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}
.outreach-history-row{padding:10px 12px;background:var(--card);border:1px solid var(--border);border-radius:8px;margin-bottom:6px;transition:var(--transition)}
.outreach-history-row:hover{border-color:var(--border-accent)}

@media(max-width:768px){
  .wb-meta-grid{grid-template-columns:1fr 1fr}
  .insurer-selector{flex-direction:column}
  .def-grid{grid-template-columns:1fr}
}

/* ── Risk Badges (Tracking Tab) ── */
.risk-badge{display:inline-block;padding:2px 9px;border-radius:10px;font-size:11px;font-weight:700;letter-spacing:.3px}
.risk-high{background:rgba(239,68,68,.15);color:#ef4444;border:1px solid rgba(239,68,68,.3)}
.risk-med{background:rgba(245,158,11,.15);color:#f59e0b;border:1px solid rgba(245,158,11,.3)}
.risk-low{background:rgba(16,185,129,.15);color:#10b981;border:1px solid rgba(16,185,129,.3)}
/* ── Leaflet map dark theme override ── */
[data-theme="dark"] .leaflet-container{background:#0a1628}
[data-theme="dark"] .leaflet-popup-content-wrapper{background:var(--card);color:var(--text);border:1px solid var(--border);box-shadow:0 4px 16px rgba(0,0,0,.4)}
[data-theme="dark"] .leaflet-popup-tip{background:var(--card)}


/* Intake Queue Tab — field helpers, btn-sm, btn-secondary */
.field-label{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.field-input{width:100%;padding:8px 12px;background:var(--input-bg,var(--panel));border:1px solid var(--border);border-radius:var(--radius-sm,6px);color:var(--text);font-size:13px;font-family:inherit;box-sizing:border-box}
.field-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(16,185,129,.15)}
.btn-sm{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;border-radius:var(--radius-sm,6px);cursor:pointer;border:none;transition:var(--transition)}
.btn-secondary{background:var(--panel);color:var(--text);border:1px solid var(--border);padding:8px 16px;border-radius:var(--radius-sm,6px);font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
#intakeQueueBody td.loading{text-align:center;color:var(--muted);padding:24px;font-size:13px}


/* ═══════════════════════════════════════════════════════════
   SCRAPER HEALTH TAB — SLHealth module styles
   ═══════════════════════════════════════════════════════════ */

/* Status badge variants for health tab */
.status-badge.status-ok     { background: rgba(0,200,150,.12); color: #00c896; }
.status-badge.status-warn   { background: rgba(255,165,2,.12);  color: #ffa502; }
.status-badge.status-error  { background: rgba(255,71,87,.12);  color: #ff4757; }
.status-badge.status-never  { background: rgba(100,116,139,.12); color: #94a3b8; }

/* Health filter buttons */
.health-filter-btn {
  padding: 5px 12px;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
}
.health-filter-btn:hover,
.health-filter-btn.active {
  background: var(--accent);
  color: #000;
  border-color: var(--accent);
}

/* Error row highlight */
tr.row-error td { background: rgba(255,71,87,.04); }
tr.row-error:hover td { background: rgba(255,71,87,.08); }

/* Extra-small button */
.btn-xs {
  padding: 3px 8px !important;
  font-size: 11px !important;
  border-radius: 5px;
  cursor: pointer;
  border: none;
}

/* Toast fade-in animation */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ═══════════════════════════════════════════════════════════
   PROSPECTIVE BONDS PIPELINE (In Progress Tab)
   ═══════════════════════════════════════════════════════════ */

/* ── Track Lead Button (Defendant Card) ── */
.btn-track-lead{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:8px;border:1px solid rgba(16,185,129,.3);background:linear-gradient(135deg,rgba(16,185,129,.06),rgba(59,130,246,.04));color:var(--accent-light);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:var(--transition)}
.btn-track-lead:hover{background:linear-gradient(135deg,rgba(16,185,129,.15),rgba(59,130,246,.08));border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px rgba(16,185,129,.15)}
.btn-track-lead.tracked{background:rgba(16,185,129,.08);color:var(--muted);border-color:var(--border);cursor:default;pointer-events:none}
.btn-track-lead.tracked::before{content:'✓ '}

/* ── Pipeline Board (Kanban) ── */
.pipeline-board{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:8px}
@media(max-width:1000px){.pipeline-board{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.pipeline-board{grid-template-columns:1fr}}

.pipeline-col{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;min-height:200px;display:flex;flex-direction:column}
.pipeline-col-header{padding:12px 16px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;border-bottom:2px solid var(--border);display:flex;align-items:center;gap:8px}
.pipeline-col-header.contacted{border-bottom-color:#3b82f6;color:#60a5fa}
.pipeline-col-header.negotiating{border-bottom-color:#f59e0b;color:#fbbf24}
.pipeline-col-header.paperwork{border-bottom-color:#8b5cf6;color:#a78bfa}
.pipeline-col-header.ready{border-bottom-color:#10b981;color:#34d399}
.pipeline-col-count{background:rgba(255,255,255,.1);padding:2px 8px;border-radius:10px;font-size:11px}
[data-theme="light"] .pipeline-col-count{background:rgba(0,0,0,.06)}

.pipeline-col-body{flex:1;padding:10px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;max-height:600px}

/* ── Pipeline Cards ── */
.pipeline-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px;cursor:pointer;transition:var(--transition);position:relative}
.pipeline-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.15)}
.pipeline-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.pipeline-card-name{font-size:13px;font-weight:700;letter-spacing:-.2px}
.pipeline-card-bond{font-size:12px;font-weight:700;color:var(--accent)}
.pipeline-card-meta{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--muted);margin-bottom:4px}
.pipeline-card-ind{font-size:11px;color:var(--text-secondary);margin-bottom:4px}
.pipeline-card-comm{font-size:10px;color:var(--muted);border-top:1px solid var(--border);padding-top:6px;margin-top:4px}
.pipeline-empty{text-align:center;padding:32px 16px;color:var(--muted);font-size:12px;opacity:.6}

.btn-officialize-sm{display:block;width:100%;margin-top:8px;padding:6px;border-radius:6px;border:1px solid rgba(16,185,129,.3);background:rgba(16,185,129,.06);color:var(--accent-light);font-size:11px;font-weight:700;cursor:pointer;transition:var(--transition);font-family:inherit}
.btn-officialize-sm:hover{background:var(--accent);color:#000;border-color:var(--accent)}

/* ── Stage Progress Bar (Detail Panel) ── */
.prosp-stage-bar{display:flex;align-items:center;justify-content:center;gap:0;margin:16px 0 24px;flex-wrap:wrap}
.prosp-stage-dot{padding:8px 16px;font-size:11px;font-weight:600;border-radius:20px;cursor:pointer;transition:var(--transition);color:var(--muted);background:var(--surface);border:1px solid var(--border);white-space:nowrap}
.prosp-stage-dot.active{color:#fff;background:var(--dot-color,var(--accent));border-color:var(--dot-color,var(--accent));box-shadow:0 0 16px color-mix(in srgb, var(--dot-color,var(--accent)) 40%, transparent)}
.prosp-stage-dot:hover:not(.active){border-color:var(--dot-color,var(--accent));color:var(--dot-color,var(--accent))}
.prosp-stage-line{width:24px;height:2px;background:var(--border);flex-shrink:0}

/* ── Detail Grid ── */
.prosp-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
@media(max-width:768px){.prosp-detail-grid{grid-template-columns:1fr}}
.prosp-info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}
.prosp-info-card h4{font-size:13px;font-weight:700;margin-bottom:12px;color:var(--text)}
.prosp-field{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);font-size:13px;gap:8px}
.prosp-field:last-of-type{border:none}
.prosp-field span:first-child{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;min-width:70px}
.prosp-field input{flex:1;background:var(--input-bg);border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:6px;font-size:13px;font-family:inherit}
.prosp-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(16,185,129,.12)}
.mono{font-family:'SF Mono',Consolas,monospace;font-size:12px;letter-spacing:.3px}

.btn-save-ind{display:block;width:100%;margin-top:10px;padding:8px;border-radius:8px;border:1px solid rgba(16,185,129,.3);background:rgba(16,185,129,.06);color:var(--accent-light);font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:var(--transition)}
.btn-save-ind:hover{background:var(--accent);color:#000;border-color:var(--accent)}

/* ── Communication Timeline ── */
.prosp-comm-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;margin-bottom:16px}
.prosp-comm-section h4{font-size:13px;font-weight:700;margin-bottom:12px}
.prosp-comm-timeline{max-height:320px;overflow-y:auto;padding:8px 0;display:flex;flex-direction:column;gap:8px}

.comm-bubble{padding:10px 14px;border-radius:12px;max-width:85%;font-size:13px;animation:fadeIn .2s ease-out}
.comm-bubble.outbound{background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.15);margin-left:auto;border-bottom-right-radius:4px}
.comm-bubble.inbound{background:var(--card);border:1px solid var(--border);margin-right:auto;border-bottom-left-radius:4px}
.comm-bubble-header{display:flex;justify-content:space-between;gap:8px;font-size:10px;color:var(--muted);margin-bottom:4px}
.comm-bubble-body{line-height:1.5;word-break:break-word}
.comm-bubble-meta{font-size:10px;color:var(--muted);margin-top:4px;opacity:.7}

/* ── Send Bar ── */
.prosp-send-bar{display:flex;flex-direction:column;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.prosp-send-bar select,.prosp-send-bar textarea{background:var(--input-bg);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:8px;font-size:13px;font-family:inherit;transition:border-color .2s}
.prosp-send-bar select:focus,.prosp-send-bar textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(16,185,129,.1)}
.prosp-send-bar textarea{resize:vertical;min-height:60px}
.btn-send-msg{padding:8px 18px;border-radius:8px;border:none;background:var(--accent);color:#000;font-weight:700;font-size:12px;cursor:pointer;font-family:inherit;transition:var(--transition)}
.btn-send-msg:hover{filter:brightness(1.15);transform:translateY(-1px)}
.btn-add-note{padding:8px 18px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-weight:600;font-size:12px;cursor:pointer;font-family:inherit;transition:var(--transition)}
.btn-add-note:hover{border-color:var(--accent);color:var(--accent)}

/* ── Timeline ── */
.prosp-timeline-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;margin-bottom:16px}
.prosp-timeline-section h4{font-size:13px;font-weight:700;margin-bottom:12px}
.prosp-timeline{display:flex;flex-direction:column;gap:12px;max-height:300px;overflow-y:auto;padding:4px 0}
.timeline-entry{display:flex;gap:12px;align-items:flex-start}
.timeline-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:4px}
.timeline-content{flex:1;font-size:12px;line-height:1.5}
.timeline-event{font-weight:600;display:block}
.timeline-detail{color:var(--text-secondary);display:block}
.timeline-time{color:var(--muted);font-size:10px}

/* ── Actions Footer ── */
.prosp-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;padding:16px 0}
.prosp-stage-select{display:flex;align-items:center;gap:6px;margin-left:auto}
.prosp-stage-select label{font-size:12px;color:var(--muted);font-weight:600}
.prosp-stage-select select{background:var(--input-bg);border:1px solid var(--border);color:var(--text);padding:6px 12px;border-radius:8px;font-size:12px;font-family:inherit}
.btn-close-lead{padding:8px 18px;border-radius:8px;border:1px solid rgba(239,68,68,.3);background:rgba(239,68,68,.06);color:#f87171;font-weight:600;font-size:12px;cursor:pointer;font-family:inherit;transition:var(--transition)}
.btn-close-lead:hover{background:rgba(239,68,68,.15);border-color:var(--red)}
.btn-officialize{padding:8px 18px;border-radius:8px;border:none;background:linear-gradient(135deg,var(--accent),#059669);color:#fff;font-weight:700;font-size:12px;cursor:pointer;font-family:inherit;transition:var(--transition);box-shadow:0 2px 8px rgba(16,185,129,.2)}
.btn-officialize:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(16,185,129,.3)}

/* ═══════════════════════════════════════════════════════════
   AI OUTREACH AGENT PANEL
   ═══════════════════════════════════════════════════════════ */
.auto-reply-panel{margin-bottom:12px}
.auto-reply-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);font-size:14px;font-weight:600}
.auto-reply-header:hover{border-color:var(--accent)}
.auto-reply-header.agent-live{border-color:rgba(16,185,129,.35);background:linear-gradient(135deg,rgba(16,185,129,.04) 0%,var(--card) 100%);box-shadow:0 0 20px rgba(16,185,129,.06)}
.ar-toggle-arrow{font-size:10px;color:var(--muted);transition:transform .2s}
.auto-reply-panel.expanded .ar-toggle-arrow{transform:rotate(180deg)}
.auto-reply-body{display:none;padding:16px 18px;background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm)}
.auto-reply-panel.expanded .auto-reply-body{display:block;animation:fadeIn .2s ease-out}

/* Grid layout for settings */
.ar-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 32px}
.ar-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}
.ar-row:last-child,.ar-row:nth-last-child(2):nth-child(odd){border:none}
.ar-row label{color:var(--text-secondary);font-weight:500}
.ar-row input[type="checkbox"]{accent-color:var(--accent);width:18px;height:18px;cursor:pointer}
.ar-row input[type="number"]{background:var(--input-bg);border:1px solid var(--border);color:var(--text);padding:4px 8px;border-radius:6px;font-family:inherit;font-size:13px}

/* Status badges */
.ar-status{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:10px;font-size:10px;font-weight:700;letter-spacing:.5px}
.ar-status.on{background:rgba(16,185,129,.15);color:#34d399}
.ar-status.off{background:rgba(239,68,68,.1);color:#f87171}

/* Pulse animation for LIVE status */
.ar-pulse{display:inline-block;width:6px;height:6px;border-radius:50%;background:#34d399;animation:arPulseGlow 2s ease-in-out infinite}
@keyframes arPulseGlow{0%,100%{box-shadow:0 0 0 0 rgba(52,211,153,.5)}50%{box-shadow:0 0 0 5px rgba(52,211,153,0)}}

/* Mode badges (GPT-4o, Multi-Turn) */
.ar-mode-badge{padding:2px 8px;border-radius:6px;font-size:9px;font-weight:700;letter-spacing:.3px;background:rgba(139,92,246,.1);color:#a78bfa;border:1px solid rgba(139,92,246,.15)}

/* Toggle switch */
.ar-switch{position:relative;display:inline-block;width:36px;height:20px;cursor:pointer}
.ar-switch input{opacity:0;width:0;height:0}
.ar-slider{position:absolute;top:0;left:0;right:0;bottom:0;background:#374151;border-radius:20px;transition:.3s}
.ar-slider::before{content:'';position:absolute;height:14px;width:14px;left:3px;bottom:3px;background:#9ca3af;border-radius:50%;transition:.3s}
.ar-switch input:checked+.ar-slider{background:rgba(16,185,129,.3)}
.ar-switch input:checked+.ar-slider::before{transform:translateX(16px);background:#34d399}

/* Poll button */
.btn-poll{padding:6px 14px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--text);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition)}
.btn-poll:hover{border-color:var(--accent);color:var(--accent);background:rgba(16,185,129,.04)}

.ar-last-poll{font-size:12px;color:var(--muted)}

/* ── Reply Badges (Pipeline Cards) ── */
.reply-badge{display:inline-flex;align-items:center;gap:3px;padding:1px 7px;border-radius:8px;font-size:9px;font-weight:700;letter-spacing:.3px;background:rgba(59,130,246,.1);color:#60a5fa;border:1px solid rgba(59,130,246,.15)}
.reply-badge.new{background:rgba(245,158,11,.15);color:#fbbf24;border-color:rgba(245,158,11,.25);animation:replyPulse 2s ease-in-out infinite}
@keyframes replyPulse{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,.3)}50%{box-shadow:0 0 0 4px rgba(245,158,11,0)}}
.turn-badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:6px;font-size:9px;font-weight:600;background:rgba(16,185,129,.1);color:#34d399;border:1px solid rgba(16,185,129,.15)}

/* ── Card New Reply Highlight ── */
.pipeline-card.has-new-reply{border-color:rgba(245,158,11,.4) !important;box-shadow:0 0 12px rgba(245,158,11,.1)}

/* ── Card Message Preview ── */
.pipeline-card-preview{font-size:10px;color:var(--text-secondary);margin-top:4px;font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.7}

/* ── Message Action Buttons ── */
.comm-actions{display:flex;gap:4px;margin-top:6px;opacity:0;transition:opacity .15s}
.comm-bubble:hover .comm-actions{opacity:1}
.comm-action-btn{padding:3px 8px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:11px;cursor:pointer;transition:var(--transition)}
.comm-action-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(16,185,129,.04)}

/* ── Auto-Reply Bubble Style ── */
.comm-bubble.auto-reply{background:rgba(139,92,246,.06);border-color:rgba(139,92,246,.15)}
.comm-bubble.auto-reply .comm-bubble-header{color:#a78bfa}

/* ── Intent Classification Badges ── */
.intent-badge{display:inline-block;padding:1px 6px;border-radius:6px;font-size:9px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}
.intent-badge.intent-interested{background:rgba(16,185,129,.12);color:#34d399}
.intent-badge.intent-question{background:rgba(59,130,246,.12);color:#60a5fa}
.intent-badge.intent-not_interested{background:rgba(239,68,68,.1);color:#f87171}
.intent-badge.intent-spam{background:rgba(100,116,139,.1);color:#94a3b8}
.intent-badge.intent-angry{background:rgba(239,68,68,.15);color:#ef4444}
.intent-badge.intent-callback{background:rgba(245,158,11,.12);color:#fbbf24}
.intent-badge.intent-greeting{background:rgba(139,92,246,.12);color:#a78bfa}


/* ═══════════════════════════════════════════════════════════════════════════
   DEFENDANT LIFECYCLE — Card Status Borders, Notes Modal, DNB/DNC, Finalize
   sl-defendant-lifecycle.js companion styles
   ═══════════════════════════════════════════════════════════════════════════ */
.slc-lifecycle-bar{padding:6px 16px 4px;border-bottom:1px solid var(--border);background:rgba(0,0,0,.04)}
[data-theme="dark"] .slc-lifecycle-bar{background:rgba(0,0,0,.18)}
.slc-status-row{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:12px}
.slc-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.slc-status-label{font-weight:700;font-size:11px;letter-spacing:.4px;text-transform:uppercase}
.slc-notes-preview{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.4;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.slc-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:5px;font-size:10px;font-weight:700;letter-spacing:.3px;white-space:nowrap}
.slc-badge-dnb{background:rgba(239,68,68,.15);color:#f87171;border:1px solid rgba(239,68,68,.3)}
.slc-badge-dnc{background:rgba(220,38,38,.15);color:#fca5a5;border:1px solid rgba(220,38,38,.3)}
.slc-badge-comm{background:rgba(59,130,246,.12);color:#93c5fd;border:1px solid rgba(59,130,246,.2)}
.slc-badge-followup{background:rgba(245,158,11,.12);color:#fcd34d;border:1px solid rgba(245,158,11,.2)}
.slc-badge-action{background:rgba(168,85,247,.12);color:#d8b4fe;border:1px solid rgba(168,85,247,.2);cursor:default}
.slc-notes-btn{margin-left:auto;background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.25);color:#93c5fd;padding:3px 10px;border-radius:5px;font-size:11px;font-weight:600;cursor:pointer;transition:background .15s}
.slc-notes-btn:hover{background:rgba(59,130,246,.2)}
.slc-dnb-filter-btn{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);color:#f87171;padding:6px 14px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}
.slc-dnb-filter-btn:hover{background:rgba(239,68,68,.2)}
.slc-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:9000;display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px)}
.slc-modal-overlay.active{display:flex}
.slc-modal-box{background:var(--card);border:1px solid var(--border);border-radius:14px;width:100%;max-width:680px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.5);overflow:hidden}
.slc-finalize-box{max-width:600px}
.slc-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.slc-modal-title{font-size:17px;font-weight:800;letter-spacing:-.3px}
.slc-modal-subtitle{font-size:12px;color:var(--muted);margin-top:2px;font-family:'SF Mono',monospace}
.slc-modal-close{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .15s}
.slc-modal-close:hover{color:var(--text)}
.slc-modal-body{overflow-y:auto;padding:20px 24px;flex:1}
.slc-modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;flex-shrink:0}
.slc-form-section{margin-bottom:22px}
.slc-form-section:last-child{margin-bottom:0}
.slc-form-section-title{font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:var(--accent);font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:6px}
.slc-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:10px}
.slc-form-field{display:flex;flex-direction:column;gap:4px}
.slc-full-width{grid-column:1/-1}
.slc-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:600}
.slc-input,.slc-select,.slc-textarea{background:var(--surface);border:1px solid var(--border);border-radius:7px;color:var(--text);padding:8px 12px;font-size:13px;font-family:inherit;transition:border-color .15s;width:100%;box-sizing:border-box}
.slc-input:focus,.slc-select:focus,.slc-textarea:focus{outline:none;border-color:var(--accent)}
.slc-textarea{resize:vertical;min-height:72px}
.slc-flag-toggle{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:all .15s;user-select:none}
.slc-flag-toggle input{width:16px;height:16px;cursor:pointer;accent-color:#ef4444}
.slc-flag-toggle.active-dnb{border-color:#ef4444;background:rgba(239,68,68,.08);color:#f87171}
.slc-flag-toggle.active-dnc{border-color:#dc2626;background:rgba(220,38,38,.08);color:#fca5a5}
.slc-contact-log{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto}
.slc-log-entry{background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:8px 12px;display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:12px}
.slc-log-method{font-weight:700;padding:2px 8px;border-radius:4px;font-size:10px}
.slc-log-call{background:rgba(59,130,246,.12);color:#93c5fd}
.slc-log-text{background:rgba(16,185,129,.12);color:#6ee7b7}
.slc-log-email{background:rgba(245,158,11,.12);color:#fcd34d}
.slc-log-in_person{background:rgba(168,85,247,.12);color:#d8b4fe}
.slc-log-dir{color:var(--muted);font-size:11px}
.slc-log-contact{font-weight:600}
.slc-log-agent{color:var(--muted);font-size:11px}
.slc-log-ts{margin-left:auto;color:var(--muted);font-size:10px;font-family:'SF Mono',monospace}
.slc-log-summary{width:100%;color:var(--text-secondary);font-size:11px;font-style:italic;padding-top:4px;border-top:1px solid var(--border);margin-top:4px}
.slc-log-empty{color:var(--muted);font-size:12px;text-align:center;padding:16px}
.slc-count{background:var(--surface);border:1px solid var(--border);padding:1px 7px;border-radius:10px;font-size:10px;font-weight:600;color:var(--muted)}
.slc-btn{padding:9px 18px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;border:none;transition:all .15s;letter-spacing:.2px}
.slc-btn-primary{background:var(--accent);color:#fff}
.slc-btn-primary:hover{filter:brightness(1.1)}
.slc-btn-secondary{background:var(--surface);border:1px solid var(--border);color:var(--text)}
.slc-btn-secondary:hover{border-color:var(--accent)}
.slc-btn-log{background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.25);color:#93c5fd;padding:7px 16px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer}
.slc-btn-log:hover{background:rgba(59,130,246,.22)}
.slc-btn-finalize{background:rgba(168,85,247,.12);border:1px solid rgba(168,85,247,.3);color:#d8b4fe}
.slc-btn-finalize:hover{background:rgba(168,85,247,.22)}
.slc-btn-confirm{background:rgba(16,185,129,.15);border:1px solid rgba(16,185,129,.35);color:#34d399;font-weight:800}
.slc-btn-confirm:hover{background:rgba(16,185,129,.28)}
.slc-btn-sm{padding:4px 10px;font-size:11px;border-radius:5px;background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer}
.slc-review-banner{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.25);color:#fcd34d;border-radius:8px;padding:10px 14px;font-size:12px;font-weight:600;margin-bottom:16px}
.slc-review-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:16px}
.slc-review-table tr{border-bottom:1px solid var(--border)}
.slc-rt-label{color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;padding:7px 0;width:130px;vertical-align:top}
.slc-rt-value{font-weight:500;padding:7px 0 7px 12px}
.slc-confirm-checklist{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.slc-check-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:13px;cursor:pointer;transition:border-color .15s}
.slc-check-item:has(input:checked){border-color:#10b981;background:rgba(16,185,129,.06)}
.slc-check-item input{width:16px;height:16px;margin-top:1px;accent-color:#10b981;cursor:pointer;flex-shrink:0}
.slc-dnb-table{width:100%;border-collapse:collapse;font-size:13px}
.slc-dnb-table th{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);font-weight:600;padding:8px 10px;border-bottom:1px solid var(--border);text-align:left}
.slc-dnb-table td{padding:10px;border-bottom:1px solid var(--border);vertical-align:middle}
.slc-dnb-table tr:hover td{background:var(--surface)}
@media(max-width:600px){.slc-form-row{grid-template-columns:1fr}.slc-modal-box{max-height:95vh}.slc-modal-footer{flex-wrap:wrap}}

/* ── Pipeline Bridge (Lifecycle → Outreach) ── */
.slc-pipeline-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:6px;font-size:10px;font-weight:600;margin-top:6px;letter-spacing:.2px}
.slc-pipeline-badge.tracked{background:rgba(16,185,129,.12);color:#34d399;border:1px solid rgba(16,185,129,.2)}
.slc-pipeline-badge.not-tracked{background:rgba(100,116,139,.08);color:var(--muted);border:1px solid rgba(100,116,139,.15)}
.slc-btn-pipeline{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.25);color:#93c5fd;transition:all .15s}
.slc-btn-pipeline:hover{background:rgba(59,130,246,.2);border-color:#60a5fa;transform:translateY(-1px)}
.slc-btn-pipeline.tracked{background:rgba(16,185,129,.08);color:#6ee7b7;border:1px solid rgba(16,185,129,.2);cursor:default;opacity:.8}

/* ── Pipeline Card Quick-Note Row ── */
.pipeline-card-notes-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.pipeline-notes-label { font-size: 12px; flex-shrink: 0; }
.pipeline-notes-input {
  flex: 1;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 5px;
  color: var(--text, #e2e8f0);
  font-size: 11px;
  padding: 3px 8px;
  outline: none;
  transition: border-color 0.2s;
}
.pipeline-notes-input:focus {
  border-color: rgba(99,179,237,0.5);
  background: rgba(255,255,255,0.09);
}

/* ═══════════════════════════════════════════════════════
   INDEMNITOR MANAGEMENT TAB — Premium Fortune 50
   ═══════════════════════════════════════════════════════ */

/* ── Card List ── */
.ind-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:16px;padding:18px}
.ind-card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}
.ind-card::before{content:'';position:absolute;inset:0;border-radius:14px;padding:1px;background:linear-gradient(135deg,transparent 40%,rgba(16,185,129,.2),rgba(59,130,246,.15));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:0;transition:opacity .3s}
.ind-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.25),0 0 0 1px rgba(16,185,129,.12)}
.ind-card:hover::before{opacity:1}
.ind-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.ind-card-name{font-weight:800;font-size:16px;color:var(--text);letter-spacing:-.2px}
.ind-stage-pill{font-size:10px;padding:4px 12px;border-radius:20px;font-weight:700;white-space:nowrap;text-transform:uppercase;letter-spacing:.6px}
.ind-badge-prospect{background:linear-gradient(135deg,rgba(59,130,246,.15),rgba(99,102,241,.1));color:#818cf8;border:1px solid rgba(99,102,241,.15)}
.ind-badge-bonded{background:linear-gradient(135deg,rgba(16,185,129,.15),rgba(52,211,153,.1));color:#34d399;border:1px solid rgba(16,185,129,.15)}
.ind-badge-contacted{background:linear-gradient(135deg,rgba(245,158,11,.15),rgba(251,191,36,.1));color:#fbbf24;border:1px solid rgba(245,158,11,.15)}
.ind-badge-negotiating{background:linear-gradient(135deg,rgba(236,72,153,.12),rgba(244,114,182,.08));color:#f472b6;border:1px solid rgba(236,72,153,.12)}
.ind-badge-paperwork{background:linear-gradient(135deg,rgba(139,92,246,.12),rgba(167,139,250,.08));color:#a78bfa;border:1px solid rgba(139,92,246,.12)}
.ind-badge-ready{background:linear-gradient(135deg,rgba(6,182,212,.12),rgba(34,211,238,.08));color:#22d3ee;border:1px solid rgba(6,182,212,.12)}
.ind-card-meta{display:flex;gap:14px;font-size:12px;color:var(--text-secondary);margin-bottom:10px;flex-wrap:wrap}
.ind-card-meta span{display:inline-flex;align-items:center;gap:3px}
.ind-card-bond{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text-secondary);margin-bottom:10px;padding:8px 12px;background:rgba(255,255,255,.02);border-radius:8px;border:1px solid rgba(255,255,255,.03)}
.ind-card-amount{font-weight:800;font-size:17px;color:var(--accent-light);font-variant-numeric:tabular-nums}
.ind-card-bottom{display:flex;justify-content:space-between;gap:8px;font-size:11px;color:var(--muted);padding-top:10px;border-top:1px solid rgba(255,255,255,.04)}

/* ── Stagger animation for card list ── */
@keyframes indCardIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.ind-card{animation:indCardIn .35s ease backwards}
.ind-card:nth-child(2){animation-delay:.04s}
.ind-card:nth-child(3){animation-delay:.08s}
.ind-card:nth-child(4){animation-delay:.12s}
.ind-card:nth-child(5){animation-delay:.16s}
.ind-card:nth-child(6){animation-delay:.20s}

/* ── Detail Panel ── */
.ind-detail-panel{margin-top:20px;border:1px solid rgba(16,185,129,.12);border-radius:14px;animation:indSlideDown .3s ease;background:var(--card);box-shadow:0 4px 20px rgba(0,0,0,.15)}
@keyframes indSlideDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}

/* ── Sub Tabs ── */
.ind-sub-tabs{display:flex;gap:4px;padding:14px 20px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.01)}
.ind-sub-btn{position:relative;background:transparent;border:1px solid transparent;color:var(--muted);padding:10px 22px;border-radius:10px;cursor:pointer;font-size:13px;font-weight:600;transition:all .25s ease;font-family:inherit;letter-spacing:-.1px}
.ind-sub-btn.active{background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(16,185,129,.06));border-color:rgba(16,185,129,.2);color:var(--accent-light);box-shadow:0 2px 8px rgba(16,185,129,.1)}
.ind-sub-btn:hover:not(.active){background:var(--hover);color:var(--text-secondary)}
.ind-sub-content{padding:22px}

/* ── Hydration Bar ── */
.ind-hydrate-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:14px 18px;background:linear-gradient(135deg,rgba(16,185,129,.04),rgba(59,130,246,.02));border:1px solid rgba(16,185,129,.1);border-radius:12px;margin-bottom:20px}
.ind-hydrate-label{font-size:12px;font-weight:700;color:var(--accent-light);white-space:nowrap;letter-spacing:.3px}
.ind-hydrate-btn{background:var(--card);border:1px solid var(--border);color:var(--text-secondary);padding:6px 12px;border-radius:8px;cursor:pointer;font-size:11px;transition:all .2s ease;font-family:inherit;white-space:nowrap;font-weight:600}
.ind-hydrate-btn:hover{background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.3);color:var(--text);transform:translateY(-1px)}

/* ── Collapsible Sections ── */
.ind-section{border:1px solid var(--border);border-radius:12px;margin-bottom:16px;overflow:hidden;transition:border-color .2s}
.ind-section:hover{border-color:rgba(255,255,255,.1)}
.ind-section-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:linear-gradient(135deg,rgba(255,255,255,.025),rgba(255,255,255,.01));cursor:pointer;font-weight:700;font-size:14px;color:var(--text);user-select:none;transition:background .2s;letter-spacing:-.1px}
.ind-section-header:hover{background:rgba(255,255,255,.04)}
.ind-chevron{font-size:11px;transition:transform .25s cubic-bezier(.4,0,.2,1);color:var(--muted)}
.ind-section.collapsed .ind-section-body{display:none}
.ind-section.collapsed .ind-chevron{transform:rotate(-90deg)}
.ind-section-body{padding:18px;border-top:1px solid var(--border)}

/* ── Form Grid ── */
.ind-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.ind-field{display:flex;flex-direction:column;gap:5px}
.ind-field.full{grid-column:1/-1}
.ind-field label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px}
.ind-input{padding:10px 14px;background:var(--input-bg);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:13px;font-family:inherit;transition:all .2s ease}
.ind-input:focus{outline:none;border-color:rgba(16,185,129,.5);box-shadow:0 0 0 3px rgba(16,185,129,.1),0 2px 8px rgba(16,185,129,.06)}
.ind-input::placeholder{color:var(--muted)}
.ind-hint{font-size:12px;color:var(--muted);font-style:italic;margin-bottom:14px;line-height:1.5}

/* ── References ── */
.ind-ref-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}
.ind-ref-card{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:12px;padding:16px;transition:border-color .2s}
.ind-ref-card:hover{border-color:rgba(16,185,129,.15)}
.ind-ref-card h5{font-size:13px;font-weight:800;color:var(--accent-light);margin-bottom:10px;letter-spacing:-.1px}

/* ── Save Bar ── */
.ind-save-bar{display:flex;align-items:center;gap:16px;padding:20px 0;margin-top:10px;border-top:1px solid var(--border)}
.ind-btn-save{background:linear-gradient(135deg,#059669,#10b981);color:#fff;border:none;padding:12px 32px;border-radius:12px;font-weight:800;font-size:14px;cursor:pointer;transition:all .25s ease;font-family:inherit;box-shadow:0 4px 14px rgba(16,185,129,.3);letter-spacing:-.1px}
.ind-btn-save:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(16,185,129,.4)}
.ind-btn-save:active{transform:translateY(0);box-shadow:0 2px 8px rgba(16,185,129,.2)}
.ind-save-hint{font-size:12px;color:var(--muted)}

/* ── Payment Tab ── */
.ind-payment-section{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:768px){.ind-payment-section{grid-template-columns:1fr}}
.ind-payment-card{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:border-color .2s}
.ind-payment-card:hover{border-color:rgba(16,185,129,.15)}
.ind-payment-header{padding:16px 20px;font-weight:800;font-size:14px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,rgba(255,255,255,.03),rgba(255,255,255,.01));letter-spacing:-.1px}
.ind-payment-grid{padding:20px}
.ind-payment-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.03);font-size:13px}
.ind-payment-row:last-child{border-bottom:none;padding-bottom:0}
.ind-payment-val{font-weight:700}
.ind-payment-val.highlight{color:var(--accent-light);font-size:18px;font-weight:900;font-variant-numeric:tabular-nums}
.ind-payment-actions{display:flex;gap:10px;padding:16px 20px;border-top:1px solid var(--border);flex-wrap:wrap;background:rgba(255,255,255,.01)}
.ind-btn-payment{padding:10px 22px;border-radius:10px;font-weight:700;font-size:13px;cursor:pointer;transition:all .25s ease;border:none;font-family:inherit;letter-spacing:-.1px}
.ind-btn-payment:not(.secondary){background:linear-gradient(135deg,#059669,#10b981);color:#fff;box-shadow:0 2px 10px rgba(16,185,129,.2)}
.ind-btn-payment:not(.secondary):hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(16,185,129,.35)}
.ind-btn-payment.secondary{background:var(--card);border:1px solid var(--border);color:var(--text-secondary)}
.ind-btn-payment.secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.ind-payment-link{padding:12px 20px;font-size:12px;word-break:break-all;background:rgba(255,255,255,.01)}
.ind-link{color:var(--accent-light);text-decoration:none;transition:color .2s}
.ind-link:hover{text-decoration:underline;color:#5eead4}
.mono{font-family:'SF Mono','Fira Code',monospace;font-size:12px}

/* ── Documents Tab ── */
.ind-docs-section{padding:0}
.ind-docs-surety-select{display:flex;align-items:center;gap:12px;margin-bottom:20px;font-size:13px;font-weight:600}
.ind-docs-surety-select select{padding:10px 16px;background:var(--input-bg);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:13px;font-family:inherit;cursor:pointer;transition:border-color .2s}
.ind-docs-surety-select select:focus{border-color:var(--accent);outline:none}
.ind-doc-group{margin-bottom:20px;border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:border-color .2s}
.ind-doc-group:hover{border-color:rgba(255,255,255,.1)}
.ind-doc-group-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:linear-gradient(135deg,rgba(255,255,255,.03),rgba(255,255,255,.01));font-weight:800;font-size:13px;letter-spacing:-.1px}
.ind-doc-counter{font-size:11px;color:var(--accent-light);background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(16,185,129,.06));padding:4px 12px;border-radius:14px;font-weight:700;letter-spacing:.3px}
.ind-doc-list{padding:0}
.ind-doc-item{display:flex;align-items:center;gap:12px;padding:12px 18px;border-top:1px solid var(--border);cursor:pointer;transition:all .15s ease;font-size:13px}
.ind-doc-item:hover{background:rgba(16,185,129,.04);padding-left:22px}
.ind-doc-item.signed{background:rgba(16,185,129,.04);border-left:3px solid rgba(16,185,129,.4)}
.ind-doc-check{font-size:16px;width:24px;text-align:center;flex-shrink:0;transition:transform .2s}
.ind-doc-item:hover .ind-doc-check{transform:scale(1.1)}
.ind-doc-label{flex:1;color:var(--text);font-weight:500}
.ind-doc-time{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums}

/* ═══════════════════════════════════════════════════════
   POA INVENTORY MODAL — Premium Glassmorphic Design
   ═══════════════════════════════════════════════════════ */

/* ── Overlay & Container ── */
.inv-overlay{position:fixed;inset:0;background:rgba(6,9,15,.72);backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2);z-index:9000;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}
.inv-overlay.show{display:flex;opacity:1;animation:invFadeIn .25s ease forwards}
.inv-modal{width:92vw;max-width:1100px;max-height:88vh;background:var(--card);border:1px solid rgba(255,255,255,.06);border-radius:20px;box-shadow:0 32px 100px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.04),inset 0 1px 0 rgba(255,255,255,.04);display:flex;flex-direction:column;overflow:hidden;animation:invSlideUp .35s cubic-bezier(.4,0,.2,1)}
@keyframes invFadeIn{from{opacity:0}to{opacity:1}}
@keyframes invSlideUp{from{transform:translateY(32px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}

/* ── Header ── */
.inv-header{display:flex;align-items:center;justify-content:space-between;padding:22px 28px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,rgba(16,185,129,.07),rgba(99,102,241,.04),rgba(245,158,11,.02))}
.inv-header-left{display:flex;align-items:center;gap:16px}
.inv-header-icon{font-size:26px;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(16,185,129,.04));border-radius:14px;border:1px solid rgba(16,185,129,.1)}
.inv-header-title{font-size:19px;font-weight:900;color:var(--text);letter-spacing:-.4px}
.inv-header-subtitle{font-size:12px;color:var(--text-secondary);margin-top:3px;font-weight:500}
.inv-close{width:38px;height:38px;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}
.inv-close:hover{background:rgba(239,68,68,.1);color:var(--red);border-color:rgba(239,68,68,.2);transform:rotate(90deg)}

/* ── KPI Bar ── */
.inv-kpi-bar{display:flex;gap:12px;padding:18px 28px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.01)}
.inv-kpi{flex:1;padding:14px 18px;border-radius:12px;background:var(--surface);border:1px solid var(--border);text-align:center;transition:all .25s ease;position:relative;overflow:hidden}
.inv-kpi::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 60%,rgba(16,185,129,.03));pointer-events:none}
.inv-kpi:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.15)}
.inv-kpi-value{font-size:26px;font-weight:900;color:var(--accent-light);font-variant-numeric:tabular-nums;letter-spacing:-.5px}
.inv-kpi-label{font-size:10px;color:var(--text-secondary);margin-top:4px;text-transform:uppercase;letter-spacing:1px;font-weight:700}
.inv-kpi-osi .inv-kpi-value{color:#818cf8}
.inv-kpi-palm .inv-kpi-value{color:#fbbf24}
.inv-kpi-alert{border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.04)}
.inv-kpi-alert .inv-kpi-value{color:var(--red)}

/* ── Tabs ── */
.inv-tabs{display:flex;gap:0;padding:0 28px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.01)}
.inv-tab-btn{padding:14px 22px;font-size:13px;font-weight:700;color:var(--muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .2s ease;font-family:inherit;letter-spacing:-.1px}
.inv-tab-btn:hover{color:var(--text-secondary)}
.inv-tab-btn.active{color:var(--accent-light);border-bottom-color:var(--accent)}
.inv-tab-pane{flex:1;overflow-y:auto;padding:22px 28px}
.inv-tab-trigger{position:relative}
.inv-tab-trigger::after{content:'';position:absolute;right:6px;top:6px;width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.7;animation:invDot 2s ease-in-out infinite}
@keyframes invDot{0%,100%{opacity:.7}50%{opacity:.3}}

/* ── Summary View — Tier Cards ── */
.inv-surety-section{margin-bottom:28px}
.inv-surety-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-radius:14px 14px 0 0;margin-bottom:0}
.inv-header-osi{background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(99,102,241,.03));border:1px solid rgba(99,102,241,.12)}
.inv-header-palm{background:linear-gradient(135deg,rgba(245,158,11,.1),rgba(245,158,11,.03));border:1px solid rgba(245,158,11,.12)}
.inv-surety-name{display:flex;align-items:center;gap:12px}
.inv-surety-icon{font-size:26px}
.inv-surety-title{font-size:15px;font-weight:900;color:var(--text);letter-spacing:-.2px}
.inv-surety-subtitle{font-size:11px;color:var(--text-secondary);font-weight:500}
.inv-surety-badge{padding:5px 16px;border-radius:20px;font-size:12px;font-weight:800;background:linear-gradient(135deg,rgba(99,102,241,.14),rgba(99,102,241,.06));color:#a5b4fc;letter-spacing:.3px}
.inv-badge-palm{background:linear-gradient(135deg,rgba(245,158,11,.14),rgba(245,158,11,.06));color:#fcd34d}
.inv-tier-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;padding:16px;background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 14px 14px}
.inv-tier-card{padding:16px;border-radius:12px;border:1px solid var(--border);background:var(--card);transition:all .25s ease;cursor:default;position:relative;overflow:hidden}
.inv-tier-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,rgba(16,185,129,.3),transparent);opacity:0;transition:opacity .3s}
.inv-tier-card:hover{transform:translateY(-3px);border-color:rgba(16,185,129,.2);box-shadow:0 10px 30px rgba(0,0,0,.2)}
.inv-tier-card:hover::before{opacity:1}
.inv-tier-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.inv-tier-prefix{font-weight:900;font-size:14px;color:var(--text);font-family:'SF Mono','Fira Code',monospace;letter-spacing:-.3px}
.inv-tier-cap{font-size:11px;color:var(--text-secondary);font-weight:700}
.inv-tier-count{font-size:36px;font-weight:900;color:var(--accent-light);font-variant-numeric:tabular-nums;line-height:1;letter-spacing:-1px}
.inv-tier-bar{height:4px;border-radius:4px;background:rgba(255,255,255,.06);margin:12px 0 10px;overflow:hidden}
.inv-tier-fill{height:100%;border-radius:4px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.inv-fill-ok{background:linear-gradient(90deg,#10b981,#34d399)}
.inv-fill-low{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.inv-fill-critical{background:linear-gradient(90deg,#ef4444,#f87171);animation:invPulse 2s infinite}
@keyframes invPulse{0%,100%{opacity:1}50%{opacity:.4}}
.inv-tier-meta{display:flex;justify-content:space-between;align-items:center}
.inv-health-badge{font-size:10px;font-weight:800;padding:3px 10px;border-radius:14px;text-transform:uppercase;letter-spacing:.6px}
.inv-badge-ok{background:rgba(16,185,129,.12);color:#34d399}
.inv-badge-low{background:rgba(245,158,11,.12);color:#fbbf24}
.inv-badge-critical{background:rgba(239,68,68,.14);color:#f87171}
.inv-next-serial{font-size:10px;color:var(--muted);font-family:'SF Mono','Fira Code',monospace}
.inv-tier-critical{border-color:rgba(239,68,68,.2)}
.inv-tier-low{border-color:rgba(245,158,11,.15)}
.inv-empty-tier{text-align:center;padding:28px;color:var(--muted);font-size:13px}

/* ── Detail View ── */
.inv-detail-controls{margin-bottom:16px}
.inv-filter-row{display:flex;gap:10px;flex-wrap:wrap}
.inv-filter-select{padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:var(--input-bg);color:var(--text);font-size:13px;font-family:inherit;cursor:pointer;transition:border-color .2s}
.inv-filter-select:focus{border-color:var(--accent);outline:none}
.inv-search-input{flex:1;min-width:180px;padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:var(--input-bg);color:var(--text);font-size:13px;font-family:inherit;transition:all .2s ease}
.inv-search-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px rgba(16,185,129,.1),0 2px 8px rgba(16,185,129,.06)}
.inv-table-wrap{overflow-x:auto;border-radius:14px;border:1px solid var(--border)}
.inv-table{width:100%;border-collapse:collapse;font-size:13px}
.inv-table thead{background:linear-gradient(135deg,rgba(255,255,255,.03),rgba(255,255,255,.01))}
.inv-table th{padding:12px 16px;text-align:left;font-weight:800;color:var(--text-secondary);font-size:10px;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border)}
.inv-table td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text)}
.inv-row{transition:background .15s ease}
.inv-row:hover{background:rgba(16,185,129,.03)}
.inv-poa-mono{font-family:'SF Mono','Fira Code',monospace;font-weight:800;font-size:13px;color:var(--accent-light);letter-spacing:-.2px}
.inv-surety-chip{font-size:10px;font-weight:800;padding:4px 12px;border-radius:14px;display:inline-block;letter-spacing:.3px;text-transform:uppercase}
.inv-chip-osi{background:linear-gradient(135deg,rgba(99,102,241,.14),rgba(99,102,241,.06));color:#a5b4fc}
.inv-chip-palm{background:linear-gradient(135deg,rgba(245,158,11,.14),rgba(245,158,11,.06));color:#fcd34d}
.inv-cell-tier{font-family:'SF Mono','Fira Code',monospace;font-size:12px;color:var(--text-secondary)}
.inv-cell-bond{font-weight:700;color:var(--accent-light)}
.inv-cell-case{font-family:'SF Mono','Fira Code',monospace;font-size:12px;color:var(--text-secondary)}
.inv-cell-actions{white-space:nowrap}
.inv-status-pill{font-size:10px;font-weight:800;padding:4px 12px;border-radius:14px;text-transform:uppercase;letter-spacing:.4px}
.inv-st-available{background:linear-gradient(135deg,rgba(16,185,129,.14),rgba(16,185,129,.06));color:#34d399}
.inv-st-assigned{background:linear-gradient(135deg,rgba(59,130,246,.14),rgba(59,130,246,.06));color:#60a5fa}
.inv-st-voided{background:linear-gradient(135deg,rgba(239,68,68,.14),rgba(239,68,68,.06));color:#f87171}
.inv-btn{padding:5px 12px;border-radius:8px;font-size:11px;font-weight:700;border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;margin-right:4px;transition:all .2s ease;font-family:inherit}
.inv-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.15)}
.inv-btn-assign:hover{border-color:var(--accent);color:var(--accent);background:rgba(16,185,129,.06)}
.inv-btn-void:hover{border-color:var(--red);color:var(--red);background:rgba(239,68,68,.06)}
.inv-btn-reassign:hover{border-color:var(--blue);color:var(--blue);background:rgba(59,130,246,.06)}
.inv-btn-restore:hover{border-color:var(--accent);color:var(--accent);background:rgba(16,185,129,.06)}

/* ── Pagination ── */
.inv-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 0}
.inv-page-btn{padding:8px 18px;border-radius:10px;border:1px solid var(--border);background:var(--card);color:var(--text);font-size:13px;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit}
.inv-page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.inv-page-btn:disabled{opacity:.3;cursor:not-allowed}
.inv-page-info{font-size:12px;color:var(--text-secondary);font-weight:600}

/* ── Add Powers Form ── */
.inv-add-section{padding:4px 0}
.inv-add-title{font-size:15px;font-weight:900;color:var(--text);margin-bottom:18px;display:flex;align-items:center;gap:8px;letter-spacing:-.2px}
.inv-add-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.inv-add-field{display:flex;flex-direction:column;gap:6px}
.inv-add-field label{font-size:10px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px}
.inv-hint{text-transform:none;letter-spacing:0;font-weight:400;color:var(--muted);font-size:11px}
.inv-add-input{padding:12px 16px;border-radius:10px;border:1px solid var(--border);background:var(--input-bg);color:var(--text);font-size:14px;font-family:inherit;transition:all .2s ease}
.inv-add-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px rgba(16,185,129,.1),0 2px 8px rgba(16,185,129,.06)}
.inv-add-actions{margin-top:20px;display:flex;align-items:center;gap:14px}
.inv-btn-submit{padding:12px 28px;border-radius:12px;border:none;background:linear-gradient(135deg,#059669,#10b981);color:#fff;font-size:14px;font-weight:800;cursor:pointer;transition:all .25s ease;font-family:inherit;box-shadow:0 4px 14px rgba(16,185,129,.3);letter-spacing:-.1px}
.inv-btn-submit:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(16,185,129,.4)}
.inv-btn-submit:active{transform:translateY(0);box-shadow:0 2px 8px rgba(16,185,129,.2)}
.inv-btn-cancel{padding:12px 28px;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:14px;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit}
.inv-btn-cancel:hover{border-color:var(--red);color:var(--red);transform:translateY(-1px)}
.inv-add-status{font-size:13px}
.inv-form-error{color:var(--red);font-weight:700}
.inv-form-success{color:var(--accent);font-weight:700}
.inv-add-divider{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:32px 0}

/* ── Image Upload Zone ── */
.inv-upload-zone{border:2px dashed rgba(16,185,129,.2);border-radius:16px;padding:40px 28px;text-align:center;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,rgba(16,185,129,.02),rgba(59,130,246,.01))}
.inv-upload-zone:hover,.inv-upload-zone.dragover{border-color:var(--accent);background:rgba(16,185,129,.04);transform:translateY(-3px);box-shadow:0 10px 30px rgba(16,185,129,.08)}
.inv-upload-icon{font-size:40px;margin-bottom:12px;opacity:.8}
.inv-upload-text{font-size:14px;color:var(--text);font-weight:700}
.inv-upload-link{color:var(--accent-light);text-decoration:underline;cursor:pointer;font-weight:600}
.inv-upload-hint{font-size:12px;color:var(--muted);margin-top:8px}
.inv-upload-result{margin-top:18px}
.inv-upload-error{color:var(--red);font-weight:700;font-size:13px;padding:14px;background:rgba(239,68,68,.06);border-radius:10px;border:1px solid rgba(239,68,68,.12)}
.inv-upload-warn{color:var(--gold);font-weight:700;font-size:13px;padding:14px;background:rgba(245,158,11,.06);border-radius:10px;border:1px solid rgba(245,158,11,.12)}
.inv-upload-success{padding:18px;background:rgba(16,185,129,.04);border-radius:12px;border:1px solid rgba(16,185,129,.12)}
.inv-upload-count{font-size:15px;font-weight:800;color:var(--accent);margin-bottom:12px}
.inv-extracted-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.inv-extracted-num{font-family:'SF Mono','Fira Code',monospace;font-size:12px;font-weight:800;padding:5px 12px;background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(16,185,129,.06));color:var(--accent-light);border-radius:8px;border:1px solid rgba(16,185,129,.12)}
.inv-upload-confirm-row{display:flex;gap:12px;align-items:center}

/* ── States ── */
.inv-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--text-secondary);font-size:13px;font-weight:500}
.inv-loading-sm{padding:8px}
.inv-error{padding:28px;text-align:center;color:var(--red);font-size:13px;font-weight:700}
.inv-empty-state{text-align:center;padding:40px;color:var(--muted);font-size:13px}

/* ── Responsive ── */
@media(max-width:700px){
  .inv-modal{width:98vw;max-height:95vh;border-radius:16px}
  .inv-header{padding:16px 18px}
  .inv-kpi-bar{padding:12px 18px;flex-wrap:wrap}
  .inv-kpi{min-width:calc(50% - 6px)}
  .inv-tabs{padding:0 18px;overflow-x:auto}
  .inv-tab-pane{padding:16px 18px}
  .inv-add-grid{grid-template-columns:1fr}
  .inv-tier-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .inv-filter-row{flex-direction:column}
}
