/* src/styles.css */
:root {
  --bg: #f6f9ff;
  --surface: rgba(255, 255, 255, 0.85);
  --surface-strong: #ffffff;
  --line: rgba(83, 124, 191, 0.12);
  --ink: #163153;
  --muted: #6e86aa;
  --blue: #4a8dff;
  --blue-deep: #2867da;
  --blue-soft: #e7f1ff;
  --violet: #8c72ff;
  --violet-soft: #f2edff;
  --success: #2dba8c;
  --warning: #ffb55d;
  --danger: #ff7094;
  --shadow: 0 26px 80px rgba(74, 141, 255, 0.14);
  --navy-strong: #10233f;
  --navy-soft: #18345b;
  --portal-shadow: 0 22px 48px rgba(16, 35, 63, 0.14);
}
* {
  box-sizing: border-box;
}
html,
body,
#root {
  min-height: 100%;
}
body {
  margin: 0;
  color: var(--ink);
  font-family: "Manrope", sans-serif;
  background:
    radial-gradient(
      circle at top left,
      rgba(74, 141, 255, 0.08),
      transparent 24%),
    linear-gradient(
      180deg,
      #f7faff 0%,
      #eef3fb 100%);
}
a {
  color: inherit;
  text-decoration: none;
}
button,
input,
select,
textarea {
  font: inherit;
}
.app-backdrop {
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(74, 141, 255, 0.035) 1px, transparent 1px),
    linear-gradient(
      90deg,
      rgba(74, 141, 255, 0.035) 1px,
      transparent 1px);
  background-size: 38px 38px;
  mask-image:
    linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.86),
      transparent 92%);
}
.site-shell,
.portal-shell {
  position: relative;
  z-index: 1;
}
.portal-shell {
  max-width: 1560px;
  margin: 0 auto;
}
.site-shell {
  max-width: 1440px;
  margin: 0 auto;
  padding: 24px 28px 34px;
}
.site-header,
.site-footer,
.hero-panel,
.metric-card,
.info-card,
.contact-card,
.contact-form,
.auth-card,
.section-banner,
.portal-topbar,
.table-card {
  background: var(--surface);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
}
.site-header,
.site-footer,
.portal-topbar {
  border-radius: 22px;
}
.site-header,
.site-footer,
.section-banner,
.portal-topbar {
  padding: 16px 20px;
}
.site-header,
.site-footer,
.section-banner,
.portal-topbar-row,
.cta-row,
.site-nav,
.footer-grid,
.portal-topbar-actions,
.topbar-nav {
  display: flex;
  align-items: center;
}
.site-header,
.site-footer,
.section-banner,
.portal-topbar-row {
  justify-content: space-between;
  gap: 20px;
}
.brand-lockup,
.brand-stack {
  display: flex;
  align-items: center;
  gap: 16px;
}
.brand-lockup img,
.brand-stack img {
  width: 82px;
  height: auto;
  object-fit: contain;
}
.site-nav,
.footer-grid,
.cta-row,
.topbar-nav,
.portal-topbar-actions {
  gap: 12px;
  flex-wrap: wrap;
}
.nav-link,
.topbar-link,
.secondary-button,
.primary-button {
  border-radius: 14px;
  transition: 180ms ease;
}
.nav-link,
.topbar-link {
  padding: 10px 14px;
  color: #6b7f9e;
  font-weight: 700;
}
.nav-link.active,
.nav-link:hover,
.topbar-link.active,
.topbar-link:hover {
  color: var(--blue-deep);
  background: rgba(239, 245, 255, 0.92);
}
.content-section {
  display: grid;
  gap: 22px;
  padding: 22px 0;
}
.home-hero,
.grid-two,
.grid-three,
.grid-four,
.stack-grid,
.form-grid,
.portal-shell {
  display: grid;
  gap: 20px;
}
.home-hero {
  grid-template-columns: 1.3fr 0.9fr;
  align-items: stretch;
}
.public-hero-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, 0.85fr);
  gap: 18px;
  align-items: stretch;
}
.public-hero-copy,
.public-hero-panel {
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(16, 35, 63, 0.06);
  box-shadow: 0 12px 30px rgba(16, 35, 63, 0.06);
  border-radius: 24px;
}
.public-hero-copy {
  padding: 34px 36px;
}
.public-hero-copy h1 {
  margin: 0;
  font-family: "Outfit", sans-serif;
  font-size: clamp(2.6rem, 5vw, 4.4rem);
  line-height: 0.98;
  letter-spacing: -0.04em;
}
.public-hero-panel {
  display: grid;
  gap: 18px;
  padding: 26px;
}
.public-hero-panel-head {
  display: grid;
  gap: 4px;
}
.public-hero-panel-head strong {
  font-family: "Outfit", sans-serif;
  font-size: 1.35rem;
  color: #10233f;
}
.public-hero-kpis {
  display: grid;
  gap: 12px;
}
.public-hero-kpis .metric-card {
  padding: 18px 20px;
  border-radius: 18px;
  background: #fbfdff;
  border: 1px solid rgba(16, 35, 63, 0.06);
  box-shadow: none;
}
.public-hero-kpis .metric-card strong {
  font-size: 1.85rem;
}
.public-hero-strip {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  padding-top: 6px;
}
.public-hero-strip div {
  padding: 14px 16px;
  border-radius: 16px;
  background: #f7faff;
  border: 1px solid rgba(16, 35, 63, 0.06);
}
.public-hero-strip strong {
  display: block;
  margin-top: 6px;
  font-family: "Outfit", sans-serif;
  font-size: 1.08rem;
}
.hero-panel,
.contact-form,
.auth-card,
.portal-topbar,
.app-section,
.metric-card,
.info-card,
.contact-card {
  border-radius: 30px;
}
.hero-panel,
.contact-form,
.auth-card,
.app-section {
  padding: 28px;
}
.hero-copy h1,
.hero-panel h1,
.section-banner h2,
.info-card h2,
.brand-stack h1 {
  margin: 0;
  font-family: "Outfit", sans-serif;
}
.hero-copy h1,
.hero-panel h1 {
  font-size: clamp(2.4rem, 5vw, 4.6rem);
  line-height: 0.96;
}
.section-copy,
.hero-copy p,
.info-card p,
.contact-card p,
.auth-hint,
.metric-card p,
.sidebar-card p {
  color: var(--muted);
}
.eyebrow {
  display: block;
  margin-bottom: 8px;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
}
.accent-blue {
  color: var(--blue-deep);
}
.accent-violet {
  color: var(--violet);
}
.stack-grid {
  grid-template-columns: 1fr;
}
.pickup-queue-list {
  display: grid;
  gap: 16px;
  margin-top: 18px;
}
.pickup-queue-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 20px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid var(--line);
}
.pickup-queue-card h3 {
  margin: 6px 0 8px;
  font-family: "Outfit", sans-serif;
  font-size: 1.25rem;
}
.pickup-queue-card p {
  margin: 4px 0;
}
.metric-card,
.info-card,
.contact-card {
  padding: 22px;
}
.site-header,
.site-footer {
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(16, 35, 63, 0.06);
  box-shadow: 0 12px 30px rgba(16, 35, 63, 0.06);
}
.metric-card strong,
.info-card strong,
.contact-card strong {
  display: block;
  font-family: "Outfit", sans-serif;
}
.metric-card strong {
  font-size: 2rem;
  margin-bottom: 8px;
}
.tone-blue {
  background:
    linear-gradient(
      180deg,
      rgba(240, 246, 255, 0.95),
      rgba(255, 255, 255, 0.96));
}
.tone-violet,
.violet-card {
  background:
    linear-gradient(
      180deg,
      rgba(246, 242, 255, 0.96),
      rgba(255, 255, 255, 0.94));
}
.tone-success {
  background:
    linear-gradient(
      180deg,
      rgba(239, 251, 246, 0.96),
      rgba(255, 255, 255, 0.94));
}
.tone-warning {
  background:
    linear-gradient(
      180deg,
      rgba(255, 247, 236, 0.96),
      rgba(255, 255, 255, 0.94));
}
.grid-two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.grid-three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.grid-four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.large-card h2 {
  margin: 0 0 12px;
}
.contact-form,
.auth-card,
.form-grid {
  display: grid;
  gap: 14px;
}
.login-shell {
  justify-items: center;
}
.login-frame {
  width: min(960px, 100%);
  display: grid;
  gap: 18px;
}
.login-intro {
  display: grid;
  gap: 8px;
  padding: 4px 2px 0;
}
.login-intro h1 {
  margin: 0;
  font-family: "Outfit", sans-serif;
  font-size: clamp(2rem, 3.8vw, 2.9rem);
  line-height: 1.02;
}
.login-intro p,
.login-demo-head p {
  margin: 0;
  color: var(--muted);
}
.login-card,
.login-demo-card {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  border-radius: 28px;
}
.login-card {
  padding: 24px;
}
.login-form-grid {
  display: grid;
  gap: 14px;
}
.login-field {
  display: grid;
  gap: 8px;
  color: var(--ink);
  font-weight: 700;
}
.login-field span {
  font-size: 0.92rem;
}
.login-demo-card {
  display: grid;
  gap: 16px;
  padding: 22px;
}
.login-demo-head {
  display: grid;
  gap: 6px;
}
.login-demo-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.login-seed-user {
  align-items: flex-start;
  flex-direction: column;
  text-align: left;
}
.filter-bar {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: 14px;
}
.billing-generate-form {
  grid-template-columns: 1.4fr repeat(3, minmax(120px, 0.75fr)) auto;
  align-items: center;
  margin-top: 16px;
}
.compact-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.contact-form input,
.contact-form textarea,
.auth-card input,
.form-grid input,
.form-grid select,
.form-grid textarea,
.filter-bar input,
.filter-bar select {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid rgba(83, 124, 191, 0.16);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.94);
}
.primary-button,
.secondary-button {
  border: none;
  cursor: pointer;
  padding: 13px 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.primary-button {
  color: white;
  background:
    linear-gradient(
      135deg,
      var(--blue),
      var(--blue-deep));
}
.secondary-button {
  color: var(--blue-deep);
  background: rgba(231, 241, 255, 0.86);
}
.full-width {
  width: 100%;
}
.primary-button:hover,
.secondary-button:hover {
  transform: translateY(-1px);
}
.primary-button:disabled,
.secondary-button:disabled {
  cursor: not-allowed;
  opacity: 0.6;
  transform: none;
}
.success-note {
  margin: 0;
  padding: 14px 18px;
  border-radius: 18px;
  color: #0d7a42;
  background: rgba(67, 176, 112, 0.12);
  border: 1px solid rgba(67, 176, 112, 0.2);
  font-weight: 700;
}
.warehouse-scan-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.9fr);
  gap: 18px;
  align-items: end;
}
.warehouse-scan-card strong {
  display: block;
  margin: 4px 0 8px;
  font-size: clamp(1.25rem, 2vw, 1.75rem);
}
.warehouse-scan-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}
.warehouse-scan-form input {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 16px 18px;
  font: inherit;
  font-weight: 700;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.92);
}
.info-list {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}
.state-block {
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.82);
  color: var(--muted);
}
.state-block.error,
.auth-error {
  color: var(--danger);
}
.seed-user {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.82);
  cursor: pointer;
}
.checkbox-row {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--ink);
}
.inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}
.tab-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 6px;
  border-radius: 20px;
  background: rgba(231, 241, 255, 0.76);
  width: fit-content;
}
.tab-button {
  border: none;
  cursor: pointer;
  border-radius: 16px;
  padding: 11px 16px;
  font-weight: 700;
  color: var(--muted);
  background: transparent;
  transition: 180ms ease;
}
.tab-button:hover {
  color: var(--blue-deep);
  background: rgba(255, 255, 255, 0.82);
}
.tab-button.active {
  color: #ffffff;
  background:
    linear-gradient(
      135deg,
      var(--blue),
      var(--blue-deep));
  box-shadow: 0 10px 24px rgba(47, 111, 228, 0.2);
}
.users-layout {
  align-items: start;
}
.users-filter-bar {
  grid-template-columns: minmax(0, 1fr);
  margin-top: 14px;
}
.users-directory {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}
.user-card {
  display: grid;
  gap: 12px;
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.82);
}
.user-card p {
  margin: 6px 0 0;
}
.user-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  color: var(--muted);
  font-size: 0.95rem;
}
.user-card-meta span {
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(231, 241, 255, 0.86);
}
.package-picker {
  display: grid;
  gap: 12px;
  margin-top: 8px;
}
.picker-card {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.82);
}
.picker-card input {
  margin-top: 4px;
}
.picker-card p {
  margin: 6px 0 0;
}
.checkbox-row input {
  width: auto;
}
.portal-shell {
  grid-template-columns: 1fr;
  min-height: 100vh;
  max-width: 1600px;
  padding: 18px 24px 32px;
}
.portal-topbar {
  display: grid;
  gap: 14px;
  position: sticky;
  top: 12px;
  z-index: 20;
  padding: 18px 22px;
  background: rgba(255, 255, 255, 0.98);
  border-color: rgba(16, 35, 63, 0.07);
  box-shadow: 0 14px 40px rgba(16, 35, 63, 0.08);
  color: var(--ink);
  backdrop-filter: blur(18px);
  border-radius: 24px;
}
.portal-main {
  display: grid;
  gap: 24px;
  padding-top: 18px;
}
.portal-topbar h1 {
  margin: 0;
  font-family: "Outfit", sans-serif;
  font-size: 1.18rem;
  letter-spacing: -0.02em;
  color: #10233f;
}
.portal-topbar-main {
  align-items: center;
}
.portal-topbar-nav-row {
  padding-top: 2px;
  border-top: 1px solid rgba(16, 35, 63, 0.05);
}
.portal-topbar-actions {
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
}
.topbar-nav {
  gap: 8px;
  flex: 1;
  justify-content: flex-start;
  padding: 0;
}
.topbar-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  font-weight: 700;
  color: #607086;
  border: 1px solid transparent;
  border-radius: 12px;
  font-size: 0.96rem;
}
.portal-topbar .eyebrow {
  margin-bottom: 2px;
  color: #7a8ba4;
}
.portal-brand {
  min-width: 280px;
}
.portal-brand-mark {
  display: grid;
  place-items: center;
  width: 56px;
  height: 44px;
  border-radius: 12px;
  background:
    linear-gradient(
      180deg,
      #f5f8fd 0%,
      #eef4fb 100%);
  border: 1px solid rgba(54, 108, 214, 0.07);
}
.portal-brand-mark img {
  width: 44px;
  height: auto;
}
.portal-brand-copy {
  display: grid;
  gap: 2px;
}
.portal-topbar .secondary-button {
  background: #ffffff;
  color: #1d4ca4;
  border: 1px solid rgba(29, 76, 164, 0.12);
  box-shadow: none;
  border-radius: 12px;
  padding: 11px 16px;
}
.topbar-link.active,
.topbar-link:hover {
  color: #18449d;
  background: #eef4ff;
  border-color: rgba(66, 118, 224, 0.12);
}
.role-pill,
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 0.8rem;
}
.role-pill {
  width: fit-content;
  color: #19449d;
  background: #edf4ff;
  border: 1px solid rgba(66, 118, 224, 0.12);
  font-weight: 700;
}
.portal-date-chip {
  display: inline-flex;
  align-items: center;
  padding: 9px 13px;
  border-radius: 12px;
  background: #f8fbff;
  border: 1px solid rgba(16, 35, 63, 0.08);
  color: #445a7c;
  font-size: 0.9rem;
  white-space: nowrap;
}
.app-section {
  display: grid;
  gap: 22px;
}
.portal-shell .app-section {
  padding: 0;
  gap: 18px;
}
.portal-shell .section-banner {
  background: #ffffff;
  border: 1px solid rgba(16, 35, 63, 0.06);
  box-shadow: 0 10px 22px rgba(16, 35, 63, 0.05);
  border-radius: 22px;
}
.portal-shell .section-banner h2 {
  font-size: clamp(1.55rem, 2.15vw, 2.15rem);
  line-height: 1.05;
}
.portal-shell .info-card,
.portal-shell .metric-card,
.portal-shell .table-card,
.portal-shell .contact-card,
.portal-shell .state-block {
  background: #ffffff;
  border: 1px solid rgba(16, 35, 63, 0.06);
  box-shadow: 0 8px 20px rgba(16, 35, 63, 0.045);
  backdrop-filter: none;
  border-radius: 20px;
}
.portal-shell .metric-card strong {
  font-size: 1.72rem;
}
.portal-shell .info-card,
.portal-shell .metric-card,
.portal-shell .contact-card {
  padding: 24px;
}
.portal-shell .table-row {
  background: #ffffff;
  border: 1px solid rgba(16, 35, 63, 0.05);
  border-radius: 16px;
}
.portal-shell .table-head {
  background: #f6f8fc;
}
.portal-shell .table-link-row:hover {
  background: #f8fbff;
}
.portal-shell .primary-button {
  background:
    linear-gradient(
      135deg,
      #225fd2,
      #194fb4);
  box-shadow: 0 10px 22px rgba(34, 95, 210, 0.18);
  border-radius: 14px;
}
.portal-shell .secondary-button {
  background: #eef4ff;
  color: #1d4ca4;
}
.table-card {
  display: grid;
  gap: 10px;
  padding: 16px;
}
.table-row {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  align-items: center;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
}
.table-link-row {
  cursor: pointer;
  transition: 180ms ease;
}
.table-link-row:hover {
  background: rgba(231, 241, 255, 0.92);
  transform: translateY(-1px);
}
.table-head {
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.78rem;
  background: rgba(231, 241, 255, 0.7);
}
.badge-default {
  background: rgba(231, 241, 255, 0.9);
}
.badge-blue {
  background: rgba(74, 141, 255, 0.14);
  color: var(--blue-deep);
}
.badge-violet {
  background: rgba(140, 114, 255, 0.14);
  color: var(--violet);
}
.badge-success {
  background: rgba(45, 186, 140, 0.14);
  color: var(--success);
}
.badge-warning {
  background: rgba(255, 181, 93, 0.2);
  color: #b7751b;
}
.badge-danger {
  background: rgba(255, 112, 148, 0.16);
  color: var(--danger);
}
.order-detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(320px, 0.95fr);
  gap: 20px;
  align-items: start;
}
.order-detail-main,
.order-detail-side,
.stack-list,
.timeline-list {
  display: grid;
  gap: 18px;
}
.detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 18px;
}
.detail-grid p,
.timeline-item p,
.list-row-card p {
  margin: 6px 0 0;
  color: var(--muted);
}
.detail-span-full {
  grid-column: 1 / -1;
}
.list-row-card {
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(16, 35, 63, 0.06);
  background: #fbfdff;
}
.timeline-item {
  padding: 16px 18px;
  border-left: 3px solid rgba(47, 111, 228, 0.28);
  border-radius: 0 18px 18px 0;
  background: #f8fbff;
}
.dispatcher-order-detail {
  gap: 10px;
  max-width: 1800px;
}
.order-command-topbar,
.order-action-strip,
.detail-panel {
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(16, 35, 63, 0.08);
  box-shadow: 0 14px 34px rgba(16, 35, 63, 0.06);
}
.order-command-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 12px 16px;
  border-radius: 18px;
}
.order-command-title,
.order-command-status,
.order-action-strip,
.panel-title-row,
.panel-heading,
.mini-status-row,
.proof-tabs {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.order-command-title strong {
  font-family: "Outfit", sans-serif;
  font-size: 1.7rem;
  color: #10233f;
}
.text-link {
  color: #10233f;
  font-weight: 800;
}
.icon-action,
.source-chip,
.meta-chip,
.star-indicator,
.status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  border-radius: 999px;
  padding: 0 12px;
  border: 1px solid rgba(16, 35, 63, 0.08);
  font-weight: 800;
  font-size: 0.82rem;
  color: #10233f;
  background: #ffffff;
}
.icon-action {
  cursor: pointer;
}
.source-chip {
  background: rgba(45, 186, 140, 0.13);
  color: #168c63;
}
.meta-chip {
  color: #5d6d89;
}
.star-indicator {
  background: rgba(255, 181, 93, 0.16);
  color: #a16912;
}
.order-command-status select,
.order-edit-panel select {
  min-height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(16, 35, 63, 0.1);
  padding: 0 12px;
  background: #ffffff;
  color: #10233f;
  font-weight: 700;
}
.order-action-strip {
  padding: 12px;
  border-radius: 16px;
}
.danger-button,
.success-button,
.compact-button {
  border: 0;
  cursor: pointer;
  font-weight: 800;
  border-radius: 10px;
  min-height: 38px;
  padding: 0 14px;
}
.danger-button {
  background: #ff304f;
  color: #ffffff;
}
.success-button {
  background: #12b76a;
  color: #ffffff;
}
.compact-button {
  min-height: 32px;
  font-size: 0.82rem;
}
.order-edit-panel h3 {
  margin: 6px 0 16px;
  font-family: "Outfit", sans-serif;
  color: #10233f;
}
.dispatcher-detail-grid {
  display: grid;
  grid-template-columns: minmax(240px, 0.85fr) minmax(360px, 1.2fr) minmax(540px, 1.95fr);
  gap: 12px;
  align-items: start;
}
.dispatcher-detail-column {
  display: grid;
  gap: 12px;
}
.wide-column {
  min-width: 0;
}
.detail-panel {
  border-radius: 12px;
  padding: 14px;
}
.detail-panel h3 {
  margin: 10px 0 8px;
  font-family: "Outfit", sans-serif;
  color: #10233f;
  letter-spacing: -0.02em;
}
.detail-panel p,
.detail-panel small,
.empty-note,
.instruction-list span,
.compact-facts span,
.proof-meta-grid span,
.order-info-matrix span,
.attempt-list span {
  color: #61708b;
}
.panel-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: #eaf2ff;
  color: #194fb4;
  font-size: 0.7rem;
  font-weight: 900;
}
.panel-heading {
  justify-content: space-between;
}
.thin-divider {
  height: 1px;
  margin: 12px 0;
  background: rgba(16, 35, 63, 0.08);
}
.compact-facts,
.proof-meta-grid,
.order-info-matrix {
  display: grid;
  gap: 10px;
}
.compact-facts {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.compact-facts div,
.proof-meta-grid div,
.order-info-matrix div {
  display: grid;
  gap: 4px;
}
.compact-facts strong,
.proof-meta-grid strong,
.order-info-matrix strong {
  color: #10233f;
  font-size: 0.92rem;
}
.label-chip-list,
.comm-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0;
}
.label-chip-list span,
.comm-tabs span,
.proof-tabs span {
  border: 1px solid rgba(47, 111, 228, 0.16);
  background: #f7fbff;
  color: #194fb4;
  border-radius: 8px;
  padding: 7px 10px;
  font-size: 0.78rem;
  font-weight: 800;
}
.full-width-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.empty-note {
  margin-top: 14px;
  padding: 14px;
  border-radius: 10px;
  background: #f8fbff;
  border: 1px solid rgba(16, 35, 63, 0.06);
}
.patient-info-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  gap: 14px;
}
.order-map-preview,
.tracking-map-preview {
  position: relative;
  min-height: 164px;
  overflow: hidden;
  border-radius: 12px;
  border: 1px solid rgba(16, 35, 63, 0.08);
  background:
    linear-gradient(
      90deg,
      rgba(47, 111, 228, 0.12) 2px,
      transparent 2px),
    linear-gradient(rgba(47, 111, 228, 0.12) 2px, transparent 2px),
    linear-gradient(
      135deg,
      #f7fbff,
      #eaf2ff);
  background-size:
    36px 36px,
    36px 36px,
    auto;
}
.order-map-preview span,
.tracking-map-preview span {
  position: absolute;
  left: 14px;
  top: 14px;
  color: #61708b;
  font-weight: 800;
}
.order-map-preview strong {
  position: absolute;
  right: 14px;
  top: 14px;
  color: #10233f;
}
.order-map-preview i,
.tracking-map-preview i {
  position: absolute;
  left: 55%;
  top: 45%;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: #ff304f;
  box-shadow: 0 0 0 8px rgba(255, 48, 79, 0.12);
}
.embedded-map iframe,
.route-map-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.embedded-map.empty-map {
  display: grid;
  align-content: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
}
.embedded-map.empty-map span,
.embedded-map.empty-map strong {
  position: static;
}
.route-map-embed {
  position: relative;
  min-height: 360px;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(16, 35, 63, 0.08);
  background: #edf5ff;
}
.order-info-matrix {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.mini-table,
.qa-table,
.history-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}
.mini-table th,
.mini-table td,
.qa-table td,
.history-table th,
.history-table td {
  padding: 9px 8px;
  border-bottom: 1px solid rgba(16, 35, 63, 0.08);
  text-align: left;
  color: #10233f;
}
.mini-table th,
.history-table th {
  color: #61708b;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.72rem;
}
.instruction-list {
  display: grid;
}
.instruction-list div {
  display: grid;
  grid-template-columns: minmax(140px, 0.55fr) minmax(0, 1fr);
  gap: 14px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(16, 35, 63, 0.08);
}
.proof-panel {
  min-width: 0;
}
.proof-tabs {
  margin-bottom: 12px;
}
.proof-tabs .active {
  background: #eaf2ff;
  color: #194fb4;
  border-color: rgba(47, 111, 228, 0.32);
}
.proof-gallery {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr)) minmax(120px, 0.8fr);
  gap: 10px;
}
.proof-tile,
.proof-empty,
.signature-box {
  min-height: 116px;
  border: 1px solid rgba(16, 35, 63, 0.08);
  border-radius: 10px;
  overflow: hidden;
  background: #f8fbff;
  color: #61708b;
  display: grid;
  align-items: center;
  justify-items: center;
  text-align: center;
  font-weight: 800;
}
.proof-tile img {
  width: 100%;
  height: 92px;
  object-fit: cover;
}
.proof-tile span {
  padding: 6px;
  color: #10233f;
  font-size: 0.76rem;
}
.proof-meta-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  margin-top: 14px;
  padding: 12px;
  border-radius: 10px;
  background: #fbfdff;
}
.qa-pass {
  color: #12b76a !important;
  font-weight: 900;
}
.qa-pending {
  color: #b7751b !important;
  font-weight: 900;
}
.qa-review {
  color: #8c72ff !important;
  font-weight: 900;
}
.qa-n\/a {
  color: #61708b !important;
  font-weight: 900;
}
.history-table {
  font-size: 0.75rem;
}
.right-bottom-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(220px, 0.8fr);
  gap: 12px;
}
.tracking-map-preview {
  min-height: 190px;
  margin: 12px 0;
}
.attempt-list {
  display: grid;
  gap: 10px;
}
.attempt-list div {
  display: grid;
  gap: 4px;
  padding: 10px;
  border-radius: 10px;
  background: #f8fbff;
  border: 1px solid rgba(16, 35, 63, 0.06);
}
.attempt-list em {
  color: #168c63;
  font-style: normal;
  font-weight: 800;
}
.return-panel {
  margin-top: 2px;
}
.dashboard-headline,
.dispatcher-hero-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.dashboard-headline h2,
.dispatcher-hero-card h2,
.dashboard-panel h3 {
  margin: 0;
  font-family: "Outfit", sans-serif;
  color: #10233f;
}
.dashboard-headline h2 {
  font-size: 2rem;
  letter-spacing: -0.03em;
}
.dashboard-headline p {
  margin: 6px 0 0;
  color: var(--muted);
  max-width: 720px;
}
.dashboard-headline-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}
.dashboard-icon-button {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  border: none;
  background: #194fb4;
  color: #ffffff;
  font-weight: 800;
  cursor: pointer;
}
.dashboard-stat-row,
.dispatcher-metric-row {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
}
.dispatcher-metric-row {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.dashboard-stat-card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 20px;
  border-radius: 18px;
  background: #ffffff;
  border: 1px solid rgba(16, 35, 63, 0.06);
  box-shadow: 0 10px 24px rgba(16, 35, 63, 0.05);
}
.dashboard-stat-card p,
.dashboard-stat-card span {
  color: var(--muted);
}
.dashboard-stat-card p {
  margin: 0 0 6px;
  font-size: 0.95rem;
}
.dashboard-stat-card strong {
  display: block;
  font-family: "Outfit", sans-serif;
  font-size: 1.95rem;
  line-height: 1;
  margin-bottom: 6px;
}
.dashboard-stat-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 14px;
  font-weight: 800;
  color: #245cc7;
  flex-shrink: 0;
  font-size: 1.2rem;
}
.dashboard-main-grid {
  display: grid;
  grid-template-columns: 1.45fr 0.8fr 0.85fr;
  gap: 14px;
  align-items: start;
}
.dashboard-lower-grid {
  display: grid;
  grid-template-columns: 1.35fr 0.95fr;
  gap: 14px;
  align-items: start;
}
.dashboard-panel,
.dispatcher-hero-card {
  background: #ffffff;
  border: 1px solid rgba(16, 35, 63, 0.06);
  border-radius: 18px;
  box-shadow: 0 8px 22px rgba(16, 35, 63, 0.045);
}
.dispatcher-hero-card {
  padding: 28px 30px;
}
.dispatcher-hero-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 92px;
  height: 92px;
  border-radius: 26px;
  background:
    linear-gradient(
      180deg,
      #edf4ff 0%,
      #f6f9ff 100%);
  color: #2f6fe4;
  font-size: 2rem;
  flex-shrink: 0;
}
.dashboard-panel {
  padding: 18px 20px;
}
.dashboard-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}
.dashboard-panel-head a {
  color: #2f6fe4;
  font-weight: 700;
  font-size: 0.92rem;
}
.dashboard-map-panel {
  min-height: 296px;
}
.dashboard-map-surface {
  position: relative;
  overflow: hidden;
  min-height: 240px;
  border-radius: 16px;
  background:
    radial-gradient(
      circle at 30% 35%,
      rgba(47, 111, 228, 0.08),
      transparent 26%),
    linear-gradient(
      180deg,
      #f9fbff 0%,
      #f1f6ff 100%);
  border: 1px solid rgba(16, 35, 63, 0.06);
}
.dashboard-map-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(104, 139, 201, 0.16) 1px, transparent 1px),
    linear-gradient(
      90deg,
      rgba(104, 139, 201, 0.16) 1px,
      transparent 1px);
  background-size: 34px 34px;
  opacity: 0.55;
}
.dashboard-route-line {
  position: absolute;
  border-radius: 999px;
  opacity: 0.9;
}
.route-a {
  left: 14%;
  top: 26%;
  width: 46%;
  height: 5px;
  background: #2f6fe4;
  transform: rotate(-14deg);
}
.route-b {
  left: 24%;
  top: 57%;
  width: 38%;
  height: 5px;
  background: #27b37d;
  transform: rotate(9deg);
}
.route-c {
  left: 55%;
  top: 32%;
  width: 24%;
  height: 5px;
  background: #8c72ff;
  transform: rotate(71deg);
}
.dashboard-map-node {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  color: #ffffff;
  font-weight: 800;
  box-shadow: 0 10px 18px rgba(16, 35, 63, 0.12);
}
.node-a {
  left: 18%;
  top: 22%;
  background: #2f6fe4;
}
.node-b {
  left: 30%;
  top: 62%;
  background: #27b37d;
}
.node-c {
  left: 58%;
  top: 48%;
  background: #8c72ff;
}
.node-d {
  left: 72%;
  top: 72%;
  background: #ff9f43;
}
.dashboard-map-city {
  position: absolute;
  left: 48%;
  top: 45%;
  transform: translate(-50%, -50%);
  font-family: "Outfit", sans-serif;
  font-size: 1.55rem;
  color: rgba(16, 35, 63, 0.72);
}
.dashboard-activity-list,
.dashboard-driver-list,
.dashboard-snapshot-grid {
  display: grid;
  gap: 12px;
}
.dashboard-activity-item,
.dashboard-driver-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
}
.dashboard-activity-item strong,
.dashboard-driver-row strong {
  display: block;
  font-size: 0.96rem;
}
.dashboard-activity-item p,
.dashboard-mini-card p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.92rem;
}
.dashboard-activity-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  margin-top: 7px;
  background:
    linear-gradient(
      135deg,
      #2f6fe4,
      #27b37d);
  flex-shrink: 0;
}
.dashboard-mini-form {
  display: grid;
  gap: 12px;
  margin-top: 16px;
}
.dashboard-mini-form label {
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-size: 0.92rem;
}
.dashboard-mini-form select {
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(16, 35, 63, 0.08);
  background: #ffffff;
}
.dashboard-driver-state {
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
}
.state-on-route {
  background: rgba(45, 186, 140, 0.12);
  color: #168c63;
}
.state-available {
  background: rgba(47, 111, 228, 0.12);
  color: #2f6fe4;
}
.state-offline {
  background: rgba(16, 35, 63, 0.08);
  color: #73819a;
}
.dashboard-table-panel .table-card,
.dispatcher-table-card .table-card {
  padding: 0;
  border: none;
  box-shadow: none;
  background: transparent;
}
.dashboard-table-panel .table-row {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}
.dashboard-mini-card {
  padding: 18px;
  border-radius: 16px;
  background: #f9fbff;
  border: 1px solid rgba(16, 35, 63, 0.05);
}
.dashboard-mini-card span {
  display: block;
  color: #5e7aad;
  font-size: 0.86rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.dashboard-mini-card strong {
  display: block;
  margin-top: 10px;
  font-family: "Outfit", sans-serif;
  font-size: 1.4rem;
}
.dispatcher-tabs-shell {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 6px;
  border-radius: 16px;
  background: #f5f7fb;
  border: 1px solid rgba(16, 35, 63, 0.06);
  width: fit-content;
}
.dispatcher-filter-row {
  display: grid;
  grid-template-columns: 1.35fr 0.85fr 0.85fr;
  gap: 14px;
}
.dispatcher-filter-row input,
.dispatcher-filter-row select,
.dispatcher-inline-control select {
  width: 100%;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(16, 35, 63, 0.08);
  background: #ffffff;
}
.dispatcher-inline-control {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 16px;
}
.dispatcher-inline-control select {
  max-width: 360px;
}
.dispatcher-table-card h2,
.dispatcher-demo-card h2 {
  margin: 0 0 12px;
}
.dispatcher-demo-card {
  background:
    linear-gradient(
      180deg,
      #f4f6ff 0%,
      #ffffff 100%);
}
.portal-shell .tab-button {
  border-radius: 12px;
  padding: 10px 14px;
  font-weight: 700;
}
.portal-shell .tab-button.active {
  box-shadow: 0 8px 18px rgba(34, 95, 210, 0.18);
}
.clickable-card {
  cursor: pointer;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    border-color 0.18s ease;
}
.clickable-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(20, 44, 82, 0.08);
  border-color: rgba(34, 95, 210, 0.18);
}
.status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.status-badge.pending-review {
  background: rgba(255, 191, 71, 0.16);
  color: #9a6600;
}
.status-badge.active {
  background: rgba(43, 170, 82, 0.14);
  color: #1a7c3d;
}
.status-badge.blocked,
.status-badge.rejected,
.status-badge.archived {
  background: rgba(214, 72, 96, 0.14);
  color: #a52b45;
}
.route-monitor-page {
  gap: 20px;
}
.route-command-hero,
.route-live-map-panel,
.route-stats-panel,
.route-timeline-panel,
.route-stops-panel {
  background: #ffffff;
  border: 1px solid rgba(16, 35, 63, 0.06);
  border-radius: 24px;
  box-shadow: 0 18px 42px rgba(16, 35, 63, 0.08);
}
.route-command-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(320px, 0.8fr);
  gap: 24px;
  padding: 26px;
  background:
    radial-gradient(
      circle at 12% 20%,
      rgba(74, 141, 255, 0.16),
      transparent 28%),
    linear-gradient(
      135deg,
      #ffffff 0%,
      #eef6ff 100%);
}
.route-command-main h2 {
  margin: 12px 0 6px;
  font-family: "Outfit", sans-serif;
  font-size: clamp(2rem, 3vw, 3.2rem);
  line-height: 0.96;
}
.route-number-line,
.route-driver-line,
.route-panel-head,
.route-map-head,
.driver-active-route-card,
.driver-active-route-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}
.route-number-line,
.route-map-head,
.driver-active-route-card {
  justify-content: space-between;
}
.route-status-chip,
.route-location-chip,
.route-stop-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 7px 12px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.route-status-chip,
.route-location-chip {
  background: rgba(74, 141, 255, 0.12);
  color: #2462cc;
}
.route-status-chip.completed,
.route-status-chip.delivered,
.route-stop-status.delivered {
  background: rgba(45, 186, 140, 0.16);
  color: #168c63;
}
.route-status-chip.needs-review,
.route-stop-status.failed-return-required,
.route-stop-status.undelivered {
  background: rgba(255, 112, 148, 0.16);
  color: #bb3157;
}
.route-driver-line {
  margin-top: 18px;
}
.route-driver-line img,
.route-driver-avatar {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  object-fit: cover;
}
.route-driver-avatar {
  display: grid;
  place-items: center;
  color: #ffffff;
  font-weight: 900;
  background:
    linear-gradient(
      135deg,
      var(--blue),
      var(--blue-deep));
}
.route-driver-line strong,
.route-driver-line span,
.route-command-side span,
.route-command-side strong {
  display: block;
}
.route-driver-line span,
.route-command-side span {
  color: var(--muted);
}
.route-command-side {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.route-command-side > div,
.route-kpi-card,
.route-stat-cell {
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(16, 35, 63, 0.06);
  padding: 16px;
}
.route-kpi-strip,
.route-stats-grid {
  display: grid;
  gap: 14px;
}
.route-kpi-strip {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}
.route-kpi-card span,
.route-stat-cell span {
  display: block;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.route-kpi-card strong,
.route-stat-cell strong {
  display: block;
  margin-top: 8px;
  font-family: "Outfit", sans-serif;
  font-size: 1.45rem;
}
.route-monitor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(360px, 0.75fr);
  gap: 20px;
}
.route-live-map-panel,
.route-stats-panel,
.route-timeline-panel,
.route-stops-panel {
  padding: 22px;
}
.route-panel-head {
  justify-content: space-between;
  margin-bottom: 16px;
}
.route-panel-head h3 {
  margin: 4px 0 0;
  font-family: "Outfit", sans-serif;
}
.route-map-canvas {
  overflow: hidden;
  min-height: 430px;
  border-radius: 22px;
  border: 1px solid rgba(16, 35, 63, 0.08);
  background: #eef6ff;
}
.route-map-canvas svg {
  display: block;
  width: 100%;
  height: 430px;
}
.route-stop-marker circle {
  stroke: #ffffff;
  stroke-width: 1.3;
}
.route-stop-marker text {
  fill: #ffffff;
  font-size: 3px;
  font-weight: 900;
  text-anchor: middle;
}
.route-stop-marker.completed circle {
  fill: #2dba8c;
}
.route-stop-marker.failed circle {
  fill: #ff5578;
}
.route-stop-marker.current circle {
  fill: #ffb55d;
}
.route-stop-marker.pending circle {
  fill: #4a8dff;
}
.route-driver-marker circle {
  fill: #ffffff;
  stroke: #10233f;
  stroke-width: 1;
}
.route-map-empty,
.route-map-warning {
  border-radius: 18px;
  padding: 18px;
}
.route-map-empty {
  color: var(--muted);
  background: #f4f8ff;
}
.route-map-warning {
  margin-bottom: 14px;
  color: #a52b45;
  background: rgba(255, 112, 148, 0.12);
  border: 1px solid rgba(255, 112, 148, 0.18);
}
.route-stats-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.route-timeline-track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(110px, 1fr);
  gap: 12px;
  overflow-x: auto;
  padding: 18px 4px 4px;
}
.route-timeline-stop {
  position: relative;
  display: grid;
  gap: 8px;
  justify-items: center;
  min-height: 118px;
  padding-top: 16px;
  color: var(--muted);
}
.route-timeline-stop::before {
  content: "";
  position: absolute;
  top: 34px;
  left: -50%;
  width: 100%;
  height: 3px;
  background: rgba(16, 35, 63, 0.08);
}
.route-timeline-stop:first-child::before {
  display: none;
}
.route-timeline-dot {
  z-index: 1;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  color: #ffffff;
  font-weight: 900;
  background: #8ca0c1;
}
.route-timeline-stop.on-time .route-timeline-dot {
  background: #2dba8c;
}
.route-timeline-stop.late .route-timeline-dot {
  background: #ffb55d;
}
.route-timeline-stop.failed .route-timeline-dot {
  background: #ff5578;
}
.route-timeline-stop.current .route-timeline-dot {
  background: #2867da;
}
.route-timeline-driver {
  position: absolute;
  top: -2px;
  padding: 4px 8px;
  border-radius: 999px;
  color: #ffffff;
  font-size: 0.7rem;
  font-weight: 900;
  background: #10233f;
}
.route-stop-table-wrap {
  overflow-x: auto;
}
.route-stop-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 1250px;
}
.route-stop-table th,
.route-stop-table td {
  padding: 13px 12px;
  border-bottom: 1px solid rgba(16, 35, 63, 0.07);
  text-align: left;
  vertical-align: top;
}
.route-stop-table th {
  color: #5e7aad;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: #f4f8ff;
}
.route-stop-table td span {
  display: block;
  color: var(--muted);
  font-size: 0.84rem;
}
.compact-button {
  padding: 8px 12px;
  border-radius: 12px;
}
.route-stop-detail-drawer {
  margin-top: 18px;
  padding: 18px;
  border-radius: 20px;
  background: #f8fbff;
  border: 1px solid rgba(16, 35, 63, 0.07);
}
.route-stop-detail-drawer h3,
.route-stop-detail-drawer h4 {
  margin: 4px 0 8px;
  font-family: "Outfit", sans-serif;
}
.route-stop-detail-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.route-stop-detail-grid section {
  padding: 14px;
  border-radius: 16px;
  background: #ffffff;
  border: 1px solid rgba(16, 35, 63, 0.06);
}
.route-stop-detail-grid ul {
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
}
.route-proof-thumb {
  width: 100%;
  max-height: 180px;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid rgba(16, 35, 63, 0.08);
}
.driver-active-route-card {
  align-items: flex-start;
  gap: 14px;
  padding: 14px;
  border-radius: 18px;
  background: #f7faff;
  border: 1px solid rgba(16, 35, 63, 0.06);
}
.driver-active-route-card.has-route {
  background:
    linear-gradient(
      135deg,
      #eff6ff,
      #ffffff);
  border-color: rgba(74, 141, 255, 0.22);
}
.driver-active-route-card strong,
.driver-active-route-card p {
  display: block;
  margin: 4px 0 0;
}
.driver-active-route-actions {
  justify-content: flex-end;
  flex-wrap: wrap;
}
.pharmacy-module {
  color: #0f2748;
}
.pharmacy-page-header,
.pharmacy-profile-header,
.pharmacy-form-header,
.pharmacy-filters,
.pharmacy-profile-meta,
.row-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}
.pharmacy-page-header,
.pharmacy-profile-header,
.pharmacy-form-header {
  justify-content: space-between;
  padding: 22px 4px 4px;
}
.pharmacy-page-header h1,
.pharmacy-profile-header h1 {
  margin: 0;
  font-family: "Outfit", sans-serif;
  font-size: clamp(2rem, 3vw, 2.7rem);
  letter-spacing: -0.04em;
}
.pharmacy-page-header p,
.pharmacy-profile-title p,
.pharmacy-form-header p {
  margin: 6px 0 0;
  color: var(--muted);
}
.pharmacy-stat-grid,
.pharmacy-profile-grid,
.pharmacy-mini-stats,
.pharmacy-overview-grid {
  display: grid;
  gap: 14px;
}
.pharmacy-stat-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.pharmacy-stat-card,
.pharmacy-table-shell,
.pharmacy-form-card,
.pharmacy-contact-card,
.pharmacy-tab-panel {
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(16, 35, 63, 0.07);
  box-shadow: 0 18px 50px rgba(16, 35, 63, 0.08);
}
.pharmacy-stat-card {
  display: flex;
  gap: 16px;
  align-items: center;
  min-height: 118px;
  padding: 20px;
  border-radius: 18px;
}
.pharmacy-stat-card p,
.pharmacy-stat-card small {
  margin: 0;
  color: var(--muted);
}
.pharmacy-stat-card strong {
  display: block;
  margin: 4px 0;
  font-size: 1.75rem;
}
.stat-icon {
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  border-radius: 18px;
  font-weight: 900;
}
.stat-icon.blue {
  color: #155ee8;
  background: #eaf2ff;
}
.stat-icon.green {
  color: #13864e;
  background: #e9f9ef;
}
.stat-icon.orange {
  color: #d76a00;
  background: #fff1df;
}
.stat-icon.violet {
  color: #793fea;
  background: #f1ebff;
}
.pharmacy-table-shell,
.pharmacy-form-card,
.pharmacy-contact-card,
.pharmacy-tab-panel {
  border-radius: 22px;
  padding: 20px;
}
.pharmacy-filters {
  align-items: stretch;
  margin-bottom: 14px;
}
.pharmacy-filters input,
.pharmacy-filters select,
.pharmacy-form-grid input,
.pharmacy-form-grid select {
  width: 100%;
  min-height: 44px;
  border: 1px solid rgba(16, 35, 63, 0.14);
  border-radius: 12px;
  padding: 10px 12px;
  color: #0f2748;
  background: #ffffff;
}
.pharmacy-filters input {
  flex: 1.4;
}
.pharmacy-filters select {
  flex: 0.7;
}
.pharmacy-table {
  overflow-x: auto;
}
.pharmacy-table-row {
  display: grid;
  grid-template-columns: minmax(190px, 1.2fr) 120px 110px 130px 140px 110px 110px 180px minmax(210px, 1fr);
  gap: 12px;
  align-items: center;
  min-width: 1320px;
  padding: 14px 12px;
  border-bottom: 1px solid rgba(16, 35, 63, 0.07);
}
.pharmacy-table-head {
  color: #5c7194;
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: #f5f8fe;
  border-radius: 14px;
}
.link-cell {
  color: #135ee8;
}
.link-cell.strong {
  font-weight: 900;
}
.status-pill {
  display: inline-flex;
  justify-content: center;
  width: fit-content;
  min-width: 78px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 900;
  color: #315177;
  background: #eaf2ff;
}
.status-pill.active {
  color: #087443;
  background: #dff8ea;
}
.status-pill.inactive {
  color: #6d7686;
  background: #eef2f7;
}
.status-pill.suspended {
  color: #b32244;
  background: #ffe8ee;
}
.icon-action {
  border: 1px solid rgba(74, 141, 255, 0.2);
  border-radius: 10px;
  padding: 7px 10px;
  color: #155ee8;
  font-weight: 800;
  background: #f2f7ff;
  cursor: pointer;
}
.icon-action.danger,
.danger-button {
  color: #c91f45;
  border-color: rgba(255, 112, 148, 0.3);
  background: #fff3f6;
}
.danger-button {
  border-radius: 14px;
  padding: 11px 16px;
  font-weight: 900;
  cursor: pointer;
}
.pharmacy-empty-state,
.success-toast {
  padding: 18px;
  border-radius: 16px;
}
.pharmacy-empty-state {
  color: var(--muted);
  background: #f8fbff;
}
.success-toast {
  color: #087443;
  font-weight: 900;
  background: #e7f8ee;
  border: 1px solid rgba(45, 186, 140, 0.16);
}
.pharmacy-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.pharmacy-form-grid label {
  display: grid;
  gap: 7px;
  color: #536b8e;
  font-weight: 800;
}
.pharmacy-form-grid .span-two {
  grid-column: span 2;
}
.checkbox-label {
  display: flex !important;
  align-items: center;
  grid-template-columns: none !important;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid rgba(16, 35, 63, 0.1);
  border-radius: 12px;
  background: #f9fbff;
}
.checkbox-label input {
  width: auto;
  min-height: auto;
}
.pharmacy-profile-grid {
  grid-template-columns: minmax(260px, 0.35fr) minmax(0, 1fr);
}
.pharmacy-contact-card h3,
.pharmacy-tab-panel h3 {
  margin-top: 0;
}
.pharmacy-contact-card dl {
  display: grid;
  gap: 10px;
  margin: 18px 0 0;
}
.pharmacy-contact-card dt,
.pharmacy-overview-grid span,
.pharmacy-mini-stats span {
  color: #6d82a4;
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.pharmacy-contact-card dd {
  margin: 3px 0 0;
  font-weight: 800;
}
.pharmacy-profile-main {
  display: grid;
  gap: 14px;
}
.pharmacy-mini-stats {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}
.pharmacy-mini-stats article {
  padding: 16px;
  border-radius: 16px;
  background: #ffffff;
  border: 1px solid rgba(16, 35, 63, 0.07);
}
.pharmacy-mini-stats strong {
  display: block;
  margin-top: 8px;
  font-size: 1.35rem;
}
.pharmacy-tabs {
  display: flex;
  gap: 6px;
  padding: 8px;
  overflow-x: auto;
  border-radius: 18px;
  background: #eef4fe;
}
.pharmacy-tabs button {
  border: 0;
  border-radius: 14px;
  padding: 12px 18px;
  color: #50688f;
  font-weight: 900;
  background: transparent;
  cursor: pointer;
}
.pharmacy-tabs button.active {
  color: #155ee8;
  background: #ffffff;
  box-shadow: 0 8px 22px rgba(16, 35, 63, 0.08);
}
.pharmacy-overview-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.pharmacy-overview-grid div {
  padding: 14px;
  border-radius: 14px;
  background: #f8fbff;
  border: 1px solid rgba(16, 35, 63, 0.06);
}
.pharmacy-overview-grid strong {
  display: block;
  margin-top: 6px;
}
.pharmacy-settings-panel,
.pharmacy-billing-panel {
  display: grid;
  gap: 16px;
}
@media (max-width: 1180px) {
  .home-hero,
  .grid-two,
  .grid-three,
  .grid-four,
  .order-detail-layout,
  .detail-grid,
  .portal-shell,
  .filter-bar,
  .compact-grid,
  .dashboard-main-grid,
  .dashboard-lower-grid,
  .dashboard-stat-row,
  .dispatcher-metric-row,
  .dispatcher-filter-row,
  .route-command-hero,
  .route-command-side,
  .route-kpi-strip,
  .route-monitor-grid,
  .route-stats-grid,
  .route-stop-detail-grid,
  .warehouse-scan-card,
  .pharmacy-stat-grid,
  .pharmacy-profile-grid,
  .pharmacy-mini-stats,
  .pharmacy-overview-grid,
  .pharmacy-form-grid,
  .public-hero-shell {
    grid-template-columns: 1fr;
  }
  .site-header,
  .site-footer,
  .section-banner,
  .portal-topbar-row {
    flex-direction: column;
    align-items: flex-start;
  }
  .portal-topbar {
    position: static;
  }
  .portal-topbar-actions {
    width: 100%;
    justify-content: flex-start;
  }
  .topbar-nav {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding: 10px 0 4px;
    width: 100%;
    justify-content: flex-start;
  }
  .dashboard-headline,
  .dispatcher-hero-card,
  .pharmacy-page-header,
  .pharmacy-profile-header,
  .pharmacy-form-header,
  .pharmacy-filters {
    flex-direction: column;
    align-items: flex-start;
  }
  .pharmacy-filters input,
  .pharmacy-filters select {
    flex: auto;
  }
  .pharmacy-form-grid .span-two {
    grid-column: span 1;
  }
}
@media (max-width: 720px) {
  .site-shell,
  .portal-shell {
    padding: 14px;
  }
  .site-header,
  .site-footer,
  .hero-panel,
  .metric-card,
  .info-card,
  .contact-card,
  .contact-form,
  .auth-card,
  .section-banner,
  .portal-topbar,
  .table-card,
  .app-section {
    border-radius: 22px;
  }
  .table-row {
    grid-template-columns: 1fr;
  }
  .login-demo-list {
    grid-template-columns: 1fr;
  }
  .warehouse-scan-form {
    grid-template-columns: 1fr;
  }
}
