/* ============================================================
   LeadSelect — design system  (light default + dark toggle)
   Premium pattern: dark sidebar + clean light content.
   ============================================================ */
:root{
  /* sidebar — always dark (premium rail) */
  --side-bg:#0d1426; --side-bg-2:#0a1020; --side-text:#aeb6c4; --side-muted:#6b7689;
  --side-active-bg:rgba(20,184,166,.16); --side-active-text:#fff; --side-hover:rgba(255,255,255,.05);
  --side-border:#1b2540; --side-brand:#2dd4bf;
  /* content — light */
  --bg:#f5f6f8; --surface:#ffffff; --surface-2:#f8f9fb; --surface-3:#f1f3f6;
  --border:#e7e9ee; --border-2:#d7dbe2; --ring:rgba(13,148,136,.18);
  --text:#141923; --text-2:#5a6472; --text-3:#8a93a2;
  --brand:#0d9488; --brand-strong:#0f766e; --brand-weak:#eaf6f4; --brand-text:#0f766e;
  --accent:#6366f1;
  --green:#16a34a; --green-bg:#e7f6ec; --green-text:#137a3b;
  --amber:#b45309; --amber-bg:#fdf3e3; --amber-text:#a45a08;
  --red:#dc2626;   --red-bg:#fdecec;   --red-text:#c0322f;
  --blue:#2563eb;  --blue-bg:#e8effd;  --blue-text:#1d4ed8;
  --violet:#7c3aed; --violet-bg:#f1ecfe; --violet-text:#6d28d9;
  --shadow-sm:0 1px 2px rgba(16,24,40,.05);
  --shadow:0 1px 3px rgba(16,24,40,.08),0 1px 2px rgba(16,24,40,.04);
  --shadow-lg:0 10px 30px rgba(16,24,40,.12),0 2px 8px rgba(16,24,40,.06);
  --radius:14px; --radius-sm:10px;
  /* backward-compat aliases (older markup/JS used these names) — they reference
     the theme tokens above, so they flip automatically in dark mode */
  --panel:var(--surface); --panel2:var(--surface-2); --card:var(--surface);
  --border2:var(--border-2); --muted:var(--text-2); --muted-2:var(--text-3);
  --primary:var(--brand); --primaryl:var(--brand); --neon:var(--brand);
  --success:var(--green); --danger:var(--red); --warning:var(--amber); --info:var(--blue);
}
[data-theme="dark"]{
  --bg:#0a0f17; --surface:#121821; --surface-2:#171f2a; --surface-3:#1e2733;
  --border:#222c39; --border-2:#2e3a4a; --ring:rgba(45,212,191,.22);
  --text:#e7eaef; --text-2:#9aa4b2; --text-3:#6b7585;
  --brand:#2dd4bf; --brand-strong:#14b8a6; --brand-weak:rgba(45,212,191,.12); --brand-text:#5eead4;
  --green-bg:rgba(22,163,74,.16); --green-text:#6ee7a8;
  --amber-bg:rgba(180,83,9,.18); --amber-text:#fcd34d;
  --red-bg:rgba(220,38,38,.16); --red-text:#fca5a5;
  --blue-bg:rgba(37,99,235,.16); --blue-text:#93c5fd;
  --violet-bg:rgba(124,58,237,.18); --violet-text:#c4b5fd;
  --shadow-sm:none; --shadow:0 1px 2px rgba(0,0,0,.3); --shadow-lg:0 16px 40px rgba(0,0,0,.5);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{font-family:'Inter',-apple-system,system-ui,sans-serif;background:var(--bg);color:var(--text);
  font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.hidden{display:none!important}
button{font-family:inherit;cursor:pointer}
a{color:inherit}
.muted{color:var(--text-2)}
::placeholder{color:var(--text-3)}

/* ---------- login ---------- */
.login{min-height:100vh;display:grid;place-items:center;padding:20px;background:
  radial-gradient(1100px 500px at 50% -20%, var(--brand-weak), transparent 60%), var(--bg)}
.login .box{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);
  border-radius:16px;padding:34px;box-shadow:var(--shadow-lg)}
.login h2{font-size:19px;font-weight:700;margin:20px 0 4px}
.login p.s{color:var(--text-2);font-size:13px;margin-bottom:18px}
.btn{background:var(--brand);color:#fff;border:0;padding:10px 16px;border-radius:var(--radius-sm);
  font-weight:600;font-size:13.5px;transition:.15s;line-height:1.2}
.btn:hover{background:var(--brand-strong)}
.login .btn{width:100%;margin-top:20px;padding:11px}
.btn.sm{padding:7px 12px;font-size:12.5px}
.btn.ghost{background:var(--surface);border:1px solid var(--border-2);color:var(--text)}
.btn.ghost:hover{background:var(--surface-3);border-color:var(--border-2)}
.err{color:var(--red-text);font-size:12.5px;margin-top:10px;min-height:16px}

/* ---------- brand mark ---------- */
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;letter-spacing:-.01em}
.brand .dot{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;color:#04211d;font-size:13px;
  background:linear-gradient(135deg,#2dd4bf,#0d9488);box-shadow:0 2px 8px rgba(13,148,136,.35)}

/* ---------- app shell ---------- */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:var(--side-bg);border-right:1px solid var(--side-border);padding:18px 14px;
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:auto;color:var(--side-text)}
.side .brand{color:#fff;padding:4px 8px 18px}
.glabel{font-size:10.5px;text-transform:uppercase;letter-spacing:.09em;color:var(--side-muted);padding:16px 10px 7px;font-weight:600}
.nav{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:9px;color:var(--side-text);
  font-weight:500;font-size:13.5px;transition:.13s;cursor:pointer;text-decoration:none;margin-bottom:1px}
.nav:hover{background:var(--side-hover);color:#fff}
.nav.active{background:var(--side-active-bg);color:var(--side-active-text);font-weight:600;
  box-shadow:inset 2px 0 0 var(--side-brand)}
.nav svg{width:18px;height:18px;flex:none;opacity:.92}
.nav .count{margin-left:auto;font-size:11px;font-weight:600;color:var(--side-muted);background:rgba(255,255,255,.06);
  padding:1px 7px;border-radius:999px}
.nav.active .count{color:#fff;background:rgba(255,255,255,.12)}
.nav.soon{opacity:.5}
.side .userchip{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px;border-top:1px solid var(--side-border);margin-top:14px}

/* ---------- topbar ---------- */
.main{display:flex;flex-direction:column;min-width:0}
.top{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 28px;height:60px;
  border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10}
.top h1{font-size:17px;font-weight:650;letter-spacing:-.01em}
.top .right{display:flex;align-items:center;gap:14px}
.who{font-size:12.5px;color:var(--text-2)}
.iconbtn{width:34px;height:34px;border-radius:9px;border:1px solid var(--border);background:var(--surface);
  display:grid;place-items:center;color:var(--text-2);transition:.13s}
.iconbtn:hover{background:var(--surface-3);color:var(--text)}
.avatar{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:12px;color:#fff;
  background:linear-gradient(135deg,#0d9488,#6366f1)}

/* ---------- content ---------- */
.content{padding:26px 28px 64px;max-width:1380px}
.view{display:none}.view.active{display:block;animation:fade .22s ease}
@keyframes fade{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
.greeting h2{font-size:22px;font-weight:700;letter-spacing:-.02em}
.greeting .sub{color:var(--text-2);font-size:13px;margin-top:3px}
.section-head{font-size:15px;font-weight:650;margin:6px 0 14px;display:flex;align-items:center;gap:8px;justify-content:space-between}

/* ---------- panels / cards ---------- */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.panel h3{font-size:14.5px;font-weight:650;letter-spacing:-.01em;display:flex;align-items:center;gap:7px;justify-content:space-between}
.panel .ps{color:var(--text-2);font-size:12.5px;margin:4px 0 14px;line-height:1.5}
.pg-title{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);font-weight:650;margin:16px 0 8px}

/* ---------- KPI tiles ---------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 17px;box-shadow:var(--shadow-sm)}
.kpi .l{font-size:12px;color:var(--text-2);font-weight:500}
.kpi .v{font-size:26px;font-weight:750;margin-top:8px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.kpi .delta{font-size:11.5px;font-weight:600;margin-top:6px;display:inline-flex;gap:3px;align-items:center}
.up{color:var(--green-text)} .down{color:var(--red-text)} .flat{color:var(--text-3)}

/* ---------- status pill strip ---------- */
.pillstrip{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.spill{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);
  border-radius:999px;padding:5px 12px;font-size:12px;font-weight:500;color:var(--text-2)}
.spill b{color:var(--text);font-weight:650}
.spill .d{width:8px;height:8px;border-radius:50%}

/* ---------- urgent cards ---------- */
.urgents{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px}
.urgent{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--brand);
  border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm)}
.urgent.red{border-left-color:var(--red)} .urgent.amber{border-left-color:var(--amber)} .urgent.blue{border-left-color:var(--blue)}
.urgent .ut{font-size:12.5px;color:var(--text-2);display:flex;justify-content:space-between;align-items:center}
.urgent .uv{font-size:30px;font-weight:750;margin:6px 0 4px;letter-spacing:-.02em}
.urgent a{font-size:12.5px;color:var(--brand-text);font-weight:600;text-decoration:none}
.urgent a:hover{text-decoration:underline}

/* ---------- tabs + filter chips ---------- */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:14px;flex-wrap:wrap}
.tab{padding:9px 13px;font-size:13px;font-weight:550;color:var(--text-2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;display:inline-flex;align-items:center;gap:6px}
.tab:hover{color:var(--text)}
.tab.active{color:var(--brand-text);border-bottom-color:var(--brand)}
.tab .c{font-size:11px;background:var(--surface-3);color:var(--text-2);padding:0 6px;border-radius:999px;font-weight:600}
.tab.active .c{background:var(--brand-weak);color:var(--brand-text)}
.fchip{display:inline-flex;align-items:center;gap:6px;background:var(--brand-weak);color:var(--brand-text);
  border:1px solid transparent;border-radius:7px;padding:5px 9px;font-size:12px;font-weight:550}
.fchip .x{cursor:pointer;opacity:.7}.fchip .x:hover{opacity:1}

/* ---------- toolbar / filters ---------- */
.toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
.toolbar .grow{flex:1;min-width:180px}
label{font-size:12px;color:var(--text-2);display:block;margin:10px 0 5px;font-weight:500}
input,select,textarea{width:100%;background:var(--surface);border:1px solid var(--border-2);color:var(--text);
  padding:9px 11px;border-radius:var(--radius-sm);font:inherit;font-size:13.5px;transition:.13s}
/* checkboxes & radios must keep their natural box size — the width:100% above is
   for text fields only, and would otherwise stretch a checkbox across its row. */
input[type=checkbox],input[type=radio]{width:auto;min-width:0;padding:0;appearance:auto;-webkit-appearance:auto;flex:none}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--ring)}
select{cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:32px;
  background-color:var(--surface-2);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;background-position:right 11px center}
select:hover{border-color:var(--brand)}
[data-theme="dark"] select{background-color:var(--surface-3)}
.toolbar input,.toolbar select{width:auto;padding:8px 11px;font-size:13px}
.sel{width:auto}

/* ---------- tables ---------- */
.table-scroll{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{background:var(--surface-2);color:var(--text-2);font-weight:600;font-size:11px;text-transform:uppercase;
  letter-spacing:.04em;text-align:left;padding:10px 14px;border-bottom:1px solid var(--border);white-space:nowrap;cursor:default}
.table-scroll thead th{cursor:pointer;user-select:none}
thead th:hover{color:var(--text)}
tbody td{padding:11px 14px;border-bottom:1px solid var(--border);white-space:nowrap;color:var(--text)}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover{background:var(--surface-2)}
td.num,td.n,th.num,th.n{text-align:right;font-variant-numeric:tabular-nums}
tr.total td{font-weight:700;background:var(--surface-2)}
.leadrow{cursor:pointer}
.cellmain{display:flex;align-items:center;gap:10px}
.cellmain .avatar{width:30px;height:30px;font-size:11px}
.cellsub{font-size:11.5px;color:var(--text-3)}

/* ---------- pills / dots / tags ---------- */
.pill{display:inline-block;padding:2px 9px;border-radius:6px;font-size:11.5px;font-weight:600;white-space:nowrap}
.p-green{background:var(--green-bg);color:var(--green-text)}
.p-amber{background:var(--amber-bg);color:var(--amber-text)}
.p-red{background:var(--red-bg);color:var(--red-text)}
.p-blue{background:var(--blue-bg);color:var(--blue-text)}
.p-violet{background:var(--violet-bg);color:var(--violet-text)}
.p-gray{background:var(--surface-3);color:var(--text-2)}
.sdot{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:550}
.sdot::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--text-3)}
.sdot.green::before{background:var(--green)} .sdot.amber::before{background:var(--amber)}
.sdot.blue::before{background:var(--blue)} .sdot.red::before{background:var(--red)} .sdot.violet::before{background:var(--violet)}
.flagdot{display:inline-block;padding:2px 7px;border-radius:5px;font-size:10.5px;font-weight:700;margin-right:4px}
.f-sale{background:var(--green-bg);color:var(--green-text)}.f-visit{background:var(--blue-bg);color:var(--blue-text)}.f-junk{background:var(--red-bg);color:var(--red-text)}
.tag{display:inline-flex;align-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:7px;
  padding:5px 9px;margin:0 6px 6px 0;font-size:12px;color:var(--text)}
.tag .x{cursor:pointer;margin-left:7px;color:var(--text-3);font-weight:700}.tag .x:hover{color:var(--red)}
.pillrow{display:flex;gap:0;flex-wrap:wrap;align-items:center}
.badge-demo{font-size:10.5px;font-weight:700;letter-spacing:.04em;color:var(--amber-text);background:var(--amber-bg);
  border-radius:999px;padding:4px 9px}

/* ---------- pager ---------- */
.pager{display:flex;gap:8px;align-items:center;justify-content:flex-end;margin-top:14px;font-size:12.5px;color:var(--text-2)}
.pager button{background:var(--surface);border:1px solid var(--border-2);color:var(--text);border-radius:7px;padding:6px 12px}
.pager button:hover{background:var(--surface-3)}

/* ---------- modal ---------- */
.overlay{position:fixed;inset:0;background:rgba(17,24,39,.5);display:none;place-items:center;z-index:60;padding:20px;backdrop-filter:blur(2px)}
.overlay.open{display:grid}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;width:100%;
  max-width:640px;max-height:90vh;overflow:auto;box-shadow:var(--shadow-lg)}
