/* ===========================================================================
   DealerRev — design system v2
   Inspired by Salesforce Lightning (Path, Highlights, structured density),
   HubSpot Canvas (whitespace, clean type), Outreach (task-first clarity).
   =========================================================================== */
:root{
  --bg:#f4f6fa; --panel:#ffffff; --panel-2:#f7f9fc; --panel-3:#eef2f8;
  --ink:#16201b; --ink-2:#384a40; --muted:#647568; --faint:#94a59a;
  --line:#e5eae6; --line-2:#d8e0da;
  --brand:#3b5bdb; --brand-d:#2f49b0; --brand-700:#25398c; --brand-soft:#e9edfb; --brand-soft-2:#d4dcf6;
  --rev:#ff5a1f; --rev-soft:#ffe9df;
  --green:#0f9d63; --green-soft:#e6f6ef;
  --red:#e02f51; --red-soft:#fdebef;
  --amber:#e08a00; --amber-soft:#fdf1dc;
  --sky:#0ea5e9; --sky-soft:#e4f4fd;
  --purple:#7c5cff; --purple-soft:#efeaff;
  --shadow-xs:0 1px 2px rgba(24,29,42,.05);
  --shadow:0 1px 2px rgba(24,29,42,.05),0 6px 18px -10px rgba(24,29,42,.14);
  --shadow-lg:0 24px 60px -22px rgba(24,29,42,.34);
  --r-sm:8px; --r:12px; --r-lg:16px;
  --font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
[data-theme="dark"]{
  --bg:#0b0f19; --panel:#121826; --panel-2:#0e1421; --panel-3:#1a2333;
  --ink:#e7f0ea; --ink-2:#bccabf; --muted:#90a497; --faint:#5d7066;
  --line:#1d2a23; --line-2:#26352c;
  --brand:#7088f2; --brand-d:#90a2f6; --brand-700:#aab8f9; --brand-soft:#161f3d; --brand-soft-2:#1d2950;
  --rev:#ff7a45; --rev-soft:#2a1409;
  --green-soft:#0f261c; --red-soft:#2b1320; --amber-soft:#2a1f0c; --sky-soft:#0d2436; --purple-soft:#1d1838;
  --shadow-xs:0 1px 2px rgba(0,0,0,.4);
  --shadow:0 1px 2px rgba(0,0,0,.4),0 10px 28px -16px rgba(0,0,0,.7);
  --shadow-lg:0 30px 80px -22px rgba(0,0,0,.82);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:var(--font);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;
  font-size:13.5px;line-height:1.5;letter-spacing:-.005em;transition:background .2s,color .2s}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.018em;color:var(--ink)}
button{font-family:inherit}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:rgba(120,134,158,.32);border-radius:8px;border:3px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:rgba(120,134,158,.5);background-clip:content-box}

#app{display:grid;grid-template-columns:230px 1fr;min-height:100vh}

/* scroll lock when an overlay (drawer / modal / mobile nav) is open */
body.locked{position:fixed;left:0;right:0;width:100%;overflow:hidden}
.dbody,.modal,.kcards,.drawer{overscroll-behavior:contain}

/* ---------- Sidebar ---------- */
.sidebar{background:#0c1322;color:#b9c4d6;display:flex;flex-direction:column;padding:16px 12px;
  position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:11px;padding:8px 8px 20px}
