:root{
  --brand:#1b3c8c; --brand-dark:#142c66; --brand-light:#2f56b8; --accent:#f47a20;
  --sidebar:#0f255c; --sidebar-hover:#1b3a78; --sidebar-active:#2f56b8;
  --bg:#eef2f8; --card:#fff; --ink:#1c2733; --muted:#6b7a8a; --line:#e3e8ee;
  --sidebar-w:240px; --sidebar-mini:64px; --topbar-h:58px;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Segoe UI',Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px}

/* ---------- LOGIN (split screen) ---------- */
.login-body{margin:0;min-height:100vh;background:#fff}
.login-split{display:flex;min-height:100vh}

/* left brand panel */
.login-brand{position:relative;flex:1.1;overflow:hidden;color:#fff;
  background:linear-gradient(135deg,#1b3c8c 0%,#142c66 55%,#0f255c 100%);
  display:flex;align-items:center;padding:60px}
.brand-inner{position:relative;z-index:2;max-width:480px}
.brand-badge{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:7px 14px;border-radius:30px}
.brand-badge i{color:var(--accent)}
.login-brand h1{font-size:42px;font-weight:800;line-height:1.15;margin:26px 0 16px}
.login-brand h1 span{color:var(--accent)}
.brand-tag{font-size:15px;color:#cfd8ee;line-height:1.6;margin-bottom:28px}
.brand-points{list-style:none;padding:0;margin:0}
.brand-points li{display:flex;align-items:center;gap:11px;font-size:14.5px;color:#e7ecf8;margin-bottom:13px}
.brand-points i{color:var(--accent);font-size:18px}
.brand-shape{position:absolute;border-radius:50%;background:rgba(255,255,255,.06)}
.brand-shape.s1{width:380px;height:380px;right:-120px;top:-120px}
.brand-shape.s2{width:260px;height:260px;right:60px;bottom:-130px;background:rgba(244,122,32,.14)}

/* right form panel */
.login-form-wrap{flex:.9;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px}
.login-card{width:100%;max-width:380px}
.login-logo-img{height:82px;margin-bottom:24px}
.login-note{font-size:12px;color:var(--muted,#6b7280);background:#f6f8fc;border:1px solid #e5e9f2;border-radius:8px;padding:8px 10px;margin:10px 0 4px;line-height:1.4}
.login-title{font-size:26px;font-weight:800;color:var(--ink);margin:0}
.login-subtitle{color:var(--muted);font-size:14px;margin:6px 0 26px}
.fld-label{display:block;font-size:13px;font-weight:600;color:#36465a;margin-bottom:7px}
.fld{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:10px;padding:0 12px;transition:border-color .15s,box-shadow .15s;background:#fff}
.fld:focus-within{border-color:var(--brand-light);box-shadow:0 0 0 3px rgba(47,86,184,.12)}
.fld i{color:#9aa7b8;font-size:16px}
.fld input{flex:1;border:none;outline:none;padding:12px 10px;font-size:14.5px;background:transparent}
.toggle-pw{border:none;background:none;color:#9aa7b8;cursor:pointer;padding:4px}
.remember{font-size:13px;color:#5a6b7e;display:flex;align-items:center;gap:7px;cursor:pointer;margin:0}
.btn-signin{width:100%;margin-top:24px;background:linear-gradient(135deg,#2f56b8,#1b3c8c);color:#fff;
  border:none;border-radius:10px;padding:13px;font-size:15px;font-weight:700;display:flex;
  align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:transform .08s,box-shadow .15s;
  box-shadow:0 6px 18px rgba(27,60,140,.32)}
.btn-signin:hover{box-shadow:0 8px 24px rgba(27,60,140,.45)}
.btn-signin:active{transform:translateY(1px)}
.login-or{display:flex;align-items:center;text-align:center;color:#9aa7b8;font-size:12px;margin:18px 0}
.login-or::before,.login-or::after{content:"";flex:1;height:1px;background:var(--line)}
.login-or span{padding:0 12px}
.btn-ms{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;border:1.5px solid var(--line);
  border-radius:10px;padding:12px;font-size:14.5px;font-weight:600;color:#2f2f2f;background:#fff;text-decoration:none;transition:background .15s,border-color .15s}
.btn-ms:hover{background:#f6f8fb;border-color:#c7d2e3}
.btn-ms i{color:#2f6fed;font-size:18px}
.btn-ms-primary{background:linear-gradient(135deg,#2f56b8,#1b3c8c);color:#fff;border:none;box-shadow:0 6px 18px rgba(27,60,140,.30)}
.btn-ms-primary:hover{background:linear-gradient(135deg,#356ae0,#1f4499);box-shadow:0 8px 24px rgba(27,60,140,.42)}
.btn-ms-primary i{color:#fff}
.pw-link{display:block;width:100%;text-align:center;background:none;border:none;color:var(--brand-light);font-size:13.5px;font-weight:600;cursor:pointer;padding:6px}
.pw-link:hover{text-decoration:underline}
.login-hint{margin-top:14px;text-align:center;font-size:12px;color:#8694a6}
.login-foot{margin-top:22px;text-align:center;font-size:11.5px}
.login-copy{margin-top:30px;font-size:11.5px;color:#9aa7b8}

@media (max-width:880px){
  .login-brand{display:none}
  .login-form-wrap{flex:1}
}

/* ---------- SIDEBAR ---------- */
.sidebar{position:fixed;top:0;left:0;height:100vh;width:var(--sidebar-w);background:var(--sidebar);
  color:#cdd9de;display:flex;flex-direction:column;transition:width .18s ease;z-index:30;overflow-y:auto;overflow-x:hidden}
/* slim scrollbar so the full menu is reachable on short screens */
.sidebar::-webkit-scrollbar{width:7px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:4px}
.sidebar::-webkit-scrollbar-track{background:transparent}
.sidebar{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.22) transparent}
.sidebar .brand{display:flex;align-items:center;gap:10px;padding:16px 18px;font-size:17px;color:#fff;white-space:nowrap;flex:0 0 auto}
.sidebar .brand i{color:var(--accent);font-size:20px;min-width:24px;text-align:center}
.sidebar .brand b{color:#fff}
.sidebar .brand .brand-logo{height:30px;width:30px;object-fit:contain;border-radius:7px;background:#fff;padding:3px}
.nav-list{list-style:none;margin:0;padding:6px 0}
.nav-list li a{display:flex;align-items:center;gap:12px;padding:11px 20px;color:#cdd9de;text-decoration:none;white-space:nowrap}
.nav-list li a i{font-size:17px;min-width:22px;text-align:center}
.nav-list li a:hover{background:var(--sidebar-hover);color:#fff}
.nav-list li.active a{background:var(--sidebar-active);color:#fff;border-left:3px solid var(--accent);padding-left:17px}
.nav-section{display:flex;justify-content:space-between;align-items:center;padding:14px 20px 4px;
  font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:#6e8893}

/* collapsed (mini) */
body.sidebar-collapsed .sidebar{width:var(--sidebar-mini)}
body.sidebar-collapsed .link-text,body.sidebar-collapsed .brand-text{display:none}
body.sidebar-collapsed .main{margin-left:var(--sidebar-mini)}

/* ---------- MAIN ---------- */
.main{margin-left:var(--sidebar-w);transition:margin-left .18s ease;min-height:100vh}
.topbar{height:var(--topbar-h);background:linear-gradient(90deg,var(--brand-dark) 0%,var(--brand) 45%,var(--brand-light) 100%);
  border-bottom:none;box-shadow:0 2px 10px rgba(16,32,48,.15);
  display:flex;align-items:center;gap:14px;padding:0 20px;position:sticky;top:0;z-index:20}
.burger{border:none;background:rgba(255,255,255,.16);width:38px;height:38px;border-radius:8px;font-size:18px;color:#fff;cursor:pointer}
.burger:hover{background:rgba(255,255,255,.30)}
.page-title{font-size:17px;font-weight:600;margin:0;color:#fff}
.topbar-right{margin-left:auto}
.btn-user{border:1px solid var(--line);background:#fff;border-radius:22px;padding:5px 12px;display:flex;align-items:center;gap:8px;cursor:pointer}
.btn-user i{font-size:18px;color:var(--brand)}
.role-tag{background:var(--brand);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px}

.content{padding:22px}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kpi-card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;display:flex;align-items:center;gap:14px;box-shadow:0 1px 3px rgba(16,32,48,.06)}
.kpi-icon{width:46px;height:46px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff}
.kpi-icon.teal{background:var(--brand)} .kpi-icon.blue{background:#2d7dd2}
.kpi-icon.orange{background:var(--accent)} .kpi-icon.green{background:#1f9d55}
.kpi-num{font-size:22px;font-weight:800}
.kpi-label{font-size:12px;color:var(--muted)}
.panel{background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:0 1px 3px rgba(16,32,48,.06)}
.panel-head{padding:13px 18px;border-bottom:1px solid var(--line);font-weight:600}
.panel-body{padding:18px}

@media (max-width:820px){
  .sidebar{width:var(--sidebar-mini)} .main{margin-left:var(--sidebar-mini)}
  .link-text,.brand-text{display:none}
  body.sidebar-collapsed .sidebar{width:var(--sidebar-w)}
  body.sidebar-collapsed .link-text,body.sidebar-collapsed .brand-text{display:inline}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
}

/* ============ PHASE 1 : grids, filters, badges ============ */
.page-flex{display:flex;gap:18px;align-items:flex-start}
.filter-panel{width:248px;flex:none;background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:0 1px 3px rgba(16,32,48,.06);position:sticky;top:74px}
.fp-head{padding:13px 16px;border-bottom:1px solid var(--line);font-weight:600;font-size:13.5px}
.fp-head i{color:var(--brand)}
.fp-body{padding:14px 16px}
.fp-body label{display:block;font-size:11.5px;font-weight:600;color:#5a6b7e;margin:12px 0 5px;text-transform:uppercase;letter-spacing:.3px}
.fp-body label:first-child{margin-top:0}
.fp-input{width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:13px;background:#fff}
.fp-input:focus{outline:none;border-color:var(--brand-light);box-shadow:0 0 0 3px rgba(47,86,184,.1)}
.fp-clear{width:100%;margin-top:16px;background:#f4f6f9;border:1px solid var(--line);border-radius:8px;padding:8px;font-size:12.5px;color:#5a6b7e;cursor:pointer}
.fp-clear:hover{background:#eaeef3}

.grid-wrap{flex:1;min-width:0}
.grid-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.gt-info{font-size:13px;color:var(--muted)}
.gt-size{font-size:12.5px;color:var(--muted)}
.gt-size select{border:1px solid var(--line);border-radius:6px;padding:4px 6px;margin-left:4px}
.grid-panel{overflow:auto}
.grid-table{width:100%;border-collapse:collapse;font-size:13.5px}
.grid-table thead th{text-align:left;padding:11px 14px;background:#f7f9fc;border-bottom:1px solid var(--line);
  font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:#6b7a8a;white-space:nowrap;cursor:pointer;position:sticky;top:0}
.grid-table tbody td{padding:11px 14px;border-bottom:1px solid #eef1f5;vertical-align:middle}
.grid-table tbody tr:hover{background:#f8fafc}
.grid-table tbody tr.clickable{cursor:pointer}
.cell-name{font-weight:600;color:var(--ink)}
.cell-sub{font-size:11.5px;color:var(--muted)}
.acc-ico{color:var(--brand)}
.acc-link{color:var(--brand);text-decoration:none;font-weight:600}
.acc-link:hover{text-decoration:underline}
.empty-row,.grid-loading{text-align:center;color:var(--muted);padding:40px!important}
.li-btn{color:#0a66c2;font-size:16px}

.src-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;white-space:nowrap}
.src-badge i{font-size:10px}
.src-seamless{background:#e7f0ff;color:#1b57c4}.src-apollo{background:#efe9ff;color:#6a3fd1}
.src-lusha{background:#e6f7f1;color:#0d8a5f}.src-zoominfo{background:#fff0e6;color:#c2620f}
.src-manual{background:#eef1f5;color:#5a6b7e}.src-ai{background:#fdeede;color:#b25b00}.src-other{background:#eef1f5;color:#5a6b7e}

.st-badge{display:inline-block;font-size:11px;font-weight:600;padding:3px 9px;border-radius:6px;max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.st-genuine{background:#e7f6ec;color:#1f8a4c}.st-junk{background:#fbeae8;color:#c0392b}
.st-verify{background:#fff6e5;color:#b8860b}.st-none{background:#eef1f5;color:#8a97a6}
.type-badge{background:#eaf0fb;color:#1b3c8c;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:6px}
.cnt-badge{background:var(--brand);color:#fff;font-size:11.5px;font-weight:700;padding:2px 9px;border-radius:20px}

.grid-foot{display:flex;justify-content:flex-end;margin-top:12px}
.pager{display:flex;align-items:center;gap:6px}
.pg-btn{border:1px solid var(--line);background:#fff;border-radius:7px;width:34px;height:34px;cursor:pointer;color:var(--ink)}
.pg-btn:hover:not([disabled]){background:#f0f3f7}
.pg-btn[disabled]{opacity:.4;cursor:not-allowed}
.pg-info{font-size:12.5px;color:var(--muted);padding:0 8px}

/* account detail */
.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--brand);text-decoration:none;font-size:13px;font-weight:600;margin-bottom:14px}
.acc-detail-head{display:flex;align-items:center;gap:18px;padding:20px}
.acc-avatar{width:60px;height:60px;border-radius:14px;background:linear-gradient(135deg,#2f56b8,#1b3c8c);color:#fff;display:flex;align-items:center;justify-content:center;font-size:26px}
.acc-meta{flex:1}.acc-meta h2{margin:0;font-size:22px;font-weight:800}
.acc-tags{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}
.chip{background:#eef1f5;color:#5a6b7e;font-size:12px;padding:3px 10px;border-radius:20px}
.acc-stat{text-align:center}.acc-stat-num{font-size:26px;font-weight:800;color:var(--brand)}
.acc-stat-lbl{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.acc-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
.info-row{display:flex;justify-content:space-between;gap:14px;padding:8px 0;border-bottom:1px solid #eef1f5;font-size:13.5px}
.info-row:last-child{border-bottom:none}
.info-row span{color:var(--muted);white-space:nowrap}
.info-row b{text-align:right;word-break:break-word}
@media (max-width:980px){.acc-grid-2{grid-template-columns:1fr}.filter-panel{width:210px}}

/* ===== contact detail: header extras ===== */
.cd-subtitle{margin-top:4px;color:var(--muted);font-size:13.5px;font-weight:500}
.cd-head-actions{display:flex;align-items:center;gap:8px}
.cd-pad{padding:8px 10px}
.cd-count{display:inline-block;min-width:18px;margin-left:6px;padding:0 7px;font-size:11px;font-weight:700;
  color:var(--brand);background:#eef2fb;border-radius:20px;line-height:18px;text-align:center}
.cd-empty{color:var(--muted);font-size:13px;padding:10px 4px}

/* ===== contact-method list (emails / phones) ===== */
.cm-item{display:flex;align-items:center;gap:12px;padding:11px 10px;border-radius:10px;transition:background .12s}
.cm-item + .cm-item{border-top:1px solid #eef1f5}
.cm-item:hover{background:#f7f9fc}
.cm-icon{width:34px;height:34px;flex:none;border-radius:9px;background:#eef2fb;color:var(--brand-light);
  display:flex;align-items:center;justify-content:center;font-size:15px}
.cm-body{flex:1;min-width:0}
.cm-main{font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cm-main a{word-break:break-all}
.cm-pill{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#1b7a4b;
  background:#e4f6ec;border:1px solid #bfe9d0;border-radius:5px;padding:1px 6px}
.cm-meta{margin-top:5px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.cm-type{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:2px 8px;border-radius:5px}
.cm-type-direct{color:#2f56b8;background:#eaf0fc}
.cm-type-mobile{color:#7a3db8;background:#f1eafc}
.cm-type-company{color:#5a6b7e;background:#eef1f5}
.cm-conf{flex:none;width:128px;text-align:right}
.cm-conf-lbl{font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:3px}
.conf{display:flex;align-items:center;gap:7px;justify-content:flex-end}
.conf-track{flex:1;height:7px;border-radius:5px;background:#e9edf2;overflow:hidden}
.conf-track span{display:block;height:100%;border-radius:5px}
.conf b{font-size:12px;font-weight:700;min-width:34px;text-align:right}
.conf-hi .conf-track span{background:#22a35a}.conf-hi b{color:#1b7a4b}
.conf-mid .conf-track span{background:#e8a317}.conf-mid b{color:#b9790a}
.conf-lo .conf-track span{background:#e0524d}.conf-lo b{color:#c23b36}
.conf-na{color:#b7c0c9;font-size:13px}

/* company description + collapsible raw block */
.cd-desc{margin-top:12px;padding-top:12px;border-top:1px solid #eef1f5;font-size:12.8px;color:#54616e;line-height:1.55;
  white-space:pre-line;max-height:170px;overflow:auto}
.cd-collapse-head{display:flex;align-items:center;justify-content:space-between}
.spin{display:inline-block;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== email-verification settings ===== */
.ev-credits{display:flex;gap:10px;margin-top:12px}
.ev-cred-box{flex:1;border:1px solid var(--line);border-radius:9px;padding:9px 11px;background:#f7f9fc;text-align:center}
.ev-cred-num{font-size:19px;font-weight:800;color:var(--brand)}
.ev-cred-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;margin-top:2px}
.ev-route-grid{display:flex;flex-direction:column;gap:10px}
.ev-route-row{display:grid;grid-template-columns:1fr 220px 70px;align-items:center;gap:14px;
  padding:11px 12px;border:1px solid var(--line);border-radius:10px;background:#fff}
.ev-route-lbl{font-weight:600;font-size:14px}
.ev-route-hint{font-size:11.5px;color:var(--muted);margin-top:2px}
.ev-route-msg{font-size:11.5px;font-weight:600}
.ev-route-msg.ok{color:#1b7a4b}.ev-route-msg.err{color:#c23b36}
@media (max-width:760px){.ev-route-row{grid-template-columns:1fr;gap:8px}}
/* deliverability badge */
.dlv-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:5px;text-transform:uppercase;letter-spacing:.3px}
.dlv-deliverable{color:#1b7a4b;background:#e4f6ec}
.dlv-undeliverable{color:#c23b36;background:#fae8e7}
.dlv-risky{color:#b9790a;background:#fcf3e2}
.dlv-unknown,.dlv-noemail,.dlv-error{color:#5a6b7e;background:#eef1f5}
.dlv-summary{display:flex;align-items:center;gap:10px;margin-top:12px;padding-top:12px;border-top:1px solid #eef1f5}
.dlv-summary-lbl{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}
.dlv-when{font-size:11.5px;color:var(--muted)}
.dlv-row{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:12.5px}
.dlv-prov{min-width:120px;font-weight:600}
.dlv-reason{color:var(--muted);font-size:11.5px}
/* source label on email rows */
.cm-src{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#2f56b8;background:#eaf0fc;border-radius:4px;padding:1px 6px}
.cm-na{color:#9aa7b4;font-size:11.5px;font-style:italic}
/* "Our checks" block */
.oc-block{margin-top:12px;padding:12px;border:1px dashed #d6deea;border-radius:10px;background:#fafbfd}
.oc-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--muted);margin-bottom:8px;word-break:break-all}
.oc-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 0;border-bottom:1px solid #eef1f5;font-size:13px}
.oc-row:last-child{border-bottom:none}
.oc-lbl{color:#54616e;font-weight:600}
.oc-by{display:inline-block;margin-left:6px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#7a3db8;background:#f1eafc;border-radius:4px;padding:1px 6px;vertical-align:middle}
.oc-sub{display:flex;align-items:center;gap:9px;padding:5px 0 5px 14px;font-size:12px}
.oc-prov{min-width:118px;font-weight:600;color:#445}
.oc-reason{color:var(--muted);font-size:11.5px}
/* labeled email signals in the contacts grid cell */
.em-sigs{display:flex;flex-wrap:wrap;gap:5px 10px;margin-top:4px}
.em-sig{display:inline-flex;align-items:center;gap:4px}
.em-sig-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#9aa7b4}
.em-na{color:#aab3bd;font-size:11px;font-style:italic}
/* per-email verification table (contact detail) */
.em-table{width:100%;border-collapse:collapse;font-size:12.5px;min-width:840px}
.em-table th{text-align:left;padding:9px 10px;border-bottom:2px solid var(--line);font-size:10.5px;
  text-transform:uppercase;letter-spacing:.3px;color:#5a6b7e;white-space:nowrap;background:#fafbfc}
.em-table td{padding:10px;border-bottom:1px solid #eef1f5;vertical-align:middle}
.em-table tr:hover td{background:#f7f9fc}
.em-th-chk{width:34px;text-align:center}
.em-addr a{font-weight:600;word-break:break-all}
.em-addr .cm-pill{margin-left:6px}
.em-slot{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#5a6b7e;background:#eef1f5;border-radius:5px;padding:2px 7px}
.em-score{font-weight:700;color:#445;font-size:11.5px}
.em-table .conf{min-width:90px}
.reco{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:6px;white-space:nowrap}
.reco-safe{color:#157347;background:#e4f6ec;border:1px solid #bfe9d0}
.reco-no{color:#c23b36;background:#fae8e7;border:1px solid #f3c9c6}
.reco-risky{color:#b9790a;background:#fcf3e2;border:1px solid #f0dcae}
.reco-none{color:#7a8794;background:#eef1f5}
/* list-page total chips */
.tot-chips{display:inline-flex;gap:8px;flex-wrap:wrap}
.tot-chip{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--brand);
  background:#eef2fb;border:1px solid #dce6f7;border-radius:20px;padding:3px 11px}

/* ============ PHASE 2 : integrations / AI keys ============ */
.fp-label{display:block;font-size:11.5px;font-weight:600;color:#5a6b7e;margin-bottom:5px;text-transform:uppercase;letter-spacing:.3px}
.sync-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.btn-primary-sm{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-weight:600;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.btn-primary-sm:hover{background:var(--brand-dark)}
.btn-soft{background:#eef2f8;color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:8px 14px;font-weight:600;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.btn-soft:hover{background:#e3e9f3}
.sync-msg{font-size:13px;margin-left:8px}
.sync-msg.ok{color:#1f8a4c}.sync-msg.err{color:#c0392b}
.prov-msg{font-size:12px;margin-top:6px}.prov-msg.ok{color:#1f8a4c}

.prov-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.prov-card{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.prov-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;background:#f7f9fc;border-bottom:1px solid var(--line)}
.prov-name{display:flex;align-items:center;gap:10px;font-weight:700}
.prov-ico{width:32px;height:32px;border-radius:8px;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px}
.prov-body{padding:14px 16px}
.prov-foot{display:flex;align-items:center;gap:10px;margin-top:12px}
.prov-status{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px}
.prov-status.on{background:#e7f6ec;color:#1f8a4c}.prov-status.off{background:#eef1f5;color:#8a97a6}
.prov-last{font-size:11.5px;color:var(--muted);flex:1}

/* toggle switch */
.switch{position:relative;display:inline-block;width:42px;height:23px}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;inset:0;background:#cbd5e1;border-radius:23px;transition:.2s;cursor:pointer}
.slider:before{content:"";position:absolute;height:17px;width:17px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked+.slider{background:var(--brand)}
.switch input:checked+.slider:before{transform:translateX(19px)}
@media (max-width:900px){.sync-grid{grid-template-columns:1fr 1fr}.prov-grid{grid-template-columns:1fr}}

/* ============ PHASE 2 : users + matrix ============ */
.tabbar{display:flex;gap:4px;border-bottom:2px solid var(--line);margin-bottom:18px}
.tab{background:none;border:none;padding:10px 18px;font-size:13.5px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;display:inline-flex;align-items:center;gap:7px}
.tab.active{color:var(--brand);border-bottom-color:var(--brand)}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:9px;overflow:hidden}
.seg-btn{border:none;background:#fff;padding:7px 14px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer}
.seg-btn+.seg-btn{border-left:1px solid var(--line)}
.seg-btn.active{background:var(--brand);color:#fff}
.seg-btn .cnt-badge{margin-left:6px}
.um-rolesel{padding:5px 8px;border:1px solid var(--line);border-radius:7px;font-size:12.5px}
.row-actions{display:flex;align-items:center;gap:6px}
.ico-btn{border:1px solid var(--line);background:#fff;border-radius:7px;width:32px;height:32px;cursor:pointer;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;padding:0;text-decoration:none;line-height:1}
.ico-btn:hover{background:#f0f3f7}
.ico-btn.danger{color:#c0392b}.ico-btn.danger:hover{background:#fbeae8}
.role-pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px}
.role-SUPERADMIN{background:#ede7ff;color:#5b35c9}
.role-ADMIN{background:#e7f0ff;color:#1b57c4}
.role-USER{background:#eef1f5;color:#5a6b7e}

.matrix-table{width:100%;border-collapse:collapse;font-size:13px}
.matrix-table th,.matrix-table td{border:1px solid var(--line);padding:9px 12px;text-align:center}
.matrix-table .mx-mod{text-align:left;font-weight:600;background:#f7f9fc;white-space:nowrap}
.matrix-table .mx-role{background:var(--brand);color:#fff;font-weight:700}
.matrix-table .mx-sub{background:#f0f3f8;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:#5a6b7e}
.matrix-table .mx-c input{width:17px;height:17px;cursor:pointer}
.mx-admin{font-size:9.5px;background:#fdeede;color:#b25b00;padding:1px 6px;border-radius:10px;font-weight:700;text-transform:uppercase}

/* ============ PHASE 4 : import/export jobs ============ */
.ie-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.btn-sm{padding:5px 10px!important;font-size:12px!important}
.pbar{display:inline-block;width:120px;height:8px;background:#e9eef5;border-radius:6px;overflow:hidden;vertical-align:middle}
.pbar-fill{height:100%;transition:width .3s;background:var(--brand)}
.pbar-run{background:var(--brand)}.pbar-done{background:#1f9d55}.pbar-fail{background:#c0392b}
/* the JS emits pb-run/pb-done/pb-fail; keep colors in sync with the pbar-* names above */
.pb-run{background:var(--brand)}.pb-done{background:#1f9d55}.pb-fail{background:#c0392b}
.pbar-num{font-size:11.5px;color:var(--muted);margin-left:7px}
@media (max-width:900px){.ie-grid{grid-template-columns:1fr}}

/* ============ PHASE 5 : dashboard ============ */
.bar-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.bar-label{width:130px;flex:none}
.bar-track{flex:1;height:10px;background:#eef2f7;border-radius:6px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,#2f56b8,#1b3c8c);border-radius:6px}
.bar-val{width:36px;text-align:right;font-weight:700;font-size:13px}

/* ============ top filter bar ============ */
.filterbar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;background:var(--card);
  border:1px solid var(--line);border-radius:12px;box-shadow:0 1px 3px rgba(16,32,48,.06);padding:14px 16px;margin-bottom:16px}
.fb-field{display:flex;flex-direction:column;min-width:150px}
.fb-field.fb-search{flex:1;min-width:230px}
.fb-field label{font-size:10.5px;font-weight:600;color:#5a6b7e;text-transform:uppercase;letter-spacing:.3px;margin-bottom:5px}
.filterbar .fp-input{width:100%}
.fb-clear{background:#f4f6f9;border:1px solid var(--line);border-radius:8px;padding:9px 14px;font-size:12.5px;
  font-weight:600;color:#5a6b7e;cursor:pointer;height:37px;white-space:nowrap}
.fb-clear:hover{background:#eaeef3}
.fb-daterange{display:flex;align-items:center;gap:5px}
.fb-daterange .fp-input{min-width:0;flex:1;padding-left:8px;padding-right:6px}
.fb-daterange .fb-dash{color:#9aa7b4;font-weight:600}
.fb-field:has(.fb-daterange){min-width:230px}
@media (max-width:760px){.fb-field,.fb-field.fb-search{min-width:100%;flex:1 1 100%}}

/* ============ field mapping ============ */
.map-head{display:grid;grid-template-columns:1fr 1fr 34px;gap:10px;font-size:10.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:.3px;color:#5a6b7e;padding:0 2px 6px;border-bottom:1px solid var(--line);margin-bottom:8px}
.map-row{display:grid;grid-template-columns:1fr 1fr 34px;gap:10px;margin-bottom:8px;align-items:center}
#map-rows{max-height:340px;overflow:auto}

/* ============ contact detail : extra columns ============ */
.extra-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px}
.extra-cell{border:1px solid var(--line);border-radius:8px;padding:9px 11px;background:#fafbfc}
.extra-k{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#5a6b7e;margin-bottom:3px}
.extra-v{font-size:13px;word-break:break-word}

/* ============ data sync ============ */
.mini{font-size:11.5px;color:var(--muted)}
.mini b{color:var(--ink)}
