/* 2T Admin — Rehlati-style dashboard */
:root {
  --dash-bg: #E9EEF3;
  --dash-bg-subtle: #f1f5f9;
  --dash-surface: #ffffff;
  --dash-ink: #0f172a;
  --dash-ink-soft: #334155;
  --dash-muted: #64748b;
  --dash-line: #e2e8f0;
  --dash-line-strong: #cbd5e1;
  --dash-primary: #1d4ed8;
  --dash-primary-hover: #1e40af;
  --dash-primary-light: #eff6ff;
  --dash-primary-ring: rgba(29, 78, 216, 0.18);
  --dash-sidebar-bg: #111827;
  --dash-sidebar-border: #1f2937;
  --dash-sidebar-text: #9ca3af;
  --dash-sidebar-text-active: #ffffff;
  --dash-gold: #c9a227;
  --dash-gold-dark: #a8841a;
  --dash-gold-light: rgba(201, 162, 39, 0.1);
  --dash-gold-ring: rgba(201, 162, 39, 0.28);
  --dash-green: #16a34a;
  --dash-green-bg: #dcfce7;
  --dash-green-text: #15803d;
  --dash-amber: #ea580c;
  --dash-amber-bg: #ffedd5;
  --dash-amber-text: #c2410c;
  --dash-red: #dc2626;
  --dash-red-bg: #fee2e2;
  --dash-red-text: #b91c1c;
  --dash-blue: #2563eb;
  --dash-header-bg: transparent;
  --dash-sidebar-w: var(--dash-sidebar-w-wide);
  --dash-sidebar-w-wide: 272px;
  --dash-topbar-h: 56px;
  --dash-topbar-total-h: var(--dash-topbar-h);
  --dash-radius: 12px;
  --dash-radius-md: 10px;
  --dash-radius-sm: 8px;
  --dash-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
  --dash-shadow-hover: 0 4px 16px rgba(15, 23, 42, 0.08);
  --dash-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --dash-transition: 0.2s var(--dash-ease);
}

/* كثافة مريحة */
html.dash-ui-compact {
  --dash-topbar-h: 56px;
  --dash-sidebar-w: 240px;
}

html.dash-ui-compact .home-page .dash-panel {
  min-height: 0;
}

html.dash-ui-compact .home-page .dash-panel-home-map .dash-map {
  min-height: 280px;
  height: min(36vh, 360px);
}

html.dash-ui-compact body[data-admin-view="home"] .home-page {
  gap: 10px;
}

html.dash-ui-compact body[data-admin-view="rides"] .dash-content,
html.dash-ui-compact body[data-admin-view="captains"] .dash-content {
  padding-top: 8px;
}

html.dash-ui-compact body[data-admin-view="rides"] .dash-content-inner,
html.dash-ui-compact body[data-admin-view="captains"] .dash-content-inner {
  padding: 8px 6px 0;
}

html.dash-ui-compact .dash-topbar-head {
  min-height: var(--dash-topbar-h);
  padding: 0 8px;
  gap: 8px;
}

html.dash-ui-compact .dash-search-wrap {
  min-width: 0;
  max-width: none;
}

html.dash-ui-compact .dash-search {
  padding: 6px 14px 6px 38px;
  font-size: 12px;
}

html.dash-ui-compact .dash-topbar-btn {
  width: 34px;
  height: 34px;
}

html.dash-ui-compact .dash-topbar-btn .fi {
  font-size: 16px;
}

html.dash-ui-compact .dash-topbar-crumb {
  padding: 0 8px 6px;
  font-size: 12px;
}

html.dash-ui-compact body.dash-shell-yt .dash-content-inner {
  padding: 12px 20px 24px;
}

html.dash-ui-compact .home-page {
  gap: 8px;
}

html.dash-ui-compact .home-page .dash-panel-head {
  padding: 8px 12px;
}

html.dash-ui-compact .home-page .dash-panel-head h3 {
  font-size: 12px;
}

html.dash-ui-compact .ride-toolbar {
  padding: 10px 12px;
  gap: 8px;
}

html.dash-ui-compact .ride-search {
  max-width: 240px;
  padding: 8px 10px;
  font-size: 12px;
}

html.dash-ui-compact .ride-filter {
  padding: 5px 9px;
  font-size: 10px;
}

html.dash-ui-compact .ride-split {
  min-height: 0;
}

html.dash-ui-compact .ride-split-head {
  padding: 10px 12px;
}

html.dash-ui-compact .ride-split-title strong {
  font-size: 13px;
}

html.dash-ui-compact .ride-split-icon {
  width: 32px;
  height: 32px;
  font-size: 16px;
  border-radius: 10px;
}

html.dash-ui-compact .ride-split-list {
  max-height: none;
}

html.dash-ui-compact .cap-toolbar {
  padding: 10px 12px;
  gap: 8px;
}

html.dash-ui-compact .cap-search {
  max-width: 240px;
  padding: 8px 10px;
  font-size: 12px;
}

html.dash-ui-compact .cap-filter {
  padding: 5px 9px;
  font-size: 10px;
}

html.dash-ui-compact .cap-split {
  min-height: 0;
}

html.dash-ui-compact .cap-split-head {
  padding: 10px 12px;
}

html.dash-ui-compact .cap-split-title strong {
  font-size: 13px;
}

html.dash-ui-compact .cap-split-icon {
  width: 32px;
  height: 32px;
  font-size: 15px;
  border-radius: 10px;
}

html.dash-ui-compact .cap-split-list {
  max-height: none;
}

html.dash-ui-compact .dash-table--captains td,
html.dash-ui-compact .dash-table--captains th {
  padding: 8px 10px;
}

html.dash-ui-compact .cap-captain-place .cap-avatar,
html.dash-ui-compact .cap-captain-place .cap-avatar--ph {
  width: 30px;
  height: 30px;
  font-size: 12px;
}

html.dash-ui-compact .cap-captain-name {
  font-size: 12px;
}

html.dash-ui-compact .dash-table--rides td,
html.dash-ui-compact .dash-table--rides th {
  padding: 8px 10px;
}

*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0;
  min-height: 100vh;
  min-width: 0;
  width: 100%;
  overflow-x: hidden;
  font-family: Cairo, system-ui, sans-serif;
  color: var(--dash-ink);
  background: var(--dash-bg);
  -webkit-font-smoothing: antialiased;
}

button, input, select, textarea { font: inherit; }
button { border: 0; cursor: pointer; background: none; }
a { color: var(--dash-ink-soft); text-decoration: none; transition: color var(--dash-transition); }
a:hover { color: var(--dash-primary); }

/* ── Login ── */
.admin-login-screen[hidden] { display: none !important; }

.admin-login-screen {
  min-height: 100vh;
  display: grid;
  place-items: center;
  background: var(--dash-bg-subtle);
  padding: 32px;
}

.admin-login-card {
  width: min(440px, 100%);
  background: var(--dash-surface);
  border-radius: var(--dash-radius);
  padding: 40px 36px;
  border: 1px solid var(--dash-line);
  box-shadow: var(--dash-shadow-hover);
}

.admin-login-brand { text-align: center; margin-bottom: 32px; }

.admin-login-brand b {
  display: block;
  font-size: 48px;
  font-weight: 900;
  letter-spacing: -2px;
  color: var(--dash-ink);
}

.admin-login-brand b::after {
  content: '';
  display: block;
  width: 48px;
  height: 3px;
  background: var(--dash-primary);
  margin: 8px auto 0;
  border-radius: 999px;
}

.admin-login-brand span {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: var(--dash-muted);
  margin-top: 12px;
}

.admin-login-label {
  display: block;
  font-size: 12px;
  font-weight: 800;
  color: var(--dash-muted);
  margin-bottom: 8px;
}

.admin-login-input {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--dash-line-strong);
  border-radius: var(--dash-radius-md);
  font-weight: 700;
  background: #fff;
  margin-bottom: 12px;
  transition: border-color var(--dash-transition), box-shadow var(--dash-transition);
}

.admin-login-input:focus {
  outline: none;
  border-color: var(--dash-primary);
  box-shadow: 0 0 0 3px var(--dash-primary-ring);
}

.admin-login-hint {
  font-size: 12px;
  font-weight: 700;
  color: var(--dash-muted);
  line-height: 1.6;
  margin: 0 0 16px;
}

.admin-login-btn {
  width: 100%;
  padding: 15px;
  border-radius: var(--dash-radius-md);
  background: var(--dash-primary);
  color: #fff;
  font-weight: 900;
  font-size: 15px;
  transition: transform var(--dash-transition), box-shadow var(--dash-transition), background var(--dash-transition);
}

.admin-login-btn:hover:not(:disabled) {
  transform: translateY(-1px);
  background: var(--dash-primary-hover);
  box-shadow: 0 8px 24px rgba(29, 78, 216, 0.25);
}

.admin-login-btn:disabled { opacity: 0.45; }

.admin-err {
  color: var(--dash-red);
  font-size: 13px;
  font-weight: 800;
  margin-top: 12px;
  text-align: center;
}

/* ── App shell — full-width header above side rails ── */
.dash-app {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-width: 0;
  box-sizing: border-box;
  padding: 0;
  background: var(--dash-bg-subtle);
}

.dash-main {
  flex: 1;
  min-width: 0;
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: var(--dash-sidebar-w);
  padding-top: var(--dash-topbar-total-h, var(--dash-topbar-h));
  box-sizing: border-box;
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.dash-app[hidden] { display: none !important; }

/* ── Sidebar ── */
.dash-sidebar {
  position: fixed;
  top: var(--dash-topbar-total-h, var(--dash-topbar-h));
  right: 0;
  width: var(--dash-sidebar-w);
  height: calc(100vh - var(--dash-topbar-total-h, var(--dash-topbar-h)));
  background: var(--dash-sidebar-bg);
  border-left: 1px solid var(--dash-sidebar-border);
  display: flex;
  flex-direction: column;
  z-index: 120;
}

.dash-sidebar-brand {
  padding: 24px 20px 20px;
  border-bottom: 1px solid var(--dash-sidebar-border);
}

.dash-sidebar-brand b {
  display: block;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -1px;
  color: #fff;
  line-height: 1;
}

.dash-sidebar-brand small {
  display: block;
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-sidebar-text);
  margin-top: 6px;
}

.dash-nav {
  flex: 1;
  overflow-y: auto;
  padding: 14px 10px;
}

.dash-nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 11px 14px;
  border-radius: var(--dash-radius-md);
  color: var(--dash-sidebar-text);
  font-weight: 700;
  font-size: 14px;
  text-align: right;
  transition: background var(--dash-transition), color var(--dash-transition);
  position: relative;
  margin-bottom: 4px;
}

.dash-nav-item:hover {
  background: rgba(255, 255, 255, 0.06);
  color: #e5e7eb;
}

.dash-nav-item.on {
  background: var(--dash-primary);
  color: var(--dash-sidebar-text-active);
}

.dash-nav-item.on::before { display: none; }

.dash-nav-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.85;
}

.dash-nav-item.on .dash-nav-icon { opacity: 1; color: #fff; }

.dash-nav-icon svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.dash-nav-icon .fi {
  font-size: 20px;
  line-height: 1;
  color: inherit;
  direction: ltr;
  unicode-bidi: isolate;
  display: inline-block;
}

.dash-sidebar-foot {
  padding: 14px 10px 18px;
  border-top: 1px solid var(--dash-sidebar-border);
}

.dash-sidebar-foot a,
.dash-sidebar-foot button {
  display: block;
  width: 100%;
  padding: 11px 14px;
  border-radius: var(--dash-radius-sm);
  font-weight: 700;
  font-size: 13px;
  text-align: center;
  transition: background var(--dash-transition), color var(--dash-transition);
}

.dash-sidebar-foot button {
  color: #fca5a5;
  margin-bottom: 6px;
}

.dash-sidebar-foot button:hover { background: rgba(239, 68, 68, 0.12); color: #fecaca; }

.dash-sidebar-foot a {
  color: var(--dash-sidebar-text);
  border: 1px solid var(--dash-sidebar-border);
}

.dash-sidebar-foot a:hover {
  background: rgba(255, 255, 255, 0.06);
  color: #e5e7eb;
}

/* ── Main ── */
.dash-topbar[hidden] {
  display: none !important;
}

.dash-topbar--sub .dash-topbar-title {
  font-size: 18px;
  font-weight: 900;
  color: #f1f5f9;
  letter-spacing: -0.01em;
}

.dash-topbar--sub .dash-topbar-crumb {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: var(--dash-muted);
}

html.dash-ui-compact .dash-topbar--sub .dash-topbar-title {
  font-size: 17px;
}

html.dash-ui-compact .dash-topbar--sub .dash-topbar-crumb {
  font-size: 12px;
}

.dash-topbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 110;
  height: auto;
  min-height: var(--dash-topbar-h);
  margin-left: 0;
  width: 100%;
  box-sizing: border-box;
  background: transparent;
  border-bottom: none;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  padding: 0;
  gap: 0;
}

.dash-topbar-head {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: var(--dash-topbar-h);
  padding: 10px 16px;
  flex: 1;
  flex-shrink: 0;
  background: transparent;
}

.dash-topbar-start {
  display: none;
  min-width: 0;
}

.dash-topbar-notify-wrap {
  position: relative;
  flex-shrink: 0;
}

.dash-topbar-crumb {
  margin: 0;
  padding: 0 12px 8px;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: var(--dash-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dash-topbar-crumb a {
  color: var(--dash-muted);
  transition: color var(--dash-transition);
}

.dash-topbar-crumb a:hover { color: var(--dash-primary); }

.dash-topbar-title {
  margin: 0;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.15;
  color: var(--dash-ink);
}

.dash-topbar-title--brand {
  display: flex;
  align-items: center;
}

.dash-app-brand {
  display: inline-flex;
  align-items: baseline;
  gap: 0.38em;
}

.dash-app-brand .brand-nashwan {
  font-size: 0.72em;
  font-weight: 700;
}

.dash-app-brand .brand-wordmark {
  font-size: 30px;
}

/* Topbar — full width, card-band height */
.dash-topbar--home {
  min-height: var(--dash-topbar-h);
}

.dash-topbar--home .dash-topbar-head {
  min-height: var(--dash-topbar-h);
}

.dash-topbar-sub {
  margin: 4px 0 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--dash-muted);
}

.dash-topbar-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-shrink: 0;
}

.dash-topbar-btn--logout:hover {
  border-color: rgba(220, 38, 38, 0.35);
  background: rgba(254, 226, 226, 0.55);
}

.dash-topbar-btn--logout:hover .fi {
  color: var(--dash-red);
}

.dash-search-wrap {
  position: relative;
  flex: 0 1 auto;
  width: min(320px, 32vw);
  min-width: 160px;
}

.dash-search {
  width: 100%;
  min-width: 0;
  padding: 7px 16px 7px 42px;
  border: 1px solid var(--dash-line);
  border-radius: var(--dash-radius-sm);
  background: #fff;
  font-weight: 600;
  font-size: 13px;
  line-height: 1.3;
  transition: border-color var(--dash-transition), box-shadow var(--dash-transition);
}

.dash-search:focus {
  outline: none;
  border-color: var(--dash-primary);
  box-shadow: 0 0 0 3px var(--dash-primary-ring);
}

.dash-search-wrap .dash-search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  color: var(--dash-muted);
  pointer-events: none;
}

.dash-topbar-btn {
  width: 40px;
  height: 40px;
  border-radius: var(--dash-radius-md);
  border: 1px solid var(--dash-line);
  background: #fff;
  display: grid;
  place-items: center;
  position: relative;
  transition: border-color var(--dash-transition), background var(--dash-transition);
}

.dash-topbar-btn:hover {
  border-color: var(--dash-line-strong);
  background: var(--dash-bg-subtle);
  transform: none;
}

.dash-topbar-btn svg {
  width: 18px;
  height: 18px;
  stroke: var(--dash-ink-soft);
  fill: none;
  stroke-width: 1.75;
}

.dash-topbar-btn .fi {
  font-size: 18px;
  line-height: 1;
  color: var(--dash-ink-soft);
}

.dash-notify-dot {
  position: absolute;
  top: 6px;
  left: 6px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: var(--dash-primary);
  color: #fff;
  font-size: 10px;
  font-weight: 900;
  display: grid;
  place-items: center;
  border: 2px solid #fff;
}

.dash-notify-dot:empty,
.dash-notify-dot[data-count="0"] { display: none; }

.dash-notify-panel {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  width: min(360px, 80vw);
  background: #fff;
  border: 1px solid var(--dash-line);
  border-radius: var(--dash-radius-md);
  box-shadow: var(--dash-shadow-hover);
  padding: 8px;
  z-index: 60;
}

.dash-notify-panel[hidden] { display: none !important; }

.dash-notify-panel-head {
  padding: 10px 12px 8px;
  font-size: 13px;
  font-weight: 900;
  color: var(--dash-ink);
}

.dash-notify-item {
  display: block;
  width: 100%;
  text-align: right;
  padding: 12px;
  border-radius: var(--dash-radius-sm);
  font-size: 12px;
  font-weight: 700;
  color: var(--dash-ink-soft);
  transition: background var(--dash-transition);
}

.dash-notify-item:hover { background: var(--dash-bg-subtle); }

.dash-notify-item small {
  display: block;
  margin-top: 4px;
  color: var(--dash-muted);
  font-weight: 700;
}

.dash-notify-empty {
  padding: 24px 12px;
  text-align: center;
  color: var(--dash-muted);
  font-size: 12px;
  font-weight: 700;
}

.dash-topbar-user {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 12px 6px 6px;
  border-radius: var(--dash-radius-md);
  border: 1px solid var(--dash-line);
  background: #fff;
}

.dash-topbar-avatar {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: var(--dash-primary-light);
  color: var(--dash-primary);
  display: grid;
  place-items: center;
  font-size: 13px;
  font-weight: 900;
}

.dash-topbar-user span {
  font-size: 13px;
  font-weight: 700;
  color: var(--dash-ink);
}

.dash-btn {
  padding: 10px 16px;
  border-radius: var(--dash-radius-md);
  font-weight: 700;
  font-size: 13px;
  background: #fff;
  color: var(--dash-ink-soft);
  border: 1px solid var(--dash-line);
  transition: background var(--dash-transition), border-color var(--dash-transition), color var(--dash-transition);
}

.dash-btn:hover:not(:disabled) {
  transform: none;
  box-shadow: none;
  border-color: var(--dash-line-strong);
  background: var(--dash-bg-subtle);
}

.dash-btn.primary {
  background: var(--dash-primary);
  color: #fff;
  border-color: var(--dash-primary);
}

.dash-btn.primary:hover:not(:disabled) {
  background: var(--dash-primary-hover);
  border-color: var(--dash-primary-hover);
  box-shadow: 0 4px 12px rgba(29, 78, 216, 0.22);
}

.dash-btn.gold {
  background: var(--dash-gold-light);
  color: var(--dash-gold-dark);
  border-color: var(--dash-gold-ring);
}

.dash-btn.danger {
  color: var(--dash-red-text);
  border-color: #fecaca;
  background: var(--dash-red-bg);
}

.dash-btn.ok {
  background: var(--dash-green-bg);
  color: var(--dash-green-text);
  border-color: #bbf7d0;
}

.dash-btn:disabled { opacity: 0.45; cursor: not-allowed; transform: none !important; }

body:not(.dash-view-home) .dash-content {
  padding-top: 16px;
}

body[data-admin-view="pricing"] .dash-content-inner {
  padding-inline: 20px 16px;
}

html.dash-ui-compact body:not(.dash-view-home) .dash-content {
  padding-top: 12px;
}

.dash-content {
  flex: 1;
  position: relative;
  z-index: 1;
  isolation: isolate;
  margin-left: 0;
  padding: 24px 28px 40px;
  overflow: auto;
  background: var(--dash-bg-subtle);
  transition: margin-left 0.2s var(--dash-ease);
}

.dash-view[hidden] { display: none !important; }

.dash-offline-banner {
  background: var(--dash-red-bg);
  border: 1px solid #fecaca;
  color: var(--dash-red-text);
  padding: 14px 18px;
  border-radius: var(--dash-radius-md);
  font-weight: 800;
  font-size: 13px;
  margin-bottom: 24px;
}

/* ── Stats ── */
.dash-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 14px;
}

.dash-stats--6 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.dash-stats--8 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.dash-stat {
  position: relative;
  background: var(--dash-surface);
  border-radius: var(--dash-radius-sm);
  padding: 7px 10px;
  border: 1px solid var(--dash-line);
  box-shadow: var(--dash-shadow);
  display: flex;
  gap: 8px;
  align-items: center;
  min-height: 50px;
  overflow: hidden;
  transition: box-shadow var(--dash-transition);
}

.dash-stat::after { display: none; }

.dash-stat:hover {
  transform: none;
  box-shadow: var(--dash-shadow-hover);
  border-color: var(--dash-line);
}

.dash-stat-icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: var(--dash-bg-subtle);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  font-size: 13px;
  line-height: 1;
}

.dash-stat-body {
  min-width: 0;
  flex: 1;
}

.dash-stat-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--dash-muted);
  margin-bottom: 1px;
  line-height: 1.25;
}

.dash-stat-value {
  font-size: 15px;
  font-weight: 900;
  line-height: 1.1;
  margin-bottom: 0;
  letter-spacing: -0.02em;
  color: var(--dash-ink);
}

.dash-stat-sub {
  font-size: 8px;
  font-weight: 700;
  color: var(--dash-muted);
  margin-top: 1px;
  line-height: 1.25;
}

