/* =========================================================
   CloudYMS Dispatch Board - Mockup Match Theme
   Style-only update: darker navy header, blue framed panels,
   stronger cards/buttons, and the polished dashboard look from
   the approved mockup image. No database or dispatch logic here.
   ========================================================= */
:root{
  --navy:#061b3a;
  --navy-2:#082a58;
  --navy-3:#0b3975;
  --blue:#0f6ed8;
  --blue-2:#16a7f2;
  --blue-3:#38bdf8;
  --ice:#f4f9ff;
  --ice-2:#e9f4ff;
  --ice-3:#d9ecff;
  --panel:#f8fbff;
  --panel-2:#eef7ff;
  --line:#9fc8ee;
  --line-2:#78b3e8;
  --text:#0b2550;
  --muted:#46617e;
  --green:#148a6a;
  --green-2:#23b887;
  --red:#d73737;
  --yellow:#f2b705;
  --purple:#6655ee;
  --shadow:0 22px 46px rgba(4,31,70,.16);
  --shadow-soft:0 12px 28px rgba(15,110,216,.14);
  --shadow-hover:0 28px 54px rgba(4,31,70,.24);
  --radius:20px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0 !important;
  min-height:100vh !important;
  font-family:"Segoe UI",Arial,Helvetica,sans-serif !important;
  color:var(--text) !important;
  background:
    radial-gradient(circle at 100% 16%, rgba(22,167,242,.22), transparent 24%),
    radial-gradient(circle at 4% 78%, rgba(15,110,216,.18), transparent 28%),
    linear-gradient(135deg, rgba(255,255,255,.62) 0 8%, transparent 8% 18%, rgba(255,255,255,.42) 18% 19%, transparent 19% 100%),
    linear-gradient(180deg,#eaf6ff 0%,#dceeff 48%,#c9e4fb 100%) !important;
  overflow-x:hidden !important;
}
body:before{
  content:"";
  position:fixed;
  inset:108px 0 0 0;
  pointer-events:none;
  z-index:0;
  opacity:.42;
  background-image:
    linear-gradient(135deg,rgba(8,42,88,.06) 25%,transparent 25%),
    linear-gradient(225deg,rgba(8,42,88,.06) 25%,transparent 25%),
    radial-gradient(circle,rgba(8,42,88,.09) 1px,transparent 1.5px);
  background-position:0 0,0 0,0 0;
  background-size:88px 88px,88px 88px,18px 18px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.42),rgba(0,0,0,.12));
}
body:after{
  content:"";
  position:fixed;
  right:-170px;
  bottom:-180px;
  width:460px;
  height:460px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(22,167,242,.24),transparent 66%);
  pointer-events:none;
  z-index:0;
}

.topbar,
.navBar,
.pageWrap,
.footer,
.loginCard,
.cleanLoginCard,
.installBox,
.seedBox{position:relative;z-index:1;}

