:root {
    --wp--preset--font-size--small: 1.125rem;
    --wp--preset--font-size--medium: 1.375rem;
    --wp--preset--font-size--medium-large: clamp(1.75rem, 1.4005rem + 0.9709vw, 2.25rem);
    --wp--preset--font-size--large: clamp(2.5rem, 2.1505rem + 0.9709vw, 3rem);
    --wp--preset--font-size--x-large: clamp(3rem, 2.4757rem + 1.4563vw, 3.75rem);
    /*--wp--preset--font-size--xx-large: clamp(3.5rem, 0.7039rem + 7.767vw, 7.5rem);*/
    --wp--preset--font-size--xx-large: clamp(3.5rem, 1.7524rem + 4.8544vw, 6rem);
    --bs-body-line-height: 1.6;
}

body {
    overflow-x: hidden;
    background: var(--wp--preset--color--color-4);
    font-family: "Inter", sans-serif;
    color: var(--wp--preset--color--color-2);
    font-size: var(--wp--preset--font-size--medium);
}

body:not(.wp-admin, #tinymce) ::selection {
    background-color: var(--wp--preset--color--color-1);
    color: var(--wp--preset--color--color-2);
}

mark {
    padding: 0;
}

main > article.post {
    margin-bottom: 5rem;
}


/* Classes utilitaires */

.bg-color-1 {
    background-color: var(--wp--preset--color--color-1) !important;
}
.bg-color-2 {
    background-color: var(--wp--preset--color--color-2) !important;
}

.border-color-1 {
    border-color: var(--wp--preset--color--color-1) !important;
}
.border-color-2 {
    border-color: var(--wp--preset--color--color-2) !important;
}

.text-color-1 {
    color: var(--wp--preset--color--color-1) !important;
}
.text-color-2 {
    color: var(--wp--preset--color--color-2) !important;
}

.text-hover-color-1:hover,
.text-hover-color-1:focus,
.text-hover-color-1:focus-visible,
.text-hover-color-1:first-child:active,
.text-hover-color-1:active {
    color: var(--wp--preset--color--color-1) !important;
}
.text-hover-color-2:hover,
.text-hover-color-2:focus,
.text-hover-color-2:focus-visible,
.text-hover-color-2:first-child:active,
.text-hover-color-2:active {
    color: var(--wp--preset--color--color-2) !important;
}

.fs-small,
.fs-small .wp-block-button__link {
    font-size: var(--wp--preset--font-size--small) !important;
}
.fs-medium,
.fs-medium .wp-block-button__link {
    font-size: var(--wp--preset--font-size--medium) !important;
}
.fs-medium-large,
.fs-medium-large .wp-block-button__link {
    font-size: var(--wp--preset--font-size--medium-large) !important;
}
.fs-large,
.fs-large .wp-block-button__link {
    font-size: var(--wp--preset--font-size--large) !important;
}
.fs-x-large,
.fs-x-large .wp-block-button__link {
    font-size: var(--wp--preset--font-size--x-large) !important;
}
.fs-xx-large,
.fs-xx-large .wp-block-button__link {
    font-size: var(--wp--preset--font-size--xx-large) !important;
}

.text-balance {
    text-wrap: balance;
}

.text-clamp {
    display: -webkit-box;
    height: calc(var(--lines, 2) * 1lh);
    overflow: hidden;
    -webkit-line-clamp: var(--lines, 2);
    line-clamp: var(--lines, 2);
    -webkit-box-orient: vertical;
}

.abs-top-left {
    position: absolute;
    top: 0;
    left: 0;
    transform: translate(-50%, -50%);
}
.abs-top-right {
    position: absolute;
    top: 0;
    right: 0;
    transform: translate(50%, -50%);
}
.abs-bottom-right {
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translate(50%, 50%);
}
.abs-bottom-left {
    position: absolute;
    bottom: 0;
    left: 0;
    transform: translate(-50%, 50%);
}

.shadow-stx {
    box-shadow: 0.5rem 0.25rem 0.8125rem rgba(0, 0, 0, 0.25);
}


.rotate-0 {
    transform: rotate(0deg);
}
.rotate-90 {
    transform: rotate(90deg);
}
.rotate-180 {
    transform: rotate(180deg);
}
.rotate-270 {
    transform: rotate(270deg);
}

@media (min-width: 576px) {
    .rotate-sm-0 {
        transform: rotate(0deg);
    }
    .rotate-sm-90 {
        transform: rotate(90deg);
    }
    .rotate-sm-180 {
        transform: rotate(180deg);
    }
    .rotate-sm-270 {
        transform: rotate(270deg);
    }
}
@media (min-width: 768px) {
    .rotate-md-0 {
        transform: rotate(0deg);
    }
    .rotate-md-90 {
        transform: rotate(90deg);
    }
    .rotate-md-180 {
        transform: rotate(180deg);
    }
    .rotate-md-270 {
        transform: rotate(270deg);
    }
}
@media (min-width: 992px) {
    .rotate-lg-0 {
        transform: rotate(0deg);
    }
    .rotate-lg-90 {
        transform: rotate(90deg);
    }
    .rotate-lg-180 {
        transform: rotate(180deg);
    }
    .rotate-lg-270 {
        transform: rotate(270deg);
    }
}

