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

  :root {
    --purple:       #7C3AED;
    --purple-dk:    #5B21B6;
    --purple-lt:    #A78BFA;
    --purple-pale:  #EDE9FE;
    --purple-xpale: #F5F3FF;
    --gold:         #F59E0B;
    --gold-lt:      #FCD34D;
    --gold-pale:    #FFFBEB;
    --teal:         #0891B2;
    --green:        #059669;
    --bg:           #F5F3FF;
    --white:        #FFFFFF;
    --text:         #1E1B4B;
    --text-md:      #4B4494;
    --muted:        #6B7280;
    --border:       rgba(124,58,237,0.15);
    --shadow-sm:    0 2px 8px rgba(124,58,237,0.10);
    --shadow-md:    0 8px 28px rgba(124,58,237,0.14);
    --shadow-lg:    0 20px 50px rgba(124,58,237,0.16);
    --r-sm: 12px;
    --r-md: 18px;
    --r-lg: 26px;
  }

  html { scroll-behavior:smooth; }

  body {
    font-family: 'DM Sans', sans-serif;
    background: var(--bg);
    color: var(--text);
    overflow-x: hidden;
  }

  ::-webkit-scrollbar { width:5px; }
  ::-webkit-scrollbar-track { background:#f0eeff; }
  ::-webkit-scrollbar-thumb { background:var(--purple); border-radius:3px; }

  h1,h2,h3,h4 { font-family:'Sora',sans-serif; }
  a { text-decoration:none; }
  img { display:block; max-width:100%; }

  /* pac-container z fix */
  .pac-container { z-index:99999 !important; }

  /* ============================================================
     NAV
  ============================================================ */
  nav {
    position: fixed; top:0; left:0; right:0; z-index: 999;
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 52px;
    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(124,58,237,0.12);
    box-shadow: 0 2px 16px rgba(124,58,237,0.07);
    transition: background 0.3s, box-shadow 0.3s;
  }
  nav.scrolled { background: rgba(255,255,255,0.98); box-shadow: 0 4px 24px rgba(124,58,237,0.12); }
  .nav-brand { display:flex; align-items:center; gap:10px; font-size:22px; font-weight:800; color:var(--purple-dk); letter-spacing:-0.5px; }
  .nav-brand svg { width:30px; height:30px; }
  .nav-links { display:flex; gap:32px; list-style:none; }
  .nav-links a { font-size:14px; font-weight:600; color:var(--text-md); position:relative; transition:color 0.25s; }
  .nav-links a::after { content:''; position:absolute; bottom:-3px; left:0; width:0; height:2px; background:linear-gradient(90deg,var(--purple),var(--gold)); border-radius:2px; transition:width 0.3s; }
  .nav-links a:hover { color:var(--purple); }
  .nav-links a:hover::after { width:100%; }
  .nav-actions { display:flex; gap:10px; align-items:center; }
  .btn-outline { color:var(--purple); padding:9px 20px; border:1.5px solid var(--purple); border-radius:50px; font-size:13.5px; font-weight:700; transition:all 0.25s; }
  .btn-outline:hover { background:var(--purple); color:white; box-shadow:var(--shadow-sm); }
  .btn-solid { background:linear-gradient(135deg,var(--purple),var(--purple-dk)); color:white; padding:10px 24px; border-radius:50px; font-size:13.5px; font-weight:700; box-shadow:0 4px 16px rgba(124,58,237,0.32); transition:all 0.3s; }
  .btn-solid:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(124,58,237,0.42); }

  /* ============================================================
     HERO
  ============================================================ */
  .hero {
    min-height: 100vh;
    background: linear-gradient(135deg,#EDE9FE 0%,#F5F3FF 45%,#FEF3C7 100%);
    display: flex; flex-direction: column;
    position: relative; overflow: hidden; padding-top: 76px;
  }
  .blob { position:absolute; border-radius:50%; filter:blur(70px); pointer-events:none; opacity:0.45; }
  .hero-content {
    flex:1; display:flex; align-items:center; gap:52px;
    max-width:1280px; margin:0 auto; width:100%;
    padding:60px 52px 0; position:relative; z-index:2;
  }
  .hero-left { flex:1; }
  .hero-badge {
    display:inline-flex; align-items:center; gap:8px; background:white;
    border:1.5px solid rgba(124,58,237,0.22); border-radius:50px;
    padding:7px 16px; font-size:12px; font-weight:700; text-transform:uppercase;
    letter-spacing:1.5px; color:var(--purple); margin-bottom:22px;
    box-shadow:var(--shadow-sm); animation:fadeInDown 0.8s ease both;
  }
  .badge-dot { width:7px; height:7px; background:var(--green); border-radius:50%; animation:pulse 2s ease-in-out infinite; }
  .hero-h1 { font-size:clamp(42px,5vw,70px); font-weight:800; line-height:1.05; letter-spacing:-2.5px; color:var(--text); margin-bottom:18px; animation:fadeInUp 0.8s ease 0.1s both; }
  .grad-text { background:linear-gradient(135deg,#7C3AED 0%,#A78BFA 50%,#F59E0B 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
  .hero-sub { font-size:16px; color:var(--muted); line-height:1.75; max-width:460px; margin-bottom:30px; animation:fadeInUp 0.8s ease 0.18s both; }
  
  /* Trust Pills & Tooltip Styles */
  .hero-trust { display:flex; flex-wrap:wrap; gap:14px; animation:fadeInUp 0.8s ease 0.26s both; }
  .trust-pill { position:relative; display:flex; align-items:center; gap:7px; background:white; border:1px solid rgba(124,58,237,0.18); border-radius:50px; padding:7px 14px; font-size:13px; font-weight:600; color:var(--text-md); box-shadow:0 2px 8px rgba(124,58,237,0.08); cursor:help; }
  .trust-pill svg { width:15px; height:15px; }
  
  /* Popup Tooltip Container */
  .trust-pill::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 135%;
    left: 50%;
    transform: translateX(-50%) scale(0.85);
    background: #1E1B4B;
    color: #FFFFFF;
    padding: 8px 14px;
    font-size: 11.5px;
    font-weight: 500;
    line-height: 1.4;
    border-radius: 8px;
    white-space: nowrap;
    box-shadow: 0 10px 25px rgba(30,27,75,0.25);
    opacity: 0;
    pointer-events: none;
    transition: transform 0.2s cubic-bezier(.23,1,.32,1), opacity 0.2s ease;
    z-index: 1000;
  }
  /* Tooltip Arrow */
  .trust-pill::before {
    content: '';
    position: absolute;
    bottom: 115%;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: #1E1B4B;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
    z-index: 1000;
  }
  /* Tooltip Hover State */
  .trust-pill:hover::after { opacity: 1; transform: translateX(-50%) scale(1); }
  .trust-pill:hover::before { opacity: 1; }

  .hero-right { width:420px; flex-shrink:0; animation:fadeInRight 0.8s ease 0.32s both; }

  /* ============================================================
     BOOKING CARD
  ============================================================ */
  .booking-card {
    background:white; border-radius:var(--r-lg); padding:28px;
    box-shadow:0 20px 60px rgba(124,58,237,0.16),0 0 0 1px rgba(124,58,237,0.08);
    border:1px solid rgba(124,58,237,0.1);
    transition:transform 0.35s ease,box-shadow 0.35s ease; will-change:transform;
    max-height:calc(100vh - 100px); overflow-y:auto;
  }
  .booking-card::-webkit-scrollbar { width:3px; }
  .booking-card::-webkit-scrollbar-thumb { background:var(--purple-lt); border-radius:3px; }
  .booking-card:hover { box-shadow:0 28px 80px rgba(124,58,237,0.2),0 0 0 1px rgba(124,58,237,0.12); }
  .booking-card h3 { font-size:20px; font-weight:800; color:var(--text); margin-bottom:16px; letter-spacing:-0.5px; }

  /* Tabs */
  .btype-tabs { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:16px; }
  .btype-tab {
    padding:6px 12px; border-radius:50px; border:1.5px solid rgba(124,58,237,0.2);
    background:var(--purple-xpale); color:var(--text-md); font-size:11.5px; font-weight:700;
    cursor:pointer; transition:all 0.22s; font-family:'DM Sans',sans-serif;
  }
  .btype-tab:hover { border-color:var(--purple); color:var(--purple); background:var(--purple-pale); }
  .btype-tab.active { background:linear-gradient(135deg,var(--purple),var(--purple-dk)); border-color:transparent; color:white; box-shadow:0 4px 14px rgba(124,58,237,0.35); }

  /* Fields */
  .field-group { margin-bottom:12px; }
  .field-label { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:1.2px; color:var(--muted); margin-bottom:5px; display:block; }
  .field-input {
    width:100%; background:var(--purple-xpale); border:1.5px solid rgba(124,58,237,0.15);
    border-radius:var(--r-sm); padding:10px 13px; color:var(--text); font-size:13.5px;
    font-family:'DM Sans',sans-serif; outline:none; transition:all 0.25s;
  }
  .field-input::placeholder { color:#aaa; }
  .field-input:focus { border-color:var(--purple); background:white; box-shadow:0 0 0 3px rgba(124,58,237,0.12); }
  .field-input.input-error { border-color:#E24B4A !important; background:#FFF5F5; box-shadow:0 0 0 3px rgba(226,75,74,0.1); }
  .field-input[readonly] { background:var(--purple-pale); border-color:rgba(124,58,237,0.3); color:#3C3489; font-weight:600; cursor:default; }
  .field-error-msg { display:none; font-size:11px; color:#A32D2D; margin-top:4px; padding-left:2px; }
  .field-error-msg.show { display:block; }
  .two-col { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:12px; }
  .return-group { display:none; margin-bottom:12px; }
  .return-group.show { display:block; }

  /* Cab type */
  .cab-type-label { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:1.2px; color:var(--muted); margin-bottom:7px; display:block; }
  .cab-types { display:flex; gap:7px; flex-wrap:wrap; margin-bottom:14px; }
  .cab-btn { padding:7px 16px; border-radius:50px; border:1.5px solid rgba(124,58,237,0.18); background:var(--purple-xpale); color:var(--text-md); font-size:12.5px; font-weight:700; cursor:pointer; transition:all 0.22s; font-family:'DM Sans',sans-serif; }
  .cab-btn.active { background:var(--purple-pale); border-color:var(--purple); color:var(--purple-dk); }
  .cab-btn:hover { border-color:var(--purple); color:var(--purple); }

  /* Distance badge */
  .dist-badge { display:none; font-size:11.5px; color:#4B4494; background:var(--purple-pale); border:1px solid rgba(124,58,237,0.2); padding:4px 11px; border-radius:50px; margin-top:6px; width:fit-content; font-weight:600; }
  .dist-badge.show { display:block; }

  /* Search button */
  .search-btn {
    width:100%; background:linear-gradient(135deg,#7C3AED 0%,#A78BFA 60%,#F59E0B 100%);
    background-size:200% auto; color:white; border:none; border-radius:var(--r-sm);
    padding:14px; font-size:14.5px; font-weight:700; font-family:'Sora',sans-serif;
    cursor:pointer; transition:all 0.4s; display:flex; align-items:center; justify-content:center; gap:8px;
    position:relative; overflow:hidden;
  }
  .search-btn::after { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent); transition:left 0.55s; }
  .search-btn:hover::after { left:100%; }
  .search-btn:hover { background-position:right center; transform:translateY(-2px); box-shadow:0 10px 30px rgba(124,58,237,0.45); }
  .search-btn:active { transform:scale(0.99); }

  /* ── AIRPORT CITY PICKER ── */
  .airport-section {
    display:none; margin-bottom:14px;
    border:1.5px solid rgba(124,58,237,0.15); border-radius:16px;
    padding:14px; background:#FAFAFF; animation:fadeSlideDown 0.28s ease both;
  }
  .airport-section.show { display:block; }
  @keyframes fadeSlideDown { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }
  .airport-section-label { display:block; font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:1.2px; color:var(--purple); margin-bottom:10px; }
  .airport-tier-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--muted); margin-bottom:6px; margin-top:10px; display:flex; align-items:center; gap:5px; }
  .airport-tier-label:first-of-type { margin-top:0; }
  .tier-dot { width:6px; height:6px; border-radius:50%; background:var(--purple); flex-shrink:0; }
  .tier-dot.gold { background:var(--gold); }
  .tier-dot.green { background:var(--green); }

  .airport-cities { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:2px; }
  .city-chip { display:flex; align-items:center; gap:5px; padding:6px 11px; border-radius:50px; border:1.5px solid rgba(124,58,237,0.18); background:white; cursor:pointer; transition:all 0.22s; font-family:'DM Sans',sans-serif; }
  .city-chip:hover { border-color:var(--purple); background:var(--purple-pale); }
  .city-chip.selected { background:linear-gradient(135deg,var(--purple),var(--purple-dk)); border-color:transparent; box-shadow:0 4px 12px rgba(124,58,237,0.3); }
  .city-chip.selected .chip-name, .city-chip.selected .chip-iata { color:white; }
  .chip-name { font-size:12px; font-weight:700; color:var(--text); white-space:nowrap; }
  .chip-iata { font-size:10px; font-weight:700; color:#9CA3AF; letter-spacing:1px; }
  .city-chip.selected .chip-iata { color:rgba(255,255,255,0.7); }

  .airport-confirm { display:none; font-size:11.5px; color:#065F46; background:#ECFDF5; border:1px solid rgba(5,150,105,0.25); border-radius:8px; padding:6px 10px; margin-top:10px; font-weight:600; align-items:center; gap:5px; }
  .airport-confirm.show { display:flex; }

  .dir-pills { display:flex; gap:6px; flex-wrap:wrap; }
  .dir-pill { padding:6px 13px; border-radius:50px; border:1.5px solid rgba(124,58,237,0.18); background:white; color:var(--text-md); font-size:12px; font-weight:700; cursor:pointer; transition:all 0.22s; font-family:'DM Sans',sans-serif; }
  .dir-pill.active { background:var(--purple-pale); border-color:var(--purple); color:var(--purple-dk); }
  .dir-pill:hover { border-color:var(--purple); color:var(--purple); }

  .section-divider { height:1px; background:rgba(124,58,237,0.1); margin:12px 0; }

  /* ============================================================
     ROAD SECTION
  ============================================================ */
  .road-section { position:relative; width:100%; height:190px; background:linear-gradient(180deg,#e8e4ff 0%,#d5cfff 100%); overflow:hidden; flex-shrink:0; z-index:2; }
  .road-sky { position:absolute; top:0; left:0; right:0; height:100px; background:linear-gradient(180deg,#ddd8ff 0%,#ede9fe 100%); }
  .road-asphalt { position:absolute; bottom:0; left:0; right:0; height:72px; background:linear-gradient(180deg,#4B5563 0%,#374151 100%); border-top:3px solid #6B7280; }
  .road-asphalt::before { content:''; position:absolute; top:8px; left:0; right:0; height:3px; background:rgba(255,255,255,0.6); }
  .road-center-line { position:absolute; bottom:32px; left:0; height:6px; display:flex; gap:0; animation:roadDash 0.6s linear infinite; }
  .road-dash { width:80px; height:6px; background:var(--gold); border-radius:3px; margin-right:60px; flex-shrink:0; }
  .car-wrapper { position:absolute; bottom:18px; animation:driveCar 9s linear infinite; will-change:transform; }
  .car-svg { width:340px; height:auto; display:block; }
  .wheel-spin { animation:wheelSpin 0.55s linear infinite; }
  .speed-streak { animation:streakFade 0.5s ease-in-out infinite alternate; }

  /* ============================================================
     SECTIONS
  ============================================================ */
  .section { padding:96px 52px; }
  .section-header { text-align:center; margin-bottom:56px; }
  .eyebrow { display:inline-block; font-size:11.5px; font-weight:700; text-transform:uppercase; letter-spacing:3px; color:var(--purple); background:var(--purple-pale); border-radius:50px; padding:5px 16px; margin-bottom:12px; }
  .section-title { font-size:clamp(28px,3.5vw,46px); font-weight:800; letter-spacing:-1.5px; color:var(--text); }

  /* ============================================================
     SERVICES — flip cards
  ============================================================ */
  .services-section { background:white; }
  .services-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; max-width:1260px; margin:0 auto; }
  .scard-wrap { perspective:1100px; height:270px; }
  .scard-inner { width:100%; height:100%; transform-style:preserve-3d; transition:transform 0.72s cubic-bezier(.23,1,.32,1); }
  .scard-wrap:hover .scard-inner { transform:rotateY(180deg); }
  .scard-front, .scard-back { position:absolute; inset:0; backface-visibility:hidden; border-radius:var(--r-md); padding:26px; display:flex; flex-direction:column; }
  .scard-front { background:var(--purple-xpale); border:1.5px solid rgba(124,58,237,0.14); box-shadow:var(--shadow-sm); }
  .scard-back { background:linear-gradient(135deg,var(--purple),var(--purple-dk)); transform:rotateY(180deg); justify-content:center; text-align:center; color:white; }
  .scard-icon { width:52px; height:52px; background:white; border:1.5px solid rgba(124,58,237,0.2); border-radius:14px; display:flex; align-items:center; justify-content:center; margin-bottom:14px; box-shadow:var(--shadow-sm); }
  .scard-icon svg { width:25px; height:25px; stroke:var(--purple); }
  .scard-name { font-size:16.5px; font-weight:800; color:var(--text); margin-bottom:8px; }
  .scard-desc { font-size:13px; color:var(--muted); line-height:1.6; flex:1; }
  .scard-hint { font-size:11px; color:var(--purple-lt); margin-top:12px; display:flex; align-items:center; gap:4px; font-weight:600; }
  .scard-back h4 { font-size:19px; font-weight:800; margin-bottom:11px; }
  .scard-back p { font-size:13px; line-height:1.65; opacity:0.88; margin-bottom:20px; }
  .scard-btn { background:white; color:var(--purple-dk); border:none; border-radius:50px; padding:11px 24px; font-weight:800; font-size:13px; cursor:pointer; font-family:'Sora',sans-serif; transition:all 0.25s; }
  .scard-btn:hover { transform:scale(1.05); box-shadow:0 6px 20px rgba(0,0,0,0.2); }

  /* ============================================================
     ROUTES
  ============================================================ */
  .routes-section { background:var(--purple-xpale); }
  .routes-top { display:flex; justify-content:space-between; align-items:flex-end; max-width:1260px; margin:0 auto 46px; }
  .routes-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; max-width:1260px; margin:0 auto; }
  .route-card { background:white; border-radius:var(--r-md); overflow:hidden; border:1.5px solid rgba(124,58,237,0.1); box-shadow:var(--shadow-sm); transition:all 0.4s cubic-bezier(.23,1,.32,1); cursor:pointer; will-change:transform; }
  .route-card:hover { transform:translateY(-12px) rotateX(4deg); box-shadow:var(--shadow-lg); border-color:rgba(124,58,237,0.3); }
  .route-img-wrap { position:relative; height:165px; overflow:hidden; }
  .route-img-wrap::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom,transparent 30%,rgba(255,255,255,0.85)); }
  .route-bg { width:100%; height:100%; transition:transform 0.5s ease; }
  .route-card:hover .route-bg { transform:scale(1.1); }
  .km-badge { position:absolute; top:12px; right:12px; background:var(--purple); color:white; font-size:10.5px; font-weight:700; padding:4px 11px; border-radius:50px; z-index:1; box-shadow:0 2px 8px rgba(124,58,237,0.4); }
  .route-info { padding:16px 18px 18px; }
  .route-dot-line { display:flex; align-items:center; gap:5px; margin-bottom:9px; }
  .rdot { width:8px; height:8px; border-radius:50%; background:var(--purple); flex-shrink:0; }
  .rdot.dest { background:var(--gold); }
  .rline { flex:1; height:2px; background:linear-gradient(90deg,var(--purple),var(--gold)); border-radius:1px; position:relative; overflow:hidden; }
  .rline::after { content:''; position:absolute; top:0; left:-60%; width:60px; height:100%; background:linear-gradient(90deg,transparent,white,transparent); animation:runLine 2s linear infinite; }
  .route-name { font-size:15px; font-weight:800; color:var(--text); margin-bottom:6px; }
  .route-price { font-size:13px; color:var(--muted); margin-bottom:13px; }
  .route-price strong { color:var(--purple-dk); font-size:15px; }
  .book-route-btn { width:100%; background:linear-gradient(135deg,var(--purple),var(--purple-dk)); color:white; border:none; border-radius:10px; padding:11px; font-size:13px; font-weight:700; cursor:pointer; font-family:'DM Sans',sans-serif; transition:all 0.3s; }
  .book-route-btn:hover { background:linear-gradient(135deg,var(--gold),#d97706); box-shadow:0 6px 20px rgba(245,158,11,0.35); transform:translateY(-1px); }
  .view-all { color:var(--purple); font-weight:700; font-size:13.5px; border:1.5px solid rgba(124,58,237,0.3); padding:10px 22px; border-radius:50px; transition:all 0.25s; }
  .view-all:hover { background:var(--purple); color:white; box-shadow:var(--shadow-sm); }

  /* ============================================================
     FLEET
  ============================================================ */
  .fleet-section { background:white; }
  .fleet-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1100px; margin:0 auto; }
  .fleet-card { background:var(--purple-xpale); border:1.5px solid rgba(124,58,237,0.12); border-radius:var(--r-md); padding:24px; position:relative; overflow:hidden; transition:all 0.38s ease; will-change:transform; }
  .fleet-card::after { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--purple),var(--gold)); opacity:0; transition:opacity 0.3s; }
  .fleet-card:hover { transform:translateY(-10px); box-shadow:var(--shadow-lg); border-color:rgba(124,58,237,0.3); background:white; }
  .fleet-card:hover::after { opacity:1; }
  .fleet-top { display:flex; justify-content:space-between; align-items:flex-start; }
  .fleet-name { font-size:17px; font-weight:800; color:var(--text); }
  .fleet-models { font-size:12.5px; color:var(--muted); margin-top:3px; }
  .fleet-badge { display:inline-block; padding:4px 12px; border-radius:50px; font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:1px; }
  .badge-avail { background:#D1FAE5; color:#065F46; border:1px solid #6EE7B7; }
  .badge-elite { background:#FEF3C7; color:#92400E; border:1px solid #FCD34D; }
  .fleet-emoji { height:110px; background:white; border-radius:12px; margin:14px 0; display:flex; align-items:center; justify-content:center; font-size:52px; border:1.5px solid rgba(124,58,237,0.1); transition:transform 0.3s; }
  .fleet-card:hover .fleet-emoji { transform:scale(1.06) translateY(-4px); }
  .fleet-divider { height:1px; background:rgba(124,58,237,0.1); margin:12px 0; }
  .fleet-specs { display:flex; gap:14px; flex-wrap:wrap; }
  .fleet-spec { font-size:12.5px; color:var(--muted); display:flex; align-items:center; gap:5px; }
  .fleet-spec svg { width:13px; height:13px; stroke:var(--purple); }
  .fleet-actions { display:flex; gap:9px; margin-top:14px; }
  .fleet-book { flex:1; background:linear-gradient(135deg,var(--purple),var(--purple-dk)); color:white; border:none; border-radius:10px; padding:11px; font-size:13px; font-weight:700; cursor:pointer; font-family:'DM Sans',sans-serif; transition:all 0.25s; }
  .fleet-book:hover { box-shadow:0 6px 20px rgba(124,58,237,0.38); transform:translateY(-1px); }
  .fleet-wa { background:#DCFCE7; color:#15803D; border:1.5px solid #86EFAC; border-radius:10px; padding:11px 13px; font-size:12.5px; font-weight:700; cursor:pointer; display:flex; align-items:center; gap:5px; font-family:'DM Sans',sans-serif; transition:all 0.25s; }
  .fleet-wa:hover { background:#BBF7D0; }
  .fleet-wa svg { width:15px; height:15px; fill:#15803D; }

  /* ============================================================
     STATS BAND
  ============================================================ */
  .stats-section { background:linear-gradient(135deg,#4C1D95,#7C3AED,#5B21B6); padding:80px 52px; position:relative; overflow:hidden; }
  .stats-section::before { content:''; position:absolute; inset:0; background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='g' width='60' height='60' patternUnits='userSpaceOnUse'%3E%3Cpath d='M60 0L0 0 0 60' fill='none' stroke='rgba(255,255,255,0.05)' stroke-width='1'/%3E%3C/pattern%3E%3C/defs%3E%3Crect width='100%25' height='100%25' fill='url(%23g)'/%3E%3C/svg%3E"); }
  .stats-inner { display:grid; grid-template-columns:repeat(4,1fr); gap:32px; max-width:1100px; margin:0 auto; position:relative; }
  .stat-item { text-align:center; padding:30px 20px; background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.18); border-radius:var(--r-md); backdrop-filter:blur(10px); transition:all 0.3s; }
  .stat-item:hover { background:rgba(255,255,255,0.18); transform:translateY(-5px); box-shadow:0 16px 40px rgba(0,0,0,0.2); }
  .stat-number { font-family:'Sora',sans-serif; font-size:44px; font-weight:800; color:var(--gold-lt); margin-bottom:6px; }
  .stat-label { font-size:14px; color:rgba(255,255,255,0.75); }

  /* ============================================================
     HOW IT WORKS + WHY US
  ============================================================ */
  .hiw-section { background:var(--purple-xpale); }
  .hiw-inner { max-width:1180px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:start; }
  .hiw-steps { margin-top:36px; display:flex; flex-direction:column; gap:14px; }
  .hiw-step { display:flex; gap:16px; align-items:flex-start; padding:18px; background:white; border:1.5px solid rgba(124,58,237,0.1); border-radius:var(--r-sm); transition:all 0.28s; cursor:default; }
  .hiw-step:hover { border-color:rgba(124,58,237,0.35); transform:translateX(7px); box-shadow:var(--shadow-sm); }
  .step-num { font-family:'Sora',sans-serif; font-size:26px; font-weight:800; background:linear-gradient(135deg,var(--purple),var(--gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; line-height:1; flex-shrink:0; }
  .step-title { font-size:15px; font-weight:800; color:var(--text); margin-bottom:4px; }
  .step-desc { font-size:12.5px; color:var(--muted); line-height:1.6; }
  .wcu-title { font-size:34px; font-weight:800; letter-spacing:-1px; color:var(--text); margin-bottom:24px; }
  .wcu-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
  .wcu-item { padding:20px; background:white; border:1.5px solid rgba(124,58,237,0.1); border-radius:var(--r-sm); transition:all 0.28s; }
  .wcu-item:hover { border-color:rgba(124,58,237,0.32); transform:translateY(-4px); box-shadow:var(--shadow-sm); }
  .wcu-icon { width:40px; height:40px; background:var(--purple-pale); border-radius:10px; display:flex; align-items:center; justify-content:center; margin-bottom:10px; }
  .wcu-icon svg { width:20px; height:20px; stroke:var(--purple); }
  .wcu-name { font-size:14.5px; font-weight:800; color:var(--text); margin-bottom:5px; }
  .wcu-desc { font-size:12.5px; color:var(--muted); line-height:1.6; }

  /* ============================================================
     TESTIMONIALS
  ============================================================ */
  .testi-section { background:white; overflow:hidden; }
  .testi-track { display:flex; gap:20px; width:max-content; animation:scrollLeft 35s linear infinite; }
  .testi-track:hover { animation-play-state:paused; }
  .testi-card { width:320px; min-width:320px; background:var(--purple-xpale); border:1.5px solid rgba(124,58,237,0.14); border-radius:var(--r-md); padding:22px; transition:all 0.28s; }
  .testi-card:hover { border-color:rgba(124,58,237,0.38); transform:translateY(-5px); box-shadow:var(--shadow-md); background:white; }
  .testi-stars { display:flex; gap:3px; margin-bottom:11px; }
  .testi-stars svg { width:15px; height:15px; }
  .star-on { color:#FBBF24; } .star-off { color:#D1D5DB; }
  .testi-text { font-size:13.5px; color:var(--muted); line-height:1.7; margin-bottom:16px; }
  .testi-author { display:flex; align-items:center; gap:11px; }
  .testi-av { width:40px; height:40px; border-radius:50%; background:linear-gradient(135deg,var(--purple),var(--purple-dk)); display:flex; align-items:center; justify-content:center; font-weight:800; font-size:14px; color:white; flex-shrink:0; }
  .testi-name { font-weight:800; font-size:13.5px; color:var(--text); }
  .testi-role { font-size:11.5px; color:var(--muted); margin-top:2px; }

  /* ============================================================
     FOOTER
  ============================================================ */
  footer { background:linear-gradient(135deg,#2E1065,#4C1D95); padding:60px 52px 30px; color:rgba(255,255,255,0.85); }
  .footer-inner { display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:44px; max-width:1260px; margin:0 auto 36px; }
  .footer-logo { display:flex; align-items:center; gap:10px; font-size:20px; font-weight:800; color:white; margin-bottom:12px; }
  .footer-logo svg { width:26px; height:26px; }
  .footer-tagline { font-size:13px; color:rgba(255,255,255,0.55); line-height:1.75; max-width:270px; margin-bottom:20px; }
  .footer-socials { display:flex; gap:9px; }
  .soc-btn { width:35px; height:35px; background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.15); border-radius:50%; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,0.7); transition:all 0.25s; }
  .soc-btn:hover { background:var(--gold); border-color:var(--gold); color:white; transform:translateY(-2px); }
  .soc-btn svg { width:14px; height:14px; }
  .footer-col-title { font-size:13px; font-weight:800; text-transform:uppercase; letter-spacing:1px; color:white; margin-bottom:16px; }
  .footer-links { list-style:none; display:flex; flex-direction:column; gap:9px; }
  .footer-links a { font-size:13px; color:rgba(255,255,255,0.55); transition:color 0.25s; }
  .footer-links a:hover { color:var(--gold-lt); }
  .footer-contact { display:flex; flex-direction:column; gap:12px; }
  .contact-row { display:flex; align-items:flex-start; gap:11px; }
  .contact-icon { width:30px; height:30px; background:rgba(255,255,255,0.1); border-radius:8px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
  .contact-icon svg { width:14px; height:14px; stroke:var(--gold-lt); }
  .contact-lbl { font-size:10.5px; color:rgba(255,255,255,0.4); text-transform:uppercase; letter-spacing:1px; }
  .contact-val { font-size:13px; color:rgba(255,255,255,0.82); font-weight:600; margin-top:2px; }
  .footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:22px; border-top:1px solid rgba(255,255,255,0.1); max-width:1260px; margin:0 auto; }
  .footer-copy { font-size:12.5px; color:rgba(255,255,255,0.4); }
  .footer-legal { display:flex; gap:18px; }
  .footer-legal a { font-size:12.5px; color:rgba(255,255,255,0.4); }
  .footer-legal a:hover { color:var(--gold-lt); }

  /* ============================================================
     ANIMATIONS
  ============================================================ */
  @keyframes fadeInDown { from{opacity:0;transform:translateY(-20px)} to{opacity:1;transform:translateY(0)} }
  @keyframes fadeInUp   { from{opacity:0;transform:translateY(28px)}  to{opacity:1;transform:translateY(0)} }
  @keyframes fadeInRight{ from{opacity:0;transform:translateX(36px)}  to{opacity:1;transform:translateX(0)} }
  @keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.5;transform:scale(0.75)} }
  @keyframes driveCar  { from{transform:translateX(-420px)} to{transform:translateX(calc(100vw + 80px))} }
  @keyframes wheelSpin { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
  @keyframes roadDash  { from{transform:translateX(0)} to{transform:translateX(-140px)} }
  @keyframes treesScroll { from{transform:translateX(0)} to{transform:translateX(-100vw)} }
  @keyframes runLine   { to{left:160%} }
  @keyframes scrollLeft { from{transform:translateX(0)} to{transform:translateX(-50%)} }
  @keyframes streakFade { from{opacity:0.65} to{opacity:0.25} }

  .reveal { opacity:0; transform:translateY(36px); transition:opacity 0.7s ease, transform 0.7s ease; }
  .reveal.visible { opacity:1; transform:translateY(0); }

  /* ============================================================
     RESPONSIVE
  ============================================================ */
  @media (max-width:1100px) {
    .services-grid, .routes-grid { grid-template-columns:repeat(2,1fr); }
    .fleet-grid { grid-template-columns:repeat(2,1fr); }
    .stats-inner { grid-template-columns:repeat(2,1fr); }
    .hiw-inner { grid-template-columns:1fr; gap:44px; }
  }
  @media (max-width:768px) {
    nav { padding:14px 20px; }
    .nav-links { display:none; }
    .hero-content { flex-direction:column; gap:32px; padding:40px 20px 0; }
    .hero-right { width:100%; }
    .section { padding:60px 20px; }
    .services-grid, .routes-grid, .fleet-grid { grid-template-columns:1fr; }
    .stats-inner { grid-template-columns:repeat(2,1fr); gap:14px; }
    .wcu-grid { grid-template-columns:1fr; }
    .footer-inner { grid-template-columns:1fr; gap:28px; }
    .footer-bottom { flex-direction:column; gap:10px; text-align:center; }
  }

  @media (max-width: 768px) {
  /* Booking card: cap height and allow scroll */
  .booking-card {
    max-height: none;
    overflow-y: visible;
  }

  /* Tabs: allow wrapping without overflow */
  .btype-tabs {
    flex-wrap: wrap;
  }
  .btype-tab {
    flex: 1 1 auto;
    text-align: center;
    font-size: 11px;
    padding: 6px 10px;
  }

  /* Cab buttons: wrap cleanly */
  .cab-types {
    flex-wrap: wrap;
  }
  .cab-btn {
    flex: 1 1 auto;
    text-align: center;
    font-size: 12px;
    padding: 7px 12px;
  }

  /* Two-col date fields: stack on small screens */
  .two-col {
    grid-template-columns: 1fr;
  }

  /* Airport city chips: allow wrap */
  .airport-cities {
    flex-wrap: wrap;
  }

  /* Nav: prevent overflow */
  .nav-actions .btn-outline {
    display: none;
  }

  /* Stats section: 2 cols not 4 */
  .stats-inner {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
  .stat-number {
    font-size: 32px;
  }

  /* Footer sections */
  .footer-inner {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .footer-bottom {
    flex-direction: column;
    gap: 10px;
    text-align: center;
  }
  .footer-legal {
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
  }
}
@media (max-width: 768px) {
  .hero-content {
    flex-direction: column-reverse;  /* was: column */
    gap: 32px;
    padding: 40px 20px 0;
  }
  .hero-right {
    width: 100%;
  }
}