/* ============================================================
   Chesapeake Pallets — Load Command — Design System v4
   Salesforce × Monday × Notion. Clean cool-neutral surfaces,
   light Notion sidebar, dense table-first layouts, vivid
   Monday status pills, all-Inter type. Terracotta = sharp
   accent only.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;450;500;600;700;800&family=JetBrains+Mono:wght@500;600&display=swap');

:root{
  /* accent — enterprise TMS blue */
  --accent:#2563eb; --accent-2:#1d4ed8; --accent-soft:#d7e3fd; --accent-tint:#eef3fe;
  /* navy command-center sidebar */
  --navy:#0e1b2e; --navy-2:#13243b; --navy-line:#0a1626;
  /* neutral surfaces */
  --bg:#f3f5f8; --card:#ffffff; --card-2:#f7f9fc; --side:#0e1b2e; --hover:#eef1f6;
  /* ink */
  --ink:#16191e; --ink-2:#4d535c; --ink-3:#7a818c; --ink-4:#a3aab4;
  /* hairlines */
  --line:#e7eaef; --line-2:#dde1e8; --line-3:#cfd4dd;
  /* status — Monday vivid */
  --green:#1fab6a; --blue:#3b7df6; --purple:#8a5cf6; --teal:#0ea5a4; --amber:#f5a623; --orange:#f97c3c; --red:#ec4747; --gray:#7a818d; --violet:#8a5cf6; --slate:#7a818d;
  --green-bg:#e4f6ee; --blue-bg:#e7effe; --purple-bg:#efe8fe; --teal-bg:#def4f3; --amber-bg:#fdf1d8; --red-bg:#fce5e5; --violet-bg:#efe8fe; --slate-bg:#eef0f3;
  /* geometry */
  --r:10px; --r-sm:7px; --r-lg:14px;
  /* shadow — minimal, Notion */
  --sh-sm:0 1px 2px rgba(20,22,28,.04);
  --sh:0 1px 3px rgba(20,22,28,.07),0 1px 2px rgba(20,22,28,.04);
  --sh-md:0 4px 12px -2px rgba(20,22,28,.12),0 2px 4px -2px rgba(20,22,28,.06);
  --sh-lg:0 24px 56px -16px rgba(15,18,26,.28);
  --ring:0 0 0 3px rgba(192,84,44,.16);
  /* type */
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --serif:'Inter',-apple-system,sans-serif; /* headlines now Inter too */
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',monospace;
  --num:'Inter',var(--sans);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-size:12.5px;line-height:1.42;letter-spacing:-.006em}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--accent-soft)}
.mono{font-family:var(--mono)} .serif{font-family:var(--sans)} .muted{color:var(--ink-3)}
.num{font-variant-numeric:tabular-nums;letter-spacing:-.02em}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:#d7dbe1;border-radius:9px;border:3px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:#c3c8d0}

/* ---------- Shell ---------- */
.app{display:grid;grid-template-columns:244px 1fr;min-height:100vh}

