/* Dredan's Landscaping — ops app styles.
 * Mobile-first PWA. Locked via Toph (design/toph). Tokens = Modern Blade brand kit.
 */
:root{
  --g900:#13341f; --g700:#1f6b3b; --g600:#268a4c; --g500:#33a35c;
  --lime:#9ad37a; --cream:#f6f8f3; --ink:#1a2420; --muted:#5b6b60;
  --line:#dbe5d9; --card:#fff; --warn:#9a6a1e;
  --gold:#caa53d; --gold-d:#9a7d1e;
  --tabh:64px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0;-webkit-font-smoothing:antialiased}
html,body{margin:0}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--cream);color:var(--ink);
  padding-bottom:calc(var(--tabh) + env(safe-area-inset-bottom));min-height:100vh}

/* ---- app bar (per-screen gradient header) ---- */
.appbar{background:linear-gradient(160deg,var(--g700),var(--g600));color:#fff;padding:16px 18px;
  padding-top:calc(16px + env(safe-area-inset-top))}
.appbar .top{display:flex;justify-content:space-between;align-items:center;font-size:13px;opacity:.95}
.brandline{display:flex;align-items:center;gap:6px;font-weight:800}
.brandline svg{width:16px;height:18px}
.appbar h2{font-size:21px;margin-top:10px;letter-spacing:-.3px}
.appbar .meta{font-size:13px;opacity:.92;margin-top:3px}
.appbar .link{font-size:13px;font-weight:700;color:#fff;background:none;border:0;opacity:.95;cursor:pointer}

/* ---- content ---- */
.wrap{max-width:520px;margin:0 auto;padding:14px}

/* ---- bottom tab bar ---- */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:20;height:calc(var(--tabh) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);background:#fff;border-top:1px solid var(--line);display:flex}
.tabbar button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  border:0;background:none;font-size:11px;color:var(--muted);font-weight:600;cursor:pointer}
.tabbar button.on{color:var(--g700);font-weight:800}
.tabbar svg{width:22px;height:22px}
.tabbar.hide{display:none}

