/* ============================================================================
   Onyx — design system stylesheet (LIGHT MODE ONLY)
   Tokens + components per ONYX_DESIGN_SYSTEM.md. No dark theme. Soft depth only.
   ========================================================================== */
:root{
  /* brand */
  --teal:#0F766E; --teal-600:#0D9488; --teal-700:#0B5E57; --teal-50:#E7F6F2;
  --grad-teal:linear-gradient(135deg,#0F766E 0%,#12A594 100%);
  /* ink / text */
  --ink:#0B1B2B; --text:#1B2A3A; --muted:#5A6B7B; --faint:#90A0B0;
  /* surfaces (LIGHT ONLY) */
  --bg:#F4F7FA; --surface:#FFFFFF; --surface-2:#FBFCFE; --line:#E7ECF2; --line-2:#DCE3EB;
  /* trade */
  --gw:#16A34A; --gw-50:#E9F8EF; --el:#2563EB; --el-50:#E8F0FE;
  /* semantic */
  --green:#16A34A; --green-50:#E9F8EF; --amber:#D97706; --amber-50:#FEF4E6;
  --red:#DC2626; --red-50:#FDECEC; --orange:#EA580C; --orange-50:#FEEEE5; --blue:#2563EB; --blue-50:#E8F0FE;
  /* elevation — soft, never heavy */
  --sh-1:0 1px 2px rgba(16,24,40,.04), 0 1px 3px rgba(16,24,40,.06);
  --sh-2:0 4px 12px rgba(16,24,40,.08); --sh-3:0 12px 28px rgba(16,24,40,.10);
  /* radius / motion */
  --r-sm:8px; --r:12px; --r-lg:16px; --r-xl:20px;
  --ease:cubic-bezier(.4,0,.2,1); --dur:170ms;
  /* layout */
  --side-w:240px; --topbar-h:54px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0}
body{
  background:var(--bg);color:var(--text);
  font:400 14.5px/1.5 "Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
.tnum{font-variant-numeric:tabular-nums}
button{font-family:inherit}

/* ---- typography helpers ---- */
.h1{font-size:22px;font-weight:600;color:var(--ink);letter-spacing:-.2px;margin:0}
.h2{font-size:18px;font-weight:600;color:var(--ink);margin:0}
.h3{font-size:15px;font-weight:600;color:var(--ink);margin:0}
.label{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}
.small{font-size:12.5px;color:var(--muted)}

/* ============================================================================
   APP SHELL — responsive: sidebar (>=900px) / bottom-tabs (<900px)
   ========================================================================== */
.shell{min-height:100vh}

/* --- mobile top bar (compact: brand + bell) --- */
.topbar{
  position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.9);backdrop-filter:saturate(1.5) blur(10px);
  border-bottom:1px solid var(--line);
  padding:max(10px,env(safe-area-inset-top)) 14px 10px;
}
.brand{display:flex;align-items:center;gap:9px;min-width:0}
.brand .mark{
  width:30px;height:30px;border-radius:9px;background:var(--grad-teal);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;letter-spacing:.5px;
  box-shadow:var(--sh-1);flex:0 0 auto;
}
.brand .wordmark{font-size:17px;font-weight:600;letter-spacing:-.2px;color:var(--ink)}

/* --- sidebar (desktop) --- */
.sidebar{display:none}
/* sidebar collapse controls — desktop only (shown inside the >=900px block) */
.sb-collapse,.sb-reopen{display:none}

/* --- main content --- */
.content{
  max-width:1180px;margin:0 auto;
  padding:16px 14px calc(74px + env(safe-area-inset-bottom));
}

/* --- bottom tab bar (mobile) --- */
.tabbar{
  position:fixed;left:0;right:0;bottom:0;z-index:40;display:flex;
  background:rgba(255,255,255,.96);backdrop-filter:saturate(1.5) blur(10px);
  border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom);
}
.tabbar button{
  flex:1 1 0;background:none;border:0;color:var(--muted);
  padding:8px 4px 9px;font-size:11px;font-weight:600;display:flex;flex-direction:column;
  align-items:center;gap:3px;cursor:pointer;transition:color var(--dur) var(--ease);
}
.tabbar button .ic{font-size:19px;line-height:1}
.tabbar button.on{color:var(--teal)}

/* ---- DESKTOP layout (>=900px) ---- */
@media(min-width:900px){
  .topbar{display:none}
  .tabbar{display:none}
  .shell{display:grid;grid-template-columns:var(--side-w) 1fr;min-height:100vh}
  .sidebar{
    display:flex;flex-direction:column;position:sticky;top:0;height:100vh;
    background:var(--surface);border-right:1px solid var(--line);padding:18px 14px 14px;
  }
  .sidebar .brand{padding:4px 8px 18px}
  .sidebar .brand .mark{width:34px;height:34px;border-radius:10px;font-size:18px}
  .sidebar .brand .wordmark{font-size:19px}
  .navlist{display:flex;flex-direction:column;gap:3px;margin-top:4px}
  .navitem{
    display:flex;align-items:center;gap:11px;width:100%;text-align:left;cursor:pointer;
    background:none;border:0;border-radius:var(--r);padding:10px 12px;
    font-size:14.5px;font-weight:500;color:var(--muted);position:relative;
    transition:background var(--dur) var(--ease),color var(--dur) var(--ease);
  }
  .navitem .ic{font-size:18px;width:20px;text-align:center}
  .navitem:hover{background:var(--surface-2);color:var(--text)}
  .navitem.on{
    background:var(--teal-50);color:var(--teal);font-weight:600;
    border-top-left-radius:0;border-bottom-left-radius:0;
  }
  .navitem.on::before{
    content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:3px;background:var(--teal);
  }
  .sidebar .sb-bell{
    margin-top:8px;display:flex;align-items:center;gap:11px;width:100%;cursor:pointer;
    background:none;border:0;border-radius:var(--r);padding:10px 12px;color:var(--muted);
    font-size:14.5px;font-weight:500;position:relative;transition:background var(--dur) var(--ease);
  }
  .sidebar .sb-bell:hover{background:var(--surface-2);color:var(--text)}
  .sidebar .sb-bell .ic{font-size:18px;width:20px;text-align:center}
  .userchip{
    margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--r);
    background:var(--surface-2);border:1px solid var(--line);
  }
  .userchip .av{
    width:34px;height:34px;border-radius:50%;background:var(--grad-teal);color:#fff;
    display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex:0 0 auto;
  }
  .userchip .who{min-width:0}
  .userchip .nm{font-size:13.5px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .userchip .rl{font-size:11.5px;color:var(--muted)}
  .content{padding:26px 28px 40px}

  /* ---- collapsible sidebar (desktop) ---- */
  .sidebar{transition:transform var(--dur) var(--ease)}
  /* collapse control in the sidebar header (push to the right of the wordmark) */
  .sb-collapse{
    display:inline-flex;align-items:center;justify-content:center;margin-left:auto;
    width:30px;height:30px;border-radius:var(--r-sm);background:none;border:0;color:var(--muted);
    font-size:18px;cursor:pointer;flex:0 0 auto;transition:background var(--dur) var(--ease),color var(--dur) var(--ease);
  }
  .sb-collapse:hover{background:var(--surface-2);color:var(--text)}
  .sidebar .brand{display:flex;align-items:center}
  /* reopen (menu) button — top-left of the content, only when collapsed */
  .sb-reopen{
    display:none;align-items:center;justify-content:center;position:fixed;top:18px;left:16px;z-index:50;
    width:40px;height:40px;border-radius:var(--r);background:var(--surface);border:1px solid var(--line);
    color:var(--teal);font-size:20px;cursor:pointer;box-shadow:var(--sh-1);
    transition:box-shadow var(--dur) var(--ease),background var(--dur) var(--ease);
  }
  .sb-reopen:hover{box-shadow:var(--sh-2);background:var(--surface-2)}

  /* collapsed state — sidebar slides fully out to the left, content takes full width */
  .shell.nav-collapsed{grid-template-columns:0 1fr}
  .shell.nav-collapsed .sidebar{
    transform:translateX(-100%);width:0;min-width:0;padding-left:0;padding-right:0;
    border-right:0;overflow:hidden;pointer-events:none;
  }
  .shell.nav-collapsed .sb-reopen{display:inline-flex}
  /* give the content room for the floating menu button when collapsed */
  .shell.nav-collapsed .content{padding-left:68px}
}