.modal h3{font-size:17px;font-weight:700;margin-bottom:16px;letter-spacing:-.01em}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
/* grid children must be allowed to shrink, else a wide table inside forces the
   whole page wider than the viewport (clips the title/sidebar). */
.grid2>*{min-width:0}
.grid2 #propertiesBody,.grid2 #projBookings{overflow-x:auto}
@media(max-width:900px){.grid2{grid-template-columns:1fr}}
.modal label{margin-top:8px}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}

/* ---------- lead detail drawer ---------- */
.overlay.drawer-ov{padding:0}
.overlay.drawer-ov.open{display:block}
.drawer{position:absolute;top:0;right:0;height:100%;background:var(--surface);width:min(1180px,100%);max-width:100%;
  display:flex;flex-direction:column;border-left:1px solid var(--border);box-shadow:-16px 0 48px rgba(0,0,0,.22);animation:ldslide .2s ease}
.drawer-body .dgrid2{display:grid;grid-template-columns:1fr 1fr;gap:18px 28px;align-items:start}
@media(max-width:900px){.drawer-body .dgrid2{grid-template-columns:1fr}}

/* ---------- project cards + detail page ---------- */
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:18px}
.pcard{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .15s,transform .15s}
.pcard:hover{box-shadow:var(--shadow-md,0 8px 24px rgba(0,0,0,.12));transform:translateY(-2px)}
.pcard-top{height:5px;background:var(--accent)}
.pcard-body{padding:16px 17px}
.pcard-head{display:flex;align-items:center;gap:11px;margin-bottom:15px}
.pavatar{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;color:#fff;font-weight:750;font-size:14px;flex:none}
.pavatar.lg{width:54px;height:54px;border-radius:14px;font-size:18px}
.pcard-id{flex:1;min-width:0}
.pcard-name{font-weight:700;font-size:15px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pcard-loc{font-size:12px;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pstats{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin-bottom:14px}
.pstat-l{font-size:9.5px}
.pstat{text-align:center}
.pstat-v{font-size:19px;font-weight:750;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.pstat-l{font-size:10.5px;color:var(--text-2);margin-top:1px;text-transform:uppercase;letter-spacing:.03em}
.pcard-sold{margin-bottom:14px}
.pcard-sold-row{display:flex;justify-content:space-between;font-size:12px;color:var(--text-2);margin-bottom:5px;font-weight:600}
.pcard-actions{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.pcard-actions .btn{width:auto;margin:0;padding:8px 0;font-size:13px}
.dpage-head{display:flex;align-items:center;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.dpage-title{display:flex;align-items:center;gap:13px;flex:1;min-width:0}
.dpage-name{font-size:20px;font-weight:750;letter-spacing:-.02em;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.backlink{cursor:pointer;color:var(--brand-text);font-size:13px;font-weight:600;text-decoration:none}
.backlink:hover{text-decoration:underline}
@media(max-width:560px){.pgrid{grid-template-columns:1fr}}

/* ---------- reports suite (menu + submenu + report panel) ---------- */
.rep-layout{display:grid;grid-template-columns:230px 1fr;gap:18px;align-items:start}
.rep-menu{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:8px;position:sticky;top:8px;max-height:calc(100vh - 120px);overflow:auto}
.rep-cat{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2);padding:12px 10px 5px}
.rep-cat:first-child{padding-top:4px}
.rep-item{display:block;padding:8px 11px;border-radius:8px;font-size:13px;font-weight:550;color:var(--text);cursor:pointer;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rep-item:hover{background:var(--surface-2)}
.rep-item.active{background:var(--brand-weak);color:var(--brand-text);font-weight:650}
.rep-main{min-width:0}
/* report list as a sidebar submenu (dark sidebar) */
.subnav{flex:none;margin:2px 0 6px 14px;padding:4px 0 6px 8px;border-left:2px solid var(--side-border);max-height:360px;overflow-y:auto}
.subnav-cat{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--side-muted,#9aa4b2);padding:8px 8px 3px}
.subnav-item{display:block;padding:5px 9px;border-radius:7px;font-size:12.5px;color:var(--side-fg,#cbd5e1);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.subnav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.subnav-item.active{background:var(--brand);color:#fff;font-weight:600}
/* compare toggle + KPI delta + sortable headers */
.rf-compare{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-2);font-weight:600;align-self:flex-end;padding-bottom:7px;cursor:pointer;white-space:nowrap}
.kpi-delta{font-size:12px;font-weight:700;margin-top:6px;display:inline-flex;gap:3px;align-items:center}
.kpi-delta.up{color:var(--green-text)} .kpi-delta.down{color:var(--red-text)}
.rep-cmp{font-size:12px;font-weight:600;color:var(--text-2);background:var(--surface-2);border:1px solid var(--border);padding:2px 9px;border-radius:999px;margin-left:8px}
th.sortable{cursor:pointer;user-select:none;white-space:nowrap}
th.sortable:hover{color:var(--brand-text)}
th.sortable .sort-ar{display:inline-block;width:0;opacity:.4;margin-left:4px}
th.sortable.sorted .sort-ar{opacity:1}
th.sortable.sorted.asc .sort-ar:after{content:"▲";font-size:9px}
th.sortable.sorted.desc .sort-ar:after{content:"▼";font-size:9px}
/* DataTable: search bar, totals, clickable rows */
.dt-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px}
.dt-search{width:260px;max-width:60%;padding:8px 11px}
.dt-count{font-size:12px;color:var(--text-2);font-weight:600;white-space:nowrap}
table.dt tfoot .dt-total td{border-top:2px solid var(--border);font-weight:750;background:var(--surface-2);font-variant-numeric:tabular-nums}
tr.dt-click{cursor:pointer}
tr.dt-click:hover td{background:var(--surface-2)}
/* DataTable pager */
.dt-pager{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:11px 2px 2px;font-size:12.5px;color:var(--text-2)}
.dt-perpage select{padding:5px 8px;font-size:12.5px;width:auto;margin:0 2px}
.dt-pagebtns{display:flex;align-items:center;gap:8px}
.dt-pagebtns .btn{width:auto;margin:0;padding:6px 12px;font-size:12.5px}
.dt-pagebtns .btn:disabled{opacity:.4;cursor:default}
.dt-pagenum{font-weight:600;font-variant-numeric:tabular-nums;min-width:54px;text-align:center}
/* custom date picker */
.dp-trigger{display:inline-flex;align-items:center;justify-content:space-between;gap:8px;min-width:140px;
  padding:8px 11px;border:1px solid var(--border);border-radius:9px;background:var(--surface-2);color:var(--text);
  font-size:13px;cursor:pointer;font-family:inherit;text-align:left}
.dp-trigger:hover{border-color:var(--brand)}
.dp-trigger .dp-val:empty:before{content:'Select date';color:var(--text-2)}
.dp-trigger .dp-ic{opacity:.6;font-size:12px}
.dp-pop{position:fixed;z-index:300;width:268px;background:var(--surface);border:1px solid var(--border);
  border-radius:13px;box-shadow:0 16px 44px rgba(0,0,0,.22);padding:12px;animation:dpIn .14s ease}
@keyframes dpIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.dp-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.dp-title{font-weight:700;font-size:13.5px}
.dp-nav{border:none;background:var(--surface-2);width:28px;height:28px;border-radius:8px;cursor:pointer;color:var(--text);font-size:15px}
.dp-nav:hover{background:var(--brand-weak);color:var(--brand-text)}
.dp-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:3px}
.dp-dow span{text-align:center;font-size:10.5px;font-weight:700;color:var(--text-2);text-transform:uppercase}
.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.dp-day{display:grid;place-items:center;height:32px;border-radius:8px;font-size:12.5px;cursor:pointer;font-variant-numeric:tabular-nums}
.dp-day:not(.dp-blank):hover{background:var(--surface-2)}
.dp-day.today{box-shadow:inset 0 0 0 1px var(--brand)}
.dp-day.sel{background:var(--brand);color:#fff;font-weight:700}
.dp-blank{cursor:default}
.dp-foot{display:flex;justify-content:space-between;margin-top:9px;border-top:1px solid var(--border);padding-top:9px}
.dp-foot button{border:none;background:none;color:var(--brand-text);font-weight:600;font-size:12.5px;cursor:pointer;padding:3px 6px}
.dp-foot button:hover{text-decoration:underline}
/* custom confirm dialog */
.cmodal{max-width:400px;text-align:center;padding:26px 26px 20px;animation:dpIn .15s ease}
.cmodal-ic{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;font-size:24px;margin:0 auto 14px}
.cmodal-ic.danger{background:var(--red-bg);color:var(--red-text)}
.cmodal-ic.info{background:var(--brand-weak);color:var(--brand-text)}
.cmodal-title{font-size:18px;font-weight:750;margin-bottom:6px}
.cmodal-msg{font-size:13.5px;color:var(--text-2);line-height:1.5;margin-bottom:20px}
.cmodal .modal-actions{display:flex;gap:10px;justify-content:center}
.cmodal .modal-actions .btn{width:auto;margin:0;padding:10px 22px;min-width:110px}
.btn.danger{background:var(--red);color:#fff}
.btn.danger:hover{background:var(--red-text);box-shadow:0 4px 14px rgba(220,38,38,.3)}
/* segmented control (inventory status filter) */
.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:2px;gap:2px}
.segbtn{border:none;background:none;padding:5px 12px;font-size:12.5px;font-weight:600;color:var(--text-2);border-radius:7px;cursor:pointer;transition:.12s}
.segbtn:hover{color:var(--text)}
.segbtn.active{background:var(--surface);color:var(--brand-text);box-shadow:var(--shadow-sm)}
/* ---------- lead detail drawer: 2-column workspace ---------- */
.ld-actionbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:0 0 16px;margin-bottom:16px;border-bottom:1px solid var(--border)}
.ld-act{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:10px;font-weight:650;font-size:13px;cursor:pointer;text-decoration:none;border:1px solid var(--border)}
.ld-act.call{background:var(--brand);color:#fff;border-color:var(--brand)}
.ld-act.call:hover{background:var(--brand-strong)}
.ld-act.wa{background:#e8f7ef;color:#128c4b;border-color:#bce8cf}
[data-theme="dark"] .ld-act.wa{background:rgba(18,140,75,.18);color:#6ee7a8;border-color:rgba(18,140,75,.4)}
.ld-facts{display:flex;gap:18px;flex-wrap:wrap;margin-left:auto}
.ld-fact{font-size:12.5px;color:var(--text)}
.ld-fact-k{color:var(--text-2);margin-right:5px;font-size:11px;text-transform:uppercase;letter-spacing:.03em;font-weight:600}
.ld-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:16px;align-items:start}
.ld-col{display:flex;flex-direction:column;gap:14px}
.ld-card{margin:0;background:var(--surface-2)}
.ld-card.ld-primary{background:var(--brand-weak);border-color:var(--brand)}
.ld-flag{background:var(--red-bg);color:var(--red-text);border:1px solid var(--red-text);border-radius:10px;padding:10px 14px;font-size:13px;font-weight:600;margin-bottom:16px}
/* leads totals bar */
.lead-totals{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.lead-totals:empty{display:none}
.lt-chip{min-width:96px;background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:10px 14px;cursor:pointer;transition:.14s;box-shadow:var(--shadow-sm)}
.lt-chip:hover{border-color:var(--brand);box-shadow:0 4px 14px rgba(13,148,136,.12)}
.lt-chip.active{border-color:var(--brand);background:var(--brand-weak)}
.lt-v{font-size:20px;font-weight:750;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.lt-l{font-size:11px;color:var(--text-2);margin-top:1px;font-weight:600}
/* active filter chips */
.active-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:12px}
.active-filters:empty{display:none}
.fchip{display:inline-flex;align-items:center;gap:7px;background:var(--brand-weak);color:var(--brand-text);border:1px solid var(--brand);border-radius:999px;padding:5px 6px 5px 12px;font-size:12.5px;font-weight:600}
.fchip-x{cursor:pointer;width:17px;height:17px;border-radius:50%;display:grid;place-items:center;background:rgba(0,0,0,.06);font-size:10px;line-height:1}
.fchip-x:hover{background:var(--brand);color:#fff}
.fchip-clear{cursor:pointer;font-size:12.5px;font-weight:600;color:var(--text-2);text-decoration:underline;margin-left:4px}
.fchip-clear:hover{color:var(--red-text)}
/* clickable dashboard widgets */
.kpi-click,.spill-click{cursor:pointer}
.kpi-click:hover{border-color:var(--brand);box-shadow:0 4px 16px rgba(13,148,136,.14)}
.spill-click:hover{border-color:var(--brand);color:var(--brand-text)}
.urgent a{cursor:pointer}
/* global sortable headers (non-DataTable tables) */
.table-scroll table:not(.dt) thead th,.panel table:not(.dt) thead th{cursor:pointer;user-select:none;position:relative}
.table-scroll table:not(.dt) thead th:hover,.panel table:not(.dt) thead th:hover{color:var(--brand-text)}
table:not(.dt) thead th.th-asc:after{content:" ▲";font-size:9px;opacity:.8}
table:not(.dt) thead th.th-desc:after{content:" ▼";font-size:9px;opacity:.8}
@media(max-width:920px){.ld-grid{grid-template-columns:1fr}.ld-facts{margin-left:0}}
/* ---------- modern polish (sitewide) ---------- */
.panel{transition:box-shadow .18s ease,border-color .18s ease}
.panel:hover{box-shadow:var(--shadow)}
.kpi{transition:box-shadow .18s ease,transform .18s ease}
.kpi:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.btn{transition:background .15s ease,box-shadow .15s ease,transform .06s ease}
.btn:not(.ghost):hover{box-shadow:0 4px 14px rgba(13,148,136,.25)}
.btn:active{transform:translateY(1px)}
.nav{transition:background .12s ease,color .12s ease}
table tbody tr{transition:background .1s ease}
.pill{transition:background .12s ease}
.dt-trigger,.dp-trigger,select,input,textarea{transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}
/* slightly tighter, more refined table headers */
table thead th{letter-spacing:.01em}
/* card corners follow the softer radius everywhere */
.kpi,.panel{border-radius:var(--radius)}
/* project overview key/value grid */
.ov-grid{display:grid;grid-template-columns:130px 1fr;gap:7px 14px;font-size:13px}
.ov-k{color:var(--text-2);font-weight:600}
.ov-v{color:var(--text);overflow-wrap:anywhere}
/* inline editable select inside a DataTable cell */
.dt-inline{padding:4px 8px;font-size:12px;border:1px solid transparent;background:transparent;border-radius:6px;cursor:pointer;max-width:150px}
.dt-inline:hover{border-color:var(--border);background:var(--surface-2)}
.dt-inline:focus{border-color:var(--brand);background:var(--surface)}
.rep-filterbar{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin-bottom:16px}
.rf{display:flex;flex-direction:column;gap:4px}
.rf label{font-size:10.5px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.03em}
.rf input,.rf select{padding:7px 9px;font-size:13px}
.rep-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px;gap:12px}
.rep-title{font-size:18px;font-weight:750;letter-spacing:-.02em}
.rep-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.rep-presetwrap{display:flex;align-items:center;gap:6px}
.rep-preset-sel{padding:7px 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-size:12.5px;max-width:190px}
.rep-preset-save,.rep-preset-del{width:auto!important;margin:0!important;padding:8px 11px!important;font-size:12.5px}
.rep-colwrap{position:relative}
.rep-colbtn{width:auto!important;margin:0!important;padding:8px 13px!important}
.rep-colmenu{position:absolute;top:calc(100% + 6px);right:0;z-index:40;background:var(--surface);border:1px solid var(--border);
  border-radius:10px;box-shadow:0 12px 32px rgba(0,0,0,.18);padding:8px;min-width:210px;max-height:340px;overflow:auto}
.rep-colmenu-h{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-2);padding:4px 8px 6px}
.rep-colopt{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:7px;font-size:13px;cursor:pointer;white-space:nowrap}
.rep-colopt:hover{background:var(--surface-2)}
/* the global input{width:100%} would stretch the checkbox and crush the label — pin it */
.rep-colopt input[type=checkbox]{margin:0;width:16px;min-width:16px;flex:none;appearance:auto;-webkit-appearance:checkbox}
.rep-colopt span{flex:1}
.rep-colmenu-f{border-top:1px solid var(--border);margin-top:6px;padding:7px 8px 3px}
.rep-colmenu-f a{font-size:12px;color:var(--brand-text);cursor:pointer}
.digest-kpis{display:flex;gap:18px;flex-wrap:wrap;margin-top:6px}
.digest-kpis .dk{display:flex;flex-direction:column;align-items:center;min-width:64px}
.digest-kpis .dk-v{font-size:22px;font-weight:750;letter-spacing:-.02em}
.digest-kpis .dk-l{font-size:11px;color:var(--text-2);text-transform:uppercase;letter-spacing:.03em}
.rep-kpis{margin-bottom:16px}
.rep-note{background:var(--brand-weak);color:var(--brand-text);border-radius:9px;padding:9px 13px;font-size:12.5px;margin-bottom:14px}
.chart-wrap{position:relative;height:300px}
@media(max-width:900px){.rep-layout{grid-template-columns:1fr}.rep-menu{position:static;max-height:none;display:flex;flex-wrap:wrap;gap:4px}.rep-cat{width:100%}}
@keyframes ldslide{from{transform:translateX(40px);opacity:.5}to{transform:none;opacity:1}}
.drawer-head{display:flex;justify-content:space-between;align-items:flex-start;padding:16px 20px;border-bottom:1px solid var(--border)}
.drawer-title{font-size:17px;font-weight:700;letter-spacing:-.01em}
.drawer-tabs{display:flex;gap:2px;padding:0 16px;border-bottom:1px solid var(--border)}
.dtab{background:none;border:none;padding:11px 14px;font-weight:600;font-size:13px;color:var(--text-2);cursor:pointer;border-bottom:2px solid transparent}
.dtab.active{color:var(--brand-text);border-bottom-color:var(--brand)}
.drawer-body{padding:16px 20px;overflow:auto;flex:1}
.chips{display:flex;gap:6px;flex-wrap:wrap}
.histchip{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:5px 13px;font-size:12px;cursor:pointer;color:var(--text-2)}
.histchip.active{background:var(--brand-weak);color:var(--brand-text);border-color:var(--brand)}
.tl-item{border-left:2px solid var(--border);padding:0 0 16px 16px;position:relative;margin-left:5px}
.tl-item:last-child{border-left-color:transparent;padding-bottom:2px}
.tl-item:before{content:'';position:absolute;left:-6px;top:2px;width:10px;height:10px;border-radius:50%;background:var(--brand);border:2px solid var(--surface)}
.tl-when{font-size:11px;color:var(--text-2)}
.tl-tag{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:1px 6px;border-radius:5px;background:var(--surface-3);color:var(--text-2);margin-right:6px}
.tagpick{cursor:pointer;user-select:none}
.tagpick.sel{background:var(--brand-weak);color:var(--brand-text);border-color:var(--brand)}
@media(max-width:560px){.drawer{width:100%}}

/* ---------- settings tabs ---------- */
.stabs{display:flex;gap:4px;flex-wrap:wrap;border-bottom:1px solid var(--border);margin-bottom:16px}
.stab{background:none;border:none;padding:9px 15px;font-size:13px;font-weight:600;color:var(--text-2);cursor:pointer;border-bottom:2px solid transparent;border-radius:8px 8px 0 0}
.stab:hover{background:var(--surface-2)}
.stab.active{color:var(--brand-text);border-bottom-color:var(--brand)}

/* ---------- lead filters slide-over ---------- */
.filter-foot{border-top:1px solid var(--border);padding:14px 20px;display:flex;gap:10px;align-items:center;background:var(--surface)}
.fsec{margin-bottom:16px}
.fsec-h{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--brand-text);border-bottom:1px solid var(--border);padding-bottom:6px;margin-bottom:11px}
.fgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px 16px}
.ffield label{display:block;font-size:11.5px;font-weight:600;color:var(--text-2);margin-bottom:4px}
.ffield input,.ffield select{width:100%;padding:8px 10px}
@media(max-width:560px){.fgrid{grid-template-columns:1fr}}

/* ---------- report builder ---------- */
.rb{display:grid;grid-template-columns:248px 1fr;gap:16px}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{background:var(--surface-2);border:1px solid var(--border-2);border-radius:7px;padding:6px 9px;font-size:12px;cursor:grab;user-select:none;display:inline-flex;align-items:center;gap:6px;color:var(--text)}
.chip:hover{border-color:var(--brand);color:var(--brand-text)}
.chip[data-kind=metric]{background:var(--brand-weak);border-color:transparent;color:var(--brand-text)}
.chip .x{cursor:pointer;opacity:.6;font-weight:700}.chip .x:hover{opacity:1;color:var(--red)}
.zones{display:grid;grid-template-columns:1fr 1fr 1.4fr;gap:10px;margin-bottom:12px}
.zone{background:var(--surface-2);border:1.5px dashed var(--border-2);border-radius:11px;padding:11px;min-height:64px}
.zone.over{border-color:var(--brand);background:var(--brand-weak)}
.z-title{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);margin-bottom:7px;font-weight:600}
.z-body{display:flex;flex-wrap:wrap;gap:6px;min-height:26px}
.rb-controls{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.rb-controls input,.rb-controls select{width:auto;font-size:12.5px}
.saved-item{display:flex;justify-content:space-between;align-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:8px 11px;margin-top:6px;font-size:12.5px;cursor:pointer}
.saved-item:hover{border-color:var(--brand)}.saved-item .x{opacity:.5;cursor:pointer}.saved-item .x:hover{opacity:1;color:var(--red)}
.chart-wrap{position:relative;height:280px}.chart-wrap.sm{height:230px}.chart-wrap.lg{height:320px}
.rb-table table{font-size:12.5px}
.bar-mini{height:7px;border-radius:5px;background:var(--surface-3);overflow:hidden;min-width:80px}
.bar-mini>span{display:block;height:100%;border-radius:5px}
.rank{width:22px;height:22px;border-radius:6px;display:inline-grid;place-items:center;font-weight:800;font-size:11px;background:var(--surface-3);color:var(--text-2)}
.rank.r1{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#3a2606}.rank.r2{background:linear-gradient(135deg,#94a3b8,#cbd5e1);color:#1e293b}.rank.r3{background:linear-gradient(135deg,#b45309,#d97706);color:#fff}
.info{width:14px;height:14px;border-radius:50%;border:1px solid var(--text-3);color:var(--text-3);font-size:9px;display:inline-grid;place-items:center;cursor:help;position:relative;font-weight:700}
.info:hover .tip{opacity:1;transform:translateY(0);pointer-events:auto}
.tip{position:absolute;bottom:140%;left:50%;transform:translateX(-50%) translateY(4px);background:var(--text);color:var(--surface);
  padding:8px 10px;border-radius:8px;font-size:11.5px;font-weight:500;width:210px;opacity:0;pointer-events:none;transition:.16s;z-index:30;box-shadow:var(--shadow-lg);line-height:1.45;text-transform:none;letter-spacing:0}
.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:11.5px;color:var(--text-2);margin-top:10px}
.legend span{display:inline-flex;align-items:center;gap:6px}.dotc{width:9px;height:9px;border-radius:3px;display:inline-block}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.g3{display:grid;grid-template-columns:2fr 1fr;gap:16px}
.soonbox{border:1.5px dashed var(--border-2);border-radius:14px;padding:42px;text-align:center;color:var(--text-2)}
.soonbox h3{font-size:16px;margin-bottom:6px;color:var(--text)}

/* ---------- responsive ---------- */
@media(max-width:1100px){.kpis{grid-template-columns:repeat(2,1fr)}.urgents{grid-template-columns:1fr}.g2,.g3,.rb{grid-template-columns:1fr}.zones{grid-template-columns:1fr}}
/* hamburger — hidden on desktop, shown on mobile */
.navburger{display:none;flex-direction:column;justify-content:center;gap:4px;width:38px;height:38px;border:1px solid var(--border);border-radius:9px;background:var(--surface);cursor:pointer;padding:0 9px;margin-right:4px}
.navburger span{display:block;height:2px;background:var(--text);border-radius:2px}
.side-backdrop{display:none;position:fixed;inset:0;background:rgba(17,24,39,.5);z-index:190}
.side-backdrop.open{display:block}
@media(max-width:820px){
  .app{grid-template-columns:1fr}
  .content{padding:18px 16px}.grid2{grid-template-columns:1fr}.top{padding:0 16px;display:flex;align-items:center;gap:6px}
  .navburger{display:flex}
  /* sidebar becomes an off-canvas drawer instead of disappearing */
  .side{position:fixed;top:0;left:0;bottom:0;width:248px;z-index:200;transform:translateX(-100%);
    transition:transform .22s ease;box-shadow:8px 0 32px rgba(0,0,0,.28)}
  .side.open{transform:none}
}

/* ============================================================
   v2 polish — live sync, toasts, fluidity, skeletons
   (restrained per design-system: fast feedback, no gimmicky motion)
   ============================================================ */

/* live-sync indicator in the header */
.live-ind{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-2);
  padding:5px 10px;border:1px solid var(--border);border-radius:999px;user-select:none}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--green-text);box-shadow:0 0 0 0 rgba(16,185,129,.5)}
.live-dot.pulse{animation:livepulse .9s ease-out}
@keyframes livepulse{0%{box-shadow:0 0 0 0 rgba(16,185,129,.55)}100%{box-shadow:0 0 0 7px rgba(16,185,129,0)}}

/* toasts */
.toast-host{position:fixed;right:18px;bottom:18px;z-index:9999;display:flex;flex-direction:column;gap:10px;max-width:380px}
.toast{display:flex;align-items:flex-start;gap:10px;background:var(--surface);border:1px solid var(--border);
  border-left:3px solid var(--text-2);border-radius:12px;padding:12px 14px;box-shadow:0 14px 40px rgba(0,0,0,.16);
  font-size:13.5px;color:var(--text);opacity:0;transform:translateY(8px) scale(.98);transition:opacity .22s ease,transform .22s ease}
.toast.in{opacity:1;transform:none}
.toast .toast-i{flex:none;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:800;color:#fff;background:var(--text-2);margin-top:1px}
.toast-m{line-height:1.45;padding-top:1px}
.toast-success{border-left-color:var(--green-text)} .toast-success .toast-i{background:var(--green-text)}
.toast-error{border-left-color:var(--red-text)} .toast-error .toast-i{background:var(--red-text)}
.toast-warn{border-left-color:var(--amber-text)} .toast-warn .toast-i{background:var(--amber-text)}
.toast-info{border-left-color:var(--brand)} .toast-info .toast-i{background:var(--brand)}

/* skeleton shimmer (use class="skel" on placeholder blocks) */
.skel{position:relative;overflow:hidden;background:var(--surface-2);border-radius:8px;min-height:14px}
.skel::after{content:"";position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(125,125,125,.12),transparent);animation:shimmer 1.2s infinite}
@keyframes shimmer{100%{transform:translateX(100%)}}

/* ---- fluidity: fast, subtle micro-interactions everywhere ---- */
.btn,.lt-chip,.fchip,.pill,.subnav-item,.nav,.kpi,.seg .segbtn,.tab,.chip{transition:background-color .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease}
.btn:active{transform:translateY(.5px)}                 /* tactile press, not a bounce */
.btn:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--brand);outline-offset:1px}
/* data rows: background change only (no movement — per design guidance) */
table tbody tr{transition:background-color .12s ease}
.leadrow{cursor:pointer}
/* KPI / clickable total chips — gentle lift is OK on cards, not on table rows */
.lt-chip{cursor:pointer}
.lt-chip:hover{border-color:var(--brand);background:var(--brand-weak)}
.kpi{transition:box-shadow .16s ease,border-color .16s ease}
.kpi:hover{box-shadow:0 4px 16px rgba(0,0,0,.06)}
/* freshly re-rendered panels fade in so auto-refresh feels alive, not flickery */
.view.active .panel,.view.active .kpis{animation:fadein .25s ease both}
@keyframes fadein{from{opacity:.55}to{opacity:1}}
/* respect users who prefer no motion */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* ---- Import Data view ---- */
.imp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:8px}
.imp-card{border:1px solid var(--border);border-radius:12px;padding:16px;background:var(--surface-2)}
.imp-h{font-weight:700;font-size:14.5px;margin-bottom:4px}
.imp-d{font-size:12.5px;color:var(--text-2);margin-bottom:12px;line-height:1.5}
.imp-card input[type=file]{font-size:12.5px;width:100%}
.imp-note{font-size:11.5px;color:var(--text-3);margin-top:8px;line-height:1.5}
.imp-note code{background:var(--surface-3);padding:1px 5px;border-radius:5px;font-size:11px}
.imp-out{margin-top:12px}
.imp-prog{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-2);padding:8px 0}
.spin{width:14px;height:14px;border:2px solid var(--border-2);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.imp-metrics{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:12px}
.imp-m{display:flex;flex-direction:column;align-items:center;min-width:58px}
.imp-mv{font-size:20px;font-weight:750;letter-spacing:-.02em}
.imp-ml{font-size:10.5px;color:var(--text-2);text-transform:uppercase;letter-spacing:.03em}
.imp-sample{overflow:auto;border:1px solid var(--border);border-radius:8px;margin-bottom:12px;max-height:200px}
.imp-sample table{width:100%;font-size:11.5px;border-collapse:collapse}
.imp-sample th{text-align:left;padding:6px 8px;background:var(--surface-3);position:sticky;top:0;font-weight:600;white-space:nowrap}
.imp-sample td{padding:5px 8px;border-top:1px solid var(--border);white-space:nowrap;max-width:160px;overflow:hidden;text-overflow:ellipsis}
.imp-wipe{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-2);margin-bottom:12px;cursor:pointer}
.imp-actions{display:flex;align-items:center;gap:10px}
.imp-warn{background:var(--amber-bg);color:var(--amber-text);border-radius:8px;padding:10px 12px;font-size:12.5px;line-height:1.5}
.imp-done{background:var(--green-bg);color:var(--green-text);border-radius:8px;padding:10px 12px;font-size:13px;font-weight:600}
.imp-hist{width:100%;font-size:12.5px;border-collapse:collapse}
.imp-hist th{text-align:left;padding:7px 10px;border-bottom:2px solid var(--border);font-weight:600;color:var(--text-2)}
.imp-hist td{padding:7px 10px;border-bottom:1px solid var(--border)}

