/* =============================================
   MediRide — Non-Emergency Medical Transport
   style.css | LTR | Dark Mode Default
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&display=swap');

/* ══════════════════════════════════
   CSS VARIABLES — DARK IS DEFAULT
══════════════════════════════════ */
:root {
  --font-main: 'Sora', 'DM Sans', sans-serif;
  --radius: 14px;
  --radius-sm: 8px;
  --transition: 0.32s cubic-bezier(.4, 0, .2, 1);

  --accent: #00c896;
  --accent-dark: #00a578;
  --accent2: #3b82f6;
  --accent-glow: rgba(0, 200, 150, 0.18);
  --accent2-glow: rgba(59, 130, 246, 0.15);
  --border-accent: rgba(0, 200, 150, 0.35);

  /* DARK — default */
  --bg-primary: #0d1117;
  --bg-secondary: #161b22;
  --bg-card: #1c2333;
  --bg-card-hover: #21283a;
  --text-primary: #e6edf3;
  --text-secondary: #8b949e;
  --text-muted: #556070;
  --border: rgba(255, 255, 255, 0.07);
  --nav-bg: rgba(13, 17, 23, 0.93);
  --shadow-card: 0 8px 32px rgba(0, 0, 0, 0.45);
  --shadow-accent: 0 0 30px rgba(0, 200, 150, 0.22);
}

/* LIGHT MODE — class on <html> only */
html.light-mode {
  --bg-primary: #f0f4f8;
  --bg-secondary: #ffffff;
  --bg-card: #ffffff;
  --bg-card-hover: #f5faff;
  --text-primary: #0d1117;
  --text-secondary: #4a5568;
  --text-muted: #8896a4;
  --border: rgba(0, 0, 0, 0.09);
  --border-accent: rgba(0, 200, 150, 0.28);
  --nav-bg: rgba(240, 244, 248, 0.95);
  --shadow-card: 0 8px 32px rgba(0, 0, 0, 0.10);
  --shadow-accent: 0 0 30px rgba(0, 200, 150, 0.14);
  --accent-glow: rgba(0, 200, 150, 0.10);
  --accent2-glow: rgba(59, 130, 246, 0.08);
}

/* ══════════════════════════════════
   RESET & BASE
══════════════════════════════════ */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  direction: ltr;
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: var(--font-main);
  background-color: #0d1117;
  /* hard fallback — prevents white flash */
  background: var(--bg-primary);
  color: #e6edf3;
  /* hard fallback */
  color: var(--text-primary);
  direction: ltr;
  text-align: left;
  line-height: 1.7;
  transition: background var(--transition), color var(--transition);
  overflow-x: hidden;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  text-decoration: none;
  color: inherit;
}

ul {
  list-style: none;
}

button {
  font-family: var(--font-main);
  cursor: pointer;
  border: none;
  outline: none;
}

::-webkit-scrollbar {
  width: 6px;
}

::-webkit-scrollbar-track {
  background: var(--bg-primary);
}

::-webkit-scrollbar-thumb {
  background: var(--accent);
  border-radius: 4px;
}

/* ══════════════════════════════════
   NAVBAR
══════════════════════════════════ */
.navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: var(--nav-bg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  transition: background var(--transition), box-shadow var(--transition);
}

.navbar.scrolled {
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.35);
}

.nav-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 72px;
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.logo-icon {
  width: 44px;
  height: 44px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  box-shadow: var(--shadow-accent);
  flex-shrink: 0;
}

.logo-text .brand {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: -0.5px;
}

.logo-text .tagline {
  font-size: 0.62rem;
  color: var(--text-secondary);
  font-weight: 400;
  letter-spacing: 0.3px;
}

/* Nav links */
.nav-links {
  display: flex;
  align-items: center;
  gap: 2px;
}

.nav-item {
  position: relative;
}

.nav-link {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 8px 13px;
  border-radius: var(--radius-sm);
  font-size: 0.865rem;
  font-weight: 500;
  color: var(--text-secondary);
  transition: color var(--transition), background var(--transition);
  white-space: nowrap;
  cursor: pointer;
  position: relative;
}

.nav-link svg {
  width: 12px;
  height: 12px;
  transition: transform var(--transition);
}

.nav-link:hover,
.nav-item:hover>.nav-link {
  color: var(--accent);
  background: var(--accent-glow);
}

.nav-item:hover>.nav-link svg {
  transform: rotate(180deg);
}

.nav-link.active {
  color: var(--accent) !important;
  background: var(--accent-glow);
  font-weight: 600;
}

.nav-link.active::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 12px;
  right: 12px;
  height: 2px;
  background: var(--accent);
  border-radius: 2px 2px 0 0;
}

/* Dropdown */
.dropdown-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 180px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 8px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all var(--transition);
  box-shadow: var(--shadow-card);
  z-index: 200;
}

.nav-item:hover .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.dropdown-menu a {
  display: block;
  padding: 9px 14px;
  font-size: 0.845rem;
  color: var(--text-secondary);
  border-radius: var(--radius-sm);
  transition: all var(--transition);
}

.dropdown-menu a:hover {
  color: var(--accent);
  background: var(--accent-glow);
  padding-left: 20px;
}

/* Nav controls */
.nav-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Theme toggle */
.theme-toggle {
  width: 46px;
  height: 26px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 20px;
  position: relative;
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition);
  flex-shrink: 0;
}

.theme-toggle::after {
  content: '🌙';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--bg-secondary);
  font-size: 11px;
  line-height: 20px;
  text-align: center;
  transition: transform var(--transition);
}

html.light-mode .theme-toggle::after {
  content: '☀️';
  transform: translateX(20px);
}

/* RTL toggle */
.rtl-toggle {
  width: 36px;
  height: 26px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition), color var(--transition);
  flex-shrink: 0;
  font-weight: 700;
  line-height: 1;
}

.rtl-toggle:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-glow);
}

.rtl-toggle.active {
  background: var(--accent-glow);
  border-color: var(--border-accent);
  color: var(--accent);
}

/* Login */
.btn-login {
  padding: 9px 22px;
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  color: #fff;
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  font-weight: 600;
  transition: all var(--transition);
  box-shadow: 0 4px 14px rgba(0, 200, 150, 0.30);
  white-space: nowrap;
}

.btn-login:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 22px rgba(0, 200, 150, 0.45);
}

/* Hamburger */
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 8px;
  background: none;
  cursor: pointer;
}

.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--text-primary);
  border-radius: 2px;
  transition: all var(--transition);
}

.hamburger.open span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}

.hamburger.open span:nth-child(2) {
  opacity: 0;
}

.hamburger.open span:nth-child(3) {
  transform: rotate(-45deg) translate(5px, -5px);
}

/* Mobile nav */
.mobile-nav {
  display: none;
  position: fixed;
  top: 72px;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--bg-primary);
  z-index: 999;
  padding: 20px 20px 40px;
  overflow-y: auto;
  flex-direction: column;
  gap: 3px;
  border-top: 1px solid var(--border);
}

.mobile-nav.open {
  display: flex;
}

.mobile-nav .m-link {
  padding: 13px 18px;
  font-size: 0.96rem;
  font-weight: 500;
  color: var(--text-primary);
  border-radius: var(--radius-sm);
  border-bottom: 1px solid var(--border);
  transition: all var(--transition);
}

.mobile-nav .m-link:hover,
.mobile-nav .m-link.active {
  color: var(--accent);
  background: var(--accent-glow);
}

.mobile-nav .m-sub {
  font-size: 0.86rem;
  padding-left: 32px;
  color: var(--text-secondary);
}

.mobile-nav .m-controls {
  margin-top: 22px;
  display: flex;
  align-items: center;
  gap: 14px;
}

/* ══════════════════════════════════
   HERO
══════════════════════════════════ */
.hero {
  min-height: 100vh;
  padding-top: 72px;
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 30%, rgba(0, 200, 150, 0.09) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 80%, rgba(59, 130, 246, 0.07) 0%, transparent 60%),
    var(--bg-primary);
  z-index: 0;
}

.hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0, 200, 150, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 200, 150, 0.04) 1px, transparent 1px);
  background-size: 60px 60px;
  animation: gridShift 20s linear infinite;
  z-index: 0;
}

@keyframes gridShift {
  0% {
    background-position: 0 0;
  }

  100% {
    background-position: 60px 60px;
  }
}

.hero-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 80px 24px 60px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  position: relative;
  z-index: 1;
}

.hero-text {
  text-align: left;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 16px;
  background: var(--accent-glow);
  border: 1px solid var(--border-accent);
  border-radius: 30px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--accent);
  margin-bottom: 24px;
  animation: fadeInDown 0.7s ease both;
}

.hero-badge .dot {
  width: 7px;
  height: 7px;
  background: var(--accent);
  border-radius: 50%;
  animation: pulse 1.5s ease infinite;
}

@keyframes pulse {

  0%,
  100% {
    opacity: 1;
    transform: scale(1);
  }

  50% {
    opacity: 0.5;
    transform: scale(1.4);
  }
}

.hero-title {
  font-size: clamp(2.2rem, 5vw, 3.8rem);
  font-weight: 800;
  line-height: 1.12;
  margin-bottom: 20px;
  animation: fadeInDown 0.8s ease 0.1s both;
}

.hero-title .hl {
  color: var(--accent);
}

.hero-desc {
  font-size: 1.05rem;
  color: var(--text-secondary);
  max-width: 520px;
  margin-bottom: 36px;
  line-height: 1.8;
  animation: fadeInDown 0.8s ease 0.2s both;
}

.hero-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  animation: fadeInDown 0.8s ease 0.3s both;
}

.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 30px;
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  color: #fff;
  border-radius: var(--radius);
  font-size: 0.95rem;
  font-weight: 600;
  transition: all var(--transition);
  box-shadow: 0 6px 24px rgba(0, 200, 150, 0.35);
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 32px rgba(0, 200, 150, 0.5);
}

.btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  background: var(--bg-card);
  color: var(--text-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: 0.95rem;
  font-weight: 600;
  transition: all var(--transition);
}

.btn-secondary:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-glow);
  transform: translateY(-2px);
}

.hero-stats {
  display: flex;
  gap: 28px;
  margin-top: 44px;
  flex-wrap: wrap;
  animation: fadeInDown 0.8s ease 0.4s both;
}

.stat-item {
  text-align: left;
}

.stat-num {
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
}

.stat-lbl {
  font-size: 0.73rem;
  color: var(--text-muted);
  margin-top: 3px;
}

.stat-sep {
  width: 1px;
  background: var(--border);
  align-self: stretch;
}

/* Hero visual */
.hero-visual {
  position: relative;
  animation: fadeInRight 0.9s ease 0.2s both;
}

@keyframes fadeInRight {
  from {
    opacity: 0;
    transform: translateX(30px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Hero image */
.hero-img-wrap {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5), 0 0 0 1px var(--border), var(--shadow-accent);
}

.hero-img-wrap::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
      transparent 40%,
      rgba(0, 200, 150, 0.08) 70%,
      rgba(13, 17, 23, 0.55) 100%);
  z-index: 1;
  pointer-events: none;
}

.hero-img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 24px;
  object-fit: cover;
  transition: transform 0.6s ease;
}

.hero-img-wrap:hover .hero-img {
  transform: scale(1.03);
}

/* Live badge overlay on image */
.hero-img-badge {
  position: absolute;
  bottom: 20px;
  left: 20px;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: rgba(13, 17, 23, 0.75);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--border-accent);
  border-radius: 30px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--accent);
  letter-spacing: 0.3px;
}



.hero-card-main {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: 26px;
  box-shadow: var(--shadow-card);
  position: relative;
  overflow: hidden;
}

.hero-card-main::before {
  content: '';
  position: absolute;
  top: -40px;
  left: -40px;
  width: 120px;
  height: 120px;
  background: radial-gradient(circle, var(--accent-glow), transparent);
  border-radius: 50%;
}

.hc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}

.hc-title {
  font-size: 0.95rem;
  font-weight: 700;
}

.hc-sub {
  font-size: 0.7rem;
  color: var(--text-muted);
}

.hc-status {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  background: rgba(0, 200, 150, 0.1);
  border: 1px solid var(--border-accent);
  border-radius: 20px;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--accent);
}

.live-dot {
  width: 6px;
  height: 6px;
  background: var(--accent);
  border-radius: 50%;
  animation: pulse 1.2s infinite;
}

/* Map mock */
.map-mock {
  background: var(--bg-secondary);
  border-radius: 14px;
  height: 165px;
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border);
  margin-bottom: 18px;
}

.map-grid-lines {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0, 200, 150, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 200, 150, 0.06) 1px, transparent 1px);
  background-size: 24px 24px;
}

.map-route {
  position: absolute;
  top: 42%;
  left: 15%;
  right: 20%;
  height: 2px;
  background: linear-gradient(90deg, var(--accent2), var(--accent));
  border-radius: 2px;
}

.map-route::before,
.map-route::after {
  content: '';
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  border-radius: 50%;
}

.map-route::before {
  left: 0;
  background: var(--accent2);
  box-shadow: 0 0 10px var(--accent2);
}

.map-route::after {
  right: 0;
  background: var(--accent);
  box-shadow: 0 0 10px var(--accent);
}

.map-vehicle {
  position: absolute;
  top: calc(42% - 14px);
  left: 48%;
  width: 28px;
  height: 28px;
  background: var(--accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  box-shadow: 0 0 20px rgba(0, 200, 150, 0.5);
  animation: vehicleMove 4s ease-in-out infinite;
}

@keyframes vehicleMove {

  0%,
  100% {
    left: 42%
  }

  50% {
    left: 54%
  }
}

.map-ping {
  position: absolute;
  top: calc(42% - 6px);
  left: 48.5%;
  width: 14px;
  height: 14px;
  border: 2px solid var(--accent);
  border-radius: 50%;
  animation: vehicleMove 4s ease-in-out infinite, ping 1.5s ease-out infinite;
}

@keyframes ping {
  0% {
    transform: scale(1);
    opacity: 0.8
  }

  100% {
    transform: scale(2.5);
    opacity: 0
  }
}

.trip-cards {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.trip-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 11px 14px;
  background: var(--bg-secondary);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
}

.tc-left {
  display: flex;
  align-items: center;
  gap: 10px;
}

.tc-icon {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}

.tc-icon.green {
  background: rgba(0, 200, 150, 0.12);
  color: var(--accent);
}

.tc-icon.blue {
  background: rgba(59, 130, 246, 0.12);
  color: var(--accent2);
}

.tc-icon.orange {
  background: rgba(251, 146, 60, 0.12);
  color: #fb923c;
}

/* FontAwesome icon sizing inside containers */
.logo-icon i {
  font-size: 20px;
  color: #fff;
}

.trust-icon i {
  font-size: 18px;
  color: var(--accent);
}

.svc-icon i {
  font-size: 22px;
  color: var(--accent);
  transition: color var(--transition);
}

.service-card:hover .svc-icon i {
  color: #fff;
}

.hiw-icon i {
  font-size: 24px;
  color: var(--accent);
}

.wi-icon i {
  font-size: 16px;
  color: var(--accent);
}

.tc-icon i {
  font-size: 14px;
}

.tc-icon.green i {
  color: var(--accent);
}

.tc-icon.blue i {
  color: var(--accent2);
}

.tc-icon.orange i {
  color: #fb923c;
}

.testi-avatar i {
  font-size: 20px;
  color: var(--accent);
}

.partner-logo i {
  font-size: 16px;
  color: var(--accent);
  margin-right: 6px;
}

.footer-contact-item i {
  font-size: 14px;
  color: var(--accent);
}

.social-btn i {
  font-size: 15px;
}

.scroll-top i {
  font-size: 14px;
}

.section-badge i {
  font-size: 13px;
  color: var(--accent);
}

.m-link i {
  font-size: 14px;
  color: var(--accent);
  margin-right: 6px;
  width: 16px;
  text-align: center;
}

.tc-name {
  font-size: 0.82rem;
  font-weight: 600;
}

.tc-time {
  font-size: 0.7rem;
  color: var(--text-muted);
}

.tc-badge {
  font-size: 0.67rem;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 20px;
  white-space: nowrap;
}

.tc-badge.on-way {
  background: rgba(0, 200, 150, 0.12);
  color: var(--accent);
}

.tc-badge.sched {
  background: rgba(59, 130, 246, 0.12);
  color: var(--accent2);
}

.tc-badge.arrived {
  background: rgba(251, 146, 60, 0.12);
  color: #fb923c;
}

/* Floating cards */
.float-card {
  position: absolute;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 13px 15px;
  box-shadow: var(--shadow-card);
  animation: float 4s ease-in-out infinite;
  z-index: 5;
  min-width: 148px;
}

@keyframes float {

  0%,
  100% {
    transform: translateY(0)
  }

  50% {
    transform: translateY(-8px)
  }
}

.float-card.fc-1 {
  bottom: -22px;
  right: -28px;
  animation-delay: 0s;
}

.float-card.fc-2 {
  top: 10px;
  right: -32px;
  animation-delay: 1.5s;
}

.fc-label {
  font-size: 0.67rem;
  color: var(--text-muted);
  margin-bottom: 3px;
}

.fc-val {
  font-size: 1.05rem;
  font-weight: 800;
  color: #00a578;
}

.fc-val.blue {
  color: #00a578;
}

@keyframes fadeInDown {
  from {
    opacity: 0;
    transform: translateY(-18px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

/* ══════════════════════════════════
   SECTION COMMONS
══════════════════════════════════ */
section {
  padding: 90px 0;
}

.section-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 24px;
}

.section-header {
  text-align: center;
  margin-bottom: 56px;
}

.section-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 16px;
  border: 1px solid var(--border-accent);
  border-radius: 30px;
  font-size: 0.74rem;
  font-weight: 600;
  color: var(--accent);
  background: var(--accent-glow);
  margin-bottom: 16px;
}

.section-title {
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 14px;
}

.section-title .hl {
  color: var(--accent);
}

.section-desc {
  font-size: 1rem;
  color: var(--text-secondary);
  /* max-width: 580px; */
  margin: 0 auto;
  line-height: 1.8;
  text-align: center;
}

/* ══════════════════════════════════
   TRUST BAR
══════════════════════════════════ */
.trust-bar {
  padding: 26px 0;
  background: var(--bg-secondary);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.trust-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 36px;
  flex-wrap: wrap;
}

.trust-item {
  display: flex;
  align-items: center;
  gap: 9px;
}

.trust-icon {
  font-size: 20px;
}

.trust-text {
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--text-secondary);
  white-space: nowrap;
}

.trust-sep {
  width: 1px;
  height: 26px;
  background: var(--border);
}

/* ══════════════════════════════════
   SERVICES
══════════════════════════════════ */
.services {
  background: var(--bg-primary);
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.service-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 30px 26px;
  text-align: left;
  transition: all var(--transition);
  position: relative;
  overflow: hidden;
}

.service-card::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
}

.service-card:hover {
  background: var(--bg-card-hover);
  border-color: var(--border-accent);
  transform: translateY(-5px);
  box-shadow: var(--shadow-card), var(--shadow-accent);
}

.service-card:hover::before {
  transform: scaleX(1);
}

.svc-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: var(--accent-glow);
  border: 1px solid var(--border-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  margin-bottom: 18px;
  transition: all var(--transition);
}

.service-card:hover .svc-icon {
  background: var(--accent);
  box-shadow: 0 0 24px rgba(0, 200, 150, 0.4);
}

.svc-title {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 9px;
}

.svc-desc {
  font-size: 0.845rem;
  color: var(--text-secondary);
  line-height: 1.75;
}

.svc-features {
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.svc-feat {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 0.8rem;
  color: var(--text-secondary);
}

.svc-feat::before {
  content: '✓';
  color: var(--accent);
  font-weight: 700;
}

/* ══════════════════════════════════
   HOW IT WORKS
══════════════════════════════════ */
.how-it-works {
  background: var(--bg-secondary);
}

.hiw-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  position: relative;
}

.hiw-connector {
  position: absolute;
  top: 42px;
  left: 12%;
  right: 12%;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  z-index: 0;
}

.hiw-card {
  position: relative;
  z-index: 1;
  text-align: center;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 30px 18px;
  transition: all var(--transition);
}