/* tactile press feedback on interactive cards */
.kpi:active,.tile2:active,.job:active{transform:translateY(0);box-shadow:var(--sh-1)}

/* ============================================================================
   BELL + NOTIFICATIONS
   ========================================================================== */
.bellwrap{margin-left:auto;position:relative}
.bellbtn{
  position:relative;background:var(--surface);border:1px solid var(--line);color:var(--teal);
  width:38px;height:38px;border-radius:11px;font-size:17px;line-height:1;display:flex;
  align-items:center;justify-content:center;box-shadow:var(--sh-1);cursor:pointer;
  transition:box-shadow var(--dur) var(--ease);
}
.bellbtn:hover{box-shadow:var(--sh-2)}
.badge{
  position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;
  background:var(--red);color:#fff;font-size:11px;font-weight:700;line-height:18px;text-align:center;
  box-shadow:0 0 0 2px var(--surface);display:none;
}
.badge.on{display:block}
.notif{
  position:absolute;top:46px;right:0;width:min(340px,86vw);max-height:70vh;overflow-y:auto;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--sh-3);z-index:60;display:none;
}
.notif.on{display:block}
.notif .nhdr{
  display:flex;align-items:center;justify-content:space-between;gap:8px;padding:13px 14px 11px;
  border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--surface);
}
.notif .nhdr b{font-size:15px;font-weight:600;color:var(--ink)}
.enablebtn{
  background:var(--grad-teal);color:#fff;border:0;border-radius:var(--r-sm);padding:7px 11px;font-size:12px;
  font-weight:600;cursor:pointer;box-shadow:var(--sh-1);transition:filter var(--dur) var(--ease);
}
.enablebtn:hover{filter:brightness(1.05)}
.enablebtn[disabled]{opacity:.55;box-shadow:none}
.enablebtn.ok{background:var(--green-50);color:#15803d;box-shadow:none}
.nitem{
  display:block;padding:11px 14px;border-bottom:1px solid var(--line);cursor:pointer;background:none;
  border-left:0;border-right:0;border-top:0;width:100%;text-align:left;transition:background var(--dur) var(--ease);
}
.nitem:last-child{border-bottom:0}
.nitem:hover{background:var(--surface-2)}
.nitem .nsite{font-weight:600;font-size:13.5px;color:var(--ink)}
.nitem .nchg{font-size:12.5px;color:var(--muted);margin-top:3px}
.nitem .nchg .to{color:var(--teal);font-weight:600}
.nitem .nat{font-size:11.5px;color:var(--faint);margin-top:4px}
.nempty{padding:28px 14px;text-align:center;color:var(--muted);font-size:13px}

/* ============================================================================
   SEGMENTED CONTROLS (trade + period)
   ========================================================================== */
.seg{
  display:inline-flex;background:var(--bg);border:1px solid var(--line);border-radius:999px;
  padding:3px;gap:2px;
}
.seg button{
  background:none;border:0;color:var(--muted);font-size:12.5px;font-weight:600;
  padding:6px 14px;border-radius:999px;cursor:pointer;white-space:nowrap;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.seg button:hover{color:var(--text)}
.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--sh-1)}
/* primary teal variant (period toggle) */
.seg.seg-teal button.on{background:var(--grad-teal);color:#fff;box-shadow:var(--sh-1)}
/* trade toggle: active segment tinted by trade */
.seg .sg-gw.on{background:var(--gw-50);color:var(--gw)}
.seg .sg-el.on{background:var(--el-50);color:var(--el)}
/* schedule trade toggle: active "All" = teal (primary) */
.tradeseg .sg-all.on{background:var(--grad-teal);color:#fff}
.tradeseg button{display:inline-flex;align-items:center;gap:6px}
.tradeseg button .sw{width:8px;height:8px;border-radius:50%}
.tradeseg .sg-gw .sw{background:var(--gw)}
.tradeseg .sg-el .sw{background:var(--el)}

/* ============================================================================
   DASHBOARD
   ========================================================================== */
.dashtop{
  display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px;
}
.dashtop .tt{min-width:0}
.dashtop .updated{font-size:11.5px;color:var(--faint);margin-top:3px}
.controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}

/* dashboard week navigator — same control style as the schedule week nav */
.dashwknav{margin:0 0 12px}
/* performance caption shown when viewing a past (non-current) week */
.perfcaption{
  display:inline-flex;align-items:center;gap:7px;margin:0 0 14px;padding:7px 13px;
  background:var(--teal-50);border:1px solid #BFE6DF;border-radius:999px;
  font-size:12.5px;font-weight:600;color:var(--teal-700);
}
.perfcaption i{font-size:15px;line-height:1;color:var(--teal)}

/* KPI grid */
.kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:560px){.kpis{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.kpis{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1100px){.kpis{grid-template-columns:repeat(3,1fr)}}

.kpi{
  position:relative;text-align:left;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:17px 15px 14px;cursor:pointer;box-shadow:var(--sh-1);overflow:hidden;
  display:flex;flex-direction:column;gap:10px;
  transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.kpi:hover{box-shadow:var(--sh-2);transform:translateY(-1px)}
.kpi::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--teal)}
.kpi.t-red::before{background:var(--red)}
.kpi.t-green::before{background:var(--green)}
.kpi.t-orange::before{background:var(--orange)}
.kpi.t-amber::before{background:var(--amber)}
.kpi.t-grey::before{background:var(--teal)}
.kpi .top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.kpi .lab{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);line-height:1.3}
.kpi .chip{
  width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:16px;flex:0 0 auto;background:var(--teal-50);color:var(--teal);
}
.kpi .num{font-size:34px;font-weight:700;line-height:1;letter-spacing:-.7px;color:var(--ink)}
.kpi .splitbar{display:flex;height:6px;border-radius:999px;overflow:hidden;background:var(--line);gap:2px}
.kpi .splitbar i{display:block;height:100%;border-radius:999px;min-width:0}
.kpi .splitbar i.gw{background:var(--gw)}
.kpi .splitbar i.el{background:var(--el)}
.kpi .splitbar i.none{background:var(--line-2);flex:1}
.kpi .leg{display:flex;align-items:center;gap:12px;font-size:11.5px;color:var(--muted);font-weight:500}
.kpi .leg .lg{display:inline-flex;align-items:center;gap:5px}
.kpi .leg .sw{width:8px;height:8px;border-radius:3px}
.kpi .leg .sw.gw{background:var(--gw)}
.kpi .leg .sw.el{background:var(--el)}
.kpi .sub{font-size:11.5px;color:var(--faint);font-weight:500}
/* tone tinting on chip + number */
.kpi.t-red .chip{background:var(--red-50);color:var(--red)} .kpi.t-red .num{color:var(--red)}
.kpi.t-green .chip{background:var(--green-50);color:var(--green)}
.kpi.t-orange .chip{background:var(--orange-50);color:var(--orange)}
.kpi.t-amber .chip{background:var(--amber-50);color:var(--amber)}
.kpi.t-grey .chip{background:var(--teal-50);color:var(--teal)}

