.dashboard-three { grid-template-columns: 1.05fr .85fr 1.1fr; }
.detail-three { grid-template-columns: 1fr 1fr 1fr; }
.cost-layout { grid-template-columns: 360px 1fr 340px; align-items: start; }
.analytics-layout { grid-template-columns: 1fr 360px; align-items: start; }
.planner-layout { grid-template-columns: minmax(300px, 360px) minmax(420px, 1fr) minmax(320px, 380px); align-items: start; }
.fleet-layout { grid-template-columns: 1fr; }
.settings-layout { grid-template-columns: 1fr 380px; align-items: start; }
.upload-layout { grid-template-columns: 1fr 1fr; align-items: start; }
.compliance-tabs, .tabs { margin-bottom: 14px; }
.truck-history-table {
  max-height: calc(100vh - var(--topbar) - 230px);
  min-height: 220px;
}
.event-list { display: grid; gap: 8px; }
.event-item { display: grid; grid-template-columns: 92px 1fr auto; gap: 10px; align-items: center; padding: 9px; border: 1px solid var(--border); border-radius: 8px; background: #fff; }
.event-item b small { display: block; margin-top: 3px; color: var(--muted); font-weight: 600; white-space: normal; }
.activity-log { display: grid; gap: 8px; max-height: 280px; overflow: auto; }
.activity-log .event-item { grid-template-columns: 142px 1fr auto; }
.profile-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.profile-cell { border: 1px solid var(--border); border-radius: 6px; padding: 9px; background: var(--surface-quiet); }
.profile-cell span { display: block; color: var(--muted); font-size: 11px; font-weight: 700; }
.profile-cell b { display: block; margin-top: 3px; }
.vehicle-profile-controls {
  display: grid;
  grid-template-columns: minmax(220px, 1.4fr) repeat(2, minmax(150px, .8fr)) auto auto;
  gap: 10px;
  align-items: end;
  margin-bottom: 16px;
}
.vehicle-profile-controls .form-row { margin: 0; min-width: 0; }
.decision-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.vehicle-profile-card {
  min-width: 0;
  overflow: hidden;
}
.vehicle-profile-card .card-head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 12px;
}
.vehicle-profile-card .report-field-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.vehicle-profile-card .report-field {
  grid-template-columns: 1fr;
}
.vehicle-profile-card .report-field .badge {
  width: max-content;
  max-width: 100%;
}
.vehicle-profile-card .report-field b {
  overflow-wrap: break-word;
  word-break: normal;
}
.decision-grid .vehicle-profile-card .report-field-grid {
  grid-template-columns: repeat(2, minmax(140px, 1fr));
}
.decision-kpis {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.decision-kpis > div {
  min-height: 72px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface-quiet);
}
.decision-kpis span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}
.decision-kpis b {
  display: block;
  min-width: 0;
  margin-top: 6px;
  overflow-wrap: anywhere;
  font-family: var(--font-mono);
  font-size: 18px;
  line-height: 1.15;
}
.compact-table {
  max-height: 320px;
}
.cost-bar-list {
  display: grid;
  gap: 9px;
  margin: 6px 0 14px;
}
.cost-bar-row {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) minmax(120px, 1.2fr) minmax(90px, auto);
  gap: 10px;
  align-items: center;
  font-size: 12px;
}
.cost-bar-row span {
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cost-bar-row div {
  height: 9px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--surface-quiet);
  border: 1px solid var(--border);
}
.cost-bar-row i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--brand);
}
.cost-bar-row b {
  font-family: var(--font-mono);
  font-size: 12px;
  text-align: right;
}
.vehicle-profile-full,
.vehicle-profile-compact {
  display: grid;
  gap: 16px;
}
.mini-stat { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--border); }
.mini-stat:last-child { border-bottom: 0; }
.planner-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.planner-summary-cell {
  min-width: 0;
  min-height: 88px;
  display: grid;
  align-content: start;
  gap: 4px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
}
.planner-summary-cell span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.planner-summary-cell b {
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 19px;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.planner-summary-cell small {
  min-width: 0;
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.planner-panel {
  position: sticky;
  top: calc(var(--topbar) + 16px);
  max-height: calc(100vh - var(--topbar) - 38px);
  overflow: auto;
}
.planner-subhead { margin-top: 0; }
.planner-divider {
  height: 1px;
  margin: 14px 0;
  background: var(--border);
}
.planner-stop-list {
  display: grid;
  gap: 8px;
}
.planner-stop-list .stop-item {
  grid-template-columns: 28px minmax(0, 1fr) 32px 18px;
}
.planner-stop-list .stop-item { margin-bottom: 0; }
.stop-main {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.stop-main b {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.stop-main small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
}
.stop-item .icon-btn {
  width: 32px;
  height: 32px;
}
.stop-item .icon-btn i,
.drag-handle {
  width: 16px;
  height: 16px;
}
.drag-handle { color: var(--muted); }
.planner-add-stop {
  display: grid;
  gap: 9px;
  margin-top: 14px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface-quiet);
}
.planner-add-stop .btn,
.planner-add-stop select {
  width: 100%;
}
.planner-checklist {
  display: grid;
  gap: 8px;
}
.planner-check {
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  font-weight: 700;
}
.planner-check input {
  width: 18px;
  height: 18px;
  accent-color: var(--brand);
}
.planner-map-card {
  min-width: 0;
}
.planner-main-column {
  min-width: 0;
  display: grid;
  gap: 16px;
}
.planner-map-head {
  min-height: 70px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 13px 14px;
  border-bottom: 1px solid var(--border);
  background: #fff;
}
.planner-map-head h2,
.planner-map-head p { margin: 0; }
.planner-map-head p { font-size: 12px; }
.planner-map {
  height: min(640px, calc(100vh - var(--topbar) - 188px));
  min-height: 520px;
}
.planner-route-list {
  display: grid;
  gap: 8px;
}
.route-option {
  width: 100%;
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto 24px;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  text-align: left;
}
.route-option:hover {
  border-color: var(--border-strong);
  box-shadow: 0 4px 12px rgba(20,24,23,.06);
}
.route-option span {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.route-option b,
.route-option small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.route-option small {
  color: var(--muted);
  font-size: 12px;
}
.route-option-stats {
  text-align: right;
}
.route-option i {
  width: 17px;
  color: var(--muted);
}
.route-option.selected-route {
  border-color: rgba(255,59,31,.5);
  background: #FFF4F1;
}
.route-option.selected-route i,
.route-option.selected-route > span:first-child b {
  color: #8F1B0B;
}
.planner-route-detail {
  display: grid;
  gap: 8px;
}
.planner-route-detail div {
  display: grid;
  grid-template-columns: minmax(92px, .8fr) minmax(0, 1fr);
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  font-size: 12px;
}
.planner-route-detail span {
  color: var(--muted);
  font-weight: 700;
}
.planner-route-detail b {
  min-width: 0;
  overflow-wrap: anywhere;
  font-weight: 800;
}
.planner-directory-card .card-head {
  align-items: flex-start;
}
.planner-directory-card .card-head p {
  margin-bottom: 0;
  font-size: 12px;
}
.planner-directory-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.planner-directory-search {
  max-width: none;
  min-width: min(360px, 100%);
}
.planner-directory {
  max-height: 460px;
  padding-right: 2px;
}
.planner-directory-row {
  grid-template-columns: minmax(0, 1fr) auto;
  padding: 0;
  overflow: hidden;
}
.directory-node-main {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(150px, auto) minmax(120px, auto);
  gap: 8px;
  align-items: center;
  padding: 9px;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
}
.directory-node-main:hover {
  background: var(--surface-quiet);
}
.directory-node-main div,
.directory-node-main span {
  min-width: 0;
}
.planner-directory-row > a {
  align-self: stretch;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border-left: 1px solid var(--border);
}
.planner-directory-row.selected-node {
  border-color: rgba(255,59,31,.45);
  background: #FFF4F1;
}
.planner-share-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.planner-share-row .btn {
  padding: 0 8px;
}
.route-card { display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: start; }
.route-meter { height: 8px; border-radius: 999px; background: #E5E7EB; overflow: hidden; margin-top: 8px; }
.route-meter span { display: block; height: 100%; background: var(--brand); width: var(--pct); }
.alert-row { border-left: 4px solid var(--border); }
.alert-row.critical { border-left-color: var(--red); }
.alert-row.warning { border-left-color: var(--amber); }
.alert-row.info { border-left-color: var(--blue); }
.config-section { margin-bottom: 16px; }
.settings-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.settings-section .card-head { margin-bottom: 12px; }
.settings-side {
  display: grid;
  gap: 16px;
  position: sticky;
  top: calc(var(--topbar) + 16px);
}
.settings-toggle-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.settings-toggle {
  min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface-quiet);
}
.settings-toggle b,
.settings-toggle small { display: block; }
.settings-toggle small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
}
.settings-toggle input {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  accent-color: var(--brand);
}
.settings-action-row { margin-top: 12px; }
.settings-connection-list .event-item {
  grid-template-columns: 100px 1fr auto;
}
.field-meta { color: var(--muted); font-size: 11px; margin-top: 4px; }
.map-callout { max-width: 280px; }
.mapping-grid { display: grid; grid-template-columns: 1fr 1fr auto; gap: 8px; align-items: center; font-size: 12px; padding: 7px 0; border-bottom: 1px solid var(--border); }
.mapping-grid:first-child { color: var(--muted); font-weight: 800; text-transform: uppercase; font-size: 11px; }
.map-full .map-overlay {
  right: auto;
  max-width: calc(100% - 410px);
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}
.full-map-tools { position: absolute; top: 14px; right: 14px; z-index: 6; width: min(360px, calc(100% - 28px)); }
.realtime-card { margin-bottom: 16px; }
.realtime-metrics { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 8px; }
.realtime-metrics .metric { min-height: 72px; overflow: hidden; }
.realtime-metrics .metric b { display: block; overflow-wrap: anywhere; }
.api-config-form { display: grid; gap: 14px; }
.api-config-primary {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(280px, 1fr);
  gap: 12px;
  align-items: start;
}
.api-key-row,
.api-base-row { min-width: 0; }
.readonly-field {
  color: var(--muted);
  background: var(--surface-quiet);
}
.api-status-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(150px, 1fr));
  gap: 8px;
}
.api-status-metric {
  min-width: 0;
  min-height: 62px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 9px 10px;
  background: var(--surface-quiet);
}
.api-status-metric span {
  display: block;
  color: var(--muted);
  font-size: 11px;
}
.api-status-metric b {
  display: block;
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 13px;
  overflow-wrap: anywhere;
}
.api-action-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.report-parameter-card { margin-bottom: 16px; }
.report-parameter-grid {
  display: grid;
  grid-template-columns: minmax(240px, 1.1fr) minmax(260px, 1.2fr) auto;
  gap: 12px;
  align-items: end;
}
.report-filter-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(160px, 1fr));
  gap: 12px;
  align-items: end;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