.hiw-card:hover {
  border-color: var(--border-accent);
  transform: translateY(-4px);
  box-shadow: var(--shadow-card);
}

.hiw-num {
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  border-radius: 50%;
  font-size: 1.1rem;
  font-weight: 800;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 14px;
  box-shadow: 0 4px 18px rgba(0, 200, 150, 0.35);
}

.hiw-icon {
  font-size: 26px;
  margin-bottom: 10px;
}

.hiw-title {
  font-size: 0.95rem;
  font-weight: 700;
  margin-bottom: 8px;
}

.hiw-desc {
  font-size: 0.81rem;
  color: var(--text-secondary);
  line-height: 1.7;
}

/* ══════════════════════════════════
   WHY CHOOSE US
══════════════════════════════════ */
.why-us {
  background: var(--bg-primary);
}

.why-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: stretch;
}

.why-text {
  text-align: left;
}

.why-title {
  font-size: clamp(1.8rem, 3.5vw, 2.5rem);
  font-weight: 800;
  margin-bottom: 14px;
  line-height: 1.2;
}

.why-title .hl {
  color: var(--accent);
}

.why-desc {
  font-size: 0.95rem;
  color: var(--text-secondary);
  line-height: 1.8;
  margin-bottom: 30px;
}

.why-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.why-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  padding: 16px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: all var(--transition);
}

.why-item:hover {
  border-color: var(--border-accent);
  background: var(--bg-card-hover);
  transform: translateY(-3px);
}

.wi-icon {
  width: 38px;
  height: 38px;
  background: var(--accent-glow);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  flex-shrink: 0;
}

.wi-title {
  font-size: 0.88rem;
  font-weight: 700;
  margin-bottom: 3px;
}

.wi-desc {
  font-size: 0.8rem;
  color: var(--text-secondary);
  line-height: 1.65;
}

.why-visual {
  height: 100%;
}

.why-img-wrap {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.4), 0 0 0 1px var(--border);
  height: 100%;
}

.why-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}

.why-img-wrap:hover .why-img {
  transform: scale(1.05);
}

.why-stats-overlay {
  position: absolute;
  top: 20px;
  left: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 2;
}

.why-stat-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: rgba(13, 17, 23, 0.75);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--border);
  border-radius: 30px;
  font-size: 0.78rem;
  font-weight: 700;
  color: #fff;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.why-stat-pill .pill-dot {
  width: 7px;
  height: 7px;
  background: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 8px var(--accent);
}

.why-stat-pill .pill-dot.blue {
  background: var(--accent2);
  box-shadow: 0 0 8px var(--accent2);
}

.why-cert-badge {
  position: absolute;
  bottom: 24px;
  right: 24px;
  background: var(--bg-card);
  border: 1px solid var(--border-accent);
  border-radius: 16px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  z-index: 3;
  box-shadow: var(--shadow-card), var(--shadow-accent);
  animation: float 4s ease-in-out infinite;
}

.why-cert-badge .cert-icon {
  font-size: 24px;
  color: var(--accent);
}

.why-cert-badge .cert-text {
  font-size: 0.7rem;
  font-weight: 800;
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 1px;
  text-align: center;
}


/* ══════════════════════════════════
   PROFESSIONAL CARE CTA
══════════════════════════════════ */
.book-cta {
  position: relative;
  padding: 120px 0;
  background: #000;
  overflow: hidden;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.book-bg-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.book-bg-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.55;
  filter: brightness(0.8) contrast(1.1);
}

.book-gradient {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at center, rgba(13, 17, 23, 0.4) 0%, rgba(13, 17, 23, 0.95) 100%);
}

.book-cta-inner {
  position: relative;
  z-index: 2;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 24px;
}

.book-card-glass {
  max-width: 840px;
  margin: 0 auto;
  padding: 60px 40px;
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(25px);
  -webkit-backdrop-filter: blur(25px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 40px;
  box-shadow: 0 40px 120px rgba(0, 0, 0, 0.6);
  text-align: center;
}

.book-content-v3 {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.book-badge-v3 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  background: var(--accent-glow);
  border: 1px solid var(--border-accent);
  border-radius: 20px;
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 24px;
}

.book-title {
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 800;
  margin-bottom: 18px;
  color: #fff;
  line-height: 1.1;
}

.book-desc {
  font-size: 1.05rem;
  color: rgba(255, 255, 255, 0.75);
  line-height: 1.8;
  max-width: 620px;
  margin-bottom: 40px;
}

.book-actions-v3 {
  display: flex;
  gap: 20px;
  margin-bottom: 40px;
  width: 100%;
  justify-content: center;
}

.btn-cta-v3 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 18px 32px;
  border-radius: 16px;
  font-size: 0.95rem;
  font-weight: 800;
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  text-decoration: none;
}

.btn-cta-v3.primary {
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #fff;
  box-shadow: 0 10px 30px rgba(0, 200, 150, 0.4);
}

.btn-cta-v3.primary:hover {
  transform: translateY(-4px) scale(1.05);
  box-shadow: 0 15px 40px rgba(0, 200, 150, 0.6);
}

.btn-cta-v3.secondary {
  background: rgba(255, 255, 255, 0.05);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.btn-cta-v3.secondary:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.3);
  transform: translateY(-4px);
}

.book-trust-v3 {
  display: flex;
  gap: 30px;
  padding-top: 30px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.trust-pill {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.75rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.trust-pill i {
  color: var(--accent);
  font-size: 14px;
}

@media (max-width: 767px) {
  .book-actions-v3 {
    flex-direction: column;
    width: 100%;
  }

  .btn-cta-v3 {
    width: 100%;
  }

  .book-trust-v3 {
    flex-direction: column;
    gap: 16px;
    align-items: center;
  }

  .book-card-glass {
    padding: 40px 24px;
  }
}

/* ══════════════════════════════════
   TESTIMONIALS
══════════════════════════════════ */
.testimonials {
  background: var(--bg-primary);
}

.testi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  align-items: stretch;
}

.testi-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 26px 22px;
  text-align: left;
  transition: all var(--transition);
  display: flex;
  flex-direction: column;
  height: 100%;
}

.testi-card:hover {
  border-color: var(--border-accent);
  transform: translateY(-4px);
  box-shadow: var(--shadow-card);
}

.testi-quote {
  font-size: 2.2rem;
  color: var(--accent);
  line-height: 1;
  margin-bottom: 12px;
  font-family: Georgia, serif;
}

.testi-text {
  font-size: 0.87rem;
  color: var(--text-secondary);
  line-height: 1.8;
  margin-bottom: 18px;
  flex-grow: 1;
}

.testi-stars {
  color: #f59e0b;
  font-size: 0.88rem;
  margin-bottom: 14px;
}

.testi-author {
  display: flex;
  align-items: center;
  gap: 11px;
  border-top: 1px solid var(--border);
  padding-top: 15px;
  margin-top: auto;
}

.testi-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  flex-shrink: 0;
  overflow: hidden;
}

.testi-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


.ta-name {
  font-size: 0.84rem;
  font-weight: 700;
}

.ta-role {
  font-size: 0.7rem;
  color: var(--text-muted);
}

/* ══════════════════════════════════
   PRICING
══════════════════════════════════ */
.pricing-preview {
  background: var(--bg-secondary);
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  align-items: center;
}

.price-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 34px 26px;
  text-align: left;
  transition: all var(--transition);
  position: relative;
}

.price-card.featured {
  border-color: var(--accent);
  background: linear-gradient(160deg, var(--bg-card), rgba(0, 200, 150, 0.04));
  transform: scale(1.04);
  box-shadow: var(--shadow-card), var(--shadow-accent);
}

.featured-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  color: #fff;
  padding: 4px 16px;
  border-radius: 20px;
  font-size: 0.71rem;
  font-weight: 700;
  white-space: nowrap;
}

.price-plan {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.price-amount {
  font-size: 2.3rem;
  font-weight: 800;
  line-height: 1;
  margin-bottom: 6px;
}

.price-amount span {
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--text-muted);
}

.price-desc {
  font-size: 0.79rem;
  color: var(--text-muted);
  margin-bottom: 22px;
}

.price-features {
  display: flex;
  flex-direction: column;
  gap: 9px;
  margin-bottom: 26px;
}

.pf-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--text-secondary);
}

.pf-check {
  color: var(--accent);
  font-weight: 700;
}

.btn-price {
  width: 100%;
  padding: 12px;
  border-radius: var(--radius-sm);
  font-size: 0.88rem;
  font-weight: 600;
  transition: all var(--transition);
}

.btn-price.outline {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-primary);
}

.btn-price.outline:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.btn-price.solid {
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  color: #fff;
  border: none;
  box-shadow: 0 4px 16px rgba(0, 200, 150, 0.3);
}

.btn-price.solid:hover {
  box-shadow: 0 6px 24px rgba(0, 200, 150, 0.5);
  transform: translateY(-1px);
}

/* ══════════════════════════════════
   PARTNERS
══════════════════════════════════ */
.partners {
  background: var(--bg-primary);
  padding: 58px 0;
}

.partners-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 24px;
}

.partners-label {
  text-align: center;
  font-size: 0.78rem;
  color: var(--text-muted);
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 30px;
}

.partners-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}

.partner-logo {
  padding: 11px 22px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 0.81rem;
  font-weight: 600;
  color: var(--text-muted);
  transition: all var(--transition);
  display: flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
}

.partner-logo:hover {
  color: var(--accent);
  border-color: var(--border-accent);
}

/* ══════════════════════════════════
   OUR FLEET
══════════════════════════════════ */
.fleet {
  background: var(--bg-secondary);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.fleet-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.fleet-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: all var(--transition);
  height: 100%;
  display: flex;
  flex-direction: column;
}

.fleet-card:hover {
  transform: translateY(-8px);
  border-color: var(--border-accent);
  box-shadow: var(--shadow-card), var(--shadow-accent);
}

.fleet-img-wrap {
  position: relative;
  height: 200px;
  overflow: hidden;
}

.fleet-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}

.fleet-card:hover .fleet-img {
  transform: scale(1.1);
}

.fleet-tag {
  position: absolute;
  top: 14px;
  right: 14px;
  padding: 4px 12px;
  background: rgba(13, 17, 23, 0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid var(--border-accent);
  border-radius: 20px;
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 700;
  z-index: 2;
}

.fleet-content {
  padding: 24px;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}

.fleet-name {
  font-size: 1.15rem;
  font-weight: 800;
  margin-bottom: 10px;
  color: var(--text-primary);
}

.fleet-info {
  font-size: 0.88rem;
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: 20px;
}

.fleet-specs {
  margin-top: auto;
  display: flex;
  gap: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}

.spec-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--accent);
}

.spec-item i {
  font-size: 14px;
}

/* Tablet / Mobile adjustment for fleet grid */
@media (max-width: 1024px) {
  .fleet-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

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

.footer {
  background: var(--bg-secondary);
  border-top: 1px solid var(--border);
  padding: 58px 0 26px;
}

.footer-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 24px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 44px;
}

.footer-col {
  text-align: left;
}

.footer-brand {
  margin-bottom: 14px;
}

.footer-desc {
  font-size: 0.82rem;
  color: var(--text-muted);
  line-height: 1.8;
  margin-bottom: 18px;
}

.footer-socials {
  display: flex;
  gap: 9px;
}

.social-btn {
  width: 34px;
  height: 34px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  transition: all var(--transition);
  cursor: pointer;
}

.social-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-glow);
}

.footer-heading {
  font-size: 0.84rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 14px;
}

.footer-links {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.footer-links a {
  font-size: 0.81rem;
  color: var(--text-muted);
  transition: color var(--transition);
}

.footer-links a:hover {
  color: var(--accent);
}

.footer-contact-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.81rem;
  color: var(--text-muted);
  margin-bottom: 8px;
}

.footer-bottom {
  border-top: 1px solid var(--border);
  padding-top: 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}

.footer-copy {
  font-size: 0.77rem;
  color: var(--text-muted);
}

.footer-copy .hl {
  color: var(--accent);
}

.footer-legal {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
}

.footer-legal a {
  font-size: 0.77rem;
  color: var(--text-muted);
  transition: color var(--transition);
}

.footer-legal a:hover {
  color: var(--accent);
}

/* ══════════════════════════════════
   SCROLL TO TOP
══════════════════════════════════ */
.scroll-top {
  position: fixed;
  bottom: 26px;
  right: 26px;
  width: 44px;
  height: 44px;
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  cursor: pointer;
  box-shadow: 0 4px 18px rgba(0, 200, 150, 0.4);
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition);
  z-index: 900;
  color: #fff;
  border: none;
}

.scroll-top.visible {
  opacity: 1;
  visibility: visible;
}

.scroll-top:hover {
  transform: translateY(-3px);
}

/* ══════════════════════════════════
   SCROLL REVEAL
══════════════════════════════════ */
.reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ══════════════════════════════════
   CONTACT PAGE COMPONENTS
══════════════════════════════════ */

/* Contact Hero / Banner */
.contact-hero {
  padding: 180px 0 100px;
  position: relative;
  overflow: hidden;
  text-align: center;
  color: #fff;
  border-bottom: 4px solid var(--accent);
}

.contact-hero-content {
  max-width: 800px;
  margin: 0 auto;
}

.contact-badge {
  display: inline-block;
  padding: 8px 20px;
  background: var(--accent);
  color: #000;
  border-radius: 50px;
  font-weight: 800;
  font-size: 0.85rem;
  margin-bottom: 24px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Contact Main Section */
.contact-main {
  padding: 100px 0;
  background: var(--bg-primary);
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 60px;
  align-items: flex-start;
}

/* Contact Info */
.contact-info-cards {
  display: grid;
  gap: 24px;
}

.info-card {
  padding: 32px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 20px;
  display: flex;
  gap: 20px;
  transition: all var(--transition);
}

.info-card:hover {
  border-color: var(--border-accent);
  transform: translateX(10px);
}

.ic-icon {
  width: 50px;
  height: 50px;
  background: var(--accent-glow);
  color: var(--accent);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  flex-shrink: 0;
}

.ic-title {
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 8px;
}

.ic-text {
  font-size: 0.95rem;
  color: var(--text-secondary);
  line-height: 1.5;
}

/* Contact Form */
.contact-form-wrap {
  padding: 50px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 32px;
  box-shadow: var(--shadow-card);
  position: relative;
  overflow: hidden;
}

.contact-form-wrap::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 4px;
  height: 100%;
  background: var(--accent);
}

.form-group {
  margin-bottom: 24px;
}

.form-group label {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  margin-bottom: 8px;
  color: var(--text-secondary);
}

.form-control {
  width: 100%;
  padding: 14px 18px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 12px;
  color: var(--text-primary);
  font-family: inherit;
  transition: all var(--transition);
}

.form-control:focus {
  outline: none;
  border-color: var(--accent);
  background: var(--bg-primary);
  box-shadow: 0 0 15px var(--accent-glow);
}

textarea.form-control {
  min-height: 150px;
  resize: vertical;
}

/* Quick Connect Cards */
.quick-connect {
  padding: 80px 0;
  background: var(--bg-secondary);
}

.qc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.qc-card {
  padding: 40px 30px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 20px;
  text-align: center;
  transition: all var(--transition);
}

.qc-card:hover {
  background: var(--accent-glow);
  transform: translateY(-10px);
  border-color: var(--border-accent);
}

.qc-icon {
  font-size: 2.2rem;
  color: var(--accent);
  margin-bottom: 20px;
}

/* ══════════════════════════════════
   RESPONSIVE — GLOBAL REPLACEMENT
══════════════════════════════════ */

/* Standard Tablet & Mobile (Combined for common elements like Hamburger) */
@media (max-width: 1024px) {

  /* Navigation */
  .nav-links {
    display: none !important;
  }

  .hamburger {
    display: flex !important;
    position: relative;
    z-index: 1001;
  }

  .nav-controls .btn-login,
  .nav-controls .rtl-toggle,
  .nav-controls .theme-toggle {
    display: none !important;
  }

  .nav-inner {
    height: 64px;
    padding: 0 16px;
  }

  .mobile-nav {
    top: 64px;
  }

  /* Structural */
  section {
    padding: 60px 0;
  }
}


/* Specific Tablet (768px - 1024px) */
@media (min-width: 768px) and (max-width: 1024px) {
  .hero-inner {
    grid-template: 1fr 1fr / 1fr;
    text-align: left;
    gap: 30px;
    padding: 60px 20px;
  }

  .hero-text {
    text-align: left;
    display: block;
    align-items: flex-start;
  }

  .hero-visual {
    display: block;
  }


  .services-grid,
  .hiw-grid,
  .testi-grid,
  .fleet-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }

  .pricing-grid {
    grid-template-columns: 1fr;
    max-width: 500px;
    margin: 0 auto;
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 30px;
  }

  /* Contact Page Tablet */
  .contact-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

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

/* Contact Map Section */
.contact-map {
  padding: 100px 0;
  background: var(--bg-secondary);
}

.map-card {
  background: var(--bg-primary);
  border-radius: 32px;
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 40px 80px rgba(0, 0, 0, 0.15);
  position: relative;
}

.map-wrapper {
  width: 100%;
  height: 500px;
  position: relative;
}

.map-wrapper iframe {
  width: 100%;
  height: 100%;
  border: 0;
  filter: grayscale(0.4) contrast(1.1) brightness(0.9);
  transition: filter 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

.map-wrapper:hover iframe {
  filter: grayscale(0);
}

/* 3-Tier Responsive Overrides for Map */
@media (max-width: 1024px) {
  .map-wrapper {
    height: 400px;
  }
}

@media (max-width: 767px) {
  .contact-map {
    padding: 60px 0;
  }

  .map-wrapper {
    height: 350px;
  }

  .map-card {
    border-radius: 20px;
  }
}

/* ══════════════════════════════════
   404 ERROR PAGE
══════════════════════════════════ */
.error-page {
  min-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 150px 24px 100px;
  background: var(--bg-primary);
  position: relative;
  overflow: hidden;
}

.error-page::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, var(--accent-glow) 0%, transparent 70%);
  opacity: 0.15;
  z-index: 0;
  pointer-events: none;
}

.error-content {
  position: relative;
  z-index: 1;
  max-width: 600px;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 32px;
  padding: 60px 40px;
  box-shadow: 0 40px 80px rgba(0, 0, 0, 0.1);
  backdrop-filter: blur(10px);
}

.error-code {
  font-size: 8rem;
  font-weight: 800;
  line-height: 1;
  background: linear-gradient(135deg, var(--accent), var(--text-primary));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 20px;
  letter-spacing: -2px;
}

.error-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 20px;
}

.error-desc {
  font-size: 1.1rem;
  color: var(--text-secondary);
  line-height: 1.6;
}

/* 3-Tier Responsive Overrides for 404 Page */
@media (max-width: 1024px) {
  .error-content {
    padding: 50px 30px;
  }

  .error-code {
    font-size: 6rem;
  }

  .error-title {
    font-size: 2rem;
  }
}

@media (max-width: 767px) {
  .error-page {
    padding: 120px 20px 80px;
  }

  .error-content {
    padding: 40px 24px;
    border-radius: 20px;
  }

  .error-code {
    font-size: 5rem;
  }

  .error-title {
    font-size: 1.6rem;
  }

  .error-desc {
    font-size: 1rem;
  }
}

/* Specific Mobile (360px - 767px) */
@media (max-width: 767px) {
  .logo-text .tagline {
    display: none !important;
  }

  /* Typography Scaling */
  html {
    font-size: 15px;
  }

  .hero-title {
    font-size: 2.2rem;
  }

  .section-title {
    font-size: 1.8rem;
  }

  /* Structural */
  section {
    padding: 60px 0;
  }

  .hero-inner {
    grid-template-columns: 1fr;
    padding: 40px 16px;
    text-align: center;
  }

  /* Grid Collapses */
  .services-grid,
  .hiw-grid,
  .why-grid,
  .why-list,
  .testi-grid,
  .pricing-grid,
  .fleet-grid,
  .footer-grid,
  .contact-grid,
  .qc-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .contact-form-wrap {
    padding: 30px 20px;
  }

  .info-card {
    padding: 24px;
    flex-direction: column;
    text-align: center;
    align-items: center;
  }

  .hero-visual {
    display: block;
    width: 100%;
    margin-top: 40px;
  }

  .float-card {
    position: static !important;
    width: 100%;
    margin-bottom: 12px;
    display: flex;
    justify-content: space-between;
    padding: 12px 18px;
    background: var(--bg-card);
    border-radius: 12px;
  }

  /* Footer Bottom */
  .footer-bottom {
    flex-direction: column;
    text-align: center;
    gap: 16px;
  }

  .section-inner,
  .footer-inner {
    padding: 0 16px;
  }
}