/* Full dark header like the mockup */
.topbar{
  width:100% !important;
  margin:0 !important;
  padding:20px clamp(18px,4vw,58px) !important;
  min-height:104px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:22px !important;
  color:#fff !important;
  background:
    linear-gradient(135deg,rgba(255,255,255,.08),transparent 28%),
    linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 48%,#0c356b 100%) !important;
  border:0 !important;
  border-bottom:3px solid rgba(56,189,248,.42) !important;
  border-radius:0 !important;
  box-shadow:0 18px 40px rgba(3,19,44,.36) !important;
  backdrop-filter:none !important;
}
.brandBlock{display:flex !important;align-items:center !important;gap:18px !important;min-width:0 !important;}
.brandLogo{
  min-width:126px !important;
  width:auto !important;
  height:62px !important;
  padding:0 18px !important;
  border-radius:17px !important;
  display:grid !important;
  place-items:center !important;
  color:#fff !important;
  background:linear-gradient(135deg,#0b5dc7 0%,#108ff0 100%) !important;
  border:1px solid rgba(104,197,255,.68) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 14px 28px rgba(0,0,0,.28),0 0 0 4px rgba(56,189,248,.08) !important;
  font-size:17px !important;
  font-weight:950 !important;
  letter-spacing:.1px !important;
}
.brandLogo.big,.brandLogo.loginPill{
  min-width:126px !important;
  width:126px !important;
  height:62px !important;
  border-radius:17px !important;
  font-size:17px !important;
}
.brandTitle{
  color:#fff !important;
  font-size:32px !important;
  font-weight:950 !important;
  line-height:1 !important;
  letter-spacing:-.8px !important;
  text-shadow:0 2px 10px rgba(0,0,0,.30) !important;
}
.brandSub{
  color:#63caff !important;
  opacity:1 !important;
  font-size:14px !important;
  font-weight:900 !important;
  letter-spacing:.9px !important;
  text-transform:uppercase !important;
  margin-top:8px !important;
}
.topRight{display:flex !important;align-items:center !important;gap:13px !important;}
.userPill{
  display:inline-flex !important;
  align-items:center !important;
  gap:10px !important;
  color:#fff !important;
  background:rgba(7,34,73,.72) !important;
  border:1px solid rgba(104,197,255,.38) !important;
  border-radius:16px !important;
  padding:14px 19px !important;
  font-weight:950 !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14),0 12px 26px rgba(0,0,0,.22) !important;
}
.userPill:before{
  content:"●";
  width:25px;
  height:25px;
  display:inline-grid;
  place-items:center;
  border-radius:50%;
  color:#bfe9ff;
  background:linear-gradient(135deg,#1578dd,#0b4da5);
  box-shadow:0 6px 14px rgba(0,0,0,.22);
  font-size:11px;
}

/* Navigation joins the main framed board */
.navBar{
  width:min(1480px,calc(100% - 56px)) !important;
  margin:34px auto 0 !important;
  padding:20px 20px 10px !important;
  display:flex !important;
  flex-wrap:wrap !important;
  justify-content:flex-start !important;
  gap:0 !important;
  background:linear-gradient(180deg,rgba(248,251,255,.96),rgba(232,244,255,.92)) !important;
  border:1px solid var(--line-2) !important;
  border-bottom:0 !important;
  border-radius:24px 24px 0 0 !important;
  box-shadow:var(--shadow) !important;
  backdrop-filter:blur(10px) !important;
  top:auto !important;
  overflow:hidden !important;
}
.navBar a{
  position:relative !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:50px !important;
  color:#063c88 !important;
  text-decoration:none !important;
  background:linear-gradient(180deg,#ffffff 0%,#eaf5ff 100%) !important;
  border:1px solid #a8cff4 !important;
  border-left:0 !important;
  border-radius:0 !important;
  padding:13px 18px !important;
  font-weight:950 !important;
  letter-spacing:-.1px !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.88),0 8px 16px rgba(4,42,92,.08) !important;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease !important;
}
.navBar a:first-child{border-left:1px solid #a8cff4 !important;border-radius:12px 0 0 12px !important;}
.navBar a:last-child{border-radius:0 12px 12px 0 !important;}
.navBar a:hover,
.navBar a:focus{
  color:#fff !important;
  background:linear-gradient(135deg,#0f6ed8 0%,#064a9f 100%) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 16px 26px rgba(6,66,143,.24) !important;
  transform:translateY(-2px) !important;
  z-index:2 !important;
}
.navBar a[href="dispatch_board.php"]{
  color:#fff !important;
  background:linear-gradient(135deg,#0e72dc,#084a9a) !important;
  border-color:#0a5dc2 !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 14px 24px rgba(6,66,143,.25) !important;
}

/* Framed main board */
.pageWrap{
  width:min(1480px,calc(100% - 56px)) !important;
  max-width:none !important;
  margin:0 auto 0 !important;
  padding:22px !important;
  background:linear-gradient(180deg,rgba(248,252,255,.98),rgba(229,243,255,.96)) !important;
  border:1px solid var(--line-2) !important;
  border-top:0 !important;
  border-radius:0 0 24px 24px !important;
  box-shadow:0 32px 60px rgba(4,31,70,.18) !important;
}

/* Page title strip */
.pageTitleRow{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:22px !important;
  background:linear-gradient(180deg,#ffffff 0%,#f2f8ff 100%) !important;
  border:1px solid #93c4f1 !important;
  border-radius:17px !important;
  box-shadow:var(--shadow-soft) !important;
  padding:28px 28px 28px 110px !important;
  margin-bottom:22px !important;
  position:relative !important;
  overflow:hidden !important;
}
.pageTitleRow:before{
  content:"🚚";
  position:absolute;
  left:25px;
  top:50%;
  transform:translateY(-50%);
  width:64px;
  height:64px;
  border-radius:50%;
  display:grid;
  place-items:center;
  color:#fff;
  background:linear-gradient(135deg,#0f6ed8,#063f8f);
  border:1px solid rgba(255,255,255,.38);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 14px 24px rgba(5,58,124,.30);
  font-size:30px;
}
.pageTitleRow:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent 0 62%,rgba(56,189,248,.08) 62% 100%);
  pointer-events:none;
}
.pageTitleRow > *{position:relative;z-index:1;}
.pageTitleRow h1{
  color:var(--navy) !important;
  font-size:clamp(2.5rem,4vw,3.35rem) !important;
  line-height:.98 !important;
  letter-spacing:-1.6px !important;
  font-weight:950 !important;
  margin:0 !important;
}
.pageTitleRow p{
  color:#24405e !important;
  line-height:1.55 !important;
  font-size:16px !important;
  font-weight:750 !important;
  margin:9px 0 0 !important;
}
.buttonRow{display:flex !important;align-items:center !important;gap:14px !important;flex-wrap:wrap !important;}

/* Buttons */
.btn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:9px !important;
  min-height:42px !important;
  text-decoration:none !important;
  border-radius:13px !important;
  padding:12px 18px !important;
  border:1px solid transparent !important;
  cursor:pointer !important;
  font-weight:950 !important;
  letter-spacing:-.1px !important;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease !important;
  white-space:nowrap !important;
}
.btn:hover{filter:none !important;transform:translateY(-2px) !important;}
.btn.primary{
  color:#fff !important;
  background:linear-gradient(135deg,#0f6ed8 0%,#064a9f 100%) !important;
  border-color:#063f8f !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 14px 25px rgba(6,66,143,.28) !important;
}
.btn.secondary{
  color:#064a9f !important;
  background:linear-gradient(180deg,#ffffff 0%,#e5f3ff 100%) !important;
  border-color:#8abfec !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 10px 20px rgba(6,66,143,.12) !important;
}
.btn.ghost{
  color:#0b3975 !important;
  background:#f7fbff !important;
  border-color:#9fc8ee !important;
  box-shadow:0 8px 16px rgba(6,66,143,.08) !important;
}
.btn.danger{
  color:#fff !important;
  background:linear-gradient(135deg,#ef4444,#be1e2d) !important;
  border-color:#a51a24 !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 14px 24px rgba(190,30,45,.30) !important;
}
.btn.small{min-height:32px !important;padding:7px 11px !important;border-radius:10px !important;font-size:12px !important;}
.btn.full{width:100% !important;}

/* Quick action cards */
.quickActionGrid{
  display:grid !important;
  grid-template-columns:repeat(6,minmax(168px,1fr)) !important;
  gap:18px !important;
  margin:0 0 22px !important;
}
.quickActionCard{
  display:grid !important;
  grid-template-columns:auto 1fr !important;
  grid-template-rows:auto 1fr auto !important;
  column-gap:14px !important;
  row-gap:5px !important;
  min-height:172px !important;
  text-decoration:none !important;
  color:var(--text) !important;
  background:linear-gradient(180deg,#ffffff 0%,#f1f8ff 100%) !important;
  border:1px solid #8ebfed !important;
  border-radius:15px !important;
  padding:24px 20px 19px !important;
  box-shadow:var(--shadow-soft) !important;
  position:relative !important;
  overflow:hidden !important;
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease !important;
}
.quickActionCard:before{
  content:"" !important;
  position:absolute !important;
  left:0 !important;
  top:0 !important;
  width:100% !important;
  height:6px !important;
  background:linear-gradient(90deg,#0f6ed8,#16a7f2) !important;
}
.quickActionCard:after{
  content:"→" !important;
  position:absolute !important;
  right:18px !important;
  bottom:16px !important;
  color:#073d8a !important;
  font-size:26px !important;
  font-weight:950 !important;
  line-height:1 !important;
}
.quickActionCard:hover{
  transform:translateY(-6px) !important;
  border-color:#4ca6ef !important;
  box-shadow:var(--shadow-hover) !important;
  filter:none !important;
}
.qaIcon{
  grid-row:1 / span 2 !important;
  width:48px !important;
  height:48px !important;
  border-radius:50% !important;
  display:grid !important;
  place-items:center !important;
  color:#fff !important;
  background:linear-gradient(135deg,#0f6ed8,#064a9f) !important;
  border:1px solid rgba(255,255,255,.42) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.26),0 12px 20px rgba(5,58,124,.28) !important;
  font-size:21px !important;
  line-height:1 !important;
}
.quickActionCard strong{
  display:block !important;
  color:var(--navy) !important;
  font-size:1.04rem !important;
  line-height:1.25 !important;
  font-weight:950 !important;
  margin:3px 0 8px !important;
}
.quickActionCard .qaSub,
.quickActionCard span:not(.qaIcon){
  display:block !important;
  color:#294866 !important;
  line-height:1.45 !important;
  font-size:.93rem !important;
  font-weight:750 !important;
}
.quickActionCard.secondary:before{background:linear-gradient(90deg,#16a7f2,#4dc7ff) !important;}
.quickActionCard.gps:before{background:linear-gradient(90deg,#6655ee,#16a7f2) !important;}
.quickActionCard.billing:before{background:linear-gradient(90deg,#148a6a,#23b887) !important;}
.quickActionCard.rates:before{background:linear-gradient(90deg,#f2b705,#ffd45e) !important;}
.quickActionCard.drivers:before{background:linear-gradient(90deg,#061b3a,#235179) !important;}
.quickActionCard.billing .qaIcon{background:linear-gradient(135deg,#23b887,#087052) !important;}
.quickActionCard.rates .qaIcon{background:linear-gradient(135deg,#f2b705,#c18400) !important;}
.quickActionCard.gps .qaIcon{background:linear-gradient(135deg,#6655ee,#3143b8) !important;}
.quickActionCard.drivers .qaIcon{background:linear-gradient(135deg,#0b3975,#061b3a) !important;}

/* Stat KPI cards */
.statGrid{
  display:grid !important;
  grid-template-columns:repeat(5,minmax(150px,1fr)) !important;
  gap:18px !important;
  margin-bottom:22px !important;
}
.statCard{
  display:grid !important;
  grid-template-columns:auto 1fr !important;
  align-items:center !important;
  gap:16px !important;
  min-height:116px !important;
  text-decoration:none !important;
  color:var(--text) !important;
  background:linear-gradient(180deg,#ffffff 0%,#f0f8ff 100%) !important;
  border:1px solid #98c5ed !important;
  border-radius:15px !important;
  box-shadow:var(--shadow-soft) !important;
  padding:21px !important;
  position:relative !important;
  overflow:hidden !important;
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease !important;
}
.statCard:before{
  content:"✓";
  width:58px;
  height:58px;
  border-radius:50%;
  display:grid;
  place-items:center;
  color:#fff;
  background:linear-gradient(135deg,#0f6ed8,#064a9f);
  box-shadow:0 12px 22px rgba(5,58,124,.24);
  font-weight:950;
  font-size:22px;
}
.statCard:after{
  content:"" !important;
  position:absolute !important;
  right:-44px !important;
  top:-44px !important;
  width:110px !important;
  height:110px !important;
  border-radius:50% !important;
  background:rgba(15,110,216,.10) !important;
}
.statCard:hover{transform:translateY(-6px) !important;box-shadow:var(--shadow-hover) !important;border-color:#4ca6ef !important;}
.statCard span{display:block !important;color:#294866 !important;font-size:1rem !important;font-weight:900 !important;letter-spacing:.1px !important;}
.statCard strong{display:block !important;color:#084a9f !important;font-size:clamp(2rem,3vw,2.75rem) !important;line-height:1 !important;letter-spacing:-1px !important;margin-top:6px !important;}

/* Cards, filters, tables, forms */
.card,.formCard,.installBox,.invoiceSheet,.driverLoadCard,.miniPanel,.noteBox,.gpsBox,.gpsCurrent,.loginCard,.cleanLoginCard{
  background:linear-gradient(180deg,#ffffff 0%,#f2f8ff 100%) !important;
  border:1px solid #95c4ed !important;
  border-radius:var(--radius) !important;
  box-shadow:var(--shadow-soft) !important;
}
.card,.formCard{padding:22px !important;margin-bottom:22px !important;}
.filterBar{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(180px,1fr)) repeat(2,minmax(180px,1fr)) minmax(260px,2fr) auto auto !important;
  align-items:end !important;
  gap:12px !important;
  background:linear-gradient(180deg,#ffffff 0%,#edf7ff 100%) !important;
  border:1px solid #8ebfed !important;
  border-radius:17px !important;
  box-shadow:var(--shadow-soft) !important;
  padding:18px !important;
  margin-bottom:22px !important;
}
.filterBar input[type=search]{min-width:0 !important;}
label{color:#153d6f !important;font-weight:950 !important;}
input,select,textarea{
  width:100%;
  min-height:46px !important;
  border:1px solid #a8cff4 !important;
  border-radius:12px !important;
  padding:12px 14px !important;
  color:var(--text) !important;
  background:linear-gradient(180deg,#ffffff,#f7fbff) !important;
  font:inherit !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9) !important;
  transition:border-color .18s ease,box-shadow .18s ease,background .18s ease !important;
}
input:focus,select:focus,textarea:focus{
  outline:none !important;
  border-color:#0f6ed8 !important;
  box-shadow:0 0 0 4px rgba(15,110,216,.16),inset 0 1px 0 rgba(255,255,255,.9) !important;
}
.sectionTitle{
  color:#fff !important;
  border-left:0 !important;
  padding:9px 15px !important;
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  border-radius:999px !important;
  background:linear-gradient(135deg,#0f6ed8,#064a9f) !important;
  border:1px solid rgba(255,255,255,.24) !important;
  box-shadow:0 10px 20px rgba(6,66,143,.18) !important;
  font-size:.92rem !important;
  margin:0 0 16px !important;
}
.tableWrap{
  overflow:auto !important;
  border-radius:16px !important;
  border:1px solid #a8cff4 !important;
  background:#fff !important;
}
table{width:100% !important;border-collapse:separate !important;border-spacing:0 !important;min-width:900px !important;background:#fff !important;}
th{
  background:linear-gradient(180deg,#0b3975,#061b3a) !important;
  color:#fff !important;
  font-size:.82rem !important;
  letter-spacing:.45px !important;
  text-transform:uppercase !important;
  text-align:left !important;
  border-bottom:1px solid rgba(255,255,255,.12) !important;
}
th,td{padding:15px 16px !important;border-bottom:1px solid #d6e9fb !important;vertical-align:top !important;}
td{color:#213f5e !important;background:#fff !important;}
tr:nth-child(even) td{background:#f7fbff !important;}
tr:hover td{background:#eaf5ff !important;}
.linkStrong{color:#064a9f !important;font-weight:950 !important;text-decoration:none !important;}
.linkStrong:hover{text-decoration:underline !important;}
.muted{color:#55708d !important;}
.smallText{font-size:12px !important;}
.empty{color:#55708d !important;font-weight:850 !important;text-align:center !important;}
.statusPill,.billingPill{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:28px !important;
  background:#e7f2ff !important;
  color:#064a9f !important;
  border:1px solid #9fc8ee !important;
  border-radius:999px !important;
  padding:7px 11px !important;
  font-weight:950 !important;
  font-size:12px !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.88) !important;
}
.statusPill.delivered{background:#e7fbf4 !important;border-color:#9ee2c9 !important;color:#087052 !important;}
.statusPill.cancelled{background:#fff0f0 !important;border-color:#f3b8b8 !important;color:#a51a24 !important;}
.statusPill.open{background:#eef6ff !important;color:#064a9f !important;}
.statusPill.assigned{background:#fff8df !important;border-color:#f7d979 !important;color:#8a5d00 !important;}
.statusPill.inroute,.statusPill.arrivedpickup,.statusPill.pickedup,.statusPill.arriveddelivery{background:#eeeaff !important;border-color:#c8c1ff !important;color:#3a2cba !important;}
.moneyCell{color:#064a9f !important;font-weight:950 !important;}
.goodText{color:#087052 !important;font-weight:950 !important;}
.badText{color:#be1e2d !important;font-weight:950 !important;}
.alert{border-radius:15px !important;border:1px solid transparent !important;box-shadow:0 10px 20px rgba(6,66,143,.08) !important;}
.alert.success{background:#e7fbf4 !important;border-color:#9ee2c9 !important;color:#087052 !important;}
.alert.danger{background:#fff0f0 !important;border-color:#f3b8b8 !important;color:#a51a24 !important;}
.actionButtonStack{display:flex !important;gap:7px !important;flex-wrap:wrap !important;}

/* Detail/driver/GPS areas */
.detailGrid div,.docRow,.timelineItem{
  background:#f7fbff !important;
  border-color:#b7d8f5 !important;
}
.driverLoadCard{transition:transform .18s ease,box-shadow .18s ease !important;}
.driverLoadCard:hover{transform:translateY(-4px) !important;box-shadow:var(--shadow-hover) !important;}
.gpsCard{border-left:0 !important;position:relative !important;overflow:hidden !important;}
.gpsCard:before{content:"";position:absolute;left:0;top:0;width:100%;height:6px;background:linear-gradient(90deg,#6655ee,#16a7f2);}
#gpsMap,.leaflet-container{
  border-radius:18px !important;
  border:1px solid #95c4ed !important;
  box-shadow:var(--shadow-soft) !important;
  overflow:hidden !important;
}
.gpsNotice{border-radius:14px !important;border-color:#9fc8ee !important;background:#f3f9ff !important;color:#294866 !important;}
.gpsNotice.good{background:#e7fbf4 !important;color:#087052 !important;border-color:#9ee2c9 !important;}
.gpsNotice.bad{background:#fff0f0 !important;color:#a51a24 !important;border-color:#f3b8b8 !important;}

/* Login and install pages inherit the same dark-header look */
.loginBody{
  min-height:100vh !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  padding:24px !important;
  background:
    radial-gradient(circle at 100% 0%,rgba(22,167,242,.24),transparent 30%),
    linear-gradient(180deg,#dceeff,#c9e4fb) !important;
}
.loginCard,.cleanLoginCard{
  width:min(440px,92vw) !important;
  border-radius:24px !important;
  padding:34px 30px 30px !important;
}
.loginBrandClean{text-align:center !important;margin-bottom:24px !important;}
.loginBrandClean .loginPill{margin:0 auto 15px !important;}
.loginBrandClean h1{color:var(--navy) !important;font-size:32px !important;letter-spacing:-.55px !important;margin:0 !important;}
.loginBrandClean p{color:#46617e !important;text-transform:uppercase !important;letter-spacing:.9px !important;font-size:12px !important;font-weight:950 !important;}
.loginButton{height:52px !important;margin-top:18px !important;font-size:16px !important;}
.loginHelpText{text-align:center !important;color:#55708d !important;font-size:13px !important;font-weight:800 !important;margin-top:16px !important;}
.installBox,.seedBox{max-width:980px !important;margin:40px auto !important;padding:30px !important;}
.seedLogo{background:linear-gradient(135deg,#0f6ed8,#064a9f) !important;box-shadow:0 10px 22px rgba(6,66,143,.22) !important;}
.seedBox h1,.installBox h1{color:var(--navy) !important;letter-spacing:-.5px !important;}

.footer{
  width:min(1480px,calc(100% - 56px)) !important;
  margin:18px auto 0 !important;
  color:#063c88 !important;
  font-weight:950 !important;
  padding:16px 0 34px !important;
  text-align:center !important;
}
.cloudymsBlockPopupInner{
  background:linear-gradient(135deg,#0f6ed8,#064a9f) !important;
  border:1px solid rgba(255,255,255,.35) !important;
  box-shadow:0 18px 45px rgba(6,66,143,.32) !important;
}
.cloudymsBlockPopupInner strong{color:#063c88 !important;}

@media(max-width:1250px){
  .quickActionGrid{grid-template-columns:repeat(3,1fr) !important;}
  .statGrid{grid-template-columns:repeat(3,minmax(150px,1fr)) !important;}
  .filterBar{grid-template-columns:repeat(2,minmax(180px,1fr)) !important;}
}
@media(max-width:900px){
  .topbar,.pageTitleRow{align-items:stretch !important;flex-direction:column !important;}
  .topbar{min-height:0 !important;padding:18px !important;}
  .navBar,.pageWrap,.footer{width:min(100% - 20px,1480px) !important;}
  .navBar{margin-top:18px !important;border-radius:20px 20px 0 0 !important;overflow:auto !important;flex-wrap:nowrap !important;}
  .navBar a{white-space:nowrap !important;}
  .pageWrap{padding:15px !important;}
  .pageTitleRow{padding:22px !important;}
  .pageTitleRow:before{position:relative !important;left:auto !important;top:auto !important;transform:none !important;width:54px !important;height:54px !important;}
  .filterBar{grid-template-columns:1fr !important;}
  .filterBar input,.filterBar select,.filterBar input[type=search]{min-width:0 !important;width:100% !important;}
  .statGrid,.quickActionGrid{grid-template-columns:1fr 1fr !important;}
}
@media(max-width:560px){
  .statGrid,.quickActionGrid{grid-template-columns:1fr !important;}
  .brandTitle{font-size:26px !important;}
  .brandLogo,.brandLogo.loginPill{min-width:112px !important;width:112px !important;height:54px !important;}
  .topRight{align-items:stretch !important;flex-direction:column !important;}
  .userPill,.topRight .btn{width:100% !important;}
}

@media print{
  body{background:white !important;}
  body:before,body:after{display:none !important;}
  .topbar,.navBar,.noPrint,.footer{display:none !important;}
  .pageWrap{width:auto !important;margin:0 !important;padding:0 !important;background:white !important;border:0 !important;box-shadow:none !important;}
  .card{box-shadow:none !important;}
}


/* =========================================================
   Mockup Match V2 - cleaner, closer to the approved image
   Adds real SVG icon treatments and stronger blue framing.
   ========================================================= */
.uiSvg{width:1.15em;height:1.15em;display:inline-block;vertical-align:-.18em;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none;flex:0 0 auto;}
body{background:radial-gradient(circle at 95% 20%,rgba(56,189,248,.24),transparent 22%),linear-gradient(135deg,rgba(255,255,255,.55) 0 9%,transparent 9% 18%,rgba(255,255,255,.34) 18% 19%,transparent 19% 100%),linear-gradient(180deg,#eaf6ff 0%,#d9eeff 48%,#a9d7fb 100%) !important;}
.topbar{padding:22px clamp(28px,5vw,70px) !important;min-height:112px !important;background:linear-gradient(135deg,rgba(255,255,255,.075),transparent 31%),linear-gradient(135deg,#071d3f 0%,#082b59 50%,#062246 100%) !important;border-bottom:4px solid rgba(68,174,255,.48) !important;}
.brandLogo{height:64px !important;min-width:132px !important;border-radius:17px !important;background:linear-gradient(135deg,#0d55bc 0%,#0b91ec 100%) !important;}
.brandTitle{font-size:34px !important;}
.userPill{min-height:58px !important;padding:14px 22px !important;border-radius:18px !important;background:rgba(7,34,73,.82) !important;}
.userPill:before{content:"" !important;background:none !important;width:0 !important;height:0 !important;margin:0 !important;box-shadow:none !important;}
.userPill:after{content:"";order:-1;width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#2b9bff,#0750ad);box-shadow:inset 0 1px 0 rgba(255,255,255,.28),0 8px 16px rgba(0,0,0,.28);}
.navBar{margin-top:34px !important;padding:20px 20px 12px !important;border-radius:24px 24px 0 0 !important;background:linear-gradient(180deg,rgba(249,252,255,.98),rgba(226,241,255,.97)) !important;border-color:#77afe5 !important;}
.navBar a{gap:9px !important;min-height:54px !important;padding:14px 17px !important;color:#073d8a !important;border-color:#9dc6ef !important;background:linear-gradient(180deg,#fff 0%,#ebf6ff 100%) !important;}
.navBar a .uiSvg{width:22px;height:22px;stroke-width:2.4;}
.navBar a:hover,.navBar a:focus,.navBar a[href="dispatch_board.php"]{background:linear-gradient(135deg,#0f73dc,#074a9c) !important;color:#fff !important;}
.pageWrap{padding:22px !important;background:linear-gradient(180deg,rgba(248,252,255,.98),rgba(223,240,255,.97)) !important;border-color:#77afe5 !important;}
.pageTitleRow{min-height:132px !important;padding:30px 30px 30px 116px !important;margin-bottom:24px !important;background:linear-gradient(180deg,#ffffff 0%,#edf7ff 100%) !important;border-color:#8dbff0 !important;box-shadow:0 14px 34px rgba(5,56,118,.13) !important;}
.pageTitleRow:before{content:"" !important;background:linear-gradient(135deg,#0f73dc,#063e8d) !important;border:1px solid rgba(255,255,255,.45) !important;}
.pageTitleRow:after{background:linear-gradient(120deg,transparent 0 68%,rgba(56,189,248,.09) 68% 100%),radial-gradient(circle at 54px 50%,rgba(255,255,255,.15) 0 28px,transparent 29px) !important;}
.pageTitleRow > div:first-child:before{content:"";position:absolute;left:-91px;top:50%;transform:translateY(-50%);width:64px;height:64px;border-radius:50%;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2.2" stroke-linecap="round" stroke-linejoin="round"><path d="M3 7h11v9H3z"/><path d="M14 10h4l3 3v3h-7z"/><circle cx="7" cy="18" r="2"/><circle cx="17" cy="18" r="2"/></svg>') center/35px 35px no-repeat;z-index:2;pointer-events:none;}
.pageTitleRow h1{font-size:clamp(2.5rem,4.1vw,3.55rem) !important;color:#06275b !important;}
.btn.iconBtn .uiSvg{width:1.1em;height:1.1em;stroke-width:2.5;}
.buttonRow .btn{min-height:56px !important;padding:0 24px !important;border-radius:14px !important;font-size:17px !important;}
.quickActionGrid{gap:18px !important;margin-bottom:24px !important;}
.quickActionCard{grid-template-columns:58px 1fr !important;min-height:176px !important;padding:24px 22px 22px !important;background:linear-gradient(180deg,#ffffff 0%,#f3f9ff 100%) !important;border:1.5px solid #87baeb !important;border-radius:14px !important;box-shadow:0 14px 28px rgba(5,56,118,.12) !important;}
.quickActionCard:before{height:7px !important;}
.quickActionCard:after{font-size:29px !important;right:20px !important;bottom:16px !important;color:#074a9c !important;}
.quickActionCard strong{font-size:1.06rem !important;color:#06275b !important;}
.qaIcon{width:50px !important;height:50px !important;color:#fff !important;font-size:0 !important;}
.qaIcon .uiSvg{width:27px;height:27px;stroke-width:2.25;}
.quickActionCard.primary .qaIcon{background:linear-gradient(135deg,#0f73dc,#063e8d) !important;}
.quickActionCard.secondary .qaIcon{background:linear-gradient(135deg,#1aa6e8,#0879c6) !important;}
.quickActionCard.gps .qaIcon{background:linear-gradient(135deg,#674ff0,#253db3) !important;}
.quickActionCard.billing .qaIcon{background:linear-gradient(135deg,#24b788,#087052) !important;}
.quickActionCard.rates .qaIcon{background:linear-gradient(135deg,#f5b700,#c88300) !important;}
.quickActionCard.drivers .qaIcon{background:linear-gradient(135deg,#0c3973,#061b3a) !important;}
.statGrid{gap:18px !important;margin-bottom:24px !important;}
.statCard.withIcon{grid-template-columns:70px 1fr !important;min-height:118px !important;padding:20px !important;background:linear-gradient(180deg,#ffffff 0%,#f2f8ff 100%) !important;border:1.5px solid #8dbff0 !important;box-shadow:0 14px 28px rgba(5,56,118,.12) !important;}
.statCard.withIcon:before{display:none !important;}
.statIcon{width:58px !important;height:58px !important;border-radius:50% !important;display:grid !important;place-items:center !important;color:#0f5fbd !important;background:linear-gradient(135deg,#e9f5ff,#cfe9ff) !important;border:1px solid rgba(15,110,216,.12) !important;box-shadow:inset 0 1px 0 rgba(255,255,255,.8),0 10px 18px rgba(5,56,118,.11) !important;}
.statIcon .uiSvg{width:30px;height:30px;stroke-width:2.25;}
.statText{display:block !important;}
.statCard span span,.statCard .statText > span{color:#163c69 !important;font-size:1rem !important;font-weight:850 !important;}
.statCard.withIcon strong{color:#0b55aa !important;font-size:2.35rem !important;}
.stat-in-route .statIcon{color:#4054d9 !important;background:linear-gradient(135deg,#eef0ff,#d8dcff) !important;}
.stat-delivered .statIcon{color:#0a58ad !important;}
.stat-ready-to-bill .statIcon{color:#0c61b8 !important;}
.dispatchFilters{grid-template-columns:repeat(2,minmax(230px,1fr)) repeat(2,minmax(210px,1fr)) minmax(270px,1.35fr) auto auto !important;padding:17px 18px !important;background:linear-gradient(180deg,#ffffff 0%,#e9f5ff 100%) !important;border:1.5px solid #87baeb !important;border-radius:16px !important;}
.fieldWithIcon{display:flex !important;align-items:center !important;min-width:0 !important;border:1px solid #a6cef3 !important;border-radius:13px !important;background:linear-gradient(180deg,#ffffff,#f5fbff) !important;box-shadow:inset 0 1px 0 rgba(255,255,255,.9) !important;overflow:hidden !important;}
.fieldWithIcon > .uiSvg{width:52px !important;height:52px !important;padding:14px !important;color:#0e72dc !important;background:linear-gradient(180deg,#edf7ff,#d9edff) !important;border-right:1px solid #b6d8f6 !important;stroke-width:2.3 !important;}
.fieldWithIcon input,.fieldWithIcon select{border:0 !important;border-radius:0 !important;min-height:52px !important;background:transparent !important;box-shadow:none !important;}
.fieldWithIcon:focus-within{border-color:#0f6ed8 !important;box-shadow:0 0 0 4px rgba(15,110,216,.13) !important;}
.card,.formCard,.installBox,.invoiceSheet,.driverLoadCard,.miniPanel,.noteBox,.gpsBox,.gpsCurrent,.loginCard,.cleanLoginCard{background:linear-gradient(180deg,#ffffff 0%,#f2f8ff 100%) !important;border:1.5px solid #8dbff0 !important;box-shadow:0 14px 30px rgba(5,56,118,.12) !important;}
.tableWrap{border-color:#91c0ed !important;box-shadow:0 10px 22px rgba(5,56,118,.08) !important;}
th{background:linear-gradient(180deg,#0c3973 0%,#061b3a 100%) !important;}
.actionButtonStack .btn.small{gap:6px !important;min-height:34px !important;}
.actionButtonStack .btn.small .uiSvg{width:14px;height:14px;}
@media(max-width:1250px){.dispatchFilters{grid-template-columns:repeat(2,minmax(180px,1fr)) !important;}}
@media(max-width:900px){.dispatchFilters{grid-template-columns:1fr !important;}.pageTitleRow > div:first-child:before{display:none !important;}}

/* =========================================================
   Mockup Match V3 - locked base cleanup
   - darker blue framed dashboard look
   - cards drill down cleanly
   - buttons stay inside cards/tables
   - active/unbilled default filter display
   ========================================================= */
:root{
  --steel-panel:#e7f2fc;
  --steel-panel-2:#d3e8fb;
  --deep-frame:#064a9f;
  --deep-frame-2:#082a58;
  --truck-blue:#0a5fbd;
}

.pageWrap{
  background:
    linear-gradient(180deg,rgba(250,253,255,.97),rgba(220,238,255,.98)) !important;
  box-shadow:0 34px 70px rgba(3,24,54,.22) !important;
}

.card,
.formCard,
.invoiceSheet,
.driverLoadCard,
.miniPanel,
.noteBox,
.gpsBox,
.gpsCurrent{
  position:relative !important;
  overflow:hidden !important;
  border:2px solid #7fb7ec !important;
  background:
    linear-gradient(180deg,rgba(255,255,255,.96),rgba(238,247,255,.98)) !important;
  box-shadow:0 16px 32px rgba(4,44,92,.13) !important;
}
.card:before,
.formCard:before,
.invoiceSheet:before,
.driverLoadCard:before,
.miniPanel:before,
.noteBox:before,
.gpsBox:before,
.gpsCurrent:before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:5px;
  background:linear-gradient(90deg,#063f8f,#0f73dc,#44b8ff);
  pointer-events:none;
}

.quickActionCard{
  overflow:hidden !important;
  align-items:flex-start !important;
  align-content:flex-start !important;
  isolation:isolate !important;
  border:2px solid #78b3e8 !important;
  box-shadow:0 16px 34px rgba(4,44,92,.15) !important;
}
.quickActionCard:hover{
  transform:translateY(-4px) !important;
  box-shadow:0 24px 44px rgba(4,44,92,.23) !important;
  border-color:#0f73dc !important;
}
.quickActionCard strong,
.quickActionCard .qaSub{
  max-width:100% !important;
  overflow-wrap:anywhere !important;
}
.quickActionCard .qaSub{
  line-height:1.45 !important;
}
.quickActionCard .qaIcon{
  flex:0 0 auto !important;
  z-index:2 !important;
}

.statCard.withIcon{
  overflow:hidden !important;
  position:relative !important;
  border:2px solid #7fb7ec !important;
  text-decoration:none !important;
}
.statCard.withIcon:hover,
.statCard.withIcon.activeDrill{
  transform:translateY(-3px) !important;
  border-color:#0758ba !important;
  box-shadow:0 22px 42px rgba(4,44,92,.23) !important;
}
.statCard.withIcon.activeDrill:after{
  content:"Selected";
  position:absolute;
  top:12px;
  right:12px;
  padding:4px 9px;
  border-radius:999px;
  color:#fff;
  background:linear-gradient(135deg,#0f73dc,#063f8f);
  font-size:11px;
  font-weight:950;
  letter-spacing:.2px;
}
.statCard .statText em{
  display:block !important;
  margin-top:4px !important;
  color:#527190 !important;
  font-size:12px !important;
  font-style:normal !important;
  font-weight:800 !important;
}

.dispatchFilters{
  grid-template-columns:minmax(230px,1.05fr) repeat(2,minmax(170px,.85fr)) repeat(2,minmax(190px,.95fr)) minmax(270px,1.45fr) auto auto !important;
  align-items:center !important;
  margin-bottom:10px !important;
  border:2px solid #7fb7ec !important;
  box-shadow:0 16px 32px rgba(4,44,92,.12) !important;
}
.filterBar .btn,
.formActions .btn,
.buttonRow .btn{
  max-width:100% !important;
}
.fieldWithIcon,
.fieldWithIcon input,
.fieldWithIcon select{
  min-width:0 !important;
}
.searchField input{
  width:100% !important;
}

.filterStatusLine{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin:0 0 18px;
}
.filterModePill,
.filterResultCount{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  font-weight:900;
  color:#08366f;
  background:linear-gradient(180deg,#ffffff,#e8f5ff);
  border:1px solid #94c3ef;
  box-shadow:0 8px 18px rgba(4,44,92,.09);
}
.filterModePill .uiSvg{
  width:18px;
  height:18px;
  color:#0f73dc;
}
.filterModePill.allLoads{
  color:#5b3510;
  border-color:#f1c15a;
  background:linear-gradient(180deg,#fff9e8,#fff0bf);
}
.filterResultCount{
  color:#fff;
  background:linear-gradient(135deg,#0f73dc,#063f8f);
  border-color:#064a9f;
}

.loadDataCard{
  scroll-margin-top:22px;
}
.sectionTitle.dataTitle{
  display:flex !important;
  align-items:flex-end !important;
  justify-content:space-between !important;
  gap:14px !important;
  flex-wrap:wrap !important;
}
.sectionTitle.dataTitle small{
  color:#54728f !important;
  font-size:12px !important;
  text-transform:none !important;
  letter-spacing:0 !important;
  font-weight:800 !important;
}

.tableWrap{
  overflow-x:auto !important;
  overflow-y:visible !important;
  border:1.5px solid #83b8eb !important;
}
table{
  width:100% !important;
}
th{
  white-space:nowrap !important;
}
td{
  vertical-align:top !important;
}
td.actions{
  min-width:190px !important;
  width:190px !important;
}
.actionButtonStack{
  display:flex !important;
  flex-wrap:wrap !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:7px !important;
  max-width:190px !important;
}
.actionButtonStack .btn.small{
  flex:0 1 auto !important;
  min-width:0 !important;
  max-width:100% !important;
  padding:8px 10px !important;
  white-space:nowrap !important;
  line-height:1 !important;
}

.buttonRow,
.formActions{
  max-width:100% !important;
  min-width:0 !important;
}
.pageTitleRow .buttonRow{
  justify-content:flex-end !important;
}
.pageTitleRow{
  overflow:hidden !important;
}
.pageTitleRow .btn{
  box-shadow:0 14px 28px rgba(4,44,92,.18) !important;
}

.statusPill,
.billingPill{
  border:1px solid rgba(8,42,88,.14) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45),0 5px 12px rgba(4,44,92,.08) !important;
}
.statusPill.billed,
.statusPill.cancelled{
  background:linear-gradient(180deg,#e4e9ef,#cfd8e3) !important;
  color:#344557 !important;
}

/* Keep buttons from floating out of compact cards/pages */
.twoCol,
.grid2,
.grid3,
.statGrid,
.quickActionGrid{
  min-width:0 !important;
}
.twoCol > *,
.grid2 > *,
.grid3 > *,
.statGrid > *,
.quickActionGrid > *{
  min-width:0 !important;
}
.card .btn,
.formCard .btn,
.miniPanel .btn,
.noteBox .btn,
.driverLoadCard .btn{
  max-width:100% !important;
}

@media(max-width:1380px){
  .dispatchFilters{
    grid-template-columns:repeat(3,minmax(190px,1fr)) !important;
  }
  .dispatchFilters .searchField{
    grid-column:span 2 !important;
  }
}
@media(max-width:980px){
  .dispatchFilters{
    grid-template-columns:1fr !important;
  }
  .dispatchFilters .searchField{
    grid-column:auto !important;
  }
  .pageTitleRow{
    align-items:flex-start !important;
  }
  .pageTitleRow .buttonRow{
    justify-content:flex-start !important;
  }
  td.actions{
    min-width:170px !important;
    width:170px !important;
  }
  .actionButtonStack{
    max-width:170px !important;
  }
}
@media(max-width:640px){
  .filterStatusLine{
    align-items:stretch;
  }
  .filterModePill,
  .filterResultCount{
    width:100%;
    justify-content:center;
  }
  .buttonRow .btn,
  .formActions .btn{
    width:100% !important;
  }
}

/* =========================================================
   Dispatch filter bar cleanup
   Keeps Filter / Reset inside the framed filter card instead
   of letting Reset float outside on medium-width screens.
   ========================================================= */
.dispatchFilters{
  grid-template-columns:minmax(220px,1.12fr) repeat(2,minmax(155px,.82fr)) repeat(2,minmax(180px,.95fr)) !important;
  align-items:center !important;
  overflow:hidden !important;
  width:100% !important;
  max-width:100% !important;
}
.dispatchFilters .fieldWithIcon{
  min-width:0 !important;
  width:100% !important;
}
.dispatchFilters .fieldWithIcon input,
.dispatchFilters .fieldWithIcon select{
  width:100% !important;
  min-width:0 !important;
}
.dispatchFilters .searchField{
  grid-column:1 / span 3 !important;
}
.dispatchFilterActions{
  grid-column:4 / span 2 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:10px !important;
  min-width:0 !important;
  width:100% !important;
}
.dispatchFilterActions .btn{
  min-height:54px !important;
  flex:0 1 132px !important;
  max-width:150px !important;
  width:auto !important;
  padding:0 18px !important;
}
.dispatchFilterActions .btn.ghost{
  background:linear-gradient(180deg,#ffffff 0%,#eef7ff 100%) !important;
}

@media(max-width:1280px){
  .dispatchFilters{
    grid-template-columns:repeat(2,minmax(180px,1fr)) !important;
  }
  .dispatchFilters .searchField{
    grid-column:1 / -1 !important;
  }
  .dispatchFilterActions{
    grid-column:1 / -1 !important;
    justify-content:flex-end !important;
  }
}
@media(max-width:640px){
  .dispatchFilterActions{
    flex-direction:column !important;
    align-items:stretch !important;
  }
  .dispatchFilterActions .btn{
    max-width:none !important;
    width:100% !important;
    flex:1 1 auto !important;
  }
}

/* =========================================================
   Email Invoice & Documents module
   ========================================================= */
.emailSettingsCard .sectionTitle svg,
.emailSendCard .sectionTitle svg{
  width:22px !important;
  height:22px !important;
  margin-right:8px !important;
  vertical-align:-5px !important;
}
.smallTitle{
  margin-top:18px !important;
  font-size:15px !important;
}
.emailTokenHint{
  margin:10px 0 14px !important;
  padding:12px 14px !important;
  border-radius:16px !important;
  border:1px solid rgba(37,99,235,.22) !important;
  background:linear-gradient(180deg,rgba(239,247,255,.96),rgba(218,235,255,.78)) !important;
  color:#1e3a5f !important;
  font-size:13px !important;
  line-height:1.45 !important;
}
.compactGrid{
  align-items:end !important;
}
.buttonAlignBottom{
  display:flex !important;
  align-items:flex-end !important;
}
.attachmentList{
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
  margin:8px 0 14px !important;
}
.attachmentRow{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:12px !important;
  padding:13px 14px !important;
  border-radius:18px !important;
  border:1px solid rgba(11,71,132,.22) !important;
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(232,242,255,.88)) !important;
  box-shadow:0 10px 22px rgba(3,31,67,.08) !important;
  cursor:pointer !important;
}
.attachmentRow.locked{
  border-color:rgba(14,165,233,.35) !important;
  background:linear-gradient(135deg,rgba(231,246,255,.98),rgba(206,231,255,.9)) !important;
  cursor:default !important;
}
.attachmentRow.missingFile{
  opacity:.68 !important;
  background:linear-gradient(180deg,#f3f5f7,#e7ebef) !important;
}
.attachmentRow span{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  min-width:0 !important;
  flex-wrap:wrap !important;
}
.attachmentRow span strong{
  color:#082a58 !important;
}
.attachmentRow small{
  flex-basis:100% !important;
  margin-left:28px !important;
  color:#5b6f86 !important;
}
.attachmentRow em{
  color:#274b72 !important;
  font-style:normal !important;
  font-size:12px !important;
  white-space:nowrap !important;
  background:rgba(8,42,88,.08) !important;
  padding:6px 9px !important;
  border-radius:999px !important;
}
.attachmentRow input[type="checkbox"]{
  width:18px !important;
  height:18px !important;
  accent-color:#0b5cad !important;
}
.detailGrid.singleCol{
  grid-template-columns:1fr !important;
}
@media(max-width:760px){
  .attachmentRow{
    align-items:flex-start !important;
    flex-direction:column !important;
  }
  .attachmentRow em{
    margin-left:28px !important;
  }
}

/* =========================================================
   Operations Suite v6 additions: alerts, archive, calendar,
   settlements, audit, document checklist, manager dashboard.
   ========================================================= */
.navBar a[href="manager_dashboard.php"],
.navBar a[href="alerts_dashboard.php"],
.navBar a[href="dispatch_calendar.php"],
.navBar a[href="load_archive.php"],
.navBar a[href="driver_settlements.php"]{
  border-color:#86bff2 !important;
}
.warningBadgeRow{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 18px !important;}
.warningBadge,.miniWarn,.docCheck{display:inline-flex;align-items:center;gap:6px;border-radius:999px;font-weight:950;letter-spacing:.05px;white-space:nowrap;}
.warningBadge{padding:10px 14px;border:1px solid rgba(255,255,255,.55);box-shadow:0 10px 22px rgba(7,42,84,.12);}
.warningBadge.danger{background:linear-gradient(135deg,#ffe5e5,#ffd0d0);color:#991b1b;border-color:#f5a3a3;}
.warningBadge.warn{background:linear-gradient(135deg,#fff4cf,#ffe49b);color:#815800;border-color:#edc44f;}
.warningBadge.info{background:linear-gradient(135deg,#dff2ff,#c7e6ff);color:#064a9a;border-color:#8dc7f2;}
.miniWarns{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}
.miniWarn{font-size:.72rem;padding:4px 7px;border:1px solid #d8b143;background:#fff4c1;color:#7a5200;}
.miniWarn.danger{background:#ffe1e1;color:#971b1b;border-color:#f0a6a6;}
.miniWarn.warn{background:#fff4c1;color:#7a5200;border-color:#e4bd50;}
.docChecklist{display:flex !important;flex-wrap:wrap;align-items:center;gap:8px !important;line-height:1.3 !important;}
.docCheck{font-size:.82rem;padding:7px 10px;border:1px solid #adcdf1;background:#eaf5ff;color:#074a9c;}
.docCheck.ok{background:#e2fff4;color:#087052;border-color:#8bdcbf;}
.docCheck.missing{background:#ffe9e9;color:#a11f1f;border-color:#f4a5a5;}
.docCheck.neutral{background:#eef4fb;color:#365a7c;border-color:#bfd6ef;}
.warnText{color:#a06400 !important;font-weight:900 !important;}
.badText{color:#b42318 !important;font-weight:900 !important;}
.goodText{color:#087052 !important;font-weight:900 !important;}
.managerStats .statCard strong{font-size:clamp(1.7rem,2.4vw,2.35rem) !important;}
.calendarGrid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;}
.calendarGrid.header{margin-bottom:10px;}
.calendarGrid.header div{padding:10px;border-radius:12px;background:linear-gradient(135deg,#07366f,#0d6fd3);color:#fff;font-weight:950;text-align:center;box-shadow:0 8px 18px rgba(8,46,100,.16);}
.calendarCell{min-height:138px;padding:10px;border-radius:16px;background:linear-gradient(180deg,#fff,#eff7ff);border:1px solid #9ec8ef;box-shadow:0 10px 22px rgba(6,48,105,.10);overflow:hidden;}
.calendarCell>strong{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:10px;background:#0d64c4;color:#fff;font-size:.92rem;}
.emptyDay{background:rgba(255,255,255,.35) !important;border-style:dashed !important;box-shadow:none !important;}
.calItem{margin-top:8px;padding:8px;border-radius:12px;background:#e9f4ff;border-left:5px solid #0f6ed8;box-shadow:inset 0 1px 0 rgba(255,255,255,.75);}
.calItem a{display:block;color:#063e82;font-weight:950;text-decoration:none;font-size:.83rem;}
.calItem small{display:block;color:#496784;font-weight:800;margin-top:2px;}
.calItem.delivery{border-left-color:#148a6a;background:#e6fff4;}
.calItem.event{border-left-color:#6655ee;background:#eeeeff;}
.compactForm{padding:0 !important;background:transparent !important;border:0 !important;box-shadow:none !important;}
.rateConfirmationSheet{max-width:1100px;margin-left:auto;margin-right:auto;}
.actionButtonStack{gap:6px !important;align-items:stretch !important;}
.quickActionCard.manager .qaIcon{background:linear-gradient(135deg,#0f6ed8,#061b3a) !important;}
.quickActionCard.archive .qaIcon{background:linear-gradient(135deg,#235179,#061b3a) !important;}
.quickActionCard.manager:before{background:linear-gradient(90deg,#0f6ed8,#061b3a) !important;}
.quickActionCard.archive:before{background:linear-gradient(90deg,#235179,#061b3a) !important;}
@media(max-width:900px){.calendarGrid{gap:6px}.calendarCell{min-height:110px;padding:7px}.calItem{padding:6px}.calItem a{font-size:.75rem}.calendarGrid.header div{font-size:.75rem;padding:8px 3px}}
@media print{.topbar,.navBar,.footer,.noPrint,.buttonRow,.filterBar{display:none !important}.pageWrap{box-shadow:none !important;border:0 !important;width:100% !important;margin:0 !important;padding:0 !important}.invoiceSheet{box-shadow:none !important;border:0 !important}}

/* =========================================================
   Flow V7 - tabbed command-center navigation
   Keeps the board from feeling crowded by grouping daily work,
   billing, drivers, reports, and admin setup into clear tabs.
   ========================================================= */
.navShell{
  width:min(1480px,calc(100% - 56px)) !important;
  margin:34px auto 0 !important;
  position:relative !important;
  z-index:1 !important;
}
.navShell .navBar.primaryTabs{
  width:100% !important;
  margin:0 !important;
  padding:18px 18px 12px !important;
  display:grid !important;
  grid-template-columns:repeat(8,minmax(120px,1fr)) !important;
  gap:10px !important;
  border-radius:24px 24px 0 0 !important;
  overflow:visible !important;
}
.navShell .navBar.primaryTabs a,
.navShell .navBar.primaryTabs a[href="dispatch_board.php"]:not(.activeTab):not(:hover):not(:focus){
  border:1px solid #9dc6ef !important;
  border-radius:16px !important;
  min-height:72px !important;
  flex-direction:column !important;
  gap:8px !important;
  padding:12px 10px !important;
  color:#073d8a !important;
  background:linear-gradient(180deg,#ffffff 0%,#ebf6ff 100%) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.88),0 8px 18px rgba(4,42,92,.10) !important;
}
.navShell .navBar.primaryTabs a .uiSvg{
  width:26px !important;
  height:26px !important;
}
.navShell .navBar.primaryTabs a span{
  line-height:1.1 !important;
  text-align:center !important;
}
.navShell .navBar.primaryTabs a.activeTab,
.navShell .navBar.primaryTabs a.activeTab[href="dispatch_board.php"]{
  color:#fff !important;
  background:linear-gradient(135deg,#0f73dc,#063f8f) !important;
  border-color:#0758ba !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 16px 30px rgba(6,66,143,.27) !important;
  transform:translateY(-2px) !important;
}
.secondaryNav{
  display:flex !important;
  flex-wrap:wrap !important;
  align-items:center !important;
  gap:10px !important;
  padding:0 18px 18px !important;
  background:linear-gradient(180deg,rgba(226,241,255,.97),rgba(213,233,252,.97)) !important;
  border:1px solid #77afe5 !important;
  border-top:0 !important;
  box-shadow:0 20px 40px rgba(4,31,70,.12) !important;
}
.workflowLabel{
  display:inline-flex !important;
  align-items:center !important;
  min-height:38px !important;
  padding:0 12px !important;
  border-radius:999px !important;
  color:#fff !important;
  background:linear-gradient(135deg,#061b3a,#082a58) !important;
  font-weight:950 !important;
  font-size:12px !important;
  letter-spacing:.45px !important;
  text-transform:uppercase !important;
}
.secondaryNav a{
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  min-height:40px !important;
  padding:8px 13px !important;
  border-radius:999px !important;
  color:#0a438f !important;
  background:linear-gradient(180deg,#ffffff,#edf7ff) !important;
  border:1px solid #9dc6ef !important;
  text-decoration:none !important;
  font-weight:950 !important;
  box-shadow:0 8px 16px rgba(4,42,92,.08) !important;
}
.secondaryNav a .uiSvg{width:18px !important;height:18px !important;}
.secondaryNav a:hover,
.secondaryNav a.activeSubTab{
  color:#fff !important;
  background:linear-gradient(135deg,#0f73dc,#063f8f) !important;
  border-color:#0758ba !important;
}
.navShell + .pageWrap,
.pageWrap{
  margin-top:0 !important;
}

.workflowStepper{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:12px !important;
  margin:0 0 22px !important;
}
.workflowStepper.adminFlow{grid-template-columns:repeat(5,minmax(0,1fr)) !important;}
.workflowStepper div{
  position:relative !important;
  min-height:74px !important;
  padding:14px 14px 14px 62px !important;
  border-radius:18px !important;
  background:linear-gradient(180deg,#ffffff,#eef7ff) !important;
  border:1.5px solid #88baeb !important;
  box-shadow:0 12px 24px rgba(5,56,118,.11) !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
}
.workflowStepper strong{
  position:absolute !important;
  left:14px !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  width:36px !important;
  height:36px !important;
  border-radius:50% !important;
  display:grid !important;
  place-items:center !important;
  color:#fff !important;
  background:linear-gradient(135deg,#0f73dc,#063f8f) !important;
  box-shadow:0 8px 16px rgba(6,66,143,.22) !important;
}
.workflowStepper span{font-weight:950 !important;color:#082a58 !important;}

.loadDetailTabs{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:10px !important;
  margin:0 0 18px !important;
  padding:14px !important;
  border-radius:18px !important;
  border:1.5px solid #86bff2 !important;
  background:linear-gradient(180deg,#ffffff,#eaf6ff) !important;
  box-shadow:0 12px 24px rgba(5,56,118,.10) !important;
  position:sticky !important;
  top:10px !important;
  z-index:5 !important;
}
.loadDetailTabs a{
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  min-height:42px !important;
  padding:9px 14px !important;
  border-radius:999px !important;
  color:#073d8a !important;
  background:linear-gradient(180deg,#ffffff,#f1f8ff) !important;
  border:1px solid #9fc8ee !important;
  text-decoration:none !important;
  font-weight:950 !important;
  box-shadow:0 8px 15px rgba(4,42,92,.08) !important;
}
.loadDetailTabs a:hover{
  color:#fff !important;
  background:linear-gradient(135deg,#0f73dc,#063f8f) !important;
}
.tabSection{scroll-margin-top:92px !important;}

.flowList{
  display:grid !important;
  grid-template-columns:repeat(5,minmax(0,1fr)) !important;
  gap:12px !important;
}
.flowList a{
  min-height:118px !important;
  padding:18px !important;
  border-radius:18px !important;
  border:1.5px solid #8dbff0 !important;
  background:linear-gradient(180deg,#ffffff,#f1f8ff) !important;
  text-decoration:none !important;
  box-shadow:0 12px 24px rgba(5,56,118,.10) !important;
}
.flowList b{display:block !important;color:#06275b !important;font-size:1rem !important;margin-bottom:8px !important;}
.flowList span{display:block !important;color:#46617e !important;font-weight:800 !important;line-height:1.35 !important;}
.adminActionGrid{grid-template-columns:repeat(4,minmax(190px,1fr)) !important;}

/* Make the daily board feel focused instead of crowded. */
.quickActionGrid:not(.adminActionGrid){grid-template-columns:repeat(6,minmax(150px,1fr)) !important;}
.quickActionGrid:not(.adminActionGrid) .quickActionCard{min-height:158px !important;}

@media(max-width:1250px){
  .navShell .navBar.primaryTabs{grid-template-columns:repeat(4,minmax(130px,1fr)) !important;}
  .quickActionGrid:not(.adminActionGrid),.adminActionGrid{grid-template-columns:repeat(3,minmax(180px,1fr)) !important;}
  .flowList{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .workflowStepper,.workflowStepper.adminFlow{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}
@media(max-width:900px){
  .navShell{width:min(100% - 20px,1480px) !important;margin-top:18px !important;}
  .navShell .navBar.primaryTabs{display:flex !important;overflow:auto !important;flex-wrap:nowrap !important;}
  .navShell .navBar.primaryTabs a{min-width:126px !important;}
  .secondaryNav{overflow:auto !important;flex-wrap:nowrap !important;}
  .secondaryNav a,.workflowLabel{white-space:nowrap !important;}
  .quickActionGrid:not(.adminActionGrid),.adminActionGrid{grid-template-columns:1fr 1fr !important;}
  .loadDetailTabs{position:relative !important;top:auto !important;}
}
@media(max-width:640px){
  .quickActionGrid:not(.adminActionGrid),.adminActionGrid,.flowList,.workflowStepper,.workflowStepper.adminFlow{grid-template-columns:1fr !important;}
  .navShell .navBar.primaryTabs a{min-width:118px !important;}
}

/* Flow Tabs v8: dispatcher-safe billing visibility + clickable date calendar */
.calendarLayout{
  align-items:start !important;
}
.calendarSideStack{
  display:grid !important;
  gap:18px !important;
}
.calendarTitleLine{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:12px !important;
}
.calendarTitleLine small{
  color:#527291 !important;
  font-weight:900 !important;
}
.calendarCell{
  padding:0 !important;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease !important;
}
.calendarCell:hover{
  transform:translateY(-2px) !important;
  border-color:#0b69cf !important;
  box-shadow:0 16px 30px rgba(7,61,132,.18) !important;
}
.calendarCell.selectedDay{
  border:2px solid #0b69cf !important;
  box-shadow:0 0 0 4px rgba(20,119,220,.13), 0 16px 30px rgba(7,61,132,.18) !important;
}
.calendarCell.todayDay .calendarDateLink strong{
  background:linear-gradient(135deg,#14a2e8,#07366f) !important;
}
.calendarCell.hasLoads{
  background:linear-gradient(180deg,#ffffff 0%,#eaf5ff 100%) !important;
}
.calendarDateLink{
  display:grid !important;
  gap:7px !important;
  min-height:138px !important;
  padding:10px !important;
  text-decoration:none !important;
  color:#063e82 !important;
}
.calendarDateLink strong{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:30px !important;
  height:30px !important;
  border-radius:10px !important;
  background:#0d64c4 !important;
  color:#fff !important;
  font-size:.92rem !important;
}
.daySummaryMain{
  display:block !important;
  color:#06275b !important;
  font-weight:1000 !important;
  font-size:.9rem !important;
}
.daySummaryLine{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:6px !important;
  padding:5px 7px !important;
  border-radius:10px !important;
  background:#e9f4ff !important;
  border:1px solid #c6e2fb !important;
  color:#164a75 !important;
  font-size:.76rem !important;
  font-weight:900 !important;
}
.daySummaryLine b{
  color:#07366f !important;
}
.deliveryLine{
  background:#e7fff4 !important;
  border-color:#bfead5 !important;
  color:#0f684c !important;
}
.eventLine{
  background:#eeeeff !important;
  border-color:#d4d1ff !important;
  color:#3d368c !important;
}
.dayLoadPanel{
  position:sticky !important;
  top:14px !important;
}
.dayLoadCard{
  display:grid !important;
  gap:5px !important;
  margin-top:10px !important;
  padding:13px 14px !important;
  border-radius:14px !important;
  text-decoration:none !important;
  color:#092b52 !important;
  background:linear-gradient(180deg,#ffffff 0%,#eff7ff 100%) !important;
  border:1.5px solid #8bbcea !important;
  box-shadow:0 10px 20px rgba(7,61,132,.10) !important;
}
.dayLoadCard:hover{
  transform:translateY(-1px) !important;
  border-color:#0b69cf !important;
  box-shadow:0 15px 28px rgba(7,61,132,.16) !important;
}
.dayLoadCard.delivery{
  border-color:#7bd3ad !important;
  background:linear-gradient(180deg,#ffffff 0%,#ebfff6 100%) !important;
}
.dayLoadCard.event{
  border-color:#b7b1ff !important;
  background:linear-gradient(180deg,#ffffff 0%,#f2f1ff 100%) !important;
}
.dayLoadCard strong{
  font-size:1rem !important;
  color:#06275b !important;
}
.dayLoadCard span,
.dayLoadCard small{
  color:#58728c !important;
  font-weight:850 !important;
}
.dayLoadType{
  justify-self:start !important;
  padding:4px 8px !important;
  border-radius:999px !important;
  background:linear-gradient(135deg,#0b69cf,#07366f) !important;
  color:#fff !important;
  font-size:.72rem !important;
  letter-spacing:.03em !important;
  text-transform:uppercase !important;
}
.dayLoadCard.delivery .dayLoadType{
  background:linear-gradient(135deg,#20a371,#0f684c) !important;
}
.dayLoadCard.event .dayLoadType{
  background:linear-gradient(135deg,#6655ee,#3d368c) !important;
}
@media(max-width:1100px){
  .calendarLayout{grid-template-columns:1fr !important;}
  .dayLoadPanel{position:static !important;}
}
@media(max-width:900px){
  .calendarDateLink{min-height:116px !important;padding:7px !important;}
  .daySummaryLine{font-size:.68rem !important;padding:4px 5px !important;}
  .daySummaryMain{font-size:.78rem !important;}
}