/* Titres */

h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5,
h6,
.h6 {
    font-weight: bold;
}
h1,
.h1,
h2,
.h2,
h3,
.h3 {
    letter-spacing: -9%;
}

h1,
.h1 {
    font-size: var(--wp--preset--font-size--x-large);
}
h2,
.h2 {
    font-size: var(--wp--preset--font-size--large);
}
h3,
.h3 {
    font-size: var(--wp--preset--font-size--medium-large);
}
h4,
.h4 {
    font-size: var(--wp--preset--font-size--medium);
}


/* Boutons */

#menu-menu-principal > li:last-child .nav-link,
.wp-block-button__link,
.btn {
    padding: 0.5rem 0.875rem;
    border-radius: 5rem;
    font-size: var(--wp--preset--font-size--small);
    font-weight: bold;
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
#menu-menu-principal > li:last-child .nav-link,
.wp-block-button__link,
.btn-color-1 {
    background-color: var(--wp--preset--color--color-1);
    border-color: var(--wp--preset--color--color-1);
    color: white;
}
#menu-menu-principal > li:last-child .nav-link:hover,
#menu-menu-principal > li:last-child .nav-link:active,
#menu-menu-principal > li:last-child .nav-link:focus-visible,
.wp-block-button__link:hover,
.wp-block-button__link:active,
.wp-block-button__link:focus-visible,
.btn-color-1:hover,
.btn-color-1:active,
.btn-color-1:focus-visible {
    background-color: var(--wp--preset--color--color-2) !important;
    border-color: var(--wp--preset--color--color-2);
    color: white !important;
}

.btn-color-2 {
    background-color: var(--wp--preset--color--color-2);
    border-color: var(--wp--preset--color--color-2);
    color: white;
}
.btn-color-2:hover,
.btn-color-2:active,
.btn-color-2:focus-visible {
    background-color: var(--wp--preset--color--color-1) !important;
    border-color: var(--wp--preset--color--color-1);
    color: white !important;
}
.btn-outline-color-1 {
    background-color: transparent;
    border-color: var(--wp--preset--color--color-1);
    color: var(--wp--preset--color--color-1);
}
.btn-outline-color-1:hover,
.btn-outline-color-1:active,
.btn-outline-color-1:focus-visible {
    background-color: var(--wp--preset--color--color-1) !important;
    border-color: var(--wp--preset--color--color-1);
    color: white !important;
}
.btn-outline-color-2 {
    background-color: transparent;
    border-color: var(--wp--preset--color--color-2);
    color: var(--wp--preset--color--color-2);
}
.btn-outline-color-2:hover,
.btn-outline-color-2:active,
.btn-outline-color-2:focus-visible {
    background-color: var(--wp--preset--color--color-2) !important;
    border-color: var(--wp--preset--color--color-2);
    color: white !important;
}

.btn-white-1 {
    background-color: white;
    border-color: white;
    color: var(--wp--preset--color--color-1);
}
.btn-white-1:hover,
.btn-white-1:active,
.btn-white-1:focus-visible {
    background-color: white !important;
    border-color: var(--wp--preset--color--color-2);
    color: var(--wp--preset--color--color-2) !important;
}
.btn-white-2 {
    background-color: white;
    border-color: white;
    color: var(--wp--preset--color--color-2);
}
.btn-white-2:hover,
.btn-white-2:active,
.btn-white-2:focus-visible {
    background-color: white !important;
    border-color: var(--wp--preset--color--color-1);
    color: var(--wp--preset--color--color-1) !important;
}

.nav-link {
    color: inherit;
}

#menu-menu-principal > li:last-child .nav-link::after,
.stx-chevron .wp-block-button__link::after,
.stx-chevron:not(:has(.wp-block-button__link))::after {
    content: '';
    display: inline-block;
    width: 20px;
    height: 20px;
    margin-left: 0.5em;
    background-color: currentColor;
    vertical-align: middle;
    mask: no-repeat center / contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none'%3E%3Cg stroke='currentColor' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18.75 9.75C18.75 4.77944 14.7206 0.75 9.75 0.75C4.77944 0.75 0.75 4.77944 0.75 9.75C0.75 14.7206 4.77944 18.75 9.75 18.75C14.7206 18.75 18.75 14.7206 18.75 9.75Z'/%3E%3Cpath d='M8.75 12.75L11.75 9.75L8.75 6.75'/%3E%3C/g%3E%3C/svg%3E");
}

article h1,
article h2,
article h3,
article p {
    padding-right: 0;
    padding-left: 0;
}

#tinymce {
    font-size: 16px !important;
}
figure {
    margin: 0;
}