/* Large Desktop (Consolidated) */
@media (min-width: 1025px) {
  .hamburger {
    display: none !important;
  }

  .mobile-nav {
    display: none !important;
  }

  .nav-links {
    display: flex !important;
  }
}


/* Wide Screens */
@media (min-width:1440px) {
  :root {
    --width: 1320px;
  }
}

/* ══════════════════════════════════
   ABOUT US PAGE STYLES
══════════════════════════════════ */
.section-padding {
  padding: 80px 24px;
}

.alt-bg {
  background: var(--bg-secondary);
}

.mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.mt-4 {
  margin-top: 1.5rem;
}

/* About Company */
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

.about-img-badge {
  position: absolute;
  bottom: 20px;
  left: 20px;
  background: rgba(13, 17, 23, 0.85);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 12px 20px;
  border-radius: 30px;
  color: var(--accent);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--border-accent);
}

.about-image-wrap {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: var(--shadow-card);
}

.about-img {
  width: 100%;
  height: auto;
  display: block;
}

.section-descs {
  font-size: 1rem;
  color: var(--text-secondary);
  /* max-width: 580px; */
  margin: 0 auto;
  line-height: 1.8;
  text-align: justify;
}

/* .section-titles{
  font-family: 'Sora', sans-serif;
  font-size: clamp(1.75rem, 3.5vw, 2.6rem);
  font-weight: 800;
  color: var(--h2-text);
  line-height: 1.2;
  margin-bottom: .85rem;
  text-align: left !important;
} */
/* Mission & Vision */
.mv-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
}

.mv-card {
  background: var(--bg-card);
  padding: 40px;
  border-radius: 24px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
  transition: transform var(--transition);
}

.mv-card:hover {
  transform: translateY(-5px);
  border-color: var(--accent);
}

.mv-icon {
  font-size: 40px;
  color: var(--accent);
  margin-bottom: 20px;
}

.mv-title {
  font-size: 1.5rem;
  margin-bottom: 15px;
}

/* Commitment */
.commitment-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}

.commitment-card {
  background: var(--bg-card);
  padding: 30px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  text-align: center;
}

.c-icon {
  font-size: 32px;
  color: var(--accent);
  margin-bottom: 15px;
}

.c-title {
  font-size: 1.2rem;
  margin-bottom: 10px;
}

/* Safety */
.safety-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

.safety-visual {
  position: relative;
}

.safety-img-wrap {
  border-radius: 24px;
  overflow: hidden;
  box-shadow: var(--shadow-card);
}

.safety-img {
  width: 100%;
}

/* Team */
.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.team-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  text-align: center;
  transition: transform var(--transition);
}

.team-card:hover {
  transform: translateY(-5px);
  border-color: var(--accent);
}

.team-img-wrap {
  width: 100%;
  height: 250px;
  overflow: hidden;
}

.team-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}

.team-card:hover .team-img {
  transform: scale(1.05);
}

.team-info {
  padding: 20px;
}

.team-name {
  font-weight: 700;
  margin-bottom: 5px;
}

.team-role {
  color: var(--accent);
  font-size: 0.85rem;
  font-weight: 600;
}

/* Responsive */
@media (max-width: 1024px) {

  .about-grid,
  .safety-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

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

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

  .section-padding {
    padding: 60px 20px;
  }
}

@media (max-width: 767px) {

  .mv-grid,
  .commitment-grid,
  .team-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .about-grid,
  .safety-grid {
    gap: 30px;
  }

  .section-padding {
    padding: 40px 16px;
  }

  .mv-card {
    padding: 25px;
  }

  .team-img-wrap {
    height: 300px;
  }
}

/* RTL Support */
[dir="rtl"] .about-grid,
[dir="rtl"] .safety-grid {
  direction: rtl;
}

[dir="rtl"] .about-img-badge {
  left: auto;
  right: 20px;
}

[dir="rtl"] .team-name,
[dir="rtl"] .team-role,
[dir="rtl"] .c-title,
[dir="rtl"] .c-desc,
[dir="rtl"] .mv-title,
[dir="rtl"] .mv-title,
[dir="rtl"] .mv-desc {
  text-align: right;
}

/* ══════════════════════════════════
   SERVICES PAGE STYLES
══════════════════════════════════ */

/* 1. Service Overview */
.svc-intro-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

.svc-intro-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 16px;
  border: 1px solid var(--border-accent);
  border-radius: 30px;
  font-size: 0.74rem;
  font-weight: 600;
  color: var(--accent);
  background: var(--accent-glow);
  margin-bottom: 16px;
}

.svc-intro-title {
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 14px;
}

.svc-intro-title .hl {
  color: var(--accent);
}

.svc-intro-desc {
  font-size: 1rem;
  color: var(--text-secondary);
  line-height: 1.8;
  text-align: justify;
}

.svc-intro-img-wrap {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: var(--shadow-card);
}

.svc-intro-img {
  width: 100%;
  height: auto;
  display: block;
}

.svc-intro-img-badge {
  position: absolute;
  bottom: 20px;
  left: 20px;
  background: rgba(13, 17, 23, 0.85);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 12px 20px;
  border-radius: 30px;
  color: var(--accent);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--border-accent);
}

/* 2. Key Features */
.key-features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}

.kf-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 40px 30px;
  text-align: center;
  transition: transform 0.4s ease, box-shadow 0.4s ease;
  overflow: hidden;
  position: relative;
}

.kf-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  transform: scaleX(0);
  transition: transform 0.4s ease;
  transform-origin: left;
}

.kf-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-card);
  border-color: var(--border-accent);
}

.kf-card:hover::before {
  transform: scaleX(1);
}

.kf-icon {
  font-size: 3rem;
  color: var(--accent);
  margin-bottom: 25px;
  transition: transform 0.4s ease;
}

.kf-card:hover .kf-icon {
  transform: scale(1.1);
}

.kf-title {
  font-size: 1.3rem;
  margin-bottom: 15px;
  font-weight: 700;
}

.kf-desc {
  color: var(--text-secondary);
  font-size: 0.95rem;
}

/* 3. How It Works (Alt) */
.hiw-alt-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  position: relative;
  margin-top: 40px;
}

.hiw-alt-card {
  background: transparent;
  text-align: center;
  padding: 20px;
  transition: transform 0.3s ease;
}

.hiw-alt-card:hover {
  transform: translateY(-8px);
}

.hiw-alt-icon-wrap {
  width: 80px;
  height: 80px;
  background: var(--bg-card);
  border: 2px solid var(--accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: var(--accent);
  margin: 0 auto 20px;
  box-shadow: var(--shadow-accent);
  transition: background 0.3s ease, color 0.3s ease, transform 0.3s ease;
}

.hiw-alt-card:hover .hiw-alt-icon-wrap {
  background: var(--accent);
  color: #000;
  transform: scale(1.1);
}

.hiw-alt-title {
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 10px;
}

.hiw-alt-desc {
  font-size: 0.85rem;
  color: var(--text-secondary);
}

/* 4. Safety Standards */
.ss-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

.ss-image-wrap {
  border-radius: 24px;
  overflow: hidden;
  box-shadow: var(--shadow-card);
}

.ss-img {
  width: 100%;
  object-fit: scale-down;
  transition: transform 0.6s ease;
}

.ss-image-wrap:hover .ss-img {
  transform: scale(1.05);
}

.ss-list {
  margin-top: 30px;
}

.ss-item {
  display: flex;
  gap: 20px;
  margin-bottom: 25px;
  padding: 20px;
  background: var(--bg-card);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  transition: box-shadow 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
}

.ss-item:hover {
  box-shadow: var(--shadow-card);
  border-color: var(--accent);
  transform: translateX(5px);
}

.ss-icon {
  font-size: 2rem;
  color: var(--accent);
  flex-shrink: 0;
}

.ss-title {
  font-size: 1.15rem;
  font-weight: 700;
  margin-bottom: 5px;
}

.ss-desc {
  font-size: 0.9rem;
  color: var(--text-secondary);
}

/* 5. Benefits & Support */
.benefits-wrap {
  background: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-primary) 100%);
  border-radius: 24px;
  border: 1px solid var(--border);
  padding: 60px;
  box-shadow: var(--shadow-card);
  text-align: center;
}

.benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  margin-top: 40px;
}

.b-card {
  padding: 20px;
  transition: transform 0.3s ease;
}

.b-card:hover {
  transform: translateY(-5px);
}

.b-icon {
  font-size: 2.5rem;
  color: var(--accent);
  margin-bottom: 15px;
  transition: transform 0.3s ease;
}

.b-card:hover .b-icon {
  transform: scale(1.1) rotate(5deg);
}

.b-title {
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 10px;
}

/* Responsive Overrides */
@media (max-width: 1024px) {

  .key-features-grid,
  .benefits-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .hiw-alt-grid {
    grid-template-columns: repeat(2, 1fr);
  }

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

@media (max-width: 767px) {

  .key-features-grid,
  .hiw-alt-grid,
  .benefits-grid {
    grid-template-columns: 1fr;
  }

  .benefits-wrap {
    padding: 40px 20px;
  }

  .ss-item {
    flex-direction: column;
    text-align: center;
    align-items: center;
  }

  .ss-item:hover {
    transform: translateY(-5px);
    /* override translateX for mobile centering */
  }
}

/* RTL Adjustments */
[dir="rtl"] .ss-item {
  text-align: right;
}

[dir="rtl"] .ss-item:hover {
  transform: translateX(-5px);
}

[dir="rtl"] .kf-desc,
[dir="rtl"] .hiw-alt-desc,
[dir="rtl"] .b-card {
  text-align: right;
}

/* ══════════════════════════════════
   BOOK A RIDE PAGE STYLES
══════════════════════════════════ */
.book-section-title {
  display: flex;
  align-items: center;
  gap: 15px;
  font-size: 1.8rem;
  margin-bottom: 30px;
}

.step-num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 45px;
  height: 45px;
  background: var(--accent);
  color: #fff;
  border-radius: 50%;
  font-size: 1.2rem;
  font-weight: 800;
  box-shadow: var(--shadow-accent);
}

.book-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 40px;
  box-shadow: var(--shadow-card);
  transition: box-shadow 0.4s ease, border-color 0.4s ease;
}

.book-card:hover {
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.1);
  border-color: var(--border-accent);
}

.book-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
}

.input-group {
  display: flex;
  flex-direction: column;
}

.book-label {
  font-size: 0.95rem;
  font-weight: 600;
  margin-bottom: 8px;
  color: var(--text-primary);
}

.book-input {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  padding: 15px 20px;
  border-radius: 12px;
  color: var(--text-primary);
  font-family: inherit;
  font-size: 1rem;
  transition: all 0.3s ease;
}

.book-input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(0, 200, 150, 0.15);
  background: var(--bg-primary);
}

.book-input::placeholder {
  color: #8fa0ba;
}

.book-select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2300c896' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 15px center;
  background-size: 16px;
  padding-right: 40px;
}

/* Responsive */
@media (max-width: 1024px) {
  .book-card {
    padding: 30px;
  }
}

@media (max-width: 767px) {
  .book-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .book-card {
    padding: 20px;
  }

  .book-section-title {
    font-size: 1.4rem;
  }
}

/* RTL Adjustments */
[dir="rtl"] .book-section-title {
  flex-direction: row;
}

[dir="rtl"] .book-select {
  background-position: left 15px center;
  padding-right: 20px;
  padding-left: 40px;
}

/* ══════════════════════════════════
   PRICING PAGE STYLES
══════════════════════════════════ */

/* Fare Structure */
.fare-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}

.fare-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 40px 30px;
  text-align: center;
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.fare-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-card);
  border-color: var(--border-accent);
}

.fare-icon {
  font-size: 3rem;
  color: var(--accent);
  margin-bottom: 25px;
  transition: transform 0.4s ease;
}

.fare-card:hover .fare-icon {
  transform: scale(1.1);
}

.fare-title {
  font-size: 1.3rem;
  margin-bottom: 20px;
  font-weight: 700;
}

.fare-list {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: left;
}

.fare-list li {
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  color: var(--text-secondary);
}

.fare-list li:last-child {
  border-bottom: none;
}

.fare-list li strong {
  color: var(--text-primary);
}

/* Pricing Tiers */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  align-items: center;
}

.price-tier {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 40px;
  position: relative;
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.price-tier:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
  border-color: var(--border-accent);
}

.price-tier.featured {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent2) 100%);
  color: #fff;
  border: none;
  transform: scale(1.05);
  box-shadow: var(--shadow-accent);
}

.price-tier.featured:hover {
  transform: scale(1.05) translateY(-10px);
}

.popular-badge {
  position: absolute;
  top: -15px;
  left: 50%;
  transform: translateX(-50%);
  background: #000;
  color: #fff;
  padding: 8px 20px;
  border-radius: 20px;
  font-size: 0.85rem;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  border: 2px solid var(--accent);
}

.tier-header {
  text-align: center;
  margin-bottom: 30px;
  padding-bottom: 30px;
  border-bottom: 1px solid var(--border);
}

.price-tier.featured .tier-header {
  border-color: rgba(255, 255, 255, 0.2);
}

.price-amount {
  font-size: 3rem;
  font-weight: 800;
  margin: 15px 0;
  line-height: 1;
}

.tier-features {
  list-style: none;
  padding: 0;
  margin: 0 0 40px 0;
}

.tier-features li {
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  gap: 15px;
  color: var(--text-secondary);
}

.price-tier.featured .tier-features li {
  color: #fff;
}

.tier-features li i {
  color: var(--accent);
}

/* Additional Charges */
.add-charge-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
}

.charge-item {
  display: flex;
  gap: 20px;
  padding: 25px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: transform 0.3s ease, border-color 0.3s ease;
}

.charge-item:hover {
  transform: translateX(5px);
  border-color: var(--accent);
}

.charge-icon {
  font-size: 2rem;
  color: var(--accent);
  flex-shrink: 0;
}

.charge-info h4 {
  font-size: 1.15rem;
  margin-bottom: 8px;
}

.charge-info p {
  color: var(--text-secondary);
  font-size: 0.95rem;
  line-height: 1.5;
}

/* Payment Methods */
.pay-methods-flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
}

.pay-badge {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 15px 25px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 30px;
  font-weight: 600;
  color: var(--text-primary);
  transition: background 0.3s ease, color 0.3s ease;
}

.pay-badge:hover {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.pay-badge i {
  font-size: 1.5rem;
  color: var(--accent);
}

.pay-badge:hover i {
  color: #fff;
}

/* Responsive */
@media (max-width: 1024px) {
  .fare-grid {
    grid-template-columns: repeat(2, 1fr);
  }

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

  .price-tier.featured {
    transform: none;
    grid-column: 1 / -1;
  }
}

@media (max-width: 767px) {

  .fare-grid,
  .pricing-grid,
  .add-charge-grid {
    grid-template-columns: 1fr;
  }

  .charge-item {
    flex-direction: column;
    text-align: center;
    align-items: center;
  }
}

/* RTL Adjustments */
[dir="rtl"] .fare-list li,
[dir="rtl"] .tier-features li {
  text-align: right;
  flex-direction: row-reverse;
}

[dir="rtl"] .charge-item {
  text-align: right;
}

[dir="rtl"] .charge-item:hover {
  transform: translateX(-5px);
}

[dir="rtl"] .pay-badge {
  flex-direction: row-reverse;
}

/* ══════════════════════════════════
   AUTH PAGES (Login/Register)
══════════════════════════════════ */
.auth-page {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background: var(--bg-primary);
  /* Subtle lighting accents for premium feel */
  background-image: radial-gradient(circle at top right, rgba(0, 200, 150, 0.05), transparent 40%),
    radial-gradient(circle at bottom left, rgba(0, 200, 150, 0.05), transparent 40%);
  padding: 40px 20px;
}

.auth-controls {
  position: absolute;
  top: 20px;
  right: 20px;
  display: flex;
  gap: 15px;
}

.auth-container {
  width: 100%;
  max-width: 480px;
}

.auth-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 30px;
  text-decoration: none;
  color: var(--text-primary);
  transition: transform 0.3s ease;
}

.auth-logo:hover {
  transform: scale(1.05);
}

.auth-logo .logo-icon {
  font-size: 2.5rem;
  color: var(--accent);
  margin-right: 15px;
}

.auth-logo .brand {
  font-size: 2.2rem;
  font-weight: 800;
  font-family: 'Sora', sans-serif;
}

.auth-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 40px;
  box-shadow: var(--shadow-card);
}

.auth-title {
  font-size: 2rem;
  margin-bottom: 10px;
  text-align: center;
}

.auth-desc {
  text-align: center;
  color: var(--text-secondary);
  margin-bottom: 30px;
  font-size: 0.95rem;
}

.auth-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.password-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.password-wrap .book-input {
  width: 100%;
  padding-right: 45px;
}

.auth-eye {
  position: absolute;
  right: 15px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: color 0.3s;
}

.auth-eye:hover {
  color: var(--accent);
}

.auth-options {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.9rem;
  color: var(--text-secondary);
}

.auth-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.auth-checkbox input {
  accent-color: var(--accent);
  width: 16px;
  height: 16px;
  cursor: pointer;
}

.auth-options a {
  color: var(--accent);
  text-decoration: none;
  font-weight: 600;
  transition: opacity 0.3s;
}

.auth-options a:hover {
  opacity: 0.8;
}

.auth-submit {
  width: 100%;
  padding: 15px;
  justify-content: center;
  font-size: 1.1rem;
  margin-top: 10px;
  border: none;
  cursor: pointer;
}

.auth-footer {
  text-align: center;
  margin-top: 30px;
  font-size: 0.95rem;
  color: var(--text-secondary);
}

.auth-footer a {
  color: var(--accent);
  font-weight: 600;
  text-decoration: none;
}

.auth-footer a:hover {
  text-decoration: underline;
}

/* Auth Responsive */
@media (max-width: 767px) {
  .auth-card {
    padding: 30px 20px;
  }

  .auth-title {
    font-size: 1.6rem;
  }
}

/* RTL Adjustments */
[dir="rtl"] .auth-controls {
  right: auto;
  left: 20px;
}

[dir="rtl"] .auth-logo .logo-icon {
  margin-right: 0;
  margin-left: 15px;
}

[dir="rtl"] .password-wrap .book-input {
  padding-right: 20px;
  padding-left: 45px;
}

[dir="rtl"] .auth-eye {
  right: auto;
  left: 15px;
}

/* ============================================================
   HOME 2 – DEDICATED STYLESHEET
   MediRide Non-Emergency Medical Transport
   Responsive: Mobile 360-767 | Tablet 768-1024 | Desktop 1025+
   Dark mode default · Light mode via .light-mode on <html>
   RTL support via [dir="rtl"]
   ============================================================ */

/* ── Shared tokens (mirroring main style.css palette) ── */
:root {
  --h2-green: #10b981;
  --h2-green-dim: rgba(16, 185, 129, .15);
  --h2-green-glow: rgba(16, 185, 129, .35);
  --h2-blue: #3b82f6;
  --h2-blue-dim: rgba(59, 130, 246, .15);
  --h2-orange: #f59e0b;
  --h2-red: #ef4444;
  --h2-bg: #0a0f1a;
  --h2-surface: #111827;
  --h2-surface2: #1a2236;
  --h2-border: rgba(255, 255, 255, .08);
  --h2-text: #f1f5f9;
  --h2-text-muted: #94a3b8;
  --h2-radius: 16px;
  --h2-radius-sm: 10px;
  --h2-transition: .3s cubic-bezier(.4, 0, .2, 1);
}