.dash-stat.accent-gold::after { background: linear-gradient(90deg, var(--dash-gold) 0%, rgba(201, 162, 39, 0.15) 100%); }
.dash-stat.accent-green::after { background: linear-gradient(90deg, var(--dash-green) 0%, rgba(22, 163, 74, 0.12) 100%); }
.dash-stat.accent-amber::after { background: linear-gradient(90deg, var(--dash-amber) 0%, rgba(202, 138, 4, 0.12) 100%); }
.dash-stat.accent-blue::after { background: linear-gradient(90deg, #2563eb 0%, rgba(37, 99, 235, 0.12) 100%); }
.dash-stat.accent-cyan::after { background: linear-gradient(90deg, #0891b2 0%, rgba(8, 145, 178, 0.12) 100%); }
.dash-stat.accent-purple::after { background: linear-gradient(90deg, #7c3aed 0%, rgba(124, 58, 237, 0.12) 100%); }

.dash-stat.accent-gold .dash-stat-icon { background: var(--dash-gold-light); }
.dash-stat.accent-gold .dash-stat-value { color: var(--dash-ink); }
.dash-stat.accent-green .dash-stat-icon { background: var(--dash-green-bg); }
.dash-stat.accent-green .dash-stat-value { color: var(--dash-ink); }
.dash-stat.accent-amber .dash-stat-icon { background: var(--dash-amber-bg); }
.dash-stat.accent-amber .dash-stat-value { color: var(--dash-ink); }
.dash-stat.accent-blue .dash-stat-icon { background: var(--dash-primary-light); }
.dash-stat.accent-blue .dash-stat-value { color: var(--dash-ink); }
.dash-stat.accent-cyan .dash-stat-icon { background: #ecfeff; }
.dash-stat.accent-cyan .dash-stat-value { color: var(--dash-ink); }
.dash-stat.accent-purple .dash-stat-icon { background: #f5f3ff; }
.dash-stat.accent-purple .dash-stat-value { color: var(--dash-ink); }

/* بطاقات بدون أيقونة (احتياط) */
.dash-stat:not(:has(.dash-stat-icon)) {
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  padding: 6px 9px;
  min-height: 44px;
}

.dash-stat:not(:has(.dash-stat-icon)) .dash-stat-value {
  font-size: 14px;
  margin-top: 1px;
}

/* ── Panels & grids ── */
.dash-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 24px;
}

.dash-grid-2-1 {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 24px;
  margin-bottom: 24px;
}

/* ── Home page — full-width strips + map ── */
.home-page {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

/* غيّر إلى home-page--map-top لو تريد الخريطة فوق */
.home-page--map-bottom .home-strip-row--activity { order: 1; }
.home-page--map-bottom .home-strip-row--rides { order: 2; }
.home-page--map-bottom .home-map-row { order: 3; }

.home-page--map-top .home-map-row { order: 1; }
.home-page--map-top .home-strip-row--activity { order: 2; }
.home-page--map-top .home-strip-row--rides { order: 3; }

.home-strip-row,
.home-map-row {
  width: 100%;
  min-width: 0;
}

.home-page .dash-panel {
  direction: rtl;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
  border-radius: 14px;
  border: 1px solid rgba(226, 232, 240, 0.95);
  box-shadow:
    0 1px 2px rgba(15, 23, 42, 0.04),
    0 6px 20px rgba(15, 23, 42, 0.04);
  background: #fff;
  overflow: hidden;
}

.dash-panel-head--home {
  padding: 0;
  background: transparent;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

.home-page .dash-panel-head {
  flex-shrink: 0;
  padding: 12px 16px;
  background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
  border-bottom: 1px solid rgba(226, 232, 240, 0.9);
}

.home-page .dash-panel-head--home,
.home-page .dash-panel-home-activity .dash-panel-head,
.home-page .dash-panel-home-rides .dash-panel-head {
  padding: 0;
  background: transparent;
  border-bottom: none;
}

.home-page .dash-panel-head h3 {
  font-size: 14px;
  font-weight: 800;
}

.dash-grid-home-top {
  direction: ltr;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 12px;
  align-items: stretch;
  width: 100%;
  margin-bottom: 12px;
}

.dash-grid-home-top .dash-panel {
  direction: rtl;
  display: flex;
  flex-direction: column;
  min-height: 0;
  border-radius: 14px;
  border: 1px solid rgba(226, 232, 240, 0.95);
  box-shadow:
    0 1px 2px rgba(15, 23, 42, 0.04),
    0 6px 20px rgba(15, 23, 42, 0.04);
  background: #fff;
  overflow: hidden;
}

.dash-grid-home-top .dash-panel-head {
  flex-shrink: 0;
  padding: 12px 16px;
  background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
  border-bottom: 1px solid rgba(226, 232, 240, 0.9);
}

.dash-grid-home-top .dash-panel-head h3 {
  font-size: 14px;
  font-weight: 800;
}

.dash-panel-home-map .dash-panel-head h3::before {
  background: var(--dash-primary);
  box-shadow: 0 0 0 4px rgba(29, 78, 216, 0.12);
}

.dash-panel-home-activity .dash-panel-head h3::before {
  background: var(--dash-amber);
  box-shadow: 0 0 0 4px var(--dash-amber-bg);
}

.dash-panel-home-rides .dash-panel-head h3::before {
  background: var(--dash-green);
  box-shadow: 0 0 0 4px var(--dash-green-bg);
}

.dash-panel-home-map {
  display: flex;
  flex-direction: column;
}

.home-page .dash-panel-home-map .dash-map {
  flex: none;
  width: 100%;
  min-height: min(400px, 42vh);
  height: min(400px, 42vh);
}

.home-page .dash-panel-home-map .dash-map-legend {
  flex-shrink: 0;
  padding: 10px 16px;
  background: #fafbfd;
}

.home-page .dash-panel-body.flush {
  display: flex;
  flex-direction: column;
}

.dash-panel-home-map .dash-map {
  flex: 1;
  min-height: 380px;
  height: auto;
  width: 100%;
}

.dash-panel-home-map .dash-map-legend {
  flex-shrink: 0;
  padding: 10px 16px;
  background: #fafbfd;
}

.dash-grid-home-top .dash-panel-body.flush {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.dash-panel-home-activity .dash-panel-body,
.dash-panel-home-rides .dash-panel-body {
  flex: 0 0 auto;
  min-height: 0;
  max-height: none;
  overflow: visible;
  padding: 8px 10px 10px;
}

.home-panel-open {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  padding: 12px 16px;
  border: 0;
  background: transparent;
  cursor: pointer;
  text-align: inherit;
  font: inherit;
  color: inherit;
  transition: background var(--dash-transition);
}

.home-panel-open:hover {
  background: rgba(248, 250, 252, 0.85);
}

.home-panel-open h3 {
  margin: 0;
  font-size: 14px;
  font-weight: 800;
}

.home-see-all {
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 800;
  color: var(--dash-primary);
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(29, 78, 216, 0.08);
  border: 1px solid rgba(29, 78, 216, 0.12);
  white-space: nowrap;
}

.dash-panel-head--home .home-panel-open {
  padding: 9px 14px;
}

.dash-panel-head--home .home-panel-open h3 {
  font-size: 13px;
}

.home-panel-head-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  padding: 12px 16px;
  direction: rtl;
  transition: background var(--dash-transition);
  box-sizing: border-box;
}

.home-panel-head-main {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  min-width: 0;
  flex: 1 1 auto;
  overflow: visible;
}

.home-panel-head-row--activity:hover,
.home-panel-head-row--rides:hover {
  background: rgba(255, 255, 255, 0.05);
}

.home-panel-title-btn {
  flex-shrink: 0;
  margin: 0;
}

.home-panel-head-chips {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  padding-inline-start: 12px;
  border-inline-start: 1px solid rgba(148, 163, 184, 0.22);
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.home-panel-head-chips::-webkit-scrollbar {
  display: none;
}

.home-panel-all-btn {
  flex-shrink: 0;
  margin: 0;
  position: relative;
  z-index: 1;
}

.home-panel-head-summary {
  display: inline-flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
  width: max-content;
  max-width: 100%;
  padding: 1px 0;
}

.home-panel-head-summary .home-ride-chip {
  padding: 5px 10px;
  gap: 6px;
  border-radius: 9px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.03);
}

.home-panel-head-summary .home-ride-chip:hover {
  box-shadow: 0 3px 12px rgba(15, 23, 42, 0.07);
}

.home-panel-head-summary .home-ride-chip-label {
  font-size: 10px;
  letter-spacing: -0.01em;
}

.home-panel-head-summary .home-ride-chip-count {
  font-size: 13px;
}

.home-panel-head-empty {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-sidebar-text);
  opacity: 0.85;
  padding-inline-start: 2px;
}

.home-panel-title-btn,
.home-panel-all-btn {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
  color: inherit;
  text-align: inherit;
  transition: opacity 0.15s ease;
}

.home-panel-title-btn:hover,
.home-panel-all-btn:hover {
  opacity: 0.82;
}

.home-panel-title-btn h3 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
  letter-spacing: -0.02em;
  color: var(--dash-sidebar-text-active, #fff);
}

.home-panel-all-btn .home-see-all {
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
}

.home-panel-all-btn:hover .home-see-all {
  transform: translateY(-1px);
}

.dash-panel-home-activity .home-panel-all-btn:hover .home-see-all,
.dash-panel-home-rides .home-panel-all-btn:hover .home-see-all {
  background: rgba(96, 165, 250, 0.18);
  border-color: rgba(96, 165, 250, 0.32);
}

.home-panel-live-foot {
  flex-shrink: 0;
  padding: 4px 16px 12px !important;
  background: transparent !important;
  border-top: none !important;
  direction: rtl;
  box-sizing: border-box;
}

.home-summary-live-foot {
  width: 100%;
  box-sizing: border-box;
  justify-content: flex-start;
}

.home-panel-live-foot:empty {
  display: none;
  padding: 0 !important;
}

.home-hscroll-empty {
  padding: 10px 12px;
  font-size: 12px;
}

/* ── Home rides summary (light, one row) ── */
.home-ride-summary {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 8px;
  width: 100%;
  overflow-x: auto;
  padding: 2px 0;
  scrollbar-width: thin;
}

.home-ride-chip {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 9px 16px;
  border-radius: 11px;
  border: 1px solid var(--dash-line);
  background: #fff;
  cursor: pointer;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.home-ride-chip:hover {
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.06);
  transform: translateY(-1px);
}

.home-ride-chip-label {
  font-size: 13px;
  font-weight: 800;
  color: var(--dash-ink-soft);
  white-space: nowrap;
}

.home-ride-chip-count {
  font-size: 16px;
  font-weight: 900;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.home-ride-chip--active {
  border-color: rgba(22, 163, 74, 0.28);
  background: linear-gradient(180deg, #fff 0%, #f0fdf4 100%);
}

.home-ride-chip--active .home-ride-chip-count { color: #16a34a; }

.home-ride-chip--searching {
  border-color: rgba(217, 119, 6, 0.28);
  background: linear-gradient(180deg, #fff 0%, #fffbeb 100%);
}

.home-ride-chip--searching .home-ride-chip-count { color: #d97706; }

.home-ride-chip--completed {
  border-color: rgba(37, 99, 235, 0.25);
  background: linear-gradient(180deg, #fff 0%, #eff6ff 100%);
}

.home-ride-chip--completed .home-ride-chip-count { color: #2563eb; }

.home-ride-chip--cancelled {
  border-color: rgba(220, 38, 38, 0.22);
  background: linear-gradient(180deg, #fff 0%, #fef2f2 100%);
}

.home-ride-chip--cancelled .home-ride-chip-count { color: #dc2626; }

.home-ride-chip--captain {
  border-color: rgba(234, 88, 12, 0.28);
  background: linear-gradient(180deg, #fff 0%, #fff7ed 100%);
}

.home-ride-chip--captain .home-ride-chip-count { color: #ea580c; }

.home-summary-block {
  display: flex;
  flex-direction: column;
  gap: 7px;
  width: 100%;
  min-width: 0;
}

.home-summary-live-foot {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 0 0 1px;
  min-width: 0;
}

.home-summary-live-foot--activity {
  padding-inline-start: 2px;
}

.home-summary-live-foot--rides {
  padding-inline-start: 2px;
}

.home-summary-live-line {
  flex: 0 0 52px;
  height: 3px;
  border-radius: 999px;
  overflow: hidden;
  background: #ecfdf5;
}

.home-summary-live-foot--activity .home-summary-live-line {
  background: rgba(251, 191, 36, 0.14);
}

.home-summary-live-line-fill {
  display: block;
  width: 46%;
  height: 100%;
  border-radius: inherit;
  animation: homeSummaryLiveFlow 2.5s ease-in-out infinite;
}

.home-summary-live-foot--rides .home-summary-live-line-fill {
  background: linear-gradient(90deg, rgba(22, 163, 74, 0.12) 0%, #16a34a 50%, rgba(22, 163, 74, 0.12) 100%);
  box-shadow: 0 0 8px rgba(22, 163, 74, 0.28);
}

.home-summary-live-foot--activity .home-summary-live-line-fill {
  background: linear-gradient(90deg, rgba(251, 191, 36, 0.14) 0%, #fbbf24 50%, rgba(251, 191, 36, 0.14) 100%);
  box-shadow: 0 0 8px rgba(251, 191, 36, 0.28);
}

@keyframes homeSummaryLiveFlow {
  0% { transform: translateX(175%); }
  100% { transform: translateX(-175%); }
}

.home-summary-live-caption {
  flex: 1;
  min-width: 0;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.35;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
}

.home-summary-live-foot--rides .home-summary-live-caption {
  color: #15803d;
}

.home-summary-live-foot--activity .home-summary-live-caption {
  color: #b45309;
}

@media (prefers-reduced-motion: reduce) {
  .home-summary-live-line-fill {
    animation: none;
    width: 62%;
    margin: 0 auto;
    transform: none;
    opacity: 0.85;
  }
}

.dash-panel-home-activity .dash-panel-body,
.dash-panel-home-rides .dash-panel-body {
  background: transparent;
  padding: 0;
  min-height: 0;
  border-top: none;
}

.dash-panel-home-activity .dash-panel-head,
.dash-panel-home-rides .dash-panel-head {
  border-bottom: none !important;
  background: transparent;
}

.home-page .dash-panel-home-activity,
.home-page .dash-panel-home-rides {
  gap: 0;
}

/* ── Home activity/rides cards — sidebar tone, chips keep status colors ── */
.home-page .dash-panel-home-activity,
.home-page .dash-panel-home-rides {
  background: var(--dash-sidebar-bg);
  border-color: var(--dash-sidebar-border);
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.2),
    0 8px 24px rgba(15, 23, 42, 0.16);
}

.dash-panel-home-activity .home-panel-live-foot,
.dash-panel-home-rides .home-panel-live-foot {
  background: transparent;
}

.dash-panel-home-activity .home-see-all,
.dash-panel-home-rides .home-see-all {
  color: #93c5fd;
  background: rgba(59, 130, 246, 0.14);
  border-color: rgba(59, 130, 246, 0.24);
}

.home-summary-live-foot--activity .home-summary-live-caption {
  color: #fcd34d;
}

.home-summary-live-foot--rides .home-summary-live-caption {
  color: #86efac;
}

[data-theme="light"] .home-page .dash-panel-home-activity,
[data-theme="light"] .home-page .dash-panel-home-rides {
  box-shadow:
    0 1px 2px rgba(15, 23, 42, 0.04),
    0 6px 20px rgba(15, 23, 42, 0.04);
}

[data-theme="light"] .home-panel-head-row--activity:hover,
[data-theme="light"] .home-panel-head-row--rides:hover {
  background: rgba(15, 23, 42, 0.03);
}

[data-theme="light"] .home-panel-head-chips {
  border-inline-start-color: var(--dash-line);
}

[data-theme="light"] .home-panel-title-btn h3 {
  color: var(--dash-ink);
}

[data-theme="light"] .dash-panel-home-activity .home-see-all,
[data-theme="light"] .dash-panel-home-rides .home-see-all {
  color: var(--dash-primary);
  background: rgba(29, 78, 216, 0.08);
  border-color: rgba(29, 78, 216, 0.12);
}

[data-theme="light"] .home-summary-live-foot--activity .home-summary-live-caption {
  color: #b45309;
}

[data-theme="light"] .home-summary-live-foot--rides .home-summary-live-caption {
  color: #15803d;
}

/* legacy card styles — kept for modal/other */
.home-ride-card {
  flex: 0 0 168px;
  width: 168px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px 12px 11px;
  border-radius: 12px;
  border: 1px solid var(--dash-line);
  background: #f8fafc;
  text-align: right;
  cursor: pointer;
  transition: border-color var(--dash-transition), box-shadow var(--dash-transition), background var(--dash-transition);
}

.home-ride-card:hover {
  background: #fff;
  border-color: rgba(29, 78, 216, 0.22);
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
}

.home-ride-card--active {
  border-color: rgba(22, 163, 74, 0.35);
  background: #f0fdf4;
}

.home-ride-card--searching {
  border-color: rgba(217, 119, 6, 0.35);
  background: #fffbeb;
}

.home-ride-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}

.home-ride-card-top .dash-badge {
  font-size: 9px;
  padding: 2px 6px;
}

.home-ride-card-id {
  font-size: 12px;
  font-weight: 900;
  color: var(--dash-ink);
}

.home-ride-card-route {
  font-size: 11px;
  font-weight: 700;
  line-height: 1.45;
  color: var(--dash-ink-soft);
  min-height: 32px;
}

.home-ride-card-meta {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  font-size: 10px;
  font-weight: 700;
  color: var(--dash-muted);
}

.home-ride-card-meta strong {
  font-size: 12px;
  font-weight: 900;
  color: var(--dash-ink);
}

.home-activity-card {
  flex: 0 0 190px;
  width: 190px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  padding: 12px 12px 11px;
  border-radius: 12px;
  border: 1px solid var(--dash-line);
  background: #f8fafc;
  text-align: right;
  cursor: pointer;
  transition: border-color var(--dash-transition), box-shadow var(--dash-transition), background var(--dash-transition);
}

.home-activity-card:hover {
  background: #fff;
  border-color: rgba(29, 78, 216, 0.22);
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
}

.home-activity-card .activity-dot {
  margin-top: 0;
}

.home-activity-card strong {
  font-size: 12px;
  font-weight: 900;
  color: var(--dash-ink);
  line-height: 1.3;
}

.home-activity-card-text {
  font-size: 11px;
  font-weight: 700;
  line-height: 1.45;
  color: var(--dash-ink-soft);
  min-height: 32px;
}

.home-activity-card-time {
  font-size: 10px;
  font-weight: 700;
  color: var(--dash-muted);
}

.dash-modal-panel--list {
  width: min(920px, 100%);
  max-height: min(88vh, 900px);
  padding: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.home-list-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--dash-line);
  background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}

.home-list-modal-head h3 {
  margin: 0;
  font-size: 16px;
  font-weight: 900;
}

.home-list-modal-close {
  width: 36px;
  height: 36px;
  border: 1px solid var(--dash-line);
  border-radius: 10px;
  background: #fff;
  color: var(--dash-muted);
  cursor: pointer;
  display: grid;
  place-items: center;
}

.home-list-modal-body {
  overflow: auto;
  padding: 0;
  min-height: 0;
}

.home-list-modal-body .dash-table-wrap {
  border-radius: 0;
}

.activity-feed--modal {
  gap: 0;
}

.dash-grid-home-top .activity-feed {
  flex: 1;
}

.dash-grid-home-top .activity-item {
  padding: 11px 14px;
  gap: 10px;
}

.dash-grid-home-top .activity-body strong {
  font-size: 12px;
}

.dash-grid-home-top .activity-body span,
.dash-grid-home-top .activity-time {
  font-size: 10px;
}

.dash-grid-home-top .dash-table th {
  padding: 10px 12px;
  font-size: 11px;
}

.dash-grid-home-top .dash-table td {
  padding: 10px 12px;
  font-size: 12px;
}

.dash-table--home-rides th {
  font-size: 12px;
  font-weight: 800;
}

.home-ride-place {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  max-width: 100%;
}

.home-ride-pin {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  flex-shrink: 0;
}

.home-ride-place--from .home-ride-pin {
  background: var(--dash-green);
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.95), 0 0 8px rgba(22, 163, 74, 0.35);
}

.home-ride-place--to .home-ride-pin {
  background: var(--dash-gold);
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.95), 0 0 8px rgba(201, 162, 39, 0.35);
}

.home-ride-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-table--home-rides .home-ride-from,
.dash-table--home-rides .home-ride-to {
  max-width: 0;
}

.dash-table--home-rides .home-ride-time {
  white-space: nowrap;
  text-align: end;
}

.dash-table--home-rides .home-ride-time strong {
  display: block;
  font-size: 13px;
  font-weight: 800;
}

.dash-table--home-rides .home-ride-time-rel {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  font-weight: 600;
  color: var(--dash-muted);
}

.dash-home-ride-row {
  cursor: pointer;
}

.dash-home-ride-row:hover td {
  background: rgba(23, 105, 255, 0.04);
}

.dash-grid-home-top .dash-table-wrap {
  max-height: none;
}

.dash-grid-home-bottom {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 24px;
  margin-bottom: 24px;
}

.dash-panel {
  background: var(--dash-surface);
  border-radius: var(--dash-radius);
  border: 1px solid var(--dash-line);
  box-shadow: var(--dash-shadow);
  overflow: hidden;
}

.dash-panel:hover { box-shadow: var(--dash-shadow-hover); }

.dash-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--dash-line);
  background: #fff;
}

.dash-panel-head h3 {
  margin: 0;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--dash-ink);
}

.dash-panel-body { padding: 20px 24px 24px; }
.dash-panel-body.flush { padding: 0; }

/* ── Map ── */
.dash-map {
  position: relative;
  z-index: 0;
  isolation: isolate;
  height: 480px;
  width: 100%;
  background: var(--dash-bg-subtle);
}

.admin-map-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid #fff;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.25);
  cursor: pointer;
}

.admin-map-dot--ride {
  background: var(--dash-green);
}

.admin-map-dot--captain {
  background: #1769ff;
}

.dash-map-legend {
  display: flex;
  gap: 20px;
  padding: 12px 24px;
  font-size: 12px;
  font-weight: 800;
  color: var(--dash-muted);
  border-top: 1px solid var(--dash-line);
}

.dash-map-legend span::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-left: 8px;
  vertical-align: middle;
}

.dash-map-legend .ride::before { background: var(--dash-green); }
.dash-map-legend .captain::before { background: var(--dash-primary); }

.dash-map-updated {
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-muted);
}

/* ── Activity & alerts ── */
.activity-feed,
.alert-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.activity-item,
.alert-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--dash-line);
  transition: background var(--dash-transition);
  border: 0;
  background: none;
  width: 100%;
  cursor: pointer;
  text-align: right;
  font: inherit;
}

.alert-item:hover { background: #fff; }

.activity-item:last-child,
.alert-item:last-child { border-bottom: 0; }

.activity-item:hover { background: var(--dash-bg-subtle); }

.activity-dot,
.alert-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-top: 6px;
  flex-shrink: 0;
  background: var(--dash-line-strong);
}

.activity-dot.ride { background: var(--dash-green); }
.activity-dot.captain { background: var(--dash-gold); }
.activity-dot.system { background: var(--dash-ink); }

.alert-list .alert-item { background: var(--dash-bg-subtle); }
.alert-dot.warn { background: var(--dash-amber); }
.alert-dot.info { background: var(--dash-gold); }
.alert-dot.ok { background: var(--dash-green); }

.dash-grid-home-bottom--2 {
  grid-template-columns: 1fr 1fr;
}

.alert-rail-btn {
  display: grid;
  place-items: center;
  width: 56px;
  height: 48px;
  padding: 0;
  border: 1px solid transparent;
  border-radius: 14px;
  background: transparent;
  color: #94a3b8;
  cursor: pointer;
  transition:
    background 0.22s var(--dash-ease),
    border-color 0.22s var(--dash-ease),
    box-shadow 0.22s var(--dash-ease),
    color 0.22s var(--dash-ease),
    transform 0.15s ease;
}

.alert-rail-icon .fi {
  font-size: 21px;
  line-height: 1;
  transition: filter 0.22s var(--dash-ease), color 0.22s var(--dash-ease);
}

.alert-rail-btn:hover {
  background: rgba(186, 230, 253, 0.07);
  border-color: rgba(186, 230, 253, 0.16);
  color: #e0f2fe;
  box-shadow:
    0 0 18px rgba(125, 211, 252, 0.14),
    inset 0 0 14px rgba(186, 230, 253, 0.05);
}

.alert-rail-btn:hover .alert-rail-icon .fi {
  color: #f0f9ff;
  filter: drop-shadow(0 0 5px rgba(224, 242, 254, 0.75)) drop-shadow(0 0 12px rgba(125, 211, 252, 0.45));
}

.alert-rail-btn.on {
  background: linear-gradient(145deg, rgba(224, 242, 254, 0.2) 0%, rgba(125, 211, 252, 0.1) 55%, rgba(56, 189, 248, 0.06) 100%);
  border-color: rgba(186, 230, 253, 0.38);
  color: #f0f9ff;
  box-shadow:
    0 0 22px rgba(125, 211, 252, 0.38),
    0 0 44px rgba(56, 189, 248, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.alert-rail-btn.on .alert-rail-icon .fi {
  color: #fff;
  filter: drop-shadow(0 0 7px rgba(255, 255, 255, 0.95)) drop-shadow(0 0 16px rgba(186, 230, 253, 0.75));
}

.alert-rail-btn.warn.on .alert-rail-icon .fi { color: #fde68a; }
.alert-rail-btn.info.on .alert-rail-icon .fi { color: #fef3c7; }
.alert-rail-btn.ok.on .alert-rail-icon .fi { color: #bbf7d0; }

.activity-body,
.alert-body { flex: 1; min-width: 0; }

.activity-body strong,
.alert-body strong {
  display: block;
  font-size: 13px;
  font-weight: 800;
  margin-bottom: 2px;
}

.activity-body span,
.alert-body span {
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-muted);
}

.activity-time {
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-muted);
  white-space: nowrap;
}

/* ── Filters ── */
.dash-filters,
.cap-toolbar,
.ride-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--dash-line);
  background: #fff;
}

.dash-filter-input,
.dash-filter-select {
  padding: 10px 14px;
  border: 1px solid var(--dash-line);
  border-radius: var(--dash-radius-md);
  font-weight: 600;
  font-size: 13px;
  background: #fff;
  min-width: 160px;
  transition: border-color var(--dash-transition), box-shadow var(--dash-transition);
}

.dash-filter-input:focus,
.dash-filter-select:focus {
  outline: none;
  border-color: var(--dash-primary);
  box-shadow: 0 0 0 3px var(--dash-primary-ring);
}

.cap-search,
.ride-search {
  flex: 1 1 260px;
  max-width: 360px;
  margin: 0;
}

.cap-filters,
.ride-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.cap-filter,
.ride-filter {
  padding: 8px 14px;
  border-radius: var(--dash-radius-md);
  border: 1px solid var(--dash-line);
  background: #fff;
  font-size: 12px;
  font-weight: 700;
  color: var(--dash-muted);
  transition: all var(--dash-transition);
}

.cap-filter:hover,
.ride-filter:hover {
  border-color: var(--dash-line-strong);
  color: var(--dash-ink);
}

.cap-filter.on,
.ride-filter.on {
  background: var(--dash-primary);
  border-color: var(--dash-primary);
  color: #fff;
}

/* ── Tables ── */
.dash-table-wrap {
  overflow-x: auto;
  max-height: 640px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.dash-table-click {
  cursor: pointer;
  transition: background var(--dash-transition);
}

.dash-table-click:hover,
.dash-table-click:focus-visible {
  background: var(--dash-bg-subtle);
  outline: none;
}

.settings-activity-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--dash-line);
  font-size: 12px;
  font-weight: 700;
  color: var(--dash-ink-soft);
}

.settings-activity-item:last-child {
  border-bottom: 0;
}

.settings-activity-item time {
  flex-shrink: 0;
  font-size: 11px;
  color: var(--dash-muted);
}

.dash-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.dash-table th {
  position: sticky;
  top: 0;
  background: #f8fafc;
  text-align: right;
  padding: 12px 18px;
  font-weight: 700;
  font-size: 12px;
  color: var(--dash-muted);
  border-bottom: 1px solid var(--dash-line);
  white-space: nowrap;
}

.dash-table td {
  padding: 14px 18px;
  border-bottom: 1px solid var(--dash-line);
  font-weight: 600;
  vertical-align: middle;
  background: #fff;
}

.dash-table tbody tr {
  transition: background var(--dash-transition);
}

.dash-table tbody tr:hover td { background: var(--dash-bg-subtle); }

.dash-table .mono {
  font-family: ui-monospace, monospace;
  font-size: 12px;
  direction: ltr;
  text-align: left;
}

.dash-table-empty {
  text-align: center;
  padding: 56px 20px;
  color: var(--dash-muted);
  font-weight: 800;
  font-size: 14px;
}

/* ── Badges ── */
.dash-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
}

.dash-badge.pending { background: var(--dash-amber-bg); color: var(--dash-amber-text); }
.dash-badge.approved, .dash-badge.completed { background: var(--dash-green-bg); color: var(--dash-green-text); }
.dash-badge.rejected, .dash-badge.cancelled, .dash-badge.expired { background: var(--dash-red-bg); color: var(--dash-red-text); }
.dash-badge.searching, .dash-badge.matched, .dash-badge.arriving, .dash-badge.active { background: var(--dash-amber-bg); color: var(--dash-amber-text); }
.dash-badge.trial { background: var(--dash-green-bg); color: var(--dash-green-text); }
.dash-badge.paid { background: #eff6ff; color: #1d4ed8; }
.dash-badge.off { background: var(--dash-bg-subtle); color: var(--dash-muted); }
.dash-badge.suspended { background: var(--dash-amber-bg); color: var(--dash-amber-text); }
.dash-badge.online-live { background: var(--dash-green-bg); color: var(--dash-green-text); }
.dash-badge.offline-live { background: var(--dash-bg-subtle); color: var(--dash-muted); }

/* ── Forms ── */
.dash-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.dash-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dash-field.full { grid-column: 1 / -1; }

.dash-field label {
  font-size: 12px;
  font-weight: 800;
  color: var(--dash-muted);
}

.dash-field input,
.dash-field select,
.dash-field textarea {
  padding: 12px 14px;
  border: 1px solid var(--dash-line-strong);
  border-radius: var(--dash-radius-sm);
  font-weight: 700;
  background: #fff;
  transition: border-color var(--dash-transition), box-shadow var(--dash-transition);
}

.dash-field input:focus,
.dash-field select:focus,
.dash-field textarea:focus {
  outline: none;
  border-color: var(--dash-primary);
  box-shadow: 0 0 0 3px var(--dash-primary-ring);
}

.dash-field textarea { min-height: 96px; resize: vertical; }

.dash-form-actions {
  display: flex;
  gap: 10px;
  margin-top: 16px;
}

/* ── Reports ── */
.dash-bars { display: flex; flex-direction: column; gap: 14px; }

.dash-bar-row {
  display: grid;
  grid-template-columns: 110px 1fr 52px;
  align-items: center;
  gap: 14px;
  font-size: 12px;
  font-weight: 800;
}

.dash-bar-track {
  height: 8px;
  background: var(--dash-bg-subtle);
  border-radius: 999px;
  overflow: hidden;
}

.dash-bar-fill {
  height: 100%;
  background: var(--dash-ink);
  border-radius: 999px;
  min-width: 4px;
  transition: width 0.6s var(--dash-ease);
}

.dash-bar-fill.green { background: var(--dash-green); }
.dash-bar-fill.gold { background: var(--dash-gold); }
.dash-bar-fill.amber { background: var(--dash-amber); }

.report-chart-bars {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  height: 180px;
  padding-top: 12px;
}

.report-chart-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.report-chart-bar {
  width: 100%;
  max-width: 48px;
  border-radius: 8px 8px 4px 4px;
  background: linear-gradient(180deg, var(--dash-gold) 0%, var(--dash-gold-dark) 100%);
  min-height: 4px;
  transition: height 0.6s var(--dash-ease);
}

.report-chart-col span {
  font-size: 10px;
  font-weight: 800;
  color: var(--dash-muted);
  text-align: center;
}

.report-chart-col strong {
  font-size: 11px;
  font-weight: 900;
  color: var(--dash-ink);
}

/* ── Reports — single card ── */
.report-page {
  display: flex;
  flex-direction: column;
  gap: var(--dash-gap);
}

.report-card .dash-panel-body {
  padding: 0;
}

.report-card-body {
  display: flex;
  flex-direction: column;
}

.report-grid-top {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border-bottom: 1px solid var(--dash-line);
}

.report-section {
  padding: 16px 18px;
}

.report-grid-top .report-section + .report-section {
  border-inline-start: 1px solid var(--dash-line);
}

.report-section-title {
  margin: 0 0 12px;
  font-size: 13px;
  font-weight: 900;
  color: var(--dash-ink);
}

.report-section--users {
  padding-bottom: 18px;
}

.report-users-row {
  display: flex;
  flex-wrap: nowrap;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 2px;
  scrollbar-width: thin;
}

.report-user-card {
  flex: 1 1 0;
  min-width: 148px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--dash-line);
  background: #f8fafc;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.report-user-rank {
  font-size: 11px;
  font-weight: 900;
  color: var(--dash-gold-dark);
}

.report-user-phone {
  font-size: 13px;
  font-weight: 900;
  color: var(--dash-ink);
  direction: ltr;
  text-align: start;
}

.report-user-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-muted);
}

.report-user-meta b {
  font-weight: 900;
  color: var(--dash-ink);
}

.report-section--users .dash-table-empty {
  padding: 4px 0 8px;
}

/* ── Modal ── */
.dash-modal {
  position: fixed;
  inset: 0;
  z-index: 400;
  background: rgba(10, 10, 11, 0.4);
  backdrop-filter: blur(4px);
  display: grid;
  place-items: center;
  padding: 24px;
  animation: dashFadeIn 0.2s var(--dash-ease);
}

.dash-modal[hidden] { display: none !important; }

@keyframes dashFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.dash-modal-panel {
  width: min(460px, 100%);
  background: var(--dash-surface);
  border-radius: var(--dash-radius);
  padding: 28px;
  border: 1px solid var(--dash-line);
  box-shadow: var(--dash-shadow-hover);
  animation: dashSlideUp 0.25s var(--dash-ease);
}

@keyframes dashSlideUp {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

.dash-modal-panel h3 {
  margin: 0 0 18px;
  font-size: 18px;
  font-weight: 900;
}

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

.dash-file-link {
  color: var(--dash-gold-dark);
  font-weight: 800;
  font-size: 12px;
}

.dash-loading {
  text-align: center;
  padding: 48px;
  color: var(--dash-muted);
  font-weight: 800;
}

.dash-server-info {
  display: grid;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
}

.dash-server-info dt { color: var(--dash-muted); font-weight: 800; }
.dash-server-info dd { margin: 0 0 8px; }

/* ── Captains ── */
.cap-page, .ride-page, .price-page, .ann-page { display: flex; flex-direction: column; gap: 24px; }

body[data-admin-view="rides"] .dash-content,
body[data-admin-view="captains"] .dash-content {
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - var(--dash-topbar-total-h, var(--dash-topbar-h)));
  overflow: hidden;
  padding-bottom: 0;
}

body[data-admin-view="rides"] .dash-content-inner,
body[data-admin-view="captains"] .dash-content-inner {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  padding-bottom: 0;
}

body[data-admin-view="rides"] .dash-view:not([hidden]),
body[data-admin-view="captains"] .dash-view:not([hidden]) {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

body[data-admin-view="rides"] .ride-page,
body[data-admin-view="captains"] .cap-page {
  flex: 1;
  min-height: 0;
  gap: 0;
}

body[data-admin-view="rides"] .ride-panel,
body[data-admin-view="captains"] .cap-panel {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  border-radius: var(--dash-radius);
}

body[data-admin-view="rides"] .ride-panel .dash-panel-body.flush,
body[data-admin-view="captains"] .cap-panel .dash-panel-body.flush,
#ridesTableWrap,
#captainsTableWrap {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

body[data-admin-view="home"] .dash-content-inner {
  display: flex;
  flex-direction: column;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

body[data-admin-view="home"] #view-home {
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

body[data-admin-view="home"] .home-page {
  flex: 1;
  min-height: 0;
}

.cap-stats, .ride-stats, .price-stats, .ann-stats { margin-bottom: 0 !important; }

.cap-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
  padding: 24px;
}

.cap-card {
  background: #fff;
  border: 1px solid var(--dash-line);
  border-radius: var(--dash-radius);
  padding: 20px;
  cursor: pointer;
  transition: transform var(--dash-transition), box-shadow var(--dash-transition), border-color var(--dash-transition);
}

.cap-card:hover {
  transform: none;
  box-shadow: var(--dash-shadow-hover);
  border-color: var(--dash-primary-ring);
}

.cap-card-head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 16px;
}

.cap-card-head strong {
  display: block;
  font-size: 15px;
  font-weight: 900;
}

.cap-card-head small {
  display: block;
  font-size: 11px;
  color: var(--dash-muted);
  font-weight: 700;
  margin-top: 2px;
}

.cap-card-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 14px;
}

.cap-card-meta div {
  padding: 10px 12px;
  border-radius: var(--dash-radius-sm);
  background: var(--dash-bg-subtle);
  font-size: 11px;
  font-weight: 800;
  color: var(--dash-muted);
}

.cap-card-meta div b {
  display: block;
  font-size: 14px;
  color: var(--dash-ink);
  margin-top: 2px;
}

.cap-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding-top: 14px;
  border-top: 1px solid var(--dash-line);
}

.cap-avatar {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  object-fit: cover;
  display: block;
  background: var(--dash-bg-subtle);
  border: 1px solid var(--dash-line);
}

.cap-avatar--ph {
  display: grid;
  place-items: center;
  font-size: 18px;
  font-weight: 900;
  color: var(--dash-ink);
  background: var(--dash-gold-light);
}

.cap-avatar--lg {
  width: 88px;
  height: 88px;
  border-radius: 22px;
  font-size: 32px;
}

.cap-dot {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 800;
}

.cap-dot::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #a1a1aa;
}

.cap-dot.on::before {
  background: var(--dash-green);
  box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.2);
}

/* Captain detail drawer */
.cap-detail, .ride-detail {
  position: fixed;
  inset: 0;
  z-index: 300;
  display: grid;
  direction: rtl;
  animation: dashFadeIn 0.2s var(--dash-ease);
}

.cap-detail {
  display: block;
}

.cap-detail[hidden], .ride-detail[hidden] { display: none !important; }

.cap-detail-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 10, 11, 0.28);
  backdrop-filter: blur(3px);
}

