/* ═══════════════════════════════════════════════════════════
   Koppelbaar CRM — Stylesheet  (Light-first, professional)
   ═══════════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── LIGHT (default) ── */
:root{
  --p:#6D28D9;--p2:#5B21B6;--p-light:#EDE9FE;--p-glow:#6D28D918;--p-border:#6D28D930;
  --bg:#F4F5F9;--bg2:#FFFFFF;--bg3:#F0F1F7;--bg4:#E6E8F2;--bg5:#D4D7EC;
  --border:#E1E4F0;--border2:#CDD0E8;--border3:#B0B5D8;
  --text:#111827;--text2:#4B5280;--text3:#9397B8;
  --green:#059669;--green-dim:#D1FAE5;--green-border:#05966920;
  --red:#DC2626;--red-dim:#FEE2E2;--red-border:#DC262628;
  --amber:#B45309;--amber-dim:#FEF3C7;--amber-border:#B4530928;
  --blue:#1D4ED8;--blue-dim:#DBEAFE;--blue-border:#1D4ED828;
  --cyan:#0E7490;--cyan-dim:#CFFAFE;--cyan-border:#0E749028;
  --r:8px;--r2:12px;--r3:16px;
  --shadow:0 4px 20px rgba(0,0,0,.08);
  --shadow-sm:0 1px 6px rgba(0,0,0,.06);
  --shadow-lg:0 12px 40px rgba(0,0,0,.12);
  --trans:.14s ease;
}

/* ── DARK ── */
body.dark{
  --bg:#0F0F1A;--bg2:#161622;--bg3:#1E1E30;--bg4:#26263E;--bg5:#30304E;
  --border:#ffffff0c;--border2:#ffffff16;--border3:#ffffff26;
  --text:#EEEEFF;--text2:#8888B8;--text3:#55557A;
  --p-light:#1E1040;--p-glow:#6D28D924;--p-border:#6D28D945;
  --green-dim:#0A2A1E;--red-dim:#2A1212;--amber-dim:#2A1F0A;
  --blue-dim:#0A1830;--cyan-dim:#0A2030;
  --shadow:0 8px 32px rgba(0,0,0,.50);
  --shadow-sm:0 2px 12px rgba(0,0,0,.40);
  --shadow-lg:0 16px 48px rgba(0,0,0,.60);
}

html{font-size:14px;-webkit-font-smoothing:antialiased}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);color:var(--text);
  height:100vh;overflow:hidden;
}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:4px}

/* ══════════════════════════════════════════════════════════
   AUTH SCREEN
══════════════════════════════════════════════════════════ */
#auth-screen{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,#EDE9FE 0%,#F4F5F9 50%,#E0E7FF 100%);
  overflow-y:auto;padding:24px;
}
body.dark #auth-screen{
  background:linear-gradient(150deg,#1A1040 0%,#0F0F1A 50%,#0A1040 100%);
}
#auth-screen::before{
  content:'';position:absolute;top:-160px;right:-160px;width:500px;height:500px;
  border-radius:50%;background:radial-gradient(circle,#6D28D910 0%,transparent 70%);
  pointer-events:none;
}
.auth-card{
  position:relative;z-index:1;width:420px;max-width:100%;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:20px;overflow:hidden;
  box-shadow:0 8px 48px rgba(109,40,217,.12),0 1px 4px rgba(0,0,0,.06);
}
body.dark .auth-card{box-shadow:var(--shadow-lg)}

.auth-header{
  background:linear-gradient(135deg,#6D28D9 0%,#4C1D95 100%);
  padding:28px 32px 24px;
}
.auth-brand{display:flex;align-items:center;gap:14px}
.auth-brand-icon{
  width:44px;height:44px;background:rgba(255,255,255,.15);
  border-radius:12px;display:flex;align-items:center;justify-content:center;
  border:1.5px solid rgba(255,255,255,.22);
  font-size:18px;font-weight:800;color:#fff;letter-spacing:-0.5px;
  box-shadow:0 4px 16px rgba(0,0,0,.2);
}
.auth-brand-text{color:#fff}
.auth-brand-name{font-size:20px;font-weight:800;letter-spacing:-0.5px}
.auth-brand-tagline{font-size:11px;opacity:.65;margin-top:2px;letter-spacing:.2px}

.auth-body{padding:28px 32px 32px}
.auth-title{font-size:17px;font-weight:700;color:var(--text);margin-bottom:3px}
.auth-sub{font-size:12.5px;color:var(--text3);margin-bottom:22px}
.auth-error{
  font-size:12.5px;color:var(--red);
  padding:10px 14px;background:var(--red-dim);
  border:1px solid var(--red-border);border-radius:var(--r);
  margin-bottom:14px;line-height:1.5;
}
.auth-switch{text-align:center;font-size:12.5px;color:var(--text3);margin-top:18px}
.auth-switch a{color:var(--p);cursor:pointer;font-weight:600;text-decoration:none}
.auth-switch a:hover{text-decoration:underline}

.color-picker{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 16px}
.color-swatch{
  width:26px;height:26px;border-radius:50%;cursor:pointer;
  border:2px solid transparent;transition:var(--trans);
  box-shadow:0 1px 4px rgba(0,0,0,.12);
}
.color-swatch:hover{transform:scale(1.1)}
.color-swatch.selected{
  border-color:#fff;transform:scale(1.18);
  outline:2px solid var(--p);outline-offset:1px;
}

/* ══════════════════════════════════════════════════════════
   FORMS
══════════════════════════════════════════════════════════ */
.form-label,.field-label,.field>label{
  display:block;font-size:11px;font-weight:600;color:var(--text2);
  margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px;
}
.input{
  display:block;width:100%;
  background:var(--bg3);border:1.5px solid var(--border2);
  border-radius:var(--r);padding:9px 12px;
  font-size:13px;color:var(--text);font-family:inherit;
  transition:border-color var(--trans),box-shadow var(--trans);
  outline:none;-webkit-appearance:none;margin-bottom:14px;
}
.input:focus{border-color:var(--p);box-shadow:0 0 0 3px var(--p-glow);background:var(--bg2)}
.input::placeholder{color:var(--text3)}
.input-sm{padding:6px 10px;font-size:12px;margin-bottom:0}
/* Raw inputs (in tables, JS-generated) */
input:not([class]),textarea:not([class]),select:not([class]){
  width:100%;background:var(--bg3);border:1.5px solid var(--border2);
  border-radius:var(--r);padding:9px 12px;font-size:13px;color:var(--text);
  font-family:inherit;outline:none;-webkit-appearance:none;
  transition:border-color var(--trans);
}
input:not([class]):focus,textarea:not([class]):focus,select:not([class]):focus{
  border-color:var(--p);box-shadow:0 0 0 3px var(--p-glow);
}
input[type=checkbox]{width:auto;cursor:pointer;accent-color:var(--p)}

/* ── Table checkbox column ──────────────────────────────── */
th.cb-col, td.cb-col {
  width: 36px;
  min-width: 36px;
  padding: 0 8px !important;
  text-align: center;
  vertical-align: middle;
}
input.cb {
  display: block;
  margin: 0 auto;
  width: 15px;
  height: 15px;
  cursor: pointer;
  accent-color: var(--p);
  flex-shrink: 0;
  border-radius: 4px;
  /* Hide until hover — show when checked or row is active */
  opacity: 0;
  transition: opacity .12s;
}
/* Always show header select-all */
th.cb-col input.cb { opacity: 1 !important; }
/* Show on row hover, or when selected/active */
tr:hover td.cb-col input.cb,
tr.row-selected td.cb-col input.cb,
tr.row-detail-active td.cb-col input.cb { opacity: 1; }
input[type=date]::-webkit-calendar-picker-indicator{opacity:.45;cursor:pointer}
body.dark input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.7)}
select option,select.input option{background:var(--bg2);color:var(--text)}
textarea.input{resize:vertical;min-height:72px;line-height:1.6}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ══════════════════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:var(--r);
  font-size:12.5px;font-weight:600;cursor:pointer;border:none;
  transition:var(--trans);white-space:nowrap;font-family:inherit;line-height:1.2;
}
.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}
.btn svg{width:14px;height:14px;flex-shrink:0}
.btn-primary{background:var(--p);color:#fff;box-shadow:0 2px 10px rgba(109,40,217,.25)}
.btn-primary:hover:not(:disabled){background:var(--p2);box-shadow:0 4px 16px rgba(109,40,217,.35);transform:translateY(-1px)}
.btn-secondary{background:var(--bg3);color:var(--text);border:1px solid var(--border2)}
.btn-secondary:hover:not(:disabled){background:var(--bg4);border-color:var(--border3)}
.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border2)}
.btn-ghost:hover:not(:disabled){background:var(--bg3);color:var(--text)}
.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid var(--red-border)}
.btn-danger:hover:not(:disabled){filter:brightness(.94)}
.btn-success{background:var(--green-dim);color:var(--green);border:1px solid var(--green-border)}
.btn-amber{background:var(--amber-dim);color:var(--amber);border:1px solid var(--amber-border)}
.btn-sm{padding:6px 12px;font-size:11.5px}
.btn-xs{padding:3px 8px;font-size:11px;border-radius:6px}

/* ══════════════════════════════════════════════════════════
   LAYOUT
══════════════════════════════════════════════════════════ */
.sidebar{
  width:220px;flex-shrink:0;
  background:var(--bg2);border-right:1px solid var(--border);
  display:flex;flex-direction:column;height:100vh;
  transition:width .22s cubic-bezier(.4,0,.2,1);
  overflow:hidden;
}
/* Collapsed sidebar — icon-only mode */
.sidebar.sb-collapsed{width:58px}
.sidebar.sb-collapsed .sb-logo-text{display:none}
.sidebar.sb-collapsed .sb-collapse-btn{margin-left:auto}
.sidebar.sb-collapsed .nav-label{display:none}
.sidebar.sb-collapsed .nav-section-label{visibility:hidden;height:16px;padding:6px 0 0}
.sidebar.sb-collapsed .nav-btn{justify-content:center;padding:7px 0}
.sidebar.sb-collapsed .nav-btn.active::before{display:none}
.sidebar.sb-collapsed .nb{position:absolute;top:4px;right:4px;min-width:14px;height:14px;font-size:9px}
.sidebar.sb-collapsed .sb-user-info,.sidebar.sb-collapsed .sb-user > button{display:none}
.sidebar.sb-collapsed .sb-user{justify-content:center;padding:10px 0}
.sidebar.sb-collapsed .online-row{justify-content:center;padding:7px 0}
.sidebar.sb-collapsed #online-txt{display:none}
.sidebar.sb-collapsed .sb-footer > div:last-child{display:none}
.sidebar.sb-collapsed .nav-icon{width:18px;height:18px;opacity:.75}
.sidebar.sb-collapsed .nav-btn:hover .nav-icon,.sidebar.sb-collapsed .nav-btn.active .nav-icon{opacity:1}
.main-content{flex:1;overflow:hidden;display:flex;flex-direction:column;height:100vh}
.panel{display:none;flex-direction:column;height:100%;overflow:hidden}
.panel.active{display:flex}