.light-mode {
  --h2-bg: #f0f4f8;
  --h2-surface: #ffffff;
  --h2-surface2: #e8edf5;
  --h2-border: rgba(0, 0, 0, .09);
  --h2-text: #0f172a;
  --h2-text-muted: #64748b;
}

/* ── Reveal animation base ── */
/* NOTE: .h2-hero is intentionally excluded — its children animate via keyframes */
.h2-journey .reveal,
.h2-coverage .reveal,
.h2-team .reveal,
.h2-dashboard .reveal,
.h2-insurance .reveal,
.h2-faq .reveal,
.h2-process-card.reveal {
  opacity: 0;
  transform: translateY(36px);
  transition: opacity .65s ease, transform .65s ease;
}

.reveal.visible,
.h2-process-card.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ════════════════════════════════════════════════════════════
   HERO — DIAGONAL SPLIT DESIGN
   ════════════════════════════════════════════════════════════ */
.h2-hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--h2-bg);
  padding-top: 80px;
}

/* Background Image & Overlay */
.h2-hero-bg-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0.8;
}

.h2-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(10, 15, 26, 0.92) 0%, rgba(10, 15, 26, 0.6) 100%);
  z-index: 1;
}

/* Hero inner layout */
.h2-hero-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 4rem 1.5rem 6rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}

/* ── Dispatch panel (left) ── */
.h2-dispatch-panel {
  background: var(--h2-surface);
  border: 1px solid var(--h2-border);
  border-radius: var(--h2-radius);
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0, 0, 0, .4), 0 0 0 1px var(--h2-border);
  animation: h2-slideInLeft .9s cubic-bezier(.4, 0, .2, 1) both;
}

@keyframes h2-slideInLeft {
  from {
    opacity: 0;
    transform: translateX(-60px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.h2-dispatch-header {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .9rem 1.2rem;
  background: var(--h2-surface2);
  border-bottom: 1px solid var(--h2-border);
}

.h2-dispatch-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--h2-red);
}

.h2-dispatch-dot.orange {
  background: var(--h2-orange);
}

.h2-dispatch-dot.green {
  background: var(--h2-green);
}

.h2-dispatch-title {
  font-size: .72rem;
  font-weight: 600;
  color: var(--h2-text-muted);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-left: .5rem;
}

.h2-dispatch-body {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: .6rem;
}

.h2-trip-row {
  display: flex;
  align-items: center;
  gap: .8rem;
  padding: .75rem 1rem;
  border-radius: var(--h2-radius-sm);
  background: var(--h2-surface2);
  border: 1px solid var(--h2-border);
  transition: transform var(--h2-transition), box-shadow var(--h2-transition);
  cursor: default;
}

.h2-trip-row:hover {
  transform: translateX(4px);
  box-shadow: 0 4px 16px rgba(16, 185, 129, .15);
  border-color: var(--h2-green);
}

.h2-trip-row.active-trip {
  border-color: var(--h2-green);
  background: linear-gradient(90deg, var(--h2-green-dim), var(--h2-surface2));
  animation: h2-tripPulse 2s ease infinite;
}

@keyframes h2-tripPulse {

  0%,
  100% {
    box-shadow: 0 0 0 0 var(--h2-green-glow);
  }

  50% {
    box-shadow: 0 0 0 6px rgba(16, 185, 129, 0);
  }
}

.h2-trip-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: var(--h2-green-dim);
  color: var(--h2-green);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  flex-shrink: 0;
}

.h2-trip-info {
  flex: 1;
  min-width: 0;
}

.h2-trip-name {
  font-size: .8rem;
  font-weight: 600;
  color: var(--h2-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.h2-trip-detail {
  font-size: .7rem;
  color: var(--h2-text-muted);
}

.h2-trip-status {
  font-size: .68rem;
  font-weight: 700;
  color: var(--h2-text-muted);
  white-space: nowrap;
}

.h2-trip-status.live-badge {
  background: var(--h2-green);
  color: #fff;
  padding: .2rem .5rem;
  border-radius: 999px;
  animation: h2-blink 1.4s ease infinite;
}

.h2-trip-status.sched {
  color: var(--h2-blue);
}

.h2-trip-status.done {
  color: var(--h2-green);
}

@keyframes h2-blink {

  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: .5;
  }
}

/* Pulse ring */
.h2-pulse-ring {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.2rem;
  position: relative;
}

.h2-pulse-center {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--h2-green);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  z-index: 1;
  animation: h2-pulseCenterScale 2s ease infinite;
}

@keyframes h2-pulseCenterScale {

  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 var(--h2-green-glow);
  }

  50% {
    transform: scale(1.08);
    box-shadow: 0 0 0 14px rgba(16, 185, 129, 0);
  }
}

.h2-dispatch-footer {
  display: flex;
  justify-content: space-between;
  padding: .8rem 1.2rem;
  background: var(--h2-surface2);
  border-top: 1px solid var(--h2-border);
  font-size: .72rem;
  color: var(--h2-text-muted);
  font-weight: 500;
}

.h2-dispatch-footer span {
  display: flex;
  align-items: center;
  gap: .4rem;
}

/* ── Hero text (right) ── */
.h2-hero-text {
  animation: h2-slideInRight .9s cubic-bezier(.4, 0, .2, 1) .2s both;
}

@keyframes h2-slideInRight {
  from {
    opacity: 0;
    transform: translateX(60px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.h2-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--h2-green);
  background: var(--h2-green-dim);
  border: 1px solid rgba(16, 185, 129, .3);
  padding: .4rem .9rem;
  border-radius: 999px;
  margin-bottom: 1.5rem;
}

.h2-eyebrow-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--h2-green);
}

.h2-eyebrow-dot.pulse {
  animation: h2-blink 1.4s ease infinite;
}

.h2-hero-title {
  font-family: 'Sora', sans-serif;
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: 800;
  line-height: 1.1;
  color: #ffffff;
  margin-bottom: 1.25rem;
}

.h2-hl {
  background: linear-gradient(135deg, var(--h2-green), #34d399);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.h2-hero-desc {
  font-size: 1.05rem;
  line-height: 1.75;
  color: rgba(255, 255, 255, 0.85);
  margin-bottom: 2rem;
  max-width: 520px;
}

.h2-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 2rem;
}

.h2-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  background: linear-gradient(135deg, var(--h2-green), #059669);
  color: #fff;
  font-size: .95rem;
  font-weight: 700;
  padding: .9rem 1.75rem;
  border-radius: 12px;
  text-decoration: none;
  transition: transform var(--h2-transition), box-shadow var(--h2-transition), filter var(--h2-transition);
  box-shadow: 0 8px 24px var(--h2-green-glow);
}

.h2-btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 36px var(--h2-green-glow);
  filter: brightness(1.1);
}

.h2-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  background: transparent;
  color: #ffffff;
  font-size: .95rem;
  font-weight: 600;
  padding: .9rem 1.75rem;
  border-radius: 12px;
  text-decoration: none;
  border: 1px solid rgba(255, 255, 255, 0.25);
  transition: transform var(--h2-transition), border-color var(--h2-transition), box-shadow var(--h2-transition);
  backdrop-filter: blur(4px);
}

.h2-btn-secondary:hover {
  transform: translateY(-3px);
  border-color: var(--h2-green);
  box-shadow: 0 0 0 3px var(--h2-green-dim);
  color: var(--h2-green);
}

.h2-trust-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.h2-trust-item {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: .78rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.85);
}

.h2-trust-item i {
  color: var(--h2-green);
}

/* Scroll cue */
.h2-scroll-cue {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .4rem;
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--h2-text-muted);
  z-index: 3;
  animation: h2-fadeInUp 1.5s 1s both;
}

.h2-scroll-line {
  width: 1px;
  height: 50px;
  background: linear-gradient(to bottom, var(--h2-green), transparent);
  animation: h2-scrollPulse 2s ease infinite;
}

@keyframes h2-scrollPulse {

  0%,
  100% {
    opacity: 1;
    transform: scaleY(1);
  }

  50% {
    opacity: .4;
    transform: scaleY(.7);
  }
}

@keyframes h2-fadeInUp {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(20px);
  }

  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}


/* ════════════════════════════════════════════════════════════
   SHARED SECTION LAYOUT
   ════════════════════════════════════════════════════════════ */
.h2-section-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 5rem 1.5rem;
}

.h2-section-header {
  text-align: center;
  max-width: 750px;
  margin: 0 auto 3.5rem;
}

.h2-section-badge {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--h2-green);
  background: var(--h2-green-dim);
  border: 1px solid rgba(16, 185, 129, .25);
  padding: .35rem .85rem;
  border-radius: 999px;
  margin-bottom: 1rem;
}

.h2-section-title {
  font-family: 'Sora', sans-serif;
  font-size: clamp(1.75rem, 3.5vw, 2.6rem);
  font-weight: 800;
  color: var(--h2-text);
  line-height: 1.2;
  margin-bottom: .85rem;
}

.h2-section-desc {
  font-size: 1rem;
  line-height: 1.75;
  color: var(--h2-text-muted);
}


/* ════════════════════════════════════════════════════════════
   SECTION 1 — PATIENT JOURNEY TIMELINE
   ════════════════════════════════════════════════════════════ */
.h2-journey {
  background: var(--h2-bg);
  position: relative;
}


.h2-process-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 1rem;
}

@media (min-width: 1025px) {
  .h2-process-grid {
    grid-template-columns: repeat(6, 1fr);
  }

  .h2-process-card:nth-child(1),
  .h2-process-card:nth-child(2),
  .h2-process-card:nth-child(3) {
    grid-column: span 2;
  }

  .h2-process-card:nth-child(4) {
    grid-column: 2 / 4;
  }

  .h2-process-card:nth-child(5) {
    grid-column: 4 / 6;
  }
}

.h2-process-card {
  position: relative;
  background: var(--h2-surface);
  border: 1px solid var(--h2-border);
  border-radius: var(--h2-radius);
  padding: 2.5rem 2rem;
  overflow: hidden;
  transition: transform var(--h2-transition), border-color var(--h2-transition), box-shadow var(--h2-transition);
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.h2-process-card:hover {
  transform: translateY(-6px);
  border-color: var(--h2-green);
  box-shadow: 0 16px 48px rgba(16, 185, 129, .12);
}

.h2-process-num {
  position: absolute;
  top: -15px;
  right: 10px;
  font-family: "Sora", sans-serif;
  font-size: 6rem;
  font-weight: 800;
  line-height: 1;
  color: var(--h2-green);
  opacity: 0.05;
  pointer-events: none;
  transition: opacity var(--h2-transition), transform var(--h2-transition);
}

.h2-process-card:hover .h2-process-num {
  opacity: 0.15;
  transform: scale(1.1) rotate(-5deg);
}

.h2-process-icon {
  width: 54px;
  height: 54px;
  border-radius: 14px;
  background: var(--h2-green-dim);
  color: var(--h2-green);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  transition: background var(--h2-transition), color var(--h2-transition);
}

.h2-process-card:hover .h2-process-icon {
  background: var(--h2-green);
  color: #fff;
}

.h2-process-content {
  position: relative;
  z-index: 1;
}

.h2-process-title {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--h2-text);
  margin-bottom: .75rem;
}

.h2-process-desc {
  font-size: .9rem;
  line-height: 1.65;
  color: var(--h2-text-muted);
}



/* ════════════════════════════════════════════════════════════
   SECTION 2 — COVERAGE MAP
   ════════════════════════════════════════════════════════════ */
.h2-coverage {
  background: var(--h2-surface);
}

.h2-coverage-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: stretch;
}

/* Map visual */
.h2-map-visual {
  position: relative;
}

.h2-map-container {
  position: relative;
  height: 100%;
  min-height: 450px;
  border-radius: var(--h2-radius);
  overflow: hidden;
  border: 1px solid var(--h2-border);
  background: var(--h2-bg);
  box-shadow: 0 24px 80px rgba(0, 0, 0, .3);
}

.h2-map-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 42% 28%, rgba(16, 185, 129, .12) 0%, transparent 40%),
    radial-gradient(circle at 65% 45%, rgba(59, 130, 246, .1) 0%, transparent 35%),
    linear-gradient(135deg, var(--h2-bg) 0%, var(--h2-surface) 100%);
}

.h2-map-routes {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.h2-route-line {
  fill: none;
  stroke: var(--h2-green);
  stroke-width: 1.5;
  stroke-dasharray: 6 4;
  opacity: .5;
  animation: h2-dashFlow 3s linear infinite;
}

@keyframes h2-dashFlow {
  from {
    stroke-dashoffset: 0;
  }

  to {
    stroke-dashoffset: -40;
  }
}

.h2-map-pulse {
  position: absolute;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
}

.h2-map-ring {
  position: absolute;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 2px solid var(--h2-green);
  opacity: .35;
  animation: h2-mapRing 2s ease-out infinite;
  transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
}

@keyframes h2-mapRing {
  0% {
    transform: translate(-50%, -50%) scale(0);
    opacity: .5;
  }

  100% {
    transform: translate(-50%, -50%) scale(2.5);
    opacity: 0;
  }
}

.h2-map-pin {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--h2-green);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .75rem;
  box-shadow: 0 4px 12px var(--h2-green-glow);
  z-index: 1;
  cursor: pointer;
  transition: transform var(--h2-transition);
}

.h2-map-pin:hover {
  transform: scale(1.2);
}

.h2-map-label {
  font-size: .6rem;
  font-weight: 700;
  color: var(--h2-text);
  background: var(--h2-surface);
  padding: .15rem .45rem;
  border-radius: 4px;
  margin-top: .25rem;
  white-space: nowrap;
  border: 1px solid var(--h2-border);
}

.h2-map-fleet-card {
  position: absolute;
  bottom: 1rem;
  right: 1rem;
  background: var(--h2-surface);
  border: 1px solid var(--h2-green);
  border-radius: var(--h2-radius-sm);
  padding: .75rem 1.1rem;
  text-align: center;
  box-shadow: 0 8px 24px var(--h2-green-glow);
}

.h2-fleet-number {
  font-family: 'Sora', sans-serif;
  font-size: 2rem;
  font-weight: 800;
  color: var(--h2-green);
  line-height: 1;
}

.h2-fleet-label {
  font-size: .68rem;
  color: var(--h2-text-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
}

/* Coverage text */
.h2-coverage-text .h2-section-title {
  text-align: left;
}

.h2-coverage-text .h2-section-desc {
  text-align: left;
  margin-bottom: 2rem;
}

.h2-area-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.h2-area-item {
  display: flex;
  align-items: flex-start;
  gap: .9rem;
  padding: .9rem 1.1rem;
  background: var(--h2-bg);
  border: 1px solid var(--h2-border);
  border-radius: var(--h2-radius-sm);
  transition: border-color var(--h2-transition), transform var(--h2-transition);
}

.h2-area-item:hover {
  border-color: var(--h2-green);
  transform: translateX(4px);
}

.h2-area-item>i {
  color: var(--h2-green);
  font-size: 1rem;
  margin-top: .15rem;
  flex-shrink: 0;
}

.h2-area-item strong {
  display: block;
  font-size: .9rem;
  font-weight: 700;
  color: var(--h2-text);
}

.h2-area-item span {
  font-size: .8rem;
  color: var(--h2-text-muted);
}


/* ════════════════════════════════════════════════════════════
   SECTION 3 — MEET THE CARE TEAM
   ════════════════════════════════════════════════════════════ */
.h2-team {
  background: var(--h2-bg);
}

.h2-team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}

.h2-team-card {
  background: var(--h2-surface);
  border: 1px solid var(--h2-border);
  border-radius: var(--h2-radius);
  overflow: hidden;
  transition: transform var(--h2-transition), border-color var(--h2-transition), box-shadow var(--h2-transition);
}

.h2-team-card:hover {
  transform: translateY(-8px);
  border-color: var(--h2-green);
  box-shadow: 0 20px 60px rgba(16, 185, 129, .15);
}

.h2-team-card.featured-team {
  border-color: var(--h2-green);
  box-shadow: 0 8px 32px rgba(16, 185, 129, .2);
}

.h2-team-avatar-wrap {
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
}

.h2-team-avatar {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
  display: block;
}

.h2-team-card:hover .h2-team-avatar {
  transform: scale(1.06);
}

.h2-team-badge-overlay {
  position: absolute;
  top: .75rem;
  right: .75rem;
  background: var(--h2-green);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  padding: .25rem .55rem;
  border-radius: 999px;
  display: flex;
  align-items: center;
  gap: .3rem;
}

.h2-team-badge-overlay.care {
  background: var(--h2-orange);
}

.h2-team-badge-overlay.tech {
  background: var(--h2-blue);
}

.h2-team-badge-overlay.alert {
  background: var(--h2-red);
}

.h2-team-info {
  padding: 1.25rem;
}

.h2-team-name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--h2-text);
  margin-bottom: .2rem;
}

.h2-team-role {
  font-size: .75rem;
  color: var(--h2-green);
  font-weight: 600;
  margin-bottom: .75rem;
}

.h2-team-certs {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
  margin-bottom: .85rem;
}

.h2-cert-tag {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: .65rem;
  font-weight: 600;
  color: var(--h2-text-muted);
  background: var(--h2-surface2);
  border: 1px solid var(--h2-border);
  padding: .2rem .5rem;
  border-radius: 6px;
}

.h2-team-bio {
  font-size: .82rem;
  line-height: 1.6;
  color: var(--h2-text-muted);
}

.h2-team-cta {
  text-align: center;
  margin-top: 2.5rem;
}


/* ════════════════════════════════════════════════════════════
   SECTION 4 — LIVE TRIP DASHBOARD
   ════════════════════════════════════════════════════════════ */
.h2-dashboard {
  position: relative;
  background: linear-gradient(135deg, #0d1b2e 0%, #071422 50%, #0a1628 100%);
  overflow: hidden;
}

.h2-dashboard-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.h2-db-shape {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: .18;
}

.h2-db-shape.s1 {
  width: 500px;
  height: 500px;
  background: var(--h2-green);
  top: -200px;
  left: -100px;
}

.h2-db-shape.s2 {
  width: 400px;
  height: 400px;
  background: var(--h2-blue);
  bottom: -150px;
  right: -80px;
}

/* Override section-header colours for dark bg */
.h2-dashboard .h2-section-header {
  position: relative;
  z-index: 1;
}

/* Highlighted text on the dark dashboard bg */
.h2-hl-light {
  background: linear-gradient(135deg, #6ee7b7, #34d399);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.light-badge {
  color: var(--h2-green) !important;
}

.light-title {
  color: #f1f5f9 !important;
}

.light-desc {
  color: #94a3b8 !important;
}

/* Counters */
.h2-counters-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-bottom: 2.5rem;
  position: relative;
  z-index: 1;
}

.h2-counter-card {
  background: rgba(255, 255, 255, .04);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: var(--h2-radius);
  padding: 2rem 1.5rem;
  text-align: center;
  transition: transform var(--h2-transition), border-color var(--h2-transition), box-shadow var(--h2-transition);
  backdrop-filter: blur(8px);
}

.h2-counter-card:hover {
  transform: translateY(-6px);
  border-color: var(--h2-green);
  box-shadow: 0 16px 48px rgba(16, 185, 129, .2);
}

.h2-counter-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: var(--h2-green-dim);
  color: var(--h2-green);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  margin: 0 auto 1rem;
}

.h2-counter-num {
  font-family: 'Sora', sans-serif;
  font-size: 2.4rem;
  font-weight: 800;
  color: #f1f5f9;
  line-height: 1;
  margin-bottom: .35rem;
}

.h2-counter-label {
  font-size: .8rem;
  color: #94a3b8;
  font-weight: 600;
  margin-bottom: .75rem;
}

.h2-counter-trend {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: .72rem;
  font-weight: 600;
  padding: .25rem .6rem;
  border-radius: 999px;
}

.h2-counter-trend.up {
  background: rgba(16, 185, 129, .15);
  color: var(--h2-green);
  border: 1px solid rgba(16, 185, 129, .3);
}

/* Dashboard preview panel */
.h2-db-preview {
  background: rgba(255, 255, 255, .04);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: var(--h2-radius);
  overflow: hidden;
  backdrop-filter: blur(8px);
  position: relative;
  z-index: 1;
}

