
/* VIP Reglements Clients - mobile/tablette uniquement.
   Le desktop reste inchange : toutes les regles ci-dessous sont limitees a max-width:1024px. */

html {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

@media screen and (max-width: 768px) {
    body {
        font-size: 17px !important;
        line-height: 1.55 !important;
    }

    .container,
    section,
    main,
    .main-content {
        max-width: 100% !important;
    }

    .header-container,
    .site-header .container,
    header .container {
        padding-left: 28px !important;
        padding-right: 28px !important;
    }

    .brand-logo,
    .logo img,
    header img.logo {
        max-height: 64px !important;
        width: auto !important;
    }

    .brand-text {
        font-size: 16px !important;
        line-height: 1.2 !important;
    }

    .hero {
        padding-top: 30px !important;
        padding-bottom: 54px !important;
    }

    .hero h1,
    h1 {
        font-size: 34px !important;
        line-height: 1.14 !important;
        letter-spacing: -0.4px !important;
        margin-bottom: 18px !important;
    }

    .hero p {
        font-size: 18px !important;
        line-height: 1.55 !important;
        max-width: 100% !important;
    }

    section {
        padding-top: 54px !important;
        padding-bottom: 54px !important;
        padding-left: 28px !important;
        padding-right: 28px !important;
    }

    section h2,
    h2 {
        font-size: 31px !important;
        line-height: 1.18 !important;
        margin-bottom: 20px !important;
    }

    h3,
    .card h3,
    .service-card h3 {
        font-size: 21px !important;
        line-height: 1.25 !important;
    }

    p,
    li,
    .card p,
    .service-card p,
    .legal-content p,
    .legal-content li {
        font-size: 17px !important;
        line-height: 1.55 !important;
    }

    .cards,
    .services-grid,
    .testimonials,
    .grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 22px !important;
    }

    .card,
    .service-card,
    .testimonial,
    .box {
        width: 100% !important;
        max-width: 100% !important;
        padding: 24px !important;
        border-radius: 18px !important;
        box-sizing: border-box !important;
    }

    footer,
    .site-footer {
        font-size: 15px !important;
        line-height: 1.45 !important;
        padding: 30px 24px !important;
    }

    footer p,
    footer a,
    footer li,
    .site-footer p,
    .site-footer a {
        font-size: 15px !important;
        line-height: 1.45 !important;
    }

    .mobile_button svg,
    .burger,
    .menu-toggle {
        width: 30px !important;
        height: 30px !important;
        font-size: 30px !important;
    }
}

@media screen and (max-width: 430px) {
    .header-container,
    .site-header .container,
    header .container {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }

    .brand-logo,
    .logo img,
    header img.logo {
        max-height: 58px !important;
    }

    .hero {
        padding-top: 26px !important;
        padding-bottom: 48px !important;
    }

    .hero h1,
    h1 {
        font-size: 30px !important;
        line-height: 1.15 !important;
    }

    .hero p {
        font-size: 17px !important;
    }

    section {
        padding: 50px 24px !important;
    }

    section h2,
    h2 {
        font-size: 29px !important;
    }

    .card,
    .service-card,
    .testimonial,
    .box {
        padding: 22px !important;
    }
}

@media screen and (min-width: 769px) and (max-width: 1024px) {
    body {
        font-size: 17px !important;
        line-height: 1.5 !important;
    }

    .hero h1,
    h1 {
        font-size: 42px !important;
        line-height: 1.15 !important;
    }

    .hero p,
    p,
    li {
        font-size: 17px !important;
        line-height: 1.5 !important;
    }

    section {
        padding-left: 42px !important;
        padding-right: 42px !important;
    }

    .card,
    .service-card,
    .testimonial,
    .box {
        padding: 24px !important;
    }
}
