:root {
  --dispatch-bg: #F7F9FC;
  --dispatch-surface: #FFFFFF;
  --dispatch-ink: #0F172A;
  --dispatch-muted: #64748B;
  --dispatch-line: rgba(15, 23, 42, 0.10);
  --dispatch-dark: #0B111A;
  --dispatch-teal: #14B8A6;
  --dispatch-lime: #B8FF2C;
  --dispatch-blue-soft: #DBEAFE;
  --dispatch-blue: #2563EB;
  --dispatch-green-soft: #DCFCE7;
  --dispatch-green: #22C55E;
  --dispatch-orange-soft: #FED7AA;
  --dispatch-orange: #F59E0B;
  --dispatch-red-soft: #FEE2E2;
  --dispatch-red: #EF4444;
  --dispatch-purple-soft: #E9D5FF;
  --dispatch-purple: #7C3AED;
  --dispatch-gray-soft: #E5E7EB;
  --dispatch-radius: 24px;
  --dispatch-radius-lg: 30px;
  --dispatch-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
}

.dispatchShell {
  display: grid;
  gap: 16px;
  grid-template-rows: auto auto minmax(0, 1fr);
  color: var(--dispatch-ink);
  min-width: 0;
  width: 100%;
}

@media (min-width: 901px) {
  html:has(.dispatchShell),
  body:has(.dispatchShell) {
    overflow-y: scroll;
    scrollbar-gutter: stable;
  }
}

.screen.dispatchScreen {
  justify-self: stretch;
  max-width: none;
  min-width: 0;
  overflow-x: clip;
  width: 100%;
}

.dispatchHero,
.dispatchFocusCard,
.dispatchPanel,
.dispatchPlanPanel,
.dispatchViewHead,
.dispatchWeekFooter {
  background: var(--dispatch-surface);
  border: 1px solid var(--dispatch-line);
  border-radius: var(--dispatch-radius-lg);
  box-shadow: var(--dispatch-shadow);
}

.dispatchHero {
  align-items: center;
  background:
    radial-gradient(circle at 92% 18%, rgba(184, 255, 44, 0.14), transparent 34%),
    linear-gradient(135deg, #FFFFFF 0%, #F8FBFF 56%, #ECFEFF 100%);
  box-sizing: border-box;
  display: grid;
  gap: 32px;
  grid-template-columns: minmax(0, 1fr) 300px;
  height: 206px;
  max-height: 206px;
  min-height: 206px;
  overflow: hidden;
  padding: 34px 40px;
  width: 100%;
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.06);
}

.screen.dispatchScreen .dataStatus {
  max-width: none;
  width: min(100%, 1180px);
}