.h2-db-preview-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
  background: rgba(255, 255, 255, .03);
}

.h2-db-preview-title {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .85rem;
  font-weight: 700;
  color: #f1f5f9;
}

.live-dot-white {
  color: var(--h2-green);
  animation: h2-blink 1.4s ease infinite;
}

.h2-db-preview-date {
  font-size: .78rem;
  color: #64748b;
}

.h2-db-preview-body {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}

.h2-db-stat {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  padding: 1.25rem 1.5rem;
  border-right: 1px solid rgba(255, 255, 255, .07);
  border-bottom: 1px solid rgba(255, 255, 255, .07);
  transition: background var(--h2-transition);
}

.h2-db-stat:hover {
  background: rgba(255, 255, 255, .04);
}

.h2-db-stat:nth-child(3n) {
  border-right: none;
}

.h2-db-stat-label {
  font-size: .72rem;
  color: #64748b;
  font-weight: 500;
}

.h2-db-stat-val {
  font-size: 1.4rem;
  font-weight: 800;
  font-family: 'Sora', sans-serif;
  color: #f1f5f9;
}

.h2-db-stat-val.green {
  color: var(--h2-green);
}

.h2-db-stat-val.orange {
  color: var(--h2-orange);
}

.h2-db-stat-val.blue {
  color: var(--h2-blue);
}

.h2-db-preview-link {
  display: flex;
  align-items: center;
  gap: .5rem;
  justify-content: center;
  padding: 1rem;
  font-size: .85rem;
  font-weight: 600;
  color: var(--h2-green);
  text-decoration: none;
  border-top: 1px solid rgba(255, 255, 255, .07);
  transition: background var(--h2-transition);
}

.h2-db-preview-link:hover {
  background: var(--h2-green-dim);
}


/* ════════════════════════════════════════════════════════════
   SECTION 5 — INSURANCE & PAYMENT
   ════════════════════════════════════════════════════════════ */
.h2-insurance {
  background: var(--h2-surface);
}

.h2-insurance-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-bottom: 3rem;
}

.h2-ins-card {
  background: var(--h2-bg);
  border: 1px solid var(--h2-border);
  border-radius: var(--h2-radius);
  padding: 2rem 1.5rem;
  text-align: center;
  transition: transform var(--h2-transition), border-color var(--h2-transition), box-shadow var(--h2-transition);
}

.h2-ins-card:hover {
  transform: translateY(-6px);
  border-color: var(--h2-green);
  box-shadow: 0 16px 48px rgba(16, 185, 129, .15);
}

.h2-ins-card.featured-ins {
  border-color: var(--h2-green);
  background: linear-gradient(135deg, var(--h2-green-dim), var(--h2-bg));
  box-shadow: 0 8px 32px rgba(16, 185, 129, .2);
  position: relative;
}

.h2-ins-icon {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: var(--h2-green-dim);
  color: var(--h2-green);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  margin: 0 auto .75rem;
  transition: transform var(--h2-transition);
}

.h2-ins-card:hover .h2-ins-icon {
  transform: scale(1.1) rotate(-5deg);
}

.h2-ins-label {
  font-size: 1rem;
  font-weight: 700;
  color: var(--h2-text);
  margin-bottom: .5rem;
}

.h2-ins-desc {
  font-size: .82rem;
  line-height: 1.6;
  color: var(--h2-text-muted);
  margin-bottom: .85rem;
}

.h2-ins-check {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: .72rem;
  font-weight: 700;
  color: var(--h2-green);
}

/* Partner scroll strip */
.h2-partners-strip {
  text-align: center;
}

.h2-partners-label {
  font-size: .75rem;
  font-weight: 600;
  color: var(--h2-text-muted);
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-bottom: 1.2rem;
}

.h2-partners-scroll-wrapper {
  overflow: hidden;
  position: relative;
  mask-image: linear-gradient(90deg, transparent 0%, black 10%, black 90%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, black 10%, black 90%, transparent 100%);
}

.h2-partners-scroll {
  display: flex;
  gap: 1.2rem;
  width: max-content;
  animation: h2-scrollLeft 22s linear infinite;
}

@keyframes h2-scrollLeft {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

.h2-partners-scroll-wrapper:hover .h2-partners-scroll {
  animation-play-state: paused;
}

.h2-partner-badge {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: var(--h2-bg);
  border: 1px solid var(--h2-border);
  color: var(--h2-text-muted);
  font-size: .82rem;
  font-weight: 600;
  padding: .5rem 1.1rem;
  border-radius: 999px;
  white-space: nowrap;
  transition: border-color var(--h2-transition), color var(--h2-transition);
  cursor: default;
}

.h2-partner-badge i {
  color: var(--h2-green);
}

.h2-partner-badge:hover {
  border-color: var(--h2-green);
  color: var(--h2-text);
}


/* ════════════════════════════════════════════════════════════
   SECTION 6 — FAQ
   ════════════════════════════════════════════════════════════ */
.h2-faq {
  background: var(--h2-bg);
}

.h2-faq-grid {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 4rem;
  align-items: start;
}

/* Accordion */
.h2-accordion {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  margin-top: 2rem;
}

.h2-acc-item {
  background: var(--h2-surface);
  border: 1px solid var(--h2-border);
  border-radius: var(--h2-radius-sm);
  overflow: hidden;
  transition: border-color var(--h2-transition);
}

.h2-acc-item.open,
.h2-acc-item:hover {
  border-color: var(--h2-green);
}

.h2-acc-trigger {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1.1rem 1.3rem;
  background: none;
  border: none;
  cursor: pointer;
  font-size: .95rem;
  font-weight: 600;
  color: var(--h2-text);
  font-family: 'Sora', sans-serif;
  text-align: left;
}

.h2-acc-trigger:hover {
  color: var(--h2-green);
}

.h2-acc-icon {
  font-size: .75rem;
  color: var(--h2-text-muted);
  flex-shrink: 0;
  transition: transform .3s ease;
}

.h2-acc-item.open .h2-acc-icon {
  transform: rotate(180deg);
  color: var(--h2-green);
}

.h2-acc-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s cubic-bezier(.4, 0, .2, 1);
}

.h2-acc-body p {
  padding: 0 1.3rem 1.1rem;
  font-size: .9rem;
  line-height: 1.7;
  color: var(--h2-text-muted);
}

.h2-acc-item.open .h2-acc-body {
  max-height: 300px;
}

/* Contact card */
.h2-faq-contact {
  position: sticky;
  top: 100px;
}

.h2-contact-card {
  background: var(--h2-surface);
  border: 1px solid var(--h2-border);
  border-radius: var(--h2-radius);
  padding: 2rem;
  transition: box-shadow var(--h2-transition);
}

.h2-contact-card:hover {
  box-shadow: 0 16px 48px rgba(16, 185, 129, .12);
}

.h2-contact-card-icon {
  width: 60px;
  height: 60px;
  border-radius: 16px;
  background: var(--h2-green-dim);
  color: var(--h2-green);
  font-size: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.25rem;
}

.h2-contact-card-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--h2-text);
  margin-bottom: .5rem;
}

.h2-contact-card-desc {
  font-size: .88rem;
  line-height: 1.6;
  color: var(--h2-text-muted);
  margin-bottom: 1.5rem;
}

.h2-contact-methods {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  margin-bottom: 1.5rem;
}

.h2-contact-method-btn {
  display: flex;
  align-items: center;
  gap: .9rem;
  padding: .9rem 1.1rem;
  border-radius: var(--h2-radius-sm);
  text-decoration: none;
  background: var(--h2-surface2);
  border: 1px solid var(--h2-border);
  transition: transform var(--h2-transition), border-color var(--h2-transition), box-shadow var(--h2-transition);
}

.h2-contact-method-btn:hover {
  transform: translateX(4px);
  border-color: var(--h2-green);
  box-shadow: 0 4px 16px rgba(16, 185, 129, .12);
}

.h2-contact-method-btn.primary {
  background: linear-gradient(135deg, var(--h2-green-dim), var(--h2-surface2));
  border-color: rgba(16, 185, 129, .3);
}

.h2-contact-method-btn>i {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: var(--h2-green-dim);
  color: var(--h2-green);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  flex-shrink: 0;
}

.h2-cm-label {
  display: block;
  font-size: .7rem;
  color: var(--h2-text-muted);
  font-weight: 500;
}

.h2-cm-val {
  display: block;
  font-size: .88rem;
  font-weight: 700;
  color: var(--h2-text);
}

.h2-emergency-strip {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  padding: .9rem 1rem;
  border-radius: var(--h2-radius-sm);
  background: rgba(239, 68, 68, .08);
  border: 1px solid rgba(239, 68, 68, .25);
}

.h2-emergency-strip>i {
  color: var(--h2-red);
  font-size: 1rem;
  flex-shrink: 0;
  margin-top: .1rem;
}

.h2-emergency-strip strong {
  display: block;
  font-size: .82rem;
  font-weight: 700;
  color: var(--h2-red);
  margin-bottom: .15rem;
}

.h2-emergency-strip span {
  font-size: .75rem;
  color: var(--h2-text-muted);
  line-height: 1.5;
}


/* ════════════════════════════════════════════════════════════
   RTL SUPPORT
   ════════════════════════════════════════════════════════════ */


[dir="rtl"] .h2-timeline-item[data-side="right"] {
  direction: ltr;
}

[dir="rtl"] .h2-timeline-item[data-side="right"] .h2-tl-card {
  direction: rtl;
}

[dir="rtl"] .h2-area-item:hover {
  transform: translateX(-4px);
}

[dir="rtl"] .h2-trip-row:hover {
  transform: translateX(-4px);
}

[dir="rtl"] .h2-contact-method-btn:hover {
  transform: translateX(-4px);
}

[dir="rtl"] .h2-scroll-cue {
  left: auto;
  right: 50%;
  transform: translateX(50%);
}

[dir="rtl"] .h2-partners-scroll {
  animation-direction: reverse;
}

[dir="rtl"] .h2-faq-grid {
  direction: rtl;
}

[dir="rtl"] .h2-acc-trigger {
  text-align: right;
}

[dir="rtl"] .h2-coverage-text .h2-section-title,
[dir="rtl"] .h2-coverage-text .h2-section-desc {
  text-align: right;
}


/* ════════════════════════════════════════════════════════════
   LIGHT MODE OVERRIDES
   ════════════════════════════════════════════════════════════ */
.light-mode .h2-dispatch-panel,
.light-mode .h2-tl-card,
.light-mode .h2-ins-card,
.light-mode .h2-acc-item,
.light-mode .h2-contact-card,
.light-mode .h2-team-card {
  box-shadow: 0 4px 24px rgba(0, 0, 0, .08);
}

.light-mode .h2-map-container {
  background: #e8f4f1;
}

.light-mode .h2-dashboard {
  background: linear-gradient(135deg, #0d2b4a 0%, #0a1f35 100%);
}

.light-mode .h2-counter-card {
  background: rgba(255, 255, 255, .08);
  border-color: rgba(255, 255, 255, .15);
}

.light-mode .h2-db-preview {
  background: rgba(255, 255, 255, .06);
}

.light-mode .h2-partner-badge {
  background: #fff;
  border-color: rgba(0, 0, 0, .1);
}


/* ════════════════════════════════════════════════════════════
   RESPONSIVE — TABLET  768-1024
   ════════════════════════════════════════════════════════════ */
@media (min-width: 768px) and (max-width: 1024px) {
  .h2-hero-inner {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    padding: 3rem 1.25rem 5rem;
  }

  .h2-hero-title {
    font-size: 2.2rem;
  }

  .h2-dispatch-title {
    display: none;
  }

  .h2-counters-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .h2-team-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .h2-insurance-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .h2-coverage-grid {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }

  .h2-coverage-text .h2-section-title,
  .h2-coverage-text .h2-section-desc {
    text-align: center;
  }

  .h2-area-list {
    max-width: 600px;
    margin: 0 auto;
  }

  .h2-coverage-text>a {
    display: flex !important;
    justify-content: center;
  }

  .h2-faq-grid {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }

  .h2-faq-contact {
    position: static;
  }

  .h2-timeline-line {
    left: 32px;
    transform: none;
  }

  .h2-timeline-item {
    grid-template-columns: 64px 1fr;
    grid-template-rows: auto;
  }

  .h2-timeline-item[data-side="right"] {
    direction: ltr;
  }

  .h2-timeline-item[data-side="right"] .h2-tl-card {
    direction: ltr;
  }

  .h2-tl-node {
    flex-direction: row;
  }

  .h2-tl-num {
    display: none;
  }

  .h2-timeline-item .h2-tl-card {
    grid-column: 2;
  }

  /* 3-column placeholder cell is removed in tablet */
  .h2-timeline-item>*:last-child:not(.h2-tl-card):not(.h2-tl-node) {
    display: none;
  }

  .h2-db-preview-body {
    grid-template-columns: repeat(2, 1fr);
  }

  .h2-db-stat:nth-child(2n) {
    border-right: none;
  }

  .h2-db-stat:nth-child(3n) {
    border-right: 1px solid rgba(255, 255, 255, .07);
  }

  .h2-section-inner {
    padding: 4rem 1.25rem;
  }
}


/* ════════════════════════════════════════════════════════════
   RESPONSIVE — MOBILE  360-767
   ════════════════════════════════════════════════════════════ */
@media (max-width: 767px) {

  /* Hero */
  .h2-hero-inner {
    grid-template-columns: 1fr;
    gap: 2rem;
    padding: 2rem 1rem 4rem;
  }

  .h2-dispatch-panel {
    order: 2;
  }

  .h2-hero-text {
    order: 1;
  }

  .h2-hero-title {
    font-size: 2rem;
  }

  .h2-hero-desc {
    font-size: .92rem;
  }

  .h2-hero-actions {
    flex-direction: column;
  }

  .h2-btn-primary,
  .h2-btn-secondary {
    width: 100%;
    justify-content: center;
  }

  .h2-trust-strip {
    flex-direction: column;
    gap: .6rem;
  }

  .h2-scroll-cue {
    display: none;
  }

  /* Dispatch panel mobile condensed */
  .h2-dispatch-title {
    font-size: .6rem;
  }

  .h2-trip-detail {
    display: none;
  }

  /* Timeline */
  .h2-timeline-line {
    left: 20px;
    transform: none;
  }

  .h2-timeline-item {
    grid-template-columns: 44px 1fr;
    grid-template-rows: auto;
  }

  .h2-timeline-item[data-side="right"] {
    direction: ltr;
  }

  .h2-timeline-item[data-side="right"] .h2-tl-card {
    direction: ltr;
  }

  .h2-tl-icon {
    width: 44px;
    height: 44px;
    font-size: .95rem;
  }

  .h2-tl-num {
    display: none;
  }

  .h2-tl-node {
    flex-direction: row;
  }

  /* Hide third empty column */
  .h2-timeline-item>*:nth-child(3):not(.h2-tl-card):not(.h2-tl-node) {
    display: none;
  }

  /* Coverage */
  .h2-coverage-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .h2-coverage-text .h2-section-title,
  .h2-coverage-text .h2-section-desc {
    text-align: center;
  }

  .h2-coverage-text>a {
    display: flex !important;
    justify-content: center;
    width: 100%;
  }

  .h2-map-container {
    max-height: 280px;
  }

  /* Team */
  .h2-team-grid {
    grid-template-columns: 1fr;
  }

  /* Dashboard counters */
  .h2-counters-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }

  .h2-counter-num {
    font-size: 1.8rem;
  }

  .h2-db-preview-body {
    grid-template-columns: 1fr 1fr;
  }

  .h2-db-stat:nth-child(2n) {
    border-right: none;
  }

  .h2-db-stat:nth-child(3n) {
    border-right: 1px solid rgba(255, 255, 255, .07);
  }

  /* Insurance */
  .h2-insurance-grid {
    grid-template-columns: 1fr;
  }

  /* FAQ */
  .h2-faq-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .h2-faq-contact {
    position: static;
  }

  /* Sections */
  .h2-section-inner {
    padding: 3.5rem 1rem;
  }

  .h2-section-title {
    font-size: 1.6rem;
  }
}

@media (max-width: 420px) {
  .h2-counters-grid {
    grid-template-columns: 1fr;
  }

  .h2-counter-num {
    font-size: 2rem;
  }

  .h2-db-preview-body {
    grid-template-columns: 1fr;
  }

  .h2-db-stat {
    border-right: none !important;
  }
}

@media (max-width: 1024px) {
  .h2-process-grid {
    grid-template-columns: repeat(2, 1fr);
    align-items: stretch;
  }
}

@media (max-width: 767px) {
  .h2-process-grid {
    grid-template-columns: 1fr;
  }

  .h2-process-card {
    padding: 2rem 1.5rem;
  }
}

/* --- Admin Dashboard CSS --- */

/* ════════════════════════════════════════════════════════════════════════════ 
   MediRide — ADMIN DASHBOARD CSS
   Non-Emergency Medical Transport Service
   Unique prefix: nad- (MediRide Admin Dashboard)
════════════════════════════════════════════════════════════════════════════  */

:root {
  --nad-bg: #080c14;
  --nad-surface: #0f1520;
  --nad-surface2: #182030;
  --nad-border: rgba(255, 255, 255, 0.06);
  --nad-text: #dde5f0;
  --nad-muted: #7a8799;
  --nad-teal: #00c9a7;
  --nad-blue: #2563eb;
  --nad-amber: #f59e0b;
  --nad-red: #ef4444;
  --nad-purple: #8b5cf6;
  --nad-green: #10b981;
  --nad-sidebar-w: 265px;
  --nad-topbar-h: 68px;
  --nad-radius: 14px;
  --nad-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
  --nad-trans: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  font-family: 'Outfit', sans-serif;
}

.mediride-light {
  --nad-bg: #edf2f8;
  --nad-surface: #ffffff;
  --nad-surface2: #e1e8f4;
  --nad-border: rgba(0, 0, 0, 0.07);
  --nad-text: #1a2035;
  --nad-muted: #5b6882;
  --nad-shadow: 0 4px 24px rgba(0, 0, 0, 0.1);
}

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

html {
  scroll-behavior: smooth;
}

body.nad-body {
  background: var(--nad-bg);
  color: var(--nad-text);
  min-height: 100vh;
  overflow-x: hidden;
  transition: background var(--nad-trans), color var(--nad-trans);
}

/* ════════════════════════════════════════════════════════════════════════════ 
   MediRide — USER DASHBOARD CSS
   Non-Emergency Medical Transport Service
   Unique prefix: nud- (MediRide User Dashboard)
════════════════════════════════════════════════════════════════════════════  */

/* ════════════════════════════════════════════════════════════════════════════ 
   MediRide — ADMIN DASHBOARD CSS
   Non-Emergency Medical Transport Service
   Unique prefix: nad- (MediRide Admin Dashboard)
════════════════════════════════════════════════════════════════════════════  */

/* ——— SIDEBAR ——— */
.nad-sidebar {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: var(--nad-sidebar-w);
  background: var(--nad-surface);
  border-right: 1px solid var(--nad-border);
  z-index: 200;
  display: flex;
  flex-direction: column;
  transition: transform var(--nad-trans);
  overflow: hidden;
}

[dir="rtl"] .nad-sidebar {
  left: auto;
  right: 0;
  border-right: none;
  border-left: 1px solid var(--nad-border);
}

.nad-sidebar-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow-y: auto;
  padding-bottom: 1rem;
  scrollbar-width: none;
}

.nad-sidebar-inner::-webkit-scrollbar {
  display: none;
}

/* Logo */
.nad-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 1.5rem 1.25rem;
  text-decoration: none;
  border-bottom: 1px solid var(--nad-border);
  transition: opacity var(--nad-trans);
}

.nad-logo:hover {
  opacity: 0.85;
}

.nad-logo-icon {
  position: relative;
  width: 44px;
  height: 44px;
  background: linear-gradient(135deg, var(--nad-teal), var(--nad-blue));
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.1rem;
  flex-shrink: 0;
  box-shadow: 0 4px 18px rgba(0, 201, 167, 0.35);
}

.nad-logo-pulse {
  position: absolute;
  inset: -3px;
  border-radius: 14px;
  border: 2px solid var(--nad-teal);
  opacity: 0;
  animation: nadLogoPulse 3s ease infinite;
}