/* ---- Appointments walk-in modal ---- */
.appt-ov{position:fixed;inset:0;background:rgba(10,15,25,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.appt-ov.hidden{display:none}
.appt-box{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);max-height:90vh;overflow:auto}
.appt-box .ffield{margin-bottom:10px}
.appt-box .ffield label{display:block;font-size:12px;color:var(--text-2);margin-bottom:4px}

/* ---- account menu (top-bar avatar) ---- */
.acct-wrap{position:relative}
.acct-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:200;background:var(--surface);border:1px solid var(--border);
  border-radius:12px;box-shadow:0 12px 32px rgba(0,0,0,.18);min-width:200px;padding:6px;overflow:hidden}
.acct-h{font-size:12px;color:var(--text-2);padding:8px 10px 6px;border-bottom:1px solid var(--border);margin-bottom:4px;font-weight:600}
.acct-item{display:block;padding:9px 10px;border-radius:8px;font-size:13px;cursor:pointer;color:var(--text);text-decoration:none}
.acct-item:hover{background:var(--surface-2)}
/* inline row edit affordance (edit pencil next to the delete ✕) */
.rowact{cursor:pointer;color:var(--text-2);padding:0 4px;font-size:13px;user-select:none}
.rowact:hover{color:var(--brand-text)}