.ride-detail-backdrop {
  grid-column: 2;
  background: rgba(10, 10, 11, 0.35);
  backdrop-filter: blur(4px);
}

.cap-detail-panel {
  position: absolute;
  top: max(14px, env(safe-area-inset-top, 0px));
  left: 14px;
  right: auto;
  width: min(420px, calc(100vw - var(--dash-sidebar-w) - 36px));
  max-height: min(92vh, 860px);
  grid-column: unset;
  border-radius: 16px;
  border: 1px solid var(--dash-line);
  box-shadow:
    0 2px 8px rgba(10, 10, 11, 0.05),
    0 16px 40px rgba(10, 10, 11, 0.14);
  animation: capDetailCardIn 0.22s cubic-bezier(0.22, 1, 0.36, 1) both;
  background: var(--dash-surface);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

@keyframes capDetailCardIn {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.97);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.ride-detail {
  grid-template-columns: min(380px, 92vw) 1fr;
}

.ride-detail-panel {
  grid-column: 1;
  background: var(--dash-surface);
  border-inline-start: 1px solid var(--dash-line);
  box-shadow: -16px 0 64px rgba(10, 10, 11, 0.1);
  display: flex;
  flex-direction: column;
  max-height: 100vh;
  overflow: hidden;
}

.cap-detail-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--dash-line);
  background: #fff;
  flex-shrink: 0;
  border-radius: 16px 16px 0 0;
}

.cap-detail-head-label {
  flex: 1;
  font-size: 13px;
  font-weight: 900;
  color: var(--dash-ink);
}

.cap-detail-save {
  width: 32px;
  height: 32px;
  border-radius: 9px;
  background: var(--dash-bg-subtle);
  color: var(--dash-primary);
  display: grid;
  place-items: center;
  transition: background var(--dash-transition), color var(--dash-transition);
}

.cap-detail-save:hover {
  background: rgba(29, 78, 216, 0.1);
  color: var(--dash-primary);
}

.cap-detail-save .fi {
  font-size: 15px;
}

.ride-detail-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--dash-line);
  background: #fff;
}

.cap-detail-head h2, .ride-detail-head h2 {
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  flex: 1;
}

.cap-detail-close {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: var(--dash-bg-subtle);
  font-size: 14px;
  line-height: 1;
  color: var(--dash-muted);
  display: grid;
  place-items: center;
  transition: background var(--dash-transition), color var(--dash-transition);
}

.ride-detail-close {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: var(--dash-bg-subtle);
  font-size: 22px;
  line-height: 1;
  color: var(--dash-muted);
  transition: background var(--dash-transition);
}

.cap-detail-close:hover, .ride-detail-close:hover { background: var(--dash-line); }

.cap-detail-body {
  flex: 1;
  overflow-y: auto;
  padding: 14px 16px 16px;
  overscroll-behavior: contain;
}

.ride-detail-body {
  flex: 1;
  overflow-y: auto;
  padding: 14px;
}

.cap-detail-sheet {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.cap-dossier-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 0 14px;
  margin-bottom: 2px;
  border-bottom: 2px solid var(--dash-line);
}

.cap-dossier-logo {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  font-size: 18px;
  font-weight: 900;
  color: #fff;
  background: linear-gradient(145deg, #1d4ed8 0%, #19a974 100%);
  box-shadow: 0 4px 14px rgba(29, 78, 216, 0.22);
  flex-shrink: 0;
}

.cap-dossier-brand-text strong {
  display: block;
  font-size: 14px;
  font-weight: 900;
  color: var(--dash-ink);
  line-height: 1.3;
}

.cap-dossier-brand-text small {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-muted);
}

.cap-dossier-foot {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: 14px;
  padding: 10px 12px;
  border-radius: 10px;
  background: var(--dash-bg-subtle);
  border: 1px solid var(--dash-line);
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-muted);
}

.cap-dossier-foot strong {
  color: var(--dash-ink);
  font-weight: 800;
}

.cap-detail-actions--admin {
  margin-top: 12px;
}

.cap-detail-hero {
  display: flex;
  gap: 12px;
  align-items: center;
  padding: 14px 0 12px;
  margin-bottom: 0;
  border-bottom: 1px solid var(--dash-line);
  background: none;
  border-radius: 0;
  border-top: 0;
  border-left: 0;
  border-right: 0;
}

.cap-detail-list {
  display: flex;
  flex-direction: column;
}

.cap-detail-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 9px 0;
  border-bottom: 1px solid var(--dash-line);
  font-size: 13px;
  text-decoration: none;
  color: inherit;
}

.cap-detail-row:last-child {
  border-bottom: 0;
}

.cap-detail-row span {
  color: var(--dash-muted);
  font-weight: 700;
  font-size: 12px;
  flex-shrink: 0;
  min-width: 88px;
}

.cap-detail-row strong {
  font-weight: 800;
  color: var(--dash-ink);
  text-align: end;
  min-width: 0;
  line-height: 1.45;
  word-break: break-word;
}

.cap-detail-row--link:hover strong {
  color: var(--dash-primary);
}

.cap-detail-section-title {
  margin: 14px 0 0;
  padding: 0 0 6px;
  font-size: 11px;
  font-weight: 900;
  color: var(--dash-muted);
  letter-spacing: 0.02em;
  border-bottom: 1px solid var(--dash-line);
}

.cap-detail-list--docs .cap-detail-row:last-child {
  border-bottom: 0;
}

.cap-avatar--md {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  font-size: 20px;
  flex-shrink: 0;
}

.cap-detail-hero-text {
  min-width: 0;
  flex: 1;
}

.cap-detail-hero h3 {
  margin: 0 0 2px;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cap-detail-phone {
  margin: 0 0 6px;
  font-size: 12px;
  font-weight: 700;
  color: var(--dash-muted);
}

.cap-detail-tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px;
}

.cap-detail-metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.cap-detail-metric {
  padding: 8px 10px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid var(--dash-line);
}

.cap-detail-metric span {
  display: block;
  font-size: 10px;
  font-weight: 800;
  color: var(--dash-muted);
  margin-bottom: 2px;
}

.cap-detail-metric strong {
  display: block;
  font-size: 13px;
  font-weight: 900;
  color: var(--dash-ink);
  line-height: 1.25;
}

.cap-detail-metric-time {
  font-size: 11px !important;
  font-weight: 700 !important;
}

.cap-detail-block {
  margin: 0;
}

.cap-detail-block h4 {
  margin: 0 0 8px;
  font-size: 11px;
  font-weight: 900;
  color: var(--dash-muted);
  letter-spacing: 0.02em;
}

.cap-detail-block--meta p {
  margin: 0;
  padding: 8px 10px;
  border-radius: 10px;
  background: var(--dash-bg-subtle);
  border: 1px solid var(--dash-line);
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-muted);
  line-height: 1.45;
}

.cap-doc-grid--dossier {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 10px;
}

.cap-doc-grid--dossier .cap-doc {
  border-radius: 12px;
}

.cap-doc-grid--dossier .cap-doc span {
  padding: 8px 6px;
  font-size: 10px;
}

.cap-doc-grid--dossier .cap-doc img {
  aspect-ratio: 4 / 3;
}

.cap-doc-grid--compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  margin-top: 8px;
}

.cap-doc-grid--compact .cap-doc span {
  padding: 4px 2px;
  font-size: 9px;
}

.cap-doc-grid--compact .cap-doc img {
  aspect-ratio: 1;
}

.cap-doc-grid--compact .cap-doc {
  border-radius: 10px;
}

.cap-detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  padding-top: 10px;
  margin-top: 10px;
  border-top: 1px solid var(--dash-line);
  background: var(--dash-surface);
}

.dash-btn--sm {
  padding: 7px 10px;
  font-size: 11px;
  border-radius: 8px;
}

.cap-detail-hero p {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  color: var(--dash-muted);
}

.cap-detail-grid, .ride-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 20px;
}

.cap-detail-stat, .ride-detail-stat {
  padding: 14px 16px;
  border-radius: var(--dash-radius-md);
  background: var(--dash-bg-subtle);
  border: 1px solid var(--dash-line);
}

.cap-detail-stat span, .ride-detail-stat span {
  display: block;
  font-size: 11px;
  font-weight: 800;
  color: var(--dash-muted);
  margin-bottom: 4px;
}

.cap-detail-stat strong, .ride-detail-stat strong {
  font-size: 17px;
  font-weight: 900;
}

.cap-detail-section { margin-bottom: 22px; }

.cap-detail-section h4 {
  margin: 0 0 12px;
  font-size: 13px;
  font-weight: 900;
  color: var(--dash-muted);
}

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

.cap-doc {
  border-radius: var(--dash-radius-md);
  overflow: hidden;
  border: 1px solid var(--dash-line);
  background: #fff;
  transition: transform var(--dash-transition), box-shadow var(--dash-transition);
}

.cap-doc:hover {
  transform: translateY(-2px);
  box-shadow: var(--dash-shadow);
}

.cap-doc img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  display: block;
}

.cap-doc span {
  display: block;
  padding: 10px;
  font-size: 11px;
  font-weight: 800;
  text-align: center;
  color: var(--dash-muted);
}

.cap-cell-name {
  display: flex;
  align-items: center;
  gap: 12px;
}

.cap-cell-name strong { display: block; font-size: 14px; }
.cap-cell-name small { display: block; font-size: 11px; color: var(--dash-muted); font-weight: 700; margin-top: 2px; }

/* ── Rides ── */
.ride-id {
  font-family: ui-monospace, monospace;
  font-size: 12px;
  font-weight: 900;
  color: var(--dash-ink);
  letter-spacing: 0.04em;
}

.ride-route { max-width: 100%; }
.ride-route strong { display: block; font-size: 13px; font-weight: 800; line-height: 1.35; }
.ride-route-arrow { color: var(--dash-green); font-weight: 900; margin: 0 4px; direction: ltr; unicode-bidi: isolate; display: inline-block; }

.ride-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  flex: 1;
  min-height: 0;
  height: 100%;
  background: #fff;
}

.ride-split-col {
  display: flex;
  flex-direction: column;
  min-width: 0;
  border-inline-start: 1px solid var(--dash-line);
}