@keyframes nadLogoPulse {

  0%,
  100% {
    opacity: 0;
    transform: scale(1)
  }

  50% {
    opacity: 0.4;
    transform: scale(1.08)
  }
}

.nad-brand {
  display: block;
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--nad-text);
  letter-spacing: -0.3px;
}

.nad-sub {
  display: block;
  font-size: 0.62rem;
  color: var(--nad-teal);
  font-weight: 600;
  letter-spacing: 0.8px;
  text-transform: uppercase;
}

/* Profile */
.nad-profile-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0.9rem 1.25rem;
  margin: 1rem;
  background: var(--nad-surface2);
  border-radius: 12px;
  border: 1px solid var(--nad-border);
}

.nad-avatar {
  position: relative;
  width: 42px;
  height: 42px;
  background: linear-gradient(135deg, var(--nad-teal), var(--nad-blue));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.nad-status-dot {
  position: absolute;
  bottom: 1px;
  right: 1px;
  width: 10px;
  height: 10px;
  background: var(--nad-teal);
  border-radius: 50%;
  border: 2px solid var(--nad-surface);
  animation: nadBlink 2s ease infinite;
}

@keyframes nadBlink {

  0%,
  100% {
    opacity: 1
  }

  50% {
    opacity: 0.5
  }
}

.nad-pname {
  font-size: 0.875rem;
  font-weight: 600;
}

.nad-prole {
  font-size: 0.68rem;
}

.nad-role-badge {
  display: inline-block;
  background: linear-gradient(135deg, rgba(0, 201, 167, 0.2), rgba(37, 99, 235, 0.2));
  color: var(--nad-teal);
  padding: 1px 8px;
  border-radius: 20px;
  border: 1px solid rgba(0, 201, 167, 0.3);
  font-weight: 700;
  letter-spacing: 0.5px;
}

/* Nav */
.nad-nav {
  flex: 1;
  padding: 0.5rem 1rem;
}

.nad-nav-group {
  margin-bottom: 1.25rem;
}

.nad-nav-label {
  font-size: 0.63rem;
  text-transform: uppercase;
  letter-spacing: 1.4px;
  color: var(--nad-muted);
  padding: 0 0.5rem 0.5rem;
  display: block;
  font-weight: 700;
}

.nad-nav-item {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 0.6rem 0.75rem;
  border-radius: 10px;
  color: var(--nad-muted);
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
  transition: all var(--nad-trans);
  margin-bottom: 2px;
}

.nad-nav-item:hover {
  background: var(--nad-surface2);
  color: var(--nad-text);
  transform: translateX(4px);
}

[dir="rtl"] .nad-nav-item:hover {
  transform: translateX(-4px);
}

.nad-nav-item.active {
  background: linear-gradient(135deg, rgba(0, 201, 167, 0.12), rgba(37, 99, 235, 0.08));
  color: var(--nad-teal);
  border: 1px solid rgba(0, 201, 167, 0.18);
}

.nad-nav-item i {
  width: 18px;
  text-align: center;
  font-size: 0.88rem;
  flex-shrink: 0;
}

.nad-badge {
  margin-left: auto;
  font-size: 0.6rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 20px;
  background: var(--nad-blue);
  color: #fff;
}

.nad-badge.live {
  background: var(--nad-teal);
  animation: nadBlink 1.5s ease infinite;
}

.nad-badge.alert {
  background: var(--nad-red);
}

.nad-sidebar-foot {
  padding: 1rem 1.25rem;
  border-top: 1px solid var(--nad-border);
}

.nad-logout {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--nad-muted);
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
  padding: 0.6rem 0.5rem;
  border-radius: 8px;
  transition: all var(--nad-trans);
}

.nad-logout:hover {
  color: var(--nad-red);
  background: rgba(239, 68, 68, 0.08);
}

/* ——— OVERLAY ——— */
.nad-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(2px);
  z-index: 190;
  opacity: 0;
  transition: opacity var(--nad-trans);
}

.nad-overlay.visible {
  display: block;
  opacity: 1;
}

/* ——— MAIN ——— */
.nad-main {
  margin-left: var(--nad-sidebar-w);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  transition: margin var(--nad-trans);
}

[dir="rtl"] .nad-main {
  margin-left: 0;
  margin-right: var(--nad-sidebar-w);
}

/* Topbar */
.nad-topbar {
  position: sticky;
  top: 0;
  height: var(--nad-topbar-h);
  background: var(--nad-surface);
  border-bottom: 1px solid var(--nad-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 1.5rem;
  z-index: 100;
  backdrop-filter: blur(16px);
  transition: background var(--nad-trans);
}

.nad-topbar.scrolled {
  box-shadow: var(--nad-shadow);
}

.nad-topbar-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.nad-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
}

.nad-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--nad-text);
  border-radius: 2px;
  transition: all var(--nad-trans);
}

.nad-hamburger.open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.nad-hamburger.open span:nth-child(2) {
  opacity: 0;
}

.nad-hamburger.open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

#nadPageHeading {
  font-size: 1.25rem;
  font-weight: 700;
}

.nad-breadcrumb {
  font-size: 0.73rem;
  color: var(--nad-muted);
}

.nad-breadcrumb span {
  color: var(--nad-teal);
}

.nad-topbar-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.nad-system-status {
  display: flex;
  align-items: center;
  gap: 7px;
  background: rgba(0, 201, 167, 0.08);
  border: 1px solid rgba(0, 201, 167, 0.15);
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--nad-teal);
  white-space: nowrap;
}

.nad-sys-dot {
  width: 7px;
  height: 7px;
  background: var(--nad-teal);
  border-radius: 50%;
  animation: nadBlink 1s ease infinite;
}

.nad-ctrl-btn {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1px solid var(--nad-border);
  background: var(--nad-surface2);
  color: var(--nad-muted);
  cursor: pointer;
  font-size: 0.85rem;
  transition: all var(--nad-trans);
  position: relative;
}

.nad-ctrl-btn:hover {
  background: var(--nad-teal);
  color: #000;
  border-color: var(--nad-teal);
  transform: scale(1.05);
}

.nad-notif-dot {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 7px;
  height: 7px;
  background: var(--nad-red);
  border-radius: 50%;
  animation: nadBlink 1.5s ease infinite;
}

.nad-topbar-avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--nad-teal), var(--nad-blue));
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.78rem;
  color: #fff;
  cursor: pointer;
  box-shadow: 0 2px 10px rgba(0, 201, 167, 0.35);
  transition: transform var(--nad-trans);
}

.nad-topbar-avatar:hover {
  transform: scale(1.08);
}

/* ——— Content ——— */
.nad-content {
  flex: 1;
  padding: 1.5rem;
}

.nad-page {
  display: none;
}

.nad-page.active {
  display: block;
  animation: nadFade 0.35s ease;
}

@keyframes nadFade {
  from {
    opacity: 0;
    transform: translateY(10px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

.reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.5s ease, transform 0.5s ease;
  transition-delay: var(--delay, 0s);
}

.reveal.visible {
  opacity: 1;
  transform: none;
}

/* ——— KPI Row ——— */
.nad-kpi-row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.nad-kpi {
  background: var(--nad-surface);
  border: 1px solid var(--nad-border);
  border-radius: var(--nad-radius);
  padding: 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  transition: all var(--nad-trans);
  position: relative;
  overflow: hidden;
}

.nad-kpi::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent, rgba(255, 255, 255, 0.015));
  pointer-events: none;
}

.nad-kpi:hover {
  transform: translateY(-3px);
  box-shadow: var(--nad-shadow);
  border-color: var(--nad-teal);
}

.nad-kpi-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
}

.nad-kpi-icon.teal {
  background: rgba(0, 201, 167, 0.12);
  color: var(--nad-teal);
}

.nad-kpi-icon.blue {
  background: rgba(37, 99, 235, 0.12);
  color: var(--nad-blue);
}

.nad-kpi-icon.green {
  background: rgba(16, 185, 129, 0.12);
  color: var(--nad-green);
}

.nad-kpi-icon.amber {
  background: rgba(245, 158, 11, 0.12);
  color: var(--nad-amber);
}

.nad-kpi-icon.purple {
  background: rgba(139, 92, 246, 0.12);
  color: var(--nad-purple);
}

.nad-kpi-icon.red {
  background: rgba(239, 68, 68, 0.12);
  color: var(--nad-red);
}

.nad-kpi-val {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--nad-text);
  font-family: 'JetBrains Mono', monospace;
  line-height: 1.1;
}

.nad-kpi-lbl {
  font-size: 0.72rem;
  color: var(--nad-muted);
}

.nad-kpi-trend {
  font-size: 0.7rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 20px;
  align-self: flex-start;
}

.nad-kpi-trend.up {
  background: rgba(16, 185, 129, 0.12);
  color: var(--nad-green);
}

.nad-kpi-trend.down {
  background: rgba(239, 68, 68, 0.12);
  color: var(--nad-red);
}

/* ——— Charts Row ——— */
.nad-charts-row {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 1.25rem;
  margin-bottom: 1.5rem;
}

/* ——— Card ——— */
.nad-card {
  background: var(--nad-surface);
  border: 1px solid var(--nad-border);
  border-radius: var(--nad-radius);
  overflow: hidden;
  transition: box-shadow var(--nad-trans);
}

.nad-card:hover {
  box-shadow: var(--nad-shadow);
}

.nad-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--nad-border);
}

.nad-card-head h3 {
  font-size: 0.95rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
}

.nad-card-head h3 i {
  color: var(--nad-teal);
}

.nad-link {
  font-size: 0.78rem;
  color: var(--nad-teal);
  text-decoration: none;
  font-weight: 500;
  transition: opacity var(--nad-trans);
}

.nad-link:hover {
  opacity: 0.7;
}

/* ——— Bar Chart ——— */
.nad-chart-area {
  padding: 1.5rem 1.5rem 0;
}

.nad-bar-chart {
  display: flex;
  align-items: flex-end;
  gap: 12px;
  height: 140px;
}

.nad-bar-item {
  flex: 1;
  border-radius: 8px 8px 0 0;
  background: linear-gradient(180deg, var(--nad-teal) 0%, var(--nad-blue) 100%);
  transition: transform 0.4s ease, opacity 0.4s ease;
  cursor: pointer;
  position: relative;
}

.nad-bar-item:hover {
  opacity: 0.8;
  transform: scaleY(1.03);
  transform-origin: bottom;
}

.nad-bar-item::after {
  content: attr(data-val);
  position: absolute;
  top: -22px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--nad-teal);
  white-space: nowrap;
}

.nad-chart-labels {
  display: flex;
  justify-content: space-between;
  padding: 0.5rem 0 1rem;
  font-size: 0.7rem;
  color: var(--nad-muted);
}

/* ——— Donut ——— */
/* .nad-donut-card {} */
.nad-donut-wrap {
  position: relative;
  padding: 1.5rem;
  display: flex;
  justify-content: center;
}

.nad-donut {
  width: 160px;
  height: 160px;
  transform: rotate(-90deg);
  filter: drop-shadow(0 4px 12px rgba(0, 201, 167, 0.2));
}

.nad-donut-bg {
  fill: none;
  stroke: var(--nad-surface2);
  stroke-width: 18;
}

.nad-donut-seg {
  fill: none;
  stroke-width: 18;
  stroke-linecap: round;
  transition: stroke-dasharray 1s ease;
}

.nad-donut-seg.seg1 {
  stroke: var(--nad-teal);
}

.nad-donut-seg.seg2 {
  stroke: var(--nad-blue);
}

.nad-donut-seg.seg3 {
  stroke: var(--nad-amber);
}

.nad-donut-seg.seg4 {
  stroke: var(--nad-red);
}

.nad-donut-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  pointer-events: none;
}

.nad-donut-total {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--nad-text);
  font-family: 'JetBrains Mono', monospace;
  line-height: 1;
}

.nad-donut-sub {
  font-size: 0.7rem;
  color: var(--nad-muted);
}

.nad-donut-legend {
  list-style: none;
  padding: 0 1.5rem 1.25rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.nad-donut-legend li {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.78rem;
  color: var(--nad-muted);
}

.nad-donut-legend strong {
  margin-left: auto;
  font-size: 0.8rem;
  color: var(--nad-text);
}

.nad-leg-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.nad-leg-dot.teal {
  background: var(--nad-teal);
}

.nad-leg-dot.blue {
  background: var(--nad-blue);
}

.nad-leg-dot.amber {
  background: var(--nad-amber);
}

.nad-leg-dot.red {
  background: var(--nad-red);
}

.nad-leg-dot.green {
  background: var(--nad-green);
}

.nad-leg-dot.purple {
  background: var(--nad-purple);
}

/* ——— Two Col ——— */
.nad-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  margin-bottom: 1.5rem;
}

/* ——— Table ——— */
.nad-table-wrap {
  overflow-x: auto;
}

.nad-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.84rem;
}

.nad-table th {
  padding: 0.75rem 1rem;
  text-align: left;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.9px;
  color: var(--nad-muted);
  border-bottom: 1px solid var(--nad-border);
  white-space: nowrap;
}

[dir="rtl"] .nad-table th {
  text-align: right;
}

.nad-table td {
  padding: 0.85rem 1rem;
  border-bottom: 1px solid var(--nad-border);
  color: var(--nad-text);
  white-space: nowrap;
}

.nad-table tr:last-child td {
  border-bottom: none;
}

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

.nad-table tbody tr:hover {
  background: var(--nad-surface2);
}

.nad-td-icon {
  color: var(--nad-teal);
  margin-right: 5px;
}

.nad-tbl-badge {
  font-size: 0.68rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
}

.nad-tbl-badge.active {
  background: rgba(37, 99, 235, 0.12);
  color: var(--nad-blue);
}

.nad-tbl-badge.arrived {
  background: rgba(16, 185, 129, 0.12);
  color: var(--nad-green);
}

.nad-tbl-badge.pickup {
  background: rgba(245, 158, 11, 0.12);
  color: var(--nad-amber);
}

.nad-tbl-badge.completed {
  background: rgba(0, 201, 167, 0.12);
  color: var(--nad-teal);
}

.nad-tbl-badge.cancelled {
  background: rgba(239, 68, 68, 0.12);
  color: var(--nad-red);
}

.nad-red {
  color: var(--nad-red);
}

.nad-tbl-btn {
  background: var(--nad-surface2);
  border: 1px solid var(--nad-border);
  color: var(--nad-text);
  padding: 4px 12px;
  border-radius: 8px;
  font-size: 0.78rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--nad-trans);
  font-family: 'Outfit', sans-serif;
  margin-right: 4px;
}

.nad-tbl-btn:hover {
  background: var(--nad-teal);
  color: #000;
  border-color: var(--nad-teal);
}

.nad-tbl-btn-sm {
  padding: 3px 10px;
  font-size: 0.73rem;
}

/* ——— Alert List ——— */
.nad-alert-list {
  list-style: none;
}

.nad-alert-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.9rem 1.5rem;
  border-bottom: 1px solid var(--nad-border);
  transition: background var(--nad-trans);
}

.nad-alert-item:last-child {
  border-bottom: none;
}

.nad-alert-item:hover {
  background: var(--nad-surface2);
}

.nad-alert-ico {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  flex-shrink: 0;
}

.nad-alert-item.critical .nad-alert-ico {
  background: rgba(239, 68, 68, 0.12);
  color: var(--nad-red);
}

.nad-alert-item.warning .nad-alert-ico {
  background: rgba(245, 158, 11, 0.12);
  color: var(--nad-amber);
}

.nad-alert-item.info .nad-alert-ico {
  background: rgba(37, 99, 235, 0.12);
  color: var(--nad-blue);
}

.nad-alert-item.success .nad-alert-ico {
  background: rgba(16, 185, 129, 0.12);
  color: var(--nad-green);
}

.nad-alert-body {
  flex: 1;
}

.nad-alert-body p {
  font-size: 0.85rem;
  color: var(--nad-text);
  margin-bottom: 3px;
}

.nad-alert-body span {
  font-size: 0.72rem;
  color: var(--nad-muted);
}

.nad-alert-full .nad-alert-item {
  align-items: flex-start;
}

.nad-alert-full .nad-tbl-btn {
  flex-shrink: 0;
}

/* ——— Live Badge ——— */
.nad-live-badge {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.73rem;
  font-weight: 700;
  color: var(--nad-teal);
  background: rgba(0, 201, 167, 0.08);
  padding: 3px 10px;
  border-radius: 20px;
}

.nad-pulse-dot {
  width: 7px;
  height: 7px;
  background: var(--nad-teal);
  border-radius: 50%;
  animation: nadBlink 1s ease infinite;
}

/* ——— Fleet Grid ——— */
.nad-fleet-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  padding: 1.5rem;
}

.nad-vehicle-card {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: var(--nad-surface2);
  border: 1px solid var(--nad-border);
  border-radius: 12px;
  padding: 1rem;
  transition: all var(--nad-trans);
}

.nad-vehicle-card:hover {
  border-color: var(--nad-teal);
  transform: translateY(-2px);
}

.nad-v-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(0, 201, 167, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--nad-teal);
  font-size: 1.1rem;
  flex-shrink: 0;
}

.nad-v-icon.nad-maint {
  background: rgba(239, 68, 68, 0.1);
  color: var(--nad-red);
}

.nad-v-info {
  flex: 1;
}

.nad-v-info h4 {
  font-size: 0.9rem;
  font-weight: 700;
  margin-bottom: 3px;
}

.nad-v-info p {
  font-size: 0.75rem;
  color: var(--nad-muted);
  margin-bottom: 2px;
}

.nad-v-driver i {
  color: var(--nad-teal);
  margin-right: 4px;
}

/* ——— Map Full ——— */
.nad-map-full {
  position: relative;
  height: 360px;
  background: #050a15;
  overflow: hidden;
}

.mediride-light .nad-map-full {
  background: #dce8f8;
}

.nad-map-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0, 201, 167, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 201, 167, 0.04) 1px, transparent 1px);
  background-size: 28px 28px;
}

.nad-map-road {
  position: absolute;
  background: rgba(255, 255, 255, 0.06);
}

.nad-road-h {
  left: 0;
  right: 0;
  height: 14px;
  transform: translateY(-50%);
}

.nad-road-v {
  top: 0;
  bottom: 0;
  width: 14px;
  transform: translateX(-50%);
}

.nad-fleet-pin {
  position: absolute;
  left: var(--tx);
  top: var(--ty);
  width: 34px;
  height: 34px;
  background: var(--nad-teal);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #000;
  font-size: 0.85rem;
  transform: translate(-50%, -50%);
  z-index: 10;
  box-shadow: 0 0 16px rgba(0, 201, 167, 0.5);
  animation: nadDriveAnim 8s ease-in-out infinite alternate;
  animation-delay: var(--delay, 0s);
}

@keyframes nadDriveAnim {
  0% {
    left: var(--tx);
    top: var(--ty);
  }

  50% {
    left: calc(var(--tx) + 8%);
    top: calc(var(--ty) - 5%);
  }

  100% {
    left: calc(var(--tx) + 15%);
    top: calc(var(--ty) - 8%);
  }
}

.nad-pin-idle {
  background: var(--nad-blue);
  box-shadow: 0 0 12px rgba(37, 99, 235, 0.4);
  animation: none;
}

.nad-fleet-ping {
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  border: 2px solid var(--nad-teal);
  animation: nadPing 1.8s ease infinite;
}

@keyframes nadPing {
  0% {
    opacity: 0.8;
    transform: scale(1)
  }

  100% {
    opacity: 0;
    transform: scale(1.8)
  }
}

.nad-dest-pin {
  position: absolute;
  width: 28px;
  height: 28px;
  background: var(--nad-red);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 0.7rem;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 10px rgba(239, 68, 68, 0.5);
}

.nad-map-legend {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  padding: 0.9rem 1.5rem;
  border-top: 1px solid var(--nad-border);
  font-size: 0.78rem;
  color: var(--nad-muted);
}

.nad-map-legend span {
  display: flex;
  align-items: center;
  gap: 6px;
}

.nad-map-count {
  margin-left: auto;
  color: var(--nad-teal);
  font-weight: 600;
}