.dispatchHeroEyebrow,
.dispatchViewHead span,
.dispatchPanelHead span,
.dispatchFocusCard span,
.dispatchPlanPanel span {
  color: var(--dispatch-muted);
  display: block;
  font-size: 0.74rem;
  font-weight: 850;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dispatchViewHead h3,
.dispatchPanelHead h3,
.dispatchFocusCard h3 {
  color: var(--dispatch-ink);
  line-height: 1.02;
  margin: 6px 0 0;
}

.dispatchHeroText {
  display: grid;
  gap: 8px;
  max-width: 720px;
  min-width: 0;
}

.dispatchHero h1 {
  color: var(--dispatch-ink);
  font-size: clamp(36px, 3vw, 48px);
  font-weight: 950;
  letter-spacing: -0.065em;
  line-height: 0.96;
  margin: 0;
}

.dispatchHero p,
.dispatchViewHead p,
.dispatchFocusCard p,
.dispatchInspector p {
  color: var(--dispatch-muted);
  line-height: 1.45;
  margin: 10px 0 0;
}

.dispatchHero p {
  font-size: 15px;
  font-weight: 650;
  margin: 0;
}

.dispatchHeroActions,
.dispatchFocusActions,
.dispatchPlanActions,
.dispatchInspectorActions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.dispatchPrimaryButton,
.dispatchGhostButton,
.dispatchHeroPrimary,
.dispatchHeroSecondary,
.dispatchSubNav button,
.dispatchBlock,
.dispatchEmployeeCell,
.dispatchPreparedCard,
.dispatchTimelineItem,
.dispatchResourceMini {
  appearance: none;
  border: 0;
  cursor: pointer;
  font: inherit;
}

.dispatchPrimaryButton,
.dispatchGhostButton,
.dispatchHeroPrimary,
.dispatchHeroSecondary {
  align-items: center;
  border-radius: 999px;
  display: inline-flex;
  font-weight: 950;
  font-size: 14px;
  height: 44px;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  line-height: 1;
  white-space: nowrap;
}

.dispatchPrimaryButton {
  background: var(--dispatch-lime);
  color: #07110a;
  box-shadow: 0 12px 28px rgba(184, 255, 44, 0.22);
}

.dispatchGhostButton {
  background: #f8fafc;
  border: 1px solid var(--dispatch-line);
  color: var(--dispatch-ink);
}

.dispatchHeroActions {
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr;
  justify-items: stretch;
  justify-self: end;
  width: 300px;
}

.dispatchHeroPrimary {
  background: var(--dispatch-lime);
  border: 0;
  box-shadow: 0 14px 32px rgba(184, 255, 44, 0.28);
  color: var(--dispatch-ink);
}

.dispatchHeroSecondary {
  background: #FFFFFF;
  border: 1px solid rgba(15, 23, 42, 0.12);
  color: var(--dispatch-ink);
}

.dispatchSubNav {
  align-items: center;
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  height: 46px;
  min-height: 46px;
  overflow-x: auto;
  padding: 2px;
  scrollbar-width: none;
}

.dispatchSubNav::-webkit-scrollbar {
  display: none;
}

.dispatchSubNav button {
  background: var(--dispatch-surface);
  border: 1px solid var(--dispatch-line);
  border-radius: 999px;
  color: var(--dispatch-muted);
  flex: 0 0 auto;
  font-size: 14px;
  font-weight: 900;
  height: 42px;
  min-height: 42px;
  padding: 0 16px;
  white-space: nowrap;
}

.dispatchSubNav button.isActive {
  background: var(--dispatch-dark);
  color: #fff;
}

.dispatchContent {
  display: grid;
  gap: 18px;
  min-height: 0;
  min-width: 0;
}

@media (min-width: 901px) {
  .dispatchSubNav {
    overflow-x: clip;
    justify-content: flex-start;
  }

  .dispatchSubNav button {
    flex: 0 1 148px;
    max-width: 164px;
    min-width: 112px;
    padding: 0 12px;
  }

  .dispatchContent {
    align-content: start;
    min-height: calc(100vh - 430px);
  }
}

.dispatchPlanPanel {
  margin: 0;
}

.dispatchCockpit,
.dispatchWeek,
.dispatchToday,
.dispatchResources,
.dispatchPrepared {
  display: grid;
  gap: 18px;
}

.dispatchFocusCard {
  border-left: 6px solid var(--dispatch-orange);
  padding: 18px 20px;
}

.dispatchFocusCard h3 {
  font-size: clamp(1.45rem, 2.1vw, 2.25rem);
  max-width: 760px;
}

.dispatchMetricStrip {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.dispatchMetric {
  background: var(--dispatch-surface);
  border: 1px solid var(--dispatch-line);
  border-radius: 22px;
  padding: 18px;
}

.dispatchMetric span,
.dispatchMetric small {
  color: var(--dispatch-muted);
  display: block;
  font-size: 0.82rem;
  font-weight: 750;
}

.dispatchMetric strong {
  color: var(--dispatch-ink);
  display: block;
  font-size: 2rem;
  line-height: 1;
  margin: 8px 0;
}

.dispatchMetric.is-critical strong { color: var(--dispatch-red); }
.dispatchMetric.is-positive strong { color: #548900; }
.dispatchMetric.is-warning strong { color: var(--dispatch-orange); }

.dispatchDecisionGrid,
.dispatchPreviewGrid,
.dispatchTodayLayout {
  display: grid;
  align-items: start;
  gap: 18px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dispatchPanel {
  align-content: start;
  padding: 22px;
}

.dispatchPanelHead {
  margin-bottom: 16px;
}

.dispatchPanelHead h3 {
  font-size: 1.35rem;
}

.dispatchInsight,
.dispatchConflict,
.dispatchResourceMini,
.dispatchTimelineItem,
.dispatchPreparedCard {
  border: 1px solid var(--dispatch-line);
  border-radius: 18px;
  display: grid;
  gap: 6px;
  padding: 14px;
  text-align: left;
}

.dispatchInsight {
  align-items: center;
  grid-template-columns: 1fr auto;
  margin-bottom: 10px;
}

.dispatchInsight strong,
.dispatchConflict strong,
.dispatchPreparedCard strong,
.dispatchTimelineItem strong,
.dispatchResourceMini strong {
  color: var(--dispatch-ink);
  font-weight: 850;
}

.dispatchInsight span,
.dispatchConflict span,
.dispatchPreparedCard small,
.dispatchPreparedCard em,
.dispatchTimelineItem span,
.dispatchResourceMini span,
.dispatchResourceMini em {
  color: var(--dispatch-muted);
  font-size: 0.9rem;
}

.dispatchInsight em,
.dispatchConflict em {
  border-radius: 999px;
  color: var(--dispatch-ink);
  font-size: 0.78rem;
  font-style: normal;
  font-weight: 850;
  padding: 7px 10px;
}

.dispatchInsight.is-critical { background: var(--dispatch-red-soft); }
.dispatchInsight.is-orange { background: var(--dispatch-orange-soft); }
.dispatchInsight.is-lime { background: #efffd7; }

.dispatchViewHead {
  align-items: center;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 16px 20px;
}

.dispatchViewHead h3 {
  font-size: clamp(1.25rem, 1.65vw, 1.7rem);
}

.dispatchLegend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.dispatchLegendItem,
.dispatchTypePill {
  border: 1px solid transparent;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  font-size: 0.78rem;
  font-weight: 850;
  min-height: 30px;
  padding: 7px 10px;
}

.dispatchLegendItem {
  cursor: pointer;
}

.dispatchLegendItem.isActive {
  background: var(--dispatch-dark);
  border-color: var(--dispatch-dark);
  color: #fff;
}

.dispatchWeekBoard {
  background: var(--dispatch-surface);
  border: 1px solid var(--dispatch-line);
  border-radius: var(--dispatch-radius-lg);
  overflow: hidden;
}

.dispatchWeekHeader,
.dispatchWeekRow {
  display: grid;
  grid-template-columns: 180px repeat(5, minmax(140px, 1fr));
}

.dispatchWeekHeader {
  background: #f8fafc;
  border-bottom: 1px solid var(--dispatch-line);
  color: var(--dispatch-muted);
  font-size: 0.78rem;
  font-weight: 850;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.dispatchWeekHeader span,
.dispatchEmployeeCell,
.dispatchDayCell {
  border-right: 1px solid var(--dispatch-line);
  min-width: 0;
  padding: 12px;
}

.dispatchWeekHeader span:last-child,
.dispatchDayCell:last-child {
  border-right: 0;
}

.dispatchWeekRow {
  border-bottom: 1px solid var(--dispatch-line);
  min-height: 104px;
}

.dispatchWeekRow:last-child {
  border-bottom: 0;
}

.dispatchEmployeeCell {
  background: #fbfdff;
  color: var(--dispatch-ink);
  display: grid;
  gap: 4px;
  text-align: left;
}

.dispatchEmployeeCell strong {
  font-size: 1rem;
}

.dispatchEmployeeCell span,
.dispatchEmployeeCell em {
  color: var(--dispatch-muted);
  font-size: 0.82rem;
  font-style: normal;
  font-weight: 750;
}

.dispatchWeekRow.isSelected .dispatchEmployeeCell {
  box-shadow: inset 4px 0 0 var(--dispatch-lime);
}

.dispatchDayCell {
  display: grid;
  gap: 8px;
  min-height: 104px;
}

.dispatchBlock {
  border: 1px solid var(--dispatch-line);
  border-left: 4px solid var(--dispatch-blue);
  border-radius: 16px;
  color: var(--dispatch-ink);
  display: grid;
  gap: 4px;
  padding: 10px;
  text-align: left;
}

.dispatchBlock strong {
  font-size: 0.88rem;
  line-height: 1.15;
}

.dispatchBlock span,
.dispatchBlock em {
  color: var(--dispatch-muted);
  font-size: 0.76rem;
  font-style: normal;
  font-weight: 750;
}

.dispatchBlock.isActive {
  outline: 2px solid var(--dispatch-lime);
  outline-offset: 2px;
}

.dispatchEmptySlot {
  align-items: center;
  border: 1px dashed var(--dispatch-line);
  border-radius: 16px;
  color: var(--dispatch-muted);
  display: flex;
  font-size: 0.82rem;
  justify-content: center;
  min-height: 52px;
}

.dispatchInspector {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr auto;
}

.dispatchInspector h3 {
  color: var(--dispatch-ink);
  font-size: 1.55rem;
  line-height: 1.05;
  margin: 10px 0 0;
}

.dispatchInspector dl {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 16px 0 0;
}

.dispatchInspector dt {
  color: var(--dispatch-muted);
  font-size: 0.72rem;
  font-weight: 850;
  text-transform: uppercase;
}

.dispatchInspector dd {
  color: var(--dispatch-ink);
  font-weight: 850;
  margin: 3px 0 0;
}

.dispatchInspectorActions {
  align-content: start;
  min-width: 220px;
}

.dispatchTimeline,
.dispatchPreparedGrid,
.dispatchResourceGrid {
  display: grid;
  gap: 12px;
}

.dispatchTimelineItem {
  border-left: 5px solid var(--dispatch-teal);
}

.dispatchTimelineItem time {
  color: var(--dispatch-muted);
  font-size: 0.78rem;
  font-weight: 850;
}

.dispatchResourceGrid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.dispatchResourceCard {
  background: var(--dispatch-surface);
  border: 1px solid var(--dispatch-line);
  border-top: 4px solid var(--dispatch-teal);
  border-radius: var(--dispatch-radius);
  box-shadow: var(--dispatch-shadow);
  display: grid;
  gap: 12px;
  padding: 18px;
}

.dispatchResourceCard h3 {
  margin: 4px 0;
}

.dispatchResourceCard span,
.dispatchResourceCard p,
.dispatchResourceCard small,
.dispatchResourceCard em {
  color: var(--dispatch-muted);
}

.dispatchResourceCard strong {
  font-size: 2rem;
}

.dispatchPreparedGrid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.dispatchPreparedCard {
  background: var(--dispatch-surface);
  border-left: 5px solid var(--dispatch-blue);
}

.dispatchPlanPanel {
  align-items: end;
  display: grid;
  gap: 14px;
  grid-template-columns: 1.3fr 1fr 1fr 1fr auto;
  padding: 18px;
}

.dispatchPlanPanel label {
  color: var(--dispatch-muted);
  display: grid;
  font-size: 0.78rem;
  font-weight: 850;
  gap: 6px;
  text-transform: uppercase;
}

.dispatchPlanPanel input,
.dispatchPlanPanel select {
  background: #fff;
  border: 1px solid var(--dispatch-line);
  border-radius: 14px;
  color: var(--dispatch-ink);
  min-height: 44px;
  padding: 0 12px;
}

.dispatchPlanActions {
  justify-content: flex-end;
}

.dispatchEmptyState {
  background: var(--dispatch-surface);
  border: 1px dashed var(--dispatch-line);
  border-radius: var(--dispatch-radius);
  color: var(--dispatch-muted);
  display: grid;
  gap: 8px;
  padding: 22px;
}

.dispatchBlock.is-project,
.dispatchPreparedCard.is-project,
.dispatchTimelineItem.is-project { border-color: var(--dispatch-blue); }
.dispatchBlock.is-service,
.dispatchPreparedCard.is-service,
.dispatchTimelineItem.is-service { border-color: var(--dispatch-teal); }
.dispatchBlock.is-maintenance,
.dispatchPreparedCard.is-maintenance,
.dispatchTimelineItem.is-maintenance { border-color: var(--dispatch-green); }
.dispatchBlock.is-disruption,
.dispatchPreparedCard.is-disruption,
.dispatchTimelineItem.is-disruption,
.dispatchBlock.is-oncall,
.dispatchPreparedCard.is-oncall,
.dispatchTimelineItem.is-oncall { border-color: var(--dispatch-orange); }
.dispatchBlock.is-critical,
.dispatchPreparedCard.is-critical,
.dispatchTimelineItem.is-critical { border-color: var(--dispatch-red); }
.dispatchBlock.is-absence,
.dispatchPreparedCard.is-absence,
.dispatchTimelineItem.is-absence { border-color: #94a3b8; }

.dispatchResourceCard.is-lime,
.dispatchResourceMini.is-lime { border-color: var(--dispatch-lime); }
.dispatchResourceCard.is-orange,
.dispatchResourceMini.is-orange { border-color: var(--dispatch-orange); }
.dispatchResourceCard.is-cyan,
.dispatchResourceMini.is-cyan { border-color: var(--dispatch-blue); }
.dispatchResourceCard.is-teal,
.dispatchResourceMini.is-teal { border-color: var(--dispatch-teal); }
.dispatchResourceCard.is-gray,
.dispatchResourceMini.is-gray { border-color: #94a3b8; }

.dispatchLegendItem.is-project,
.dispatchTypePill.is-project { background: var(--dispatch-blue-soft); color: var(--dispatch-blue); }
.dispatchLegendItem.is-service,
.dispatchTypePill.is-service { background: #ccfbf1; color: #0f766e; }
.dispatchLegendItem.is-maintenance,
.dispatchTypePill.is-maintenance { background: var(--dispatch-green-soft); color: #15803d; }
.dispatchLegendItem.is-disruption,
.dispatchTypePill.is-disruption,
.dispatchLegendItem.is-oncall,
.dispatchTypePill.is-oncall { background: var(--dispatch-orange-soft); color: #9a3412; }
.dispatchLegendItem.is-critical,
.dispatchTypePill.is-critical { background: var(--dispatch-red-soft); color: #b91c1c; }
.dispatchLegendItem.is-absence,
.dispatchTypePill.is-absence { background: var(--dispatch-gray-soft); color: #475569; }
.dispatchLegendItem.is-all {
  background: #fff;
  border-color: var(--dispatch-line);
  color: var(--dispatch-muted);
}
.dispatchLegendItem.isActive,
.dispatchLegendItem.is-all.isActive {
  background: var(--dispatch-dark);
  border-color: var(--dispatch-dark);
  color: #fff;
}

@media (max-width: 1180px) {
  .dispatchViewHead,
  .dispatchInspector,
  .dispatchPlanPanel {
    grid-template-columns: 1fr;
  }

  .dispatchDecisionGrid,
  .dispatchPreviewGrid,
  .dispatchTodayLayout,
  .dispatchResourceGrid,
  .dispatchPreparedGrid {
    grid-template-columns: 1fr;
  }

  .dispatchWeekBoard {
    overflow-x: auto;
  }

  .dispatchWeekHeader,
  .dispatchWeekRow {
    min-width: 940px;
  }
}

@media (max-width: 1400px) and (min-width: 901px) {
  .dispatchHero {
    gap: 24px;
    grid-template-columns: minmax(0, 1fr) 260px;
    height: 190px;
    max-height: 190px;
    min-height: 190px;
    padding: 28px 32px;
  }

  .dispatchHero h1 {
    font-size: clamp(34px, 3.2vw, 44px);
  }

  .dispatchHeroActions {
    width: 260px;
  }
}

@media (max-width: 900px) {
  .dispatchHero {
    align-items: start;
    display: grid;
    gap: 18px;
    grid-template-columns: 1fr;
    height: auto;
    max-height: none;
    min-height: 0;
    padding: 22px;
    border-radius: 24px;
  }

  .dispatchHeroText {
    gap: 8px;
    max-width: none;
  }

  .dispatchHero h1 {
    font-size: clamp(30px, 8.4vw, 38px);
    line-height: 0.96;
  }

  .dispatchHero p {
    font-size: 15px;
  }

  .dispatchHeroActions {
    display: grid;
    flex-basis: auto;
    gap: 10px;
    grid-template-columns: 1fr;
    width: 100%;
  }

  .dispatchHeroActions button,
  .dispatchHeroPrimary,
  .dispatchHeroSecondary {
    height: 48px;
    min-height: 48px;
    width: 100%;
  }
}

@media (max-width: 720px) {
  .dispatchShell {
    gap: 14px;
  }

  .dispatchFocusCard,
  .dispatchPanel,
  .dispatchViewHead,
  .dispatchWeekFooter,
  .dispatchPlanPanel {
    border-radius: 22px;
    padding: 18px;
  }

  .dispatchFocusCard h3 {
    font-size: 1.75rem;
  }

  .dispatchFocusActions,
  .dispatchInspectorActions,
  .dispatchPlanActions {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
  }

  .dispatchPrimaryButton,
  .dispatchGhostButton {
    width: 100%;
  }

  .dispatchMetricStrip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dispatchMetric {
    padding: 14px;
  }

  .dispatchMetric strong {
    font-size: 1.55rem;
  }

  .dispatchInsight {
    grid-template-columns: 1fr;
  }

  .dispatchWeekHeader,
  .dispatchWeekRow {
    grid-template-columns: 150px repeat(5, 170px);
    min-width: 1000px;
  }

  .dispatchInspector {
    grid-template-columns: 1fr;
  }

  .dispatchInspector dl {
    grid-template-columns: 1fr;
  }
}