/* ---- shared tokens ---- */
.cad{display:inline-block;font-size:10px;font-weight:800;padding:3px 7px;border-radius:6px;letter-spacing:.4px}
.cad.W{background:#e7f4ec;color:var(--g700)}
.cad.BI{background:#e4eefb;color:#1f5fb0}
.cad.M{background:#f6ecdc;color:#9a6a1e}
.cad.ONCALL{background:#eee;color:#666}
.crewdot{width:10px;height:10px;border-radius:50%;flex:0 0 auto;display:inline-block}
.chip{display:inline-block;font-size:11px;font-weight:800;padding:4px 9px;border-radius:999px;background:#e4eefb;color:#1f5fb0;letter-spacing:.3px}
.muted{color:var(--muted)}
.empty{color:var(--muted);text-align:center;padding:30px 12px;font-style:italic}
.confirm{display:inline-block;font-size:11px;font-weight:800;color:#9a6a1e;background:#f6ecdc;padding:2px 7px;border-radius:6px;margin-top:3px}

.fab{position:fixed;right:16px;bottom:calc(var(--tabh) + 16px + env(safe-area-inset-bottom));
  width:56px;height:56px;border-radius:18px;background:var(--g600);color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 24px rgba(20,80,40,.4);z-index:15;border:0;cursor:pointer}
.fab svg{width:26px;height:26px;fill:#fff}

.toast{position:fixed;left:50%;bottom:calc(var(--tabh) + 20px);transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:11px 18px;border-radius:11px;z-index:40;font-size:14px;font-weight:600;box-shadow:0 8px 22px rgba(0,0,0,.25)}

/* ============ ROUTE ============ */
.ctrlrow{display:flex;gap:8px;margin-bottom:13px}
.ctrlrow select,.ctrlrow input{flex:1;background:#fff;border:1px solid var(--line);border-radius:11px;padding:10px 11px;font-size:14px;font-family:inherit;color:var(--ink)}
.swiper{position:relative;overflow:hidden;border-radius:20px;border:1px solid var(--line);box-shadow:0 6px 18px rgba(16,40,22,.10);background:#fff;touch-action:pan-y}
.track{display:flex;width:200%;transition:transform .32s cubic-bezier(.4,0,.2,1)}
.track.s2{transform:translateX(-50%)}
.slide{flex:0 0 50%;min-height:300px}
.cardpad{padding:18px}
.kicker{font-size:12px;font-weight:800;color:var(--g600);letter-spacing:1.5px}
.addr{font-size:26px;font-weight:800;line-height:1.06;margin:6px 0 4px;letter-spacing:-.5px;color:var(--g900)}
.who{font-size:15px;color:var(--muted)}
.acts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}
.btn{display:flex;align-items:center;justify-content:center;gap:8px;height:54px;border:0;border-radius:14px;font-size:16px;font-weight:800;cursor:pointer;width:100%;color:#fff;text-decoration:none}
.btn svg{width:21px;height:21px}
.btn.nav-b{background:var(--g600)} .btn.call-b{background:var(--ink)} .btn.full{grid-column:1/3}
.btn.disabled{opacity:.45;pointer-events:none}
/* slide-to-complete */
.slidedone{position:relative;height:54px;margin-top:10px;border-radius:14px;background:var(--g500);
  display:flex;align-items:center;justify-content:center;overflow:hidden;user-select:none;touch-action:none}
.slidedone span{font-size:16px;font-weight:800;color:#0c2c18;letter-spacing:.2px;padding-left:30px;pointer-events:none}
.slidedone .knob{position:absolute;left:4px;top:4px;width:46px;height:46px;border-radius:11px;background:#0c2c18;
  display:flex;align-items:center;justify-content:center;touch-action:none}
.slidedone .knob svg{width:24px;height:24px;fill:none;stroke:#fff;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.skiprow{text-align:center;margin-top:10px}
.skiprow button{border:0;background:none;color:var(--muted);font-size:13px;font-weight:700;cursor:pointer;text-decoration:underline}
.routedone{padding:30px 18px;text-align:center}
.routedone .big{font-size:20px;font-weight:800;color:var(--g700);margin-bottom:4px}
/* map slide */
.maparea{position:relative;height:300px;background:
  repeating-linear-gradient(0deg,#e8efe6,#e8efe6 1px,transparent 1px,transparent 26px),
  repeating-linear-gradient(90deg,#e8efe6,#e8efe6 1px,transparent 1px,transparent 26px),#eef3ec;
  display:flex;flex-direction:column}
.maptop{position:absolute;top:12px;left:12px;background:#0c2c18;color:#fff;font-size:11px;font-weight:800;padding:6px 11px;border-radius:999px;z-index:2}
.mapstops{flex:1;overflow:auto;padding:46px 12px 12px}
.mapstop{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.86);border-radius:10px;padding:7px 10px;margin-bottom:6px;font-size:13px;font-weight:600}
.mapstop .pin{width:22px;height:22px;border-radius:50%;background:var(--g600);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:800;flex:0 0 auto}
.mapbtn{padding:12px}
.dots{display:flex;gap:6px;justify-content:center;margin-top:12px}
.dot{width:7px;height:7px;border-radius:50%;background:#cdd9cb}
.dot.on{background:var(--g600);width:18px;border-radius:99px}
.swipehint{text-align:center;color:var(--muted);font-size:12px;margin-top:7px}
.upnext{margin-top:18px}
.upnext .lab{font-size:12px;font-weight:800;color:var(--muted);letter-spacing:1px;margin-bottom:8px}
.mini{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:13px;padding:11px 12px;margin-bottom:8px}
.mini .n{width:28px;height:28px;border-radius:50%;background:var(--g700);color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px;flex:0 0 auto}
.mini.skip{opacity:.5}
.mini .g{min-width:0}
.mini .g b{font-size:14px}
.mini .g span{font-size:12px;color:var(--muted);display:block}
.mini .cad{margin-left:auto}

/* ============ YARDS ============ */
.search{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:0 12px;margin-bottom:10px}
.search svg{width:18px;height:18px;fill:var(--muted);flex:0 0 auto}
.search input{flex:1;border:0;padding:11px 0;font-size:15px;background:none;color:var(--ink);outline:none}
.vtog{display:flex;background:#eef3ec;border-radius:11px;padding:4px;gap:4px;margin-bottom:13px}
.vtog button{flex:1;border:0;background:transparent;padding:9px 0;border-radius:8px;font-weight:800;font-size:13px;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}
.vtog button.on{background:#fff;color:var(--g700);box-shadow:0 1px 3px rgba(0,0,0,.12)}
.vtog svg{width:15px;height:15px;fill:currentColor}
.grp{background:#fff;border:1px solid var(--line);border-radius:16px;margin-bottom:12px;overflow:hidden}
.ghead{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--line);cursor:pointer}
.grp.solo .ghead{border-bottom:0}
.ava{width:34px;height:34px;border-radius:10px;background:var(--g700);color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px;flex:0 0 auto}
.gname{font-weight:800;font-size:15px;line-height:1.1}
.gsub{font-size:12px;color:var(--muted)}
.gcount{margin-left:auto;font-size:12px;font-weight:800;color:var(--g600);background:#e7f4ec;padding:4px 9px;border-radius:999px}
.ghead .cad{margin-left:auto}
.prow{display:flex;align-items:center;gap:9px;padding:10px 14px;border-top:1px solid #eef3ec;cursor:pointer}
.grp .prow:first-of-type{border-top:0}
.paddr{font-weight:700;font-size:14px}
.pcity{font-size:12px;color:var(--muted)}
.prow .right{margin-left:auto;display:flex;align-items:center;gap:7px}

/* ============ WEEK ============ */
.wswitch{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.wseg{display:flex;background:#eef3ec;border-radius:11px;padding:4px;gap:4px;flex:1}
.wseg button{flex:1;border:0;background:transparent;padding:8px 0;border-radius:8px;font-weight:800;font-size:13px;color:var(--muted);cursor:pointer;line-height:1.1}
.wseg button.on{background:#fff;color:var(--g700);box-shadow:0 1px 3px rgba(0,0,0,.12)}
.wseg small{display:block;font-size:10px;font-weight:700;opacity:.7}
.parity{font-size:11px;font-weight:800;color:#1f5fb0;background:#e4eefb;padding:6px 10px;border-radius:999px;flex:0 0 auto}
.crewbar{display:flex;gap:8px;margin-bottom:13px;overflow:auto}
.crewbar .cpill{flex:1;white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:7px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:9px 12px;font-weight:800;font-size:13px;color:var(--muted);cursor:pointer}
.crewbar .cpill.on{border-color:var(--g600);background:#eef7f0;color:var(--g700)}
.day{background:#fff;border:1px solid var(--line);border-radius:15px;margin-bottom:11px;overflow:hidden}
.day.today{border-color:var(--g500);box-shadow:0 0 0 2px rgba(51,163,92,.18)}
.dhead{display:flex;align-items:center;gap:9px;padding:11px 13px;background:#f4f8f2;border-bottom:1px solid var(--line)}
.dname{font-weight:800;font-size:15px}
.ddate{font-size:12px;color:var(--muted)}
.dcount{margin-left:auto;font-size:12px;font-weight:800;color:var(--muted)}
.todaytag{font-size:10px;font-weight:800;color:#fff;background:var(--g600);padding:3px 7px;border-radius:999px;margin-left:auto}
.wstop{display:flex;align-items:center;gap:8px;padding:9px 13px;border-top:1px solid #eef3ec;font-size:14px;cursor:pointer}
.wstop:first-of-type{border-top:0}
.wstop .nm{font-weight:700}
.wstop .ct{font-size:12px;color:var(--muted)}
.wstop .right{margin-left:auto;display:flex;align-items:center;gap:6px}
.dayempty{padding:11px 13px;color:#9aa89e;font-size:13px;font-style:italic}

/* ============ CREW ============ */
.ccard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;margin-bottom:12px}
.ctop{display:flex;align-items:center;gap:11px}
.cava{width:44px;height:44px;border-radius:13px;color:#fff;display:grid;place-items:center;font-weight:800;font-size:17px;flex:0 0 auto}
.cname{font-weight:800;font-size:16px;line-height:1.1}
.crole{font-size:12px;color:var(--muted);margin-top:2px}
.cedit{margin-left:auto;font-size:13px;font-weight:800;color:var(--g600);background:none;border:0;cursor:pointer}
.cmeta{display:flex;gap:8px;margin-top:12px}
.stat{flex:1;background:#f4f8f2;border-radius:11px;padding:9px;text-align:center}
.stat b{display:block;font-size:18px;color:var(--g700)}
.stat span{font-size:11px;color:var(--muted);font-weight:700}
.homerow{display:flex;align-items:center;gap:7px;margin-top:11px;font-size:13px;color:var(--muted)}
.homerow svg{width:15px;height:15px;fill:var(--g600);flex:0 0 auto}
.load{margin-top:12px}
.loadlab{display:flex;justify-content:space-between;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:5px}
.loadtrack{height:10px;border-radius:999px;background:#eef3ec;overflow:hidden}
.loadfill{height:100%;border-radius:999px}
.nudge{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:#9a6a1e;background:#f6ecdc;border-radius:10px;padding:9px 11px;margin-top:9px;cursor:pointer}
.nudge svg{width:15px;height:15px;fill:#9a6a1e;flex:0 0 auto}
.nudge .go{margin-left:auto;font-weight:800;color:#7a5414;white-space:nowrap}
.sect{font-size:12px;font-weight:800;color:var(--muted);letter-spacing:1px;margin:18px 2px 9px}
.srow{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 13px;margin-bottom:9px;cursor:pointer;width:100%;text-align:left;border:1px solid var(--line)}
.srow svg{width:18px;height:18px;fill:var(--g600);flex:0 0 auto}
.srow .lab{font-weight:700;font-size:14px}
.srow .val{margin-left:auto;font-size:13px;color:var(--muted)}
.addbtn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;border:1.5px dashed #bcd2bb;background:#fff;color:var(--g700);border-radius:13px;padding:13px;font-weight:800;font-size:14px;cursor:pointer}
.addbtn svg{width:18px;height:18px;fill:var(--g700)}

/* ============ FORM / EDITOR ============ */
.editscreen{display:flex;flex-direction:column;min-height:100vh}
.fld{margin-bottom:14px}
.fld label{display:block;font-size:12px;font-weight:800;color:var(--muted);letter-spacing:.4px;margin-bottom:6px}
.input{background:#fff;border:1px solid var(--line);border-radius:11px;padding:12px;font-size:15px;color:var(--ink);font-family:inherit;width:100%}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.seg{display:flex;background:#eef3ec;border-radius:11px;padding:4px;gap:4px}
.seg button{flex:1;border:0;background:transparent;padding:10px 0;border-radius:8px;font-weight:800;font-size:14px;color:var(--muted);cursor:pointer}
.seg button.on{background:#fff;color:var(--g700);box-shadow:0 1px 3px rgba(0,0,0,.12)}
.days{display:flex;gap:6px}
.days button{flex:1;border:1px solid var(--line);background:#fff;border-radius:9px;padding:9px 0;font-weight:800;font-size:13px;color:var(--muted);cursor:pointer}
.days button.on{background:var(--g600);border-color:var(--g600);color:#fff}
.hint{font-size:12px;color:var(--muted);margin-top:6px}
.crewpick{display:flex;gap:8px;flex-wrap:wrap}
.crewpick button{flex:1;min-width:120px;display:flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--line);background:#fff;border-radius:11px;padding:11px 0;font-weight:800;font-size:14px;cursor:pointer}
.crewpick button.on{border-color:var(--g600);background:#eef7f0;color:var(--g700)}
.savebar{position:sticky;bottom:0;padding:12px 14px;border-top:1px solid var(--line);background:#fff;display:flex;gap:8px}
.savebar .btn{flex:1}
.btn.danger{background:#fff;color:#b3402a;border:1px solid #e8c9c0;flex:0 0 auto;width:auto;padding:0 18px}
.advtoggle{border:0;background:none;color:var(--g600);font-weight:800;font-size:13px;cursor:pointer;padding:4px 0}

/* ===== Crew editor: pay model ===== */
.payseg{display:flex;background:#eef3ec;border-radius:11px;padding:4px;gap:4px}
.payseg button{flex:1;border:0;background:transparent;padding:11px 6px;border-radius:8px;font-weight:800;font-size:13px;color:var(--muted);cursor:pointer}
.payseg button.on{background:#fff;color:var(--g700);box-shadow:0 1px 3px rgba(0,0,0,.12)}
.rateinput{display:flex;align-items:center;background:#fff;border:1px solid var(--line);border-radius:11px;overflow:hidden}
.rateinput .rpre{padding:0 14px;font-weight:800;color:var(--g700);background:#eef7f0;align-self:stretch;display:flex;align-items:center;border-right:1px solid var(--line)}
.rateinput .input{border:0;border-radius:0}
.ratepresets{display:flex;gap:8px;margin-top:8px}
.ratepresets button{flex:1;border:1px solid var(--line);background:#fff;border-radius:10px;padding:9px 6px;font-weight:800;font-size:12px;color:var(--g700);cursor:pointer}
.ratepresets button:active{background:#eef7f0}
.ownernote{background:#eef7f0;border:1px solid var(--line);border-radius:11px;padding:12px 13px;font-size:13px;color:var(--g700);font-weight:600;line-height:1.45}

/* ===== Route start point (home vs current location) ===== */
.startrow{display:flex;align-items:center;gap:10px;margin:12px 0 4px}
.startrow .slab{font-size:12px;font-weight:800;color:var(--muted);letter-spacing:.4px;flex:0 0 auto}
.startseg{display:flex;background:#eef3ec;border-radius:10px;padding:3px;gap:3px;flex:1}
.startseg button{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;border:0;background:transparent;padding:9px 4px;border-radius:8px;font-weight:800;font-size:13px;color:var(--muted);cursor:pointer}
.startseg button svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2}
.startseg button.on{background:#fff;color:var(--g700);box-shadow:0 1px 2px rgba(0,0,0,.1)}
.startwhere{font-size:12px;color:var(--muted);margin:0 0 10px 2px}
.endpt.cur{border-style:solid;border-color:var(--g500);background:#eef7f0}
.endpt.cur .pin{background:var(--g600)}
.endpt.cur .pin svg{fill:none;stroke:#fff;stroke-width:2}
.actsheet button small{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-top:1px}

/* ===== Week/Month toggle ===== */
.modetog{display:flex;background:#eef3ec;border-radius:12px;padding:4px;gap:4px;margin-bottom:12px}
.modetog button{flex:1;border:0;background:transparent;padding:9px 0 7px;border-radius:9px;font-weight:800;font-size:14px;color:var(--muted);cursor:pointer;line-height:1.1}
.modetog button small{display:block;font-size:10px;font-weight:700;opacity:.7;margin-top:2px}
.modetog button.on{background:#fff;color:var(--g700);box-shadow:0 1px 3px rgba(0,0,0,.12)}

/* ===== Month money meter ===== */
.lensrow{display:flex;gap:8px;margin-bottom:10px}
.lens{display:flex;background:#eef3ec;border-radius:10px;padding:3px;gap:3px;flex:1}
.lens button{flex:1;border:0;background:transparent;padding:8px 4px;border-radius:8px;font-weight:800;font-size:12px;color:var(--muted);cursor:pointer}
.lens button.on{background:#fff;color:var(--g700);box-shadow:0 1px 2px rgba(0,0,0,.1)}
.lens.money button.on{color:var(--gold-d)}
.monthnav{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.monthnav b{font-size:15px;font-weight:800;color:var(--ink)}
.monthnav button{width:40px;height:40px;border-radius:11px;border:1px solid var(--line);background:#fff;font-size:20px;color:var(--g700);cursor:pointer;line-height:1}
.totline{display:flex;justify-content:space-between;align-items:flex-end;background:linear-gradient(160deg,var(--g900),var(--g700));color:#fff;border-radius:16px;padding:15px 17px;margin-bottom:12px}
.totline .tlab{font-size:12px;font-weight:700;opacity:.8;letter-spacing:.4px}
.totline .tbig{font-size:30px;font-weight:800;letter-spacing:-.5px;margin-top:2px}
.totline .tsm{font-size:12px;text-align:right;opacity:.85;line-height:1.5}
.wkhead{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-bottom:5px}
.wkhead span{text-align:center;font-size:11px;font-weight:800;color:var(--muted)}
.mcal{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.mcell{aspect-ratio:1/1.05;border:1px solid var(--line);border-radius:10px;background:#fff;padding:5px 4px;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;overflow:hidden}
.mcell.off{border:0;background:transparent;cursor:default}
.mcell .md{font-size:11px;font-weight:700;color:var(--muted)}
.mcell .mv{font-size:12px;font-weight:800;color:var(--g700);line-height:1.1}
.mcell .mz{color:var(--line);font-weight:700}
.mcell.zero{background:#fbfcfa}
.mcell.zero .mv{color:var(--line)}
.mcell.heavy{background:#eef7f0;border-color:var(--g500)}
.mcell.heavy .mv{color:var(--gold-d)}
.mcell.today{border:2px solid var(--g600);box-shadow:0 0 0 2px #eef7f0}
.mlegend{text-align:center;font-size:12px;color:var(--muted);margin-top:12px}

/* ===== Route builder ===== */
.crewtog{display:flex;gap:8px;margin-bottom:12px}
.crewtog button{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--line);background:#fff;border-radius:11px;padding:11px 0;font-weight:800;font-size:13px;color:var(--muted);cursor:pointer}
.crewtog button.on{border-color:var(--g600);background:#eef7f0;color:var(--g700)}
.crewtog .cd{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
.optbar{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--muted);background:#f4f8f2;border:1px solid var(--line);border-radius:11px;padding:9px 12px;margin-bottom:10px}
.optbar svg{width:17px;height:17px;fill:none;stroke:var(--g600);stroke-width:2;flex:0 0 auto}
.optbar .reopt{margin-left:auto;border:0;background:none;color:var(--g600);font-weight:800;font-size:13px;cursor:pointer}
.endpt{display:flex;align-items:center;gap:11px;background:#fff;border:1px dashed var(--line);border-radius:12px;padding:11px 13px}
.endpt .pin{width:30px;height:30px;border-radius:9px;background:#eef7f0;display:grid;place-items:center;flex:0 0 auto}
.endpt .pin svg{width:17px;height:17px;fill:var(--g600)}
.endpt .g{flex:1;min-width:0}
.endpt .g b{font-size:11px;font-weight:800;letter-spacing:1px;color:var(--muted);display:block}
.endpt .g span{font-size:14px;color:var(--ink);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.endpt .chg{border:0;background:none;color:var(--g600);font-weight:800;font-size:13px;cursor:pointer;flex:0 0 auto}
.leg{width:2px;height:14px;background:var(--line);margin:2px 0 2px 28px}
.bldrow{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 11px;margin-bottom:8px;touch-action:pan-y}
.bldrow.drag{box-shadow:0 8px 22px rgba(16,40,22,.18);opacity:.95;border-color:var(--g500)}
.bldrow .grip{display:flex;flex-direction:column;gap:3px;padding:4px 2px;cursor:grab;flex:0 0 auto;touch-action:none}
.bldrow .grip i{width:14px;height:2px;border-radius:2px;background:var(--line);display:block}
.bldrow .ordn{width:26px;height:26px;border-radius:50%;color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px;flex:0 0 auto}
.bldrow .g{flex:1;min-width:0}
.bldrow .g b{font-size:14px;font-weight:700;color:var(--ink);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bldrow .g span{font-size:12px;color:var(--muted);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bldrow .bmeta{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex:0 0 auto}
.bldrow .bmeta .t{font-size:11px;color:var(--muted);font-weight:700}
.bldrow .rowmenu{border:0;background:none;font-size:20px;color:var(--muted);cursor:pointer;padding:0 4px;line-height:1;flex:0 0 auto;align-self:stretch;min-width:34px}
.totbar{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:800;color:var(--ink);padding:12px 4px 4px}
.addrow{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;border:1.5px dashed var(--g500);background:#fff;color:var(--g700);border-radius:12px;padding:13px 0;font-weight:800;font-size:14px;cursor:pointer;margin-top:8px}
.addrow svg{width:18px;height:18px;fill:var(--g600)}

/* ===== Action sheet ===== */
.sheetwrap{position:fixed;inset:0;z-index:60}
.sheetback{position:absolute;inset:0;background:rgba(16,30,20,.42)}
.actsheet{position:absolute;left:0;right:0;bottom:0;background:#fff;border-radius:20px 20px 0 0;padding:10px 12px calc(16px + env(safe-area-inset-bottom));box-shadow:0 -8px 30px rgba(0,0,0,.22)}
.actsheet.up{animation:sheetup .2s ease}
@keyframes sheetup{from{transform:translateY(100%)}to{transform:translateY(0)}}
.actsheet .ah{font-size:11px;font-weight:800;letter-spacing:1px;color:var(--muted);padding:8px 8px 10px}
.actsheet button{display:flex;align-items:center;gap:12px;width:100%;border:0;background:none;padding:13px 8px;font-size:15px;font-weight:700;color:var(--ink);cursor:pointer;text-align:left;border-radius:10px}
.actsheet button:active{background:#f2f6f0}
.actsheet button.warn{color:#b3402a}
.actsheet .ic{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;flex:0 0 auto}
.actsheet .ic svg{width:17px;height:17px}
.actsheet .ic.blue{background:#e4eefb}.actsheet .ic.blue svg{fill:#1f5fb0}
.actsheet .ic.green{background:#e7f4ec}.actsheet .ic.green svg{fill:var(--g600)}
.actsheet .ic.amber{background:#f6ecdc}.actsheet .ic.amber svg{fill:var(--warn)}
.actsheet .ic.red{background:#fbe7e2}.actsheet .ic.red svg{fill:#b3402a}

/* ===== Crew home (Mix A+B) ===== */
.asbtn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:12px;border:1px solid var(--line);background:#fafcf9;color:var(--g700);border-radius:11px;padding:12px 0;font-weight:800;font-size:14px;cursor:pointer}
.asbtn svg{width:17px;height:17px;fill:var(--g600)}
.earnstrip{background:linear-gradient(155deg,var(--cc,var(--g700)),color-mix(in srgb,var(--cc,var(--g700)) 70%,#000));color:#fff;border-radius:16px;padding:14px 16px;margin-bottom:12px}
.earnstrip .erow{display:flex;justify-content:space-between;align-items:baseline}
.earnstrip .elab{font-size:13px;font-weight:700;opacity:.9}
.earnstrip .ebig{font-size:26px;font-weight:800;letter-spacing:-.5px}
.earnstrip .etrack{height:7px;border-radius:99px;background:rgba(255,255,255,.28);margin:9px 0 7px;overflow:hidden}
.earnstrip .efill{height:100%;border-radius:99px;background:var(--lime);transition:width .3s}
.earnstrip .esub{font-size:12px;font-weight:600;opacity:.92}
.crewnav{display:flex;background:#eef3ec;border-radius:12px;padding:4px;gap:4px;margin-bottom:14px}
.crewnav button{flex:1;border:0;background:transparent;padding:10px 0;border-radius:9px;font-weight:800;font-size:14px;color:var(--muted);cursor:pointer}
.crewnav button.on{background:#fff;color:var(--g700);box-shadow:0 1px 3px rgba(0,0,0,.12)}
.rcard{border-radius:20px;border:1px solid var(--line);box-shadow:0 6px 18px rgba(16,40,22,.10);background:#fff;overflow:hidden;margin-bottom:14px}
.kicker .paytag{float:right;background:#eef7f0;color:var(--gold-d);border-radius:99px;padding:2px 10px;font-size:13px;font-weight:800;letter-spacing:0}
.mini .pay{font-size:14px;font-weight:800;color:var(--gold-d);flex:0 0 auto}
.moneybar{display:flex;align-items:center;justify-content:space-between;width:100%;background:linear-gradient(160deg,var(--g900),var(--g700));color:#fff;border:0;border-radius:14px;padding:14px 17px;font-size:14px;font-weight:700;cursor:pointer;margin-top:6px}
.moneybar .mb-amt{font-weight:800;font-size:16px}
.cwlist{margin-bottom:12px}
.cwday{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 13px;margin-bottom:8px}
.cwday.on{border-color:var(--g600);background:#eef7f0}
.cwday .cwd{flex:0 0 56px}
.cwday .cwd b{font-size:14px;font-weight:800;color:var(--ink);display:block}
.cwday .cwd span{font-size:11px;color:var(--muted);display:block}
.cwday .cwmid{flex:1;font-size:13px;color:var(--muted);font-weight:600}
.cwday .cwamt{font-size:16px;font-weight:800;color:var(--g700)}
.paycard{background:linear-gradient(155deg,var(--cc,var(--g700)),color-mix(in srgb,var(--cc,var(--g700)) 68%,#000));color:#fff;border-radius:16px;padding:16px 17px;margin-bottom:12px}
.paycard .pck{font-size:11px;font-weight:800;letter-spacing:1px;opacity:.85}
.paycard .pcbig{font-size:21px;font-weight:800;margin:4px 0 6px;letter-spacing:-.3px}
.paycard .pcsub{font-size:12px;opacity:.9;line-height:1.5}
.paylist{margin-top:4px}
.payrow{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:12px 14px;margin-bottom:7px;font-size:14px;font-weight:700;color:var(--ink)}
.payrow .pm{margin-left:auto;font-size:12px;color:var(--muted);font-weight:700}
.payrow .pa{font-size:15px;font-weight:800;color:var(--gold-d);min-width:56px;text-align:right}

/* ===== Leads / Quotes ===== */
.lchips{display:flex;gap:8px;margin-bottom:12px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.lchips .lchip{flex:0 0 auto;border:1px solid var(--line);background:#fff;border-radius:99px;padding:9px 15px;font-weight:800;font-size:13px;color:var(--muted);cursor:pointer}
.lchips .lchip.on{background:var(--g700);border-color:var(--g700);color:#fff}
.leadcard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px 14px;margin-bottom:10px;cursor:pointer;box-shadow:0 2px 8px rgba(16,40,22,.05)}
.leadcard.over{border-color:#e8c9a0;background:#fffdf8}
.leadcard .lhead{display:flex;align-items:center;justify-content:space-between;gap:8px}
.leadcard .lname{font-size:16px;font-weight:800;color:var(--ink)}
.leadcard .laddr{font-size:13px;color:var(--muted);margin-top:2px}
.leadcard .lfoot{display:flex;align-items:center;justify-content:space-between;margin-top:9px}
.leadcard .lq{font-size:16px;font-weight:800;color:var(--gold-d)}
.leadcard .lq i{font-style:normal;font-size:13px;font-weight:700;color:var(--warn)}
.leadcard .lage{font-size:12px;color:var(--muted);font-weight:600}
.lstat{font-size:11px;font-weight:800;letter-spacing:.5px;padding:4px 10px;border-radius:99px;text-transform:uppercase;flex:0 0 auto}
.lstat.new{background:#f6ecdc;color:var(--warn)}
.lstat.quoted{background:#e4eefb;color:#1f5fb0}
.lstat.won{background:#e7f4ec;color:var(--g700)}
.lstat.lost{background:#eee;color:#777}
.lnudge{display:flex;align-items:center;gap:7px;margin-top:10px;padding:8px 10px;background:#fbf3e3;border-radius:10px;font-size:12.5px;font-weight:700;color:var(--warn)}
.lnudge svg{width:15px;height:15px;fill:var(--warn);flex:0 0 auto}
.convbtn{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;margin-top:6px;border:1.5px solid var(--g500);background:#eef7f0;color:var(--g700);border-radius:12px;padding:14px 0;font-weight:800;font-size:15px;cursor:pointer}
.convbtn svg{width:19px;height:19px}

/* ===== Embedded route map (Leaflet) ===== */
.routemap{height:300px;min-height:300px;flex:0 0 auto;border-radius:16px;overflow:hidden;border:1px solid var(--line);margin-bottom:10px;position:relative;z-index:0;background:#e9eef0}
.routemap .leaflet-container{font:inherit;background:#e9eef0}
.rmpin{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px;border:2px solid #fff;box-shadow:0 1px 5px rgba(0,0,0,.4)}
.hmpin{width:28px;height:28px;border-radius:9px;display:grid;place-items:center;background:var(--g900);border:2px solid #fff;box-shadow:0 1px 5px rgba(0,0,0,.4)}
.hmpin svg{width:15px;height:15px;fill:var(--lime)}
.mapnote{font-size:12px;color:var(--warn);background:#f6ecdc;border:1px solid #ecd9b6;border-radius:9px;padding:7px 10px;margin-bottom:10px;text-align:center}
.leaflet-popup-content{font:inherit;font-size:13px;line-height:1.4}