/* ——— Form ——— */
.nad-schedule-card .nad-book-form {
  padding: 1.5rem;
}

.nad-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1rem;
}

.nad-form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.nad-form-full {
  margin-bottom: 1rem;
}

.nad-form-group label {
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--nad-muted);
}

.nad-form-group label i {
  margin-right: 5px;
  color: var(--nad-teal);
}

.nad-input {
  background: var(--nad-surface2);
  border: 1px solid var(--nad-border);
  border-radius: 10px;
  padding: 0.7rem 1rem;
  color: var(--nad-text);
  font-family: 'Outfit', sans-serif;
  font-size: 0.9rem;
  transition: border-color var(--nad-trans), box-shadow var(--nad-trans);
  width: 100%;
}

.nad-input:focus {
  outline: none;
  border-color: var(--nad-teal);
  box-shadow: 0 0 0 3px rgba(0, 201, 167, 0.1);
}

.nad-select {
  appearance: none;
  cursor: pointer;
}

.nad-textarea {
  resize: vertical;
  min-height: 90px;
}

.nad-book-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

/* ——— Buttons ——— */
.nad-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--nad-teal), var(--nad-blue));
  color: #000;
  border: none;
  padding: 0.7rem 1.5rem;
  border-radius: 10px;
  font-family: 'Outfit', sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  transition: all var(--nad-trans);
  box-shadow: 0 4px 15px rgba(0, 201, 167, 0.3);
}

.nad-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 22px rgba(0, 201, 167, 0.45);
}

.nad-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--nad-surface2);
  color: var(--nad-text);
  border: 1px solid var(--nad-border);
  padding: 0.7rem 1.5rem;
  border-radius: 10px;
  font-family: 'Outfit', sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: all var(--nad-trans);
}

.nad-btn-secondary:hover {
  background: var(--nad-border);
}

.nad-btn-sm {
  padding: 0.4rem 1rem;
  font-size: 0.78rem;
}

/* ——— Search ——— */
.nad-filter-row {
  display: flex;
  gap: 0.5rem;
}

.nad-mini-select {
  background: var(--nad-surface2);
  border: 1px solid var(--nad-border);
  color: var(--nad-text);
  padding: 0.4rem 0.75rem;
  border-radius: 8px;
  font-family: 'Outfit', sans-serif;
  font-size: 0.8rem;
  cursor: pointer;
}

.nad-search-input {
  background: var(--nad-surface2);
  border: 1px solid var(--nad-border);
  color: var(--nad-text);
  padding: 0.4rem 0.85rem;
  border-radius: 8px;
  font-family: 'Outfit', sans-serif;
  font-size: 0.8rem;
  transition: border-color var(--nad-trans);
}

.nad-search-input:focus {
  outline: none;
  border-color: var(--nad-teal);
}

/* ——— Driver Grid ——— */
.nad-driver-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  padding: 1.5rem;
}

.nad-driver-card {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: var(--nad-surface2);
  border: 1px solid var(--nad-border);
  border-radius: 12px;
  padding: 1rem;
  transition: all var(--nad-trans);
}

.nad-driver-card:hover {
  border-color: var(--nad-teal);
  transform: translateY(-2px);
  box-shadow: var(--nad-shadow);
}

.nad-drv-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(0, 201, 167, 0.15), rgba(37, 99, 235, 0.15));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--nad-teal);
  font-size: 1.1rem;
  flex-shrink: 0;
}

.nad-drv-info {
  flex: 1;
}

.nad-drv-info h4 {
  font-size: 0.875rem;
  font-weight: 700;
  margin-bottom: 3px;
}

.nad-drv-info p {
  font-size: 0.72rem;
  color: var(--nad-muted);
}

.nad-drv-rating {
  color: var(--nad-amber) !important;
  margin-top: 2px;
}

.nad-drv-rating i {
  margin-right: 3px;
}

/* â”€â”€â”€ Reports â”€â”€â”€ */
.nad-reports-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1.25rem;
}

.nad-sparkline-chart {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  height: 120px;
  padding: 1.25rem 1.25rem 0;
}

.nad-spark-bar {
  flex: 1;
  border-radius: 6px 6px 0 0;
  background: var(--c, var(--nad-teal));
  opacity: 0.75;
  transition: all 0.5s ease;
}

.nad-spark-bar:hover {
  opacity: 1;
  transform: scaleY(1.05);
  transform-origin: bottom;
}

.nad-report-stats {
  display: flex;
  justify-content: space-between;
  padding: 0.75rem 1.25rem 1.25rem;
  font-size: 0.78rem;
  color: var(--nad-muted);
}

.nad-report-stats strong {
  color: var(--nad-teal);
  font-weight: 700;
}

.nad-perf-list {
  list-style: none;
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.nad-perf-list li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.82rem;
}

.nad-perf-list span {
  width: 120px;
  flex-shrink: 0;
  color: var(--nad-text);
}

.nad-perf-bar-wrap {
  flex: 1;
  height: 6px;
  background: var(--nad-surface2);
  border-radius: 6px;
  overflow: hidden;
}

.nad-perf-bar {
  height: 100%;
  border-radius: 6px;
  background: var(--c, var(--nad-teal));
  transition: width 1s ease;
}

.nad-perf-list strong {
  width: 36px;
  text-align: right;
  color: var(--nad-teal);
  font-size: 0.78rem;
}

.nad-export-btns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  padding: 1.25rem;
}

.nad-export-btn {
  justify-content: center;
}

/* â”€â”€â”€ Billing â”€â”€â”€ */
.nad-billing-kpi {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--nad-border);
}

.nad-bil-k p {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--nad-muted);
  margin-bottom: 4px;
}

.nad-bil-k strong {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--nad-text);
  font-family: 'JetBrains Mono', monospace;
}

/* â”€â”€â”€ Settings â”€â”€â”€ */
.nad-settings-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 2rem;
  padding: 1.5rem;
}

.nad-set-section h4 {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--nad-teal);
  margin-bottom: 1rem;
}

.nad-set-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
  font-size: 0.875rem;
  color: var(--nad-text);
}

.nad-toggle {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
  cursor: pointer;
}

.nad-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.nad-slider {
  position: absolute;
  inset: 0;
  background: var(--nad-surface2);
  border: 1px solid var(--nad-border);
  border-radius: 24px;
  transition: background var(--nad-trans);
}

.nad-slider::before {
  content: '';
  position: absolute;
  left: 3px;
  top: 50%;
  width: 16px;
  height: 16px;
  background: var(--nad-muted);
  border-radius: 50%;
  transform: translateY(-50%);
  transition: all var(--nad-trans);
}

.nad-toggle input:checked+.nad-slider {
  background: var(--nad-teal);
  border-color: var(--nad-teal);
}

.nad-toggle input:checked+.nad-slider::before {
  left: 23px;
  background: #000;
}

/* â”€â”€â”€ Toast â”€â”€â”€ */
.nad-toast {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  background: var(--nad-surface);
  border: 1px solid var(--nad-teal);
  color: var(--nad-text);
  padding: 0.9rem 1.5rem;
  border-radius: 12px;
  font-size: 0.875rem;
  font-weight: 500;
  z-index: 1000;
  transform: translateY(20px);
  opacity: 0;
  pointer-events: none;
  transition: all var(--nad-trans);
  box-shadow: var(--nad-shadow);
  max-width: 320px;
}

[dir="rtl"] .nad-toast {
  right: auto;
  left: 1.5rem;
}

.nad-toast.show {
  opacity: 1;
  transform: translateY(0);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   RESPONSIVE
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* Large Tablet: 1025â€“1280 */
@media (max-width: 1280px) {
  .nad-kpi-row {
    grid-template-columns: repeat(3, 1fr);
  }

  .nad-charts-row {
    grid-template-columns: 1fr;
  }

  .nad-donut-card {
    max-width: 100%;
  }

  .nad-donut-legend {
    grid-template-columns: repeat(4, 1fr);
  }

  .nad-reports-grid {
    grid-template-columns: 1fr 1fr;
  }

  .nad-fleet-grid {
    grid-template-columns: 1fr 1fr;
  }

  .nad-driver-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* Tablet: 768â€“1024 */
@media (max-width: 1024px) {
  :root {
    --nad-sidebar-w: 250px;
  }

  .nad-sidebar {
    transform: translateX(-100%);
  }

  [dir="rtl"] .nad-sidebar {
    transform: translateX(100%);
  }

  .nad-sidebar.open {
    transform: translateX(0);
    box-shadow: 8px 0 48px rgba(0, 0, 0, 0.6);
  }

  [dir="rtl"] .nad-sidebar.open {
    box-shadow: -8px 0 48px rgba(0, 0, 0, 0.6);
  }

  .nad-main {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .nad-hamburger {
    display: flex;
  }

  .nad-system-status .nad-sys-label {
    display: none;
  }

  .nad-two-col {
    grid-template-columns: 1fr;
  }

  .nad-kpi-row {
    grid-template-columns: repeat(3, 1fr);
  }

  .nad-settings-grid {
    grid-template-columns: 1fr 1fr;
  }

  .nad-billing-kpi {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile: 360â€“767 */
@media (max-width: 767px) {
  .nad-content {
    padding: 1rem;
  }

  .nad-kpi-row {
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
  }

  .nad-kpi-val {
    font-size: 1.25rem;
  }

  .nad-charts-row {
    grid-template-columns: 1fr;
  }

  .nad-form-row {
    grid-template-columns: 1fr;
  }

  .nad-fleet-grid {
    grid-template-columns: 1fr;
  }

  .nad-driver-grid {
    grid-template-columns: 1fr;
  }

  .nad-reports-grid {
    grid-template-columns: 1fr;
  }

  .nad-settings-grid {
    grid-template-columns: 1fr;
  }

  .nad-billing-kpi {
    grid-template-columns: 1fr 1fr;
  }

  .nad-topbar {
    padding: 0 1rem;
  }

  .nad-topbar-right {
    gap: 0.3rem;
  }

  .nad-ctrl-btn {
    width: 34px;
    height: 34px;
  }
}

@media (max-width: 480px) {
  .nad-kpi-row {
    grid-template-columns: 1fr;
  }

  .nad-topbar-avatar {
    display: none;
  }

  #nadPageHeading {
    font-size: 1.05rem;
  }
}


/* --- User Dashboard CSS --- */

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   MediRide â€” USER DASHBOARD CSS
   Non-Emergency Medical Transport Service
   Unique prefix: nud- (MediRide User Dashboard)
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€â”€ CSS Variables â”€â”€â”€ */
:root {
  --nud-bg: #0d1117;
  --nud-surface: #161b26;
  --nud-surface2: #1e2535;
  --nud-border: rgba(255, 255, 255, 0.07);
  --nud-text: #e8eaf0;
  --nud-muted: #8892a4;
  --nud-accent: #00d4aa;
  --nud-accent2: #0099ff;
  --nud-amber: #f59e0b;
  --nud-red: #ef4444;
  --nud-purple: #a855f7;
  --nud-green: #10b981;
  --nud-sidebar-w: 260px;
  --nud-topbar-h: 70px;
  --nud-radius: 14px;
  --nud-shadow: 0 4px 24px rgba(0, 0, 0, 0.4);
  --nud-trans: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  font-family: 'Outfit', sans-serif;
}

.mediride-light {
  --nud-bg: #f0f4f8;
  --nud-surface: #ffffff;
  --nud-surface2: #e8edf5;
  --nud-border: rgba(0, 0, 0, 0.08);
  --nud-text: #1a202c;
  --nud-muted: #64748b;
  --nud-shadow: 0 4px 24px rgba(0, 0, 0, 0.1);
}

/* â”€â”€â”€ Reset â”€â”€â”€ */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body.nud-body {
  background: var(--nud-bg);
  color: var(--nud-text);
  min-height: 100vh;
  overflow-x: hidden;
  transition: background var(--nud-trans), color var(--nud-trans);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SIDEBAR
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.nud-sidebar {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: var(--nud-sidebar-w);
  background: var(--nud-surface);
  border-right: 1px solid var(--nud-border);
  display: flex;
  flex-direction: column;
  z-index: 200;
  transition: transform var(--nud-trans), width var(--nud-trans);
  overflow: hidden;
}

[dir="rtl"] .nud-sidebar {
  left: auto;
  right: 0;
  border-right: none;
  border-left: 1px solid var(--nud-border);
}

.nud-sidebar-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow-y: auto;
  padding: 0 0 1rem;
  scrollbar-width: none;
}

.nud-sidebar-inner::-webkit-scrollbar {
  display: none;
}

/* Logo */
.nud-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 1.5rem 1.25rem;
  text-decoration: none;
  border-bottom: 1px solid var(--nud-border);
  transition: opacity var(--nud-trans);
}

.nud-logo:hover {
  opacity: 0.85;
}

.nud-logo-icon {
  position: relative;
  width: 42px;
  height: 42px;
  background: linear-gradient(135deg, var(--nud-accent), var(--nud-accent2));
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.1rem;
  flex-shrink: 0;
  box-shadow: 0 4px 15px rgba(0, 212, 170, 0.35);
}

.nud-logo-pulse {
  position: absolute;
  inset: -3px;
  border-radius: 14px;
  border: 2px solid var(--nud-accent);
  opacity: 0;
  animation: nudLogoPulse 2.5s ease infinite;
}

@keyframes nudLogoPulse {

  0%,
  100% {
    opacity: 0;
    transform: scale(1)
  }

  50% {
    opacity: 0.5;
    transform: scale(1.08)
  }
}

.nud-brand {
  display: block;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--nud-text);
  letter-spacing: -0.3px;
}

.nud-sub {
  display: block;
  font-size: 0.65rem;
  color: var(--nud-muted);
  font-weight: 400;
}

/* Profile Card */
.nud-profile-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 1rem 1.25rem;
  margin: 1rem;
  background: var(--nud-surface2);
  border-radius: 12px;
  border: 1px solid var(--nud-border);
}

.nud-avatar {
  position: relative;
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg, var(--nud-accent2), var(--nud-purple));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1rem;
  flex-shrink: 0;
}

.nud-status-dot {
  position: absolute;
  bottom: 1px;
  right: 1px;
  width: 10px;
  height: 10px;
  background: var(--nud-green);
  border-radius: 50%;
  border: 2px solid var(--nud-surface);
}

.nud-pname {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--nud-text);
}

.nud-prole {
  font-size: 0.72rem;
  color: var(--nud-muted);
}

/* Nav */
.nud-nav {
  flex: 1;
  padding: 0.5rem 1rem;
}

.nud-nav-group {
  margin-bottom: 1.5rem;
}

.nud-nav-label {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--nud-muted);
  padding: 0 0.5rem 0.5rem;
  display: block;
  font-weight: 600;
}

.nud-nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0.65rem 0.75rem;
  border-radius: 10px;
  color: var(--nud-muted);
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 500;
  transition: all var(--nud-trans);
  position: relative;
  margin-bottom: 2px;
}

.nud-nav-item:hover {
  background: var(--nud-surface2);
  color: var(--nud-text);
  transform: translateX(3px);
}

[dir="rtl"] .nud-nav-item:hover {
  transform: translateX(-3px);
}

.nud-nav-item.active {
  background: linear-gradient(135deg, rgba(0, 212, 170, 0.15), rgba(0, 153, 255, 0.1));
  color: var(--nud-accent);
  border: 1px solid rgba(0, 212, 170, 0.2);
}

.nud-nav-item i {
  width: 18px;
  text-align: center;
  font-size: 0.9rem;
  flex-shrink: 0;
}

/* .nud-nav-item span:last-child { margin-left: auto; } */
.nud-badge {
  font-size: 0.6rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 20px;
  background: var(--nud-accent2);
  color: #fff;
  letter-spacing: 0.3px;
}

.nud-badge.live {
  background: var(--nud-green);
  animation: nudBlink 1.5s ease infinite;
}

.nud-badge.alert {
  background: var(--nud-red);
}

@keyframes nudBlink {

  0%,
  100% {
    opacity: 1
  }

  50% {
    opacity: 0.6
  }
}

.nud-sidebar-foot {
  padding: 1rem 1.25rem;
  border-top: 1px solid var(--nud-border);
}

.nud-logout {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--nud-muted);
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
  padding: 0.6rem 0.5rem;
  border-radius: 8px;
  transition: all var(--nud-trans);
}

.nud-logout:hover {
  color: var(--nud-red);
  background: rgba(239, 68, 68, 0.08);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   OVERLAY (mobile)
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.nud-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(2px);
  z-index: 190;
  opacity: 0;
  transition: opacity var(--nud-trans);
}

.nud-overlay.visible {
  display: block;
  opacity: 1;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   MAIN
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.nud-main {
  margin-left: var(--nud-sidebar-w);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  transition: margin var(--nud-trans);
}

[dir="rtl"] .nud-main {
  margin-left: 0;
  margin-right: var(--nud-sidebar-w);
}

/* â”€â”€â”€ Topbar â”€â”€â”€ */
.nud-topbar {
  position: sticky;
  top: 0;
  height: var(--nud-topbar-h);
  background: var(--nud-surface);
  border-bottom: 1px solid var(--nud-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 1.5rem;
  z-index: 100;
  backdrop-filter: blur(12px);
  transition: background var(--nud-trans);
}

.nud-topbar.scrolled {
  box-shadow: var(--nud-shadow);
}

.nud-topbar-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.nud-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
}

.nud-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--nud-text);
  border-radius: 2px;
  transition: all var(--nud-trans);
}

.nud-hamburger.open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.nud-hamburger.open span:nth-child(2) {
  opacity: 0;
}

.nud-hamburger.open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

#nudPageHeading {
  font-size: 1.25rem;
  font-weight: 700;
}

.nud-breadcrumb {
  font-size: 0.75rem;
  color: var(--nud-muted);
  margin-top: 1px;
}

.nud-breadcrumb span {
  color: var(--nud-accent);
}

.nud-topbar-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.nud-ctrl-btn {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1px solid var(--nud-border);
  background: var(--nud-surface2);
  color: var(--nud-muted);
  cursor: pointer;
  font-size: 0.85rem;
  transition: all var(--nud-trans);
  position: relative;
}

.nud-ctrl-btn:hover {
  background: var(--nud-accent);
  color: #fff;
  border-color: var(--nud-accent);
  transform: scale(1.05);
}

.nud-notif-dot {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 7px;
  height: 7px;
  background: var(--nud-red);
  border-radius: 50%;
  animation: nudBlink 1.5s ease infinite;
}

.nud-topbar-avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--nud-accent), var(--nud-accent2));
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.8rem;
  color: #fff;
  cursor: pointer;
  box-shadow: 0 2px 10px rgba(0, 212, 170, 0.3);
  transition: transform var(--nud-trans);
}

.nud-topbar-avatar:hover {
  transform: scale(1.08);
}

/* â”€â”€â”€ Content â”€â”€â”€ */
.nud-content {
  flex: 1;
  padding: 1.5rem;
}

.nud-page {
  display: none;
}

.nud-page.active {
  display: block;
  animation: nudFadeIn 0.35s ease;
}

@keyframes nudFadeIn {
  from {
    opacity: 0;
    transform: translateY(10px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

/* Reveal */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
  transition-delay: var(--delay, 0s);
}

.reveal.visible {
  opacity: 1;
  transform: none;
}

/* â”€â”€â”€ Welcome Banner â”€â”€â”€ */
.nud-welcome {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(135deg, var(--nud-surface2) 0%, rgba(0, 212, 170, 0.08) 100%);
  border: 1px solid rgba(0, 212, 170, 0.15);
  border-radius: var(--nud-radius);
  padding: 1.5rem 2rem;
  margin-bottom: 1.5rem;
  position: relative;
  overflow: hidden;
}

.nud-welcome::before {
  content: '';
  position: absolute;
  top: -20px;
  right: -20px;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 212, 170, 0.12) 0%, transparent 70%);
  pointer-events: none;
}

.nud-welcome h2 {
  font-size: 1.35rem;
  font-weight: 700;
  margin-bottom: 0.3rem;
}

.nud-welcome p {
  color: var(--nud-muted);
  font-size: 0.9rem;
}