/* Sidebar (navy command center) */
.side{background:var(--navy);color:#9fb0c6;display:flex;flex-direction:column;padding:11px 8px;position:sticky;top:0;height:100vh;border-right:1px solid var(--navy-line)}
.brand{display:flex;align-items:center;gap:9px;padding:6px 8px 11px;margin-bottom:5px;border-bottom:1px solid rgba(255,255,255,.07)}
.brand .mark{width:29px;height:29px;border-radius:7px;background:var(--accent);display:grid;place-items:center;flex-shrink:0}
.brand .mark svg{width:17px;height:17px}
.brand .wm{font-weight:700;font-size:13.5px;letter-spacing:-.2px;line-height:1.05;color:#fff}
.brand .wm small{display:block;font-size:9.5px;letter-spacing:.3px;color:#6f8198;font-weight:500;margin-top:2px}
.nav{display:flex;flex-direction:column;gap:1px;margin-top:2px;overflow-y:auto;flex:1}
.nav::-webkit-scrollbar{width:0}
.nav .lbl{font-size:9.5px;letter-spacing:.6px;color:#5a6c82;padding:13px 9px 5px;font-weight:600;text-transform:uppercase}
.nav a{display:flex;align-items:center;gap:9px;padding:6.5px 9px;border-radius:6px;color:#9fb0c6;font-size:12.5px;font-weight:500;transition:.1s;cursor:pointer;position:relative}
.nav a svg{width:16px;height:16px;opacity:.66;flex-shrink:0}
.nav a:hover{background:rgba(255,255,255,.055);color:#fff}
.nav a:hover svg{opacity:1}
.nav a.active{background:rgba(37,99,235,.24);color:#fff;font-weight:600}
.nav a.active:before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:17px;border-radius:0 3px 3px 0;background:#4d8bff}
.nav a.active svg{opacity:1;color:#6ea2ff}
.nav a .badge{margin-left:auto;font-family:var(--num);font-size:10px;font-weight:600;padding:0 6px;border-radius:20px;background:rgba(255,255,255,.1);color:#aebed2;min-width:18px;text-align:center}
.nav a .badge.amber,.nav a.active .badge{background:var(--accent);color:#fff}
.nav a .badge.muted{background:rgba(255,255,255,.08);color:#8194ab}
.side-foot{margin-top:6px;display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04)}
.side-foot .av{width:29px;height:29px;border-radius:7px;background:var(--accent);display:grid;place-items:center;font-weight:700;font-size:11px;color:#fff;flex-shrink:0}
.side-foot b{font-size:12px;color:#fff;display:block;letter-spacing:-.1px}
.side-foot small{color:#7889a0;font-size:10.5px}
.side-foot .gear{margin-left:auto;color:#7889a0;width:15px;height:15px}
.side-foot .gear:hover{color:#fff}

/* Main */
.main{display:flex;flex-direction:column;min-width:0}
.top{display:flex;align-items:center;gap:12px;padding:0 20px;height:50px;border-bottom:1px solid var(--line);background:var(--card);position:sticky;top:0;z-index:30}
.top .h{flex-shrink:0;min-width:130px}
.top h1{font-size:18px;font-weight:700;margin:0;letter-spacing:-.4px;line-height:1.1}
.top .sub{color:var(--ink-3);font-size:11.5px;margin-top:1px;font-weight:450}
.search{margin-left:8px;flex:1;max-width:380px;display:flex;align-items:center;gap:9px;background:var(--card-2);border:1px solid var(--line-2);padding:8px 12px;border-radius:8px;color:var(--ink-3);transition:.14s}
.search:focus-within{border-color:var(--accent);box-shadow:var(--ring);background:var(--card)}
.search svg{width:15px;height:15px}
.search input{border:0;background:transparent;outline:none;width:100%;font-size:13px;color:var(--ink);font-family:var(--sans)}
.search kbd{font-family:var(--mono);font-size:10px;color:var(--ink-4);border:1px solid var(--line-2);border-radius:4px;padding:1px 5px;background:var(--card)}
.iconbtn{width:34px;height:34px;border-radius:8px;border:1px solid var(--line-2);background:var(--card);display:grid;place-items:center;color:var(--ink-2);position:relative;transition:.12s;flex-shrink:0}
.iconbtn:hover{background:var(--hover);color:var(--ink)}
.iconbtn svg{width:17px;height:17px}
.iconbtn .dotr{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--red);border:1.5px solid var(--card)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line-2);background:var(--card);color:var(--ink);padding:7.5px 12px;border-radius:7px;font-size:12.5px;font-weight:600;transition:.12s;letter-spacing:-.01em;white-space:nowrap}
.btn svg{width:14px;height:14px}
.btn:hover{background:var(--hover)}
.btn.primary{background:var(--accent);border-color:transparent;color:#fff}
.btn.primary:hover{background:var(--accent-2)}
.btn.ghost{background:transparent;border-color:transparent;color:var(--ink-2)}
.btn.ghost:hover{background:var(--hover);color:var(--ink)}
.btn.sm{padding:6px 10px;font-size:12px;border-radius:6px}
.btn.block{width:100%;justify-content:center}
.btn:disabled{opacity:.4;cursor:not-allowed}
.skilltile{justify-content:flex-start;padding:10px 12px;gap:10px}
.skilltile .st-ic{width:28px;height:28px;border-radius:7px;display:grid;place-items:center;background:var(--accent-tint);color:var(--accent);flex-shrink:0;transition:.12s}
.skilltile .st-ic svg{width:15px;height:15px}
.skilltile:hover .st-ic{background:var(--accent);color:#fff}

.content{padding:16px 20px 72px;overflow:auto}
.view{display:none;animation:fade .2s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
.section-title{font-size:15px;font-weight:700;margin:2px 0 15px;display:flex;align-items:center;gap:10px;letter-spacing:-.3px}
.section-title .count{font-family:var(--num);font-size:11.5px;color:var(--ink-3);background:var(--card);border:1px solid var(--line-2);padding:1px 8px;border-radius:20px;font-weight:600}

/* KPI */
.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:13px;margin-bottom:22px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:15px 16px 13px;position:relative;overflow:hidden;transition:.14s}
.kpi:hover{border-color:var(--line-3);box-shadow:var(--sh)}
.kpi .ic{position:absolute;right:14px;top:14px;width:28px;height:28px;border-radius:7px;display:grid;place-items:center;background:var(--card-2);color:var(--ink-3);border:1px solid var(--line)}
.kpi .ic svg{width:14px;height:14px}
.kpi .lbl{font-size:10.5px;letter-spacing:.2px;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.kpi .val{font-family:var(--num);font-size:26px;font-weight:700;margin-top:10px;letter-spacing:-.04em;line-height:1;font-variant-numeric:tabular-nums;color:var(--ink)}
.kpi .delta{font-size:11px;margin-top:8px;font-weight:600;font-family:var(--num);display:inline-flex;align-items:center;gap:5px}
.kpi .delta .pill{padding:2px 7px;border-radius:5px;display:inline-flex;align-items:center;gap:4px}
.kpi .spark{position:absolute;right:14px;bottom:13px;width:72px;height:26px;pointer-events:none}
.up{color:var(--green)} .down{color:var(--red)} .flat{color:var(--ink-3)}
.up .pill{background:var(--green-bg)} .down .pill{background:var(--red-bg)} .flat .pill{background:var(--slate-bg)}

/* Panels */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.panel-h{display:flex;align-items:center;gap:10px;padding:14px 17px;border-bottom:1px solid var(--line)}
.panel-h h3{font-size:14px;font-weight:700;margin:0;letter-spacing:-.2px}
.panel-h .btn{margin-left:auto}
.grid-2{display:grid;grid-template-columns:1.62fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}

/* Toolbar */
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.seg{display:flex;background:var(--card);border:1px solid var(--line-2);border-radius:8px;padding:2px}
.seg button{border:0;background:transparent;color:var(--ink-3);font-weight:600;font-size:12px;padding:6px 12px;border-radius:6px;transition:.1s;display:inline-flex;align-items:center;gap:6px}
.seg button svg{width:14px;height:14px}
.seg button.on{background:var(--accent-tint);color:var(--accent-2)}
.chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{font-size:12px;color:var(--ink-2);background:var(--card);border:1px solid var(--line-2);padding:6px 11px;border-radius:7px;font-weight:500;transition:.12s}
.chip:hover{background:var(--hover)}
.chip.on{color:#fff;border-color:transparent;background:var(--accent)}
.spacer{margin-left:auto}

/* ====== Monday status pills ====== */
.spill{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;color:#fff;white-space:nowrap;letter-spacing:.1px;min-width:84px}
.spill.sm{min-width:0;padding:3px 9px;font-size:10.5px}
.sp-new,.sp-lead{background:var(--blue)} .sp-outreach{background:#5b8def}
.sp-sourcing,.sp-quote{background:var(--purple)} .sp-dispatched{background:var(--teal)}
.sp-transit,.sp-chase{background:var(--orange)} .sp-delivered,.sp-won{background:var(--green)}
.sp-invoiced{background:var(--gray)} .sp-motion{background:var(--teal)}
.sp-risk,.sp-overdue{background:var(--red)} .sp-paid{background:var(--green)} .sp-open{background:var(--blue)}

/* ====== Monday grouped grid (Load Board · Table) ====== */
.mtable{--cols:130px 110px 146px minmax(148px,1fr) 74px 74px 72px 142px 82px 68px 46px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow-x:auto}
.mt-head{display:grid;grid-template-columns:var(--cols);gap:0;border-bottom:1px solid var(--line-2);background:var(--card-2);min-width:1240px}
.mt-head .mc{font-size:9.5px;letter-spacing:.3px;text-transform:uppercase;color:var(--ink-3);font-weight:600;padding:8px 11px}
.mgroup{min-width:1240px}
.mg-head{display:flex;align-items:center;gap:9px;padding:9px 13px 7px;cursor:pointer}
.mg-head .car{color:var(--ink-4);width:13px;height:13px;transition:.15s}
.mg-head.collapsed .car{transform:rotate(-90deg)}
.mg-head b{font-size:13px;font-weight:700;letter-spacing:-.2px}
.mg-head .gct{font-family:var(--num);font-size:11px;color:var(--ink-3);font-weight:600;background:var(--card-2);border:1px solid var(--line-2);padding:0 7px;border-radius:20px}
.mg-head .gsum{margin-left:auto;font-family:var(--num);font-size:11.5px;color:var(--ink-3);font-weight:600}
.mg-rows{display:block}
.mg-head.collapsed + .mg-rows{display:none}
.mrow{display:grid;grid-template-columns:var(--cols);align-items:center;border-bottom:1px solid var(--line);border-left:3px solid var(--gc,var(--line-3));transition:.1s;cursor:pointer;background:var(--card)}
.mrow:hover{background:var(--card-2)}
.mrow .mc{padding:7px 11px;font-size:12px;min-width:0}
.mc-name b{font-family:var(--mono);font-weight:600;font-size:11.5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.1px;color:var(--accent-2)}
.mc-name small{font-family:var(--mono);font-size:10px;color:var(--ink-3);display:block;margin-top:1px}
.mc-cust b{font-weight:600;font-size:12px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mc.dt{font-family:var(--num);font-size:11.5px;color:var(--ink-2);font-weight:500;font-variant-numeric:tabular-nums}
.mc .equip{font-size:10px;font-weight:600;color:var(--ink-2);background:var(--card-2);border:1px solid var(--line-2);padding:2px 6px;border-radius:5px;white-space:nowrap}
.mc .lane{display:flex;align-items:center;gap:6px;color:var(--ink-2);font-size:12px}
.mc .lane .ar{color:var(--ink-4);display:inline-flex}
.mc .lane svg{width:13px;height:13px;flex-shrink:0}
.mc .gradechip{font-family:var(--num);font-size:11px;font-weight:600;background:var(--accent-tint);color:var(--accent-2);padding:2px 7px;border-radius:5px}
.mc .sup{display:flex;align-items:center;gap:7px;color:var(--ink-2);font-size:12px;white-space:nowrap;overflow:hidden}
.mc .sup .sav{width:18px;height:18px;border-radius:5px;background:var(--slate-bg);color:var(--ink-2);font-size:8px;font-weight:700;display:grid;place-items:center;flex-shrink:0}
.mc .sup.none{color:var(--ink-4)}
.mc.val{font-family:var(--num);font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.mc.marg{font-family:var(--num);font-weight:600;color:var(--green);font-size:12px}
.mc.marg.tbd{color:var(--ink-4)}
.mc .eta{font-size:11.5px;color:var(--amber);font-weight:600}
.mc .eta.risk{color:var(--red)}
.owner-av{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:10px;font-weight:700;color:#fff}
.oav-d{background:#3b7df6} .oav-g{background:#8a5cf6}

/* Kanban (Board view, restyled Monday) */
.kanban{display:grid;grid-template-columns:repeat(6,minmax(216px,1fr));gap:13px;align-items:start}
.col{background:transparent;border-radius:var(--r);padding:0 1px}
.col h4{margin:0 4px 11px;font-size:11px;letter-spacing:.2px;color:var(--ink-2);display:flex;align-items:center;gap:8px;font-weight:700}
.col h4 .dot{width:9px;height:9px;border-radius:3px}
.col h4 .ct{margin-left:auto;font-family:var(--num);background:var(--card);border:1px solid var(--line-2);color:var(--ink-3);font-size:10.5px;padding:0 7px;border-radius:20px;font-weight:600}
.lcard{background:var(--card);border:1px solid var(--line);border-radius:9px;padding:12px;margin-bottom:9px;transition:.12s;position:relative;box-shadow:var(--sh-sm)}
.lcard:hover{border-color:var(--line-3);box-shadow:var(--sh-md)}
.lcard .cust{font-weight:600;font-size:13px;letter-spacing:-.1px}
.lcard .lid{font-family:var(--mono);font-size:10px;color:var(--ink-3);margin-top:2px}
.lane{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--ink-2);margin:10px 0}
.lane b{font-weight:500;color:var(--ink)} .lane .ar{color:var(--ink-4)}
.tags{display:flex;gap:5px;flex-wrap:wrap;margin:9px 0}
.tag{font-family:var(--num);font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:5px;background:var(--card-2);border:1px solid var(--line-2);color:var(--ink-2)}
.tag.grade{background:var(--accent-tint);color:var(--accent-2);border-color:transparent}
.lcard .prog{display:flex;gap:3px;margin:11px 0}
.lcard .prog i{height:3px;flex:1;border-radius:3px;background:var(--line-2)}
.lcard .prog i.on{background:var(--stage,var(--accent))}
.lcard .sup{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--ink-2)}
.lcard .sup .av{width:17px;height:17px;border-radius:5px;background:var(--slate-bg);color:var(--ink-2);font-size:8px;font-weight:700;display:grid;place-items:center}
.lfoot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding-top:10px;margin-top:11px}
.lfoot .money{font-family:var(--num);font-weight:700;font-size:15px;letter-spacing:-.03em}
.lfoot .marg{font-family:var(--num);font-size:10.5px;color:var(--green);font-weight:600;margin-top:1px}
.lfoot .eta{font-size:10.5px;color:var(--amber);font-weight:600;text-align:right}
.lcard.risk{border-color:#f1c4c4}
.lcard.risk .eta{color:var(--red)}
.ribbon{position:absolute;top:0;right:0;font-size:8.5px;font-weight:700;letter-spacing:.3px;color:#fff;background:var(--red);padding:3px 8px;border-radius:0 9px 0 8px;text-transform:uppercase}

/* Tables (Salesforce list view) */
.tbl-wrap{overflow:auto;border-radius:var(--r)}
table.tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.tbl thead th{font-size:10px;letter-spacing:.3px;text-transform:uppercase;color:var(--ink-3);font-weight:600;text-align:left;padding:11px 15px;border-bottom:1px solid var(--line-2);background:var(--card-2);position:sticky;top:0;z-index:1}
.tbl tbody td{padding:11px 15px;border-bottom:1px solid var(--line)}
.tbl tbody tr{transition:.1s}
.tbl tbody tr.row-click{cursor:pointer}
.tbl tbody tr:hover{background:var(--card-2)}
.tbl tbody tr.row-click:hover{box-shadow:inset 3px 0 0 var(--accent)}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl .num{font-family:var(--num);font-weight:600;font-variant-numeric:tabular-nums}
.tbl .strong{font-weight:600;letter-spacing:-.1px}
.tbl .sub{color:var(--ink-3);font-size:11px}

/* Badges (soft, secondary) */
.badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--num);font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:6px;letter-spacing:.1px;white-space:nowrap}
.badge .d{width:5px;height:5px;border-radius:50%;background:currentColor}
.b-green{color:#177e4e;background:var(--green-bg)} .b-amber{color:#9a6914;background:var(--amber-bg)}
.b-red{color:#b4322a;background:var(--red-bg)} .b-blue{color:#2b5fc0;background:var(--blue-bg)}
.b-teal{color:#0b7d7c;background:var(--teal-bg)} .b-violet{color:#6b44c4;background:var(--violet-bg)}
.b-slate{color:var(--gray);background:var(--slate-bg)}

/* Feed */
.feed{padding:5px 5px}
.fitem{display:flex;gap:11px;padding:11px 13px;border-radius:8px;transition:.1s;align-items:flex-start}
.fitem:hover{background:var(--card-2)}
.fitem .fi{width:30px;height:30px;border-radius:7px;display:grid;place-items:center;flex-shrink:0}
.fitem .fi svg{width:15px;height:15px}
.fi.deals{background:var(--purple-bg);color:var(--purple)} .fi.ops{background:var(--teal-bg);color:var(--teal)} .fi.money{background:var(--green-bg);color:#177e4e}
.fitem .ft{font-size:12.5px;line-height:1.45}
.fitem .ft b{font-weight:600}
.fitem .fm{font-size:10.5px;color:var(--ink-3);margin-top:3px;display:flex;align-items:center;gap:6px}
.fitem .chan{font-family:var(--mono);font-size:10px;color:var(--accent);font-weight:600}

/* Drawer (Salesforce record) */
.scrim{position:fixed;inset:0;background:rgba(20,22,28,.4);opacity:0;pointer-events:none;transition:.2s;z-index:50}
.scrim.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100vh;width:min(600px,96vw);background:var(--bg);border-left:1px solid var(--line-3);box-shadow:var(--sh-lg);transform:translateX(100%);transition:.28s cubic-bezier(.4,0,.2,1);z-index:60;display:flex;flex-direction:column}
.drawer.show{transform:none}
.dh{padding:20px 24px 17px;border-bottom:1px solid var(--line);background:var(--card)}
.dh .top-row{display:flex;align-items:flex-start;gap:12px}
.dh h2{font-size:19px;font-weight:700;margin:0;letter-spacing:-.4px}
.dh .lid{font-size:11.5px;color:var(--ink-3);margin-top:4px}
.dh .x{margin-left:auto;width:30px;height:30px;border-radius:7px;border:1px solid var(--line-2);background:var(--card);display:grid;place-items:center;color:var(--ink-3);transition:.12s;flex-shrink:0}
.dh .x:hover{background:var(--hover);color:var(--ink)}
.dh .x svg{width:15px;height:15px}
.dbody{padding:20px 24px;overflow:auto;flex:1}
.route{display:flex;align-items:stretch;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:15px 16px;margin-bottom:20px}
.route .node{flex:1}
.route .node small{font-size:9.5px;letter-spacing:.3px;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.route .node b{display:block;font-size:13.5px;margin-top:5px;font-weight:600}
.route .node span{font-size:11.5px;color:var(--ink-3)}
.route .mid{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--accent);min-width:58px}
.route .mid svg{width:18px;height:18px}
.route .mid .line{width:100%;height:2px;background:repeating-linear-gradient(90deg,var(--line-3) 0 5px,transparent 5px 10px);margin:6px 0}
.route .mid small{font-family:var(--mono);font-size:9px;color:var(--ink-3)}
.fields{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:20px}
.field{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.field small{font-size:9.5px;letter-spacing:.3px;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.field b{display:block;font-size:14.5px;margin-top:5px;font-weight:700;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.field b.pos{color:#177e4e}
.sub-h{font-size:10.5px;letter-spacing:.3px;text-transform:uppercase;color:var(--ink-3);font-weight:600;margin:0 0 12px}
.timeline{margin-bottom:22px}
.tl{display:flex;gap:13px;padding-bottom:16px;position:relative}
.tl:before{content:"";position:absolute;left:7px;top:17px;bottom:-2px;width:2px;background:var(--line-2)}
.tl:last-child:before{display:none}
.tl .td{width:15px;height:15px;border-radius:50%;border:2px solid var(--line-3);background:var(--bg);margin-top:1px;flex-shrink:0;z-index:1}
.tl.done .td{background:var(--green);border-color:var(--green)}
.tl.cur .td{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.tl .tt{font-size:12.5px;font-weight:600}
.tl.todo .tt{color:var(--ink-3);font-weight:500}
.tl .ts{font-size:10.5px;color:var(--ink-3);margin-top:2px}
.docrow{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--line);border-radius:9px;padding:11px 13px;margin-bottom:9px}
.docrow .di{width:32px;height:32px;border-radius:7px;background:var(--card-2);color:var(--ink-2);border:1px solid var(--line);display:grid;place-items:center;flex-shrink:0}
.docrow .di svg{width:15px;height:15px}
.docrow b{font-size:12.5px;font-weight:600} .docrow small{display:block;color:var(--ink-3);font-size:11px;margin-top:1px}
.docrow .st{margin-left:auto}
.dactions{padding:13px 24px 18px;border-top:1px solid var(--line);background:var(--card);display:grid;grid-template-columns:1fr 1fr;gap:8px}
.dactions .full{grid-column:1/-1}
/* tabbed load record */
.rec-id{font-size:11px;color:var(--ink-3);font-weight:600;margin-bottom:3px;letter-spacing:.2px}
.dtabs{display:flex;gap:1px;margin-top:14px;border-bottom:1px solid var(--line);margin-bottom:-17px}
.dtab{border:0;background:transparent;color:var(--ink-3);font-size:12.5px;font-weight:600;padding:8px 13px;border-bottom:2px solid transparent;cursor:pointer;margin-bottom:-1px}
.dtab:hover{color:var(--ink)}
.dtab.on{color:var(--accent-2);border-bottom-color:var(--accent)}
.fields.four{grid-template-columns:repeat(4,1fr);gap:9px}
.fields.four .field{padding:10px 11px}
.fields.four .field b{font-size:13px}
.stop{display:flex;gap:12px;margin-bottom:13px}
.stop-n{width:24px;height:24px;border-radius:50%;color:#fff;font-weight:700;font-size:12px;display:grid;place-items:center;flex-shrink:0;margin-top:2px}
.stop-b{flex:1;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:13px 15px}
.stop-h{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.stop-h b{font-size:13px;font-weight:700}
.stop-addr{font-size:13px;font-weight:600}
.stop-sub{font-size:12px;color:var(--ink-2);margin-top:2px}
.stop-meta{font-size:11.5px;color:var(--ink-3);margin-top:8px;padding-top:8px;border-top:1px solid var(--line)}
.acct-row{display:flex;justify-content:space-between;align-items:center;padding:10px 2px;border-bottom:1px solid var(--line);font-size:13px;color:var(--ink-2)}
.acct-row b{font-family:var(--num);font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}
.acct-row.total{border-bottom:0;border-top:1px solid var(--line-2);margin-top:3px}
.acct-row.total span{font-weight:700;color:var(--ink)}
.acct-row b.pos{color:#177e4e}

/* Modal */
.modal-scrim{position:fixed;inset:0;background:rgba(20,22,28,.5);backdrop-filter:blur(3px);display:grid;place-items:center;opacity:0;pointer-events:none;transition:.18s;z-index:80;padding:24px}
.modal-scrim.show{opacity:1;pointer-events:auto}
.modal{width:min(640px,100%);max-height:88vh;background:var(--bg);border-radius:var(--r-lg);box-shadow:var(--sh-lg);display:flex;flex-direction:column;transform:scale(.98);transition:.2s;overflow:hidden;border:1px solid var(--line-2)}
.modal-scrim.show .modal{transform:none}
.modal-h{padding:17px 21px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;background:var(--card)}
.modal-h .mi{width:36px;height:36px;border-radius:9px;background:var(--accent-tint);color:var(--accent);display:grid;place-items:center;flex-shrink:0}
.modal-h .mi svg{width:18px;height:18px}
.modal-h h3{font-size:16px;font-weight:700;margin:0;letter-spacing:-.3px}
.modal-h .ms{font-size:11px;color:var(--ink-3);margin-top:2px}
.modal-h .x{margin-left:auto;color:var(--ink-3);width:30px;height:30px;border-radius:7px;border:1px solid var(--line-2);background:var(--card);display:grid;place-items:center}
.modal-h .x svg{width:15px;height:15px}
.modal-b{padding:20px 21px;overflow:auto}
.email-preview{background:var(--card);border:1px solid var(--line-2);border-radius:10px;overflow:hidden;margin-top:4px}
.email-preview .eh{padding:13px 16px;border-bottom:1px solid var(--line);background:var(--card-2);font-size:12.5px}
.email-preview .eh .erow{display:flex;gap:8px;margin-bottom:5px}
.email-preview .eh .erow:last-child{margin-bottom:0}
.email-preview .eh .ek{font-family:var(--mono);font-size:10px;color:var(--ink-3);min-width:44px;text-transform:uppercase;letter-spacing:.4px;padding-top:1px}
.email-preview .eh .ev{font-weight:500;color:var(--ink)}
.email-preview .eb{padding:16px;white-space:pre-wrap;font-size:13px;line-height:1.65;color:var(--ink)}
.email-preview .att{display:flex;gap:8px;padding:0 16px 14px;flex-wrap:wrap}
.att-pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;background:var(--card-2);border:1px solid var(--line-2);padding:5px 10px;border-radius:7px;color:var(--ink-2)}
.att-pill svg{width:13px;height:13px;color:var(--accent)}
.note{display:flex;gap:9px;align-items:flex-start;background:var(--amber-bg);border:1px solid #f0dcb0;border-radius:9px;padding:11px 13px;font-size:12px;color:#86600f;margin-top:14px;line-height:1.5}
.note.ok{background:var(--green-bg);border-color:#c5e6d4;color:#177e4e}
.note svg{width:15px;height:15px;flex-shrink:0;margin-top:1px}
.modal-f{padding:14px 21px;border-top:1px solid var(--line);background:var(--card);display:flex;gap:9px;align-items:center}
.modal-f .meta{font-size:10.5px;color:var(--ink-3)}
.modal-f .spacer{margin-left:auto}

/* Forms */
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:6px}
.fg{display:flex;flex-direction:column;gap:5px}
.fg.full{grid-column:1/-1}
.fg label{font-size:9.5px;letter-spacing:.3px;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.fg input,.fg select,.fg textarea{font-family:var(--sans);font-size:13px;padding:9px 11px;border:1px solid var(--line-2);border-radius:8px;background:var(--card);color:var(--ink);outline:none;transition:.12s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--accent);box-shadow:var(--ring)}

/* Toast */
.toast-wrap{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:90;display:flex;flex-direction:column;gap:9px;align-items:center}
.toast{display:flex;align-items:center;gap:11px;background:var(--ink);color:#fff;padding:12px 15px 12px 13px;border-radius:9px;box-shadow:var(--sh-lg);font-size:12.5px;font-weight:500;transform:translateY(18px);opacity:0;transition:.24s}
.toast.show{transform:none;opacity:1}
.toast .ti{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;background:var(--green);color:#fff}
.toast .ti svg{width:13px;height:13px}
.toast .undo{margin-left:6px;font-size:11px;font-weight:700;color:#fff;border:1px solid rgba(255,255,255,.25);padding:5px 9px;border-radius:7px}
.toast .undo:hover{background:rgba(255,255,255,.1)}
.toast .ring{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.6)}

/* misc */
.demo-tag{position:fixed;bottom:14px;right:16px;font-family:var(--mono);font-size:10px;color:var(--ink-3);background:var(--card);border:1px solid var(--line-2);padding:5px 11px;border-radius:20px;z-index:40}
.empty{padding:54px 20px;text-align:center;color:var(--ink-3)}
.empty .serif{font-size:16px;color:var(--ink-2);margin-bottom:6px;font-weight:600}
.split-bar{height:6px;border-radius:6px;background:var(--line-2);overflow:hidden;margin-top:7px}
.split-bar i{display:block;height:100%;background:var(--green)}

/* Clients */
.clients-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.clientcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px;cursor:pointer;transition:.12s}
.clientcard:hover{border-color:var(--line-3);box-shadow:var(--sh-md)}
.cc-top{display:flex;align-items:center;gap:11px;margin-bottom:15px}
.cc-logo{width:38px;height:38px;border-radius:9px;background:var(--accent-tint);color:var(--accent-2);display:grid;place-items:center;font-weight:700;font-size:13px;flex-shrink:0;letter-spacing:-.5px}
.cc-logo.lg{width:46px;height:46px;border-radius:11px;font-size:16px}
.cc-id{min-width:0;flex:1}
.cc-id b{font-size:13.5px;font-weight:600;display:block;letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cc-id small{font-size:11.5px;color:var(--ink-3)}
.cc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cc-stats small{font-size:9px;letter-spacing:.2px;text-transform:uppercase;color:var(--ink-3);font-weight:600;display:block}
.cc-stats b{font-family:var(--num);font-size:16px;font-weight:700;margin-top:5px;display:block;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.cc-stats b.pos{color:#177e4e}
.cc-foot{display:flex;align-items:center;gap:7px;margin-top:14px}

/* Quote Desk */
.quote-desk{display:grid;grid-template-columns:1.06fr 1fr;gap:18px;align-items:start}
.qd-slider{margin:20px 0 6px}
.qd-slider input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:6px;margin:13px 0 8px;background:var(--line-2);outline:none}
.qd-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid var(--accent);box-shadow:var(--sh-md);cursor:grab}
.qd-slider input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid var(--accent);box-shadow:var(--sh-md);cursor:grab}
.qd-scale{display:flex;justify-content:space-between;font-family:var(--num);font-size:10px;color:var(--ink-3);font-weight:600}
.qd-check{display:flex;align-items:center;gap:9px;margin-top:15px;font-size:12.5px;color:var(--ink-2);font-weight:500;background:var(--card-2);border:1px solid var(--line-2);padding:11px 13px;border-radius:8px;cursor:pointer}
.qd-check input{width:15px;height:15px;accent-color:var(--accent)}
.qd-summary{position:sticky;top:78px}
.qd-bignum{display:flex;flex-direction:column;align-items:center;text-align:center;padding:8px 0 18px;border-bottom:1px solid var(--line);margin-bottom:17px}
.qd-bignum span{font-size:10px;letter-spacing:.3px;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.qd-bignum b{font-family:var(--num);font-size:44px;font-weight:800;letter-spacing:-.05em;line-height:1;margin:9px 0 4px;font-variant-numeric:tabular-nums}
.qd-bignum small{font-size:11.5px;color:var(--ink-3)}
.qd-econ,.qd-annual{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.qd-annual{margin-top:15px;padding-top:15px;border-top:1px solid var(--line)}
.qd-econ small,.qd-annual small{font-size:9px;letter-spacing:.2px;text-transform:uppercase;color:var(--ink-3);font-weight:600;display:block}
.qd-econ b,.qd-annual b{font-family:var(--num);font-size:16px;font-weight:700;margin-top:4px;display:block;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.qd-econ b.pos,.qd-annual b.pos{color:#177e4e}
.qd-margin-bar{margin:16px 0 4px}
.qd-margin-bar i{display:block;height:8px;border-radius:5px;background:var(--green);transition:width .25s}
.qd-margin-bar span{display:block;font-size:10.5px;color:var(--ink-3);margin-top:7px;font-weight:500}

/* Charts */
.legend{font-size:10.5px;color:var(--ink-3);display:inline-flex;align-items:center;gap:5px;font-weight:500}
.legend i{width:9px;height:9px;border-radius:3px;display:inline-block;margin-left:7px}
.legend .lg1{background:var(--accent)} .legend .lg2{background:var(--teal)}
.gbars{display:flex;align-items:flex-end;gap:5px;height:168px;padding-top:10px}
.gcol{display:flex;flex-direction:column;align-items:center;height:100%}
.gbar-pair{display:flex;align-items:flex-end;gap:3px;height:100%;width:100%;justify-content:center}
.gb{width:38%;max-width:16px;border-radius:4px 4px 0 0;transition:height .4s cubic-bezier(.2,.7,.2,1)}
.gb1{background:var(--accent)} .gb2{background:var(--teal)}
.gcol small{font-size:9.5px;color:var(--ink-3);margin-top:9px;font-weight:500}
.hbars{display:flex;flex-direction:column;gap:13px}
.hbar{display:grid;grid-template-columns:96px 1fr auto;align-items:center;gap:12px}
.hb-l{font-size:12px;font-weight:600;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hb-track{height:10px;border-radius:6px;background:var(--card-2);overflow:hidden;border:1px solid var(--line)}
.hb-track i{display:block;height:100%;border-radius:6px;transition:width .5s cubic-bezier(.2,.7,.2,1)}
.hb-v{font-family:var(--num);font-size:12px;font-weight:700;color:var(--ink);min-width:54px;text-align:right;font-variant-numeric:tabular-nums}

/* Login */
.login{position:fixed;inset:0;z-index:200;display:grid;grid-template-columns:1.05fr .95fr;background:var(--card);transition:opacity .5s,visibility .5s}
.login.hide{opacity:0;visibility:hidden;pointer-events:none}
.login-hero{position:relative;overflow:hidden;background:#1a1c20;color:#eef0f3;padding:54px 56px;display:flex;flex-direction:column}
.login-hero:after{content:"";position:absolute;inset:0;background:radial-gradient(640px 440px at 86% 6%,rgba(192,84,44,.26),transparent 62%),radial-gradient(540px 460px at 8% 102%,rgba(59,125,246,.14),transparent 60%)}
.login-hero>*{position:relative;z-index:1}
.login-brand{display:flex;align-items:center;gap:12px}
.login-brand .mark{width:42px;height:42px;border-radius:11px;background:var(--accent);display:grid;place-items:center}
.login-brand .mark svg{width:24px;height:24px}
.login-brand .wm{font-size:18px;font-weight:700;color:#fff}
.login-brand .wm small{display:block;font-size:9.5px;letter-spacing:.3px;color:#9aa0ac;font-weight:500;margin-top:3px}
.login-hero .tagwrap{margin-top:auto}
.login-hero h2{font-size:38px;font-weight:700;line-height:1.1;letter-spacing:-1.2px;margin:0 0 18px;max-width:16ch}
.login-hero p{font-size:14px;color:#aab0bc;line-height:1.6;max-width:42ch;margin:0 0 30px;font-weight:450}
.login-stats{display:flex;gap:34px;border-top:1px solid rgba(255,255,255,.1);padding-top:24px}
.login-stats .s b{font-family:var(--num);font-size:24px;font-weight:700;color:#fff;display:block;letter-spacing:-.04em}
.login-stats .s span{font-size:9.5px;letter-spacing:.3px;text-transform:uppercase;color:#8a909c;font-weight:600;margin-top:3px;display:block}
.login-form{display:flex;flex-direction:column;justify-content:center;padding:54px 64px;max-width:520px}
.login-form .eyebrow{font-size:11px;letter-spacing:.4px;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:13px}
.login-form h1{font-size:27px;font-weight:700;letter-spacing:-.6px;margin:0 0 8px}
.login-form .lede{color:var(--ink-3);font-size:13.5px;margin:0 0 30px}
.login-form .fg{margin-bottom:15px}
.login-form .fg input{padding:11px 13px;font-size:14px}
.login-form .row{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;color:var(--ink-3);margin:3px 0 24px}
.login-form .row a{color:var(--accent);font-weight:600}
.login-form .big{width:100%;justify-content:center;padding:12px;font-size:14px;border-radius:9px}
.login-form .sso{display:flex;gap:10px;margin-top:13px}
.login-form .sso .btn{flex:1;justify-content:center}
.login-divider{display:flex;align-items:center;gap:12px;margin:22px 0;color:var(--ink-4);font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;font-weight:600}
.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--line-2)}
.login-foot{margin-top:30px;font-size:11.5px;color:var(--ink-4)}

@media(max-width:1280px){.kpis{grid-template-columns:repeat(3,1fr)}.clients-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:1100px){.kanban{grid-template-columns:repeat(3,minmax(200px,1fr))}.grid-2{grid-template-columns:1fr}.quote-desk{grid-template-columns:1fr}.qd-summary{position:static}.login{grid-template-columns:1fr;place-items:center}.login-hero{display:none}.login-form{margin:0 auto;width:100%}}
@media(max-width:760px){.app{grid-template-columns:1fr}.side{display:none}.kpis{grid-template-columns:repeat(2,1fr)}}