.ride-split-col:first-child { border-inline-start: 0; }

.ride-split-col--car {
  --ride-col-accent: rgba(22, 163, 74, 0.55);
  --ride-col-tint: rgba(22, 163, 74, 0.04);
  --ride-col-tint-hover: rgba(22, 163, 74, 0.07);
  --ride-col-border: rgba(22, 163, 74, 0.12);
}

.ride-split-col--tuk {
  --ride-col-accent: rgba(180, 130, 20, 0.55);
  --ride-col-tint: rgba(180, 130, 20, 0.04);
  --ride-col-tint-hover: rgba(180, 130, 20, 0.07);
  --ride-col-border: rgba(180, 130, 20, 0.12);
}

.ride-split-head {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--dash-line);
  background: #fff;
  box-shadow: inset 0 2px 0 var(--ride-col-accent);
}

.ride-split-title {
  display: flex;
  align-items: center;
  gap: 12px;
}

.ride-split-title strong {
  display: block;
  font-size: 15px;
  font-weight: 900;
  color: var(--dash-ink);
}

.ride-split-title small {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-muted);
}

.ride-split-icon {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  font-size: 20px;
  background: var(--ride-col-tint);
  border: 1px solid var(--ride-col-border);
}

.ride-split-list,
.cap-split-list,
.dash-content {
  overscroll-behavior: contain;
}

.ride-split-list {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: var(--ride-col-tint);
}

.ride-split-list--table {
  padding: 0;
  gap: 0;
  background: #fff;
}

.ride-split-list--table .ride-table-wrap {
  border: 0;
  border-radius: 0;
}

.ride-split-list--table .dash-table--rides thead {
  position: sticky;
  top: 0;
  z-index: 1;
  background: #fff;
}

.ride-split-list--table .dash-table--rides th {
  background: #fff;
  border-bottom: 1px solid var(--dash-line);
}

.dash-ride-row--active td {
  background: rgba(22, 163, 74, 0.05);
}

.dash-ride-row--searching td {
  background: rgba(245, 158, 11, 0.06);
}

.dash-ride-row--active:hover td,
.dash-ride-row--searching:hover td {
  background: rgba(23, 105, 255, 0.06);
}

.ride-split-empty,
.ride-split-empty-page,
.cap-split-empty,
.cap-split-empty-page {
  padding: 28px 16px;
  text-align: center;
  font-size: 13px;
  font-weight: 800;
  color: var(--dash-muted);
}

#ridesTableWrap > .ride-split-empty-page,
#captainsTableWrap > .cap-split-empty-page,
#ridesTableWrap > .dash-table-empty,
#captainsTableWrap > .dash-table-empty {
  flex: 1;
  display: grid;
  place-items: center;
}

.ride-split-col .ride-card {
  padding: 14px 14px 12px;
  border: 1px solid var(--dash-line);
  border-inline-start: 2px solid var(--ride-col-accent);
  border-radius: 14px;
  background: #fff;
  cursor: pointer;
  transition: border-color var(--dash-transition), box-shadow var(--dash-transition), background var(--dash-transition);
}

.ride-split-col .ride-card:hover {
  border-color: var(--ride-col-border);
  box-shadow: var(--dash-shadow);
  background: #fff;
}

.ride-split-col .ride-card.is-active,
.ride-split-col .ride-card.is-searching {
  border-color: var(--ride-col-border);
  background: #fff;
  box-shadow: inset 0 0 0 1px var(--ride-col-tint-hover);
}

.ride-split-col .ride-card-time strong {
  color: var(--dash-ink);
}

.ride-split-col .ride-route-arrow {
  color: var(--ride-col-accent);
}

.ride-split-col .ride-card-cap--wait {
  color: var(--dash-muted);
}

.ride-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.ride-card-time {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 64px;
}

.ride-card-time strong {
  font-size: 15px;
  font-weight: 900;
  line-height: 1.1;
  color: var(--dash-ink);
}

.ride-card-time span {
  font-size: 11px;
  font-weight: 800;
  color: var(--dash-muted);
}

.ride-card-id {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
}

.ride-card-route { margin-bottom: 10px; }

.ride-card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 12px;
  font-weight: 800;
}

.ride-card-phone { color: var(--dash-muted); }

.ride-card-cap {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed var(--dash-line);
  font-size: 12px;
  font-weight: 800;
  color: var(--dash-ink);
}

.ride-card-cap--wait { color: var(--dash-gold-dark); }

/* ── Captains split list ── */
.cap-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  flex: 1;
  min-height: 0;
  height: 100%;
  background: #fff;
}

.cap-split-col {
  display: flex;
  flex-direction: column;
  min-width: 0;
  border-inline-start: 1px solid var(--dash-line);
}

.cap-split-col:first-child { border-inline-start: 0; }

.cap-split-col--car {
  --cap-col-accent: rgba(22, 163, 74, 0.55);
  --cap-col-tint: rgba(22, 163, 74, 0.04);
  --cap-col-border: rgba(22, 163, 74, 0.12);
  --cap-col-icon-bg: rgba(22, 163, 74, 0.1);
}

.cap-split-col--tuk {
  --cap-col-accent: rgba(180, 130, 20, 0.55);
  --cap-col-tint: rgba(180, 130, 20, 0.04);
  --cap-col-border: rgba(180, 130, 20, 0.12);
  --cap-col-icon-bg: rgba(180, 130, 20, 0.1);
}

.cap-split-head {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--dash-line);
  background: #fff;
  box-shadow: inset 0 2px 0 var(--cap-col-accent);
}

.cap-split-title {
  display: flex;
  align-items: center;
  gap: 12px;
}

.cap-split-title strong {
  display: block;
  font-size: 15px;
  font-weight: 900;
  color: var(--dash-ink);
}

.cap-split-title small {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-muted);
}

.cap-split-icon {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  font-size: 20px;
  line-height: 1;
  background: var(--cap-col-icon-bg);
  border: 1px solid var(--cap-col-border);
}

.cap-split-list {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  max-height: none;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: var(--cap-col-tint);
}

.cap-split-list--table {
  padding: 0;
  gap: 0;
  background: #fff;
}

.cap-split-list--table .cap-table-wrap {
  border: 0;
  border-radius: 0;
}

.cap-split-list--table .dash-table--captains thead {
  position: sticky;
  top: 0;
  z-index: 1;
  background: #fff;
}

.cap-split-list--table .dash-table--captains th {
  background: #fff;
  border-bottom: 1px solid var(--dash-line);
}

.cap-captain-place {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  max-width: 100%;
}

.cap-captain-place .cap-avatar,
.cap-captain-place .cap-avatar--ph {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  font-size: 14px;
  flex-shrink: 0;
}

.cap-captain-place--online .cap-avatar,
.cap-captain-place--online .cap-avatar--ph {
  box-shadow: 0 0 0 2px rgba(22, 163, 74, 0.35);
}

.cap-captain-place--pending .cap-avatar,
.cap-captain-place--pending .cap-avatar--ph {
  box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.35);
}

.cap-captain-meta {
  min-width: 0;
}

.cap-captain-name {
  display: block;
  font-size: 13px;
  font-weight: 900;
  color: var(--dash-ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cap-captain-sub {
  display: block;
  margin-top: 2px;
  font-size: 10px;
  font-weight: 700;
  color: var(--dash-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-table--captains .cap-col-name {
  max-width: 0;
}

.dash-table--captains .cap-col-phone {
  white-space: nowrap;
  font-size: 12px;
  font-weight: 700;
}

.dash-table--captains .cap-col-status {
  white-space: nowrap;
}

.cap-status-cell {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}

.dash-cap-row {
  cursor: pointer;
}

.dash-cap-row--online td {
  background: rgba(22, 163, 74, 0.04);
}

.dash-cap-row--pending td {
  background: rgba(245, 158, 11, 0.05);
}

.dash-cap-row--online:hover td,
.dash-cap-row--pending:hover td {
  background: rgba(23, 105, 255, 0.06);
}

.dash-cap-row:hover td {
  background: rgba(23, 105, 255, 0.04);
}

.dash-user-row:hover td {
  background: #f8fafc;
}

.user-page {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.user-panel {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.user-toolbar {
  padding: 12px 16px;
  border-bottom: 1px solid var(--dash-line);
  background: linear-gradient(180deg, #fafbfc 0%, #fff 100%);
}

.user-search {
  max-width: 320px;
  margin: 0;
}

.user-table-wrap {
  flex: 1;
  min-height: 0;
}

.dash-table--users thead {
  display: none;
}

.dash-table--users td {
  padding: 10px 16px;
}

.user-user-place {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  max-width: 100%;
}

.user-user-place .cap-avatar,
.user-user-place .cap-avatar--ph {
  width: 36px;
  height: 36px;
  border-radius: 11px;
  font-size: 15px;
  flex-shrink: 0;
}

.user-user-name {
  font-size: 14px;
  font-weight: 900;
  color: var(--dash-ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-user-row {
  cursor: pointer;
}

.user-avatar--ph {
  background: linear-gradient(145deg, #6366f1 0%, #2563eb 100%);
  color: #fff;
}

body[data-admin-view="users"] .dash-content {
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - var(--dash-topbar-total-h, var(--dash-topbar-h)));
  overflow: hidden;
  padding-bottom: 0;
}

body[data-admin-view="users"] .dash-content-inner {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  padding-bottom: 0;
}

body[data-admin-view="users"] .dash-view:not([hidden]) {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

body[data-admin-view="users"] .user-page {
  flex: 1;
  min-height: 0;
}

body[data-admin-view="users"] #usersTableWrap {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

@media (max-width: 960px) {
  .ride-split,
  .cap-split {
    grid-template-columns: 1fr;
  }

  .ride-split-col {
    border-inline-start: 0;
    border-top: 1px solid var(--dash-line);
  }

  .ride-split-col:first-child { border-top: 0; }

  .ride-split-list {
    max-height: none;
  }
}

.ride-vehicle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 800;
}

.ride-vehicle-icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  font-size: 14px;
  background: var(--dash-bg-subtle);
}

.ride-vehicle-icon.tuk { background: var(--dash-gold-light); }

.ride-price { font-weight: 900; white-space: nowrap; }

.ride-price .surge {
  display: inline-block;
  margin-right: 6px;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--dash-gold-light);
  color: var(--dash-gold-dark);
  font-size: 10px;
  font-weight: 900;
}

.ride-detail-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 0 0 14px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--dash-line);
}

.ride-detail-top .ride-id {
  font-size: 13px;
  font-weight: 800;
  color: var(--dash-muted);
}

.ride-detail-route {
  padding: 14px 0;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--dash-line);
  background: none;
  border-radius: 0;
  border-top: 0;
  border-left: 0;
  border-right: 0;
}

.ride-detail-route .from,
.ride-detail-route .to {
  font-size: 14px;
  font-weight: 800;
  line-height: 1.45;
}

.ride-detail-route .arrow {
  text-align: center;
  color: var(--dash-green);
  font-size: 16px;
  font-weight: 900;
  margin: 6px 0;
  direction: ltr;
  unicode-bidi: isolate;
}

.ride-timeline {
  margin-bottom: 18px;
  padding: 16px 18px;
  border-radius: var(--dash-radius-md);
  border: 1px solid var(--dash-line);
  background: #fff;
}

.ride-timeline h4 {
  margin: 0 0 12px;
  font-size: 13px;
  font-weight: 900;
  color: var(--dash-muted);
}

.ride-timeline-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 8px 0;
  border-bottom: 1px dashed var(--dash-line);
  font-size: 12px;
  font-weight: 700;
}

.ride-timeline-item:last-child { border-bottom: 0; }

.ride-timeline-item time {
  flex: 0 0 auto;
  color: var(--dash-muted);
  font-size: 11px;
  min-width: 110px;
}

/* ── Pricing — soft white panels, light borders ── */
.price-page {
  display: flex;
  flex-direction: column;
  gap: 18px;
  max-width: 1100px;
}

.price-sys-head {
  margin-bottom: 0;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--dash-line);
}

.price-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.price-sys-grid {
  display: grid;
  grid-template-columns: 1fr 1fr min(240px, 24vw);
  gap: 0;
  align-items: stretch;
}

.price-sys-grid--rates {
  margin-top: 2px;
}

.price-sys-col {
  min-width: 0;
  padding: 0 16px;
}

.price-sys-col:first-child {
  padding-inline-start: 0;
}

.price-sys-col:last-child {
  padding-inline-end: 0;
}

.price-sys-col + .price-sys-col {
  border-inline-start: 1px solid var(--dash-line);
}

.price-sys-col-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 10px;
  padding: 0 0 8px;
  font-size: 12px;
  font-weight: 900;
  color: var(--dash-ink);
  border-bottom: 1px solid rgba(226, 232, 240, 0.85);
}

.price-sys-col-title span:last-child {
  min-width: 0;
}

.price-sys-col--car .price-sys-col-title span:last-child {
  color: var(--dash-green-text);
}

.price-sys-col--car .price-sys-section-icon {
  color: var(--dash-green-text);
}

.price-sys-col--tuk .price-sys-col-title span:last-child {
  color: var(--dash-gold-dark);
}

.price-sys-col--tuk .price-sys-section-icon {
  color: var(--dash-gold-dark);
}

.price-sys-col--preview .price-sys-col-title span:last-child {
  color: var(--dash-primary);
}

.price-sys-col--preview .price-sys-section-icon,
.price-sys-col--preview .price-sys-section-icon .fi {
  color: var(--dash-primary);
}

.price-sys-block--rates .cap-detail-section-title--icon span:last-child {
  font-weight: 800;
}

.price-sys-block--rates .cap-detail-section-title--icon:first-of-type span:last-child {
  color: var(--dash-green-text);
}

.price-sys-block--rates .cap-detail-section-title--icon:last-of-type span:last-child {
  color: var(--dash-gold-dark);
}

.price-sys-block--rates .price-sys-section-title {
  margin-bottom: 12px;
}

.price-sys-block--rates .cap-detail-section-title {
  margin-top: 8px;
  border-bottom-color: rgba(226, 232, 240, 0.85);
}

.price-sys-block--rates .cap-detail-section-title:first-of-type {
  margin-top: 0;
}

.price-sys-block--rates .cap-detail-row {
  border-bottom-color: rgba(226, 232, 240, 0.85);
}

.price-sys-block--rates .cap-detail-list:first-of-type .cap-detail-row strong,
.price-sys-block--rates .cap-detail-list--docs .cap-detail-row strong {
  font-size: 14px;
  font-weight: 900;
  color: var(--dash-ink);
}

.price-sys-block {
  padding: 14px 16px 12px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid var(--dash-line);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.03);
}

.price-sys-section-title {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 10px;
  padding: 0 0 9px;
  font-size: 13px;
  font-weight: 900;
  color: var(--dash-ink);
  border-bottom: 1px solid var(--dash-line);
}

.price-sys-section-icon {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  font-size: 16px;
  line-height: 1;
  flex-shrink: 0;
  color: var(--dash-muted);
  background: #f8fafc;
  border: 1px solid var(--dash-line);
}

.price-sys-section-icon .fi {
  font-size: 15px;
  line-height: 1;
  color: var(--dash-muted);
}

.price-sys-section-icon--sm {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  font-size: 14px;
}

.price-sys-section-label {
  min-width: 0;
  flex: 1;
  color: var(--dash-ink);
}

.price-sys-block--rates > .price-sys-section-title .price-sys-section-label {
  color: var(--dash-ink);
}

.price-sys-block--global .price-sys-section-label {
  color: var(--dash-primary);
}

.price-sys-block--global .price-sys-section-icon,
.price-sys-block--global .price-sys-section-icon .fi {
  color: var(--dash-primary);
}

.price-sys-block--history .price-sys-section-label {
  color: var(--dash-ink-soft);
}

.price-sys-block--history .price-sys-section-icon,
.price-sys-block--history .price-sys-section-icon .fi {
  color: var(--dash-muted);
}

.cap-detail-section-title--icon {
  display: flex;
  align-items: center;
  gap: 8px;
}

.price-sys-fields {
  display: flex;
  flex-direction: column;
  padding: 0;
}

.price-sys-fields--grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 20px;
}

.price-sys-field {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 9px 0;
  border-bottom: 1px solid rgba(226, 232, 240, 0.85);
  transition: background var(--dash-transition);
}

.price-sys-field:hover {
  background: #f8fafc;
  margin-inline: -6px;
  padding-inline: 6px;
  border-radius: 8px;
}

.price-sys-field:last-child {
  border-bottom: 0;
}

.price-sys-field label {
  font-size: 12px;
  font-weight: 700;
  color: var(--dash-muted);
  flex: 1;
  min-width: 0;
  max-width: calc(100% - 136px);
}

.price-sys-field input[type="number"] {
  width: min(128px, 42%);
  flex-shrink: 0;
  padding: 7px 10px;
  border: 1px solid var(--dash-line);
  border-radius: 9px;
  background: #fff;
  font-size: 13px;
  font-weight: 800;
  text-align: end;
  color: var(--dash-ink);
  transition:
    border-color var(--dash-transition),
    background var(--dash-transition),
    box-shadow var(--dash-transition);
  position: relative;
  z-index: 1;
}

.price-sys-field input[type="number"]:hover {
  border-color: var(--dash-line-strong);
  background: #fafbfc;
}

.price-sys-field input[type="number"]:focus {
  outline: none;
  border-color: var(--dash-line-strong);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(15, 23, 42, 0.04);
}

.price-sys-field--toggle {
  grid-column: 1 / -1;
  justify-content: flex-start;
  padding-top: 10px;
  border-bottom: 0;
}

.price-sys-field--toggle:hover {
  background: none;
  margin-inline: 0;
  padding-inline: 0;
}

.price-sys-block--preview .cap-detail-section-title {
  margin-top: 10px;
  color: var(--dash-muted);
  border-bottom-color: var(--dash-line);
}

.price-sys-block--preview .cap-detail-section-title:first-of-type {
  margin-top: 2px;
}

.price-sys-block--preview .cap-detail-row {
  border-bottom-color: rgba(226, 232, 240, 0.85);
}

.price-sys-block--preview .cap-detail-list:first-of-type .cap-detail-row strong,
.price-sys-block--preview .cap-detail-list--docs .cap-detail-row strong {
  font-size: 14px;
  font-weight: 900;
  color: var(--dash-ink);
}

.price-sys-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid var(--dash-line);
  background: #fff;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.03);
}

.price-sys-history-body {
  padding: 0;
}

.price-sys-history-body .dash-table-empty {
  padding: 16px 0;
  font-size: 13px;
  color: var(--dash-muted);
}

.price-history-item {
  padding: 10px 8px;
  border-bottom: 1px solid rgba(226, 232, 240, 0.85);
  border-radius: 8px;
  transition: background var(--dash-transition);
}

.price-history-item:hover {
  background: #f8fafc;
}

.price-history-item:last-child {
  border-bottom: 0;
}

.price-history-item time {
  display: block;
  font-size: 11px;
  font-weight: 800;
  color: var(--dash-muted);
  margin-bottom: 4px;
}

.price-history-item ul {
  margin: 6px 0 0;
  padding: 0 18px 0 0;
  font-size: 12px;
  font-weight: 700;
  color: var(--dash-ink-soft);
}

.price-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 10px;
  border: 1px solid var(--dash-line);
  background: #f8fafc;
  font-size: 12px;
  font-weight: 800;
  color: var(--dash-ink);
  cursor: pointer;
  transition:
    border-color var(--dash-transition),
    background var(--dash-transition);
}

.price-toggle:hover {
  background: #fff;
  border-color: var(--dash-line-strong);
}

.price-toggle input {
  width: 16px;
  height: 16px;
  accent-color: var(--dash-primary);
}

@media (max-width: 1100px) {
  .price-sys-grid {
    grid-template-columns: 1fr 1fr;
  }

  .price-sys-col--preview {
    grid-column: 1 / -1;
    margin-top: 14px;
    padding-top: 14px;
    padding-inline: 0;
    border-inline-start: 0;
    border-top: 1px solid var(--dash-line);
  }
}

@media (max-width: 720px) {
  .price-sys-grid,
  .price-sys-fields--grid {
    grid-template-columns: 1fr;
  }

  .price-sys-col {
    padding: 0;
  }

  .price-sys-col + .price-sys-col {
    margin-top: 14px;
    padding-top: 14px;
    border-inline-start: 0;
    border-top: 1px solid var(--dash-line);
  }

  .price-sys-col--preview {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--dash-line);
  }
}

/* legacy pricing (unused) */
.price-form-old { display: flex; flex-direction: column; gap: 24px; }

.price-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.price-card-head {
  display: flex;
  align-items: center;
  gap: 12px;
}

.price-card-icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  font-size: 22px;
  background: var(--dash-bg-subtle);
}

.price-card-icon.tuk { background: var(--dash-gold-light); }

.price-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 16px;
}

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

.price-toggle-field {
  display: flex;
  align-items: flex-end;
  grid-column: span 1;
}

.price-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: var(--dash-radius-sm);
  border: 1px solid var(--dash-line);
  background: var(--dash-bg-subtle);
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  width: 100%;
}

.price-toggle input {
  width: 18px;
  height: 18px;
  accent-color: var(--dash-primary);
}

.price-preview-note {
  font-size: 12px;
  font-weight: 700;
  color: var(--dash-muted);
}

.price-preview-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.price-preview-col {
  padding: 18px 20px;
  border-radius: var(--dash-radius-md);
  background: var(--dash-bg-subtle);
  border: 1px solid var(--dash-line);
}

.price-preview-col h4 {
  margin: 0 0 12px;
  font-size: 14px;
  font-weight: 900;
}

.price-preview-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px dashed var(--dash-line);
  font-size: 13px;
  font-weight: 700;
}

.price-preview-row:last-child { border-bottom: 0; }

.price-preview-row strong {
  font-size: 18px;
  font-weight: 900;
  color: var(--dash-ink);
}

.price-actions { display: flex; flex-wrap: wrap; gap: 10px; }

.price-history-item {
  padding: 16px 24px;
  border-bottom: 1px solid var(--dash-line);
}

.price-history-item:last-child { border-bottom: 0; }

.price-history-item time {
  display: block;
  font-size: 11px;
  font-weight: 800;
  color: var(--dash-muted);
  margin-bottom: 6px;
}

.price-history-item ul {
  margin: 0;
  padding-right: 18px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.6;
}

.price-history-item .price-history-action {
  display: inline-block;
  margin-bottom: 4px;
  padding: 3px 10px;
  border-radius: 999px;
  background: var(--dash-gold-light);
  color: var(--dash-gold-dark);
  font-size: 11px;
  font-weight: 900;
}

/* ── Announcements — app mock preview ── */
/* RTL: العمود 1 = يمين (النموذج) · العمود 2 = يسار (المعاينة) — عرض متساوٍ */
.ann-layout {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: stretch;
  max-width: 900px;
  width: 100%;
  margin-inline: auto;
}

.ann-editor,
.ann-preview-col {
  min-width: 0;
}

.ann-editor .dash-panel-head,
.ann-preview-panel .dash-panel-head {
  padding: 12px 16px;
}

.ann-editor .dash-panel-body,
.ann-preview-panel .dash-panel-body {
  padding: 14px 16px 16px;
}

.ann-editor .ann-form-grid {
  gap: 12px;
}

.ann-preview-col {
  display: flex;
  flex-direction: column;
}

.ann-preview-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  width: 100%;
}

.ann-preview-panel .dash-panel-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.ann-preview-head h3 {
  margin: 0;
  font-size: 13px;
}