/* â”€â”€â”€ Stats â”€â”€â”€ */
.nud-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.nud-stat-card {
  background: var(--nud-surface);
  border: 1px solid var(--nud-border);
  border-radius: var(--nud-radius);
  padding: 1.25rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  transition: all var(--nud-trans);
  position: relative;
  overflow: hidden;
}

.nud-stat-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent, rgba(255, 255, 255, 0.02));
  pointer-events: none;
}

.nud-stat-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--nud-shadow);
  border-color: var(--nud-accent);
}

.nud-stat-icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.nud-stat-icon.green {
  background: rgba(16, 185, 129, 0.12);
  color: var(--nud-green);
}

.nud-stat-icon.blue {
  background: rgba(0, 153, 255, 0.12);
  color: var(--nud-accent2);
}

.nud-stat-icon.amber {
  background: rgba(245, 158, 11, 0.12);
  color: var(--nud-amber);
}

.nud-stat-icon.purple {
  background: rgba(168, 85, 247, 0.12);
  color: var(--nud-purple);
}

.nud-stat-body {
  flex: 1;
}

.nud-stat-val {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--nud-text);
  font-family: 'JetBrains Mono', monospace;
  line-height: 1;
}

.nud-stat-lbl {
  font-size: 0.75rem;
  color: var(--nud-muted);
  margin-top: 4px;
}

.nud-stat-trend {
  font-size: 0.72rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 20px;
  white-space: nowrap;
}

.nud-stat-trend.up {
  background: rgba(16, 185, 129, 0.12);
  color: var(--nud-green);
}

.nud-stat-trend.down {
  background: rgba(239, 68, 68, 0.12);
  color: var(--nud-red);
}

/* â”€â”€â”€ Two-Col â”€â”€â”€ */
.nud-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  margin-bottom: 1.5rem;
}

/* â”€â”€â”€ Card â”€â”€â”€ */
.nud-card {
  background: var(--nud-surface);
  border: 1px solid var(--nud-border);
  border-radius: var(--nud-radius);
  overflow: hidden;
  transition: box-shadow var(--nud-trans);
}

.nud-card:hover {
  box-shadow: var(--nud-shadow);
}

.nud-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.1rem 1.5rem;
  border-bottom: 1px solid var(--nud-border);
}

.nud-card-head h3 {
  font-size: 1rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
}

.nud-card-head h3 i {
  color: var(--nud-accent);
}

.nud-link {
  font-size: 0.8rem;
  color: var(--nud-accent);
  text-decoration: none;
  font-weight: 500;
  transition: opacity var(--nud-trans);
}

.nud-link:hover {
  opacity: 0.75;
}

/* â”€â”€â”€ Ride List â”€â”€â”€ */
.nud-ride-list {
  list-style: none;
  padding: 0.5rem 0;
}

.nud-ride-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.9rem 1.5rem;
  border-bottom: 1px solid var(--nud-border);
  transition: background var(--nud-trans);
}

.nud-ride-item:last-child {
  border-bottom: none;
}

.nud-ride-item:hover {
  background: var(--nud-surface2);
}

.nud-ride-date {
  text-align: center;
  min-width: 38px;
}

.nud-rday {
  display: block;
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--nud-accent);
  line-height: 1;
  font-family: 'JetBrains Mono', monospace;
}

.nud-rmon {
  font-size: 0.65rem;
  text-transform: uppercase;
  color: var(--nud-muted);
  letter-spacing: 1px;
}

.nud-ride-info {
  flex: 1;
}

.nud-ride-dest {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--nud-text);
  margin-bottom: 3px;
}

.nud-ride-time {
  font-size: 0.75rem;
  color: var(--nud-muted);
}

.nud-ride-dest i,
.nud-ride-time i {
  margin-right: 5px;
  color: var(--nud-accent);
}

.nud-ride-status {
  font-size: 0.7rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  white-space: nowrap;
}

.nud-ride-status.confirmed {
  background: rgba(16, 185, 129, 0.12);
  color: var(--nud-green);
}

.nud-ride-status.pending {
  background: rgba(245, 158, 11, 0.12);
  color: var(--nud-amber);
}

/* â”€â”€â”€ Map Mock â”€â”€â”€ */
.nud-map-mock {
  position: relative;
  height: 200px;
  background: #0a1628;
  overflow: hidden;
}

.mediride-light .nud-map-mock {
  background: #e8f0fe;
}

.nud-map-grid {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(0, 212, 170, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 212, 170, 0.05) 1px, transparent 1px);
  background-size: 30px 30px;
}

.nud-map-road {
  position: absolute;
  background: rgba(255, 255, 255, 0.08);
}

.nud-road-h {
  left: 0;
  right: 0;
  height: 12px;
  transform: translateY(-50%);
}

.nud-road-v {
  top: 0;
  bottom: 0;
  width: 12px;
  transform: translateX(-50%);
}

.nud-vehicle-pin {
  position: absolute;
  top: 50%;
  left: 30%;
  width: 36px;
  height: 36px;
  background: var(--nud-accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 0.9rem;
  transform: translate(-50%, -50%);
  z-index: 10;
  animation: nudDrive 6s ease-in-out infinite alternate;
  box-shadow: 0 0 20px rgba(0, 212, 170, 0.5);
}

@keyframes nudDrive {
  0% {
    left: 20%;
    top: 55%;
  }

  50% {
    left: 45%;
    top: 40%;
  }

  100% {
    left: 62%;
    top: 28%;
  }
}

.nud-vehicle-ping {
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  border: 2px solid var(--nud-accent);
  animation: nudPing 1.5s ease infinite;
}

@keyframes nudPing {
  0% {
    opacity: 0.8;
    transform: scale(1)
  }

  100% {
    opacity: 0;
    transform: scale(1.8)
  }
}

.nud-dest-pin {
  position: absolute;
  width: 30px;
  height: 30px;
  background: var(--nud-red);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 0.75rem;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 12px rgba(239, 68, 68, 0.5);
}

.nud-you-pin {
  position: absolute;
  width: 28px;
  height: 28px;
  background: var(--nud-accent2);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 0.75rem;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 12px rgba(0, 153, 255, 0.5);
}

.nud-track-info {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  padding: 0.9rem 1.5rem;
  border-top: 1px solid var(--nud-border);
}

.nud-track-item {
  font-size: 0.8rem;
  color: var(--nud-muted);
  display: flex;
  align-items: center;
  gap: 6px;
}

.nud-track-item i {
  color: var(--nud-accent);
}

.nud-live-badge {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--nud-green);
  background: rgba(16, 185, 129, 0.1);
  padding: 3px 10px;
  border-radius: 20px;
}

.nud-pulse-dot {
  width: 7px;
  height: 7px;
  background: var(--nud-green);
  border-radius: 50%;
  animation: nudBlink 1s ease infinite;
}

/* â”€â”€â”€ Table â”€â”€â”€ */
.nud-table-wrap {
  overflow-x: auto;
}

.nud-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}

.nud-table th {
  padding: 0.75rem 1rem;
  text-align: left;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--nud-muted);
  border-bottom: 1px solid var(--nud-border);
  white-space: nowrap;
}

[dir="rtl"] .nud-table th {
  text-align: right;
}

.nud-table td {
  padding: 0.85rem 1rem;
  border-bottom: 1px solid var(--nud-border);
  color: var(--nud-text);
  white-space: nowrap;
}

.nud-table tr:last-child td {
  border-bottom: none;
}

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

.nud-table tbody tr:hover {
  background: var(--nud-surface2);
}

.nud-td-icon {
  color: var(--nud-accent);
  margin-right: 5px;
}

.nud-tbl-badge {
  font-size: 0.68rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
}

.nud-tbl-badge.completed {
  background: rgba(16, 185, 129, 0.12);
  color: var(--nud-green);
}

.nud-tbl-badge.cancelled {
  background: rgba(239, 68, 68, 0.12);
  color: var(--nud-red);
}

.nud-tbl-badge.upcoming {
  background: rgba(0, 153, 255, 0.12);
  color: var(--nud-accent2);
}

.nud-tbl-badge.active-badge {
  background: rgba(0, 212, 170, 0.12);
  color: var(--nud-accent);
}

.nud-tbl-btn {
  background: var(--nud-surface2);
  border: 1px solid var(--nud-border);
  color: var(--nud-text);
  padding: 4px 12px;
  border-radius: 8px;
  font-size: 0.78rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--nud-trans);
  font-family: 'Outfit', sans-serif;
  margin-right: 4px;
}

.nud-tbl-btn:hover {
  background: var(--nud-accent);
  color: #fff;
  border-color: var(--nud-accent);
}

.nud-tbl-btn.danger:hover {
  background: var(--nud-red);
  border-color: var(--nud-red);
}

/* â”€â”€â”€ Book Form â”€â”€â”€ */
.nud-book-card .nud-book-form {
  padding: 1.5rem;
}

.nud-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1rem;
}

.nud-form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.nud-form-full {
  margin-bottom: 1rem;
}

.nud-form-group label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--nud-muted);
}

.nud-form-group label i {
  margin-right: 5px;
  color: var(--nud-accent);
}

.nud-input {
  background: var(--nud-surface2);
  border: 1px solid var(--nud-border);
  border-radius: 10px;
  padding: 0.7rem 1rem;
  color: var(--nud-text);
  font-family: 'Outfit', sans-serif;
  font-size: 0.9rem;
  transition: border-color var(--nud-trans), box-shadow var(--nud-trans);
  width: 100%;
}

.nud-input:focus {
  outline: none;
  border-color: var(--nud-accent);
  box-shadow: 0 0 0 3px rgba(0, 212, 170, 0.1);
}

.nud-select {
  appearance: none;
  cursor: pointer;
}

.nud-textarea {
  resize: vertical;
  min-height: 90px;
}

.nud-form-check-row {
  margin-bottom: 1.25rem;
}

.nud-check-label {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-size: 0.875rem;
  color: var(--nud-text);
}

.nud-check {
  display: none;
}

.nud-checkmark {
  width: 18px;
  height: 18px;
  border-radius: 5px;
  border: 2px solid var(--nud-border);
  background: var(--nud-surface2);
  transition: all var(--nud-trans);
  flex-shrink: 0;
}

.nud-check:checked+.nud-checkmark {
  background: var(--nud-accent);
  border-color: var(--nud-accent);
}

.nud-book-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

/* â”€â”€â”€ Buttons â”€â”€â”€ */
.nud-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--nud-accent), var(--nud-accent2));
  color: #fff;
  border: none;
  padding: 0.7rem 1.5rem;
  border-radius: 10px;
  font-family: 'Outfit', sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: all var(--nud-trans);
  box-shadow: 0 4px 15px rgba(0, 212, 170, 0.25);
}

.nud-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 212, 170, 0.4);
}

.nud-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--nud-surface2);
  color: var(--nud-text);
  border: 1px solid var(--nud-border);
  padding: 0.7rem 1.5rem;
  border-radius: 10px;
  font-family: 'Outfit', sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: all var(--nud-trans);
}

.nud-btn-secondary:hover {
  background: var(--nud-border);
}

.nud-btn-sm {
  padding: 0.45rem 1rem;
  font-size: 0.8rem;
}

/* â”€â”€â”€ Filter â”€â”€â”€ */
.nud-filter-row {
  display: flex;
  gap: 0.5rem;
}

.nud-mini-select {
  background: var(--nud-surface2);
  border: 1px solid var(--nud-border);
  color: var(--nud-text);
  padding: 0.4rem 0.75rem;
  border-radius: 8px;
  font-family: 'Outfit', sans-serif;
  font-size: 0.8rem;
  cursor: pointer;
}

/* â”€â”€â”€ Recurring â”€â”€â”€ */
.nud-recurring-list {
  padding: 1rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.nud-rec-card {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: var(--nud-surface2);
  border: 1px solid var(--nud-border);
  border-radius: 12px;
  padding: 1.1rem 1.25rem;
  transition: all var(--nud-trans);
}

.nud-rec-card:hover {
  border-color: var(--nud-accent);
  transform: translateX(4px);
}

[dir="rtl"] .nud-rec-card:hover {
  transform: translateX(-4px);
}

.nud-rec-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.nud-rec-icon.blue {
  background: rgba(0, 153, 255, 0.12);
  color: var(--nud-accent2);
}

.nud-rec-icon.green {
  background: rgba(16, 185, 129, 0.12);
  color: var(--nud-green);
}

.nud-rec-info {
  flex: 1;
}

.nud-rec-info h4 {
  font-size: 0.9rem;
  font-weight: 600;
  margin-bottom: 4px;
}

.nud-rec-info p {
  font-size: 0.78rem;
  color: var(--nud-muted);
  margin-bottom: 2px;
}

.nud-rec-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

/* â”€â”€â”€ Track Full â”€â”€â”€ */
.nud-map-large {
  height: 320px;
}

.nud-vehicle-lg {
  width: 44px;
  height: 44px;
  font-size: 1.1rem;
}

.nud-dest-lg {
  width: 36px;
  height: 36px;
}

.nud-track-details {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  border-top: 1px solid var(--nud-border);
}

.nud-tdet {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 1.1rem 1.25rem;
  border-right: 1px solid var(--nud-border);
}

.nud-tdet:last-child {
  border-right: none;
}

.nud-tdet i {
  font-size: 1.1rem;
  color: var(--nud-accent);
  width: 20px;
  text-align: center;
}

.nud-tdet p {
  font-size: 0.72rem;
  color: var(--nud-muted);
  margin-bottom: 2px;
}

.nud-tdet strong {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--nud-text);
}

/* â”€â”€â”€ Medical â”€â”€â”€ */
.nud-med-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--nud-border);
  padding: 1.5rem;
  padding-top: 0;
  gap: 1rem;
}

.nud-med-item {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.nud-med-full {
  grid-column: 1 / -1;
}

.nud-med-item label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--nud-muted);
  font-weight: 600;
}

.nud-med-item p {
  font-size: 0.9rem;
  color: var(--nud-text);
  font-weight: 500;
}

.nud-med-grid {
  padding: 1.5rem;
}

/* â”€â”€â”€ Billing â”€â”€â”€ */
.nud-billing-summary {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--nud-border);
}

.nud-bil-stat p {
  font-size: 0.72rem;
  color: var(--nud-muted);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 4px;
}

.nud-bil-stat strong {
  font-size: 1rem;
  font-weight: 700;
  color: var(--nud-text);
}

/* â”€â”€â”€ Notifications â”€â”€â”€ */
.nud-notif-list {
  list-style: none;
}

.nud-notif-item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--nud-border);
  transition: background var(--nud-trans);
}

.nud-notif-item:last-child {
  border-bottom: none;
}

.nud-notif-item:hover {
  background: var(--nud-surface2);
}

.nud-notif-item.unread {
  border-left: 3px solid var(--nud-accent);
}

[dir="rtl"] .nud-notif-item.unread {
  border-left: none;
  border-right: 3px solid var(--nud-accent);
}

.nud-notif-ico {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}

.nud-notif-ico.green {
  background: rgba(16, 185, 129, 0.12);
  color: var(--nud-green);
}

.nud-notif-ico.blue {
  background: rgba(0, 153, 255, 0.12);
  color: var(--nud-accent2);
}

.nud-notif-ico.amber {
  background: rgba(245, 158, 11, 0.12);
  color: var(--nud-amber);
}

.nud-notif-ico.purple {
  background: rgba(168, 85, 247, 0.12);
  color: var(--nud-purple);
}

.nud-notif-body p {
  font-size: 0.88rem;
  color: var(--nud-text);
  margin-bottom: 4px;
}

.nud-notif-body span {
  font-size: 0.73rem;
  color: var(--nud-muted);
}

/* â”€â”€â”€ Settings â”€â”€â”€ */
.nud-settings-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 2rem;
  padding: 1.5rem;
}

.nud-set-section h4 {
  font-size: 0.95rem;
  font-weight: 700;
  margin-bottom: 1rem;
  color: var(--nud-accent);
}

.nud-set-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
  font-size: 0.875rem;
  color: var(--nud-text);
}

.nud-toggle {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
  cursor: pointer;
}

.nud-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.nud-slider {
  position: absolute;
  inset: 0;
  background: var(--nud-surface2);
  border: 1px solid var(--nud-border);
  border-radius: 24px;
  transition: background var(--nud-trans);
}

.nud-slider::before {
  content: '';
  position: absolute;
  left: 3px;
  top: 50%;
  width: 16px;
  height: 16px;
  background: var(--nud-muted);
  border-radius: 50%;
  transform: translateY(-50%);
  transition: all var(--nud-trans);
}

.nud-toggle input:checked+.nud-slider {
  background: var(--nud-accent);
  border-color: var(--nud-accent);
}

.nud-toggle input:checked+.nud-slider::before {
  left: 23px;
  background: #fff;
}

/* â”€â”€â”€ Toast â”€â”€â”€ */
.nud-toast {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  background: var(--nud-surface);
  border: 1px solid var(--nud-accent);
  color: var(--nud-text);
  padding: 0.9rem 1.5rem;
  border-radius: 12px;
  font-size: 0.875rem;
  font-weight: 500;
  z-index: 1000;
  transform: translateY(20px);
  opacity: 0;
  pointer-events: none;
  transition: all var(--nud-trans);
  box-shadow: var(--nud-shadow);
  max-width: 320px;
}

[dir="rtl"] .nud-toast {
  right: auto;
  left: 1.5rem;
}

.nud-toast.show {
  opacity: 1;
  transform: translateY(0);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   RESPONSIVE
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* Tablet: 768â€“1024 */
@media (max-width: 1024px) {
  :root {
    --nud-sidebar-w: 240px;
  }

  .nud-stats-row {
    grid-template-columns: repeat(2, 1fr);
  }

  .nud-track-details {
    grid-template-columns: repeat(2, 1fr);
  }

  .nud-tdet:nth-child(2) {
    border-right: none;
  }

  .nud-tdet:nth-child(3) {
    border-right: 1px solid var(--nud-border);
  }

  .nud-tdet:nth-child(4) {
    border-right: none;
  }

  .nud-billing-summary {
    grid-template-columns: repeat(2, 1fr);
  }

  .nud-settings-grid {
    grid-template-columns: 1fr 1fr;
  }

  .nud-med-grid {
    grid-template-columns: 1fr 1fr;
  }

  .nud-sidebar {
    transform: translateX(-100%);
    box-shadow: none;
  }

  [dir="rtl"] .nud-sidebar {
    transform: translateX(100%);
  }

  .nud-sidebar.open {
    transform: translateX(0);
    box-shadow: 6px 0 40px rgba(0, 0, 0, 0.5);
  }

  [dir="rtl"] .nud-sidebar.open {
    box-shadow: -6px 0 40px rgba(0, 0, 0, 0.5);
  }

  .nud-main {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .nud-hamburger {
    display: flex;
  }
}

/* Mobile: 360â€“767 */
@media (max-width: 767px) {
  .nud-content {
    padding: 1rem;
  }

  .nud-stats-row {
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
  }

  .nud-stat-card {
    padding: 1rem;
  }

  .nud-stat-val {
    font-size: 1.3rem;
  }

  .nud-two-col {
    grid-template-columns: 1fr;
  }

  .nud-form-row {
    grid-template-columns: 1fr;
  }

  .nud-track-details {
    grid-template-columns: 1fr 1fr;
  }

  .nud-tdet {
    border-right: none !important;
  }

  .nud-billing-summary {
    grid-template-columns: 1fr 1fr;
  }

  .nud-settings-grid {
    grid-template-columns: 1fr;
  }

  .nud-med-grid {
    grid-template-columns: 1fr;
  }

  .nud-welcome {
    flex-direction: column;
    gap: 1rem;
    align-items: flex-start;
  }

  .nud-topbar {
    padding: 0 1rem;
  }

  .nud-topbar-right {
    gap: 0.3rem;
  }

  .nud-ctrl-btn {
    width: 34px;
    height: 34px;
    font-size: 0.78rem;
  }

  .nud-rec-card {
    flex-wrap: wrap;
  }

  .nud-rec-actions {
    width: 100%;
  }
}

@media (max-width: 480px) {
  .nud-stats-row {
    grid-template-columns: 1fr;
  }

  #nudPageHeading {
    font-size: 1.1rem;
  }

  .nud-topbar-avatar {
    display: none;
  }
}