/* chart card */
.panel{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:16px 18px;box-shadow:var(--sh-1);margin-top:18px;
}
.panel .phdr{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}
.panel .phdr .h3{font-size:15px}
.chartlegend{display:flex;gap:16px;font-size:12px;color:var(--muted);font-weight:500}
.chartlegend .lg{display:inline-flex;align-items:center;gap:6px}
.chartlegend .sw{width:10px;height:10px;border-radius:3px}
.chartlegend .sw.gw{background:var(--gw)}
.chartlegend .sw.el{background:var(--el)}
.chartwrap{position:relative;height:240px;margin-top:10px}

/* secondary metric tiles */
.sectitle{margin:22px 2px 10px}
.tiles2{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:560px){.tiles2{grid-template-columns:repeat(4,1fr)}}
.tile2{
  text-align:left;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);
  padding:13px 14px;cursor:pointer;display:flex;flex-direction:column;gap:5px;
  transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.tile2:hover{box-shadow:var(--sh-1);transform:translateY(-1px)}
.tile2 .n{font-size:24px;font-weight:700;line-height:1;color:var(--ink);letter-spacing:-.4px}
.tile2.t-red .n{color:var(--red)} .tile2.t-amber .n{color:var(--amber)} .tile2.t-orange .n{color:var(--orange)}
.tile2 .l{font-size:12px;font-weight:600;color:var(--muted)}
.tile2 .s{font-size:11px;color:var(--faint);font-weight:500}

/* ============================================================================
   SCHEDULE — week nav, chips, filters, list
   ========================================================================== */