/* ══════════════════════════════════════════════════════════
   SIDEBAR
══════════════════════════════════════════════════════════ */
.sb-logo{
  padding:10px 10px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:10px;flex-shrink:0;min-height:54px;
}
.sb-collapse-btn{
  margin-left:auto;flex-shrink:0;width:26px;height:26px;border-radius:6px;
  background:none;border:1px solid var(--border);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);transition:var(--trans);
}
.sb-collapse-btn:hover{background:var(--bg3);color:var(--text);border-color:transparent}
.sb-logo-icon{
  width:32px;height:32px;background:var(--p);border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:800;color:#fff;flex-shrink:0;
  box-shadow:0 2px 10px rgba(109,40,217,.3);letter-spacing:-0.5px;
}
.sb-nav{flex:1;overflow-y:auto;padding:8px 6px}
.nav-section-label{
  display:block;font-size:9.5px;font-weight:700;color:var(--text3);
  letter-spacing:1.2px;text-transform:uppercase;padding:10px 10px 3px;
}
.nav-btn{
  display:flex;align-items:center;gap:8px;padding:7px 10px;
  border-radius:var(--r);font-size:12.5px;font-weight:500;color:var(--text2);
  cursor:pointer;transition:var(--trans);border:none;background:none;
  width:100%;text-align:left;margin-bottom:1px;position:relative;
  font-family:inherit;
}
.nav-btn:hover{background:var(--bg3);color:var(--text)}
.nav-btn.active{
  background:var(--p-light);color:var(--p2);font-weight:600;
  border:1px solid var(--p-border);
}
body.dark .nav-btn.active{background:var(--p-glow);color:#a78bfa;border-color:var(--p-border)}
.nav-btn.active::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:14px;background:var(--p);border-radius:0 2px 2px 0;
}
.nav-icon{width:15px;height:15px;flex-shrink:0;opacity:.6;transition:opacity var(--trans)}
.nav-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:opacity .15s}
.nav-btn.active .nav-icon,.nav-btn:hover .nav-icon{opacity:1}
.nb{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:17px;height:17px;padding:0 4px;border-radius:8px;
  font-size:10px;font-weight:700;margin-left:auto;background:var(--p);color:#fff;
}
.nb.red{background:var(--red)}.nb.amber{background:var(--amber);color:#fff}
.nb.green{background:var(--green)}

/* Sidebar footer */
.sb-footer{border-top:1px solid var(--border);flex-shrink:0}
.online-row{
  display:flex;align-items:center;gap:6px;
  padding:7px 12px;border-bottom:1px solid var(--border);
}
.online-dot{
  width:7px;height:7px;border-radius:50%;background:var(--text3);flex-shrink:0;
  transition:background var(--trans),box-shadow var(--trans);
}
.sb-user{
  padding:10px 12px;display:flex;align-items:center;gap:9px;
  cursor:pointer;transition:var(--trans);
}
.sb-user:hover{background:var(--bg3)}
.sb-user-info{flex:1;min-width:0}
.sb-user-name{font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user-role{font-size:10px;color:var(--text3);text-transform:capitalize}

/* ══════════════════════════════════════════════════════════
   AVATAR
══════════════════════════════════════════════════════════ */
.av{
  display:inline-flex;align-items:center;justify-content:center;border-radius:50%;
  font-weight:700;color:#fff;flex-shrink:0;
  text-transform:uppercase;font-size:11px;width:30px;height:30px;
}
.av.sm{width:22px;height:22px;font-size:9px}
.av.md{width:32px;height:32px;font-size:13px}
.av.lg{width:40px;height:40px;font-size:16px}
.av.xl{width:52px;height:52px;font-size:20px}

/* ══════════════════════════════════════════════════════════
   PANEL HEADER / BODY
══════════════════════════════════════════════════════════ */
.panel-header,.ph{
  padding:14px 20px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-shrink:0;flex-wrap:wrap;min-height:54px;
}
.panel-title,.ph-title{font-size:15px;font-weight:700;letter-spacing:-0.2px}
.ph-sub{font-size:12px;color:var(--text2)}
.panel-body{flex:1;overflow-y:auto;padding:20px}

/* ══════════════════════════════════════════════════════════
   CARDS
══════════════════════════════════════════════════════════ */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);padding:18px}
.card-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:14px}
.card-hover{transition:var(--trans);cursor:pointer}
.card-hover:hover{border-color:var(--p-border);background:var(--bg3);transform:translateY(-1px);box-shadow:var(--shadow-sm)}

/* ══════════════════════════════════════════════════════════
   STAT CARDS
══════════════════════════════════════════════════════════ */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);padding:16px 18px;position:relative;overflow:hidden;transition:var(--trans)}
.stat-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.stat-card-accent{position:absolute;top:0;left:0;right:0;height:3px}
.stat-label{font-size:10.5px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}
.stat-value{font-size:28px;font-weight:800;letter-spacing:-1.5px;line-height:1}
.stat-sub{font-size:11px;color:var(--text2);margin-top:5px}
.stat-up{color:var(--green)}.stat-down{color:var(--red)}

/* ══════════════════════════════════════════════════════════
   TABLE
══════════════════════════════════════════════════════════ */
.table-wrap,.tbl-wrap{overflow:auto;flex:1}
.data-table,table{width:100%;border-collapse:collapse}
.data-table th,th{
  font-size:10.5px;font-weight:700;color:var(--text3);text-transform:uppercase;
  letter-spacing:.5px;padding:10px 14px;text-align:left;
  border-bottom:2px solid var(--border2);background:var(--bg2);
  position:sticky;top:0;z-index:2;white-space:nowrap;user-select:none;
}
th.sortable{cursor:pointer}
th.sortable:hover{color:var(--text2)}
th.sorted{color:var(--p)}
.sort-icon{margin-left:3px;opacity:.3;display:inline-flex;align-items:center;vertical-align:middle}
th.sorted .sort-icon{opacity:.9}
th.sortable:hover .sort-icon{opacity:.6}
.data-table td,td{
  padding:10px 14px;border-bottom:1px solid var(--border);
  font-size:12.5px;vertical-align:middle;transition:background var(--trans);
}
.data-table tr:hover td,tr:hover td{background:var(--bg3)}
tr.row-selected td{background:var(--p-light)}
body.dark tr.row-selected td{background:var(--p-glow)}
.td-name{font-weight:600;display:flex;align-items:center;gap:0;min-width:0}
.td-name-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.td-muted{color:var(--text2);font-size:12px}
/* Contact cell: phone icon + name */
.td-contact-line{display:flex;align-items:center;gap:5px;font-weight:500}
.td-contact-link{
  display:flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:4px;flex-shrink:0;
  color:var(--text3);text-decoration:none;transition:background .1s,color .1s;
}
.td-contact-link:hover{background:var(--green-dim);color:var(--green)}
.td-actions{display:flex;gap:4px;opacity:0;transition:opacity var(--trans)}
tr:hover .td-actions{opacity:1}
.loading-msg{text-align:center;padding:32px;color:var(--text3);font-size:13px}
.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ══════════════════════════════════════════════════════════
   STATUS BADGES
