@media screen and (max-width: 768px) {
    body {
        overflow-x: hidden;
        padding-top: 56px;
        padding-bottom: 52px;
    }

    .display-1,
    .hero-title {
        font-size: 2.25rem;
    }

    .display-4 {
        font-size: 1.75rem;
    }

    .hero-eyebrow {
        font-size: 0.875rem;
    }

    .hero-lead {
        font-size: 1rem;
    }

    .contact-form-title {
        font-size: 1.75rem;
    }

    .mobile-header-logo {
        width: auto;
    }

    .mobile-nav-toggle {
        color: #fff;
        padding: 0.25rem;
        border: none;
        background: transparent;
        line-height: 1;
    }

    .mobile-nav-toggle:focus {
        box-shadow: none;
    }

    .mobile-nav-offcanvas {
        background: var(--bs-primary);
        color: #fff;
        width: min(320px, 85vw);
    }

    .mobile-nav-logo {
        max-height: 48px;
    }

    .mobile-nav-link {
        color: rgba(255, 255, 255, 0.85);
        font-weight: 500;
        padding: 0.75rem 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    }

    .mobile-nav-link.active,
    .mobile-nav-link:hover {
        color: var(--bs-warning);
    }

    .mobile-bottom-bar a {
        font-size: 0.875rem;
    }

    .hero-section {
        margin-bottom: 0;
        padding-bottom: 2rem;
        background-position: left;
    }

    .hero-row {
        min-height: auto;
        padding-top: 5rem;
        padding-bottom: 1rem;
    }

    .hero-google-badge {
        position: static;
        display: flex;
        justify-content: center;
        margin: 1.5rem auto 0;
        width: fit-content;
    }

    .hero-featured-wrap {
        position: static;
        padding: 0 0.75rem;
        margin-top: 1.5rem;
    }

    .hero-featured-bar {
        border-radius: 1rem !important;
    }

    .hero-featured-bar .fs-4 {
        font-size: 1.1rem !important;
    }

    .who-we-are-stats {
        margin-bottom: 18rem;
    }

    .who-we-are-stats > div {
        flex: 1 1 calc(50% - 1rem);
        min-width: 120px;
        text-align: center;
    }

    .bg-who-we-are {
        background-size: contain;
    }

    .promo-timer {
        margin-top: 1.5rem;
    }

    .promo-timer img {
        max-height: 100px;
    }

    .promo-overlay {
        left: 0;
        right: 0;
        padding: 1rem !important;
        background: linear-gradient(to top, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.4) 60%, transparent 100%);
    }

    .promo-title {
        font-size: 1.25rem;
        line-height: 1.3;
    }

    .promo-free-label {
        font-size: 1rem !important;
    }

    #services .service-title,
    #services p.fw-bold {
        font-size: 0.95rem !important;
        width: 100% !important;
    }

    #services img {
        max-width: 140px;
    }

    .process-panel .col-12.col-md-2 {
        margin-bottom: 2rem;
        text-align: center;
    }

    .process-panel .rounded-circle {
        margin: 0 auto;
    }

    #contact {
        top: 0;
        bottom: 0;
        padding-bottom: 0;
        background-position: left;
    }

    #contact .row.py-5 {
        padding-top: 2rem !important;
        padding-bottom: 2rem !important;
    }

    #service-area {
        min-height: auto;
        padding-bottom: 2rem;
    }

    .service-area-bottom-card {
        position: static;
        width: 100%;
        height: auto;
        min-height: 210px;
        background-size: cover;
    }

    .service-area-bottom-card div {
        position: static;
        width: 65%;
        padding: 5.5rem 2rem 0 2rem;
        text-align: center;
    }

    .service-area-cards {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0.75rem;
        margin-top: 2rem;
    }

    .service-area-card {
        position: static;
        width: auto;
    }

    .service-area-card p {
        font-size: 0.875rem !important;
    }

    .accordion-faq .accordion-button {
        font-size: 1rem;
        padding: 0.875rem 1rem;
    }

    .accordion-faq .accordion-body {
        padding: 0 1rem 0.875rem 1.25rem;
        font-size: 0.9rem;
    }

    .bg-cta {
        background-position: right;
    }

    .bg-cta .col-12 {
        text-align: center;
    }

    .bg-cta .d-flex {
        justify-content: center;
    }

    .footer-info-col {
        border-left: none;
        border-right: none;
        border-top: 1px solid rgba(255, 255, 255, 0.12);
        border-bottom: 1px solid rgba(255, 255, 255, 0.12);
        padding: 1.5rem 0.75rem;
    }

    .footer-nav a {
        font-size: 0.75rem;
    }

    .site-footer .col-12.col-lg-4 > .d-flex {
        flex-direction: column;
        align-items: flex-start !important;
    }

    #faq .container.py-5 {
        padding-top: 2rem !important;
        padding-bottom: 2rem !important;
    }

    .bg-cta .py-5 {
        padding-top: 2rem !important;
        padding-bottom: 2rem !important;
    }

    .thank-you-row {
        min-height: auto;
        padding: 6rem 0 4rem;
    }

    .bg-core-value .container.py-5 {
        padding-bottom: 2rem !important;
    }

    .core-value-cards {
        min-height: auto;
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }

    .core-value-card {
        position: relative;
        top: auto;
        right: auto;
        bottom: auto;
        left: auto;
        width: 100%;
        margin: 0;
    }
}