.dropdown-toggle::after {
    content: '';
    display: inline-block;
    width: 1em;
    height: 1em;
    margin-left: 0.5em;
    background-color: var(--wp--preset--color--color-1);
    border: none;
    vertical-align: text-bottom;
    mask: no-repeat center / contain url("data:image/svg+xml,%3Csvg width='22' height='13' viewBox='0 0 22 13' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1.5 1.5L10.6934 10.767L19.9604 1.57358' stroke='%23FBAE17' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

/* Gravity Forms */

.gform-theme--framework.gform-theme.gform_wrapper {
    --gf-form-gap-y: 1.5rem;
}

.gform-theme--framework.gform-theme.gform_wrapper .gform_required_legend {
    display: none;
}
.gform-theme--framework.gform-theme.gform_wrapper .gform-field-label,
.gform-theme--framework.gform-theme.gform_wrapper .gfield_required {
    color: var(--wp--preset--color--color-2);
    font-size: var(--wp--preset--font-size--small);
    gap: 0;
}

.gform-theme--framework.gform-theme.gform_wrapper input[type],
.gform-theme--framework.gform-theme.gform_wrapper textarea {
    padding: 1.5rem 1rem;
    box-shadow: none;
    border: 1px solid #D9D9D9;
    border-radius: 8px;
    font-size: var(--wp--preset--font-size--small);
}
.gform-theme--framework.gform-theme.gform_wrapper textarea {
    padding: .75rem 1rem;
}
.gform-theme--framework.gform-theme.gform_wrapper ::placeholder {
    color: #B3B3B3;
}
.gform-theme--framework.gform-theme.gform_wrapper .gform_footer input[type="submit"].button.gform_button {
    width: 100%;
    padding: 1rem;
    background-color: var(--wp--preset--color--color-1);
    border: none;
    border-radius: 0.5rem;
    font-size: var(--wp--preset--font-size--small);
    font-size: normal;
    transition: background-color 0.15s ease-in-out;
}
.gform-theme--framework.gform-theme.gform_wrapper .gform_footer input[type="submit"].button.gform_button:hover {
    background-color: var(--wp--preset--color--color-2);
}

/* Breadcrumb */
.rank-math-breadcrumb {
    font-size: 1rem;
}
.rank-math-breadcrumb p {
    margin-bottom: .5rem;
}
.rank-math-breadcrumb a {
    text-decoration: none;
}


/* Gutenberg */

@media (min-width: 782px) and (max-width: 1199px) {
    .wp-block-columns:not(.is-not-stacked-on-mobile) {
        flex-wrap: wrap !important;
    }
}
@media (max-width: 1199px) {
    .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column {
        flex-grow: 1;
        flex-basis: 100% !important;
    }
}
.wp-block-columns .wp-block-column:has(> *:not(figure)) {
    order: -1;
}
@media (min-width: 1200px) {
    .wp-block-columns .wp-block-column:has(> *:not(figure)) {
        order: 0;
    }
}

/* Mettre en évidence => badge */
mark[style*="background-color"] {
    padding: 0.75rem 1rem;
    border-radius: 2rem;
}
mark[style*="background-color:#fbae17"] {
    padding: 0.5rem 1rem;
    border-radius: 0.75rem;
}
mark[style*="background-color:rgba(0, 0, 0, 0)"] {
    padding: 0;
    border-radius: 0;
}

/* Image cover */
figure.wp-block-image.is-style-cover {
    width: 100%;
    height: 100%;
}
figure.wp-block-image.is-style-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Liste */
.wp-block-list:not(.is-style-classic) {
    list-style: none;
    padding-left: 0;
}
.wp-block-list:not(.is-style-classic) li {
    margin-bottom: 0.5em;
    padding-left: 2em;
    background: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 12C0 5.37258 5.37258 0 12 0C18.6274 0 24 5.37258 24 12C24 18.6274 18.6274 24 12 24C5.37258 24 0 18.6274 0 12Z' fill='%233D824F'/%3E%3Cpath d='M17.3337 8L10.0003 15.3333L6.66699 12' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat left 0.2em / 1.1em;
}

/* Grille (bordures internes) */
body .is-layout-grid {
    display: block;
    overflow: hidden;
    gap: 0 !important;
}
@media (min-width: 768px) {
    body .is-layout-grid {
        display: grid;
    }
}
body .is-layout-grid > * {
    padding: 2rem;
    box-shadow:
        1px 0 0 0 var(--wp--preset--color--color-1),
        0 1px 0 0 var(--wp--preset--color--color-1),
        1px 1px 0 0 var(--wp--preset--color--color-1);
}

/* Mascotte en sticky à gauche (Sous-pages offres) */
.sticky-robot {
    --width: 366px;
    --height: 414px;
    --offset: 80px;
    position: sticky;
    top: calc(var(--offset) * -1);
    float: left;
    height: var(--height);
    margin-bottom: var(--offset);
    padding-top: var(--offset);
    z-index: -1;
}
.sticky-robot img {
    position: absolute;
    width: var(--width) !important;
    max-width: none;
    transform: translateX(-75%);
}

/* Note (étoiles) */
.star-rating::after {
    content: '★★★★★';
    background: linear-gradient(to right, var(--wp--preset--color--color-1) var(--percent), var(--wp--preset--color--color-2) var(--percent));
    background-clip: text;
    color: transparent;
}