@media (max-width: 1199px) {
    .hero-grid { grid-template-columns: 1fr 420px; gap: 35px; }
    .service-grid { grid-template-columns: repeat(3, 1fr); }
    .popular-grid { grid-template-columns: repeat(2, 1fr); }
    .rate-grid { grid-template-columns: repeat(2, 1fr); }
    .service-choices { grid-template-columns: repeat(3, 1fr); }
    .footer-grid { gap: 35px; }
}

@media (max-width: 991px) {
    .section { padding: 85px 0; }
    .site-header .navbar { min-height: 70px; }
    /* backdrop-filter would make the header a containing block for the fixed drawer; drop it on mobile */
    .site-header { backdrop-filter: none; }
    body.nav-open .site-header { z-index: 1300; }
    /* Mobile/tablet navigation slides in from the right as a side drawer */
    .site-header .nav-drawer {
        display: flex !important;
        position: fixed;
        z-index: 1200;
        top: 0;
        right: 0;
        bottom: 0;
        width: min(86vw, 350px);
        margin: 0;
        padding: 0 0 28px;
        flex-direction: column;
        align-items: stretch;
        overflow-y: auto;
        overscroll-behavior: contain;
        border: 0;
        border-radius: 0;
        background: #fff;
        box-shadow: -18px 0 50px rgba(4, 12, 24, .22);
        transform: translateX(105%);
        transition: transform .34s cubic-bezier(.2, .7, .2, 1);
    }
    .site-header .nav-drawer.show { transform: translateX(0); }
    .nav-drawer-head { display: flex !important; align-items: center; justify-content: space-between; padding: 18px 18px 14px; border-bottom: 1px solid var(--line); }
    .nav-drawer-title { color: var(--charcoal); font-family: var(--font-heading); font-size: 1.05rem; font-weight: 800; }
    .nav-drawer-close { display: grid; width: 40px; height: 40px; place-items: center; border: 1px solid var(--line); border-radius: 12px; color: var(--charcoal); background: #fff; font-size: 1rem; }
    .site-header .nav-drawer .navbar-nav { width: 100%; margin: 0; padding: 6px 18px; }
    .site-header .nav-link { padding: 13px 6px; border-bottom: 1px solid rgba(226, 232, 240, .7); font-size: 1rem; }
    .site-header .nav-link::after { display: none; }
    .site-header .nav-drawer .btn { width: calc(100% - 36px); margin: 16px 18px 0 !important; }
    .nav-drawer-map { display: block !important; margin: 20px 18px 0; }
    .nav-drawer-map .location-map-frame { aspect-ratio: 4 / 3; }
    .nav-drawer-map .location-map-head { padding: 14px 16px; }
    .hero-grid { grid-template-columns: 1fr; padding-top: 90px; padding-bottom: 90px; }
    .hero-copy { max-width: 760px; }
    .quick-booking { max-width: 760px; }
    .page-hero-inner { grid-template-columns: 1fr; }
    .page-hero-visual { max-width: 520px; min-height: 280px; }
    .trust-grid { grid-template-columns: repeat(3, 1fr); padding: 18px 0; gap: 18px 0; }
    .trust-grid span { min-height: 35px; }
    .service-grid { grid-template-columns: repeat(2, 1fr); }
    .steps-grid { grid-template-columns: repeat(2, 1fr); }
    .split-layout { grid-template-columns: 1fr; gap: 55px; }
    .safety-band-grid { grid-template-columns: 1fr; gap: 40px; }
    .feature-visual { min-height: 430px; }
    .faq-layout { grid-template-columns: 1fr; gap: 35px; }
    .faq-intro { position: static; }
    .final-cta-inner, .compact-cta-inner { align-items: flex-start; flex-direction: column; }
    .footer-grid { grid-template-columns: 1.2fr 1fr 1fr; }
    .footer-about { grid-column: 1 / -1; }
    .booking-shell { grid-template-columns: 1fr; }
    .booking-sidebar { position: relative; top: 0; padding: 20px; }
    .booking-steps { grid-template-columns: repeat(7, 1fr); }
    .booking-steps li { padding: 5px; }
    .booking-steps li > div { display: none; }
    .booking-steps li > span { margin: auto; }
    .booking-help { display: none; }
    .choice-grid, .service-choices { grid-template-columns: repeat(3, 1fr); }
    .safety-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 767px) {
    body { padding-bottom: 65px; }
    .container { width: min(100% - 28px, 1180px); }
    .section { padding: 70px 0; }
    h1 { font-size: 2.75rem; }
    h2 { font-size: 2.15rem; }
    .hero, .hero-grid { min-height: auto; }
    .hero-grid { padding-top: 70px; padding-bottom: 70px; }
    .hero-lead { font-size: 1rem; }
    .quick-booking { padding: 24px 20px; }
    .hero-trust { display: grid; grid-template-columns: 1fr 1fr; }
    .trust-grid { grid-template-columns: repeat(2, 1fr); }
    .trust-grid span:last-child { grid-column: 1 / -1; }
    .answer-card { padding: 25px; flex-direction: column; }
    .section-heading { align-items: flex-start; flex-direction: column; margin-bottom: 32px; }
    .service-grid { grid-template-columns: 1fr; }
    .popular-grid { grid-template-columns: 1fr; }
    .service-card { min-height: 235px; }
    .steps-grid { grid-template-columns: 1fr; }
    .step-card { min-height: auto; }
    .area-grid { grid-template-columns: 1fr; }
    .cta-grid { grid-template-columns: 1fr; }
    .needs-grid { grid-template-columns: 1fr; }
    .image-cta { min-height: 390px; padding: 32px; }
    .image-cta h2 { margin-top: 55px; font-size: 1.9rem; }
    .page-hero, .booking-hero { padding: 70px 0 120px; }
    .page-hero h1, .booking-hero h1 { font-size: 2.7rem; }
    .page-hero-grid { grid-template-columns: 1fr; }
    .service-hero-icon { display: none; }
    .detail-columns, .pricing-grid { grid-template-columns: 1fr; }
    .pricing-hero-card { grid-template-columns: 1fr; padding: 28px; }
    .rate-grid { grid-template-columns: 1fr; }
    .distance-rate-panel { padding: 22px; }
    .related-grid { grid-template-columns: 1fr; }
    .contact-grid { grid-template-columns: 1fr; }
    .contact-form-card { padding: 28px 22px; }
    .booking-section { margin-top: -75px; padding-bottom: 75px; }
    .booking-form-card { min-height: 0; padding: 28px 20px; }
    .form-step-heading { gap: 13px; }
    .form-step-icon { width: 45px; height: 45px; flex-basis: 45px; }
    .form-step-heading h2 { font-size: 1.45rem; }
    .choice-grid, .service-choices { grid-template-columns: repeat(2, 1fr); }
    .choice-card { min-height: 125px; padding: 15px; }
    .booking-summary { grid-template-columns: 1fr; }
    .booking-summary > div { border-right: 0; }
    .success-card { padding: 38px 22px; }
    .success-card h1 { font-size: 2.1rem; }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .footer-about { grid-column: 1 / -1; }
    .footer-bottom { align-items: flex-start; flex-direction: column; justify-content: center; gap: 7px; }
    .floating-whatsapp { display: none; }
    .mobile-cta-bar { position: fixed; z-index: 1100; right: 0; bottom: 0; left: 0; display: grid; min-height: 64px; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); background: #fff; box-shadow: 0 -10px 30px rgba(15,23,42,.1); }
    .mobile-cta-bar a { display: flex; align-items: center; justify-content: center; gap: 6px; color: #475569; font-size: .75rem; font-weight: 800; }
    .mobile-cta-bar a.active { color: #fff; background: var(--brand-gradient); }
}

@media (max-width: 480px) {
    .hero-actions { align-items: stretch; flex-direction: column; }
    .hero-actions .btn { width: 100%; }
    .hero-trust { grid-template-columns: 1fr; }
    .trust-grid { grid-template-columns: 1fr; }
    .trust-grid span { border-right: 0; }
    .trust-grid span:last-child { grid-column: auto; }
    .trust-matrix-grid { grid-template-columns: 1fr; }
    .value-banner-grid { grid-template-columns: 1fr; }
    .wa-flow-shell { grid-template-columns: 1fr; padding: 22px; }
    .choice-grid, .service-choices { grid-template-columns: 1fr; }
    .driver-query-visual { min-height: 260px; }
    .hud-status.status-a { bottom: 48px; font-size: .62rem; }
    .hud-status.status-b { font-size: .62rem; }
    .shield-plate { width: 108px; height: 108px; }
    .safety-shield { font-size: 3.4rem; }
    .choice-card, .compact-choices .choice-card { min-height: 96px; }
    .form-navigation .btn { padding-right: 14px; padding-left: 14px; font-size: .82rem; }
    .success-summary { grid-template-columns: 1fr; }
    .success-summary div { border-right: 0; }
    .footer-grid { grid-template-columns: 1fr; }
}

/* Laptop / desktop / TV: trim bulky hero CTAs and make trust bullets clearly visible */
@media (min-width: 992px) {
    .hero-actions { gap: 14px; }
    .hero-actions .btn.btn-lg { min-height: 50px; padding: 12px 22px; font-size: 1rem; border-radius: 12px; }
    .hero-actions .btn.btn-lg i { font-size: 1.02rem; }

    .hero-trust { gap: 12px 14px; margin-top: 32px; }
    .hero-trust span {
        display: inline-flex;
        align-items: center;
        gap: 9px;
        padding: 9px 16px;
        border: 1px solid rgba(255, 255, 255, .16);
        border-radius: 999px;
        background: rgba(255, 255, 255, .07);
        font-size: .95rem;
        font-weight: 700;
    }
    .hero-trust i { margin-right: 0; font-size: 1.1rem; }
}

@media (min-width: 1400px) {
    .hero-actions .btn.btn-lg { font-size: 1.05rem; padding: 13px 26px; }
    .hero-trust span { font-size: 0.9rem; padding: 7px 14px; }
    .hero-trust i { font-size: 1.18rem; }
}