.schhdr{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:6px}
/* list ⇄ map view toggle */
.viewseg button{display:inline-flex;align-items:center;gap:6px;padding:6px 12px}
.viewseg button i{font-size:15px;line-height:1}
.viewseg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--sh-1)}
@media(max-width:380px){.viewseg button span{display:none}.viewseg button{padding:6px 11px}}
.wknav{
  display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:6px;box-shadow:var(--sh-1);width:fit-content;
}
.wknav b{font-size:14.5px;font-weight:600;color:var(--ink);min-width:120px;text-align:center}
.wknav button{
  background:var(--surface-2);color:var(--teal);border:1px solid var(--line);
  width:34px;height:32px;border-radius:var(--r-sm);font-size:17px;cursor:pointer;line-height:1;
  transition:background var(--dur) var(--ease);
}
.wknav button:hover{background:var(--teal-50)}
.chips{display:flex;gap:7px;overflow-x:auto;padding:12px 0 4px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{
  flex:0 0 auto;background:var(--surface);border:1px solid var(--line);color:var(--muted);
  padding:7px 13px;border-radius:999px;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.chip:hover{background:var(--surface-2)}
.chip.on{background:var(--grad-teal);border-color:transparent;color:#fff;font-weight:600}

/* --- schedule toolbar: trade toggle + search --- */
.schtoolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:12px 0 4px}
.searchbar{
  position:relative;display:flex;align-items:center;flex:1 1 260px;min-width:200px;
  background:var(--surface);border:1px solid var(--line);border-radius:999px;box-shadow:var(--sh-1);
  transition:box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.searchbar:focus-within{box-shadow:var(--sh-2);border-color:var(--line-2)}
.searchbar i{position:absolute;left:13px;font-size:16px;color:var(--faint);pointer-events:none}
.searchbar input{
  flex:1 1 auto;width:100%;background:none;border:0;outline:none;color:var(--text);
  font-family:inherit;font-size:16px;padding:10px 14px 10px 36px;border-radius:999px;
}
.searchbar input::placeholder{color:var(--faint)}
.searchhint{font-size:11.5px;color:var(--faint);font-weight:500;white-space:nowrap;padding-right:4px}

/* --- status filter pills (with optional colour swatch) --- */
.chip .sw{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px;vertical-align:-1px}
.chip.st.on{background:var(--surface);border-color:var(--line-2);color:var(--ink);box-shadow:var(--sh-1)}
.chiprow{display:flex;align-items:center;gap:7px;overflow-x:auto;padding:6px 0 4px;scrollbar-width:none}
.chiprow::-webkit-scrollbar{display:none}
.chiprow .rl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);flex:0 0 auto;margin-right:2px}

/* --- crews collapse toggle (declutter — crew pills collapsed by default) --- */
.crewfilter{margin:6px 0 2px}
.crewstoggle{
  display:inline-flex;align-items:center;gap:8px;min-height:40px;background:var(--surface);
  border:1px solid var(--line);color:var(--text);padding:8px 14px;border-radius:999px;
  font-size:13px;font-weight:600;cursor:pointer;box-shadow:var(--sh-1);
  transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.crewstoggle:hover{background:var(--surface-2);box-shadow:var(--sh-2)}
.crewstoggle i{font-size:16px;line-height:1;color:var(--muted)}
.crewstoggle .ct-count{
  font-size:11.5px;font-weight:600;color:var(--teal);background:var(--teal-50);
  padding:2px 9px;border-radius:999px;font-variant-numeric:tabular-nums;
}
.crewstoggle .ct-chev{transition:transform var(--dur) var(--ease)}
.crewfilter.open .crewstoggle{border-color:var(--line-2)}
.crewfilter.open .ct-chev{transform:rotate(180deg)}
/* crew-pill row hidden until the toggle is open */
.crewfilter .crewpills{display:none}
.crewfilter.open .crewpills{display:flex}

/* --- crew filter pills (§10 multi-select, colour-dot per crew) --- */
.crewpills{display:flex;flex-wrap:wrap;gap:8px;padding:10px 0 4px}
.crewpill{
  display:inline-flex;align-items:center;gap:7px;min-height:38px;background:var(--surface);
  border:1px solid var(--line);color:var(--text);padding:8px 13px;border-radius:999px;
  font-size:13px;font-weight:600;cursor:pointer;box-shadow:var(--sh-1);
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),
    border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.crewpill:hover{box-shadow:var(--sh-2)}
.crewpill .cdot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
.crewpill.all i{font-size:15px;line-height:1;color:var(--muted)}
.crewpill.all.on{background:var(--grad-teal);border-color:transparent;color:#fff}
.crewpill.all.on i{color:#fff}
/* active crew pill colours applied inline (crew tint); just bump weight */
.crewpill.on{font-weight:700}

.count{color:var(--muted);font-size:12.5px;margin:8px 2px 10px;font-weight:500}
.daygroup{margin-bottom:18px}
.dayhdr{font-size:11.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin:10px 2px 9px;font-weight:600}

.list{display:grid;gap:10px}
@media(min-width:720px){.list{grid-template-columns:repeat(2,1fr)}}
.job{
  display:flex;gap:12px;align-items:stretch;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:12px 13px;box-shadow:var(--sh-1);cursor:pointer;
  transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.job:hover{box-shadow:var(--sh-2);transform:translateY(-1px)}
.tstrip{
  flex:0 0 auto;width:54px;text-align:center;border-right:1px solid var(--line);padding-right:11px;
  display:flex;flex-direction:column;justify-content:center;
}
.tstrip .t{font-weight:700;font-size:14.5px;color:var(--ink);font-variant-numeric:tabular-nums}
.tstrip .tr{font-size:10.5px;color:var(--muted);margin-top:3px;text-transform:uppercase;letter-spacing:.4px}
.jmid{flex:1 1 auto;min-width:0}
.jsite{font-weight:600;font-size:14.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.jsub{color:var(--muted);font-size:12.5px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.jmeta{display:flex;align-items:center;gap:7px;margin-top:8px;flex-wrap:wrap}

/* status pills (semantic families) */
.pill{font-size:11px;padding:3px 9px;border-radius:999px;font-weight:600;line-height:1.4}
.s-green{background:var(--green-50);color:#15803d}
.s-amber{background:var(--amber-50);color:#b45309}
.s-blue{background:var(--blue-50);color:#1d4ed8}
.s-grey{background:#EEF2F7;color:#475569}
.s-red{background:var(--red-50);color:#b91c1c}
.s-orange{background:var(--orange-50);color:#c2410c}

/* trade badge — pill, GW green / EL blue */
.tbadge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;display:inline-flex;align-items:center;gap:5px}
.tbadge.gw{background:var(--gw-50);color:var(--gw)}
.tbadge.el{background:var(--el-50);color:var(--el)}
.tbadge.other{background:#F1EEFB;color:#7C3AED}
.tdot{width:7px;height:7px;border-radius:50%}
.jeng{font-size:11.5px;color:var(--muted)}

.empty,.err{color:var(--muted);text-align:center;padding:54px 20px}
.err{color:#b91c1c}
.notmapped{color:var(--amber);font-weight:600}

/* ============================================================================
   SCHEDULE MAP (Leaflet, design-system styled)
   ========================================================================== */
.mapwrap{position:relative;margin-top:6px}
.schedmap{
  height:62vh;min-height:360px;border-radius:var(--r-lg);border:1px solid var(--line);
  box-shadow:var(--sh-1);overflow:hidden;background:var(--surface-2);
}
@media(min-width:900px){.schedmap{height:520px}}
.mapempty{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;
  color:var(--muted);font-size:13.5px;padding:24px;pointer-events:none;
}
/* round crew-coloured pin with a white ring + soft shadow */
.mpin{
  display:block;width:16px;height:16px;border-radius:50%;
  box-shadow:0 0 0 2px #fff,0 1px 4px rgba(16,24,40,.35);
}
/* numbered run-order pin (single-crew sequence) — suite-style "1, 2, 3…" inside the marker */
.mpin-num{
  width:22px;height:22px;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums;
  font-family:"Plus Jakarta Sans",sans-serif;
}
/* crew legend below the map — swatch + crew name per colour */
.maplegend{
  display:flex;flex-wrap:wrap;gap:8px 14px;margin-top:12px;padding:12px 14px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-1);
}
.maplegend .ml{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:500;color:var(--text)}
.maplegend .mlsw{width:11px;height:11px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 1px rgba(16,24,40,.08)}
/* leaflet popup restyled to the design system */
.onyx-pop .leaflet-popup-content-wrapper{
  border-radius:var(--r);box-shadow:var(--sh-3);border:1px solid var(--line);
}
.onyx-pop .leaflet-popup-content{margin:12px 13px;font-family:"Plus Jakarta Sans",sans-serif;line-height:1.4}
.onyx-pop .leaflet-popup-tip{box-shadow:var(--sh-1)}
.mpop-site{font-size:14px;font-weight:600;color:var(--ink)}
.mpop-sub{font-size:12px;color:var(--muted);margin-top:2px;font-variant-numeric:tabular-nums}
/* crew (engineer) line in the pin popup — crew colour dot + name */
.mpop-crew{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--text);margin-top:6px}
.mpop-cdot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 1px rgba(16,24,40,.08)}
.mpop-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin:8px 0 2px}
.mpop-btn{
  display:inline-block;margin-top:8px;background:var(--grad-teal);color:#fff;border:0;border-radius:var(--r-sm);
  padding:7px 13px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:inherit;box-shadow:var(--sh-1);
  transition:filter var(--dur) var(--ease);
}
.mpop-btn:hover{filter:brightness(1.05)}
.leaflet-container{font-family:"Plus Jakarta Sans",sans-serif}

/* ============================================================================
   SCHEDULE TABLE — crew → day grid (whole week, fluid, no h-scroll)
   ========================================================================== */
/* TABLE VIEW VISIBILITY — exactly one layout per breakpoint (mobile-first).
   < 700px : stacked crew cards (.crewcards) ; the grid is hidden.
   >=700px : crew × day grid (.schgrid)      ; the crew cards are hidden.
   These two display rules are mutually exclusive across the 700px breakpoint.
   NOTE: the .crewcards layout properties live under a min-width:0 (always-on)
   block BELOW, so the visibility here is never re-overridden out of sequence. */
.schgrid{display:none}
.crewcards{display:flex;flex-direction:column;gap:12px;margin-top:6px}

@media(min-width:700px){
  .schgrid{
    display:grid;margin-top:6px;background:var(--surface);border:1px solid var(--line);
    border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden;
  }
  .crewcards{display:none}
  .sg-head,.sg-row{
    display:grid;grid-template-columns:minmax(132px,1.4fr) repeat(5,1fr);
  }
  /* clear 1px separator + zebra so each crew row reads as its own band */
  .sg-row{border-top:1px solid var(--line-2)}
  .sg-row:nth-child(even) .sg-crew,
  .sg-row:nth-child(even) .sg-cell{background:var(--surface-2)}
  .sg-row:hover .sg-crew,.sg-row:hover .sg-cell{background:var(--teal-50)}
  /* sticky header row */
  .sg-head{position:sticky;top:0;z-index:2;background:var(--surface-2)}
  .sg-crewhd,.sg-dayhd{
    font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);
    padding:11px 12px;border-right:1px solid var(--line);
  }
  .sg-dayhd:last-child,.sg-cell:last-child{border-right:0}
  .sg-dayhd .dcount{
    margin-left:6px;font-size:11px;font-weight:600;color:var(--faint);
    font-variant-numeric:tabular-nums;letter-spacing:0;text-transform:none;
  }
  /* crew label cell — carries the crew colour as a left accent bar */
  .sg-crew{
    position:relative;display:flex;align-items:center;gap:9px;padding:13px 12px 13px 16px;
    border-right:1px solid var(--line);background:var(--surface);min-width:0;
    transition:background var(--dur) var(--ease);
  }
  .sg-crew::before{
    content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
    background:var(--crew,var(--faint));
  }
  .sg-crew .cdot{width:11px;height:11px;border-radius:50%;flex:0 0 auto}
  .sg-crewtxt{min-width:0}
  .sg-cell{padding:8px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:6px;min-width:0;background:var(--surface);transition:background var(--dur) var(--ease)}
  .sg-cell.empty{background:var(--surface-2)}
  .sg-row:nth-child(even) .sg-cell.empty{background:var(--bg)}
  .crewname{font-size:13.5px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;letter-spacing:-.1px}
  .crewtot{font-size:10.5px;color:var(--muted);font-weight:500;margin-top:2px;display:block;font-variant-numeric:tabular-nums}
}

/* MOBILE (<700px): crew cards, only days that have jobs, chips stacked.
   (.crewcards display/flex is declared once above with the visibility rules so
   it is never re-asserted after the 700px media query — see the note there.) */
.crewcards{margin-top:8px;gap:14px}
.crewcard{
  position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--sh-2);overflow:hidden;
}
/* crew-colour left accent so each card is clearly its own crew */
.crewcard::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--crew,var(--faint));z-index:1;
}
.cc-hd{
  display:flex;align-items:center;gap:10px;padding:13px 15px 13px 17px;border-bottom:1px solid var(--line-2);
  background:var(--surface-2);
}
.cc-hd .cdot{width:13px;height:13px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 3px var(--crew,transparent);box-shadow:0 0 0 3px color-mix(in srgb,var(--crew,transparent) 16%,transparent)}
.cc-name{font-size:15px;font-weight:700;color:var(--ink);flex:1 1 auto;min-width:0;letter-spacing:-.1px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cc-tot{font-size:11.5px;font-weight:600;color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums;
  background:var(--bg);padding:3px 10px;border-radius:999px}
.cc-day{padding:10px 14px;border-bottom:1px solid var(--line)}
.cc-day:last-child{border-bottom:0}
.cc-dayhd{
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);
  margin-bottom:8px;display:flex;align-items:center;gap:7px;
}
.cc-daycount{
  font-size:11px;font-weight:600;color:var(--faint);font-variant-numeric:tabular-nums;
  letter-spacing:0;text-transform:none;
}
.cc-chips{display:flex;flex-direction:column;gap:7px}

/* job chip — 4px trade-coloured left border (shared by grid + crew cards) */
.jchip{
  display:block;width:100%;text-align:left;cursor:pointer;background:var(--surface);
  border:1px solid var(--line);border-left:4px solid var(--faint);border-radius:var(--r-sm);
  padding:7px 9px;box-shadow:var(--sh-1);transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.jchip:hover{box-shadow:var(--sh-2);transform:translateY(-1px)}
.jchip.gw{border-left-color:var(--gw)}
.jchip.el{border-left-color:var(--el)}
.jchip.other{border-left-color:#7C3AED}
.jchip .jc-site{font-size:12px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.jchip .jc-time{font-size:10.5px;color:var(--muted);font-variant-numeric:tabular-nums;margin-top:2px}
.jchip .jc-meta{margin-top:5px}
.jchip .pill{font-size:10px;padding:2px 7px}

/* ============================================================================
   JOB CARD
   ========================================================================== */
.card{padding:0 0 20px;max-width:760px}
.back{
  display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--line);
  color:var(--text);font-size:13.5px;font-weight:600;padding:7px 13px;border-radius:var(--r-sm);
  margin:0 0 14px;cursor:pointer;box-shadow:var(--sh-1);transition:background var(--dur) var(--ease);
}
.back:hover{background:var(--surface-2)}

/* ---- header band: site + address + status/trade + key facts (card depth) ---- */
.jhead{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--sh-2);padding:18px 18px 16px;margin-bottom:14px;
  background-image:linear-gradient(180deg,var(--surface-2),var(--surface) 64px);
}
.jh-site{font-size:22px;font-weight:600;color:var(--ink);margin:0;letter-spacing:-.3px;line-height:1.2}
.jh-sub{color:var(--muted);font-size:13.5px;margin-top:5px}
.jh-tags{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:12px}
.jh-tags .pill{font-size:11.5px;padding:4px 10px}
.jh-type{font-size:11.5px;font-weight:600;color:var(--muted);background:var(--bg);border:1px solid var(--line);
  padding:3px 10px;border-radius:999px}
/* key facts grid */
.jfacts{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1px;margin-top:14px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
}
@media(min-width:560px){.jfacts{grid-template-columns:repeat(3,minmax(0,1fr))}}
.jfact{
  display:flex;flex-direction:column;gap:5px;background:var(--surface);padding:11px 12px;min-width:0;
}
.jf-top{display:flex;align-items:center;gap:7px;min-width:0}
.jfact i{font-size:16px;color:var(--teal);flex:0 0 auto}
.jf-k{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--faint)}
.jf-v{font-size:14px;font-weight:600;color:var(--ink);min-width:0;line-height:1.3;
  overflow-wrap:anywhere;font-variant-numeric:tabular-nums}
/* header actions: Maps + SSD */
.jh-acts{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-top:14px}
.jh-act{
  display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--line);
  color:var(--text);font-size:13px;font-weight:600;text-decoration:none;padding:8px 13px;border-radius:var(--r-sm);
  box-shadow:var(--sh-1);transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.jh-act:hover{background:var(--surface-2);box-shadow:var(--sh-2)}
.jh-act i{font-size:15px;color:var(--teal)}

/* ---- scope of works — prominent teal panel (for not-yet-complete jobs) ---- */
.scope{
  position:relative;background:var(--teal-50);border:1px solid #BFE6DF;border-left:4px solid var(--teal);
  border-radius:var(--r-lg);padding:16px 18px;margin:14px 0;box-shadow:var(--sh-1);
}
.scope-hd{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.scope-ic{
  width:30px;height:30px;border-radius:9px;background:var(--teal);color:#fff;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;font-size:17px;box-shadow:var(--sh-1);
}
.scope-ti{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--teal-700)}
.scope-body{font-size:15.5px;line-height:1.55;color:var(--ink);white-space:pre-wrap;font-weight:500}

.maplink{
  display:inline-flex;align-items:center;gap:6px;color:var(--teal);font-size:13px;text-decoration:none;
  font-weight:600;margin-top:8px;
}
.sec{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px;margin:14px 0;
  box-shadow:var(--sh-1);
}
.sec h3{margin:0 0 12px;font-size:11.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:600}
/* completed-job scope: standard section with a subtle teal scope accent (lighter than the live teal panel) */
.sec-scope{border-left:3px solid var(--teal)}
.sec-scope .sechd i{color:var(--teal)}
/* section header with a Tabler icon (structured, not flat) */
.sechd{
  display:flex;align-items:center;gap:9px;margin:0 0 13px;
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);
}
.sechd i{font-size:17px;color:var(--teal);flex:0 0 auto}
.kv{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.kv:last-child{border-bottom:0}
.kv .k{color:var(--muted)}
.kv .v{text-align:right;font-weight:600;color:var(--text)}
.desc{font-size:14px;white-space:pre-wrap;color:var(--text);line-height:1.6}

/* worksheet — questions made distinct (defined cards, clear separation) */
.ws{display:flex;flex-direction:column;gap:10px}
.wsq{
  padding:13px 14px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface-2);
  box-shadow:var(--sh-1);
}
.wsq .q{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--faint)}
.wsq .a{font-size:15.5px;font-weight:600;margin-top:6px;color:var(--ink);line-height:1.45}
.wsq.boolyes{border-left:4px solid var(--green);background:var(--green-50)}
.wsq.boolno{border-left:4px solid var(--red);background:var(--red-50)}
.yes{color:#15803d}.no{color:#b91c1c}
.wsphoto{margin-top:8px}
.wsphoto img{
  max-width:200px;width:48%;border-radius:var(--r);border:1px solid var(--line);cursor:pointer;
  image-rendering:auto;transition:box-shadow var(--dur) var(--ease);
}
.wsphoto img:hover{box-shadow:var(--sh-2)}
.sig img{max-width:230px;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:6px;margin-top:6px}
.file{display:flex;align-items:center;gap:8px;font-size:13.5px;padding:6px 0;color:var(--text)}

/* attachments gallery — SSD PDF + the engineers' job photos */
button.jh-act{cursor:pointer;font-family:inherit}
.attdocs{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.attdoc{
  display:flex;align-items:center;gap:10px;padding:11px 13px;border:1px solid var(--line);
  border-radius:var(--r);background:var(--surface-2);color:var(--text);text-decoration:none;
  font-size:13.5px;font-weight:600;box-shadow:var(--sh-1);
  transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.attdoc:hover{background:var(--surface);box-shadow:var(--sh-2)}
.attdoc>i:first-child{font-size:19px;color:var(--teal);flex:0 0 auto}
.attdoc.ssd>i:first-child{color:#b45309}
.attname{flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.attbadge{
  flex:0 0 auto;font-size:10.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  color:#b45309;background:#FEF3C7;border:1px solid #FDE68A;border-radius:999px;padding:2px 8px;
}
.attgo{font-size:15px;color:var(--faint);flex:0 0 auto}
.attgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px}
.attcell{aspect-ratio:1/1;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:var(--surface-2)}
.attcell img{width:100%;height:100%;object-fit:cover;cursor:pointer;display:block;
  transition:transform var(--dur) var(--ease)}
.attcell img:hover{transform:scale(1.04)}

/* worksheet — collapsible sections (one design-system card per worksheet) */
.wsheet{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);margin:14px 0;
  box-shadow:var(--sh-1);overflow:hidden;
}
.wshead{
  display:flex;align-items:center;gap:11px;width:100%;text-align:left;cursor:pointer;
  background:none;border:0;padding:14px 16px;
}
.wshead:hover{background:var(--surface-2)}
.wsic{
  width:30px;height:30px;border-radius:9px;background:var(--teal-50);color:var(--teal);flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;font-size:16px;
}
.wsheet.open .wsic{background:var(--teal);color:#fff}
.wsname{font-size:14.5px;font-weight:600;color:var(--ink);flex:1 1 auto;min-width:0}
.wscount{font-size:12px;color:var(--muted);font-weight:500;white-space:nowrap;font-variant-numeric:tabular-nums}
.wschev{font-size:18px;color:var(--faint);flex:0 0 auto;transition:transform var(--dur) var(--ease)}
.wsheet.open .wschev{transform:rotate(180deg)}
.wsbody{display:none;padding:0 16px 16px}
.wsheet.open .wsbody{display:block}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(8,12,20,.92);display:none;align-items:center;justify-content:center;z-index:70;padding:14px}
.lb.on{display:flex;flex-direction:column;gap:10px}
.lb img{max-width:96vw;max-height:82vh;border-radius:var(--r-sm)}
.lb .cap{color:#e8eef6;font-size:13px;text-align:center;max-width:90vw}

/* ============================================================================
   REPORTS — summary tiles, jobs-by-crew, by-status, by-trade
   ========================================================================== */
/* summary metric tiles */
.rtiles{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:4px}
@media(min-width:680px){.rtiles{grid-template-columns:repeat(4,1fr)}}
.rtile{
  position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:15px 16px 14px;box-shadow:var(--sh-1);overflow:hidden;
  display:flex;flex-direction:column;gap:6px;
}
.rtile::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--teal)}
.rtile.t-green::before{background:var(--green)}
.rtile.t-amber::before{background:var(--amber)}
.rtile.t-blue::before{background:var(--blue)}
.rtile.t-teal::before{background:var(--teal)}
.rt-lab{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);line-height:1.3}
.rt-num{font-size:28px;font-weight:700;line-height:1;letter-spacing:-.6px;color:var(--ink)}
.rtile.t-green .rt-num{color:#15803d}
.rtile.t-amber .rt-num{color:var(--amber)}
.rtile.t-blue .rt-num{color:var(--blue)}
.rtile.t-teal .rt-num{color:var(--teal)}
.rt-sub{font-size:11.5px;color:var(--faint);font-weight:500}

/* report section card */
.rep-sec{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:16px 18px;box-shadow:var(--sh-1);margin-top:18px;
}
.rep-sechd{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.rep-sechd i{font-size:18px;color:var(--teal);flex:0 0 auto}
.rep-sechd .h3{font-size:15px}
.rep-empty{color:var(--muted);font-size:13px;padding:18px 2px;text-align:center}
.rep-legend{display:flex;gap:16px;font-size:12px;color:var(--muted);font-weight:500;margin-bottom:8px}
.rep-legend .lg{display:inline-flex;align-items:center;gap:6px}
.rep-legend .sw{width:10px;height:10px;border-radius:3px}
.rep-legend .sw.gw{background:var(--gw)}
.rep-legend .sw.el{background:var(--el)}
.rep-chartwrap{position:relative;width:100%;margin:6px 0 14px}

/* crew table — design-system table, reflows to fit within the card */
.rep-tablewrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r);border:1px solid var(--line)}
.rep-table{width:100%;border-collapse:collapse;font-size:13px;min-width:0}
.rep-table thead th{
  background:var(--surface-2);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;
  color:var(--muted);padding:9px 10px;text-align:right;white-space:nowrap;border-bottom:1px solid var(--line);
}
.rep-table thead th.l,.rep-table tbody td.l{text-align:left}
.rep-table tbody td{padding:9px 10px;text-align:right;border-bottom:1px solid var(--line);color:var(--text);
  font-variant-numeric:tabular-nums;white-space:nowrap}
.rep-table tbody tr:last-child td{border-bottom:0}
.rep-table tbody tr:nth-child(even) td{background:var(--surface-2)}
.rep-table tbody td.l{font-weight:600;color:var(--ink)}
.rep-table .gwn{color:var(--gw);font-weight:600}
.rep-table .eln{color:var(--el);font-weight:600}

/* by-status — horizontal bars with counts + % */
.statlist{display:flex;flex-direction:column;gap:13px}
.statrow{min-width:0}
.st-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}
.st-name{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text);min-width:0}
.st-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
.st-cnt{display:inline-flex;align-items:baseline;gap:8px;flex:0 0 auto}
.st-cnt b{font-size:14px;color:var(--ink)}
.st-pct{font-size:11.5px;color:var(--faint);font-weight:600}
.st-bar{height:8px;border-radius:999px;background:var(--line);overflow:hidden}
.st-bar i{display:block;height:100%;border-radius:999px;min-width:2px;transition:width var(--dur) var(--ease)}

/* by-trade — split bar + legend */
.tradesplit{display:flex;flex-direction:column;gap:12px}
.ts-bar{display:flex;height:14px;border-radius:999px;overflow:hidden;background:var(--line);gap:2px}
.ts-bar i{display:block;height:100%;border-radius:999px;min-width:0}
.ts-bar i.gw{background:var(--gw)}
.ts-bar i.el{background:var(--el)}
.ts-bar i.other{background:#7C3AED}
.ts-bar i.none{background:var(--line-2)}
.ts-legend{display:flex;flex-wrap:wrap;gap:8px 18px}
.ts-lg{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--text);font-weight:500}
.ts-lg b{color:var(--ink);font-weight:700}
.ts-lg .sw{width:10px;height:10px;border-radius:3px}
.ts-lg .sw.gw{background:var(--gw)}
.ts-lg .sw.el{background:var(--el)}
.ts-lg .sw.other{background:#7C3AED}

/* more-reports note */
.rep-note{
  display:flex;align-items:center;gap:10px;margin-top:18px;padding:13px 16px;
  background:var(--teal-50);border:1px solid #BFE6DF;border-radius:var(--r);
  font-size:12.5px;color:var(--teal-700);font-weight:500;
}
.rep-note i{font-size:18px;color:var(--teal);flex:0 0 auto}

/* ============================================================================
   LOADING / COMING SOON
   ========================================================================== */
.loading{text-align:center;color:var(--muted);padding:50px}
.spin{
  width:24px;height:24px;border:3px solid var(--line);border-top-color:var(--teal);
  border-radius:50%;display:inline-block;animation:sp .8s linear infinite;
}
@keyframes sp{to{transform:rotate(360deg)}}
.soon{text-align:center;color:var(--muted);padding:80px 24px}
.soon .ic{
  width:64px;height:64px;border-radius:18px;background:var(--teal-50);color:var(--teal);
  display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 16px;
}
.soon b{font-size:18px;font-weight:600;color:var(--ink);display:block}
.soon .ln{margin-top:6px;font-size:13.5px}

/* ============================================================================
   AUTH — login screen + set-new-password (full-viewport, centred card)
   ========================================================================== */
.authwrap{
  position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;
  padding:max(20px,env(safe-area-inset-top)) 18px calc(20px + env(safe-area-inset-bottom));
  background:
    radial-gradient(120% 80% at 50% -10%, var(--teal-50) 0%, transparent 60%),
    var(--bg);
  overflow-y:auto;
}
.authcard{
  width:100%;max-width:380px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-xl);box-shadow:var(--sh-3);padding:26px 24px 24px;margin:auto;
}
.authbrand{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:20px;text-align:center}
.authbrand .mark{
  width:52px;height:52px;border-radius:15px;background:var(--grad-teal);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;letter-spacing:.5px;
  box-shadow:var(--sh-2);
}
.authbrand .wordmark{font-size:24px;font-weight:600;letter-spacing:-.3px;color:var(--ink);line-height:1}
.authbrand .authsub{font-size:13px;color:var(--muted);font-weight:500}
.authform{display:flex;flex-direction:column;gap:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.field input{
  width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:12px 13px;font-family:inherit;font-size:16px;color:var(--text);outline:none;min-height:44px;
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease),background var(--dur) var(--ease);
}
.field input::placeholder{color:var(--faint)}
.field input:focus{border-color:var(--teal);background:var(--surface);box-shadow:0 0 0 3px var(--teal-50)}
.btn-primary{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:46px;
  background:var(--grad-teal);color:#fff;border:0;border-radius:var(--r-sm);
  font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;box-shadow:var(--sh-1);
  transition:filter var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.btn-primary:hover{filter:brightness(1.05);box-shadow:var(--sh-2)}
.btn-primary[disabled]{opacity:.6;cursor:default;box-shadow:none;filter:none}
.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:44px;
  background:var(--surface);color:var(--text);border:1px solid var(--line);border-radius:var(--r-sm);
  font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;box-shadow:var(--sh-1);padding:0 14px;
  transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.btn-ghost:hover{background:var(--surface-2);box-shadow:var(--sh-2)}
.autherr{
  display:none;align-items:flex-start;gap:8px;background:var(--red-50);border:1px solid #F5C6C6;
  color:#b91c1c;border-radius:var(--r-sm);padding:10px 12px;font-size:13px;font-weight:500;line-height:1.4;
}
.autherr.on{display:flex}
.autherr i{font-size:16px;line-height:1.2;flex:0 0 auto}
.authhint{font-size:12px;color:var(--muted);text-align:center;line-height:1.5;margin-top:2px}

/* ============================================================================
   USER MENU (sidebar chip + mobile) — logout / change password / users
   ========================================================================== */
.userchip{position:relative}
.userchip.btn{cursor:pointer;text-align:left;width:100%;font-family:inherit;
  transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.userchip.btn:hover{box-shadow:var(--sh-1)}
.userchip .chev{margin-left:auto;flex:0 0 auto;color:var(--faint);font-size:16px}
/* popover menu anchored above the chip */
.usermenu{
  position:absolute;bottom:calc(100% + 8px);left:0;right:0;z-index:70;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-3);
  padding:6px;display:none;
}
.usermenu.on{display:block}
.usermenu .mi{
  display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:0;
  border-radius:var(--r-sm);padding:10px 11px;font-family:inherit;font-size:13.5px;font-weight:500;
  color:var(--text);cursor:pointer;transition:background var(--dur) var(--ease);min-height:42px;
}
.usermenu .mi:hover{background:var(--surface-2)}
.usermenu .mi i{font-size:17px;width:20px;text-align:center;color:var(--muted);flex:0 0 auto}
.usermenu .mi.danger{color:#b91c1c}
.usermenu .mi.danger i{color:var(--red)}
.usermenu .sep{height:1px;background:var(--line);margin:5px 4px}

/* ============================================================================
   MODAL (change password, add user, temp-password reveal)
   ========================================================================== */
.modal{
  position:fixed;inset:0;z-index:90;display:none;align-items:center;justify-content:center;
  background:rgba(8,12,20,.5);backdrop-filter:blur(2px);
  padding:max(18px,env(safe-area-inset-top)) 16px calc(18px + env(safe-area-inset-bottom));
  overflow-y:auto;
}
.modal.on{display:flex}
.modalcard{
  width:100%;max-width:420px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-lg);box-shadow:var(--sh-3);padding:20px;margin:auto;
}
.modalhd{display:flex;align-items:center;gap:11px;margin-bottom:16px}
.modalhd .mic{
  width:38px;height:38px;border-radius:11px;background:var(--teal-50);color:var(--teal);flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;font-size:19px;
}
.modalhd .h2{font-size:17px}
.modalhd .mclose{
  margin-left:auto;flex:0 0 auto;width:34px;height:34px;border-radius:var(--r-sm);background:none;border:0;
  color:var(--muted);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background var(--dur) var(--ease);
}
.modalhd .mclose:hover{background:var(--surface-2);color:var(--text)}
.modalbody{display:flex;flex-direction:column;gap:14px}
.modalacts{display:flex;gap:10px;margin-top:4px}
.modalacts .btn-primary,.modalacts .btn-ghost{flex:1 1 0;width:auto}
.field select{
  width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:12px 13px;font-family:inherit;font-size:16px;color:var(--text);outline:none;min-height:44px;
  cursor:pointer;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.field select:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-50)}
/* temp-password reveal block */
.tempbox{
  background:var(--teal-50);border:1px solid #BFE6DF;border-radius:var(--r);padding:14px;
  display:flex;flex-direction:column;gap:10px;
}
.tempbox .tlab{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--teal-700)}
.tempbox .trow{display:flex;align-items:center;gap:8px}
.tempbox code{
  flex:1 1 auto;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:16px;font-weight:600;
  color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:10px 12px;letter-spacing:.5px;word-break:break-all;
}
.copybtn{
  flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;background:var(--grad-teal);color:#fff;border:0;
  border-radius:var(--r-sm);padding:0 13px;min-height:42px;font-family:inherit;font-size:13px;font-weight:600;
  cursor:pointer;box-shadow:var(--sh-1);transition:filter var(--dur) var(--ease);
}
.copybtn:hover{filter:brightness(1.05)}
.copybtn.ok{background:var(--green-50);color:#15803d;box-shadow:none}
.tempbox .twarn{font-size:12px;color:var(--teal-700);font-weight:500;line-height:1.45}

/* ============================================================================
   USERS SCREEN (admin) — header, table (desktop) / cards (mobile)
   ========================================================================== */
.usershd{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.usershd .tt{min-width:0}
.usershd .updated{font-size:11.5px;color:var(--faint);margin-top:3px}
.adduserbtn{
  display:inline-flex;align-items:center;gap:7px;background:var(--grad-teal);color:#fff;border:0;
  border-radius:var(--r-sm);padding:10px 15px;min-height:44px;font-family:inherit;font-size:14px;font-weight:600;
  cursor:pointer;box-shadow:var(--sh-1);transition:filter var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.adduserbtn:hover{filter:brightness(1.05);box-shadow:var(--sh-2)}
.adduserbtn i{font-size:17px}

/* role + active pills */
.rolepill{font-size:11px;font-weight:600;padding:3px 10px;border-radius:999px;display:inline-block;line-height:1.5}
.rolepill.admin{background:var(--teal-50);color:var(--teal-700)}
.rolepill.manager{background:#EEF2F7;color:#475569}
.statepill{font-size:11px;font-weight:600;padding:3px 10px;border-radius:999px;display:inline-flex;align-items:center;gap:5px;line-height:1.5}
.statepill.active{background:var(--green-50);color:#15803d}
.statepill.inactive{background:#EEF2F7;color:#64748B}
.statepill .dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.mustpill{font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--amber-50);color:#b45309;display:inline-block}

/* row action buttons */
.uact{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--surface);
  border:1px solid var(--line);color:var(--text);border-radius:var(--r-sm);padding:7px 11px;min-height:38px;
  font-family:inherit;font-size:12.5px;font-weight:600;cursor:pointer;box-shadow:var(--sh-1);white-space:nowrap;
  transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease),color var(--dur) var(--ease);
}
.uact:hover{background:var(--surface-2);box-shadow:var(--sh-2)}
.uact i{font-size:15px;color:var(--muted)}
.uact.danger{color:#b91c1c}.uact.danger i{color:var(--red)}
.uact.go{color:#15803d}.uact.go i{color:var(--green)}
.uact[disabled]{opacity:.45;cursor:default;box-shadow:none}

/* DESKTOP/TABLET (>=720px): table; MOBILE: stacked cards */
.userstable{display:none}
.usercards{display:flex;flex-direction:column;gap:12px}
@media(min-width:720px){
  .userstable{
    display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
    box-shadow:var(--sh-1);overflow:hidden;
  }
  .usercards{display:none}
  .userstable table{width:100%;border-collapse:collapse;font-size:13.5px}
  .userstable thead th{
    background:var(--surface-2);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;
    color:var(--muted);padding:11px 14px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--line);
  }
  .userstable thead th.r,.userstable tbody td.r{text-align:right}
  .userstable tbody td{padding:12px 14px;border-bottom:1px solid var(--line);color:var(--text);vertical-align:middle}
  .userstable tbody tr:last-child td{border-bottom:0}
  .userstable tbody tr:nth-child(even) td{background:var(--surface-2)}
  .userstable .u-name{font-weight:600;color:var(--ink)}
  .userstable .u-name .you{font-size:11px;font-weight:600;color:var(--teal);margin-left:7px}
  .userstable .u-email{color:var(--muted);font-variant-numeric:tabular-nums}
  .userstable .u-acts{display:flex;gap:7px;justify-content:flex-end;flex-wrap:wrap}
}
/* mobile user card */
.usercard{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);
  padding:14px 15px;display:flex;flex-direction:column;gap:11px;
}
.usercard .uc-top{display:flex;align-items:flex-start;gap:11px}
.usercard .uc-av{
  width:40px;height:40px;border-radius:50%;background:var(--grad-teal);color:#fff;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;
}
.usercard .uc-who{min-width:0;flex:1 1 auto}
.usercard .uc-name{font-size:15px;font-weight:600;color:var(--ink);line-height:1.25}
.usercard .uc-name .you{font-size:11px;font-weight:600;color:var(--teal);margin-left:6px}
.usercard .uc-email{font-size:12.5px;color:var(--muted);margin-top:2px;word-break:break-all}
.usercard .uc-tags{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.usercard .uc-acts{display:flex;gap:8px;flex-wrap:wrap}
.usercard .uc-acts .uact{flex:1 1 auto}

/* ============================================================================
   MOTION — reduced
   ========================================================================== */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .kpi:hover,.job:hover,.tile2:hover{transform:none}
}

/* ============================================================================
   ALERTS screen — preference rows, toggle switches, history
   ========================================================================== */
.acard{padding:2px 14px;margin-top:10px}
.arow{display:flex;align-items:center;gap:12px;padding:13px 0;min-height:52px}
.arow.brd{border-top:1px solid var(--line)}
.alab{flex:1 1 auto;min-width:0}
.alab b{font-size:14.5px;font-weight:600;color:var(--ink);display:block}
.ahint{font-size:12px;color:var(--muted);margin-top:2px;line-height:1.35}
.atag{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
  color:var(--amber);background:var(--amber-50);padding:2px 7px;border-radius:999px;margin-left:6px;vertical-align:2px}
.aswitch{flex:0 0 auto;width:46px;height:28px;border-radius:999px;background:var(--line-2);border:0;
  position:relative;cursor:pointer;transition:background var(--dur) var(--ease);padding:0}
.aswitch.on{background:var(--teal)}
.aknob{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;
  box-shadow:var(--sh-1);transition:left var(--dur) var(--ease)}
.aswitch.on .aknob{left:21px}
.asaved{height:17px;font-size:12px;font-weight:600;color:var(--muted);text-align:right;margin:6px 2px 0;
  opacity:0;transition:opacity var(--dur) var(--ease)}
.asaved.show{opacity:1}
.asaved.ok{color:var(--green)}
/* alerts history list */
.alist{display:flex;flex-direction:column;gap:8px}
.aitem{display:flex;align-items:center;gap:11px;text-align:left;width:100%;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r);padding:12px 13px;cursor:pointer;box-shadow:var(--sh-1);
  transition:box-shadow var(--dur) var(--ease)}
.aitem:hover{box-shadow:var(--sh-2)}
.adot{flex:0 0 auto;width:10px;height:10px;border-radius:50%}
.amid{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:2px}
.amid .as{font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.amid .ac{font-size:12.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.aat{flex:0 0 auto;font-size:11.5px;color:var(--faint);white-space:nowrap}