.ann-placement-form-hint {
  margin: 4px 0 0;
  font-size: 12px;
  font-weight: 700;
  color: var(--dash-muted);
  line-height: 1.5;
}

.ann-placement-active {
  margin: 8px 0 0;
  padding: 8px 12px;
  border-radius: 10px;
  border: 1px solid var(--dash-line);
  background: #f8fafc;
  font-size: 12px;
  font-weight: 800;
  color: var(--dash-ink);
}

.ann-preview-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.ann-mock-tabs {
  display: inline-flex;
  gap: 4px;
  padding: 3px;
  border-radius: 10px;
  border: 1px solid var(--dash-line);
  background: #f8fafc;
}

.ann-mock-tab {
  padding: 6px 12px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  font-size: 11px;
  font-weight: 800;
  color: var(--dash-muted);
  cursor: pointer;
  transition: background var(--dash-transition), color var(--dash-transition);
}

.ann-mock-tab.on {
  background: #fff;
  color: var(--dash-ink);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

.ann-mock-hint {
  margin: 0 0 8px;
  font-size: 10px;
  font-weight: 700;
  color: var(--dash-muted);
  text-align: center;
  line-height: 1.4;
}

.ann-app-device {
  position: relative;
  width: min(100%, 100%);
  max-width: 300px;
  margin: 0 auto;
  padding: 8px 8px 12px;
  border-radius: 22px;
  border: 1px solid var(--dash-line);
  background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
  box-shadow:
    0 8px 24px rgba(15, 23, 42, 0.07),
    inset 0 0 0 1px rgba(255, 255, 255, 0.9);
}

.ann-app-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 2px 8px 8px;
  font-size: 10px;
  font-weight: 800;
  color: var(--dash-muted);
}

.ann-app-status-icons {
  letter-spacing: 1px;
  font-size: 9px;
}

.ann-app-screen {
  min-height: 340px;
  border-radius: 14px;
  border: 1px solid var(--dash-line);
  background: #fff;
  overflow: hidden;
}

.ann-app-ui {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 8px;
  min-height: 340px;
}

.ann-app-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.ann-app-brand {
  font-size: 14px;
  font-weight: 900;
  color: var(--dash-ink);
}

.ann-app-avatar {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: linear-gradient(145deg, #ecfdf5, #d1fae5);
  border: 1px solid var(--dash-line);
}

.ann-app-hero {
  padding: 2px 2px 4px;
}

.ann-app-hero strong {
  display: block;
  font-size: 13px;
  font-weight: 900;
  color: var(--dash-ink);
}

.ann-app-hero strong em {
  font-style: normal;
  color: var(--dash-green-text);
}

.ann-app-hero small {
  display: block;
  margin-top: 2px;
  font-size: 10px;
  font-weight: 700;
  color: var(--dash-muted);
}

.ann-app-vehicles {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.ann-app-vehicle {
  padding: 8px 6px;
  border-radius: 10px;
  border: 1px solid var(--dash-line);
  background: #fafbfc;
  text-align: center;
}

.ann-app-vehicle span {
  display: block;
  font-size: 15px;
  line-height: 1;
}

.ann-app-vehicle b {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  font-weight: 900;
}

.ann-app-captain-strip {
  margin-top: auto;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px dashed var(--dash-line);
  background: #f8fafc;
  font-size: 11px;
  font-weight: 800;
  color: var(--dash-muted);
  text-align: center;
}

.ann-app-ui--ride {
  padding: 0;
  gap: 0;
  min-height: 340px;
}

.ann-app-map {
  flex: 1;
  min-height: 140px;
  background:
    linear-gradient(180deg, rgba(236, 253, 245, 0.5), rgba(241, 245, 249, 0.9)),
    repeating-linear-gradient(0deg, transparent, transparent 18px, rgba(148, 163, 184, 0.08) 18px, rgba(148, 163, 184, 0.08) 19px),
    repeating-linear-gradient(90deg, transparent, transparent 18px, rgba(148, 163, 184, 0.08) 18px, rgba(148, 163, 184, 0.08) 19px);
}

.ann-app-sheet {
  padding: 10px 10px 12px;
  border-top: 1px solid var(--dash-line);
  background: #fff;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ann-app-sheet-handle {
  width: 36px;
  height: 4px;
  margin: 0 auto 4px;
  border-radius: 999px;
  background: var(--dash-line);
}

.ann-app-route {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 10px;
  font-weight: 700;
  color: var(--dash-muted);
}

.ann-app-request-btn {
  padding: 10px;
  border-radius: 12px;
  background: linear-gradient(145deg, #22c55e, #16a34a);
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  text-align: center;
}

.ann-app-slot {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 4px;
  width: 100%;
  padding: 6px;
  border: 1px dashed rgba(148, 163, 184, 0.55);
  border-radius: 10px;
  background: rgba(248, 250, 252, 0.65);
  cursor: pointer;
  text-align: inherit;
  transition:
    border-color var(--dash-transition),
    background var(--dash-transition),
    box-shadow var(--dash-transition);
}

.ann-app-slot:hover {
  border-color: var(--dash-line-strong);
  background: #fff;
}

.ann-app-slot.is-on {
  border-style: solid;
  border-color: var(--dash-primary);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(29, 78, 216, 0.08);
}

.ann-app-slot-tag {
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0.02em;
  color: var(--dash-muted);
  text-align: center;
}

.ann-app-slot.is-on .ann-app-slot-tag {
  color: var(--dash-primary);
}

.ann-app-slot-ad:empty {
  display: none;
}

.ann-app-slot.is-on .ann-app-slot-ad:not(:empty) {
  display: block;
}

.ann-app-slot--compact {
  min-height: 0;
}

.ann-app-slot--wide {
  margin-top: 2px;
}

.ann-app-slot--popup {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 10px;
  z-index: 4;
  margin: 0;
}

.ann-app-popup-layer {
  position: absolute;
  inset: 24px 8px 46px;
  z-index: 3;
  display: grid;
  place-items: center;
  padding: 12px;
  border-radius: 16px;
  background: rgba(15, 23, 42, 0.38);
  pointer-events: none;
}

.ann-app-popup-layer:not([hidden]) {
  display: grid;
}

.ann-app-popup-card {
  width: 100%;
  max-width: 240px;
}

.ann-mock-ad {
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid var(--dash-line);
  background: #fff;
  display: flex;
  align-items: flex-start;
  gap: 8px;
  text-align: start;
}

.ann-mock-ad img {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  object-fit: cover;
  flex-shrink: 0;
}

.ann-mock-ad-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  font-size: 16px;
  background: #f8fafc;
  border: 1px solid var(--dash-line);
  flex-shrink: 0;
}

.ann-mock-ad-text strong {
  display: block;
  font-size: 10px;
  font-weight: 900;
  color: var(--dash-ink);
  line-height: 1.35;
}

.ann-mock-ad-text p {
  margin: 2px 0 0;
  font-size: 9px;
  font-weight: 700;
  color: var(--dash-muted);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.ann-mock-ad--hero {
  flex-direction: column;
  padding: 0;
  overflow: hidden;
}

.ann-mock-ad--hero img {
  width: 100%;
  height: 56px;
  border-radius: 0;
  border: 0;
}

.ann-mock-ad--hero .ann-mock-ad-body {
  padding: 6px 8px 8px;
  display: flex;
  gap: 6px;
  align-items: flex-start;
}

.ann-placements--hidden {
  display: none !important;
}

.ann-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

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

.ann-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid var(--dash-line-strong);
  background: #fff;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  transition: all var(--dash-transition);
}

.ann-chip:has(input:checked) {
  background: var(--dash-gold-light);
  border-color: var(--dash-gold-ring);
  color: var(--dash-gold-dark);
}

.ann-chip input { accent-color: var(--dash-primary); }

.ann-notify-block {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--dash-line);
}

.ann-notify-block h4 {
  margin: 0 0 12px;
  font-size: 13px;
  font-weight: 900;
}

.ann-notify-actions { display: flex; flex-wrap: wrap; gap: 8px; }

.ann-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}

.ann-preview-phone {
  max-width: 320px;
  margin: 0 auto;
}

.ann-preview-note {
  text-align: center;
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-muted);
  margin-top: 12px;
}

.ann-image-hint {
  font-size: 11px;
  font-weight: 700;
  color: var(--dash-muted);
  margin: 6px 0 0;
}

.ann-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
  padding: 24px;
}

.ann-card {
  border: 1px solid var(--dash-line);
  border-radius: var(--dash-radius);
  overflow: hidden;
  background: #fff;
  transition: transform var(--dash-transition), box-shadow var(--dash-transition);
}

.ann-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--dash-shadow-hover);
}

.ann-card-media {
  aspect-ratio: 16/9;
  background: var(--dash-bg-subtle);
  display: grid;
  place-items: center;
  overflow: hidden;
}

.ann-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ann-card-media .ann-card-icon {
  font-size: 40px;
}

.ann-card-body { padding: 16px 18px 18px; }

.ann-card-body strong {
  display: block;
  font-size: 14px;
  font-weight: 900;
  margin-bottom: 6px;
}

.ann-card-body p {
  margin: 0 0 12px;
  font-size: 12px;
  font-weight: 700;
  color: var(--dash-muted);
  line-height: 1.5;
}

.ann-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 14px;
}

.ann-card-placements {
  font-size: 10px;
  font-weight: 800;
  color: var(--dash-muted);
  margin-bottom: 12px;
}

.ann-card-actions { display: flex; flex-wrap: wrap; gap: 6px; }

.ann-table-thumb {
  width: 48px;
  height: 48px;
  border-radius: 10px;
  object-fit: cover;
}

.ann-table-icon { font-size: 24px; }

/* Preview card (uses t2-ann classes) */
.ann-preview-card {
  border-radius: 18px;
  border: 1px solid var(--dash-line);
  overflow: hidden;
}

.t2-ann-stack { padding: 0; }
.t2-ann { border-radius: 16px; border: 1px solid var(--dash-line); }
.t2-ann-img--hero { height: 140px; object-fit: cover; }

/* ── Settings — compact ── */
.settings-page {
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-width: 780px;
  width: 100%;
  margin-inline: auto;
}

.settings-page .settings-tabs {
  padding: 4px;
  gap: 4px;
}

.settings-page .settings-tab {
  padding: 6px 11px;
  font-size: 12px;
}

.settings-page .settings-panels {
  gap: 14px;
}

.settings-page .dash-panel-head {
  padding: 10px 14px;
}

.settings-page .dash-panel-head h3 {
  font-size: 14px;
}

.settings-page .dash-panel-body {
  padding: 12px 14px 14px;
}

.settings-page .settings-form-grid {
  gap: 10px 12px;
}

.settings-page .dash-field {
  gap: 5px;
}

.settings-page .dash-field label {
  font-size: 11px;
}

.settings-page .dash-field input,
.settings-page .dash-field select,
.settings-page .dash-field textarea {
  padding: 8px 10px;
  font-size: 13px;
}

.settings-page .dash-field textarea {
  min-height: 68px;
}

.settings-page .settings-form .dash-btn {
  margin-top: 2px;
  padding: 8px 14px;
  font-size: 12px;
}

.settings-page .settings-toggle {
  font-size: 12px;
  gap: 8px;
}

.settings-page .settings-toggle input {
  width: 16px;
  height: 16px;
}

.settings-page .settings-hint {
  font-size: 11px;
  line-height: 1.5;
  padding: 8px 10px;
  margin-bottom: 10px;
}

.settings-page .settings-logo-preview {
  width: 60px;
  height: 60px;
  border-radius: 10px;
  margin-top: 6px;
}

.settings-page .settings-backup-note {
  font-size: 11px;
  margin-top: 10px;
}

.settings-page .settings-panel > .dash-grid-2 + .dash-panel,
.settings-page .settings-panel > .dash-panel + .dash-panel {
  margin-top: 14px;
}

.settings-page .release-layout {
  grid-template-columns: 1fr;
  gap: 12px;
}

.settings-page .release-guide {
  gap: 8px;
}

.settings-page .release-guide-block {
  padding: 9px 11px;
}

.settings-page .release-guide-block h4 {
  margin-bottom: 5px;
  font-size: 12px;
}

.settings-page .release-guide-block p,
.settings-page .release-guide-block ul,
.settings-page .release-guide-block ol {
  font-size: 11px;
  line-height: 1.5;
}

.settings-page .release-guide-block li + li {
  margin-top: 4px;
}

.settings-page .release-guide-block code {
  font-size: 10px;
  padding: 1px 5px;
}

.settings-page .release-guide-table {
  font-size: 10px;
}

.settings-page .release-guide-table th,
.settings-page .release-guide-table td {
  padding: 5px 7px;
}

.settings-page .release-status {
  padding: 4px 9px;
  font-size: 10px;
}

.settings-page .settings-backup-list {
  margin-top: 12px;
}

.settings-page .settings-restore-form {
  margin-top: 14px;
}

.settings-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 6px;
  background: #fff;
  border-radius: var(--dash-radius-md);
  border: 1px solid var(--dash-line);
  width: fit-content;
  max-width: 100%;
}

.settings-tab {
  padding: 9px 16px;
  border-radius: var(--dash-radius-sm);
  font-size: 13px;
  font-weight: 700;
  color: var(--dash-muted);
  transition: all var(--dash-transition);
}

.settings-tab:hover { color: var(--dash-ink); background: var(--dash-bg-subtle); }

.settings-tab.on {
  background: var(--dash-primary);
  color: #fff;
}

.settings-panels { display: flex; flex-direction: column; gap: 20px; }

.settings-panel[hidden] { display: none !important; }

.settings-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.settings-form-grid.single { grid-template-columns: 1fr; }

.settings-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
}

.settings-toggle input { accent-color: var(--dash-primary); width: 18px; height: 18px; }

.settings-logo-preview {
  width: 80px;
  height: 80px;
  border-radius: 16px;
  border: 1px solid var(--dash-line);
  background: var(--dash-bg-subtle) center/contain no-repeat;
  margin-top: 8px;
}

.settings-backup-actions { margin-bottom: 8px; }

.settings-backup-note {
  font-size: 12px;
  font-weight: 700;
  color: var(--dash-muted);
  margin-top: 12px;
}

.settings-hint {
  font-size: 13px;
  font-weight: 600;
  line-height: 1.6;
  color: var(--dash-muted);
  margin: 0 0 16px;
  padding: 12px 14px;
  border-radius: var(--dash-radius-sm);
  background: #f8fafc;
  border: 1px solid var(--dash-line);
}

.release-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
  gap: var(--dash-gap);
  align-items: start;
}

.release-guide {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.release-status-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.release-status {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
}

.release-status.off {
  color: #64748b;
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
}

.release-status.on-warn {
  color: #b45309;
  background: #fffbeb;
  border: 1px solid #fcd34d;
}

.release-status.on-info {
  color: #1d4ed8;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
}

.release-guide-block {
  padding: 14px 16px;
  border-radius: var(--dash-radius-md);
  background: #fff;
  border: 1px solid var(--dash-line);
  box-shadow: var(--dash-shadow);
}

.release-guide-block h4 {
  margin: 0 0 8px;
  font-size: 14px;
  font-weight: 800;
  color: var(--dash-ink);
}

.release-guide-block p {
  margin: 0;
  font-size: 13px;
  line-height: 1.65;
  font-weight: 600;
  color: var(--dash-ink-soft);
}

.release-guide-block ul,
.release-guide-block ol {
  margin: 0;
  padding: 0 18px 0 0;
  font-size: 13px;
  line-height: 1.65;
  font-weight: 600;
  color: var(--dash-ink-soft);
}

.release-guide-block li + li { margin-top: 6px; }

.release-guide-block code {
  font-size: 12px;
  padding: 2px 6px;
  border-radius: 6px;
  background: #f1f5f9;
  color: #334155;
}

.release-guide-warn {
  background: #fffbeb;
  border-color: #fcd34d;
}

.release-guide-warn h4 { color: #b45309; }

.release-guide-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  font-weight: 600;
}

.release-guide-table th,
.release-guide-table td {
  padding: 8px 10px;
  border: 1px solid var(--dash-line);
  text-align: right;
  vertical-align: top;
}

.release-guide-table th {
  background: #f8fafc;
  font-weight: 800;
  color: var(--dash-ink);
}

.release-form-panel { position: sticky; top: calc(var(--dash-topbar-total-h, var(--dash-topbar-h)) + 12px); }

.field-hint {
  display: block;
  margin-top: 6px;
  font-size: 11px;
  font-weight: 600;
  color: var(--dash-muted);
}

@media (max-width: 1100px) {
  .release-layout { grid-template-columns: 1fr; }
  .release-form-panel { position: static; }
}

/* ── Leaflet overrides ── */
.leaflet-container { font-family: Cairo, sans-serif; }

/* @admin-pro merged */
/* 2T Admin — Pro layout & creative polish */

:root {
  --dash-accent: #19a974;
  --dash-accent-soft: rgba(25, 169, 116, 0.12);
  --dash-sidebar-w: 272px;
  --dash-topbar-h: 72px;
  --dash-gap: 20px;
  --dash-gap-lg: 28px;
  --dash-radius: 16px;
  --dash-radius-md: 12px;
  --dash-radius-sm: 10px;
  --dash-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 8px 24px rgba(15, 23, 42, 0.06);
  --dash-shadow-hover: 0 8px 32px rgba(15, 23, 42, 0.1);
  --dash-sidebar-bg: linear-gradient(180deg, #0f172a 0%, #111827 48%, #0b1220 100%);
}

/* ── Login ── */
.admin-login-screen {
  position: relative;
  overflow: hidden;
  background: #0f172a;
}

.admin-login-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(29, 78, 216, 0.35), transparent 42%),
    radial-gradient(circle at 80% 10%, rgba(25, 169, 116, 0.28), transparent 38%),
    radial-gradient(circle at 50% 100%, rgba(29, 78, 216, 0.15), transparent 50%);
  pointer-events: none;
}

.admin-login-card {
  position: relative;
  z-index: 1;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.98);
  backdrop-filter: blur(12px);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.35);
}

.admin-login-brand b { display: none; }

.admin-login-logo {
  width: 64px;
  height: 64px;
  margin: 0 auto 14px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  font-size: 24px;
  font-weight: 900;
  color: #fff;
  background: linear-gradient(135deg, var(--dash-primary) 0%, var(--dash-accent) 100%);
  box-shadow: 0 12px 28px rgba(29, 78, 216, 0.35);
}

.admin-login-brand strong {
  display: block;
  font-size: 20px;
  font-weight: 900;
  color: var(--dash-ink);
}

.admin-login-brand span {
  margin-top: 6px;
  font-size: 13px;
  font-weight: 600;
}

.admin-login-brand b::after { display: none; }

/* ── Sidebar ── */
.dash-sidebar {
  background: var(--dash-sidebar-bg);
  border-left: 0;
  box-shadow: -8px 0 32px rgba(0, 0, 0, 0.12);
}

.dash-sidebar-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 22px 18px 18px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.dash-sidebar-brand b,
.dash-sidebar-brand small { display: none; }

.dash-brand-logo {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  font-size: 17px;
  font-weight: 900;
  color: #fff;
  background: linear-gradient(135deg, #2563eb 0%, #19a974 100%);
  box-shadow: 0 8px 20px rgba(37, 99, 235, 0.35);
}

.dash-brand-text strong {
  display: block;
  font-size: 15px;
  font-weight: 800;
  color: #f8fafc;
  line-height: 1.2;
}

.dash-brand-text small {
  display: block;
  margin-top: 3px;
  font-size: 11px;
  font-weight: 600;
  color: #94a3b8;
}

.dash-nav {
  padding: 10px 12px 16px;
}

.dash-nav-label {
  margin: 14px 10px 8px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #64748b;
}

.dash-nav-label:first-child { margin-top: 4px; }

.dash-nav-item {
  padding: 10px 12px;
  border-radius: var(--dash-radius-sm);
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 3px;
}

.dash-nav-item.on {
  background: linear-gradient(90deg, rgba(37, 99, 235, 0.95) 0%, rgba(29, 78, 216, 0.85) 100%);
  box-shadow: 0 4px 14px rgba(29, 78, 216, 0.35);
}

.dash-sidebar-foot {
  padding: 14px 12px 18px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.dash-build-tag {
  display: block;
  margin-bottom: 10px;
  padding: 6px 10px;
  border-radius: 8px;
  font-size: 10px;
  font-weight: 800;
  text-align: center;
  color: #86efac;
  background: rgba(25, 169, 116, 0.12);
  border: 1px solid rgba(25, 169, 116, 0.25);
}

.dash-sidebar-logout,
.dash-sidebar-foot button {
  width: 100%;
  padding: 11px 14px;
  border-radius: var(--dash-radius-sm);
  font-weight: 700;
  font-size: 13px;
  color: #fecaca;
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.2);
  margin-bottom: 8px;
}

.dash-sidebar-logout:hover,
.dash-sidebar-foot button:hover {
  background: rgba(239, 68, 68, 0.18);
  color: #fff;
}

.dash-sidebar-link,
.dash-sidebar-foot a {
  display: block;
  width: 100%;
  padding: 10px 14px;
  border-radius: var(--dash-radius-sm);
  font-weight: 700;
  font-size: 12px;
  text-align: center;
  color: #cbd5e1;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
}

.dash-sidebar-link:hover,
.dash-sidebar-foot a:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

/* ── Main shell ── */
.dash-main {
  background:
    radial-gradient(circle at 0% 0%, rgba(29, 78, 216, 0.04), transparent 28%),
    radial-gradient(circle at 100% 0%, rgba(25, 169, 116, 0.05), transparent 24%),
    var(--dash-bg-subtle);
}

.dash-content {
  padding: 0;
}

.dash-content-inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: var(--dash-gap-lg) var(--dash-gap-lg) 48px;
}

.dash-view {
  animation: dashFadeIn 0.28s ease;
}

@keyframes dashFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ── Topbar ── */
.dash-topbar {
  height: var(--dash-topbar-h);
  padding: 0 var(--dash-gap-lg);
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(226, 232, 240, 0.9);
}

.dash-topbar-title {
  font-size: 22px;
  font-weight: 900;
  background: linear-gradient(90deg, var(--dash-ink) 0%, #334155 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.dash-topbar-crumb {
  font-size: 12px;
  font-weight: 600;
  color: var(--dash-muted);
}

.dash-search {
  width: 260px;
  background: #f8fafc;
  border-color: transparent;
  box-shadow: inset 0 0 0 1px var(--dash-line);
}

.dash-search:focus {
  background: #fff;
  box-shadow: inset 0 0 0 1px var(--dash-primary), 0 0 0 3px var(--dash-primary-ring);
}

.dash-btn-ghost {
  background: #f8fafc;
  border-color: var(--dash-line);
  color: var(--dash-ink-soft);
}

.dash-btn-ghost:hover:not(:disabled) {
  background: #fff;
  border-color: var(--dash-primary-ring);
  color: var(--dash-primary);
}

.dash-topbar-user {
  flex-direction: row-reverse;
  gap: 12px;
  padding: 6px 8px 6px 14px;
  border-radius: 999px;
  background: #f8fafc;
  border-color: var(--dash-line);
}

.dash-topbar-user-meta {
  text-align: left;
  line-height: 1.25;
}

.dash-topbar-user-meta strong {
  display: block;
  font-size: 12px;
  font-weight: 800;
  color: var(--dash-ink);
}

.dash-topbar-user-meta span {
  display: block;
  font-size: 10px;
  font-weight: 700;
  color: var(--dash-muted);
}

.dash-topbar-avatar {
  background: linear-gradient(135deg, var(--dash-primary) 0%, var(--dash-accent) 100%);
  color: #fff;
  font-size: 12px;
}

.dash-topbar-user > span { display: none; }

/* ── Stats ── */
.dash-stats {
  gap: 12px;
  margin-bottom: var(--dash-gap);
}

.dash-stats--8 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.dash-stat {
  border-radius: var(--dash-radius-md);
  border: 1px solid rgba(226, 232, 240, 0.9);
  box-shadow: var(--dash-shadow);
  background: #fff;
  position: relative;
  overflow: hidden;
}

.dash-stat::before {
  content: '';
  position: absolute;
  inset-inline-start: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--dash-line-strong);
}