/* ===== Notifications (bell + panel) ===== */
.notif-wrap{position:relative;display:inline-flex}
.notif-bell{position:relative;background:transparent;border:none;color:var(--text-2);cursor:pointer;padding:6px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center}
.notif-bell:hover{background:var(--surface-2);color:var(--text)}
.notif-badge{position:absolute;top:-1px;right:-1px;min-width:16px;height:16px;padding:0 4px;border-radius:9px;background:var(--red-text,#dc2626);color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center;box-shadow:0 0 0 2px var(--surface)}
.notif-panel{position:absolute;top:40px;right:0;width:360px;max-width:92vw;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 16px 44px rgba(0,0,0,.18);z-index:60;overflow:hidden}
.notif-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border)}
.notif-allread{font-size:12px;color:var(--brand-text);cursor:pointer}
.notif-allread:hover{text-decoration:underline}
.notif-list{max-height:420px;overflow:auto}
.notif-item{display:flex;gap:10px;align-items:flex-start;padding:11px 14px;border-bottom:1px solid var(--border);cursor:pointer;position:relative}
.notif-item:hover{background:var(--surface-2)}
.notif-item.unread{background:var(--brand-weak)}
.notif-item.unread:hover{background:var(--brand-weak)}
.notif-ic{font-size:16px;line-height:1.3;flex:0 0 auto}
.notif-main{min-width:0;flex:1}
.notif-title{font-size:13px;font-weight:600;color:var(--text)}
.notif-body{font-size:12px;color:var(--text-2);margin-top:1px}
.notif-meta{font-size:11px;color:var(--text-3,var(--text-2));margin-top:3px}
.notif-x{color:var(--text-3,var(--text-2));font-size:16px;line-height:1;padding:0 2px;opacity:.5}
.notif-x:hover{opacity:1;color:var(--red-text)}
/* notification preferences table */
.np-table{width:100%;border-collapse:collapse}
.np-table th,.np-table td{padding:9px 10px;border-bottom:1px solid var(--border);text-align:left;font-size:13px}
.np-table th{font-size:11.5px;text-transform:uppercase;letter-spacing:.03em;color:var(--text-2)}
.np-table input[type=checkbox]{width:auto}