.form-row.compact label { min-height: 17px; }
.action-row .btn { width: 100%; }
.source-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(130px, 1fr));
  gap: 8px;
  margin-bottom: 16px;
}
.source-pill {
  display: grid;
  gap: 7px;
  min-height: 68px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
}
.source-pill span:first-child {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.source-pill small { color: var(--muted); line-height: 1.35; }
.report-stack { display: grid; gap: 12px; }
.report-section { padding: 0; overflow: hidden; }
.report-section summary {
  min-height: 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 16px;
  cursor: pointer;
  font-weight: 800;
}
.report-section summary::-webkit-details-marker { display: none; }
.report-section-body {
  padding: 0 16px 16px;
  border-top: 1px solid var(--border);
}
.report-field-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  padding-top: 12px;
}
.report-field {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 6px 8px;
  align-items: start;
  min-height: 76px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface-quiet);
}
.report-field span:first-child {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.report-field b {
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: 13px;
}
.report-sublist { margin-top: 12px; }
.route-map-panel { margin: 10px 0 12px; }
.map-empty {
  display: grid;
  place-items: center;
  color: var(--muted);
  border: 1px solid var(--border);
}
.report-callout {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 12px;
  padding: 10px 12px;
  border: 1px solid rgba(255,59,31,.24);
  border-radius: 8px;
  background: #FFF4F1;
}
.report-callout.warning {
  border-color: rgba(245,158,11,.32);
  background: #FFFBEB;
}
.report-callout span {
  color: #374151;
  overflow-wrap: anywhere;
}
.link-inline {
  color: var(--blue);
  font-weight: 800;
}
.link-inline:hover { text-decoration: underline; }
.tracking-page {
  max-width: none;
  padding: 18px;
}
.tracking-shell {
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}
.tracking-fleet-pane {
  position: sticky;
  top: calc(var(--topbar) + 58px);
  max-height: calc(100vh - var(--topbar) - 82px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  background: var(--surface);
}
.tracking-pane-head,
.tracking-job-header,
.tracking-event-top,
.tracking-map-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
}
.tracking-pane-head { justify-content: space-between; }
.tracking-pane-head h1 { margin: 0; }
.tracking-pane-head > div { display: flex; align-items: center; gap: 8px; }
.tracking-search {
  position: relative;
}
.tracking-search i {
  position: absolute;
  left: 11px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  color: var(--muted);
}
.tracking-search .field {
  width: 100%;
  padding-left: 34px;
}
.tracking-search.compact { margin-bottom: 10px; }
.tracking-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.tracking-filter-chip {
  border: 1px solid var(--border);
  cursor: pointer;
}
.tracking-filter-chip.active {
  border-color: rgba(255,59,31,.45);
  background: #FFE8E3;
  color: #8F1B0B;
}
.tracking-fleet-list {
  display: grid;
  gap: 8px;
  overflow: auto;
  padding-right: 2px;
}
.tracking-truck-card {
  width: 100%;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
  text-align: left;
  padding: 10px;
  border: 1px solid var(--border);
  border-left: 4px solid transparent;
  border-radius: 8px;
  background: #fff;
}
.tracking-truck-card:hover { background: #FAFCFB; }
.tracking-truck-card.selected {
  border-left-color: var(--brand);
  background: #FFF4F1;
}
.tracking-thumb,
.tracking-photo-thumb {
  display: grid;
  place-items: center;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface-quiet);
  color: var(--muted);
}
.tracking-thumb {
  width: 42px;
  height: 42px;
}
.tracking-thumb i { width: 20px; }
.tracking-truck-main {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.tracking-truck-title { font-weight: 800; color: var(--text); }
.tracking-truck-sub,
.tracking-truck-model,
.tracking-truck-job {
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tracking-truck-job {
  display: flex;
  align-items: center;
  gap: 5px;
  min-width: 0;
}
.tracking-detail-pane {
  min-width: 0;
  display: grid;
  gap: 12px;
}
.tracking-job-header {
  min-height: 62px;
  flex-wrap: wrap;
}
.tracking-job-id {
  display: grid;
  gap: 1px;
}
.tracking-job-id span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}
.tracking-job-id b {
  font-family: var(--font-mono);
  font-size: 16px;
}
.live-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 24px;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid var(--border);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}
.live-pill span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--muted);
}
.live-pill.is-live {
  border-color: rgba(255,59,31,.3);
  color: #8F1B0B;
  background: #FFE8E3;
}
.live-pill.is-live span {
  background: var(--brand);
  animation: trackingPulse 1.4s ease infinite;
}
@keyframes trackingPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255,59,31,.34); }
  50% { box-shadow: 0 0 0 6px rgba(255,59,31,0); }
}
.tracking-route-title {
  flex: 1 1 320px;
  min-width: 0;
  color: #374151;
  overflow-wrap: anywhere;
}
.tracking-route-title span { color: var(--muted); }
.tracking-header-meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}
.tracking-header-meta i { width: 16px; }
.tracking-map-card {
  position: relative;
  min-height: 380px;
}
.tracking-map-card.is-collapsed {
  min-height: 56px;
}
.tracking-map-card.is-collapsed .tracking-map {
  display: none;
}
.tracking-map-toolbar {
  position: absolute;
  z-index: 6;
  top: 12px;
  left: 12px;
  right: 12px;
  justify-content: space-between;
  pointer-events: none;
}
.tracking-map-toolbar > * { pointer-events: auto; }
.tracking-map {
  height: 440px;
  min-height: 360px;
}
.tracking-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 12px;
  align-items: start;
}
.tracking-detail-grid.manifest-closed {
  grid-template-columns: minmax(0, 1fr);
}
.tracking-detail-grid.manifest-closed .tracking-manifest {
  display: none;
}
.tracking-tabs {
  margin-bottom: 12px;
  max-width: 100%;
  overflow-x: auto;
}
.tracking-progress-card {
  margin-bottom: 12px;
}
.tracking-stepper {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
  align-items: start;
}
.tracking-step {
  position: relative;
  display: grid;
  gap: 4px;
  min-width: 0;
  padding-top: 28px;
}
.tracking-step::before {
  content: "";
  position: absolute;
  top: 10px;
  left: 16px;
  right: -18px;
  border-top: 2px solid #D1D5DB;
}
.tracking-step:last-child::before { display: none; }
.tracking-step-dot {
  position: absolute;
  top: 2px;
  left: 0;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid #D1D5DB;
  background: #fff;
  z-index: 1;
}
.tracking-step.past .tracking-step-dot,
.tracking-step.current .tracking-step-dot {
  border-color: var(--brand);
  background: var(--brand);
}
.tracking-step.current b { color: #8F1B0B; }
.tracking-step b {
  min-width: 0;
  overflow-wrap: anywhere;
}
.tracking-step small {
  color: var(--muted);
  font-size: 11px;
}
.tracking-summary-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 12px;
}
.tracking-card-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(150px, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}
.tracking-metric {
  min-height: 108px;
  display: grid;
  gap: 6px;
  align-content: start;
}
.tracking-metric i {
  width: 18px;
  color: var(--muted);
}
.tracking-metric b {
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: 18px;
  line-height: 1.25;
}
.tracking-metric span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}
.tracking-person-card {
  min-height: 108px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.tracking-avatar {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #FFE8E3;
  color: #8F1B0B;
  font-weight: 800;
}
.tracking-person-card div {
  display: grid;
  gap: 3px;
}
.tracking-person-card span:last-child {
  color: var(--muted);
  font-size: 12px;
}
.tracking-photo-section {
  margin-bottom: 12px;
}
.tracking-photo-row {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(178px, 210px);
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
}
.tracking-photo-card {
  min-height: 188px;
  display: grid;
  gap: 6px;
  align-content: start;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  text-align: left;
}
button.tracking-photo-card {
  cursor: pointer;
}
button.tracking-photo-card.disabled {
  cursor: not-allowed;
  opacity: .55;
}
.tracking-photo-thumb {
  height: 88px;
}
.tracking-photo-thumb i {
  width: 24px;
  height: 24px;
}
.tracking-photo-card span,
.tracking-photo-card small {
  color: var(--muted);
  font-size: 12px;
}
.tracking-timeline-card {
  padding-bottom: 12px;
}
.tracking-timeline-head {
  align-items: center;
}
.tracking-timeline-tools {
  display: grid;
  gap: 10px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.tracking-timeline-search {
  min-width: min(320px, 100%);
}
.tracking-event-feed {
  display: grid;
  gap: 8px;
  max-height: 520px;
  overflow: auto;
  padding: 12px 2px 0 0;
}
.tracking-event {
  display: grid;
  grid-template-columns: 150px 34px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
}
.tracking-event time {
  color: #374151;
  font-size: 12px;
}
.tracking-event-rail {
  min-height: 100%;
  display: grid;
  justify-items: center;
  color: var(--muted);
  border-left: 3px solid var(--border);
}
.tracking-event-rail i {
  width: 18px;
  height: 18px;
  margin-left: -3px;
  padding: 2px;
  background: #fff;
}
.tracking-event.event-checkpoint .tracking-event-rail { border-color: var(--brand); color: var(--brand); }
.tracking-event.event-gps .tracking-event-rail { border-color: var(--blue); color: var(--blue); }
.tracking-event.event-status .tracking-event-rail,
.tracking-event.event-traffic .tracking-event-rail { border-color: var(--amber); color: var(--amber); }
.tracking-event.event-compliance .tracking-event-rail,
.tracking-event.event-audit .tracking-event-rail { border-color: var(--purple); color: var(--purple); }
.tracking-event.event-financial .tracking-event-rail { border-color: var(--green); color: var(--green); }
.tracking-event-body {
  min-width: 0;
  display: grid;
  gap: 6px;
}
.tracking-event-top {
  justify-content: space-between;
  color: var(--muted);
  font-size: 12px;
}
.tracking-event-top small {
  color: var(--muted);
}
.tracking-event-top .icon-btn {
  width: 30px;
  height: 30px;
}
.tracking-event-body > b {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tracking-event details {
  color: var(--muted);
  font-size: 12px;
}
.tracking-event summary {
  cursor: pointer;
  font-weight: 800;
  color: #374151;
}
.tracking-event p {
  margin: 6px 0 0;
  overflow-wrap: anywhere;
}
.tracking-event pre {
  overflow: auto;
  margin: 8px 0 0;
  padding: 8px;
  border-radius: 6px;
  background: var(--surface-quiet);
  color: #374151;
  font: 11px/1.45 var(--font-mono);
}
.tracking-comment-box {
  display: grid;
  gap: 8px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
.tracking-comment-box textarea {
  width: 100%;
  min-height: 82px;
}
.tracking-comment-box.disabled {
  padding: 10px;
  border: 1px dashed var(--border);
  border-radius: 8px;
}
.tracking-manifest {
  position: sticky;
  top: calc(var(--topbar) + 58px);
  max-height: calc(100vh - var(--topbar) - 82px);
  overflow: auto;
}
.tracking-manifest-list {
  display: grid;
  gap: 7px;
  margin-top: 10px;
}
.tracking-manifest-row {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 10px auto auto;
  gap: 8px;
  align-items: center;
  padding: 9px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  text-align: left;
}
.tracking-manifest-row span:first-child {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.tracking-manifest-row b,
.tracking-manifest-row small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tracking-manifest-row small {
  color: var(--muted);
  font-size: 12px;
}
.tracking-status-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--muted);
}
.tracking-status-dot.status-green { background: var(--green); }
.tracking-status-dot.status-yellow { background: var(--amber); }
.tracking-status-dot.status-red { background: var(--red); }
.tracking-status-dot.status-blue { background: var(--blue); }
.tracking-mini-checkpoints {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
@media (max-width: 1279px) {
  .dashboard-three, .detail-three, .cost-layout, .analytics-layout, .planner-layout, .settings-layout, .upload-layout { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .planner-layout > .map-card, .cost-layout > .card:nth-child(2) { grid-column: 1 / -1; }
  .planner-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .decision-grid { grid-template-columns: 1fr; }
  .vehicle-profile-controls { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .settings-summary-grid,
  .settings-toggle-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .settings-side { position: static; }
  .planner-panel {
    position: static;
    max-height: none;
  }
  .planner-map { height: 560px; min-height: 480px; }
  .realtime-metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .api-config-primary,
  .api-status-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .report-parameter-grid, .report-filter-grid, .source-strip, .report-field-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .tracking-shell { grid-template-columns: 320px minmax(0, 1fr); }
  .tracking-detail-grid { grid-template-columns: 1fr; }
  .tracking-manifest { position: static; max-height: none; }
  .tracking-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 767px) {
  .dashboard-three, .detail-three, .cost-layout, .analytics-layout, .planner-layout, .settings-layout, .upload-layout { grid-template-columns: 1fr; }
  .planner-summary { grid-template-columns: 1fr; }
  .vehicle-profile-controls,
  .decision-grid,
  .decision-kpis { grid-template-columns: 1fr; }
  .cost-bar-row { grid-template-columns: 1fr; }
  .cost-bar-row b { text-align: left; }
  .vehicle-profile-card .report-field-grid,
  .decision-grid .vehicle-profile-card .report-field-grid { grid-template-columns: 1fr; }
  .settings-summary-grid,
  .settings-toggle-grid { grid-template-columns: 1fr; }
  .planner-map-head {
    align-items: flex-start;
    flex-direction: column;
  }
  .planner-map { height: 420px; min-height: 360px; }
  .planner-share-row { grid-template-columns: 1fr; }
  .planner-directory-toolbar { align-items: stretch; flex-direction: column; }
  .planner-directory-search { min-width: 0; width: 100%; }
  .directory-node-main { grid-template-columns: 1fr; }
  .planner-directory-row { grid-template-columns: 1fr; }
  .planner-directory-row > a {
    min-height: 40px;
    border-left: 0;
    border-top: 1px solid var(--border);
  }
  .planner-stop-list .stop-item {
    grid-template-columns: 28px minmax(0, 1fr) 32px;
  }
  .planner-stop-list .drag-handle { display: none; }
  .event-item, .activity-log .event-item, .route-card { grid-template-columns: 1fr; }
  .realtime-metrics { grid-template-columns: 1fr; }
  .api-config-primary,
  .api-status-grid { grid-template-columns: 1fr; }
  .api-action-row .btn { width: 100%; }
  .report-parameter-grid, .report-filter-grid, .source-strip, .report-field-grid { grid-template-columns: 1fr; }
  .report-callout { align-items: flex-start; flex-direction: column; }
  .tracking-page { padding: 12px; }
  .tracking-shell { grid-template-columns: 1fr; }
  .tracking-fleet-pane {
    position: static;
    max-height: none;
  }
  .tracking-map-toolbar {
    position: static;
    padding: 10px;
    flex-wrap: wrap;
    background: #fff;
    border-bottom: 1px solid var(--border);
  }
  .tracking-map { height: 360px; min-height: 320px; }
  .tracking-card-grid { grid-template-columns: 1fr; }
  .tracking-event { grid-template-columns: 1fr; }
  .tracking-event-rail {
    min-height: 0;
    height: 3px;
    border-left: 0;
    border-top: 3px solid var(--border);
    justify-items: start;
  }
  .tracking-event-rail i { margin-top: -11px; margin-left: 0; }
  .tracking-truck-card { grid-template-columns: 42px minmax(0, 1fr); }
  .tracking-truck-card > .badge { grid-column: 2; width: fit-content; }
  .map-full .map-overlay {
    right: 14px;
    max-width: calc(100% - 28px);
  }
  .full-map-tools {
    left: 14px;
    right: 14px;
    top: 132px;
    width: auto;
    max-height: calc(100% - 146px);
    overflow: auto;
  }
}

/* RESPONSIVE: mobile-first layout stacking */
.dashboard-three,
.detail-three,
.cost-layout,
.analytics-layout,
.planner-layout,
.settings-layout,
.upload-layout,
.planner-summary,
.realtime-metrics,
.api-config-primary,
.api-status-grid,
.report-parameter-grid,
.report-filter-grid,
.source-strip,
.report-field-grid,
.tracking-shell,
.tracking-detail-grid,
.tracking-card-grid {
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .dashboard-three,
  .detail-three,
  .cost-layout,
  .analytics-layout,
  .planner-layout,
  .settings-layout,
  .upload-layout,
  .planner-summary,
  .realtime-metrics,
  .api-config-primary,
  .api-status-grid,
  .report-parameter-grid,
  .report-filter-grid,
  .source-strip,
  .report-field-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .tracking-shell {
    grid-template-columns: 320px minmax(0, 1fr);
  }
  .tracking-card-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 1280px) {
  .dashboard-three { grid-template-columns: 1.05fr .85fr 1.1fr; }
  .detail-three { grid-template-columns: 1fr 1fr 1fr; }
  .cost-layout { grid-template-columns: 360px 1fr 340px; }
  .analytics-layout { grid-template-columns: 1fr 360px; }
  .planner-layout { grid-template-columns: minmax(300px, 360px) minmax(420px, 1fr) minmax(320px, 380px); }
  .settings-layout { grid-template-columns: 1fr 380px; }
  .upload-layout { grid-template-columns: 1fr 1fr; }
  .planner-summary { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .realtime-metrics { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .api-status-grid { grid-template-columns: repeat(5, minmax(150px, 1fr)); }
  .api-config-primary { grid-template-columns: minmax(280px, 1fr) minmax(280px, 1fr); }
  .report-parameter-grid { grid-template-columns: minmax(240px, 1.1fr) minmax(260px, 1.2fr) auto; }
  .report-filter-grid { grid-template-columns: repeat(4, minmax(160px, 1fr)); }
  .source-strip { grid-template-columns: repeat(6, minmax(130px, 1fr)); }
  .report-field-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .tracking-shell { grid-template-columns: 360px minmax(0, 1fr); }
  .tracking-detail-grid { grid-template-columns: minmax(0, 1fr) 340px; }
  .tracking-card-grid { grid-template-columns: repeat(5, minmax(150px, 1fr)); }
}

/* Page-level responsiveness and density refinements */
.dashboard-three,
.detail-three,
.cost-layout,
.analytics-layout,
.planner-layout,
.settings-layout,
.upload-layout,
.tracking-shell,
.tracking-detail-grid,
.tracking-card-grid,
.report-parameter-grid,
.report-filter-grid {
  min-width: 0;
}

.event-item,
.tracking-event,
.tracking-truck-card,
.tracking-manifest-row,
.route-option,
.report-field,
.planner-summary-cell,
.source-pill {
  min-width: 0;
}

.event-item b,
.event-item span,
.tracking-event-body,
.tracking-route-title,
.tracking-truck-title,
.tracking-truck-sub,
.tracking-truck-model,
.tracking-truck-job,
.tracking-manifest-row b,
.tracking-manifest-row small,
.route-option b,
.route-option small {
  min-width: 0;
  overflow-wrap: anywhere;
}

.tracking-chip-row,
.tracking-tabs,
.compliance-tabs,
.upload-tabs {
  max-width: 100%;
  overflow-x: auto;
  padding-bottom: 2px;
  scrollbar-width: thin;
}

.tracking-filter-chip {
  flex: 0 0 auto;
}

.tracking-map-card,
.planner-map-card {
  overflow: hidden;
}

.tracking-map-toolbar .layer-panel,
.planner-map-card .layer-panel,
.map-full .layer-panel {
  max-width: min(560px, 100%);
}

.tracking-timeline-tools .filter-row {
  align-items: stretch;
}

.tracking-timeline-tools .field {
  min-width: min(220px, 100%);
}

.report-section summary span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.source-pill,
.report-field,
.api-status-metric,
.planner-summary-cell {
  align-content: start;
}

.planner-panel {
  overscroll-behavior: contain;
}

.full-map-tools.card {
  box-shadow: var(--shadow-md);
}

@media (max-width: 1023px) {
  .tracking-shell {
    grid-template-columns: 1fr;
  }

  .tracking-fleet-pane {
    position: static;
    max-height: none;
  }

  .tracking-fleet-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-height: 360px;
  }

  .tracking-detail-grid {
    grid-template-columns: 1fr;
  }

  .tracking-manifest {
    position: static;
    max-height: none;
  }

  .planner-layout {
    grid-template-columns: 1fr;
  }

  .planner-map {
    height: 520px;
    min-height: 440px;
  }
}

@media (max-width: 767px) {
  .tracking-fleet-list {
    grid-template-columns: 1fr;
    max-height: none;
  }

  .tracking-job-header {
    align-items: flex-start;
  }

  .tracking-route-title,
  .tracking-header-meta {
    flex: 1 1 100%;
  }

  .tracking-timeline-tools .filter-row {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tracking-timeline-tools .field,
  .tracking-timeline-search {
    width: 100%;
  }

  .tracking-photo-row {
    grid-auto-columns: minmax(158px, 82vw);
  }

  .planner-map {
    height: 420px;
    min-height: 340px;
  }

  .planner-summary-cell b,
  .planner-summary-cell small {
    white-space: normal;
  }

  .report-section summary {
    min-height: 48px;
    padding: 10px 12px;
  }

  .report-field {
    grid-template-columns: 1fr;
  }

  .full-map-tools {
    top: 150px;
  }
}

/* Compact typography overrides for dense operational pages */
.event-item,
.planner-summary-cell,
.planner-check,
.route-option,
.directory-node,
.directory-node-main,
.mapping-grid,
.api-status-metric,
.source-pill,
.report-field,
.tracking-truck-card,
.tracking-job-header,
.tracking-metric,
.tracking-photo-card,
.tracking-event,
.tracking-manifest-row {
  font-size: 12px;
}

.profile-cell span,
.planner-summary-cell span,
.stop-main small,
.field-meta,
.mapping-grid:first-child,
.api-status-metric span,
.source-pill span:first-child,
.report-field span:first-child,
.tracking-job-id span,
.tracking-step small {
  font-size: 10px;
}

.planner-summary-cell b,
.tracking-job-id b,
.tracking-metric b {
  font-size: 13px;
}

.planner-summary-cell small,
.planner-map-head p,
.route-option small,
.directory-node div span,
.tracking-truck-sub,
.tracking-truck-model,
.tracking-truck-job,
.live-pill,
.tracking-header-meta,
.tracking-metric span,
.tracking-person-card span:last-child,
.tracking-photo-card span,
.tracking-photo-card small,
.tracking-event time,
.tracking-event-top,
.tracking-event details,
.tracking-manifest-row small {
  font-size: 10.5px;
}

.tracking-event pre {
  font: 10px/1.4 var(--font-mono);
}

@media (max-width: 767px) {
  .tracking-page {
    padding: 10px;
  }

  .planner-summary-cell,
  .tracking-metric,
  .tracking-person-card {
    min-height: 82px;
  }

  .tracking-photo-card {
    min-height: 154px;
  }
}