══════════════════════════════════════════════════════════ */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}
.badge-new{background:var(--blue-dim);color:var(--blue);border:1px solid var(--blue-border)}
.badge-contacted{background:var(--amber-dim);color:var(--amber);border:1px solid var(--amber-border)}
.badge-replied{background:var(--cyan-dim);color:var(--cyan);border:1px solid var(--cyan-border)}
.badge-qualified{background:var(--green-dim);color:var(--green);border:1px solid var(--green-border)}
.badge-toekomst{background:var(--p-light);color:var(--p);border:1px solid var(--p-border)}
body.dark .badge-toekomst{background:#1E1040;color:#a78bfa}
.badge-lost{background:var(--red-dim);color:var(--red);border:1px solid var(--red-border)}
.badge-won{background:#DCFCE7;color:#16a34a;border:1px solid #16a34a25}
body.dark .badge-won{background:#0A2A1E;color:#34D399;border-color:#34D39930}
.badge-sm{padding:2px 7px;font-size:10px}

/* ══════════════════════════════════════════════════════════
   FOLLOW-UP / SCORE
══════════════════════════════════════════════════════════ */
.fu-overdue{color:var(--red);font-weight:700}
.fu-today{color:var(--amber);font-weight:700}
.fu-soon{color:var(--cyan)}
.fu-future{color:var(--text2)}
.score-wrap{display:flex;gap:3px;align-items:center}
.score-pip{width:8px;height:8px;border-radius:2px;background:var(--bg5);transition:background var(--trans)}
.score-pip.on{background:var(--p)}
.score-pip.on.hot{background:var(--green)}
.score-pip.on.warm{background:var(--amber)}

/* ══════════════════════════════════════════════════════════
   PIPELINE
══════════════════════════════════════════════════════════ */
.pipeline-board,.pipeline-wrap{display:flex;gap:12px;padding:16px;overflow-x:auto;flex:1;align-items:flex-start}
.pipeline-col{
  width:236px;flex-shrink:0;background:var(--bg2);
  border:1px solid var(--border);border-radius:var(--r2);
  display:flex;flex-direction:column;max-height:calc(100vh - 100px);
}
.pipeline-col.drag-target{border-color:var(--p);background:var(--p-light)}
body.dark .pipeline-col.drag-target{background:var(--p-glow)}
.pcol-header{padding:11px 13px 9px;border-bottom:1px solid var(--border);flex-shrink:0}
.pcol-title{font-size:12px;font-weight:700;display:flex;align-items:center;gap:8px}
.pcol-count{font-size:11px;color:var(--text3);font-weight:500}
.pcol-value{font-size:11px;color:var(--green);font-weight:600;margin-top:2px}
.pcol-cards{flex:1;overflow-y:auto;padding:7px;display:flex;flex-direction:column;gap:5px}
.pcard{
  background:var(--bg);border:1px solid var(--border);border-radius:var(--r);
  padding:10px 12px;cursor:pointer;transition:all var(--trans);user-select:none;
}
.pcard:hover{border-color:var(--p-border);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.pcard.dragging{opacity:.4;cursor:grabbing}
.pcard[draggable]{cursor:grab}
.pc-company{font-size:12.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}
.pc-contact{font-size:11px;color:var(--text2);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pc-footer{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.pc-value{font-size:11px;color:var(--green);font-weight:700}
.pipeline-drop-zone{text-align:center;padding:20px;font-size:12px;color:var(--text3);border:1.5px dashed var(--border2);border-radius:var(--r)}

/* ══════════════════════════════════════════════════════════
   MESSENGER CHAT
══════════════════════════════════════════════════════════ */
.chat-messages{
  flex:1;overflow-y:auto;padding:20px 24px;
  display:flex;flex-direction:column;
  background:var(--bg);
}
body.dark .chat-messages{background:var(--bg)}

/* Date separator */
.chat-date-sep{
  display:flex;align-items:center;justify-content:center;
  margin:16px 0 8px;
}
.chat-date-sep span{
  font-size:11px;font-weight:500;color:var(--text3);
  background:var(--bg2);border:1px solid var(--border);
  border-radius:20px;padding:3px 12px;
}

/* Empty / loading state */
.chat-loading{text-align:center;padding:32px;color:var(--text3);font-size:13px}
.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:40px;gap:8px}
.chat-empty-icon{
  width:52px;height:52px;border-radius:16px;background:var(--bg4);
  display:flex;align-items:center;justify-content:center;margin-bottom:4px;
}
.chat-empty-title{font-size:15px;font-weight:700;color:var(--text2)}
.chat-empty-sub{font-size:12.5px;color:var(--text3)}

/* Message row */
.msg-row{display:flex;align-items:flex-end;gap:8px;margin-bottom:2px;max-width:100%}
.msg-row.mine{flex-direction:row-reverse}
.msg-row:not(.grouped){margin-top:10px}

/* Avatar (others only) */
.msg-av{
  width:30px;height:30px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#fff;text-transform:uppercase;
  align-self:flex-end;
}
.msg-row.grouped .msg-av{visibility:hidden}
.msg-row.mine .msg-av{display:none}

/* Message column */
.msg-col{display:flex;flex-direction:column;max-width:62%}
.msg-row.mine .msg-col{align-items:flex-end}

/* Sender name */
.msg-sender{
  font-size:11px;font-weight:600;color:var(--text3);
  margin-bottom:4px;padding:0 4px;
}

/* Bubble */
.msg-bubble{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:16px 16px 16px 4px;
  padding:10px 14px;
  font-size:13.5px;line-height:1.55;word-break:break-word;
  box-shadow:var(--shadow-sm);
}
.msg-row.mine .msg-bubble{
  background:var(--p);color:#fff;
  border-color:transparent;
  border-radius:16px 16px 4px 16px;
  box-shadow:0 2px 12px rgba(109,40,217,.25);
}

/* Grouped bubble corners */
.msg-row.grouped:not(.mine) .msg-bubble{border-radius:4px 16px 16px 4px}
.msg-row.grouped.mine .msg-bubble{border-radius:16px 4px 4px 16px}

/* Timestamp */
.msg-time{
  font-size:10.5px;color:var(--text3);
  padding:3px 4px 0;opacity:0;transition:opacity .2s;
}
.msg-row:hover .msg-time,.msg-row:last-child .msg-time{opacity:1}
.msg-row.has-next .msg-time{display:none}
.msg-row.mine .msg-time{text-align:right}

/* Links in chat */
.chat-link{color:var(--p);text-decoration:underline}
.msg-row.mine .chat-link{color:rgba(255,255,255,.85)}

/* Lead mention chip */
.chat-mention-chip{
  display:inline-flex;align-items:center;
  background:rgba(109,40,217,.15);color:var(--p);
  border:1px solid var(--p-border);border-radius:20px;
  padding:1px 9px;font-size:11.5px;font-weight:600;cursor:pointer;
  margin-left:2px;transition:var(--trans);
}
.chat-mention-chip:hover{background:var(--p-light)}
.msg-row.mine .chat-mention-chip{
  background:rgba(255,255,255,.2);color:#fff;border-color:rgba(255,255,255,.3);
}

/* Chat input bar */
.chat-input-bar,.chat-input-row{
  padding:12px 16px;border-top:1px solid var(--border);
  display:flex;gap:10px;align-items:flex-end;flex-shrink:0;
  background:var(--bg2);
}
.chat-input-wrap{
  flex:1;display:flex;align-items:flex-end;gap:0;
  background:var(--bg3);border:1.5px solid var(--border2);
  border-radius:24px;padding:8px 14px;
  transition:border-color var(--trans),box-shadow var(--trans);
}
.chat-input-wrap:focus-within{border-color:var(--p);box-shadow:0 0 0 3px var(--p-glow)}
.chat-textarea{
  flex:1;background:transparent;border:none;outline:none;
  font-size:14px;color:var(--text);font-family:inherit;
  resize:none;max-height:120px;line-height:1.5;padding:2px 0;
}
.chat-textarea::placeholder{color:var(--text3)}
.chat-send-btn{
  width:38px;height:38px;border-radius:50%;
  background:var(--p);color:#fff;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:var(--trans);
  box-shadow:0 2px 10px rgba(109,40,217,.3);
}
.chat-send-btn:hover{background:var(--p2);transform:scale(1.05)}
.chat-send-btn svg{width:16px;height:16px}

/* Mention popup */
.mention-popup{
  position:absolute;background:var(--bg2);border:1px solid var(--border2);
  border-radius:var(--r2);padding:6px;min-width:240px;max-height:220px;
  overflow-y:auto;z-index:600;box-shadow:var(--shadow-lg);
}
.mention-item{
  padding:8px 12px;border-radius:var(--r);cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;
}
.mention-item:hover,.mention-item.sel{background:var(--bg3)}
.mention-name{font-size:13px;font-weight:600;color:var(--text)}
.mention-meta{font-size:11px;color:var(--text3)}

/* ══════════════════════════════════════════════════════════
   LEADS SPLIT-PANE LAYOUT
══════════════════════════════════════════════════════════ */

/* ── Single top bar ── */
.leads-top-bar{
  display:flex;align-items:center;gap:0;
  padding:0 16px;border-bottom:1px solid var(--border);
  background:var(--bg2);flex-shrink:0;min-height:48px;
}
.ltb-left{flex:1;display:flex;align-items:center;min-width:0;overflow-x:auto}
.ltb-right{display:flex;align-items:center;gap:5px;flex-shrink:0;padding-left:12px}
.ltb-search{width:148px !important;margin-bottom:0 !important}
.ltb-divider{width:1px;height:20px;background:var(--border2);margin:0 4px;flex-shrink:0}
.ltb-filter-toggle{gap:5px}

/* Quick view tabs inside top bar */
.leads-top-bar .qv-tabs{gap:2px;padding:6px 0;overflow-x:auto}
.leads-top-bar .qv-tab{padding:4px 11px;font-size:12px;border-radius:16px;white-space:nowrap}

/* ── Collapsible filter bar ── */
.leads-filters-collapse{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  padding:6px 16px;border-bottom:1px solid var(--border);
  background:var(--bg3);flex-shrink:0;
}

/* ── Split layout ── */
.leads-split{
  display:flex;flex:1;min-height:0;overflow:hidden;
}
.leads-left{
  flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden;
  /* border-right removed — resize handle provides the separator */
}
.leads-right{
  width:420px;flex-shrink:0;display:flex;flex-direction:column;
  overflow:hidden;background:var(--bg2);position:relative;
}

/* ── Resize handle ── */
.leads-resize-handle{
  width:5px;
  flex-shrink:0;
  cursor:col-resize;
  position:relative;
  background:var(--border);
  transition:background .15s;
  z-index:5;
  /* extend clickable zone without affecting layout */
}
.leads-resize-handle::before{
  content:'';
  position:absolute;
  top:0;bottom:0;
  left:-4px;right:-4px;
}
/* Grip pill that appears on hover / drag */
.leads-resize-handle::after{
  content:'';
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:3px;height:28px;
  border-radius:3px;
  background:var(--p);
  opacity:0;
  transition:opacity .15s;
}
.leads-resize-handle:hover,
.leads-resize-handle.rh-dragging{
  background:var(--p);
}
.leads-resize-handle:hover::after,
.leads-resize-handle.rh-dragging::after{
  opacity:1;
}

/* Pagination inside left pane */
.leads-pagination-bar{
  display:flex;gap:4px;align-items:center;padding:6px 14px;
  border-top:1px solid var(--border);flex-shrink:0;font-size:12px;flex-wrap:wrap;
}

/* ── Detail panel in split mode ── */
.leads-right .detail-panel{
  /* Override fixed positioning — live inside the split right pane */
  position:absolute;inset:0;
  width:100%;height:100%;
  right:auto;top:auto;
  box-shadow:none;
  border-left:none;
  transition:none;
  display:none;   /* hidden until a lead is selected */
}

/* ── Empty state (right pane, no lead selected) ── */
.lrp-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  height:100%;gap:10px;color:var(--text3);padding:40px 24px;text-align:center;
}
.lrp-empty-icon{opacity:.2;line-height:1;display:flex;align-items:center;justify-content:center}
.lrp-empty-title{font-size:15px;font-weight:600;color:var(--text2)}
.lrp-empty-sub{font-size:13px;color:var(--text3)}
.lrp-empty-hint{
  display:flex;gap:12px;margin-top:8px;font-size:12px;color:var(--text3);flex-wrap:wrap;justify-content:center;
}
.lrp-empty-hint kbd{
  background:var(--bg4);border:1px solid var(--border2);border-radius:4px;
  padding:1px 6px;font-size:11px;font-family:inherit;color:var(--text2);
}

/* ── Active row in table (currently shown in detail) ── */
tr.row-detail-active td{
  background:var(--p-light) !important;
}
body.dark tr.row-detail-active td{background:var(--p-glow) !important}
tr.row-detail-active td:nth-child(2){
  box-shadow:inset 3px 0 0 var(--p);
}

/* ══════════════════════════════════════════════════════════
   STATUS LEFT-BORDER COLOUR SYSTEM
══════════════════════════════════════════════════════════ */
tr[data-status] td:nth-child(2){ box-shadow:inset 3px 0 0 var(--border2) }
tr[data-status="new"]               td:nth-child(2){ box-shadow:inset 3px 0 0 #6D28D9 }
tr[data-status="te_contacteren"]     td:nth-child(2){ box-shadow:inset 3px 0 0 #6366F1 }
tr[data-status="contacted"]          td:nth-child(2){ box-shadow:inset 3px 0 0 #0E7490 }
tr[data-status="replied"]            td:nth-child(2){ box-shadow:inset 3px 0 0 #1D4ED8 }
tr[data-status="qualified"]          td:nth-child(2){ box-shadow:inset 3px 0 0 #059669 }
tr[data-status="toekomst"]           td:nth-child(2){ box-shadow:inset 3px 0 0 #D97706 }
tr[data-status="won"]                td:nth-child(2){ box-shadow:inset 3px 0 0 #16A34A }
tr[data-status="lost"]               td:nth-child(2){ box-shadow:inset 3px 0 0 #9CA3AF }
tr[data-status="te_groot"]           td:nth-child(2){ box-shadow:inset 3px 0 0 #9CA3AF }
tr[data-status="geen_budget"]        td:nth-child(2){ box-shadow:inset 3px 0 0 #9CA3AF }
tr[data-status="niet_geinteresseerd"] td:nth-child(2){ box-shadow:inset 3px 0 0 #9CA3AF }
/* Don't double-border when row is actively selected */
tr.row-detail-active td:nth-child(2){ box-shadow:inset 3px 0 0 var(--p) !important }

/* ══════════════════════════════════════════════════════════
   DETAIL PANEL (base styles — work in both split & overlay)
══════════════════════════════════════════════════════════ */
.detail-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:499;
  opacity:0;pointer-events:none;transition:opacity .25s;backdrop-filter:blur(2px);
}
.detail-overlay.open{opacity:1;pointer-events:auto}
.detail-panel{
  /* Default: fixed overlay (used by non-leads panels) */
  position:fixed;top:0;right:-580px;width:560px;height:100vh;
  background:var(--bg2);border-left:1px solid var(--border2);
  z-index:500;transition:right .28s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;box-shadow:-8px 0 40px rgba(0,0,0,.10);
}
body.dark .detail-panel:not(.leads-right .detail-panel){box-shadow:-8px 0 40px rgba(0,0,0,.5)}
.detail-panel.open{right:0}
.detail-header{
  padding:16px 20px 12px;border-bottom:1px solid var(--border);
  display:flex;align-items:flex-start;gap:12px;flex-shrink:0;
}
.detail-hdr-info{flex:1;min-width:0}
.detail-company{font-size:18px;font-weight:800;letter-spacing:-0.4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.detail-contact{font-size:12.5px;color:var(--text2);margin-top:3px}
.detail-actions{
  display:flex;gap:6px;padding:10px 20px;border-bottom:1px solid var(--border);
  flex-shrink:0;flex-wrap:wrap;align-items:center;
}
.detail-tabs{
  display:flex;padding:0 20px;border-bottom:1px solid var(--border);flex-shrink:0;
}
.dtab{
  padding:10px 16px;font-size:12.5px;font-weight:600;color:var(--text2);
  cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;
  transition:var(--trans);white-space:nowrap;font-family:inherit;
}
.dtab:hover{color:var(--text)}
.dtab.active{color:var(--p);border-bottom-color:var(--p)}
.det-tab-content,.dpane{display:none;padding:18px 20px;overflow-y:auto}
.det-tab-content.active,.dpane.active{display:block}

/* Info grid */
.det-info-grid,.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.info-item{background:var(--bg3);border-radius:var(--r);padding:10px 12px}
.info-item-label{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.info-item-value{font-size:13px;font-weight:500;word-break:break-word}
.info-item-value a{color:var(--p);text-decoration:none}
.info-item-value a:hover{text-decoration:underline}

/* ══════════════════════════════════════════════════════════
   TASKS / NOTES / ACTIVITY
══════════════════════════════════════════════════════════ */
.add-task-row{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
.add-note-row{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.task-item{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 12px;background:var(--bg3);border:1px solid var(--border);
  border-radius:var(--r);margin-bottom:6px;
}
.task-item.done{opacity:.45}
.task-item.done .task-title{text-decoration:line-through;color:var(--text2)}
.task-check{
  width:20px;height:20px;border-radius:50%;border:2px solid var(--border3);
  background:transparent;cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  transition:var(--trans);margin-top:1px;font-size:11px;
}
.task-check:hover{border-color:var(--green)}
.task-check.done{background:var(--green);border-color:var(--green);color:#fff}
.task-body{flex:1;min-width:0}
.task-title{font-size:12.5px;font-weight:600;margin-bottom:2px}
.task-meta{font-size:11px;color:var(--text2);display:flex;gap:8px;flex-wrap:wrap}
.task-overdue{color:var(--red)!important;font-weight:600}
.note-item{display:flex;gap:10px;margin-bottom:12px}
.note-bubble{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:0 var(--r2) var(--r2) var(--r2);padding:10px 13px}
.note-text{font-size:12.5px;line-height:1.7;white-space:pre-wrap;word-break:break-word}
.note-meta{font-size:10.5px;color:var(--text3);margin-top:6px;display:flex;align-items:center;gap:8px}
.act-item{display:flex;gap:12px;padding:9px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.act-item:last-child{border-bottom:none}
.act-icon{width:26px;height:26px;border-radius:50%;background:var(--bg4);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;margin-top:2px}
.act-body{flex:1;min-width:0}
.act-text{font-size:12.5px;color:var(--text2);line-height:1.5}
.act-text strong{color:var(--text);font-weight:600}
.act-time{font-size:11px;color:var(--text3);margin-top:2px}

/* ══════════════════════════════════════════════════════════
   MY DAY
══════════════════════════════════════════════════════════ */
.myday-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);
  padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:all var(--trans);
  display:flex;gap:12px;align-items:center;
}
.myday-card:hover{border-color:var(--p-border);box-shadow:var(--shadow-sm)}
.myday-card.urgent{border-left:3px solid var(--red)}
.myday-card.today{border-left:3px solid var(--amber)}
.myday-info{flex:1;min-width:0}
.myday-company{font-size:13.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.myday-contact{font-size:11.5px;color:var(--text2);margin-top:2px}
.myday-fu{font-size:11px;margin-top:3px;font-weight:600}

/* ══════════════════════════════════════════════════════════
   MODALS
══════════════════════════════════════════════════════════ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:800;
  display:none;align-items:center;justify-content:center;
  backdrop-filter:blur(4px);padding:16px;
}
.modal-overlay.open{display:flex}
.modal{
  background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r3);
  width:540px;max-width:100%;max-height:90vh;overflow-y:auto;
  box-shadow:var(--shadow-lg);padding:24px;
}
.modal-sm{width:400px}
/* Lead add/edit modal — wider with 3-col grid */
.modal-lead{width:min(860px,calc(100vw - 40px));padding:0}
.modal-lead .modal-header{padding:20px 28px 16px;border-bottom:1px solid var(--border)}
.modal-lead .modal-body{padding:20px 28px 8px;overflow-y:auto;max-height:calc(90vh - 130px)}
.modal-lead .modal-footer{padding:14px 28px}
/* Section labels inside lead modal */
.lm-section-label{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;
  color:var(--text3);margin:16px 0 8px;padding-bottom:6px;
  border-bottom:1px solid var(--border);
}
.lm-section-label:first-child{margin-top:0}
/* 3-column form grid */
.lm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px 16px;margin-bottom:4px}
.lm-span2{grid-column:span 2}
.lm-span3{grid-column:1/-1}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-header span{font-size:16px;font-weight:700;letter-spacing:-0.2px}
.modal-body{margin-bottom:4px}
.modal-close{
  cursor:pointer;color:var(--text2);width:28px;height:28px;
  display:flex;align-items:center;justify-content:center;
  border-radius:7px;font-size:16px;border:none;background:transparent;transition:var(--trans);
}
.modal-close:hover{background:var(--bg4);color:var(--text)}
.modal-footer{
  display:flex;gap:8px;justify-content:flex-end;
  margin-top:20px;padding-top:16px;border-top:1px solid var(--border);
}

/* ══════════════════════════════════════════════════════════
   DASHBOARD CHARTS
══════════════════════════════════════════════════════════ */
.funnel{display:flex;flex-direction:column;gap:5px}
.funnel-row{display:flex;align-items:center;gap:10px}
.funnel-label{font-size:11.5px;color:var(--text2);width:100px;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}
.funnel-track{flex:1;background:var(--bg4);border-radius:4px;height:22px;overflow:hidden}
.funnel-bar{height:100%;border-radius:4px;display:flex;align-items:center;padding-left:10px;font-size:11px;font-weight:700;color:#fff;transition:width .5s ease;min-width:20px}
.funnel-nums{font-size:11px;width:46px;text-align:right;flex-shrink:0}
.leader-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.leader-item:last-child{border-bottom:none}
.leader-rank{font-size:13px;font-weight:800;width:24px;text-align:center;flex-shrink:0}
.rank-1{color:#F59E0B}.rank-2{color:#9CA3AF}.rank-3{color:#B45309}
.leader-info{flex:1;min-width:0}
.leader-name{font-size:13px;font-weight:600}
.leader-stats{font-size:11px;color:var(--text2);margin-top:2px}
.leader-bar{height:4px;background:var(--bg4);border-radius:2px;overflow:hidden;margin-top:4px}
.leader-bar-fill{height:100%;border-radius:2px;background:var(--p);transition:width .4s ease}

/* ══════════════════════════════════════════════════════════
   MISC
══════════════════════════════════════════════════════════ */
.tags-wrap{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
.tag{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;background:var(--p-light);border:1px solid var(--p-border);border-radius:20px;font-size:11px;font-weight:500;color:var(--p)}
body.dark .tag{background:var(--bg4);border-color:var(--border2);color:var(--text2)}
.tag-del{cursor:pointer;opacity:.5;font-size:14px;line-height:1;margin-left:2px}
.tag-del:hover{opacity:1;color:var(--red)}
#toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:380px;width:100%}
.toast{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);
  padding:13px 14px;font-size:13px;box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:12px;
  pointer-events:auto;animation:toastIn .22s cubic-bezier(.4,0,.2,1);
  line-height:1.45;border-left:4px solid var(--border3);
}
.toast-ok  { border-left-color:var(--green) }
.toast-err { border-left-color:var(--red) }
.toast-info{ border-left-color:var(--blue) }
.toast-warn{ border-left-color:var(--amber) }
.toast-icon-wrap{
  width:30px;height:30px;border-radius:8px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.toast-ok   .toast-icon-wrap{background:var(--green-dim);color:var(--green)}
.toast-err  .toast-icon-wrap{background:var(--red-dim);color:var(--red)}
.toast-info .toast-icon-wrap{background:var(--blue-dim);color:var(--blue)}
.toast-warn .toast-icon-wrap{background:var(--amber-dim);color:var(--amber)}
.toast-body{flex:1;color:var(--text)}
.toast-close{
  background:none;border:none;cursor:pointer;color:var(--text3);
  display:flex;align-items:center;padding:2px;border-radius:4px;flex-shrink:0;
  transition:color .1s,background .1s;
}
.toast-close:hover{background:var(--bg3);color:var(--text)}
@keyframes toastIn{from{transform:translateX(16px);opacity:0}to{transform:none;opacity:1}}
@keyframes toastOut{from{opacity:1;transform:none}to{opacity:0;transform:translateX(16px)}}
.bulk-bar,#bulk-bar{background:var(--bg2);border-top:2px solid var(--p);padding:8px 16px;display:none;align-items:center;gap:6px;flex-shrink:0;flex-wrap:wrap}
.bulk-bar.show,#bulk-bar.show{display:flex}
.bulk-divider{width:1px;height:20px;background:var(--border2);margin:0 2px;flex-shrink:0}
.select-all-banner{background:var(--p-light,#f3e8ff);border-bottom:1px solid var(--p);padding:8px 16px;font-size:13px;color:var(--text);display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex-shrink:0}
body.dark .select-all-banner{background:var(--p-glow,rgba(139,0,232,.15))}
.drop-zone{border:2px dashed var(--border2);border-radius:var(--r2);padding:44px 24px;text-align:center;cursor:pointer;transition:var(--trans);background:var(--bg2)}
.drop-zone:hover,.drop-zone.drag-over{border-color:var(--p);background:var(--p-light)}
body.dark .drop-zone:hover,.body.dark .drop-zone.drag-over{background:var(--p-glow)}
.tpl-preview{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:14px;font-size:13px;line-height:1.7;min-height:200px;white-space:pre-wrap;word-break:break-word}
.progress-bar{height:5px;background:var(--bg4);border-radius:3px;overflow:hidden;margin-top:10px}
.progress-fill{height:100%;background:var(--p);border-radius:3px;transition:width .3s ease}
[contenteditable]{outline:none;border-radius:4px;padding:1px 4px}
[contenteditable]:focus{background:var(--bg4);box-shadow:0 0 0 2px var(--p)}
#fab{position:fixed;bottom:24px;right:24px;width:48px;height:48px;background:var(--p);color:#fff;border:none;border-radius:50%;font-size:26px;cursor:pointer;box-shadow:0 4px 16px rgba(109,40,217,.35);z-index:400;display:flex;align-items:center;justify-content:center;transition:var(--trans);line-height:1}
#fab:hover{background:var(--p2);transform:scale(1.07);box-shadow:0 8px 28px rgba(109,40,217,.5)}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:56px 24px;color:var(--text2);text-align:center;gap:8px;flex:1}
.empty-icon{font-size:48px;opacity:.2;margin-bottom:4px}
.empty-title{font-size:15px;font-weight:700;color:var(--text3)}
.empty-sub{font-size:12.5px;color:var(--text3);max-width:280px;line-height:1.6}
.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;background:var(--bg3);border:1px solid var(--border);border-radius:20px;font-size:11.5px;white-space:nowrap}
.chip-sm{padding:2px 8px;font-size:11px}
.chip-purple{background:var(--p-light);border-color:var(--p-border);color:var(--p)}
.chip-blue{background:var(--blue-dim);border-color:var(--blue-border);color:var(--blue)}
.chip-gray{background:var(--bg4);border-color:var(--border2);color:var(--text2)}

/* ── Scripts panel ── */
.scripts-layout{display:flex;flex:1;overflow:hidden;height:100%}
.scripts-sidebar{width:200px;flex-shrink:0;border-right:1px solid var(--border);padding:12px 8px;overflow-y:auto;background:var(--bg2)}
.scripts-list{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px}
.script-cat-btn{display:block;width:100%;text-align:left;padding:7px 12px;border-radius:var(--r);border:none;background:none;color:var(--text2);font-size:13px;cursor:pointer;transition:background .15s}
.script-cat-btn:hover{background:var(--bg3)}
.script-cat-btn.active{background:var(--p-light);color:var(--p);font-weight:600}
.script-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);padding:18px 20px;transition:box-shadow .15s}
.script-card:hover{box-shadow:var(--shadow-sm)}
.script-card-header{display:flex;gap:16px;align-items:flex-start;margin-bottom:12px}
.script-name{font-size:14px;font-weight:700;color:var(--text)}
.script-subject{font-size:12px;color:var(--text2);margin-top:6px;font-style:italic}
.script-body{font-family:inherit;font-size:13px;line-height:1.7;color:var(--text2);white-space:pre-wrap;word-break:break-word;border-top:1px solid var(--border);padding-top:12px;margin:0}
body.dark .scripts-sidebar{background:var(--bg2)}
body.dark .script-card{background:var(--bg2)}
.section-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.7px;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.divider{height:1px;background:var(--border);margin:14px 0}
hr{border:none;border-top:1px solid var(--border);margin:12px 0}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.flex-1{flex:1}.ml-auto{margin-left:auto}
.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}
.text-green{color:var(--green)}.text-red{color:var(--red)}.text-amber{color:var(--amber)}
.text-muted{color:var(--text2)}.text-xs{font-size:11px}.text-sm{font-size:12.5px}.fw-700{font-weight:700}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}

/* ── Extra status badges ── */
.badge-te_groot{background:#fce7f3;color:#9d174d;border:1px solid #f9a8d425}
.badge-geen_budget{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa40}
.badge-niet_geinteresseerd{background:#f1f5f9;color:#475569;border:1px solid #cbd5e130}
body.dark .badge-te_groot{background:#4a0723;color:#f9a8d4}
body.dark .badge-geen_budget{background:#431407;color:#fdba74}
body.dark .badge-niet_geinteresseerd{background:#1e293b;color:#94a3b8}
.badge-moderne_website{background:#f1f5f9;color:#475569;border:1px solid #cbd5e130}
body.dark .badge-moderne_website{background:#1e293b;color:#94a3b8}
.badge-verouderde_website{background:#fffbeb;color:#b45309;border:1px solid #fde68a40}
body.dark .badge-verouderde_website{background:#1c1400;color:#fbbf24}

/* ── Priority inline select (table) ── */
.priority-select{border:none;border-radius:5px;font-size:11px;font-weight:700;padding:2px 6px;cursor:pointer;outline:none;appearance:none;text-align:center}
.priority-hoog{background:#fee2e2;color:#b91c1c}
.priority-normaal{background:var(--bg3);color:var(--text2)}
.priority-laag{background:#f1f5f9;color:#94a3b8}
body.dark .priority-hoog{background:#450a0a;color:#fca5a5}
body.dark .priority-normaal{background:var(--bg3);color:var(--text2)}
body.dark .priority-laag{background:#1e293b;color:#64748b}

/* ── Priority badge (detail panel) ── */
.priority-badge{display:inline-block;border-radius:5px;padding:2px 8px;font-size:11px;font-weight:700}
.priority-badge.priority-hoog{background:#fee2e2;color:#b91c1c}
.priority-badge.priority-normaal{background:var(--bg3);color:var(--text2)}
.priority-badge.priority-laag{background:#f1f5f9;color:#94a3b8}

/* ── Leads table enhancements ── */
.stale-badge{display:inline-block;background:#fee2e2;color:#b91c1c;border-radius:4px;padding:1px 5px;font-size:10px;font-weight:600;vertical-align:middle;margin-left:4px}
body.dark .stale-badge{background:#450a0a;color:#fca5a5}
.source-badge{display:inline-block;background:var(--bg3);color:var(--text3);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-size:10px;font-weight:600;vertical-align:middle;margin-left:3px}
.tag-xs{display:inline-block;background:var(--p-light);color:var(--p);border-radius:4px;padding:1px 5px;font-size:10px;font-weight:500;margin:1px 2px 1px 0;vertical-align:middle}
body.dark .tag-xs{background:rgba(109,40,217,.2);color:#a78bfa}
.deal-val{font-weight:600;color:var(--text3)}
.deal-val.has-value{color:var(--green)}
.td-assign-name{font-size:12px;vertical-align:middle;margin-left:4px}
.nb.blue{background:#dbeafe;color:#1d4ed8}
body.dark .nb.blue{background:rgba(29,78,216,.2);color:#93c5fd}

/* Inline status select in table */
.status-select-inline{background:transparent;border:1px solid transparent;border-radius:4px;font-size:12px;padding:2px 4px;color:var(--text);cursor:pointer;outline:none;max-width:130px}
.status-select-inline:hover{border-color:var(--border2);background:var(--bg2)}

/* Clickable follow-up cell */
.fu-cell{cursor:pointer;padding:2px 4px;border-radius:4px;transition:background .12s}
.fu-cell:hover{background:var(--bg3)}

/* Quick follow-up dropdown menu */
.fu-quick-menu{background:var(--bg);border:1px solid var(--border2);border-radius:8px;box-shadow:var(--shadow);padding:4px;z-index:9000;min-width:130px;display:flex;flex-direction:column;gap:2px}
.fu-quick-item{background:none;border:none;padding:7px 12px;font-size:13px;color:var(--text);text-align:left;cursor:pointer;border-radius:5px;width:100%;display:flex;align-items:center;gap:6px}
.fu-quick-item:hover{background:var(--bg3)}
.fu-quick-active{color:var(--p);font-weight:600}
.fu-quick-clear{color:var(--red)}
.fu-quick-clear:hover{background:#fee2e2}
body.dark .fu-quick-clear:hover{background:#450a0a}

/* Clickable assign cell in table */
.assign-cell{display:flex;align-items:center;gap:6px;cursor:pointer;padding:3px 6px;border-radius:5px;transition:background .12s;min-width:80px}
.assign-cell:hover{background:var(--bg3)}
.assign-cell-empty{font-size:12px;color:var(--text3);font-style:italic}

/* Detail panel assignment section */
.det-assign-section{padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg2)}
.assign-section-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.assign-section-who{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text)}
.assign-name{font-size:13px;font-weight:600}
.assign-none{font-size:13px;color:var(--text3);font-style:italic}
.assign-section-controls{display:flex;align-items:center;gap:8px}
.assign-select{font-size:12.5px;padding:4px 8px;border:1px solid var(--border2);border-radius:6px;background:var(--bg);color:var(--text);cursor:pointer;outline:none;max-width:160px}
.assign-select:focus{border-color:var(--p)}

/* ── Overdue row highlight ── */
tr.row-overdue td{background:rgba(220,38,38,.04)}
tr.row-overdue:hover td{background:rgba(220,38,38,.08)}
body.dark tr.row-overdue td{background:rgba(220,38,38,.08)}

/* ── Sector group headers ── */
tr.sector-group-header{cursor:pointer;user-select:none}
tr.sector-group-header td{background:var(--bg2);border-top:2px solid var(--border);padding:7px 12px 7px 10px !important}
tr.sector-group-header:hover td{background:var(--bg3)}
body.dark tr.sector-group-header td{background:var(--bg3)}
.sg-caret{display:inline-flex;align-items:center;color:var(--text3);width:16px;flex-shrink:0}
.sg-name{font-weight:700;font-size:13px;color:var(--text);margin-right:8px}
.sg-count{font-size:12px;color:var(--text2);margin-right:10px}
.sg-badge{display:inline-block;font-size:11px;font-weight:600;border-radius:5px;padding:1px 7px;margin-left:4px}
.sg-won{background:#dcfce7;color:#166534}
.sg-val{background:var(--p-light,#eff6ff);color:var(--p)}

/* ── Last contact column ── */
.lc-never {color:var(--text3);font-style:italic;font-size:12px}
.lc-today {color:var(--green);font-weight:700;font-size:12px}
.lc-recent{color:var(--green);font-size:12px}
.lc-ok    {color:var(--text2);font-size:12px}
.lc-stale {color:var(--red);font-weight:600;font-size:12px}

/* ── Belmodus overlay ── */
.bm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:3000;display:none;align-items:center;justify-content:center;padding:16px}
.bm-overlay.open{display:flex}
.bm-panel{background:var(--bg);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.3);width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}

.bm-header{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.bm-title{font-size:15px;font-weight:700;color:var(--text);flex-shrink:0}
.bm-progress-wrap{flex:1;display:flex;align-items:center;gap:10px}
.bm-progress-bar-bg{flex:1;height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}
.bm-progress-bar-fill{height:100%;background:var(--p);border-radius:3px;transition:width .3s}
.bm-progress-text{font-size:12px;color:var(--text2);white-space:nowrap}

.bm-body{display:grid;grid-template-columns:1fr 1fr;gap:0;flex:1;overflow:hidden;min-height:0}
.bm-left{padding:20px;border-right:1px solid var(--border);overflow-y:auto;display:flex;flex-direction:column;gap:12px}
.bm-right{padding:20px;overflow-y:auto;display:flex;flex-direction:column}

.bm-lead-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px}
.bm-lead-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.bm-bedrijf{font-size:18px;font-weight:700;color:var(--text)}
.bm-contact{font-size:13px;color:var(--text2);margin-top:2px}
.bm-sector{font-size:12px;color:var(--text3);margin-top:2px}
.bm-contact-btns{display:flex;gap:8px;margin-top:10px}

.bm-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text3);margin-bottom:6px;flex-shrink:0}
.bm-script-body{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:12px 14px;font-size:13px;line-height:1.7;color:var(--text);white-space:pre-wrap;word-break:break-word;flex:1;overflow-y:auto;min-height:80px;margin:0;font-family:inherit}

.bm-notes{display:flex;flex-direction:column;gap:8px;flex-shrink:0}
.bm-note-item{background:var(--bg2);border:1px solid var(--border);border-radius:7px;padding:10px 12px}
.bm-note-text{font-size:13px;color:var(--text);line-height:1.5}
.bm-note-meta{font-size:11px;color:var(--text3);margin-top:4px}
.bm-notes-empty{font-size:12px;color:var(--text3);font-style:italic;padding:8px 0}

.bm-actions{display:flex;gap:8px;margin-top:14px;justify-content:flex-end;flex-shrink:0}

@media(max-width:680px){
  .bm-body{grid-template-columns:1fr}
  .bm-left{border-right:none;border-bottom:1px solid var(--border)}
}

/* Detail panel quick follow-up strip */
.det-fu-quick{padding:12px 16px;border-top:1px solid var(--border);margin-top:6px}
.det-fu-quick-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:8px}
.det-fu-quick-btns{display:flex;gap:6px;flex-wrap:wrap}
.w-full{width:100%}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── Kans badge ─────────────────────────────────────────── */
.kans-badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:12px;font-weight:600}
.kans-badge.kans-high{background:#dcfce7;color:#166534}
.kans-badge.kans-mid{background:#fef9c3;color:#854d0e}
.kans-badge.kans-low{background:#fee2e2;color:#991b1b}

/* ── Opening hours ───────────────────────────────────────── */
.ot-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.ot-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3)}
.ot-grid{display:flex;flex-direction:column;gap:2px}
.ot-row{display:grid;grid-template-columns:32px 1fr;gap:8px;align-items:center;padding:4px 6px;border-radius:5px;font-size:13px}
.ot-row:hover{background:var(--bg2)}
.ot-closed .ot-time{color:var(--text3);font-style:italic}
.ot-day{font-weight:600;color:var(--text2);font-size:12px}
.ot-time{color:var(--text)}

/* Edit modal rows */
.ot-edit-row{display:grid;grid-template-columns:28px 80px 12px 80px 1fr;gap:6px;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);font-size:13px}
.ot-edit-row:last-child{border-bottom:none}
.ot-sep{text-align:center;color:var(--text3);font-size:11px}
.ot-closed-label{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text2);cursor:pointer;white-space:nowrap}
.ot-open,.ot-close{padding:3px 6px !important;font-size:12px !important;min-width:0}

/* ── ICP Qualification ───────────────────────────────────── */
.det-icp-section{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.icp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.icp-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3)}
.icp-score{font-size:13px;font-weight:700;padding:2px 10px;border-radius:20px}
.icp-score.icp-high{background:#dcfce7;color:#166534}
.icp-score.icp-mid{background:#fef9c3;color:#854d0e}
.icp-score.icp-low{background:#fee2e2;color:#991b1b}
.icp-checks{display:grid;grid-template-columns:1fr 1fr;gap:4px 8px}
.icp-check{display:flex;align-items:center;gap:7px;padding:4px 0}
.icp-cb{width:15px !important;height:15px !important;min-width:15px;flex-shrink:0;cursor:pointer;accent-color:var(--p);margin:0 !important;padding:0 !important;background:none !important;border:none !important;box-shadow:none !important}
.icp-check-label{font-size:13px;color:var(--text2);cursor:pointer;line-height:1.3;user-select:none}
.icp-check.checked .icp-check-label{color:var(--text);font-weight:500}
@media(max-width:480px){.icp-checks{grid-template-columns:1fr}}

/* ── Offertes tab ────────────────────────────────────────── */
.add-offerte-row{padding:12px 16px;border-bottom:1px solid var(--border)}
.offerte-total{font-size:12px;color:var(--text3);padding:10px 16px 6px;font-weight:500}
.offerte-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin:0 16px 10px}
.offerte-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:6px}
.offerte-nr{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text3)}
.offerte-titel{font-size:14px;font-weight:600;color:var(--text);margin-top:2px}
.offerte-card-right{text-align:right;flex-shrink:0}
.offerte-bedrag{font-size:16px;font-weight:700;color:var(--text)}
.offerte-dates{font-size:12px;color:var(--text3);margin-bottom:6px}
.offerte-link{font-size:12px;margin-bottom:6px}
.offerte-link a{color:var(--purple);text-decoration:none}
.offerte-link a:hover{text-decoration:underline}
.offerte-notitie{font-size:12.5px;color:var(--text2);font-style:italic;background:var(--bg);border-radius:6px;padding:6px 10px;margin-bottom:8px}
.offerte-actions{display:flex;gap:8px;align-items:center;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.offerte-status-sel{width:auto;flex:1;min-width:0}

/* Offerte status badges */
.offerte-status{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:12px;text-transform:capitalize}
.off-concept{background:#f1f5f9;color:#475569}
.off-verstuurd{background:#dbeafe;color:#1d4ed8}
.off-geaccepteerd{background:#dcfce7;color:#166534}
.off-afgewezen{background:#fee2e2;color:#991b1b}
.off-verlopen{background:#f1f5f9;color:#94a3b8}

/* Modal footer */
.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--border)}

/* ══════════════════════════════════════════════════════════
   DASHBOARD
══════════════════════════════════════════════════════════ */

/* Dashboard wrapper */
#dashboard-content{padding-bottom:32px}

/* Welcome */
.db-welcome{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding:2px 0;gap:12px;flex-wrap:wrap}
.db-welcome-left{}
.db-greeting{font-size:19px;font-weight:800;letter-spacing:-0.4px;color:var(--text)}
.db-date{font-size:12px;color:var(--text3);margin-top:2px}
.db-alert-chips{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.db-alert-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;cursor:pointer;border:1px solid;white-space:nowrap;transition:background .15s}
.db-alert-red{background:#FEF2F2;color:#DC2626;border-color:#FECACA}
.db-alert-red:hover{background:#FEE2E2}
.db-alert-amber{background:#FFFBEB;color:#D97706;border-color:#FDE68A}
.db-alert-amber:hover{background:#FEF3C7}
.db-alert-blue{background:#EFF6FF;color:#2563EB;border-color:#BFDBFE}
.db-alert-blue:hover{background:#DBEAFE}
.db-alert-green{background:#F0FDF4;color:#059669;border-color:#BBF7D0;cursor:default}
body.dark .db-alert-red{background:#2A1212;border-color:#7f1d1d;color:#FCA5A5}
body.dark .db-alert-amber{background:#2A1A00;border-color:#78350f;color:#FCD34D}
body.dark .db-alert-blue{background:#0f1a2e;border-color:#1e3a5f;color:#93C5FD}
body.dark .db-alert-green{background:#0a1f0a;border-color:#14532d;color:#86EFAC}

/* Pipeline flow band */
.db-pipeline-flow{display:flex;align-items:stretch;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);margin-bottom:14px;overflow:hidden}
.db-pf-stage{flex:1;padding:14px 12px 0;display:flex;flex-direction:column;cursor:pointer;transition:background .15s;position:relative;overflow:hidden;min-width:0}
.db-pf-stage:hover{background:var(--bg3)}
.db-pf-stage+.db-pf-stage{border-left:1px solid var(--border)}
.db-pf-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.db-pf-count{font-size:24px;font-weight:800;letter-spacing:-.5px;color:var(--text);line-height:1}
.db-pf-sub{font-size:10.5px;color:var(--text3);margin-top:3px;margin-bottom:10px}
.db-pf-bar{position:absolute;bottom:0;left:0;height:3px;transition:width .6s ease;border-radius:0}
.db-pf-arrow{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 6px;flex-shrink:0;gap:3px}
.db-pf-pct{font-size:10px;font-weight:600;white-space:nowrap}
.db-pf-pct-good{color:#059669}
.db-pf-pct-warn{color:#D97706}
.db-pf-pct-bad{color:#DC2626}
.db-pf-pct-none{color:var(--text3)}
.db-pf-dropout{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:14px 16px;border-left:1px solid var(--border);flex-shrink:0;gap:4px}
.db-pf-dropout-n{font-size:18px;font-weight:800;color:var(--text3);line-height:1}
.db-pf-dropout-n2{font-size:18px;font-weight:800;color:var(--text3);line-height:1}
.db-pf-dropout-lbl{font-size:10px;color:var(--text3);white-space:nowrap}

/* KPI strip */
.db-kpi-strip{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);display:flex;margin-bottom:14px;overflow:hidden}
.db-metric{flex:1;padding:16px 18px;display:flex;flex-direction:column;cursor:default;transition:background .15s;min-width:0}
.db-metric[onclick]{cursor:pointer}
.db-metric:hover{background:var(--bg3)}
.db-metric+.db-metric{border-left:1px solid var(--border)}
.db-metric-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text3);margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.db-metric-val{font-size:20px;font-weight:800;letter-spacing:-.5px;line-height:1;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.db-metric-sub{font-size:11.5px;color:var(--text2);margin-top:4px;line-height:1.4}
@media(max-width:1200px){.db-kpi-strip{flex-wrap:wrap}.db-metric{flex-basis:33.333%}}
@media(max-width:700px){.db-metric{flex-basis:50%}}
@media(max-width:480px){.db-metric{flex-basis:100%}}

/* Layout grids */
.db-grid-today{display:grid;grid-template-columns:1.5fr 1fr;gap:14px;margin-bottom:14px;align-items:start}
@media(max-width:1100px){.db-grid-today{grid-template-columns:1fr}}

/* Cards */
.db-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);padding:18px 20px}
.db-card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.db-card-title{font-size:13px;font-weight:700;color:var(--text)}
.db-card-sub{font-size:11px;color:var(--text3)}
.db-empty{font-size:13px;color:var(--text3);padding:16px 0;text-align:center}

/* Today agenda items */
.db-today-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 0;text-align:center}
.db-today-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--r);cursor:pointer;transition:background .15s;margin-bottom:2px}
.db-today-item:hover{background:var(--bg3)}
.db-today-item:last-child{margin-bottom:0}
.db-today-overdue{border-left:2px solid #DC2626;padding-left:8px}
.db-today-body{flex:1;min-width:0}
.db-today-company{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.db-today-contact{font-size:11.5px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.db-today-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}
.db-today-actions{display:flex;gap:4px}
.db-today-type-pill{font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;flex-shrink:0;white-space:nowrap}

/* Activity grid */
.db-act-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 24px;max-height:260px;overflow-y:auto;scrollbar-width:thin}
@media(max-width:900px){.db-act-grid{grid-template-columns:1fr}}
.act-item{display:flex;align-items:flex-start;gap:10px;padding:7px 0;border-bottom:1px solid var(--border)}
.act-item:last-child{border-bottom:none}
.act-icon-wrap{width:26px;height:26px;border-radius:7px;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.act-body{flex:1;min-width:0}
.act-text{font-size:12px;color:var(--text2);line-height:1.4}
.act-text strong{color:var(--text);font-weight:600}
.act-lead-link{color:var(--p);text-decoration:none;font-weight:500}
.act-lead-link:hover{text-decoration:underline}
.act-time{font-size:10.5px;color:var(--text3);margin-top:1px}

/* Leaderboard */
.lb-hdr{display:flex;align-items:center;gap:8px;padding-bottom:10px;border-bottom:1px solid var(--border);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3)}
.lb-hdr-s{width:40px;text-align:right;flex-shrink:0}
.lb-row{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--border)}
.lb-row:last-child{border-bottom:none}
.lb-rank{width:18px;text-align:center;flex-shrink:0;font-size:11px;font-weight:800}
.lb-rank-1{color:#F59E0B}
.lb-rank-2{color:#9CA3AF}
.lb-rank-3{color:#B45309}
.lb-info{flex:1;min-width:0}
.lb-name{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lb-s{width:40px;text-align:right;font-size:12px;color:var(--text);flex-shrink:0}

/* Sectors */
.sec-row{display:flex;align-items:center;gap:8px;margin-bottom:7px}
.sec-row:last-child{margin-bottom:0}
.sec-name{width:110px;font-size:11.5px;color:var(--text2);flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right}
.sec-track{flex:1;background:var(--bg4);border-radius:4px;height:12px;overflow:hidden}
.sec-bar{height:100%;border-radius:4px;transition:width .5s ease}
.sec-count{width:32px;text-align:right;font-size:12px;font-weight:600;color:var(--text);flex-shrink:0}

/* Role badge */
.role-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:1px 5px;border-radius:4px;text-transform:uppercase;letter-spacing:.4px}
.role-admin{background:rgba(109,40,217,.12);color:var(--p)}
.role-sales{background:var(--bg3);color:var(--text2)}
#sb-role[data-role="admin"]{color:var(--p);font-weight:600}

/* My Day improvements */
.myday-fu-tag{display:inline-block;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;white-space:nowrap}
.myday-fu-tag.fu-overdue{background:#FEF2F2;color:#DC2626}
.myday-fu-tag.fu-today{background:#EFF6FF;color:#2563EB}
.myday-fu-tag.fu-soon{background:#F0FDF4;color:#059669}
body.dark .myday-fu-tag.fu-overdue{background:#2A1212;color:#FCA5A5}
body.dark .myday-fu-tag.fu-today{background:#0f1a2e;color:#93C5FD}
body.dark .myday-fu-tag.fu-soon{background:#0a1f0a;color:#86EFAC}
.task-type-pill{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:var(--bg4);color:var(--text3);border-radius:4px;padding:2px 6px;flex-shrink:0;align-self:flex-start;margin-top:2px}

/* ── Verrijkingsmodus ───────────────────────────────────── */
.em-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:600;display:none;align-items:center;justify-content:center;padding:16px}
.em-overlay.open{display:flex}
.em-panel{background:var(--bg);border-radius:var(--r2);box-shadow:var(--shadow-lg);width:100%;max-width:860px;max-height:92vh;display:flex;flex-direction:column;overflow:hidden}

.em-header{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--border);flex-shrink:0}
.em-title{font-size:15px;font-weight:700;color:var(--text);flex-shrink:0}
.em-progress-wrap{flex:1;display:flex;align-items:center;gap:10px}
.em-progress-bar-bg{flex:1;height:6px;background:var(--bg4);border-radius:3px;overflow:hidden}
.em-progress-bar-fill{height:100%;background:var(--p);border-radius:3px;transition:width .4s ease}
.em-progress-text{font-size:12px;color:var(--text3);white-space:nowrap}

.em-body{display:grid;grid-template-columns:1fr 260px;flex:1;overflow:hidden}
.em-left{padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:0;border-right:1px solid var(--border)}
.em-right{padding:16px;overflow-y:auto;background:var(--bg2)}

.em-lead-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px}
.em-bedrijf{font-size:17px;font-weight:700;color:var(--text);margin-bottom:3px}
.em-meta{font-size:12px;color:var(--text3);margin-bottom:8px}
.em-existing{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.enrich-existing-tag{background:var(--green-dim,#dcfce7);color:#166534;border-radius:20px;font-size:11px;font-weight:500;padding:2px 10px}

.enrich-searching{color:var(--text3);font-size:13px;padding:12px 0;font-style:italic}
.enrich-error{color:var(--red);font-size:13px;padding:8px 0}
.enrich-not-found{background:var(--amber-dim,#fef9c3);border:1px solid var(--amber-border,#fde68a);color:#92400e;border-radius:8px;padding:10px 14px;font-size:13px;line-height:1.5}
.enrich-found-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:8px;margin-top:4px}
.enrich-group-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin:10px 0 4px}
.enrich-item{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;margin-bottom:5px}
.enrich-value{font-size:13px;color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.enrich-item-actions{display:flex;gap:5px;flex-shrink:0}
.enrich-source{font-size:11px;color:var(--text3);margin-top:10px;font-style:italic}

.em-actions{display:flex;gap:8px;margin-top:14px;justify-content:flex-end;flex-shrink:0}

.em-section-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text3);margin-bottom:8px}
.em-links{display:flex;flex-direction:column;gap:6px}
.em-link-btn{display:block;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:12.5px;color:var(--text);text-decoration:none;transition:var(--trans)}
.em-link-btn:hover{border-color:var(--p-border);color:var(--p);background:var(--p-light)}
.em-tips{margin:0;padding:0 0 0 16px;display:flex;flex-direction:column;gap:5px}
.em-tips li{font-size:12px;color:var(--text2);line-height:1.4}

/* Single-lead enrich result (in detail panel) */
.det-enrich-result{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-top:12px}
.enrich-single-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:8px}
.enrich-single-empty{font-size:13px;color:var(--text3);font-style:italic}
.enrich-single-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:5px 0;border-bottom:1px solid var(--border);font-size:13px}
.enrich-single-row:last-of-type{border-bottom:none}
.enrich-website-link{color:var(--p);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}

/* Stats strip */
.em-stats-strip{display:flex;align-items:center;gap:14px;padding:8px 18px;background:var(--bg2);border-bottom:1px solid var(--border);font-size:12px;flex-shrink:0;flex-wrap:wrap}
.em-stat{color:var(--text2)}
.em-stat span{font-weight:700;color:var(--text)}
.em-stat-found span{color:#16a34a}
.em-stat-nf span{color:#dc2626}
.em-stat-skip span{color:var(--text3)}
.em-auto-status{margin-left:auto;font-size:11.5px;font-weight:600;color:var(--p);animation:em-pulse 1.6s ease-in-out infinite}
.em-auto-status.em-auto-status-warn{color:#d97706;animation:none}
@keyframes em-pulse{0%,100%{opacity:1}50%{opacity:.5}}

/* ── Spotlight / Command Palette ──────────────────────────── */
.spotlight-overlay{
  position:fixed;inset:0;z-index:10000;
  display:flex;align-items:flex-start;justify-content:center;
  padding-top:14vh;
  background:rgba(0,0,0,0);
  backdrop-filter:blur(0px);
  -webkit-backdrop-filter:blur(0px);
  pointer-events:none;
  transition:background .18s,backdrop-filter .18s;
}
.spotlight-overlay.sp-open{
  background:rgba(0,0,0,.46);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  pointer-events:all;
}
.spotlight-box{
  width:min(640px,calc(100vw - 40px));
  background:var(--bg);
  border:1px solid var(--border2);
  border-radius:14px;
  box-shadow:0 28px 80px rgba(0,0,0,.32),0 4px 16px rgba(0,0,0,.14);
  overflow:hidden;
  transform:scale(.96) translateY(-10px);
  opacity:0;
  transition:transform .16s cubic-bezier(.2,0,0,1),opacity .16s;
}
.sp-open .spotlight-box{
  transform:scale(1) translateY(0);
  opacity:1;
}
/* Input row */
.sp-input-row{
  display:flex;align-items:center;gap:10px;
  padding:14px 18px;
  border-bottom:1px solid var(--border);
}
.sp-search-icon{flex-shrink:0;color:var(--text3)}
.sp-input{
  flex:1;min-width:0;
  background:none;border:none;outline:none;
  font-size:15px;color:var(--text);font-family:inherit;
}
.sp-input::placeholder{color:var(--text3)}
.sp-kbd{
  font-size:10px;font-family:inherit;
  padding:2px 6px;border-radius:5px;
  background:var(--bg3);border:1px solid var(--border2);
  color:var(--text2);line-height:1.6;
}
/* Results list */
.sp-results{
  max-height:380px;
  overflow-y:auto;
  padding:4px 0;
  scrollbar-width:thin;
  scrollbar-color:var(--border2) transparent;
}
.sp-section-label{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.55px;
  color:var(--text3);
  padding:8px 18px 4px;
}
.sp-hint-text{
  text-align:center;color:var(--text3);font-size:13px;
  padding:22px 18px;
}
.sp-hint-text strong{color:var(--text2)}
.sp-loading{opacity:.7}
.sp-err{color:var(--red)}
/* Loading dots animation */
.sp-dots::after{
  content:'';
  animation:sp-dot-cycle 1.2s steps(4,end) infinite;
}
@keyframes sp-dot-cycle{
  0%{content:''}25%{content:'.'}50%{content:'..'}75%{content:'...'}
}
/* Result row */
.sp-row{
  display:flex;align-items:center;gap:10px;
  padding:9px 18px;
  cursor:pointer;
  border-left:2px solid transparent;
  transition:background .08s,border-color .08s;
}
.sp-row:hover,.sp-row.sp-selected{
  background:var(--bg3);
  border-left-color:var(--p);
}
.sp-dot{
  width:8px;height:8px;border-radius:50%;
  flex-shrink:0;margin-top:1px;
}
.sp-row-body{flex:1;min-width:0}
.sp-company{
  font-size:13.5px;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.sp-sub{
  font-size:11px;color:var(--text2);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin-top:1px;
}
.sp-row-meta{
  display:flex;align-items:center;gap:7px;
  flex-shrink:0;
}
.sp-status-pill{
  font-size:10px;font-weight:600;
  padding:2px 8px;border-radius:20px;
  white-space:nowrap;
}
.sp-fu{
  font-size:10px;font-weight:600;
  padding:2px 7px;border-radius:20px;
  white-space:nowrap;
}
.sp-fu-overdue{background:rgba(220,38,38,.1);color:var(--red)}
.sp-fu-today{background:rgba(217,119,6,.1);color:var(--amber)}
/* Footer */
.sp-footer{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  padding:9px 18px;
  border-top:1px solid var(--border);
  background:var(--bg2);
}
.sp-footer span{
  display:flex;align-items:center;gap:4px;
  font-size:11px;color:var(--text3);
}

/* Auto badge on items */
.enrich-auto-badge{display:inline-block;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;background:var(--p);color:#fff;border-radius:4px;padding:1px 5px;margin-left:6px;vertical-align:middle}
.enrich-item-picked{background:var(--p-light,#eff6ff);border-radius:6px;outline:1.5px solid var(--p-border,#bfdbfe)}

@media(max-width:680px){.em-body{grid-template-columns:1fr}.em-right{border-top:1px solid var(--border)}}

/* ══════════════════════════════════════════════════════════
   1. QUICK VIEW TABS (now inside .leads-top-bar)
══════════════════════════════════════════════════════════ */
.qv-tabs{display:flex;gap:2px;flex-wrap:nowrap;overflow-x:auto}
.qv-tab{
  padding:5px 12px;font-size:12px;font-weight:500;border-radius:20px;
  background:transparent;border:1.5px solid transparent;color:var(--text2);
  cursor:pointer;white-space:nowrap;transition:var(--trans);flex-shrink:0;
}
.qv-tab:hover{background:var(--bg3);color:var(--text);border-color:var(--border2)}
.qv-tab.qv-active{
  background:var(--p-light);color:var(--p);border-color:var(--p-border);font-weight:600;
}
body.dark .qv-tab.qv-active{background:var(--p-glow)}

.filter-check-label{
  font-size:12px;color:var(--text2);
  display:flex;align-items:center;gap:5px;
  cursor:pointer;white-space:nowrap;
}

/* ══════════════════════════════════════════════════════════
   2. LEAD QUALITY DOT
══════════════════════════════════════════════════════════ */
.qdot{
  display:inline-block;width:6px;height:6px;border-radius:50%;
  flex-shrink:0;margin-right:5px;vertical-align:middle;opacity:.65;
}
.qdot-green { background:#16A34A }
.qdot-orange{ background:#D97706 }
.qdot-red   { background:#DC2626 }

/* ══════════════════════════════════════════════════════════
   3. STALENESS ROW TINT
══════════════════════════════════════════════════════════ */
tr.row-stale td{background:color-mix(in srgb,var(--red-dim) 30%,transparent)}
body.dark tr.row-stale td{background:color-mix(in srgb,var(--red-dim) 15%,transparent)}
tr.row-stale:hover td{background:color-mix(in srgb,var(--red-dim) 45%,transparent)}

/* ══════════════════════════════════════════════════════════
   4. HOVER QUICK-ACTIONS
══════════════════════════════════════════════════════════ */
.row-hover-actions{
  display:flex;gap:1px;align-items:center;justify-content:flex-end;
  opacity:0;transition:opacity .12s;pointer-events:none;
  overflow:hidden;
}
tr:hover .row-hover-actions{ opacity:1; pointer-events:auto }
.rha-btn{
  width:26px;height:26px;border-radius:6px;border:none;
  background:transparent;cursor:pointer;color:var(--text3);
  display:flex;align-items:center;justify-content:center;
  transition:background .1s,color .1s;flex-shrink:0;padding:0;
}
.rha-btn svg{ width:13px;height:13px;pointer-events:none }
.rha-btn:hover{ background:var(--bg4);color:var(--text) }
.rha-open{
  color:var(--p);margin-left:2px;
  border-radius:6px;
}
.rha-open:hover{ background:var(--p);color:#fff }
body.dark .rha-btn:hover{ background:var(--bg4) }
body.dark .rha-open:hover{ background:var(--p) }

/* ══════════════════════════════════════════════════════════
   5. KANBAN BOARD
══════════════════════════════════════════════════════════ */
.kanban-board{
  display:flex;gap:12px;padding:16px;overflow-x:auto;overflow-y:hidden;
  flex:1;min-height:0;align-items:flex-start;
}
.kb-col{
  flex-shrink:0;width:240px;
  background:var(--bg3);border-radius:var(--r2);
  display:flex;flex-direction:column;max-height:100%;
}
.kb-col-header{
  padding:10px 12px;border-radius:var(--r2) var(--r2) 0 0;
  background:var(--bg2);border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:6px;flex-shrink:0;
}
.kb-col-title{font-size:13px;font-weight:700;color:var(--text);flex:1}
.kb-col-count{
  font-size:11px;font-weight:700;background:var(--bg4);color:var(--text3);
  border-radius:10px;padding:1px 7px;
}
.kb-col-value{font-size:11px;color:var(--green);font-weight:600}
.kb-cards{padding:8px;overflow-y:auto;display:flex;flex-direction:column;gap:6px;flex:1}
.kb-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);
  padding:10px 12px;cursor:pointer;transition:var(--trans);
}
.kb-card:hover{border-color:var(--p-border);box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.kb-card-overdue{border-left:3px solid var(--red)}
.kb-card-header{display:flex;align-items:center;gap:5px;margin-bottom:3px}
.kb-card-name{font-size:13px;font-weight:600;color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kb-prio-dot{width:7px;height:7px;border-radius:50%;background:var(--red);flex-shrink:0;display:inline-block}
.kb-card-contact{font-size:12px;color:var(--text3);margin-bottom:5px}
.kb-card-footer{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:4px}
.kb-deal{font-size:12px;font-weight:600;color:var(--green)}
.kb-fu{font-size:11px;color:var(--text3);display:inline-flex;align-items:center;gap:3px}
.kb-fu svg{flex-shrink:0}
.kb-fu-overdue{color:var(--red);font-weight:600}
/* drag over highlight */
.kb-col[ondragover]:focus-within,
.kb-col.drag-over{background:var(--p-light);border:2px dashed var(--p-border)}
body.dark .kb-col.drag-over{background:var(--p-glow)}

/* ══════════════════════════════════════════════════════════
   6. KEYBOARD FOCUSED ROW
══════════════════════════════════════════════════════════ */
tr.row-kb-focus td{
  background:var(--p-light) !important;
  outline:2px solid var(--p) !important;
  outline-offset:-1px;
}
body.dark tr.row-kb-focus td{background:var(--p-glow) !important}

/* ══════════════════════════════════════════════════════════
   7. COLUMN CHOOSER POPOVER
══════════════════════════════════════════════════════════ */
.col-chooser-wrap{position:relative}
.col-chooser-popover{
  position:absolute;top:calc(100% + 6px);right:0;z-index:400;
  background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r);
  box-shadow:var(--shadow);padding:10px;min-width:180px;
}
.col-chooser-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:8px}
.col-chooser-row{
  display:flex;align-items:center;gap:8px;padding:4px 0;
  font-size:13px;color:var(--text);cursor:pointer;
}
.col-chooser-row:hover{color:var(--p)}

/* Column hide rules (table uses class toggling) */
.data-table.hide-col-contact  th:nth-child(3),.data-table.hide-col-contact  td:nth-child(3) {display:none}
.data-table.hide-col-status   th:nth-child(4),.data-table.hide-col-status   td:nth-child(4) {display:none}
.data-table.hide-col-priority th:nth-child(5),.data-table.hide-col-priority td:nth-child(5) {display:none}
.data-table.hide-col-deal     th:nth-child(6),.data-table.hide-col-deal     td:nth-child(6) {display:none}
.data-table.hide-col-followup th:nth-child(7),.data-table.hide-col-followup td:nth-child(7) {display:none}
.data-table.hide-col-assigned th:nth-child(8),.data-table.hide-col-assigned td:nth-child(8) {display:none}
.data-table.hide-col-tn       th:nth-child(9),.data-table.hide-col-tn       td:nth-child(9) {display:none}
.data-table.hide-col-nexttask th:nth-child(10),.data-table.hide-col-nexttask td:nth-child(10){display:none}
.data-table.hide-col-lastcont th:nth-child(11),.data-table.hide-col-lastcont td:nth-child(11){display:none}
.data-table.hide-col-created  th:nth-child(12),.data-table.hide-col-created  td:nth-child(12){display:none}

/* ══════════════════════════════════════════════════════════
   8. COMPACT ROW DENSITY
══════════════════════════════════════════════════════════ */
.data-table.compact td,.data-table.compact th{
  padding:3px 8px !important;font-size:12px;
}
.data-table.compact .td-name{font-size:12px}
.data-table.compact .td-muted{font-size:11px}
.data-table.compact .status-select-inline{padding:2px 4px;font-size:11px}
.data-table.compact .priority-select{padding:2px 4px;font-size:11px}
.data-table.compact .rha-btn{width:22px;height:22px}
.data-table.compact .rha-btn svg{width:11px;height:11px}

/* ══════════════════════════════════════════════════════════
   9. NEXT TASK CELL
══════════════════════════════════════════════════════════ */
.next-task-cell{display:flex;flex-direction:column;gap:1px}
.nt-title{font-size:12px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}
.nt-date{font-size:11px;color:var(--text3)}
.next-task-cell.nt-overdue .nt-title{color:var(--red);font-weight:600}
.next-task-cell.nt-overdue .nt-date{color:var(--red)}
