/* ============================================================
   Trimbakraj Cab Services – Responsive Stylesheet
   ============================================================ */

/* ---------- Large Desktop (≥1400px) ---------- */
@media (min-width: 1400px) {
  .hero-title { font-size: 4rem; }
}

/* ---------- Desktop (≥1200px) ---------- */
@media (min-width: 1200px) {
  .navbar-nav { gap: 2px; }
}

/* ---------- Tablet Landscape (≤1199px) ---------- */
@media (max-width: 1199px) {
  .section-pad { padding: 70px 0; }
  .hero-stats { gap: 24px; }
}

/* ---------- Tablet Portrait (≤991px) ---------- */
@media (max-width: 991px) {
  #mainNavbar.scrolled,
  #mainNavbar { background: var(--primary) !important; }
  .navbar-collapse {
    background: var(--primary);
    border-top: 1px solid rgba(255,255,255,.08);
    padding: 16px 0;
    margin-top: 8px;
    border-radius: 0 0 var(--radius-md) var(--radius-md);
  }
  .nav-cta { margin: 8px 0 0 0; display: inline-flex; }
  .section-pad { padding: 60px 0; }
  .hero-content { text-align: center; }
  .hero-subtitle { margin: 0 auto 28px; }
  .hero-cta-group { justify-content: center; }
  .hero-stats { justify-content: center; }
  .hero-image-card { margin-top: 40px; }
  .contact-info-card,
  .contact-form-card { border-radius: var(--radius-md); padding: 30px 24px; }
  .footer-brand .brand-desc { max-width: 100%; }
}

/* ---------- Mobile Landscape (≤767px) ---------- */
@media (max-width: 767px) {
  .section-pad { padding: 50px 0; }
  .hero-title { font-size: 1.95rem; }
  .hero-subtitle { font-size: .93rem; }
  .hero-cta-group .btn-accent,
  .hero-cta-group .btn-call,
  .hero-cta-group .btn-white-outline { width: 100%; justify-content: center; }
  .hero-stats { gap: 20px; justify-content: space-around; width: 100%; }
  .stat-number { font-size: 1.6rem; }

  .trust-bar-inner { gap: 16px; }
  .trust-item { font-size: .78rem; }

  .counter-number { font-size: 2.1rem; }

  .package-price { flex-direction: column; gap: 10px; align-items: flex-start; }

  .fleet-img-wrap { height: 180px; }

  .cta-section h2 { font-size: 1.5rem; }
  .cta-section .btn-accent,
  .cta-section .btn-white-outline { width: 100%; max-width: 320px; justify-content: center; }
  .cta-section .d-flex { flex-direction: column; align-items: center; }

  .map-wrapper iframe { height: 300px; }

  .floating-call { display: flex; }
  .scroll-top { left: 16px; bottom: 20px; }
  .floating-whatsapp { bottom: 20px; right: 16px; }
  .floating-call { bottom: 80px; right: 16px; }

  .page-header { padding: 100px 0 44px; }

  .gallery-item { aspect-ratio: 1/1; }

  .contact-form-card,
  .contact-info-card { padding: 24px 18px; }

  .route-card { flex-wrap: wrap; }
  .route-price { margin-left: 0; text-align: left; width: 100%; }
}

/* ---------- Mobile Portrait (≤575px) ---------- */
@media (max-width: 575px) {
  body { font-size: 15px; }
  .hero-title { font-size: 1.7rem; }
  .section-heading h2 { font-size: 1.6rem; }
  .service-card { padding: 24px 18px; }
  .why-card { padding: 22px 18px; }
  .testimonial-card { padding: 22px 18px; }
  .footer-bottom { text-align: center; }
  .footer-bottom .d-flex { flex-direction: column; gap: 6px; }
  .footer-bottom .ms-auto { margin: 0 !important; }
  .footer-heading { font-size: .95rem; }
  .hero-badge { font-size: .72rem; padding: 6px 14px; }
}

/* ---------- Very Small (≤360px) ---------- */
@media (max-width: 360px) {
  .brand-text .brand-name { font-size: 1rem; }
  .hero-title { font-size: 1.5rem; }
  .stat-item { min-width: 90px; }
}

/* ---------- Hide floating call on desktop ---------- */
@media (min-width: 992px) {
  .floating-call-desktop-hide { display: none; }
}