.dash-stat.accent-blue::before { background: var(--dash-primary); }
.dash-stat.accent-green::before { background: var(--dash-accent); }
.dash-stat.accent-amber::before { background: var(--dash-amber); }
.dash-stat.accent-gold::before { background: var(--dash-gold); }
.dash-stat.accent-purple::before { background: #7c3aed; }
.dash-stat.accent-cyan::before { background: #0891b2; }

.dash-stat-icon {
  border-radius: 10px;
}

/* ── Panels & pages ── */
.dash-grid-2,
.dash-grid-2-1,
.dash-grid-home-bottom {
  gap: var(--dash-gap);
  margin-bottom: var(--dash-gap);
}

.dash-panel {
  border-radius: var(--dash-radius);
  border: 1px solid rgba(226, 232, 240, 0.95);
  box-shadow: var(--dash-shadow);
  background: #fff;
}

.dash-panel-head {
  padding: 14px 18px;
  background: linear-gradient(180deg, #fff 0%, #fafbfd 100%);
}

.dash-panel-head h3 {
  font-size: 15px;
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: 8px;
}

.dash-panel-head h3::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--dash-accent);
  box-shadow: 0 0 0 4px var(--dash-accent-soft);
}

.ride-page,
.cap-page,
.price-page,
.ann-page,
.settings-page {
  gap: var(--dash-gap);
}

.ride-panel,
.cap-panel {
  border-radius: var(--dash-radius);
  overflow: hidden;
}

/* ── Toolbars & filters ── */
.ride-toolbar,
.cap-toolbar {
  padding: 14px 18px;
  background: linear-gradient(180deg, #fafbfd 0%, #fff 100%);
  gap: 10px;
}

.ride-search,
.cap-search {
  max-width: 320px;
  background: #f8fafc;
}

.ride-filters,
.cap-filters {
  gap: 6px;
}

.ride-filter,
.cap-filter {
  font-size: 11px;
  padding: 7px 12px;
}

.ride-filter.on,
.cap-filter.on {
  box-shadow: 0 4px 12px rgba(29, 78, 216, 0.25);
}

/* ── Ride split ── */
.ride-split {
  border-radius: 0 0 var(--dash-radius) var(--dash-radius);
  overflow: hidden;
}

.ride-split-col--car { --ride-col-accent: rgba(25, 169, 116, 0.6); }
.ride-split-col--tuk { --ride-col-accent: rgba(201, 162, 39, 0.65); }

.ride-split-head {
  background: #fff;
  padding: 14px 16px;
}

.ride-split-list {
  padding: 12px;
  gap: 8px;
}

.ride-split-col .ride-card {
  border-radius: var(--dash-radius-sm);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.ride-split-col .ride-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--dash-shadow-hover);
}

/* ── Captain cards ── */
.cap-grid {
  gap: 16px;
  padding: 18px;
}

.cap-card {
  border-radius: var(--dash-radius-md);
  border: 1px solid var(--dash-line);
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
}

.cap-card:hover {
  box-shadow: var(--dash-shadow-hover);
  border-color: rgba(29, 78, 216, 0.2);
}

/* ── Tables ── */
.dash-table th {
  background: #f8fafc;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.dash-table tbody tr:hover td {
  background: #f8fafc;
}

/* ── Detail drawers ── */
.ride-detail-panel,
.cap-detail-panel {
  border-radius: var(--dash-radius) 0 0 var(--dash-radius);
  box-shadow: -12px 0 40px rgba(15, 23, 42, 0.12);
}

.ride-detail-head,
.cap-detail-head {
  background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}

/* ── Settings ── */
.settings-tabs {
  background: #fff;
  padding: 5px;
  border-radius: var(--dash-radius-md);
  box-shadow: var(--dash-shadow);
}

.settings-tab.on {
  box-shadow: 0 4px 12px rgba(29, 78, 216, 0.22);
}

/* ── Buttons ── */
.dash-btn.primary {
  background: linear-gradient(135deg, var(--dash-primary) 0%, #2563eb 100%);
  border: 0;
  box-shadow: 0 4px 14px rgba(29, 78, 216, 0.28);
}

.dash-btn.primary:hover:not(:disabled) {
  background: linear-gradient(135deg, var(--dash-primary-hover) 0%, #1d4ed8 100%);
}

.dash-btn.ok {
  background: var(--dash-accent-soft);
  color: var(--dash-green-text);
  border-color: rgba(25, 169, 116, 0.25);
}

/* ── Badges ── */
.dash-badge {
  font-weight: 700;
  letter-spacing: 0.01em;
}

/* ── Map ── */
.dash-map {
  border-radius: 0;
}

.dash-map-legend {
  background: #fafbfd;
}

.dash-map-updated {
  padding: 4px 10px;
  border-radius: 999px;
  background: #f1f5f9;
  font-size: 10px;
}

/* ── Modal ── */
.dash-modal-panel {
  border-radius: var(--dash-radius);
  box-shadow: var(--dash-shadow-hover);
}

/* ── Offline banner ── */
.dash-offline-banner {
  border-radius: var(--dash-radius-sm);
  margin-bottom: var(--dash-gap);
}

/* ── Announcements grid ── */
.ann-card-grid {
  gap: 16px;
  padding: 18px;
}

.ann-card {
  border-radius: var(--dash-radius-md);
}

/* ── YouTube-style shell: header + mini nav + wide content ── */
.dash-shell-yt {
  --dash-sidebar-w-mini: 72px;
  --dash-sidebar-w-expanded: 240px;
  --dash-sidebar-w: var(--dash-sidebar-w-mini);
  /* YouTube white ratio — أبيض ~92% · رمادي ~8% (chips + search فقط) */
  --dash-yt-chrome-bg: #E9EEF3;
  --dash-yt-sidebar-bg: var(--dash-yt-chrome-bg);
  --dash-yt-sidebar-line: #e3e3e3;
  --dash-yt-header-bg: #E9EEF3;
  --dash-yt-header-line: #E9EEF3;
  --dash-yt-canvas-bg: var(--dash-yt-chrome-bg);
  --dash-yt-ink: #0f0f0f;
  --dash-yt-text-secondary: #606060;
  --dash-yt-text-tertiary: #909090;
  --dash-yt-chip-bg: #f2f2f2;
  --dash-yt-chip-hover: #e5e5e5;
  --dash-yt-muted-bg: var(--dash-yt-chip-bg);
  --dash-yt-surface-bg: #ffffff;
  --dash-yt-surface-border: #e3e3e3;
  --dash-yt-surface-shadow: none;
  --dash-yt-header-shadow: none;
  --dash-yt-search-bg: #f8f8f8;
  --dash-yt-search-border: #cccccc;
  /* T+ — أيقونات القائمة سوداء */
  --tplus-nav-icon: #0f0f0f;
  --tplus-nav-icon-hover: #000000;
  --tplus-nav-icon-active: #000000;
  --tplus-nav-on-bg: rgba(0, 0, 0, 0.06);
}

body.dash-sidebar-expanded.dash-shell-yt {
  --dash-sidebar-w: var(--dash-sidebar-w-expanded);
}

[data-theme="dark"] .dash-shell-yt {
  --dash-yt-chrome-bg: #0f0f0f;
  --dash-yt-sidebar-bg: var(--dash-yt-chrome-bg);
  --dash-yt-sidebar-line: rgba(255, 255, 255, 0.1);
  --dash-yt-header-bg: var(--dash-yt-chrome-bg);
  --dash-yt-header-line: rgba(255, 255, 255, 0.1);
  --dash-yt-canvas-bg: var(--dash-yt-chrome-bg);
  --dash-yt-ink: #f1f1f1;
  --dash-yt-text-secondary: #aaaaaa;
  --dash-yt-text-tertiary: #717171;
  --dash-yt-chip-bg: #272727;
  --dash-yt-chip-hover: #3f3f3f;
  --dash-yt-muted-bg: var(--dash-yt-chip-bg);
  --dash-yt-surface-bg: #0f0f0f;
  --dash-yt-surface-border: rgba(255, 255, 255, 0.1);
  --dash-yt-surface-shadow: none;
  --dash-yt-header-shadow: none;
  --dash-yt-search-bg: #121212;
  --dash-yt-search-border: rgba(255, 255, 255, 0.2);
  --tplus-nav-icon: #aaaaaa;
  --tplus-nav-icon-hover: #f1f1f1;
  --tplus-nav-icon-active: #ffffff;
  --tplus-nav-on-bg: rgba(255, 255, 255, 0.08);
}

.dash-app.dash-shell-yt .dash-main {
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-inline-start: 0 !important;
  margin-inline-end: 0 !important;
  padding-right: var(--dash-sidebar-w) !important;
  padding-left: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0;
  flex: 1;
  box-sizing: border-box !important;
  overflow-x: hidden;
  background: var(--dash-yt-canvas-bg);
  transition: padding-right 0.22s var(--dash-ease);
}

.dash-shell-yt .dash-sidebar--yt {
  width: var(--dash-sidebar-w);
  background: var(--dash-yt-sidebar-bg);
  border-left: 1px solid var(--dash-yt-sidebar-line);
  box-shadow: none;
  transition: width 0.22s var(--dash-ease);
  overflow: hidden;
}

.dash-shell-yt .dash-yt-brand {
  display: none;
  align-items: center;
  gap: 12px;
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--dash-yt-sidebar-line);
  flex-shrink: 0;
}

body.dash-sidebar-expanded.dash-shell-yt .dash-yt-brand {
  display: flex;
}

.dash-shell-yt .dash-yt-brand .dash-brand-text strong {
  font-size: 15px;
  font-weight: 800;
  color: var(--dash-ink);
}

.dash-shell-yt .dash-yt-brand .dash-brand-text small {
  font-size: 11px;
  color: var(--dash-muted);
}

[data-theme="dark"] .dash-shell-yt .dash-yt-brand .dash-brand-text strong {
  color: #f1f5f9;
}

.dash-shell-yt .dash-topbar {
  background: transparent;
  border-bottom: none;
  box-shadow: none;
  left: 0;
  right: 0;
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  box-sizing: border-box;
}

body.dash-sidebar-expanded.dash-shell-yt .dash-sidebar--yt .dash-nav-item {
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  height: auto;
  min-height: 0;
  padding: 8px 12px;
  gap: 14px;
  font-size: 13px;
  text-align: right;
}

body.dash-sidebar-expanded.dash-shell-yt .dash-sidebar--yt .dash-nav-text {
  max-width: none;
  white-space: nowrap;
  font-size: 13px;
}

body.dash-sidebar-expanded.dash-shell-yt .dash-sidebar--yt .dash-nav-icon .fi {
  font-size: 20px;
}

.dash-shell-yt .dash-sidebar--yt .dash-nav {
  padding: 4px 2px 10px;
  display: flex;
  flex-direction: column;
  gap: 0;
  flex: 1;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.dash-shell-yt .dash-sidebar--yt .dash-nav::-webkit-scrollbar {
  display: none;
  width: 0;
  height: 0;
}

.dash-shell-yt .dash-sidebar--yt .dash-nav::-webkit-scrollbar-button,
.dash-shell-yt .dash-sidebar--yt .dash-nav::-webkit-scrollbar-thumb,
.dash-shell-yt .dash-sidebar--yt .dash-nav::-webkit-scrollbar-track {
  display: none;
  width: 0;
  height: 0;
}

.dash-shell-yt .dash-sidebar--yt .dash-nav-item {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 3px;
  width: 100%;
  min-height: 0;
  height: 56px;
  padding: 6px 2px;
  margin: 0;
  border-radius: 10px;
  font-size: 9px;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  color: var(--dash-ink-soft);
  background: transparent;
}

.dash-shell-yt .dash-sidebar--yt .dash-nav-item:hover {
  background: rgba(0, 0, 0, 0.05);
  color: var(--dash-ink);
}

.dash-shell-yt .dash-sidebar--yt .dash-nav-icon .fi {
  font-size: 18px;
  line-height: 1;
  color: var(--tplus-nav-icon);
  filter: none;
  transition: color 0.2s ease, transform 0.15s ease;
}

.dash-shell-yt .dash-sidebar--yt .dash-nav-item:hover .dash-nav-icon .fi {
  color: var(--tplus-nav-icon-hover);
  filter: none;
  transform: scale(1.04);
}

.dash-shell-yt .dash-sidebar--yt .dash-nav-item.on .dash-nav-icon .fi {
  color: var(--tplus-nav-icon-active);
  filter: none;
  transform: none;
}

.dash-shell-yt .dash-sidebar--yt .dash-nav-item.on {
  background: var(--tplus-nav-on-bg);
  color: #0f0f0f;
  font-weight: 800;
  box-shadow: none;
}

@media (prefers-reduced-motion: reduce) {
  .dash-shell-yt .dash-sidebar--yt .dash-nav-icon .fi {
    transition: none;
    transform: none !important;
  }
}

.dash-shell-yt .dash-sidebar--yt .dash-nav-icon {
  width: auto;
  height: auto;
  opacity: 1;
}

.dash-shell-yt .dash-sidebar--yt .dash-nav-text {
  display: block;
  max-width: 64px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 9px;
  line-height: 1.15;
}

[data-theme="dark"] .dash-shell-yt .dash-sidebar--yt .dash-nav-item {
  color: var(--dash-muted);
}

[data-theme="dark"] .dash-shell-yt .dash-sidebar--yt .dash-nav-item:hover {
  background: rgba(255, 255, 255, 0.06);
  color: #f1f5f9;
}

[data-theme="dark"] .dash-shell-yt .dash-sidebar--yt .dash-nav-item.on {
  background: var(--tplus-nav-on-bg);
  color: #ecfdf5;
  box-shadow: none;
}

[data-theme="dark"] .dash-shell-yt .dash-sidebar--yt .dash-nav-item.on .dash-nav-icon .fi {
  color: var(--tplus-nav-icon-active);
  filter: none;
}

.home-yt-quick {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0 12px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.home-yt-quick::-webkit-scrollbar {
  display: none;
}

.home-yt-quick-alerts {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

@media (max-width: 1024px) {
  .dash-app.dash-shell-yt .dash-main {
    padding-right: var(--dash-sidebar-w) !important;
    width: 100% !important;
  }

  .dash-shell-yt .dash-topbar {
    right: 0;
    width: 100%;
  }

  .dash-shell-yt .dash-sidebar--yt {
    transform: none;
    width: var(--dash-sidebar-w);
  }

  .dash-shell-yt .dash-sidebar--yt .dash-nav-item {
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    height: auto;
    min-height: 0;
    padding: 12px 16px;
    gap: 14px;
    font-size: 14px;
    text-align: right;
  }

  .dash-shell-yt .dash-sidebar--yt .dash-nav-icon .fi {
    font-size: 20px;
  }

  .dash-shell-yt .dash-sidebar--yt .dash-nav-text {
    max-width: none;
    white-space: normal;
  }

  .dash-shell-yt .dash-topbar-center,
  .dash-shell-yt .dash-topbar-main .dash-search-wrap--yt {
    display: none;
  }

  .dash-shell-yt .dash-topbar-btn--desktop-only {
    display: none !important;
  }

  .dash-shell-yt .dash-topbar-btn--mobile-only {
    display: inline-grid !important;
  }

  .dash-shell-yt .dash-topbar-head--yt {
    gap: 8px;
    padding: 6px 10px 6px 96px;
  }

  body.dash-shell-yt .dash-topbar-head--yt > .dash-topbar-end,
  .dash-app.dash-shell-yt .dash-topbar-head--yt > .dash-topbar-end {
    left: 8px;
    padding: 0 2px;
  }

  .dash-shell-yt .dash-topbar-main {
    gap: 8px;
    min-width: 0;
  }

  .dash-shell-yt .dash-topbar-title--brand .brand-wordmark {
    font-size: 20px;
  }

  .dash-shell-yt .dash-topbar-title--brand .brand-nashwan {
    font-size: 15px;
  }

  .dash-shell-yt .dash-topbar--sub .dash-topbar-title {
    font-size: 15px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 42vw;
  }

  .dash-app.dash-shell-yt .dash-content {
    padding: 12px 14px 28px;
  }

  .dash-shell-yt .ride-toolbar,
  .dash-shell-yt .cap-toolbar,
  .dash-shell-yt .user-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .dash-shell-yt .ride-search,
  .dash-shell-yt .cap-search,
  .dash-shell-yt .user-search {
    max-width: none;
    width: 100%;
  }

  .dash-shell-yt .ann-layout {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .dash-shell-yt .price-page,
  .dash-shell-yt .settings-page,
  .dash-shell-yt .ann-page,
  .dash-shell-yt .report-page {
    max-width: none;
  }

  .dash-shell-yt .dash-panel-head {
    flex-wrap: wrap;
    gap: 8px;
  }

  .dash-shell-yt .home-stats-bar {
    grid-template-columns: 1fr;
    margin-bottom: 8px;
  }

  .dash-shell-yt .home-stats-bar > .home-yt-quick {
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
    width: auto;
  }

  .dash-shell-yt .home-stats-bar > .dash-stats {
    grid-column: 1;
    grid-row: 2;
  }

  .dash-shell-yt .home-yt-quick {
    padding: 0 0 10px;
  }

  .dash-shell-yt .cap-detail-panel,
  .dash-shell-yt .ride-detail-panel {
    left: 0;
    right: 0;
    width: 100%;
    max-width: none;
    border-radius: 16px 16px 0 0;
    max-height: 92vh;
  }

  body.dash-shell-yt .home-page .dash-panel-home-activity,
  body.dash-shell-yt .home-page .dash-panel-home-rides {
    border-radius: 12px;
  }

@media (max-width: 720px) {
  .home-panel-head-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: auto auto;
    gap: 8px 10px;
    align-items: center;
    direction: rtl;
  }

  .home-panel-head-main {
    display: contents;
  }

  .home-panel-title-btn {
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
  }

  .home-panel-all-btn {
    grid-column: 2;
    grid-row: 1;
    margin: 0;
  }

  .home-panel-head-chips {
    grid-column: 1 / -1;
    grid-row: 2;
    width: 100%;
    padding-inline-start: 0;
    border-inline-start: none;
  }
}

  .dash-shell-yt .price-sys-head {
    padding-bottom: 8px;
  }

  .dash-shell-yt .price-sys-actions {
    flex-wrap: wrap;
    gap: 8px;
  }

  .dash-shell-yt .dash-table-wrap {
    max-height: none;
  }

  .dash-shell-yt .dash-notify-panel {
    left: 0;
    right: auto;
    width: min(320px, calc(100vw - 24px));
  }
}

/* ── YouTube shell — phase 2 polish ── */
.dash-shell-yt .dash-topbar-head--yt {
  display: flex !important;
  align-items: center;
  gap: 10px;
  padding: 8px 16px 8px 168px;
  min-height: var(--dash-topbar-h);
  direction: ltr;
  position: relative;
  box-sizing: border-box;
  background: transparent;
}

body.dash-shell-yt .dash-topbar-head--yt > .dash-topbar-end,
.dash-app.dash-shell-yt .dash-topbar-head--yt > .dash-topbar-end {
  position: fixed;
  top: 0;
  left: 12px;
  height: var(--dash-topbar-h);
  z-index: 130;
  display: flex !important;
  align-items: center;
  justify-content: flex-start;
  gap: 4px;
  margin: 0;
  padding: 0 6px;
  background: transparent;
}

.dash-shell-yt .dash-topbar-head--yt > .dash-topbar-main {
  flex: 1 1 auto;
  direction: rtl;
  min-width: 0;
}

.dash-shell-yt .dash-topbar-main {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.dash-shell-yt .dash-topbar-main .dash-topbar-title {
  flex-shrink: 0;
  margin: 0;
  line-height: 1;
}

.dash-shell-yt .dash-topbar-main .dash-topbar-title:not(.dash-topbar-title--brand) {
  flex-shrink: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 17px;
  font-weight: 900;
}

.dash-shell-yt .dash-topbar-end {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 4px;
  flex-shrink: 0;
}

.dash-shell-yt .dash-search-wrap--yt {
  position: relative;
  display: flex;
  align-items: stretch;
  flex: 1 1 auto;
  width: auto;
  min-width: 0;
  height: 34px;
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid rgba(34, 197, 94, 0.45);
  background: var(--dash-yt-search-bg);
  box-shadow: none;
  transition: border-color 0.2s ease;
}

.dash-shell-yt .dash-search-wrap--yt:focus-within {
  border-color: rgba(34, 197, 94, 0.72);
  box-shadow: none;
}

.dash-shell-yt .dash-search-wrap--yt .dash-search {
  flex: 1;
  min-width: 0;
  height: 100%;
  padding: 0 12px;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  font-size: 13px;
}

.dash-shell-yt .dash-search-wrap--yt .dash-search:focus {
  outline: none;
  box-shadow: none;
}

.dash-shell-yt .dash-search-submit {
  flex-shrink: 0;
  width: 40px;
  height: 100%;
  display: grid;
  place-items: center;
  border: 0;
  border-inline-start: 1px solid rgba(34, 197, 94, 0.22);
  background: rgba(34, 197, 94, 0.06);
  color: #16a34a;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}

.dash-shell-yt .dash-search-submit svg {
  width: 16px;
  height: 16px;
}

.dash-shell-yt .dash-search-submit:hover {
  background: rgba(34, 197, 94, 0.12);
  color: #15803d;
}

.dash-shell-yt .dash-topbar-title {
  margin: 0;
  line-height: 1;
}

.dash-shell-yt .dash-topbar-title--brand .brand-wordmark {
  font-size: 24px;
}

.dash-shell-yt .dash-topbar-title--brand .brand-nashwan {
  font-size: 17px;
}

.dash-shell-yt .dash-yt-brand .brand-lockup--sidebar {
  gap: 0.32em;
}

.dash-shell-yt .dash-yt-brand .brand-lockup--sidebar .brand-nashwan {
  font-size: 14px;
  font-weight: 700;
}

.dash-shell-yt .dash-yt-brand .brand-lockup--sidebar .brand-wordmark--sm {
  font-size: 14px;
}

.dash-shell-yt .dash-topbar--sub .dash-topbar-title {
  font-size: 17px;
  font-weight: 900;
  white-space: nowrap;
}

[data-theme="dark"] .dash-app.dash-shell-yt .dash-content {
  background: var(--dash-yt-canvas-bg);
}

.dash-shell-yt .dash-content-inner {
  width: 100%;
  max-width: none !important;
  margin: 0 !important;
  box-sizing: border-box;
}

/* محتوى الصفحات — كامل العرض (كروت المحتوى فقط، ليس dash-stats) */
.dash-shell-yt .dash-view {
  width: 100%;
  max-width: none !important;
  min-width: 0;
  box-sizing: border-box;
}

.dash-shell-yt .ride-page,
.dash-shell-yt .cap-page,
.dash-shell-yt .user-page,
.dash-shell-yt .home-page,
.dash-shell-yt .price-page,
.dash-shell-yt .ann-page,
.dash-shell-yt .report-page,
.dash-shell-yt .settings-page {
  width: 100%;
  max-width: none !important;
  min-width: 0;
  margin: 0 !important;
  margin-inline: 0 !important;
  box-sizing: border-box;
}

.dash-shell-yt .ann-layout {
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
  margin-inline: 0 !important;
}

.dash-shell-yt .dash-view > .dash-panel,
.dash-shell-yt .ride-page > .dash-panel,
.dash-shell-yt .cap-page > .dash-panel,
.dash-shell-yt .user-page > .dash-panel,
.dash-shell-yt .ann-page .dash-panel,
.dash-shell-yt .report-page .dash-panel,
.dash-shell-yt .settings-page .dash-panel,
.dash-shell-yt .price-page .price-sys-block,
.dash-shell-yt .price-page .price-sys-head,
.dash-shell-yt .price-page .price-form,
.dash-shell-yt #view-offers > .dash-panel {
  width: 100%;
  max-width: none !important;
  min-width: 0;
  box-sizing: border-box;
}

.dash-shell-yt .home-strip-row,
.dash-shell-yt .home-map-row {
  width: 100%;
  max-width: none !important;
  min-width: 0;
}

.dash-shell-yt .home-page .dash-panel-home-map {
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--dash-yt-surface-border);
  box-shadow: var(--dash-yt-surface-shadow);
  background: var(--dash-yt-surface-bg);
}

[data-theme="dark"] .dash-shell-yt .home-page .dash-panel-home-map {
  background: var(--dash-yt-surface-bg);
}

.dash-shell-yt .home-yt-quick {
  padding: 2px 0 14px;
}

/* تنبيهات النظام — يسار، بنفس سطر الإحصائيات */
.dash-shell-yt .home-stats-bar {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  direction: ltr;
}

.dash-shell-yt .home-stats-bar > .home-yt-quick {
  grid-column: 1;
  grid-row: 1;
  margin: 0 !important;
  padding: 0 !important;
  justify-self: start;
}

.dash-shell-yt .home-stats-bar > .dash-stats {
  grid-column: 2;
  grid-row: 1;
  direction: rtl;
  flex: none;
  margin-bottom: 0;
  min-width: 0;
}

.dash-shell-yt .home-stats-bar .home-yt-quick-alerts {
  gap: 6px;
}

.dash-shell-yt .home-stats-bar .alert-rail-btn {
  width: 32px;
  height: 32px;
  min-height: 32px;
  padding: 0;
  border-radius: 50%;
  flex-direction: row;
  justify-content: center;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(15, 118, 110, 0.14);
  box-shadow: none;
}

.dash-shell-yt .home-stats-bar .alert-rail-icon .fi {
  font-size: 15px;
}

.dash-shell-yt .home-stats-bar .alert-rail-btn:hover {
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(15, 118, 110, 0.24);
  box-shadow: none;
}

.dash-shell-yt .home-stats-bar .alert-rail-btn.on {
  background: rgba(255, 255, 255, 0.95);
  border-color: rgba(15, 118, 110, 0.32);
  box-shadow: none;
}

[data-theme="dark"] .dash-shell-yt .home-stats-bar .alert-rail-btn {
  background: rgba(15, 23, 42, 0.32);
  border-color: rgba(167, 243, 208, 0.18);
}

[data-theme="dark"] .dash-shell-yt .home-stats-bar .alert-rail-btn:hover {
  background: rgba(15, 23, 42, 0.48);
  border-color: rgba(167, 243, 208, 0.28);
}

.dash-shell-yt .home-yt-quick .alert-rail-btn {
  font-size: 13px;
  font-weight: 700;
}

body.dash-shell-yt .dash-view > .home-stats-bar,
body.dash-shell-yt .dash-view > .dash-stats,
body.dash-shell-yt .dash-view > .dash-stats--8,
body.dash-shell-yt .ride-page > .dash-stats,
body.dash-shell-yt .cap-page > .dash-stats,
body.dash-shell-yt .user-page > .dash-stats,
body.dash-shell-yt .price-page > .price-stats,
body.dash-shell-yt .ann-page > .ann-stats,
body.dash-shell-yt .report-page > .dash-stats,
body.dash-shell-yt .settings-page > .settings-stats,
body.dash-shell-yt .dash-view > .offer-stats {
  margin-bottom: 14px;
}

[data-theme="dark"] .dash-shell-yt .dash-search-wrap--yt {
  background: var(--dash-yt-search-bg);
  border-color: rgba(74, 222, 128, 0.42);
  box-shadow: none;
}

[data-theme="dark"] .dash-shell-yt .dash-search-wrap--yt:focus-within {
  border-color: rgba(134, 239, 172, 0.65);
  box-shadow: none;
}

[data-theme="dark"] .dash-shell-yt .dash-search-wrap--yt .dash-search {
  color: #f1f5f9;
}

[data-theme="dark"] .dash-shell-yt .dash-search-submit {
  background: rgba(34, 197, 94, 0.1);
  border-inline-start-color: rgba(74, 222, 128, 0.22);
  color: #86efac;
}

[data-theme="dark"] .dash-shell-yt .dash-search-submit:hover {
  background: rgba(34, 197, 94, 0.16);
  color: #bbf7d0;
}

.dash-shell-yt .dash-panel:not(.dash-panel-home-activity):not(.dash-panel-home-rides) {
  border-radius: 16px;
  border: 1px solid var(--dash-yt-surface-border);
  box-shadow: var(--dash-yt-surface-shadow);
  background: var(--dash-yt-surface-bg);
}

[data-theme="dark"] .dash-shell-yt .dash-panel:not(.dash-panel-home-activity):not(.dash-panel-home-rides) {
  background: var(--dash-yt-surface-bg);
}

[data-theme="light"] .dash-shell-yt .dash-topbar,
[data-theme="light"] body.dash-shell-yt .dash-topbar,
[data-theme="light"] .dash-app.dash-shell-yt .dash-topbar,
[data-theme="light"] .dash-shell-yt .dash-topbar-head--yt,
[data-theme="light"] body.dash-shell-yt .dash-topbar-head--yt > .dash-topbar-end,
[data-theme="light"] .dash-app.dash-shell-yt .dash-topbar-head--yt > .dash-topbar-end {
  background: transparent;
  border-bottom: none;
  box-shadow: none;
}

.dash-shell-yt .dash-topbar-end .dash-topbar-btn {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: none;
  background: transparent;
  color: var(--dash-ink-soft);
}

.dash-shell-yt .dash-topbar-end .dash-topbar-btn:hover {
  background: rgba(15, 23, 42, 0.06);
  border-color: transparent;
}

.dash-shell-yt .dash-topbar-end .dash-topbar-btn svg {
  stroke: currentColor;
}

.dash-shell-yt .dash-topbar-end .dash-topbar-btn .fi {
  color: inherit;
}

.dash-shell-yt .dash-topbar-title--brand .brand-wordmark {
  color: var(--dash-ink);
}

[data-theme="dark"] .dash-shell-yt .dash-topbar-title--brand .brand-wordmark,
[data-theme="dark"] .dash-shell-yt .dash-topbar--sub .dash-topbar-title {
  color: #f1f5f9;
}

[data-theme="dark"] .dash-shell-yt .dash-topbar-end .dash-topbar-btn {
  color: #e2e8f0;
}

[data-theme="dark"] .dash-shell-yt .dash-topbar-end .dash-topbar-btn:hover {
  background: rgba(255, 255, 255, 0.08);
}

body.dash-shell-yt .home-page .dash-panel-home-activity,
body.dash-shell-yt .home-page .dash-panel-home-rides {
  background: #A0F3E1 !important;
  border: none !important;
  border-radius: 10px;
  box-shadow: none !important;
  overflow: hidden;
}

[data-theme="dark"] body.dash-shell-yt .home-page .dash-panel-home-activity,
[data-theme="dark"] body.dash-shell-yt .home-page .dash-panel-home-rides {
  background: #1e4d44 !important;
  box-shadow: none !important;
}

/* الكارت الكبير — نفس أسلوب mint للإحصائيات */
.dash-shell-yt .home-page .dash-panel-home-activity .dash-panel-head,
.dash-shell-yt .home-page .dash-panel-home-rides .dash-panel-head {
  background: transparent !important;
  border-bottom: none !important;
  padding: 10px 12px 0;
}

.dash-shell-yt .home-page .dash-panel-home-activity .home-panel-live-foot,
.dash-shell-yt .home-page .dash-panel-home-rides .home-panel-live-foot {
  background: transparent !important;
  border-top: none !important;
  padding: 4px 12px 10px !important;
}

.dash-shell-yt .home-panel-head-row--activity,
.dash-shell-yt .home-panel-head-row--rides {
  padding: 0;
}

.dash-shell-yt .home-panel-head-row--activity:hover,
.dash-shell-yt .home-panel-head-row--rides:hover {
  background: transparent;
}

.dash-shell-yt .home-panel-title-btn h3 {
  color: rgba(15, 23, 42, 0.82);
  font-size: 12px;
  font-weight: 800;
}

[data-theme="dark"] .dash-shell-yt .home-panel-title-btn h3 {
  color: #ecfdf5;
}

.dash-shell-yt .home-panel-head-chips {
  border-inline-start-color: rgba(15, 118, 110, 0.22);
}

.dash-shell-yt .home-panel-head-empty {
  color: rgba(6, 95, 70, 0.62);
  font-weight: 700;
}

[data-theme="dark"] .dash-shell-yt .home-panel-head-empty {
  color: rgba(167, 243, 208, 0.72);
}

.dash-shell-yt .home-panel-head-summary .home-ride-chip {
  background: rgba(255, 255, 255, 0.52);
  border-color: rgba(15, 118, 110, 0.16);
  box-shadow: none;
}

.dash-shell-yt .home-panel-head-summary .home-ride-chip:hover {
  background: rgba(255, 255, 255, 0.72);
  box-shadow: none;
  transform: none;
}

[data-theme="dark"] .dash-shell-yt .home-panel-head-summary .home-ride-chip {
  background: rgba(15, 23, 42, 0.22);
  border-color: rgba(167, 243, 208, 0.14);
}

[data-theme="dark"] .dash-shell-yt .home-panel-head-summary .home-ride-chip:hover {
  background: rgba(15, 23, 42, 0.32);
}

.dash-shell-yt .home-summary-live-foot--activity .home-summary-live-caption,
.dash-shell-yt .home-summary-live-foot--rides .home-summary-live-caption {
  color: rgba(6, 95, 70, 0.58);
  font-size: 9px;
  font-weight: 600;
}

[data-theme="dark"] .dash-shell-yt .home-summary-live-foot--activity .home-summary-live-caption,
[data-theme="dark"] .dash-shell-yt .home-summary-live-foot--rides .home-summary-live-caption {
  color: rgba(167, 243, 208, 0.62);
}

.dash-shell-yt .home-summary-live-line {
  background: rgba(15, 118, 110, 0.18);
}

.dash-shell-yt .home-summary-live-line-fill {
  background: linear-gradient(90deg, #0f766e, #14b8a6, #0d9488);
}

.dash-shell-yt .home-page .dash-panel-home-activity .home-see-all,
.dash-shell-yt .home-page .dash-panel-home-rides .home-see-all {
  color: #0f766e;
  background: rgba(255, 255, 255, 0.48);
  border-color: rgba(15, 118, 110, 0.22);
}

.dash-shell-yt .home-page .dash-panel-home-activity .home-panel-all-btn:hover .home-see-all,
.dash-shell-yt .home-page .dash-panel-home-rides .home-panel-all-btn:hover .home-see-all {
  background: rgba(255, 255, 255, 0.68);
  border-color: rgba(15, 118, 110, 0.32);
  transform: none;
}

[data-theme="dark"] .dash-shell-yt .home-page .dash-panel-home-activity .home-see-all,
[data-theme="dark"] .dash-shell-yt .home-page .dash-panel-home-rides .home-see-all {
  color: #a7f3d0;
  background: rgba(15, 23, 42, 0.28);
  border-color: rgba(167, 243, 208, 0.2);
}

/* ── Stats tiles — square mint, number in bottom corner ── */
.dash-shell-yt .dash-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 10px;
}

.dash-shell-yt .dash-stats > .dash-stat,
.dash-shell-yt .dash-stats > .home-stat-card {
  position: relative;
  box-sizing: border-box;
  width: 70px;
  height: 70px;
  aspect-ratio: 1;
  flex: 0 0 70px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  gap: 0;
  padding: 6px;
  border-radius: 10px;
  border: none;
  background: #A0F3E1;
  box-shadow: none;
  text-align: start;
  overflow: hidden;
}

.dash-shell-yt .dash-stats > .dash-stat::before,
.dash-shell-yt .dash-stats > .dash-stat::after {
  display: none;
}

.dash-shell-yt .dash-stats > .dash-stat:hover {
  transform: none;
  box-shadow: none;
  border: none;
}

.dash-shell-yt .dash-stats .dash-stat-icon,
.dash-shell-yt .dash-stats .home-stat-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  width: auto;
  height: auto;
  margin: 0 0 2px;
  padding: 0;
  background: transparent;
  border-radius: 0;
  color: #0f172a;
  font-size: 13px;
  line-height: 1;
  flex-shrink: 0;
}

.dash-shell-yt .dash-stats .dash-stat-icon .fi,
.dash-shell-yt .dash-stats .home-stat-card-icon .fi {
  font-size: 13px;
  line-height: 1;
}

.dash-shell-yt .dash-stats .dash-stat-body {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-end;
  flex: 1;
  gap: 0;
  min-width: 0;
  min-height: 0;
  width: 100%;
}

.dash-shell-yt .dash-stats .dash-stat-label,
.dash-shell-yt .dash-stats .home-stat-card-label {
  order: 0;
  font-size: 7px;
  font-weight: 600;
  line-height: 1.15;
  color: rgba(15, 23, 42, 0.72);
  margin: 0;
  text-align: center;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.dash-shell-yt .dash-stats .dash-stat-value,
.dash-shell-yt .dash-stats .home-stat-card-value {
  order: 1;
  align-self: flex-start;
  margin-top: auto;
  padding-top: 2px;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  background: linear-gradient(125deg, #064e3b 0%, #0f766e 42%, #0d9488 78%, #047857 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.dash-shell-yt .dash-stats > .accent-blue .dash-stat-value,
.dash-shell-yt .dash-stats > .tone-blue .dash-stat-value {
  background: linear-gradient(125deg, #134e4a 0%, #0e7490 50%, #0d9488 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

.dash-shell-yt .dash-stats > .accent-green .dash-stat-value,
.dash-shell-yt .dash-stats > .tone-green .dash-stat-value {
  background: linear-gradient(125deg, #065f46 0%, #047857 55%, #10b981 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

.dash-shell-yt .dash-stats > .accent-amber .dash-stat-value,
.dash-shell-yt .dash-stats > .tone-amber .dash-stat-value {
  background: linear-gradient(125deg, #115e59 0%, #0f766e 45%, #059669 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

.dash-shell-yt .dash-stats > .accent-gold .dash-stat-value,
.dash-shell-yt .dash-stats > .tone-gold .dash-stat-value {
  background: linear-gradient(125deg, #064e3b 0%, #0d9488 40%, #047857 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

.dash-shell-yt .dash-stats > .accent-purple .dash-stat-value,
.dash-shell-yt .dash-stats > .tone-purple .dash-stat-value {
  background: linear-gradient(125deg, #134e4a 0%, #0f766e 50%, #0891b2 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

.dash-shell-yt .dash-stats > .accent-cyan .dash-stat-value,
.dash-shell-yt .dash-stats > .tone-cyan .dash-stat-value {
  background: linear-gradient(125deg, #155e75 0%, #0e7490 50%, #14b8a6 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

.dash-shell-yt .dash-stats > .accent-blue .dash-stat-icon,
.dash-shell-yt .dash-stats > .tone-blue .dash-stat-icon { color: #0e7490; }

.dash-shell-yt .dash-stats > .accent-green .dash-stat-icon,
.dash-shell-yt .dash-stats > .tone-green .dash-stat-icon { color: #047857; }

.dash-shell-yt .dash-stats > .accent-amber .dash-stat-icon,
.dash-shell-yt .dash-stats > .tone-amber .dash-stat-icon { color: #0f766e; }

.dash-shell-yt .dash-stats > .accent-gold .dash-stat-icon,
.dash-shell-yt .dash-stats > .tone-gold .dash-stat-icon { color: #0d9488; }

.dash-shell-yt .dash-stats > .accent-purple .dash-stat-icon,
.dash-shell-yt .dash-stats > .tone-purple .dash-stat-icon { color: #0891b2; }

.dash-shell-yt .dash-stats > .accent-cyan .dash-stat-icon,
.dash-shell-yt .dash-stats > .tone-cyan .dash-stat-icon { color: #14b8a6; }

.dash-shell-yt .dash-stats .dash-stat-icon,
.dash-shell-yt .dash-stats .home-stat-card-icon {
  color: #0f766e;
}

.dash-shell-yt .dash-stats .dash-stat-sub,
.dash-shell-yt .dash-stats .home-stat-card-sub {
  order: 2;
  align-self: flex-start;
  font-size: 6px;
  font-weight: 500;
  line-height: 1.1;
  color: rgba(6, 95, 70, 0.52);
  margin: 1px 0 0;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

[data-theme="dark"] .dash-shell-yt .dash-stats > .dash-stat,
[data-theme="dark"] .dash-shell-yt .dash-stats > .home-stat-card {
  background: #1e4d44;
  border: none;
}

[data-theme="dark"] .dash-shell-yt .dash-stats .dash-stat-label,
[data-theme="dark"] .dash-shell-yt .dash-stats .home-stat-card-label {
  color: #ecfdf5;
}

[data-theme="dark"] .dash-shell-yt .dash-stats .dash-stat-value,
[data-theme="dark"] .dash-shell-yt .dash-stats .home-stat-card-value {
  background: linear-gradient(125deg, #a7f3d0 0%, #5eead4 45%, #67e8f9 85%, #6ee7b7 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

[data-theme="dark"] .dash-shell-yt .dash-stats > .accent-blue .dash-stat-value,
[data-theme="dark"] .dash-shell-yt .dash-stats > .tone-blue .dash-stat-value {
  background: linear-gradient(125deg, #99f6e4 0%, #67e8f9 55%, #5eead4 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

[data-theme="dark"] .dash-shell-yt .dash-stats > .accent-green .dash-stat-value,
[data-theme="dark"] .dash-shell-yt .dash-stats > .tone-green .dash-stat-value {
  background: linear-gradient(125deg, #6ee7b7 0%, #34d399 55%, #a7f3d0 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

[data-theme="dark"] .dash-shell-yt .dash-stats > .accent-amber .dash-stat-value,
[data-theme="dark"] .dash-shell-yt .dash-stats > .tone-amber .dash-stat-value {
  background: linear-gradient(125deg, #5eead4 0%, #2dd4bf 50%, #6ee7b7 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

[data-theme="dark"] .dash-shell-yt .dash-stats > .accent-gold .dash-stat-value,
[data-theme="dark"] .dash-shell-yt .dash-stats > .tone-gold .dash-stat-value {
  background: linear-gradient(125deg, #99f6e4 0%, #5eead4 45%, #34d399 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

[data-theme="dark"] .dash-shell-yt .dash-stats > .accent-purple .dash-stat-value,
[data-theme="dark"] .dash-shell-yt .dash-stats > .tone-purple .dash-stat-value {
  background: linear-gradient(125deg, #5eead4 0%, #67e8f9 50%, #2dd4bf 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

[data-theme="dark"] .dash-shell-yt .dash-stats > .accent-cyan .dash-stat-value,
[data-theme="dark"] .dash-shell-yt .dash-stats > .tone-cyan .dash-stat-value {
  background: linear-gradient(125deg, #67e8f9 0%, #22d3ee 50%, #5eead4 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

[data-theme="dark"] .dash-shell-yt .dash-stats > .accent-blue .dash-stat-icon,
[data-theme="dark"] .dash-shell-yt .dash-stats > .tone-blue .dash-stat-icon { color: #67e8f9; }

[data-theme="dark"] .dash-shell-yt .dash-stats > .accent-green .dash-stat-icon,
[data-theme="dark"] .dash-shell-yt .dash-stats > .tone-green .dash-stat-icon { color: #6ee7b7; }

[data-theme="dark"] .dash-shell-yt .dash-stats > .accent-amber .dash-stat-icon,
[data-theme="dark"] .dash-shell-yt .dash-stats > .tone-amber .dash-stat-icon { color: #5eead4; }

[data-theme="dark"] .dash-shell-yt .dash-stats > .accent-gold .dash-stat-icon,
[data-theme="dark"] .dash-shell-yt .dash-stats > .tone-gold .dash-stat-icon { color: #2dd4bf; }

[data-theme="dark"] .dash-shell-yt .dash-stats > .accent-purple .dash-stat-icon,
[data-theme="dark"] .dash-shell-yt .dash-stats > .tone-purple .dash-stat-icon { color: #22d3ee; }

[data-theme="dark"] .dash-shell-yt .dash-stats > .accent-cyan .dash-stat-icon,
[data-theme="dark"] .dash-shell-yt .dash-stats > .tone-cyan .dash-stat-icon { color: #5eead4; }

[data-theme="dark"] .dash-shell-yt .dash-stats .dash-stat-icon,
[data-theme="dark"] .dash-shell-yt .dash-stats .home-stat-card-icon {
  color: #5eead4;
}

[data-theme="dark"] .dash-shell-yt .dash-stats .dash-stat-label,
[data-theme="dark"] .dash-shell-yt .dash-stats .home-stat-card-label {
  color: rgba(236, 253, 245, 0.72);
}

[data-theme="dark"] .dash-shell-yt .dash-stats .dash-stat-sub,
[data-theme="dark"] .dash-shell-yt .dash-stats .home-stat-card-sub {
  color: rgba(236, 253, 245, 0.55);
}

@media (max-width: 640px) {
  .dash-shell-yt .dash-stats {
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding-bottom: 2px;
  }

  .dash-shell-yt .dash-stats::-webkit-scrollbar {
    display: none;
  }

  .dash-shell-yt .dash-stats > .dash-stat,
  .dash-shell-yt .dash-stats > .home-stat-card {
    flex: 0 0 64px;
    width: 64px;
    height: 64px;
    scroll-snap-align: start;
    padding: 5px;
    border-radius: 9px;
  }

  .dash-shell-yt .dash-stats .dash-stat-value,
  .dash-shell-yt .dash-stats .home-stat-card-value {
    font-size: 10px;
  }
}

/* ── YouTube shell — inner pages (rides, captains, settings, …) ── */
.dash-shell-yt .dash-panel {
  border-radius: 16px;
  border: 1px solid var(--dash-yt-surface-border);
  box-shadow: var(--dash-yt-surface-shadow);
  background: var(--dash-yt-surface-bg);
}

.dash-shell-yt .dash-panel:hover {
  box-shadow: var(--dash-yt-surface-shadow);
}

.dash-shell-yt .dash-panel-head {
  background: var(--dash-yt-surface-bg);
  border-bottom: 1px solid var(--dash-yt-surface-border);
  padding: 14px 18px;
}

.dash-shell-yt .home-page .dash-panel-home-activity .dash-panel-head,
.dash-shell-yt .home-page .dash-panel-home-rides .dash-panel-head {
  border-bottom: none !important;
  padding-bottom: 0;
}

.dash-shell-yt .home-page .dash-panel-home-activity .home-panel-live-foot,
.dash-shell-yt .home-page .dash-panel-home-rides .home-panel-live-foot {
  background: transparent !important;
  border-top: none !important;
}

.dash-shell-yt .dash-panel-head h3 {
  font-size: 15px;
  font-weight: 800;
}

/* List pages: filters on canvas, table in white card */
.dash-shell-yt .ride-panel,
.dash-shell-yt .cap-panel,
.dash-shell-yt .user-panel {
  background: transparent;
  border: none;
  box-shadow: none;
  border-radius: 0;
  overflow: visible;
}

.dash-shell-yt .ride-toolbar,
.dash-shell-yt .cap-toolbar,
.dash-shell-yt .user-toolbar {
  background: transparent;
  border-bottom: none;
  padding: 0 0 12px;
  gap: 10px;
}

.dash-shell-yt .ride-panel .dash-panel-body.flush,
.dash-shell-yt .cap-panel .dash-panel-body.flush,
.dash-shell-yt .user-panel .dash-panel-body.flush {
  background: var(--dash-yt-chrome-bg);
  border: none;
  border-top: 1px solid var(--dash-yt-surface-border);
  border-radius: 0;
  box-shadow: none;
  overflow: hidden;
}

.dash-shell-yt .ride-filters,
.dash-shell-yt .cap-filters {
  flex: 1 1 auto;
  min-width: 0;
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  gap: 8px;
  padding-bottom: 2px;
}

.dash-shell-yt .ride-filters::-webkit-scrollbar,
.dash-shell-yt .cap-filters::-webkit-scrollbar {
  display: none;
}

.dash-shell-yt .ride-filter,
.dash-shell-yt .cap-filter,
.dash-shell-yt .settings-tab,
.dash-shell-yt .ann-mock-tab {
  flex-shrink: 0;
  padding: 8px 14px;
  border-radius: 999px;
  border: none;
  background: var(--dash-yt-muted-bg);
  color: var(--dash-ink-soft);
  font-size: 13px;
  font-weight: 700;
  box-shadow: none;
  transition: background 0.15s ease, color 0.15s ease;
}

.dash-shell-yt .ride-filter:hover,
.dash-shell-yt .cap-filter:hover,
.dash-shell-yt .settings-tab:hover,
.dash-shell-yt .ann-mock-tab:hover {
  background: var(--dash-yt-chip-hover);
  color: var(--dash-yt-ink);
}

.dash-shell-yt .ride-filter.on,
.dash-shell-yt .cap-filter.on,
.dash-shell-yt .settings-tab.on,
.dash-shell-yt .ann-mock-tab.on {
  background: var(--dash-yt-ink);
  border-color: var(--dash-yt-ink);
  color: #ffffff;
  box-shadow: none;
}

[data-theme="dark"] .dash-shell-yt .ride-filter,
[data-theme="dark"] .dash-shell-yt .cap-filter,
[data-theme="dark"] .dash-shell-yt .settings-tab,
[data-theme="dark"] .dash-shell-yt .ann-mock-tab {
  box-shadow: none;
}

[data-theme="dark"] .dash-shell-yt .ride-filter:hover,
[data-theme="dark"] .dash-shell-yt .cap-filter:hover,
[data-theme="dark"] .dash-shell-yt .settings-tab:hover,
[data-theme="dark"] .dash-shell-yt .ann-mock-tab:hover {
  background: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .dash-shell-yt .ride-filter.on,
[data-theme="dark"] .dash-shell-yt .cap-filter.on,
[data-theme="dark"] .dash-shell-yt .settings-tab.on,
[data-theme="dark"] .dash-shell-yt .ann-mock-tab.on {
  background: #ffffff;
  border-color: #ffffff;
  color: #0f0f0f;
}

.dash-shell-yt .dash-filter-input,
.dash-shell-yt .dash-filter-select {
  border-radius: 999px;
  background: var(--dash-yt-search-bg);
  border: 1px solid rgba(15, 23, 42, 0.08);
  font-size: 14px;
  font-weight: 600;
  min-height: 40px;
  box-shadow: none;
}

.dash-shell-yt .dash-filter-input:focus,
.dash-shell-yt .dash-filter-select:focus {
  border-color: rgba(15, 23, 42, 0.18);
  box-shadow: 0 0 0 2px rgba(15, 23, 42, 0.06);
  background: var(--dash-yt-surface-bg);
}

[data-theme="dark"] .dash-shell-yt .dash-filter-input,
[data-theme="dark"] .dash-shell-yt .dash-filter-select {
  border-color: rgba(255, 255, 255, 0.12);
  color: #f1f5f9;
}

[data-theme="dark"] .dash-shell-yt .dash-filter-input:focus,
[data-theme="dark"] .dash-shell-yt .dash-filter-select:focus {
  border-color: rgba(255, 255, 255, 0.22);
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.08);
}

.dash-shell-yt .dash-table th {
  background: var(--dash-yt-chrome-bg);
  font-size: 12px;
  font-weight: 800;
  color: var(--dash-yt-text-secondary);
  border-bottom: 1px solid var(--dash-yt-surface-border);
}

.dash-shell-yt .dash-table td {
  background: var(--dash-yt-chrome-bg);
  border-bottom: 1px solid var(--dash-yt-surface-border);
}

.dash-shell-yt .dash-table tbody tr:hover td {
  background: var(--dash-yt-chip-bg);
}

[data-theme="dark"] .dash-shell-yt .dash-table tbody tr:hover td {
  background: var(--dash-yt-chip-bg);
}

.dash-shell-yt .dash-table-empty {
  background: var(--dash-yt-surface-bg);
}

.dash-shell-yt .ride-split-head {
  background: var(--dash-yt-surface-bg);
  border-bottom: 1px solid var(--dash-yt-surface-border);
}

.dash-shell-yt .ride-split-col .ride-card {
  border-radius: 12px;
  border: 1px solid var(--dash-yt-surface-border);
  background: var(--dash-yt-surface-bg);
}

.dash-shell-yt .cap-grid {
  padding: 16px;
  gap: 12px;
}

.dash-shell-yt .cap-card {
  border-radius: 14px;
  border: 1px solid var(--dash-yt-surface-border);
  background: var(--dash-yt-surface-bg);
  box-shadow: var(--dash-yt-surface-shadow);
}

.dash-shell-yt .cap-card:hover {
  border-color: rgba(15, 23, 42, 0.14);
  box-shadow: var(--dash-yt-surface-shadow);
}

.dash-shell-yt .cap-detail-panel,
.dash-shell-yt .ride-detail-panel {
  background: var(--dash-yt-surface-bg);
  border-inline-start: 1px solid var(--dash-yt-surface-border);
  box-shadow: -8px 0 32px rgba(15, 23, 42, 0.1);
}

.dash-shell-yt .cap-detail-head,
.dash-shell-yt .ride-detail-head {
  background: var(--dash-yt-surface-bg);
  border-bottom: 1px solid var(--dash-yt-surface-border);
}

[data-theme="dark"] .dash-shell-yt .cap-detail-panel,
[data-theme="dark"] .dash-shell-yt .ride-detail-panel {
  box-shadow: -8px 0 32px rgba(0, 0, 0, 0.45);
}

/* Pricing */
.dash-shell-yt .price-page {
  gap: 16px;
  max-width: 100%;
  margin: 0;
  width: 100%;
}

.dash-shell-yt .price-sys-head {
  padding: 0 0 4px;
  border-bottom: none;
}

.dash-shell-yt .price-sys-block {
  border-radius: 16px;
  border: 1px solid var(--dash-yt-surface-border);
  background: var(--dash-yt-surface-bg);
  box-shadow: var(--dash-yt-surface-shadow);
}

.dash-shell-yt .price-sys-section-icon {
  background: var(--dash-yt-muted-bg);
  border-color: transparent;
}

.dash-shell-yt .price-sys-field input {
  border-radius: 12px;
  background: var(--dash-yt-search-bg);
  border-color: var(--dash-yt-surface-border);
}

/* Settings */
.dash-shell-yt .settings-page {
  max-width: 100%;
  width: 100%;
  margin: 0;
  gap: 12px;
}

.dash-shell-yt .settings-tabs {
  width: 100%;
  max-width: 100%;
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0 0 12px;
  gap: 8px;
}

.dash-shell-yt .settings-tabs::-webkit-scrollbar {
  display: none;
}

.dash-shell-yt .settings-page .dash-panel {
  border-radius: 16px;
}

.dash-shell-yt .settings-page .dash-field input,
.dash-shell-yt .settings-page .dash-field select,
.dash-shell-yt .settings-page .dash-field textarea,
.dash-shell-yt .ann-form .dash-field input,
.dash-shell-yt .ann-form .dash-field select,
.dash-shell-yt .ann-form .dash-field textarea {
  border-radius: 12px;
  background: var(--dash-yt-search-bg);
  border-color: var(--dash-yt-surface-border);
}

/* Announcements & reports */
.dash-shell-yt .ann-page,
.dash-shell-yt .report-page {
  max-width: 100%;
  margin: 0;
  width: 100%;
}

.dash-shell-yt .ann-layout {
  max-width: none;
  gap: 16px;
}

.dash-shell-yt .report-card-body {
  padding: 18px 20px 22px;
}

.dash-shell-yt .report-section {
  border-radius: 12px;
  border: 1px solid var(--dash-yt-surface-border);
  background: var(--dash-yt-chrome-bg);
  padding: 14px 16px;
}

[data-theme="dark"] .dash-shell-yt .report-section {
  background: var(--dash-yt-chrome-bg);
}

.dash-shell-yt .dash-btn:not(.primary) {
  border-radius: 999px;
  border: 1px solid var(--dash-yt-surface-border);
  background: var(--dash-yt-surface-bg);
  font-weight: 700;
}

.dash-shell-yt .dash-btn.primary {
  border-radius: 999px;
  font-weight: 800;
}

.dash-shell-yt .release-guide,
.dash-shell-yt .settings-page .release-layout > .dash-panel {
  border-radius: 12px;
  border: 1px solid var(--dash-yt-surface-border);
  background: var(--dash-yt-chrome-bg);
  box-shadow: none;
}

/* كروت المحتوى — حد فقط بدون ظل (نسبة بياض YouTube) */
.dash-shell-yt .dash-panel,
body.dash-shell-yt .home-page .dash-panel-home-activity,
body.dash-shell-yt .home-page .dash-panel-home-rides,
.dash-shell-yt .home-page .dash-panel-home-map,
.dash-shell-yt .price-sys-block {
  box-shadow: none !important;
}

.dash-shell-yt .dash-filter-input,
.dash-shell-yt .dash-filter-select {
  border-color: var(--dash-yt-search-border);
  background: var(--dash-yt-search-bg);
}

.dash-shell-yt .dash-filter-input:focus,
.dash-shell-yt .dash-filter-select:focus {
  border-color: var(--dash-yt-search-border);
  box-shadow: none;
  background: var(--dash-yt-chrome-bg);
}

.dash-shell-yt .price-sys-section-icon {
  background: var(--dash-yt-chip-bg);
  border-color: transparent;
}

/* ── Mobile: search sheet + more menu ── */
.dash-topbar-btn--mobile-only {
  display: none;
}

.dash-topbar-more-wrap {
  position: relative;
}

.dash-topbar-more-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 200px;
  padding: 6px;
  border-radius: 12px;
  border: 1px solid var(--dash-yt-surface-border, #e3e3e3);
  background: var(--dash-yt-chrome-bg, #fff);
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.12);
  z-index: 200;
}

.dash-topbar-more-item {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 12px 14px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--dash-yt-ink, #0f0f0f);
  font-size: 14px;
  font-weight: 700;
  text-align: right;
  cursor: pointer;
}

.dash-topbar-more-item .fi {
  font-size: 18px;
  color: var(--dash-yt-text-secondary, #606060);
}

.dash-topbar-more-item:hover {
  background: var(--dash-yt-chip-bg, #f2f2f2);
}

.dash-topbar-more-item--danger {
  color: #dc2626;
}

.dash-topbar-more-item--danger .fi {
  color: #dc2626;
}

.dash-mobile-search-sheet {
  position: fixed;
  inset: 0;
  z-index: 300;
}

.dash-mobile-search-sheet[hidden] {
  display: none !important;
}

.dash-mobile-search-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 15, 15, 0.35);
}

.dash-mobile-search-panel {
  position: relative;
  z-index: 1;
  background: var(--dash-yt-chrome-bg, #fff);
  border-bottom: 1px solid var(--dash-yt-header-line, #e3e3e3);
  padding: 10px 12px calc(10px + env(safe-area-inset-top, 0px));
  padding-top: calc(10px + env(safe-area-inset-top, 0px));
}

.dash-mobile-search-bar {
  display: flex;
  align-items: center;
  gap: 8px;
}

.dash-mobile-search-back {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--dash-yt-ink, #0f0f0f);
  cursor: pointer;
}

.dash-mobile-search-back svg {
  width: 22px;
  height: 22px;
}

.dash-search-wrap--mobile {
  flex: 1;
  min-width: 0;
  width: auto;
  max-width: none;
}

[data-theme="dark"] .dash-topbar-more-menu {
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
}

[data-theme="dark"] .dash-mobile-search-backdrop {
  background: rgba(0, 0, 0, 0.55);
}

/* ── YT shell — المحتوى لا يدخل خلف القائمة (الهيدر كامل) ── */
body.dash-shell-yt .dash-content {
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-inline: 0 !important;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow-x: hidden;
  box-sizing: border-box;
}

body.dash-shell-yt .dash-content-inner,
body.dash-shell-yt .dash-view,
body.dash-shell-yt .home-page,
body.dash-shell-yt .ride-page,
body.dash-shell-yt .cap-page,
body.dash-shell-yt .user-page,
body.dash-shell-yt .price-page,
body.dash-shell-yt .ann-page,
body.dash-shell-yt .report-page,
body.dash-shell-yt .settings-page {
  max-width: 100%;
  min-width: 0;
  overflow-x: hidden;
  box-sizing: border-box;
}

body.dash-shell-yt,
.dash-app.dash-shell-yt {
  background: var(--dash-yt-canvas-bg);
}

html.dash-ui-compact body.dash-shell-yt .dash-content-inner {
  padding-inline: 20px;
}

/* ── Header: شفاف = يندمج مع الخلفية ── */
html[data-theme="light"] .dash-topbar,
html[data-theme="light"] .dash-topbar-head,
html[data-theme="light"] .dash-topbar-head--yt,
html[data-theme="light"] .dash-app.dash-shell-yt .dash-topbar,
html[data-theme="light"] body.dash-shell-yt .dash-topbar-head--yt,
html[data-theme="light"] body.dash-shell-yt .dash-topbar-head--yt > .dash-topbar-end,
html[data-theme="light"] .dash-app.dash-shell-yt .dash-topbar-head--yt > .dash-topbar-end {
  background: transparent !important;
  background-image: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

/* ── v230: هيدر + رئيسية (بعد استعادة CSS) ── */
.dash-shell-yt {
  --dash-header-bg: transparent;
  --dash-yt-chrome-bg: #e9eef3;
  --dash-yt-sidebar-bg: #e9eef3;
  --dash-yt-header-bg: #e9eef3;
  --dash-yt-canvas-bg: #e9eef3;
  --dash-yt-surface-bg: #ffffff;
}

.dash-shell-yt .dash-top-chrome {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 110;
  background: transparent !important;
  box-shadow: none !important;
}

.dash-shell-yt .dash-topbar-toolbar,
.dash-shell-yt .dash-topbar-search-row {
  background: transparent !important;
  border-bottom: none !important;
  padding: 4px 8px;
  width: 100%;
  position: relative;
  box-sizing: border-box;
}

.dash-shell-yt .dash-topbar-leading {
  display: flex;
  align-items: center;
  gap: 8px;
  width: max-content;
  max-width: min(100%, calc(50% - 4.5rem));
  min-height: var(--dash-topbar-h, 40px);
  height: var(--dash-topbar-h, 40px);
  background: transparent !important;
}

.dash-shell-yt .dash-topbar-toolbar .dash-topbar-brand,
.dash-shell-yt .dash-topbar-brand--center {
  display: flex !important;
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  pointer-events: auto;
  z-index: 2;
  background: transparent !important;
}

.dash-shell-yt .dash-topbar-brand-btn {
  appearance: none;
  border: none;
  margin: 0;
  padding: 4px 6px;
  cursor: pointer;
  background: transparent;
  border-radius: 8px;
  transition: background 0.15s ease, transform 0.12s ease;
}

.dash-shell-yt .dash-topbar-brand-btn:hover {
  background: rgba(15, 23, 42, 0.06);
}

.dash-shell-yt .dash-topbar-brand-btn:active {
  transform: translate(-50%, -50%) scale(0.96) !important;
}

.dash-shell-yt .dash-topbar-brand-btn .brand-lockup--topbar {
  display: inline-flex;
  align-items: baseline;
  gap: 0.38em;
}

.dash-shell-yt .dash-topbar-brand-btn .brand-nashwan {
  font-size: 15px;
  font-weight: 700;
  color: rgba(15, 23, 42, 0.72);
}

.dash-shell-yt .dash-topbar-brand-btn .brand-wordmark--chrome {
  filter: none;
  font-size: 22px;
}

.dash-shell-yt .dash-search-wrap--yt {
  border-color: rgba(15, 23, 42, 0.14) !important;
}

.dash-shell-yt .dash-search-wrap--yt:focus-within {
  border-color: rgba(15, 23, 42, 0.28) !important;
}

.dash-shell-yt .dash-search-wrap--yt .dash-search-submit {
  border-inline-start-color: rgba(15, 23, 42, 0.12) !important;
}

.dash-shell-yt .home-strip-duo {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}

.dash-shell-yt .home-page .dash-panel-home-activity,
.dash-shell-yt .home-page .dash-panel-home-rides {
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
  border-radius: 14px !important;
  box-shadow: none !important;
}

.dash-shell-yt .dash-panel-home-activity .home-panel-head-chips--home-card .load-card--home-compact {
  background: #10b981 !important;
  color: #ffffff;
}

.dash-shell-yt .dash-panel-home-rides .home-panel-head-chips--home-card .load-card--home-compact {
  background: #f59e0b !important;
  color: #ffffff;
}

@media (max-width: 900px) {
  .dash-shell-yt .home-strip-duo {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .dash-shell-yt .dash-topbar-leading {
    max-width: min(100%, calc(50% - 2.75rem));
  }

  .dash-shell-yt .dash-topbar-brand-btn .brand-nashwan {
    display: none;
  }
}

/* Admin home: elegant recent activity / recent rides cards */
.dash-shell-yt .home-page .home-strip-duo {
  align-items: stretch;
}

.dash-shell-yt .home-page .dash-panel-home-activity,
.dash-shell-yt .home-page .dash-panel-home-rides {
  overflow: hidden;
}

.dash-shell-yt .home-page .dash-panel-home-activity .dash-panel-head,
.dash-shell-yt .home-page .dash-panel-home-rides .dash-panel-head {
  padding: 13px 14px 12px !important;
}

.dash-shell-yt .home-page .home-panel-head-row {
  align-items: stretch;
  gap: 12px;
}

.dash-shell-yt .home-page .home-panel-head-main {
  display: grid;
  grid-template-columns: minmax(105px, 0.28fr) minmax(0, 1fr);
  align-items: stretch;
  gap: 12px;
  min-width: 0;
}

.dash-shell-yt .home-page .home-panel-title-btn {
  min-height: 86px;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(16, 185, 129, 0.14);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(240, 253, 244, 0.94), rgba(255, 255, 255, 0.94));
}

.dash-shell-yt .home-page .home-panel-title-btn h3 {
  max-width: 82px;
  margin: 0;
  color: #0f172a !important;
  font-size: 13px;
  font-weight: 900;
  line-height: 1.35;
  text-align: center;
}

.dash-shell-yt .home-page .home-panel-head-chips--home-card {
  display: block;
  min-width: 0;
  padding: 0 !important;
  border: 0 !important;
  overflow: visible;
}

.dash-shell-yt .home-page .home-panel-head-chips--home-card .load-card--home-compact {
  width: 100%;
  min-height: 86px;
  margin: 0;
  padding: 12px 13px !important;
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  color: #0f172a !important;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 12px;
  background: #ffffff !important;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.045);
  cursor: pointer;
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.dash-shell-yt .home-page .home-panel-head-chips--home-card .load-card--home-compact:hover {
  transform: translateY(-1px);
  border-color: rgba(16, 185, 129, 0.24);
  box-shadow: 0 12px 26px rgba(15, 23, 42, 0.075);
}

.dash-shell-yt .home-page .load-card--home-compact.load-card--active,
.dash-shell-yt .home-page .load-card--home-compact.load-card--captain {
  border-color: rgba(16, 185, 129, 0.28);
  background: linear-gradient(180deg, #ffffff, #f7fefb) !important;
}

.dash-shell-yt .home-page .load-card--home-compact.load-card--searching {
  border-color: rgba(16, 185, 129, 0.22);
  background: linear-gradient(180deg, #ffffff, #f8fffb) !important;
}

.dash-shell-yt .home-page .load-card--home-compact.load-card--completed {
  border-color: rgba(37, 99, 235, 0.18);
}

.dash-shell-yt .home-page .load-card--home-compact.load-card--cancelled {
  border-color: rgba(220, 38, 38, 0.16);
}

.dash-shell-yt .home-page .load-card--home-compact .card-name-price,
.dash-shell-yt .home-page .load-card--home-compact .card-time {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.dash-shell-yt .home-page .load-card--home-compact .load-card-nm {
  min-width: 0;
  color: #64748b;
  font-size: 11px;
  font-weight: 900;
  direction: ltr;
  text-align: left;
}

.dash-shell-yt .home-page .load-card--home-compact .load-card-price {
  color: #0f172a;
  font-size: 13px;
  font-weight: 950;
  white-space: nowrap;
}

.dash-shell-yt .home-page .load-card--home-compact .load-card-tm {
  color: #16a34a;
  font-size: 12px;
  font-weight: 950;
  white-space: nowrap;
}

.dash-shell-yt .home-page .load-card--home-compact .load-card-mi {
  max-width: 58%;
  padding: 4px 8px;
  border: 1px solid rgba(16, 185, 129, 0.16);
  border-radius: 999px;
  color: #15803d;
  background: rgba(240, 253, 244, 0.9);
  font-size: 10px;
  font-weight: 900;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dash-shell-yt .home-page .load-card--home-compact .card-route-compact {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding-top: 2px;
  color: #334155;
  font-size: 11px;
  font-weight: 850;
  line-height: 1.35;
}

.dash-shell-yt .home-page .load-card--home-compact .city-nm {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-shell-yt .home-page .load-card--home-compact .route-arrow {
  flex: 0 0 auto;
  color: #10b981;
  font-size: 13px;
  font-weight: 950;
}

.dash-shell-yt .home-page .home-panel-all-btn {
  align-self: stretch;
}

.dash-shell-yt .home-page .home-panel-all-btn .home-see-all {
  height: 100%;
  min-height: 86px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  border-radius: 12px;
  white-space: nowrap;
}

@media (max-width: 720px) {
  .dash-shell-yt .home-page .home-panel-head-row {
    display: grid;
    grid-template-columns: 1fr;
  }

  .dash-shell-yt .home-page .home-panel-head-main {
    grid-template-columns: 1fr;
  }

  .dash-shell-yt .home-page .home-panel-title-btn,
  .dash-shell-yt .home-page .home-panel-all-btn .home-see-all {
    min-height: 48px;
  }

  .dash-shell-yt .home-page .home-panel-title-btn h3 {
    max-width: none;
  }
}