.brand-mark{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;overflow:hidden;
  background:linear-gradient(140deg,#3b5bdb,#1b2a6b);color:#fff}
.brand-mark svg{width:30px;height:30px}
.brand .brand-mark{background:none;border-radius:0;width:46px;height:46px;overflow:visible}
.brand .brand-mark svg{width:46px;height:46px}
.db-badge::before{background:#3b5bdb !important}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text strong{color:#fff;font-size:21px;font-weight:600;letter-spacing:.2px}
.brand-text span{color:#ff5470}
.nav{display:flex;flex-direction:column;gap:1px;margin-top:2px;overflow:auto}
.nav a{display:flex;align-items:center;gap:11px;padding:8.5px 11px;border-radius:9px;color:#9aa7bd;
  font-weight:500;font-size:13px;transition:.13s}
.nav a .ic{width:18px;text-align:center;opacity:.8;font-size:14px}
.nav a:hover{background:#15203a;color:#e7edf6}
.nav a.active{background:rgba(59,91,219,.20);color:#fff;box-shadow:inset 2px 0 0 var(--brand)}
.sidebar-foot{margin-top:auto;padding:10px 6px 2px;display:flex;flex-direction:column;gap:8px}
.theme-toggle{display:flex;align-items:center;gap:8px;justify-content:center;background:#11192b;border:1px solid #1f2b44;
  color:#9aa9c2;padding:8px;border-radius:9px;cursor:pointer;font-size:12px;font-weight:500;transition:.13s}
.theme-toggle:hover{background:#17223a;color:#dde6f2}
.db-badge{font-size:10.5px;color:#67768f;background:#11192b;border:1px solid #1f2b44;padding:7px 10px;border-radius:8px;display:flex;align-items:center;gap:7px}
.db-badge::before{content:"";width:7px;height:7px;border-radius:50%;background:#0e9f6e;box-shadow:0 0 0 3px rgba(14,159,110,.22)}

/* ---------- Topbar ---------- */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 26px 12px;flex-wrap:wrap}
.topbar-title{display:flex;align-items:center;gap:12px;min-width:0}
.topbar h1{font-size:21px;font-weight:650}
.sub{margin:2px 0 0;color:var(--muted);font-size:12.5px}
.topbar-right{display:flex;align-items:center;gap:10px}
.menu-btn{display:none;border:1px solid var(--line-2);background:var(--panel);color:var(--ink);width:40px;height:40px;
  border-radius:10px;font-size:18px;cursor:pointer;flex:0 0 auto}
.nl-mini{display:none}
.nav-scrim{position:fixed;inset:0;background:rgba(10,15,26,.46);opacity:0;visibility:hidden;transition:.2s;z-index:55}
.nav-scrim.show{opacity:1;visibility:visible}
.search-wrap{position:relative}
.search-wrap input{width:330px;max-width:40vw;padding:9px 14px 9px 36px;border:1px solid var(--line-2);background:var(--panel);
  color:var(--ink);border-radius:10px;font-size:13px;outline:none;transition:.14s;box-shadow:var(--shadow-xs)}
.search-wrap::before{content:"⌕";position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--faint);font-size:16px}
.search-wrap input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}

.view{padding:12px 26px 44px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-xs);overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 18px;border-bottom:1px solid var(--line)}
.panel-head h3{font-size:13.5px;font-weight:600}
.muted{color:var(--muted)}.faint{color:var(--faint)}
.row-empty{padding:48px;text-align:center;color:var(--faint)}
.skeleton{padding:36px;color:var(--faint)}
.grid2{display:grid;grid-template-columns:1.45fr 1fr;gap:16px}
.grid2e{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:12px}
.fc-proj{display:flex;gap:14px;margin-top:8px}
.fc-proj>div{flex:1}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:1120px){.grid2,.grid2e,.grid-3{grid-template-columns:1fr}.grid4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid4{grid-template-columns:1fr}}

/* ---------- KPI cards ---------- */
.statbar{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:13px;margin-bottom:18px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:15px 18px;box-shadow:var(--shadow-xs);min-height:82px;display:flex;flex-direction:column;justify-content:center}
.stat.click{cursor:pointer;transition:.13s}.stat.click:hover{border-color:var(--brand);box-shadow:var(--shadow)}
.stat .k{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.045em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stat .v{font-size:28px;font-weight:700;letter-spacing:-.022em;margin-top:6px;color:var(--ink);line-height:1.06;font-variant-numeric:tabular-nums lining-nums}
.stat .v small{font-size:14px;color:var(--faint);font-weight:600;margin-left:1px}
.stat.accent .v{color:var(--brand)}.stat.green .v{color:var(--green)}.stat.red .v{color:var(--red)}.stat.amber .v{color:var(--amber)}
/* KPI tiles: even fixed grid so rows are straight & evenly spaced (matches mobile) */
.kpibar{display:grid;grid-template-columns:repeat(6,1fr);gap:13px;margin-bottom:18px}
@media(max-width:1280px){.kpibar{grid-template-columns:repeat(4,1fr)}}
@media(max-width:760px){.kpibar{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.kpibar{grid-template-columns:repeat(2,1fr);gap:10px}}
/* Lead sources by rep widget */
.sbr{display:flex;flex-direction:column;gap:13px;padding:4px 0 8px}
.sbr-rep{padding:0}
.sbr-h{font-size:12.5px;font-weight:700;color:var(--ink);padding:0 16px 5px;letter-spacing:-.01em}
.sbr table{width:100%}


/* ---------- Pills ---------- */
.pill{display:inline-flex;align-items:center;gap:5px;padding:2.5px 9px;border-radius:999px;font-size:11px;font-weight:600;white-space:nowrap;letter-spacing:.005em}
.pill.green{background:var(--green-soft);color:#0a7d56}.pill.red{background:var(--red-soft);color:#c11f43}
.pill.amber{background:var(--amber-soft);color:#aa6800}.pill.sky{background:var(--sky-soft);color:#0379ab}
.pill.brand{background:var(--brand-soft);color:var(--brand-d)}.pill.gray{background:var(--panel-3);color:var(--muted)}
.pill.purple{background:var(--purple-soft);color:#5b3fd6}
[data-theme="dark"] .pill.green{color:#54d49d}[data-theme="dark"] .pill.red{color:#f88aa3}
[data-theme="dark"] .pill.amber{color:#f0bf72}[data-theme="dark"] .pill.sky{color:#6cc6f2}[data-theme="dark"] .pill.purple{color:#b9a4f8}

/* ---------- Tables ---------- */
table.grid{width:100%;border-collapse:collapse}
table.grid th{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--faint);text-align:left;
  padding:10px 18px;border-bottom:1px solid var(--line);font-weight:600;background:var(--panel-2);position:sticky;top:0}
table.grid td{padding:11px 18px;border-bottom:1px solid var(--line);vertical-align:middle}
table.grid tbody tr{cursor:pointer;transition:.1s}
table.grid tbody tr:hover{background:var(--brand-soft)}
table.grid tr:last-child td{border-bottom:0}
.cust strong{font-size:13.5px;font-weight:550}.cust .sub2{color:var(--faint);font-size:11.5px;margin-top:1px}
.tnum{font-variant-numeric:tabular-nums}
/* horizontally scrollable wide table (inventory) */
.invscroll{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;width:100%;max-width:100%}
.invscroll .invtable{min-width:1040px}
.invscroll .invtable th,.invscroll .invtable td{white-space:nowrap}
.invscroll .invtable th{position:static}
.invhint{display:none;font-size:11px;color:var(--faint);padding:6px 18px 0}
@media(max-width:900px){ .invhint{display:block} }

/* ---------- Bars / charts ---------- */
.barlist{display:flex;flex-direction:column;gap:12px;padding:16px 18px}
.barrow{display:grid;grid-template-columns:128px 1fr 56px;gap:12px;align-items:center;font-size:12.5px}
.barrow .lbl{color:var(--muted);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bartrack{height:8px;background:var(--panel-3);border-radius:999px;overflow:hidden}
.bartrack>i{display:block;height:100%;border-radius:999px;background:var(--brand)}
.bartrack.g>i{background:var(--green)}
.barrow .val{text-align:right;font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink-2)}
.funnel{display:flex;flex-direction:column;gap:7px;padding:16px 18px}
.fstage{display:grid;grid-template-columns:118px 1fr 36px;gap:12px;align-items:center;font-size:12.5px}
.fstage .fn{color:var(--muted);font-weight:500}
.fbar{height:22px;border-radius:6px;background:var(--brand);min-width:6px;display:flex;align-items:center;justify-content:flex-end;color:#fff;font-size:11px;font-weight:600;padding-right:7px}
.fnum{font-weight:600;text-align:right;color:var(--ink-2)}
.loadbars{display:flex;gap:8px;align-items:flex-end;padding:18px;height:130px}
.loadbars .lb{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;justify-content:flex-end;height:100%}
.loadbars .lb .bar{width:100%;border-radius:6px 6px 0 0;background:var(--brand);min-height:4px}
.loadbars .lb .d{font-size:10px;color:var(--faint);font-weight:500}
.loadbars .lb .c{font-size:11px;font-weight:600;color:var(--ink-2)}

/* ---------- Rhythm (rapid-fire) ---------- */
.rhythm{max-width:560px;margin:0 auto}
.rhythm-prog{margin-bottom:14px}
.rp-bar{height:7px;background:var(--panel-3);border-radius:999px;overflow:hidden}
.rp-bar>i{display:block;height:100%;background:var(--brand);border-radius:999px;transition:width .25s}
.rp-txt{margin-top:8px;font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:7px}
.rcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:18px}
.rc-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.rc-name{font-size:21px;font-weight:650}
.rc-sub{color:var(--muted);font-size:13px;margin-top:3px}
.rc-last{background:var(--sky-soft);border-radius:11px;padding:11px 13px;margin-top:14px;font-size:13px;color:var(--ink)}
.rc-tag{display:block;font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;font-weight:700;color:#0379ab;margin-bottom:4px}
.rc-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:7px}
.rc-suggest{margin-top:16px}
#r-text,#camp-text{width:100%;box-sizing:border-box;border:1px solid var(--line-2);border-radius:12px;padding:13px 14px;font-family:inherit;font-size:15px;line-height:1.45;
  min-height:84px;resize:vertical;outline:none;background:var(--brand-soft);color:var(--ink)}
#camp-text{min-height:180px}
#cb-msg{min-height:130px;resize:vertical}
#r-text:focus,#camp-text:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.rc-actions{margin-top:13px;display:flex;flex-direction:column;gap:9px}
.bigbtn{display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line-2);background:var(--panel);
  color:var(--ink);border-radius:12px;padding:14px;font-size:15px;font-weight:600;cursor:pointer;text-decoration:none;min-height:50px}
.bigbtn.text{background:var(--brand);border-color:var(--brand);color:#fff}
.bigbtn.text:hover{background:var(--brand-d)}
.rc-row2{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.bigbtn.call{background:var(--green-soft);color:#0a7d56;border-color:transparent}
.bigbtn.email{background:var(--sky-soft);color:#0379ab;border-color:transparent}
.bigbtn.off{opacity:.4;pointer-events:none}
.rc-note{width:100%;border:1px solid var(--line-2);border-radius:11px;padding:11px 13px;font-family:inherit;font-size:14px;
  min-height:52px;resize:vertical;outline:none;background:var(--panel);color:var(--ink)}
.rc-note:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.disps{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.disp{border:1px solid var(--line-2);background:var(--panel);color:var(--ink);border-radius:11px;padding:13px 8px;font-size:13px;font-weight:600;cursor:pointer;min-height:46px;transition:.1s}
.disp:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}
.disp.danger:hover{border-color:var(--red);color:var(--red);background:var(--red-soft)}
.disps.oneway{grid-template-columns:repeat(4,1fr)}
@media(max-width:600px){.disps.oneway{grid-template-columns:1fr 1fr}}
.disps.twoway{margin-top:6px}
.disp.green{border-color:color-mix(in srgb,var(--brand) 35%,var(--line-2))}
.disp.green:hover{border-color:var(--brand);color:#fff;background:var(--brand)}
.rc-foot{margin-top:14px;display:flex;gap:10px;justify-content:center}
/* interactive temperature toggle in Rhythm */
.rtemp{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.rtbtn{border:1px solid var(--line-2);background:var(--panel);color:var(--muted);border-radius:999px;padding:6px 12px;font-size:12.5px;font-weight:700;cursor:pointer;transition:.1s}
.rtbtn:hover{border-color:var(--brand)}
.rtbtn.hot.on{background:var(--red-soft);color:#c11f43;border-color:#e7a1b1}
.rtbtn.warm.on{background:var(--amber-soft);color:#aa6800;border-color:#e9c88a}
.rtbtn.cold.on{background:var(--sky-soft);color:#0379ab;border-color:#9fd2ea}
.rtbtn.dead.on{background:var(--panel-3);color:var(--muted);border-color:var(--line-2);text-decoration:line-through}
.rc-steps .rstep{cursor:pointer}
.rc-steps .rstep:hover{background:var(--brand-soft);color:var(--brand-d)}
/* next follow-up chip */
.rc-next{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap}
.rc-nextpick{border:1px dashed var(--line-2);background:var(--panel);border-radius:10px;padding:8px 12px;font-size:13px;color:var(--ink);cursor:pointer;display:inline-flex;gap:6px;align-items:center}
.rc-nextpick:hover{border-color:var(--brand);background:var(--brand-soft)}
.rc-nextpick .muted{font-weight:500}
/* reschedule calendar */
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.cal-title{font-weight:700;font-size:14px}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}
.cal-dow span{text-align:center;font-size:11px;font-weight:700;color:var(--muted)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-cell{position:relative;aspect-ratio:1/1;border:1px solid var(--line);border-radius:8px;background:var(--panel);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.cal-cell.empty{border:0;background:transparent;cursor:default}
.cal-cell .cd{font-size:13px;font-weight:600;color:var(--ink)}
.cal-cell .cn{position:absolute;top:3px;right:4px;font-size:9px;font-weight:700;color:#fff;background:var(--muted);border-radius:999px;min-width:14px;height:14px;display:grid;place-items:center;padding:0 3px}
.cal-cell.mid .cn{background:#e0a23a}
.cal-cell.busy .cn{background:#e0573a}
.cal-cell.busy{background:var(--red-soft)}
.cal-cell.sug{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-soft) inset}
.cal-cell.sel{background:var(--brand)}
.cal-cell.sel .cd{color:#fff}
.cal-cell.past{opacity:.35;cursor:default}
.cal-cell:not(.empty):not(.past):hover{border-color:var(--brand)}
.cal-legend{display:flex;gap:14px;margin-top:10px;font-size:11px;color:var(--muted)}
.cl{display:inline-flex;align-items:center;gap:5px}
.cl::before{content:"";width:11px;height:11px;border-radius:3px;display:inline-block}
.cl.sug::before{border:2px solid var(--brand)}
.cl.mid::before{background:#e0a23a}
.cl.busy::before{background:#e0573a}
.dash-regrade{border:1px solid var(--line);background:var(--panel);color:var(--brand-d);border-radius:8px;padding:4px 10px;font-size:11.5px;font-weight:600;cursor:pointer}
.dash-regrade:hover{border-color:var(--brand);background:var(--brand-soft)}
.rhythm-done{max-width:480px;margin:40px auto;text-align:center;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:48px 24px;box-shadow:var(--shadow-xs)}
.rhythm-done .big{font-size:46px;margin-bottom:8px}
.rhythm-done h2{font-size:20px}

/* ---------- Feed ---------- */
.feed{display:flex;flex-direction:column}
.feedrow{display:grid;grid-template-columns:36px 1fr auto;gap:13px;padding:12px 18px;border-bottom:1px solid var(--line);cursor:pointer;transition:.1s}
.feedrow:last-child{border-bottom:0}.feedrow:hover{background:var(--panel-2)}
.feedrow .ico{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;font-size:14px;background:var(--brand-soft);color:var(--brand-d)}
.feedrow.text_message .ico,.feedrow.text_out .ico,.feedrow.text_in .ico{background:var(--sky-soft);color:#0379ab}
.feedrow.note .ico,.feedrow.step_log .ico{background:var(--amber-soft);color:#aa6800}
.feedrow.closed_lead .ico,.feedrow.status_change .ico{background:var(--red-soft);color:#c11f43}
.feedrow .ttl{font-weight:550;font-size:13px}
.feedrow .bd{color:var(--muted);font-size:12px;margin-top:2px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}
.feedrow .when{color:var(--faint);font-size:11px;white-space:nowrap;text-align:right}

/* ---------- Chips ---------- */
.filters{display:flex;gap:7px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.chip{padding:7px 13px;border:1px solid var(--line-2);background:var(--panel);border-radius:999px;font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;transition:.12s;display:inline-flex;gap:7px;align-items:center}
.chip:hover{border-color:var(--brand);color:var(--brand)}
.chip.on{background:var(--brand);border-color:var(--brand);color:#fff}
.chip .badge{background:rgba(0,0,0,.1);border-radius:999px;padding:0 7px;font-size:10.5px;font-weight:700}
.chip.on .badge{background:rgba(255,255,255,.26)}

/* ---------- Kanban ---------- */
.kanban{display:flex;gap:13px;overflow-x:auto;padding-bottom:10px}
.kcol{flex:0 0 252px;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r);display:flex;flex-direction:column;max-height:75vh}
.kcol.drop{outline:2px dashed var(--brand);outline-offset:-3px;background:var(--brand-soft)}
.kcol-head{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border-bottom:1px solid var(--line)}
.kcol-head .nm{font-weight:600;font-size:12.5px}
.kcol-head .n{font-size:11px;font-weight:600;color:var(--muted);background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:1px 8px}
.kcards{padding:9px;display:flex;flex-direction:column;gap:8px;overflow:auto}
.kcard{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:11px 12px;cursor:grab;box-shadow:var(--shadow-xs);transition:.1s}
.kcard:hover{border-color:var(--brand);box-shadow:var(--shadow)}
.kcard:active{cursor:grabbing}.kcard.drag{opacity:.45}
.kcard .nm{font-weight:550;font-size:12.5px}
.kcard .veh{color:var(--muted);font-size:11.5px;margin-top:3px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}
.kcard .ft{display:flex;align-items:center;justify-content:space-between;margin-top:9px}
.kmore{padding:8px;text-align:center;color:var(--faint);font-size:11.5px}

/* ---------- Calendar ---------- */
.cal{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-xs);overflow:hidden}
.cal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}
.cal-head h3{font-size:14.5px}
.cal-nav{display:flex;gap:6px}
.cal-nav button{border:1px solid var(--line-2);background:var(--panel);height:32px;min-width:32px;padding:0 10px;border-radius:8px;cursor:pointer;color:var(--muted);font-size:13px;font-weight:500}
.cal-nav button:hover{border-color:var(--brand);color:var(--brand)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-grid .dow{padding:9px;text-align:center;font-size:10.5px;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--line)}
.cell{min-height:96px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:7px 8px;position:relative}
.cell:nth-child(7n){border-right:0}
.cell.out{background:var(--panel-2)}
.cell.today{box-shadow:inset 0 0 0 2px var(--brand)}
.cell .dn{font-size:11.5px;font-weight:550;color:var(--muted)}
.cell.today .dn{color:var(--brand)}
.cell .tag{margin-top:6px;display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:#fff;background:var(--brand);border-radius:7px;padding:3px 8px;cursor:pointer}
.cell .tag.hot{background:var(--red)}

/* ---------- Drawer ---------- */
.scrim,.modal-scrim{position:fixed;inset:0;background:rgba(10,15,26,.46);opacity:0;visibility:hidden;transition:.2s;z-index:40;backdrop-filter:blur(2px)}
.scrim.show,.modal-scrim.show{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100vh;width:min(600px,96vw);background:var(--panel);box-shadow:var(--shadow-lg);
  transform:translateX(102%);transition:transform .26s cubic-bezier(.4,0,.2,1);z-index:50;display:flex;flex-direction:column;overflow:hidden}
.drawer.show{transform:translateX(0)}
.dhead{padding:18px 22px 0;border-bottom:1px solid var(--line);background:var(--panel-2)}
.dhead .top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.dhead h2{font-size:19px;font-weight:600}
.dhead .ref{color:var(--faint);font-size:12px;font-weight:500;margin-top:3px;display:flex;gap:7px;align-items:center;flex-wrap:wrap}
.xbtn{border:1px solid var(--line-2);background:var(--panel);width:33px;height:33px;border-radius:8px;cursor:pointer;font-size:16px;color:var(--muted)}
.xbtn:hover{background:var(--panel-3);color:var(--ink)}

/* Salesforce-style Path (stage chevrons) */
.path{display:flex;gap:4px;margin:16px 0 6px;overflow-x:auto;padding:2px 0 7px}
.pstep{flex:0 0 auto;position:relative;height:40px;background:var(--panel-3);color:var(--muted);
  display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;cursor:pointer;transition:.13s;white-space:nowrap;
  clip-path:polygon(0 0,calc(100% - 12px) 0,100% 50%,calc(100% - 12px) 100%,0 100%,12px 50%);padding:0 16px 0 22px}
.path .pstep:first-child{clip-path:polygon(0 0,calc(100% - 12px) 0,100% 50%,calc(100% - 12px) 100%,0 100%);padding-left:15px}
.pstep:hover{background:var(--brand-soft-2);color:var(--brand-d)}
.pstep.done{background:var(--brand-soft-2);color:var(--brand-d)}
.pstep.current{background:var(--brand);color:#fff;box-shadow:0 2px 9px -3px var(--brand)}
.pstep.current .pn{background:rgba(255,255,255,.28);color:#fff}
.pstep.done .pn{background:rgba(0,0,0,.06)}
.pstep .pn{display:inline-grid;place-items:center;width:19px;height:19px;border-radius:50%;background:rgba(0,0,0,.07);font-size:10.5px;font-weight:800;opacity:1;margin:0;flex:0 0 auto}

/* Highlights panel */
.highlights{display:flex;flex-wrap:wrap;gap:0;margin:12px 0 14px;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--panel)}
.hl{flex:1 1 33%;min-width:132px;padding:11px 15px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.hl .l{font-size:10px;color:var(--faint);text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.hl .v{font-size:13.5px;margin-top:4px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hl .v a{color:var(--brand)}

.dactions{display:flex;gap:7px;flex-wrap:wrap;padding:14px 22px}
.btn{border:1px solid var(--line-2);background:var(--panel);color:var(--ink);padding:8.5px 13px;border-radius:9px;font-size:12.5px;font-weight:550;cursor:pointer;transition:.12s;display:inline-flex;align-items:center;gap:6px}
.btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}
.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}.btn.primary:hover{background:var(--brand-d);color:#fff}
.btn.green{background:var(--green);border-color:var(--green);color:#fff}.btn.green:hover{filter:brightness(.96);color:#fff}
.btn.ghostred:hover{border-color:var(--red);color:var(--red);background:var(--red-soft)}
.btn.deal{background:linear-gradient(135deg,#12b886,#0e7490);border:0;color:#fff;font-weight:600;box-shadow:0 4px 12px -5px rgba(14,116,144,.6)}
.btn.deal:hover{filter:brightness(1.05);color:#fff}
.tabs{display:flex;gap:2px;padding:0 18px;border-bottom:1px solid var(--line);background:var(--panel-2)}
.tabs button{border:0;background:none;padding:11px 12px;font-size:12.5px;font-weight:550;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.tabs button:hover{color:var(--ink)}
.tabs button.on{color:var(--brand);border-bottom-color:var(--brand)}
.dhead{flex-shrink:0}
#drawer-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}
.dbody{flex:1;min-height:0;overflow:auto;padding:18px 22px 34px}
.dfacts{display:grid;grid-template-columns:1fr 1fr;gap:11px 18px}
.fact .l{font-size:10.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.fact .v{font-size:13px;margin-top:2px;font-weight:500}.fact .v a{color:var(--brand)}

.tl{position:relative;margin:4px 0 0;padding-left:21px}
.tl::before{content:"";position:absolute;left:5px;top:6px;bottom:6px;width:2px;background:var(--line-2)}
.tlitem{position:relative;padding:0 0 16px}
.tlitem::before{content:"";position:absolute;left:-19px;top:3px;width:10px;height:10px;border-radius:50%;background:var(--panel);border:2.5px solid var(--brand)}
.tlitem.text_in::before{border-color:var(--sky)}.tlitem.text_out::before{border-color:var(--green)}
.tlitem.closed_lead::before,.tlitem.status_change::before{border-color:var(--red)}
.tlitem.note::before,.tlitem.step_log::before{border-color:var(--amber)}
.tlitem .meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--faint)}
.tlitem .kindlbl{font-weight:600;color:var(--muted);text-transform:capitalize}
.tlitem .text{margin-top:4px;font-size:13px;white-space:pre-wrap;word-break:break-word}
.tlitem.text_out .text,.tlitem.text_in .text{background:var(--brand-soft);padding:9px 12px;border-radius:10px;display:inline-block;max-width:90%}
.tlitem.text_in .text{background:var(--sky-soft)}

.composer{display:flex;gap:8px;margin-bottom:16px}
.composer textarea{flex:1;border:1px solid var(--line-2);border-radius:10px;padding:10px 12px;font-family:inherit;font-size:13px;
  resize:vertical;min-height:42px;outline:none;background:var(--panel);color:var(--ink)}
.composer textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}

/* ---------- Modal ---------- */
.modal-scrim{display:flex;align-items:center;justify-content:center;padding:20px;z-index:70}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);width:min(520px,96vw);max-height:92vh;overflow:auto;transform:scale(.97);transition:.18s}
.modal-scrim.show .modal{transform:scale(1)}
.modal h3{font-size:16px;padding:18px 22px 0}
.modal .msub{color:var(--muted);font-size:12px;padding:2px 22px 0}
.mbody{padding:16px 22px 8px;display:flex;flex-direction:column;gap:14px}
.field label{display:block;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px}
.field select,.field input,.field textarea{width:100%;border:1px solid var(--line-2);border-radius:9px;padding:10px 12px;font-family:inherit;font-size:13px;background:var(--panel);color:var(--ink);outline:none}
.field select:focus,.field input:focus,.field textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.steps{display:flex;gap:6px;flex-wrap:wrap}
.stepchip{width:34px;height:34px;border-radius:8px;border:1px solid var(--line-2);background:var(--panel);color:var(--muted);font-weight:600;font-size:12.5px;cursor:pointer;transition:.1s}
.stepchip:hover{border-color:var(--brand);color:var(--brand)}
.stepchip.on{background:var(--brand);border-color:var(--brand);color:#fff}
.toggle{display:inline-flex;border:1px solid var(--line-2);border-radius:9px;overflow:hidden}
.toggle button{border:0;background:var(--panel);color:var(--muted);padding:9px 14px;font-size:12.5px;font-weight:550;cursor:pointer}
.toggle button.on{background:var(--brand);color:#fff}
.mfoot{display:flex;justify-content:flex-end;gap:8px;padding:12px 22px 18px;border-top:1px solid var(--line);position:sticky;bottom:0;background:var(--panel)}

/* ---------- Toast / misc ---------- */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:#0c1322;color:#fff;padding:11px 18px;border-radius:10px;font-size:12.5px;font-weight:500;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transition:.2s;z-index:80}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.toast.err{background:#8d1c30}
.pager{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;color:var(--muted);font-size:12px}
.pager button{border:1px solid var(--line-2);background:var(--panel);color:var(--ink);border-radius:8px;padding:7px 12px;cursor:pointer;font-weight:550}
.pager button:disabled{opacity:.4;cursor:default}
.empty-state{text-align:center;padding:64px 20px;color:var(--muted)}
.empty-state .big{font-size:40px;margin-bottom:10px}
.btn.primary[id=new-lead]{box-shadow:var(--shadow-xs)}

/* ===========================================================================
   Responsive / mobile (SalesLoft-clean, touch-friendly)
   =========================================================================== */
@media(max-width:900px){
  #app{grid-template-columns:1fr}
  /* sidebar becomes a slide-in overlay */
  .sidebar{position:fixed;top:0;left:0;height:100dvh;width:262px;z-index:60;
    transform:translateX(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg)}
  .sidebar.open{transform:translateX(0)}
  .menu-btn{display:flex;align-items:center;justify-content:center}

  .topbar{padding:14px 16px 8px;position:sticky;top:0;background:var(--bg);z-index:30}
  .topbar h1{font-size:18px}
  .sub{display:none}
  .topbar-right{flex:1 1 100%;order:3}
  .search-wrap{flex:1}
  .search-wrap input{width:100%;max-width:none}
  #new-lead{padding:0;width:40px;height:40px;justify-content:center;font-size:18px;flex:0 0 auto}
  .nl-full{display:none}.nl-mini{display:inline}

  .view{padding:12px 14px 90px}
  .statbar{grid-template-columns:repeat(2,1fr);gap:10px}
  .stat{min-height:72px;padding:13px 14px}
  .stat .v{font-size:23px}
  .grid2,.grid-3{grid-template-columns:1fr;gap:12px}

  /* tables scroll horizontally inside their panel */
  .view .panel{overflow-x:auto}
  table.grid{min-width:560px}

  /* drawer + modal full screen */
  .drawer{width:100vw}
  .dhead{padding:16px 16px 0}
  .dbody{padding:16px 16px 40px}
  .dactions{padding:12px 16px}
  .highlights .hl{flex-basis:50%}
  .modal-scrim{padding:0;align-items:flex-end}
  .modal{width:100vw;max-height:90dvh;border-radius:18px 18px 0 0}

  /* kanban: one column at a time, swipeable */
  .kcol{flex-basis:82vw;max-height:none}
  .kcards{max-height:64vh}

  /* calendar tighter */
  .cell{min-height:62px;padding:5px 5px}
  .cell .dn{font-size:11px}
  .cell .tag{font-size:9.5px;padding:2px 5px;margin-top:4px}
  .cal-head{padding:12px 14px}

  /* feed / rows breathe a bit less */
  .feedrow{grid-template-columns:32px 1fr auto;gap:10px;padding:12px 14px}
  .barrow{grid-template-columns:96px 1fr 46px}
  .fstage{grid-template-columns:84px 1fr 30px}
}
@media(max-width:420px){
  .statbar{grid-template-columns:1fr 1fr}
  .topbar-right{gap:8px}
  .pstep{font-size:11px;height:36px;padding:0 13px 0 18px}
  .pstep .pn{width:17px;height:17px}
  .cell .tag{font-size:0;padding:5px}
  .cell .tag::after{content:attr(data-n);font-size:10px;font-weight:700}
}

/* AI suggest button + modal hint */
.btn.ai{ background:linear-gradient(135deg,#7c3aed,#4f46e5); color:#fff; border-color:transparent; }
.btn.ai:hover{ filter:brightness(1.07); }
.shint{ margin-top:8px; font-size:12px; }

/* ---------- Settings ---------- */
.settings{display:flex;flex-direction:column;gap:16px;max-width:920px}
.setcard{padding:0}
.seth{padding:15px 18px;border-bottom:1px solid var(--line)}
.seth h3{font-size:15px}
.seth p{margin-top:2px;font-size:12px}
.setgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:16px 18px}
.setgrid .field.span2{grid-column:1 / -1}
.setgrid .field label{display:block;font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.04em;font-weight:600;margin-bottom:5px}
.setgrid input,.setgrid select,.setgrid textarea,.setadd input,.setadd select,.setrow input,.setrow select{
  width:100%;border:1px solid var(--line-2);border-radius:9px;padding:9px 11px;font-family:inherit;font-size:13px;
  background:var(--panel);color:var(--ink);outline:none}
.setgrid input:focus,.setgrid select:focus,.setgrid textarea:focus,.setrow input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.setgrid input[type=color]{padding:4px;height:40px;cursor:pointer}
.sublabel{padding:6px 18px 0;font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.setfoot{padding:0 18px 16px;display:flex;justify-content:flex-end}
.setlist{display:flex;flex-direction:column;gap:8px;padding:14px 18px}
.setrow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.setrow .setname{flex:1;min-width:150px}
.setrow .setcode{max-width:96px;text-transform:uppercase}
.setrow .setrole{max-width:150px}
.setck{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);white-space:nowrap}
.setck input{width:auto}
.muted.small,.setrow .small{font-size:11px}
.btn.small{padding:6px 10px;font-size:12px}
.setadd{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:0 18px 16px;border-top:1px dashed var(--line);padding-top:14px}
.setadd input{flex:1;min-width:140px;max-width:260px}
@media(max-width:720px){ .setgrid{grid-template-columns:1fr} }
/* ---------- Auth screen ---------- */
.authscreen{position:fixed;inset:0;z-index:90;background:
  radial-gradient(1200px 600px at 80% -10%, var(--brand-soft), transparent),
  var(--bg);display:flex;align-items:center;justify-content:center;overflow:auto;padding:24px}
.authwrap{display:flex;flex-direction:column;align-items:center;gap:14px;width:100%}
.authcard{background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);
  width:min(400px,94vw);padding:26px 26px 28px}
.authbrand{display:flex;align-items:center;gap:11px;margin-bottom:18px}
.authbrand .brand-mark{width:40px;height:40px;border-radius:11px}
.authbrand-t{display:flex;flex-direction:column;line-height:1.15}
.authbrand-t strong{font-size:16px}
.authbrand-t span{color:var(--muted);font-size:10.5px;letter-spacing:.07em;text-transform:uppercase}
.autherr{background:var(--red-soft);color:#c11f43;border-radius:10px;padding:9px 12px;font-size:12.5px;margin-bottom:14px}
.authnote{background:var(--brand-soft);color:var(--brand-d);border-radius:10px;padding:9px 12px;font-size:12.5px;margin:0 0 14px}
.authtabs{display:flex;gap:4px;background:var(--panel-3);border-radius:10px;padding:3px;margin-bottom:16px}
.authtabs button{flex:1;border:0;background:transparent;color:var(--muted);font-weight:600;font-size:13px;padding:8px;border-radius:8px;cursor:pointer}
.authtabs button.on{background:var(--panel);color:var(--ink);box-shadow:var(--shadow-xs)}
.authpane.hide{display:none}
.authpane .field{margin-bottom:12px}
.authpane .field label{display:block;font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.04em;font-weight:600;margin-bottom:5px}
.authpane .field input{width:100%;border:1px solid var(--line-2);border-radius:9px;padding:10px 12px;font-family:inherit;font-size:14px;background:var(--panel);color:var(--ink);outline:none}
.authpane .field input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.btn.block{width:100%;justify-content:center;padding:11px;font-size:14px;margin-top:4px}
.authsocial{display:flex;flex-direction:column;gap:9px}
.btn.social{justify-content:center;padding:10px;font-size:13.5px;font-weight:600;border:1px solid var(--line-2);background:var(--panel);color:var(--ink)}
.btn.social:hover{background:var(--panel-2)}
.btn.social.apple{background:#000;color:#fff;border-color:#000}
.btn.social.apple::before{content:"\F8FF Continue with Apple"}
.btn.social .gmark{font-weight:800;color:#4285F4}
.author{display:flex;align-items:center;gap:10px;color:var(--faint);font-size:11px;margin:14px 0}
.author::before,.author::after{content:"";flex:1;height:1px;background:var(--line)}
.authfoot{color:var(--faint);font-size:11px}

/* sidebar user chip */
.user-chip{display:flex;align-items:center;gap:8px;background:#11192b;border:1px solid #1f2b44;border-radius:9px;padding:8px 10px}
.user-chip .uc-id{flex:1;min-width:0}
.user-chip .uc-name{color:#e7edf6;font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-chip .uc-role{color:#74829c;font-size:10.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-chip .uc-logout{background:transparent;border:0;color:#9aa9c2;font-size:16px;cursor:pointer;padding:2px 4px;border-radius:6px}
.user-chip .uc-logout:hover{background:#17223a;color:#fff}

/* respect the hidden attribute over the display:flex/flex classes */
.authscreen[hidden]{display:none}
.user-chip[hidden]{display:none}

/* Rhythm redraft button */
.rc-labelrow{display:flex;align-items:center;justify-content:space-between;gap:8px}
.rc-redraft{background:transparent;border:1px solid var(--line-2);color:var(--muted);border-radius:8px;padding:3px 9px;font-size:11.5px;font-weight:600;cursor:pointer}
.rc-redraft:hover{border-color:var(--brand);color:var(--brand)}
.rc-redraft:disabled{opacity:.5;cursor:default}

/* ---------- Rhythm: full-width two-column desktop layout ---------- */
.rhythm{max-width:1040px;margin:0 auto}
.rcard{display:grid;grid-template-columns:.82fr 1.18fr;gap:24px;align-items:start}
.rc-left,.rc-right{min-width:0}
.rc-meta{display:flex;flex-wrap:wrap;gap:7px;margin-top:13px}
.rc-chip{background:var(--panel-3);color:var(--muted);border-radius:999px;padding:4px 10px;font-size:11.5px;font-weight:600;white-space:nowrap}
/* customer file: link, units, garage, deal cards */
.lockbox{padding:9px 12px;border:1px dashed var(--border);border-radius:9px;color:var(--muted);font-size:12.5px;font-weight:600;background:var(--panel-3)}
/* campaigns */
.camp-top{margin-bottom:14px}
.camp-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.campcard{border:1px solid var(--border);border-radius:12px;padding:14px;background:var(--panel);cursor:pointer;transition:border-color .12s}
.campcard:hover{border-color:var(--brand)}
.cc-h{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px}
.cc-name{font-weight:700;font-size:14px}
.cc-chans{font-size:14px;flex:none}
.cc-bar{height:7px;border-radius:99px;background:var(--panel-3);overflow:hidden}
.cc-bar i{display:block;height:100%;background:var(--brand);border-radius:99px}
.cc-meta{font-size:11.5px;color:var(--muted);margin-top:7px}
.cb-presets{display:flex;flex-wrap:wrap;gap:7px}
.cbpreset{border:1px solid var(--border);background:var(--panel-3);border-radius:99px;padding:5px 11px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}
.cbpreset:hover{border-color:var(--brand);color:var(--brand-d)}
.cb-grouphd{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:12px 16px 2px;border-top:1px solid var(--border);margin-top:4px}
.cbwrap{display:grid;grid-template-columns:1fr 300px;gap:16px;align-items:start}
.cb-main{display:flex;flex-direction:column;gap:14px}
.cb-side{position:sticky;top:12px}
.chbar{display:flex;flex-wrap:wrap;gap:12px}
.chpick{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;cursor:pointer}
.cb-count{font-size:30px;font-weight:800;color:var(--brand-d)}
.cb-count .muted{font-size:13px;font-weight:600}
.cb-sample{margin-top:8px;display:flex;flex-direction:column;gap:2px;max-height:240px;overflow:auto}
.cb-results{margin-top:6px;max-height:170px;overflow:auto;border-radius:8px}
.cb-res{padding:7px 9px;border-radius:7px;cursor:pointer;font-size:13px}
.cb-res:hover{background:var(--panel-3)}
.cb-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.cbchip{display:inline-flex;align-items:center;gap:5px;background:var(--brand-soft);color:var(--brand-d);border-radius:99px;padding:3px 6px 3px 10px;font-size:12px;font-weight:600}
.cbchip button{border:0;background:transparent;color:inherit;cursor:pointer;font-size:12px}
.btn.block{display:block;width:100%}
.cd-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap;margin-bottom:12px}
.cd-title{margin:4px 0 2px;font-size:21px}
.cd-actions{display:flex;gap:8px;flex-wrap:wrap}
.cd-bar{height:9px;border-radius:99px;background:var(--panel-3);overflow:hidden;margin-top:4px}
.cd-bar i{display:block;height:100%;background:var(--brand);border-radius:99px}
.cd-msg{padding:12px 16px;white-space:pre-wrap;line-height:1.5}
#ec-msg{width:100%;box-sizing:border-box;min-height:150px;resize:vertical}
.bigbtn.done{background:var(--brand);color:#fff;border:0}
@media(max-width:820px){.cbwrap{grid-template-columns:1fr}.cb-side{position:static}}
.custlink{color:var(--brand-d);font-weight:600;cursor:pointer}
.custlink:hover{text-decoration:underline}
.unitsblock{margin-bottom:16px}
.unit-head,.cf-h{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.unit-head .u-h{font-weight:700;font-size:13px}
.unitlist,.ownlist{display:flex;flex-direction:column;gap:6px}
.unitrow,.ownrow{display:flex;align-items:center;gap:10px;padding:9px 11px;border:1px solid var(--border);border-radius:10px;background:var(--panel)}
.unitrow.trade{background:var(--panel-3)}
.u-ic,.o-ic{font-size:18px;width:24px;text-align:center;flex:none}
.u-main,.o-main{flex:1;min-width:0}
.u-name,.o-name{font-weight:600;font-size:13.5px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.u-sub,.o-sub{font-size:11.5px;color:var(--muted);margin-top:1px}
.u-tag,.o-tag{font-size:10px;font-weight:700;border-radius:5px;padding:1px 6px;background:var(--brand-soft);color:var(--brand-d)}
.u-tag.trade,.o-tag.traded{background:var(--amber-soft);color:#aa6800}
.o-tag.previous{background:var(--panel-3);color:var(--muted)}
.o-tag.us{background:var(--green-soft);color:#0a7d56}
.u-acts{display:flex;gap:4px;flex:none}
.ubtn{border:1px solid var(--border);background:var(--panel);border-radius:7px;padding:3px 7px;cursor:pointer;font-size:12px}
.ubtn.red{color:#c11f43}.ubtn:hover{background:var(--panel-3)}
.u-divider{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;margin:8px 0 2px}
.cf-sec{margin-bottom:20px}
.cf-tl{max-height:440px;overflow-y:auto;padding-right:4px}
.cinfogrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}
.cinfo{display:flex;flex-direction:column;gap:3px;border:1px solid var(--line);border-radius:10px;padding:9px 12px;background:var(--panel)}
.cinfo .ci-l{font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--muted)}
.cinfo .ci-v{font-size:13.5px;color:var(--ink);word-break:break-word}
.phacts{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}
.phacts .phnum{font-weight:600}
.phbtn{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;line-height:1;padding:5px 9px;border-radius:999px;border:1px solid var(--line);background:var(--panel);color:var(--ink);cursor:pointer;text-decoration:none}
.phbtn.call{color:var(--brand-d);border-color:color-mix(in srgb,var(--brand) 40%,var(--line))}
.phbtn.text{color:#1f7ae0;border-color:color-mix(in srgb,#1f7ae0 35%,var(--line))}
.phbtn:hover{filter:brightness(.97)}
.nsec{border:1px solid var(--border);border-radius:10px;padding:6px 12px;margin-top:4px}
.nsec>summary{cursor:pointer;font-weight:600;font-size:13px;padding:4px 0;color:var(--ink)}
.nv-row{display:flex;gap:6px;align-items:center;margin:6px 0;flex-wrap:wrap}
.nv-row input,.nv-row select{padding:7px 9px;border:1px solid var(--border);border-radius:8px;font-size:13px;background:var(--panel);color:var(--ink)}
.nv-row .nv-y{width:70px}.nv-row .nv-mk,.nv-row .nv-md{flex:1;min-width:90px}
.doclist{display:flex;flex-direction:column;gap:6px}
.o-fin{font-size:11.5px;font-weight:600;color:var(--brand-d);margin-top:3px}
.o-use{font-size:11.5px;font-weight:600;color:var(--muted);margin-top:2px}
.o-tag.risk{background:var(--red-soft);color:#c11f43}
.dep-acts{display:flex;align-items:center;gap:6px;flex:none}
.dep-status{padding:5px 8px;border:1px solid var(--border);border-radius:8px;background:var(--panel);color:var(--ink);font-size:12px;font-weight:600;cursor:pointer}
.dep-alert{background:var(--red-soft);color:#c11f43;border-radius:9px;padding:8px 12px;font-size:12.5px;font-weight:600;margin:0 2px 10px}
.ownrow.dep-done{opacity:.6}
.docimg{max-width:100%;max-height:64vh;border-radius:10px;border:1px solid var(--border)}
.vid-prog{margin:8px 0}
.vp-bar{height:8px;border-radius:99px;background:var(--panel-3);overflow:hidden}
.vp-bar i{display:block;height:100%;width:0;background:var(--brand);border-radius:99px;transition:width .15s}
.vp-txt{margin-top:5px}
/* Today command center */
.today-hi{font-size:21px;font-weight:800;margin:2px 2px 14px}
.today-sync{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;background:var(--brand-soft);border:1px solid var(--brand);border-radius:14px;padding:14px 16px;margin-bottom:14px}
.today-sync .tsy-h{font-weight:700;font-size:15px;color:var(--brand-d)}
.todo-alerts{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}
.todo-alert{border:1px solid var(--border);border-radius:13px;background:var(--panel);padding:12px;cursor:pointer;text-align:center;transition:border-color .12s;display:flex;flex-direction:column;align-items:center;justify-content:center}
.todo-alert:hover{border-color:var(--brand)}
.todo-alert.zero{opacity:.55}
.ta-n{font-size:26px;font-weight:800;line-height:1}
.ta-l{font-size:11.5px;color:var(--muted);margin-top:4px;font-weight:600}
.todo-alert.red .ta-n{color:#c11f43}.todo-alert.amber .ta-n{color:#aa6800}.todo-alert.brand .ta-n{color:var(--brand-d)}.todo-alert.sky .ta-n{color:#0379ab}.todo-alert.gray .ta-n{color:var(--muted)}
.ts-out{margin:12px 16px 0;font-size:13.5px}
.ts-ok{font-weight:600;color:var(--brand-d);margin-bottom:8px}
.ts-steps{margin:0;padding-left:20px;line-height:1.6}
.ts-steps li{margin-bottom:8px}
.ts-cmd{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:6px}
.ts-cmd code{background:#0d1411;color:#7fe0b0;padding:8px 12px;border-radius:8px;font-size:12.5px;font-family:ui-monospace,Menlo,monospace;word-break:break-all}
.ts-warn{margin-top:10px;background:var(--amber-soft);color:#aa6800;border-radius:9px;padding:8px 11px;font-size:12.5px;font-weight:600}
.ts-divider{height:1px;background:var(--border);margin:18px 16px}
.ts-ai{background:var(--panel-3);border-radius:10px;padding:12px 14px;font-size:13.5px;line-height:1.55;white-space:normal}
#set-textsync textarea{width:100%;box-sizing:border-box;border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-family:inherit;font-size:13.5px;resize:vertical}
.custtab-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.custtab-head .highlights{flex:1;margin:0}
.rc-headbtns{display:flex;gap:6px;flex:none}
.famlist{display:flex;flex-direction:column;gap:6px}
/* family tree diagram */
.ftree{display:flex;flex-direction:column;align-items:center;padding:6px 0 2px;overflow-x:auto}
.ft-row{display:flex;justify-content:center;align-items:stretch;gap:14px;flex-wrap:wrap}
.ft-conn{width:2px;height:18px;background:var(--border)}
.ft-kidbar{height:2px;background:var(--border);width:min(80%,520px)}
.ft-kids{margin-top:0}
.ft-kids .ft-node::before{content:"";position:absolute;top:-12px;left:50%;width:2px;height:12px;background:var(--border)}
.ft-node{position:relative;width:122px;border:1px solid var(--border);border-radius:13px;background:var(--panel);padding:12px 8px 10px;text-align:center;cursor:default}
.ft-node.linked{cursor:pointer}
.ft-node.linked:hover{border-color:var(--brand);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.ft-node.self{border-color:var(--brand);background:var(--brand-soft)}
.ft-av{width:38px;height:38px;border-radius:50%;background:var(--panel-3);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:17px;margin:0 auto 6px;color:var(--brand-d)}
.ft-node.self .ft-av{background:var(--brand);color:#fff}
.ft-nm{font-weight:700;font-size:13px;line-height:1.2}
.ft-rel{font-size:11px;color:var(--muted);margin-top:2px}
.ft-bd{font-size:10.5px;color:var(--muted);margin-top:3px}
.ft-x{position:absolute;top:4px;right:5px;border:0;background:transparent;color:var(--muted);cursor:pointer;font-size:11px;opacity:0;transition:opacity .1s}
.ft-node:hover .ft-x{opacity:.7}.ft-x:hover{opacity:1;color:#c11f43}
.ft-edit{position:absolute;top:4px;left:5px;border:0;background:transparent;color:var(--muted);cursor:pointer;font-size:11px;opacity:0;transition:opacity .1s}
.ft-node:hover .ft-edit{opacity:.7}.ft-edit:hover{opacity:1;color:var(--brand)}
/* smart-data review queue */
.sd-head{display:flex;gap:14px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:12px}
.sd-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.sd-intro{flex:1;min-width:240px}
.segbar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.seg{border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:999px;padding:5px 12px;font-size:12.5px;font-weight:600;cursor:pointer}
.seg.on{background:var(--brand);border-color:var(--brand);color:#fff}
.ownrow.sugg{align-items:flex-start}
.sugg-ev{font-size:11.5px;color:var(--muted);margin-top:3px;font-style:italic}
.sugg-sec{border:1px solid color-mix(in srgb,var(--brand) 30%,var(--line));border-radius:12px;background:var(--brand-soft);padding:12px 14px}
/* in-market prediction rows */
.ownrow.imkt{align-items:flex-start;gap:12px}
.imkt-score{flex:none;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;color:#fff;background:var(--muted)}
.imkt-score.hot{background:#e0533a}.imkt-score.warm{background:#e0a23a}.imkt-score.watch{background:#7a8aa0}
.rsns{display:flex;flex-wrap:wrap;gap:5px;margin:5px 0 2px}
.rsn{font-size:11.5px;font-weight:600;color:var(--ink);background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:3px 9px}
.eq-good{color:var(--brand-d)}.eq-neg{color:#c11f43}
/* deal close-out form */
.dealform .frow3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
@media(max-width:560px){.dealform .frow3{grid-template-columns:1fr 1fr}}
.dsec{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);margin:12px 0 6px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:4px}
.dli{display:grid;grid-template-columns:120px 1fr 90px 90px 28px;gap:6px;margin-bottom:6px;align-items:center}
.dli input,.dli select{padding:6px 8px;border:1px solid var(--border);border-radius:7px;font-size:12.5px;background:var(--panel);color:var(--ink);width:100%}
@media(max-width:560px){.dli{grid-template-columns:1fr 1fr;}}
.dl-gross{margin:10px 0 4px;padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:var(--brand-soft);font-size:13px}
/* deal records + proposal on the customer file */
.dealrec .o-fin{color:var(--brand-d);font-weight:600}
.proposal{border:1px solid var(--line);border-radius:12px;padding:12px 14px;background:var(--panel)}
.proposal.good{border-color:color-mix(in srgb,var(--brand) 45%,var(--line));background:var(--brand-soft)}
.proposal.neg{border-color:color-mix(in srgb,#c11f43 35%,var(--line))}
.prop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:8px}
@media(max-width:560px){.prop-grid{grid-template-columns:1fr 1fr}}
.pcell{display:flex;flex-direction:column;gap:2px}
.pcell .pl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.02em;color:var(--muted)}
.pcell .pv{font-size:16px;font-weight:800;color:var(--ink)}
.pcell .pv.good{color:var(--brand-d)}.pcell .pv.neg{color:#c11f43}
/* KPI grid for deal performance report */
.kpigrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.kpi{border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:var(--panel)}
.kpi-l{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.02em;color:var(--muted)}
.kpi-v{font-size:19px;font-weight:800;color:var(--ink);margin-top:2px}
.kpi-s{font-size:11px;color:var(--muted);margin-top:1px}
.ft-rel-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:16px;border-top:1px dashed var(--border);padding-top:12px;justify-content:center}
.ft-rel-lbl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
/* low-confidence connection marker */
.ft-q{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:var(--amber-soft,#fde9c8);color:#b06d00;font-size:10px;font-weight:800;line-height:1;cursor:help}
.o-tag + .ft-q{margin-left:3px}
.ft-node.uncertain{border-style:dashed;border-color:color-mix(in srgb,#b06d00 45%,var(--border))}
/* friends group, alongside the family tree */
.ft-friends{margin-top:14px;border-top:1px dashed var(--border);padding-top:12px}
.ft-friend-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.fam-linked{margin-top:8px}
.fam-linkchip{display:flex;align-items:center;gap:8px;background:var(--green-soft);color:#0a7d56;border-radius:9px;padding:8px 11px;font-size:12.5px}
.fam-linkchip button{margin-left:auto;border:0;background:transparent;color:var(--brand-d);font-weight:700;cursor:pointer;font-size:12px}
.fmtgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.fmtcell{border:1px solid var(--border);border-radius:10px;padding:10px 12px;background:var(--panel)}
.fmtcell.empty{background:var(--panel-3);opacity:.7}
.fmt-l{font-size:11.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.02em;display:flex;align-items:center;gap:6px;margin-bottom:4px}
.fmt-v{font-size:13.5px;line-height:1.4;white-space:pre-wrap}
.fmt-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:5px;background:var(--brand);color:#fff;font-size:11px;font-weight:800}
.cf-h h3{font-size:14px;margin:0}
.dealgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.dealcard{border:1px solid var(--border);border-radius:11px;padding:11px 12px;background:var(--panel);cursor:pointer;transition:border-color .12s}
.dealcard:hover{border-color:var(--brand)}
.dc-top{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.dc-stage{font-size:11px;color:var(--muted);font-weight:600}
.dc-veh{font-weight:650;font-size:13.5px}
.dc-meta{font-size:11.5px;color:var(--muted);margin-top:3px}
.dc-loss{font-size:11.5px;color:#c11f43;margin-top:4px}
.frow{display:flex;gap:10px}.frow .field{flex:1}
.repfilter{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.repfilter .rf-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.repfilter .repsel,select.repsel{padding:7px 11px;border:1px solid var(--border);border-radius:9px;background:var(--panel);color:var(--ink);font-size:13.5px;font-weight:600;min-width:190px;cursor:pointer}
.rhythm-head{margin-bottom:12px}
.crk-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.crk-tag{font-size:10px;font-weight:700;letter-spacing:.01em;border-radius:5px;padding:1.5px 6px;background:var(--panel-3);color:var(--muted)}
.crk-tag.overdue{background:var(--red-soft);color:#c11f43}
.crk-tag.no-fu{background:var(--amber-soft);color:#aa6800}
.crk-tag.quiet{background:var(--sky-soft);color:#0379ab}
[data-theme="dark"] .crk-tag.overdue{color:#f88aa3}[data-theme="dark"] .crk-tag.no-fu{color:#f0bf72}[data-theme="dark"] .crk-tag.quiet{color:#6cc6f2}
.rc-temp{border-radius:999px;padding:4px 11px;font-size:11.5px;font-weight:700;white-space:nowrap}
.rc-temp.hot{background:var(--red-soft);color:#c11f43}
.rc-temp.warm{background:var(--amber-soft);color:#aa6800}
.rc-temp.cold{background:var(--sky-soft);color:#0379ab}
.rc-temp.dead{background:var(--panel-3);color:var(--muted);text-decoration:line-through;text-decoration-thickness:1.5px}
.rc-temp.none{background:var(--panel-3);color:var(--faint)}
.rc-steps{display:flex;align-items:center;gap:5px;margin-top:15px;flex-wrap:wrap}
.rc-steplbl{font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;font-weight:700;color:var(--faint);margin-right:4px}
.rstep{width:27px;height:27px;display:grid;place-items:center;border-radius:8px;background:var(--panel-3);color:var(--muted);font-size:12px;font-weight:700;transition:.12s}
.rstep.on{background:var(--brand);color:#fff;box-shadow:0 0 0 3px var(--brand-soft);transform:scale(1.14)}
.toggle.temp{display:flex;width:100%}
.toggle.temp button{flex:1;border:0;background:var(--panel-3);color:var(--muted);padding:9px;font-weight:600;font-size:13px;cursor:pointer;border-right:1px solid var(--line)}
.toggle.temp button:last-child{border-right:0}
.toggle.temp button.on{background:var(--brand);color:#fff}
.toggle.temp button.dead.on{background:#4b5563;color:#fff}
.temp-dot.dead{background:var(--panel-3);color:var(--muted);text-decoration:line-through}
.temp-dot{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:700;background:var(--panel-3)}
.temp-dot.hot{background:var(--red-soft);color:#c11f43}
.temp-dot.warm{background:var(--amber-soft);color:#aa6800}
.temp-dot.cold{background:var(--sky-soft);color:#0379ab}
@media(max-width:760px){ .rhythm{max-width:560px} .rcard{grid-template-columns:1fr;gap:16px} }

/* Redraft feedback + learned preferences */
.rc-fb{display:flex;align-items:center;gap:8px;margin-top:9px;flex-wrap:wrap}
.rc-fb input#r-feedback{flex:1;min-width:160px;border:1px solid var(--line-2);border-radius:9px;padding:9px 11px;font-family:inherit;font-size:13px;background:var(--panel);color:var(--ink);outline:none}
.rc-fb input#r-feedback:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.rc-remember{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);white-space:nowrap}
.btn.small.primary{background:var(--brand);border-color:var(--brand);color:#fff}
.learned{display:flex;flex-wrap:wrap;gap:7px}
.lnote{display:inline-flex;align-items:center;gap:7px;background:var(--brand-soft);color:var(--brand-d);border-radius:999px;padding:5px 6px 5px 12px;font-size:12px;font-weight:500}
.lnote button{border:0;background:rgba(0,0,0,.08);color:inherit;width:17px;height:17px;border-radius:50%;cursor:pointer;font-size:11px;line-height:1}

/* Rhythm activity-history quick view */
.rc-history{margin-top:16px}
.rc-tlwrap{max-height:260px;overflow:auto;border:1px solid var(--line);border-radius:11px;padding:13px 14px 6px;background:var(--panel-2)}
.rc-tlwrap .tl{margin:0}
.rc-tlwrap .tlitem{padding-bottom:13px}
.rc-tlwrap .tlitem:last-child{padding-bottom:2px}
.rc-tlwrap .tlitem .text{font-size:12.5px}
@media(max-width:760px){ .rc-tlwrap{max-height:220px} }

/* ID / insurance scanner */
.scanrow{display:flex;gap:8px;flex-wrap:wrap}
.scanarea{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.scancard{display:flex;align-items:center;gap:11px;border:1px solid var(--line-2);border-radius:11px;padding:8px;background:var(--panel-2)}
.scancard img{width:66px;height:44px;object-fit:cover;border-radius:7px;border:1px solid var(--line);background:#fff}
.scancard .sc-info{flex:1;min-width:0}
.scancard .sc-l{font-weight:600;font-size:13px}
.scancard .sc-s{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.scancard .sc-x{border:0;background:transparent;color:var(--faint);cursor:pointer;font-size:14px;padding:4px 7px;border-radius:6px}
.scancard .sc-x:hover{background:var(--red-soft);color:var(--red)}

/* Appointments + scan icon + drawer appt rows */
.sc-ic{width:40px;height:40px;display:grid;place-items:center;font-size:20px;background:var(--panel-3);border-radius:9px}
.dappt{background:var(--sky-soft);color:#0379ab;border-radius:9px;padding:9px 12px;font-size:12.5px;font-weight:600;margin-bottom:6px}
.bigbtn.appt{background:var(--purple-soft);color:#5b3fd6;border-color:transparent}
.appts{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:18px}
.appt-day{}
.appt-date{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--brand);margin-bottom:9px}
.appt-row{display:flex;align-items:center;gap:13px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 14px;box-shadow:var(--shadow-xs);margin-bottom:8px;flex-wrap:wrap}
.appt-row.completed,.appt-row.canceled,.appt-row.no_show{opacity:.62}
.appt-time{font-weight:700;font-size:14px;min-width:52px}
.appt-main{flex:1;min-width:160px}
.appt-cust{font-weight:600;font-size:14px;cursor:pointer}
.appt-cust:hover{color:var(--brand)}
.appt-sub{color:var(--muted);font-size:12px;margin-top:2px}
.appt-acts{display:flex;gap:6px;flex-wrap:wrap}
.cal .tag.appt{background:var(--purple-soft);color:#5b3fd6}

/* Dashboard analytics */
.dashbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.periodseg{display:inline-flex;background:var(--panel-3);border-radius:10px;padding:3px}
.periodseg button{border:0;background:transparent;color:var(--muted);font-weight:600;font-size:12.5px;padding:7px 12px;border-radius:8px;cursor:pointer}
.periodseg button.on{background:var(--panel);color:var(--ink);box-shadow:var(--shadow-xs)}
.dashbar select{border:1px solid var(--line-2);background:var(--panel);color:var(--ink);border-radius:9px;padding:8px 11px;font-size:13px;font-family:inherit;outline:none}
.dashbar #dash-customize{margin-left:auto}
.dashcustomize{display:flex;flex-wrap:wrap;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:13px 16px;margin-bottom:14px}
.dashcustomize label{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink-2);font-weight:500;cursor:pointer}
.dashgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}
.dashgrid .dashw{margin:0}
.dtable{overflow-x:auto;padding:6px 6px 10px}
.dtable table{width:100%}
@media(max-width:1000px){ .dashgrid{grid-template-columns:1fr} }

/* Traffic view */
.traffic-src{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:4px}
.hotlist{padding:12px 14px;display:flex;flex-direction:column;gap:10px;max-height:none}
.hotcard{border:1px solid var(--line);border-radius:12px;padding:12px 14px;background:var(--panel-2);cursor:pointer;transition:.12s}
.hotcard:hover{border-color:var(--brand);box-shadow:var(--shadow-xs)}
.hot-top{display:flex;align-items:center;gap:9px}
.hot-name{font-weight:650;font-size:14px}
.hot-veh{color:var(--muted);font-size:12.5px;margin-top:3px}
.hot-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.hot-need{margin-top:9px;font-size:12.5px;background:var(--rev-soft);border-radius:9px;padding:8px 11px;color:var(--ink-2)}
.hot-need-l{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.05em;font-weight:700;color:var(--rev);margin-bottom:3px}

/* Purchase-offer modal */
.ofgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ofgrid .field label{display:block;font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.04em;font-weight:600;margin-bottom:4px}
.ofgrid .field input{width:100%;border:1px solid var(--line-2);border-radius:9px;padding:9px 11px;font-family:inherit;font-size:14px;background:var(--panel);color:var(--ink);outline:none}
.ofgrid .field input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.ofotd{display:flex;justify-content:space-between;align-items:baseline;margin-top:14px;padding:12px 14px;background:var(--brand-soft);border-radius:11px;font-weight:600;color:var(--brand-d)}
.ofotd b{font-size:22px;font-weight:800;color:var(--brand)}
.oflinks{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.oflinks .btn.off{opacity:.4;pointer-events:none}

/* Inventory actions + offer-link timeline delete */
.invactions{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:12px}
.tl-del{border:1px solid var(--line-2);background:transparent;color:var(--muted);border-radius:7px;padding:2px 7px;font-size:11px;font-weight:600;cursor:pointer;margin-left:4px}
.tl-del:hover{border-color:var(--red);color:var(--red);background:var(--red-soft)}
.tlitem .text a{color:var(--brand);font-weight:600}

/* Rev score gauges */
.revwrap{padding:14px 16px}
.revteam{display:flex;align-items:center;gap:16px;justify-content:center;padding-bottom:12px;border-bottom:1px solid var(--line);margin-bottom:14px}
.revteam-l{font-size:13px;color:var(--muted);font-weight:500}
.revteam-l b{font-size:16px}
.revgrid{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}
.revcard{position:relative;flex:0 0 138px;text-align:center;padding:11px 6px 9px;border-radius:12px;background:var(--panel-2);border:1px solid var(--line)}
.revg{display:block;margin:0 auto}
.revname{font-size:12.5px;font-weight:600;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.revzone{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.revtip{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;background:#1b2a6b;color:#fff;font-size:11px;line-height:1.34;font-weight:500;padding:10px;border-radius:12px;opacity:0;visibility:hidden;transition:opacity .12s;overflow:auto}
.revcard:hover .revtip{opacity:1;visibility:visible}
/* Rhythm quick-notes */
.rc-notes{margin-top:16px}
.rc-notes textarea{width:100%;min-height:62px;border:1px solid var(--line-2);border-radius:11px;padding:10px 12px;font-family:inherit;font-size:13.5px;line-height:1.4;background:var(--panel);color:var(--ink);outline:none;resize:vertical}
.rc-notes textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.rc-notes .btn.small{margin-top:8px}
/* Deal Desk — Work a Deal worksheet */
.wd-otd{font-size:20px;font-weight:800;color:var(--brand);padding:5px 0}
.wd-gross{background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:9px 12px;font-size:12.5px;line-height:1.5;margin:4px 0 8px}
.wd-gross b{font-weight:700}
.wd-info{font-size:12.5px;margin:4px 0 8px}
.wd-unit{display:flex;justify-content:space-between;gap:10px;font-size:12.5px;padding:5px 2px;border-bottom:1px dotted var(--line)}
.wd-unit:last-child{border-bottom:0}
.wd-foot{flex-wrap:wrap;gap:6px}

/* Notifications */
.navbadge{display:inline-block;min-width:16px;height:16px;line-height:16px;text-align:center;background:var(--red);color:#fff;font-size:10px;font-weight:700;border-radius:999px;padding:0 4px;margin-left:6px;vertical-align:middle}
.feedrow.notif.unread{background:var(--panel-2)}
.feedrow.notif.unread .ttl{font-weight:700}
.feedrow.notif.red .ttl{color:var(--red)}
.feedrow.notif.amber .ttl{color:var(--amber)}
.dot-unread{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--brand);margin-left:6px;vertical-align:middle}
/* Inventory unit picker (autocomplete + finder) */
.unitac{position:absolute;left:0;right:0;top:100%;z-index:80;background:var(--panel);border:1px solid var(--line-2);border-radius:0 0 11px 11px;max-height:264px;overflow:auto;box-shadow:var(--shadow)}
.unitac-i{display:flex;justify-content:space-between;gap:10px;padding:8px 12px;cursor:pointer;font-size:13px;border-bottom:1px solid var(--line)}
.unitac-i:last-child{border-bottom:0}.unitac-i.on,.unitac-i:hover{background:var(--panel-2)}
.unitac-empty{padding:8px 12px;font-size:12px;color:var(--muted)}
.uf-scrim{position:fixed;inset:0;background:rgba(16,22,40,.5);z-index:200;display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.uf-scrim.show{display:flex}
.uf-panel{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);width:min(640px,96vw);max-height:86vh;display:flex;flex-direction:column;overflow:hidden}
.uf-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line)}
.uf-head h3{margin:0;font-size:16px}
.uf-filters{display:flex;flex-wrap:wrap;gap:8px;padding:12px 16px;border-bottom:1px solid var(--line)}
.uf-filters input,.uf-filters select{border:1px solid var(--line-2);border-radius:9px;padding:8px 11px;background:var(--panel);color:var(--ink);font-size:13px;outline:none}
.uf-filters #uf-q{flex:1;min-width:180px}
.uf-list{overflow:auto;padding:6px 10px}
.uf-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 8px;border-bottom:1px solid var(--line)}
.uf-row:last-child{border-bottom:0}
.uf-empty{padding:24px;text-align:center;color:var(--muted);font-size:13px}
.uf-foot{padding:8px 16px;border-top:1px solid var(--line)}
/* Traffic source-category groups */
.src-group{margin-bottom:4px}
.src-group-h{font-size:12px;font-weight:700;color:var(--ink);padding:9px 4px 4px;position:sticky;top:0;background:var(--panel)}
/* Vehicles of interest — interest badges + AI text */
.u-tag.leaning{background:var(--brand-soft);color:var(--brand)}
.u-tag.ruledout{background:#fde8e8;color:var(--red)}
.u-sub em{font-style:italic;color:var(--muted)}
.ai-text{font-size:14px;line-height:1.6;white-space:pre-wrap}
/* Forecast / floorplan + service-parts */
.bartrack.r i{background:var(--red)}
.sp-tot{font-size:12.5px;color:var(--muted);padding:4px 2px 8px;font-weight:500}
/* Team chat */
.chat-wrap{display:flex;height:calc(100vh - 150px);min-height:420px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--panel)}
.chat-side{width:232px;flex:0 0 232px;border-right:1px solid var(--line);overflow:auto;background:var(--panel-2)}
.chat-side-h{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:13px 12px 4px;display:flex;justify-content:space-between;align-items:center}
.chat-add{background:none;border:none;color:var(--muted);font-size:16px;cursor:pointer;line-height:1}
.chat-list{padding:0 6px 6px}
.chat-srow{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;cursor:pointer;font-size:13.5px}
.chat-srow:hover{background:var(--panel-3)}
.chat-srow.on{background:var(--brand-soft);color:var(--brand);font-weight:600}
.cs-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cs-badge{background:var(--red);color:#fff;font-size:10px;font-weight:700;border-radius:999px;padding:1px 6px;min-width:16px;text-align:center}
.chat-main{flex:1;display:flex;flex-direction:column;min-width:0}
.chat-head{padding:13px 16px;border-bottom:1px solid var(--line);font-weight:700;font-size:15px}
.chat-msgs{flex:1;overflow:auto;padding:12px 16px;display:flex;flex-direction:column;gap:2px}
.chat-msg{max-width:78%;align-self:flex-start}
.chat-msg.mine{align-self:flex-end}
.cm-who{font-size:11.5px;color:var(--muted);font-weight:600;margin-top:9px}
.cm-time{font-weight:400;font-size:10.5px}
.cm-body{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:7px 11px;font-size:14px;line-height:1.42;display:inline-block;margin-top:2px;text-align:left}
.chat-msg.mine .cm-body{background:var(--brand);color:#fff;border-color:var(--brand)}
.chat-composer{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--line)}
.chat-composer textarea{flex:1;border:1px solid var(--line-2);border-radius:11px;padding:9px 12px;font-family:inherit;font-size:14px;resize:none;background:var(--panel);color:var(--ink);outline:none;max-height:120px}
.chat-composer textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
@media(max-width:760px){.chat-side{width:148px;flex-basis:148px}.chat-wrap{height:calc(100vh - 130px)}}
/* Schedule */
.sched-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.sched-nav{display:flex;align-items:center;gap:8px}
.sched-title{font-weight:700;font-size:16px;min-width:160px;text-align:center}
.sched-right{display:flex;align-items:center;gap:10px}
.seg.sched-seg button{padding:6px 14px}
.sched-grid{display:grid;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--panel);font-size:13px}
.sg-cell{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:7px 9px;min-height:54px}
.sg-corner,.sg-head{background:var(--panel-2);font-weight:700;text-align:center;min-height:0;padding:9px 6px}
.sg-head span{display:block;font-size:16px;color:var(--ink)}
.sg-head.sg-tod{background:var(--brand-soft);color:var(--brand)}
.sg-name{display:flex;align-items:center;gap:8px;font-weight:600;background:var(--panel-2)}
.sg-ava{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--brand);color:#fff;font-size:10px;font-weight:700;flex:0 0 26px}
.sg-day{display:flex;flex-direction:column;gap:4px}
.sg-click{cursor:pointer}.sg-click:hover{background:var(--panel-3)}
.sg-shift{background:var(--brand-soft);border:1px solid var(--brand);color:var(--brand);border-radius:7px;padding:3px 7px;font-weight:600;font-size:12px;cursor:pointer;line-height:1.25}
.sg-shift.off{background:var(--panel-3);border-color:var(--line-2);color:var(--muted);font-weight:500}
.sg-pos{display:block;font-size:10px;font-weight:500;opacity:.85}
.sg-plus{color:var(--line-2);font-size:16px;align-self:center;margin:auto}
.month-cal{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--panel)}
.mc-dows,.mc-grid{display:grid;grid-template-columns:repeat(7,1fr)}
.mc-dow{padding:8px;text-align:center;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:var(--panel-2);border-bottom:1px solid var(--line)}
.mc-day{min-height:92px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:5px 6px;display:flex;flex-direction:column;gap:2px}
.mc-day.sg-click{cursor:pointer}.mc-day.sg-click:hover{background:var(--panel-3)}
.mc-out{background:var(--panel-2);opacity:.55}
.mc-num{font-size:12px;font-weight:600;color:var(--muted)}
.mc-tod .mc-num{background:var(--brand);color:#fff;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.mc-chip{font-size:11px;background:var(--brand-soft);color:var(--brand);border-radius:5px;padding:1px 5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}
.mc-more{font-size:10px;color:var(--muted)}
/* Time clock */
.tc-wrap{display:grid;grid-template-columns:340px 1fr;gap:18px;align-items:start}
@media(max-width:820px){.tc-wrap{grid-template-columns:1fr}}
.tc-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:22px;text-align:center}
.tc-status{font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;gap:8px}
.tc-dot{width:11px;height:11px;border-radius:50%;display:inline-block}
.tc-dot.in{background:var(--green,#1faf5a);box-shadow:0 0 0 4px color-mix(in srgb,var(--green,#1faf5a) 22%,transparent)}
.tc-dot.out{background:var(--line-2)}
.tc-dot.brk{background:#e0a32e;box-shadow:0 0 0 4px rgba(224,163,46,.22)}
.tc-big{font-size:40px;font-weight:800;margin:14px 0 2px;line-height:1}
.tc-big small{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-top:4px}
.tc-since{font-size:12px;color:var(--muted)}
.tc-shift{margin:14px 0;font-size:13px;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:9px}
.tc-btns{display:flex;flex-direction:column;gap:9px;margin-top:6px}
.btn.big{padding:13px;font-size:15px;font-weight:700;width:100%}
.btn.amber{background:#e0a32e;border-color:#e0a32e;color:#fff}
.tc-week{margin-top:14px;font-size:13px;color:var(--muted)}
.tc-sheet .ts-totals{display:flex;flex-wrap:wrap;gap:14px;padding:6px 2px 12px;font-size:13px}
.ts-tot{background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:5px 10px}
.tcf{font-size:10.5px;font-weight:700;border-radius:5px;padding:1px 6px;text-transform:uppercase;letter-spacing:.02em}
.tcf.late{background:#fbe5c6;color:#9a5b00}.tcf.short{background:#fcd9d9;color:#9a1c1c}
.tcf.open{background:var(--brand-soft);color:var(--brand)}.tcf.ok{background:transparent;color:var(--green,#1faf5a)}
.ts-missed{margin-top:10px;font-size:12.5px;color:#9a1c1c;background:#fcd9d9;border-radius:8px;padding:8px 11px}

/* ---- Parts & Service module ---- */
.psbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:6px 0 14px}
.psbar input,.psbar select{padding:9px 11px;border:1px solid var(--border);border-radius:10px;background:var(--panel);color:var(--text);font-size:13px}
.psbar input{flex:1;min-width:200px}
.psck{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);white-space:nowrap}
.psbar .btn{margin-left:auto}
tr.lowstk td{background:color-mix(in srgb,#c11f43 7%,transparent)}
.psform{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;padding:14px}
.psf{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}
.psf>span{font-weight:600}
.psf input,.psf select,.psf textarea{padding:9px 10px;border:1px solid var(--border);border-radius:9px;background:var(--panel);color:var(--text);font-size:13px;font-family:inherit}
.ps-sub{padding:12px 14px 4px;font-weight:700;font-size:13px}
.cust-res{position:relative}
.cust-opt{padding:7px 10px;border:1px solid var(--border);border-top:none;cursor:pointer;font-size:13px;background:var(--panel)}
.cust-opt:hover{background:var(--hover,rgba(0,0,0,.04))}
.jp-list{display:flex;flex-direction:column;gap:7px;padding:4px 14px 10px}
.jp-row{display:flex;gap:7px;align-items:center}
.jp-row input{padding:7px 9px;border:1px solid var(--border);border-radius:8px;background:var(--panel);color:var(--text);font-size:13px}
.jp-row input:nth-child(1){width:110px}.jp-row input:nth-child(2){flex:1}
/* parts orders chips */
.po-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.po-chip{padding:7px 13px;border:1px solid var(--border);border-radius:999px;background:var(--panel);color:var(--muted);cursor:pointer;font-size:13px;font-weight:600}
.po-chip.on{border-color:var(--brand);color:var(--brand-d);background:color-mix(in srgb,var(--brand) 10%,transparent)}
.po-chip b{color:var(--text)}
/* shop schedule */
.jobgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px}
.jobcard{border:1px solid var(--border);border-radius:14px;background:var(--panel);padding:14px}
.jc-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.jc-title{font-weight:700;font-size:15px}
.jc-meta{font-size:12px;color:var(--muted);margin-top:8px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.jc-parts{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.jp{font-size:11.5px;padding:3px 8px;border-radius:7px;border:1px solid var(--border)}
.jp.ok{color:#2b8a3e;border-color:#b2f2bb;background:#ebfbee}
.jp.wait{color:#aa6800;border-color:#ffe8a3;background:#fff9db}
.jc-notes{margin-top:8px}
.jc-acts{display:flex;gap:6px;margin-top:11px;flex-wrap:wrap}
@media(max-width:560px){.psform{grid-template-columns:1fr}}

/* parts/service additions */
.seg{display:inline-flex;border:1px solid var(--border);border-radius:9px;overflow:hidden}
.segbtn{padding:8px 12px;background:var(--panel);color:var(--muted);border:none;cursor:pointer;font-size:13px;font-weight:600}
.segbtn.on{background:var(--brand);color:#fff}
.dayblock{margin-bottom:18px}
.day-h{font-weight:700;font-size:14px;margin:6px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.jp.ord{color:#0379ab;border-color:#a5d8ff;background:#e7f5ff}
.jp-ord{margin-left:6px;border:1px solid currentColor;border-radius:6px;background:transparent;color:#aa6800;font-size:10.5px;padding:1px 6px;cursor:pointer;font-weight:700}
.bartrack{flex:1;height:9px;border-radius:5px;background:var(--border);overflow:hidden;margin:0 10px}
.bartrack>i{display:block;height:100%;background:var(--brand)}
.bartrack.r>i{background:#c11f43}

/* trade-up payment projection */
.tu-proj{margin-top:3px}
.pay-down{color:#2b8a3e;font-weight:700}
.pay-up{color:#c11f43;font-weight:700}
.pay-flat{color:var(--muted);font-weight:700}

/* shop drag-and-drop day calendar */
.shopcal{display:grid;grid-template-columns:236px 1fr;gap:14px;align-items:start;margin-top:6px}
.cal-unsched{border:1px solid var(--border);border-radius:12px;background:var(--panel);position:sticky;top:8px}
.cal-uh{padding:10px 12px;font-weight:700;border-bottom:1px solid var(--border)}
.cal-ulist{padding:10px;display:flex;flex-direction:column;gap:8px;min-height:140px;max-height:72vh;overflow:auto}
.cal-ulist.over,.cal-slot.over{outline:2px dashed var(--brand);outline-offset:-2px;background:color-mix(in srgb,var(--brand) 10%,transparent)}
.cal-main{border:1px solid var(--border);border-radius:12px;background:var(--panel);overflow:hidden}
.cal-daynav{display:flex;gap:8px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.cal-daynav input[type=date]{padding:6px 9px;border:1px solid var(--border);border-radius:8px;background:var(--panel);color:var(--text)}
.cal-grid{display:grid;overflow:auto;max-height:74vh}
.cal-corner,.cal-techhead{position:sticky;top:0;z-index:2;background:var(--panel)}
.cal-techhead{padding:8px 6px;font-weight:700;font-size:12.5px;text-align:center;border-bottom:2px solid var(--border);border-left:1px solid var(--border)}
.cal-hour{font-size:11px;color:var(--muted);padding:5px 6px;border-top:1px solid var(--border);text-align:right}
.cal-slot{min-height:48px;border-top:1px solid var(--border);border-left:1px solid var(--border);padding:3px;display:flex;flex-direction:column;gap:3px}
.calblock{border-radius:7px;padding:5px 7px;font-size:11.5px;cursor:grab;border:1px solid var(--border);background:var(--panel)}
.calblock:active{cursor:grabbing}
.calblock.dragging{opacity:.45}
.calblock .cb-t{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calblock .cb-s{color:var(--muted);font-size:10.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calblock.sky{background:#e7f5ff;border-color:#a5d8ff}
.calblock.amber{background:#fff9db;border-color:#ffe8a3}
.calblock.brand{background:#e6fcf5;border-color:#96f2d7}
.calblock.green{background:#ebfbee;border-color:#b2f2bb}
@media(max-width:760px){.shopcal{grid-template-columns:1fr}}
