/* ----------------------------------------------------------------------------- */
/** GLOBAL **/
/* ----------------------------------------------------------------------------- */

@font-face {
    font-family: 'SF Pro Display bold';
    src: url('../font/SFProDisplay-Bold.woff2') format('woff2'),
        url('../font/SFProDisplay-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display bold italic';
    src: url('../font/SFProDisplay-BoldItalic.woff2') format('woff2'),
        url('../font/SFProDisplay-BoldItalic.woff') format('woff');
    font-weight: bold;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display black italic';
    src: url('../font/SFProDisplay-BlackItalic.woff2') format('woff2'),
        url('../font/SFProDisplay-BlackItalic.woff') format('woff');
    font-weight: 900;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display black';
    src: url('../font/SFProDisplay-Black.woff2') format('woff2'),
        url('../font/SFProDisplay-Black.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display heavy';
    src: url('../font/SFProDisplay-Heavy.woff2') format('woff2'),
        url('../font/SFProDisplay-Heavy.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display regular';
    src: url('../font/SFProDisplay-Regular.woff2') format('woff2'),
        url('../font/SFProDisplay-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display semibold';
    src: url('../font/SFProDisplay-Semibold.woff2') format('woff2'),
        url('../font/SFProDisplay-Semibold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display regular italic';
    src: url('../font/SFProDisplay-RegularItalic.woff2') format('woff2'),
        url('../font/SFProDisplay-RegularItalic.woff') format('woff');
    font-weight: normal;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display thin italic';
    src: url('../font/SFProDisplay-ThinItalic.woff2') format('woff2'),
        url('../font/SFProDisplay-ThinItalic.woff') format('woff');
    font-weight: 100;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display thin';
    src: url('../font/SFProDisplay-Thin.woff2') format('woff2'),
        url('../font/SFProDisplay-Thin.woff') format('woff');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display light italic';
    src: url('../font/SFProDisplay-LightItalic.woff2') format('woff2'),
        url('../font/SFProDisplay-LightItalic.woff') format('woff');
    font-weight: 200;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display ultralight italic';
    src: url('../font/SFProDisplay-UltralightItalic.woff2') format('woff2'),
        url('../font/SFProDisplay-UltralightItalic.woff') format('woff');
    font-weight: 200;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display medium';
    src: url('../font/SFProDisplay-Medium.woff2') format('woff2'),
        url('../font/SFProDisplay-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display medium italic';
    src: url('../font/SFProDisplay-MediumItalic.woff2') format('woff2'),
        url('../font/SFProDisplay-MediumItalic.woff') format('woff');
    font-weight: 500;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display ultralight';
    src: url('../font/SFProDisplay-Ultralight.woff2') format('woff2'),
        url('../font/SFProDisplay-Ultralight.woff') format('woff');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display heavy italic';
    src: url('../font/SFProDisplay-HeavyItalic.woff2') format('woff2'),
        url('../font/SFProDisplay-HeavyItalic.woff') format('woff');
    font-weight: 900;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display light';
    src: url('../font/SFProDisplay-Light.woff2') format('woff2'),
        url('../font/SFProDisplay-Light.woff') format('woff');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'SF Pro Display semibold italic';
    src: url('../font/SFProDisplay-SemiboldItalic.woff2') format('woff2'),
        url('../font/SFProDisplay-SemiboldItalic.woff') format('woff');
    font-weight: 600;
    font-style: italic;
    font-display: swap;
}

:root {
    --primary_color_1: #589fe0;
    --primary_color_2: #1F2749;
    --primary_color_3: #F5F4F4;
    --primary_color_4: #1B2442;
    --primary_color_5: #ffffff;
    --main_font: 'SF Pro Display regular';
    --body_text_color: #1F2749;
    --body_font_size: 23px;
    --body_line_height: 1.4;
    --desktop_container: 1400px;
    --grid_gutter: 30px;
    --h1_mb: 35px;
    --h2_mb: 30px;
    --h3_mb: 25px;
    --h4_mb: 20px;
    --h5_mb: 15px;
    --h6_mb: 10px;
    --p_mb: 25px;
    --global_component_mb: 50px;
}

html {
    scroll-padding-top: 90px;
}

body {
    font-family: var(--main_font);
    color: var(--body_text_color);
    font-size: var(--body_font_size);
    line-height: var(--body_line_height);
    -webkit-font-smoothing: antialiased;
    -moz-font-smoothing: antialiased;
    -o-font-smoothing: antialiased;
    text-rendering: optimizelegibility;
    -moz-osx-font-smoothing: grayscale;
    -webkit-tap-highlight-color: transparent;
    min-height: 100vh;
}

.no-scroll {
    overflow-y: hidden;
}

*:focus {
    outline: none;
}

a {
    transition: 0.3s;
    color: var(--primary_color_2);
}

a,
a:hover {
    text-decoration: none;
}

a:hover {
    color: var(--primary_color_1);
}

.main-content {
    /* padding: 100px 0; */
    overflow-x: hidden;
}

.home .main-content {
    /* padding: 0 0 100px 0; */
    margin-bottom: -25px;
}

.button-area .btn {
    font-size: 18px!important;
    padding: 10px 30px!important;
    color: #000!important;
    background-color: #EFEFEF!important;
    border: 1px solid #EFEFEF!important;
    border-radius: 40px;
    position: relative;
    line-height: 1.4;
    display: inline-flex;
    align-items: center;
    height: auto;
    margin-top: 4px;
}

.button-area .btn:hover {
    color: #000!important;
    background-color: var(--primary_color_5)!important;
}

.btn,
.wp-block-button > .wp-block-button__link,
button {
    font-size: 21px!important;
    padding: 10px 25px!important;
    color: #000!important;
    background-color: #EFEFEF!important;
    border: 1px solid #EFEFEF!important;
    border-radius: 40px;
    position: relative;
    line-height: 1.4;
    display: inline-flex;
    align-items: center;
    height: auto;
    margin-top: 4px;
    box-shadow: none;
    cursor: pointer;
    text-align: center;
    text-decoration: none;
}

.wp-block-button > .wp-block-button__link:hover {
    color: #000!important;
    background-color: var(--primary_color_5)!important;
}

.wp-block-button.is-style-outline > .wp-block-button__link {
    font-size: 21px!important;
    padding: 10px 15px!important;
    color: #000!important;
    background-color: #EFEFEF!important;
    border: 1px solid #EFEFEF!important;
    border-radius: 40px;
    position: relative;
    line-height: 1.4;
    display: inline-flex;
    align-items: center;
    height: auto;
    margin-top: 4px;
}

.wp-block-button.is-style-outline > .wp-block-button__link:hover {
    color: #000!important;
    background-color: var(--primary_color_5)!important;
}

.wp-block-button.is-style-fill > .wp-block-button__link {
    font-size: 21px!important;
    padding: 10px 15px!important;
    color: #fcfcfc!important;
    background-color: var(--primary_color_2)!important;
    border: 1px solid var(--primary_color_2)!important;
    border-radius: 40px;
    position: relative;
    line-height: 1.4;
    display: inline-flex;
    align-items: center;
    height: auto;
    margin-top: 4px;
}

.wp-block-button.is-style-fill > .wp-block-button__link:hover {
    color: #000!important;
    background-color: var(--primary_color_5)!important;
}

/* Boutons dans les bannières */
.wp-block-cover .wp-block-button > .wp-block-button__link {
    font-size: 21px!important;
    padding: 10px 15px!important;
    color: #000!important;
    background-color: #EFEFEF!important;
    border: 1px solid #EFEFEF!important;
    border-radius: 40px;
    position: relative;
    line-height: 1.4;
    display: inline-flex;
    align-items: center;
    height: auto;
    margin-top: 4px;
}

.wp-block-cover .wp-block-button > .wp-block-button__link:hover {
    color: #000!important;
    background-color: var(--primary_color_5)!important;
}

.wp-block-cover .wp-block-button.is-style-outline > .wp-block-button__link {
    font-size: 21px!important;
    padding: 10px 15px!important;
    color: #000!important;
    background-color: #EFEFEF!important;
    border: 1px solid #EFEFEF!important;
    border-radius: 40px;
    position: relative;
    line-height: 1.4;
    display: inline-flex;
    align-items: center;
    height: auto;
    margin-top: 4px;
}

.wp-block-cover .wp-block-button.is-style-outline > .wp-block-button__link:hover {
    color: #000!important;
    background-color: var(--primary_color_5)!important;
}

.is-type-video .wp-block-embed__wrapper {
    position: relative;
    padding-bottom: 56.2%;
    height: 0;
    overflow: hidden;
}

.is-type-video .wp-block-embed__wrapper iframe {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
}

.wp-block-image.is-style-width-100 img {
    width: 100%;
    height: auto;
}

.wp-block-image.is-style-width-50 img {
    width: 50%;
    height: auto;
}

.wp-block-separator {
    border-bottom: 1px solid;
    border-left: none;
    border-right: none;
    border-top: 0;
    background-color: transparent !important;
    color: var(--secondary_color);
    border-color: currentColor;
    margin: var(--global_component_mb) 0;
    opacity: 1;
}

.wp-block-separator.is-style-dots:before {
    display: none;
}

.wp-block-separator.is-style-dots {
    border-bottom: 1px dashed;
    background-color: transparent !important;
}

.text-center {
    text-align: center;
}

.text-right {
    text-align: right;
}

.wp-block-group {
    padding: 40px 0px;
    margin-top: 40px;
    margin-bottom: 40px;
}

.wp-block-group.is-style-section-fond-bleu {
    padding: 40px 40px !important;
    background-color: #1F2749;
    margin-top: 40px;
    margin-bottom: 40px;
}

.wp-block-group.is-style-section-fond-bleu h1,
.wp-block-group.is-style-section-fond-bleu h2,
.wp-block-group.is-style-section-fond-bleu h3,
.wp-block-group.is-style-section-fond-bleu h4,
.wp-block-group.is-style-section-fond-bleu h5,
.wp-block-group.is-style-section-fond-bleu h6,
.wp-block-group.is-style-section-fond-bleu p,
.wp-block-group.is-style-section-fond-bleu li,
.wp-block-group.is-style-section-fond-bleu a:not(.btn):not(.wp-block-button__link),
.wp-block-group.is-style-section-fond-bleu .wp-block-heading,
.wp-block-group.is-style-section-fond-bleu .wp-block-paragraph {
    color: #ffffff !important;
}

.wp-block-group.is-style-section-fond-gris {
    margin-top: 40px;
    margin-bottom: 40px;
    padding: 40px 0;
    background-color: #F5F4F4;
}

/* Assurer que les rows Bootstrap ont les bonnes marges dans les sections */
.wp-block-group.is-style-section .row,
.wp-block-group.is-style-section-fond-bleu .row,
.wp-block-group.is-style-section-fond-gris .row {
    margin-right: calc(-0.5 * var(--grid_gutter));
    margin-left: calc(-0.5 * var(--grid_gutter));
}

.wp-block-group.is-style-section .container .row,
.wp-block-group.is-style-section-fond-bleu .container .row,
.wp-block-group.is-style-section-fond-gris .container .row {
    margin-right: calc(-0.5 * var(--grid_gutter));
    margin-left: calc(-0.5 * var(--grid_gutter));
}

.main-content > .container > .alignfull {
    position: relative;
    width: 100vw;
    left: calc(0px - ((100vw - 100%) / 2));
}

.wp-block-group.alignfull > .container > *:last-child {
    padding: 0;
    margin-bottom: 0;
}

.wp-block-cover .wp-block-cover__inner-container {
    position: relative;
}

.wp-block-image.aligncenter {
    margin-left: auto;
    margin-right: auto;
}

.wp-block-image.alignright {
    margin-left: auto;
}

.h-100 {
    height: 100%;
}

.is-style-heading-p {
    font-size: 25px;
}

.lg-outer .lg-thumb-item {
    border: 0;
    position: relative;
    border-radius: 0;
}

.lg-outer .lg-thumb-item:after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: var(--secondary_color);
    opacity: 0;
    transition: 0.3s;
}

.lg-outer .lg-thumb-item.active:after,
.lg-outer .lg-thumb-item:hover:after {
    opacity: 0.5;
}

.lg-outer .lg-thumb-outer,
.lg-outer .lg-toogle-thumb {
    background-color: #222;
}

sup.fn a {
    scroll-margin-top: 80px;
}

.is-style-justify-content-between {
    justify-content: space-between;
}

.is-style-justify-content-evenly {
    justify-content: space-evenly;
}

/* ----------------------------------------------------------------------------- */
/** Typography **/
/* ----------------------------------------------------------------------------- */
h1 {
    margin-bottom: var(--h1_mb);
    font-family: 'SF Pro Display bold', sans-serif;
    font-optical-sizing: auto;
    font-weight: 800;
}

h2 {
    margin-bottom: var(--h2_mb);
    font-family: 'SF Pro Display bold', sans-serif;
    font-optical-sizing: auto;
    font-weight: 800;
    text-transform: uppercase;
}

h2.wp-block-heading {
    font-size: 48px;
}

#footer h2.wp-block-heading {
    font-size: 30px;
    text-transform: uppercase;
}

h3 {
    margin-bottom: var(--h3_mb);
    font-family: 'SF Pro Display bold', sans-serif;
    font-optical-sizing: auto;
    font-weight: 800;
    font-size: 2rem;
}

h4 {
    margin-bottom: var(--h4_mb);
    font-family: 'SF Pro Display bold', sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
}

h5 {
    margin-bottom: var(--h5_mb);
    font-family: 'SF Pro Display bold', sans-serif;
}

h6 {
    margin-bottom: var(--h6_mb);
    font-family: 'SF Pro Display bold', sans-serif;
}

p {
    margin-bottom: var(--p_mb);
    font-size: 24px;
}

p + *:not(ul, ol, p),
ul + *:not(ul, ol, p),
ol + *:not(ul, ol, p),
p + .row,
ul + .row,
ol + .row {
    margin-top: calc(var(--p_mb) * 2);
}

*:not(h1, h2, h3, h4, h5, h6) + h2 {
    margin-top: calc(var(--p_mb) + var(--h2_mb));
}

*:not(h1, h2, h3, h4, h5, h6) + h3 {
    margin-top: calc(var(--p_mb) + var(--h3_mb));
}

*:not(h1, h2, h3, h4, h5, h6) + h4 {
    margin-top: calc(var(--p_mb) + var(--h4_mb));
}

*:not(h1, h2, h3, h4, h5, h6) + h5 {
    margin-top: calc(var(--p_mb) + var(--h5_mb));
}

*:not(h1, h2, h3, h4, h5, h6) + h6 {
    margin-top: calc(var(--p_mb) + var(--h6_mb));
}

ul.editor-list,
.tab ul,
.accordion-item-content ul {
    margin-bottom: var(--p_mb);
    margin-left: 14px;
    list-style: none;
    padding: 0;
}

ul.editor-list ul,
.tab ul ul,
.accordion-item-content ul ul {
    margin-bottom: 16px;
    margin-top: 12px;
}

ul.editor-list > li,
.tab ul > li,
.accordion-item-content ul > li {
    position: relative;
    padding-left: 24px;
    margin-bottom: 16px;
}

ul.editor-list > li:before,
.tab ul > li:before,
.accordion-item-content ul > li:before {
    content: "";
    position: absolute;
    left: 0;
    top: 10px;
    width: 5px;
    height: 5px;
    background: currentColor;
    border-radius: 100%;
}

ul.editor-list ul > li:before,
.tab ul ul > li:before,
.accordion-item-content ul ul > li:before {
    background: transparent;
    border: 1px solid currentColor;
}

ol {
    counter-reset: legal;
    list-style-type: none;
    margin-left: 14px;
    padding: 0;
    margin-bottom: var(--p_mb);
}

ol.wp-block-footnotes {
    counter-reset: inherit;
    list-style-type: auto;
    margin-left: 33px;
}

ol li:before {
    content: counters(legal, ".") ".";
    padding-right: 15px;
    display: table-cell;
}

ol.wp-block-footnotes li:before {
    display: none;
}

ol li {
    display: table;
    margin-bottom: 16px;
    counter-increment: legal;
}

ol.wp-block-footnotes li {
    display: list-item;
    counter-increment: inherit;
    padding-left: 11px;
}

ol ol {
    margin-top: 16px;
    margin-bottom: 7px;
}

ol ol li:last-child {
    margin-bottom: 0;
}

ol:not(.wp-block-footnotes) li:before {
    content: counter(legal, ".") ".";
    padding-right: 15px;
    display: table-cell;
}

.tab ol {
    counter-reset: legal2;
}

.tab ol li {
    counter-increment: legal2;
}

.tab ol li:before {
    content: counters(legal2, ".") ".";
}

.accordion-item-content ol {
    counter-reset: legal3;
}

.accordion-item-content ol li:before {
    content: counters(legal3, ".") ".";
}

.uppercase {
    text-transform: uppercase;
}

/* ----------------------------------------------------------------------------- */
/** Bannière **/
/* ----------------------------------------------------------------------------- */

.wp-block-cover {
    min-height: 400px;
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    border-radius: 0;
    display: flex;
    align-items: flex-end;
}

.wp-block-cover .wp-block-cover__background {
    opacity: 0 !important;
}

.wp-block-cover .wp-block-cover__inner-container {
    width: 100%;
    max-width: var(--desktop_container);
    margin: 0 auto;
    padding: 0 calc(var(--grid_gutter) * 0.5) 50px calc(var(--grid_gutter) * 0.5);
}

.wp-block-cover .wp-block-cover__inner-container p {
    margin: 0;
    font-size: 60px;
    font-weight: 700;
    text-transform: uppercase;
    color: white;
    text-align: left !important;
    filter: drop-shadow(0px 4px 8px rgba(0, 0, 0, 0.5));
}

.wp-block-cover h1 {
    margin: 0;
    font-size: 50px;
    text-transform: uppercase;
    color: white;
    text-align: left;
}

.wp-block-cover h2 {
    margin: 0;
    font-size: 60px;
    text-transform: uppercase;
    color: white;
    text-align: left;
}

/* ----------------------------------------------------------------------------- */
/** Container **/
/* ----------------------------------------------------------------------------- */

@media (min-width: 1200px) {
    .container,
    .container-lg,
    .container-md,
    .container-sm,
    .container-xl {
        max-width: var(--desktop_container);
    }
}

.row > * {
    padding-right: calc(var(--grid_gutter) * 0.5);
    padding-left: calc(var(--grid_gutter) * 0.5);
}

.row {
    margin-right: calc(-0.5 * var(--grid_gutter));
    margin-left: calc(-0.5 * var(--grid_gutter));
}

.wp-block-columns {
    gap: var(--grid_gutter);
}

.container,
.container-fluid,
.container-lg,
.container-md,
.container-sm,
.container-xl,
.container-xxl {
    padding-left: calc(var(--grid_gutter) * 0.5);
    padding-right: calc(var(--grid_gutter) * 0.5);
}

/* ----------------------------------------------------------------------------- */
/** MENU **/
/* ----------------------------------------------------------------------------- */
#website-menu {
    box-shadow: 0 2px 8px 0 rgb(0 0 0 / 6%);
    background-color: rgba(255, 255, 255, 0.95);
    width: 100%;
    position: sticky;
    top: 0;
    z-index: 101;
    transition: 0.3s ease-in-out;
}

#website-menu:not(.menu-open).sticky {
    transform: translateY(-100%);
}

#website-menu:not(.menu-open).visible {
    transform: translateY(0%);
}

.menu-content {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    padding: 5px 105px;
    gap: 1rem;
    width: 100%;
    height:110px;
    background-color: var(--primary_color_2);
}

.logo-area {
    position: relative;
    z-index: 3;
    height: calc(100% - 20px);
}

.logo-area img {
    /* width: 80px; */
    height: 100%;
}

.menus-area {
    justify-self: right;
    column-gap: 30px;
}

.button-area {
    width: 210px;
}

.search-content {
    position: relative;
    z-index: 10;
    display: none;
}

.search-content .search-area {
    position: absolute;
    transition: all 0.3s ease;
    right: -100%;
    opacity: 0;
    visibility: hidden;
    top: 50%;
    transform: translateY(-50%);
}

.search-content .search-area .main-search {
    display: flex;
    box-shadow: 0 19px 60px rgb(0 0 0 / 10%), 0 15px 60px rgb(0 0 0 / 10%);
}

.search-content .search-area .main-search input[type="text"] {
    border: none;
    padding: 15px 20px;
    line-height: 1;
}

.search-content .search-area .main-search .search-send {
    border: none;
    background: #fff;
    padding: 0 18px 0 0;
    color: var(--secondary_color);
}

.search-content .search-area.active {
    opacity: 1;
    visibility: visible;
}

.main-menu-inner {
    padding: 0px;
    margin-bottom: 0px;
    display: flex;
    gap: 40px;
    margin-right: 25px;
}

.main-menu-inner ul {
    padding: 0;
    margin: 0;
}

.main-menu-inner li {
    list-style-type: none;
    display: inline-block;
    position: relative;
    font-size: 25px;
}

.main-menu-inner li a {
    color: var(--primary_color_5);
    display: inline-block;
    padding: 5px 0;
    position: relative;
    text-decoration: none;
    font-size: 18px;
}

.main-menu-inner li a:hover,
.main-menu-inner li.current_page_item > a,
.main-menu-inner li.current_page_ancestor > a {
    color: var(--primary_color_5);
    text-decoration: none;
}

.main-menu-inner li .sub-menu {
    position: absolute;
    top: calc(100% + 10px);
    background: #fff;
    left: 0;
    z-index: 1;
    padding: 20px;
    min-width: 300px;
    opacity: 0;
    visibility: hidden;
    transition: 0.3s;
    transform: translateY(20px);
    box-shadow: 0 2px 8px 0 rgb(0 0 0 / 6%);
    display: flex;
    flex-direction: column;
    row-gap: 10px;
}

.main-menu-inner li.menu-item-has-children:hover > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0px);
}

.menuburger {
    display: none;
}

/* ----------------------------------------------------------------------------- */
/** FOOTERMENU **/
/* ----------------------------------------------------------------------------- */
#footer-menu li:first-child {
    display: none;   
}
#footer-menu li {
    list-style-type: none;
}

#footer-menu {
    text-align: left;
}

/* ----------------------------------------------------------------------------- */
/** FOOTER **/
/* ----------------------------------------------------------------------------- */
#footer {
    background-color: var(--primary_color_2) !important;
    padding: 60px 0 0 0 !important;
}

#footer * {
    color: var(--primary_color_3);
}

.footer-columns {
    padding: 20px!important;
}

.footer-title {
    font-family: 'SF Pro Display semibold', sans-serif !important;
    font-size: 24px !important;
    color: var(--primary_color_3) !important;
}

.footer-content,
.footer-menu-list,
.footer-menu-list li,
.footer-menu-list li a,
.footer-address {
    font-family: 'SF Pro Display regular', sans-serif !important;
    font-size: 16px !important;
}

.footer-menu-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.footer-menu-list li {
    list-style: none !important;
    list-style-type: none !important;
}

.footer-contact-btn {
    font-family: 'SF Pro Display regular', sans-serif !important;
    font-size: 16px !important;
    background-color: var(--primary_color_3) !important;
    color: var(--primary_color_2) !important;
    padding: 15px 30px !important;
    border-radius: 40px !important;
    text-decoration: none !important;
    display: inline-block !important;
    transition: 0.3s !important;
}


/* Alignement à droite de la colonne contact entre 768px et 1199px */
@media (min-width: 991px) and (max-width: 1199px) {
    /* Margin-top sur les colonnes lg-4 */
    .footer-col.col-lg-4 {
        margin-top: 20px !important;
    }
    #footer-col-contact {
        text-align: right !important;
    }
    .reseaux-sociaux-footer {
        text-align: right !important;
    }
}

@media (max-width: 991px) {
    .footer-col {
        margin-top: 40px !important;
    }
}

/* ----------------------------------------------------------------------------- */
/** RESEAUX SOCIAUX FOOTER **/
/* ----------------------------------------------------------------------------- */
.reseaux-sociaux-footer {
    margin-top: 20px;
    padding-left: 2rem;
    text-align: left;
}

.reseau-social-link {
    display: inline-block;
    margin-left: 15px;
    color: var(--primary_color_2);
    font-size: 1.5em;
    transition: color 0.3s ease, transform 0.3s ease;
}

.reseau-social-link:hover {
    color: var(--primary_color_1);
    transform: translateY(-2px);
    text-decoration: none;
}

.reseau-social-link:first-child {
    margin-left: 0;
}

/* ----------------------------------------------------------------------------- */
/** FOOTER BOTTOM **/
/* ----------------------------------------------------------------------------- */
.footer-bottom {
    background-color: var(--secondary_color_5);
    padding: 15px 0;
    font-size: 0.9em;
}

.copyright-info {
    color: var(--body_text_color);
    margin-bottom: 10px;
    font-size: 12px;
    text-align: center;
}

.copyright-info a {
    color: var(--primary_color_2);
    text-decoration: none;
    transition: color 0.3s ease;
}

.copyright-info a:hover {
    color: var(--primary_color_1);
    text-decoration: underline;
}

.footer-menu-bottom {
    text-align: right;
}

.footer-menu-bottom-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 20px;
}

.footer-menu-bottom-list li {
    margin: 0;
}

.footer-menu-bottom-list li a {
    color: var(--body_text_color);
    text-decoration: none;
    transition: color 0.3s ease;
    font-size: 0.9em;
}

.footer-menu-bottom-list li a:hover {
    color: var(--primary_color_1);
    text-decoration: underline;
}

/* Responsive */
@media (max-width: 768px) {
    .footer-bottom .row {
        text-align: center;
    }
    
    .footer-menu-bottom {
        text-align: center;
        margin-top: 15px;
    }
    
    .footer-menu-bottom-list {
        justify-content: center;
    }
}
/* ----------------------------------------------------------------------------- */
/** SEARCH PAGE **/
/* ----------------------------------------------------------------------------- */

.search-item {
    padding: 30px;
    background-color: #f7f7f7;
    border-radius: 2px;
    position: relative;
    display: flex;
    flex-direction: column;
    height: calc(100% - 30px);
    margin-bottom: 30px;
    color: var(--body_text_color);
}

.search-item p {
    margin-bottom: 0;
}

.search-item:hover {
    background-color: var(--secondary_color);
    color: #fff;
    text-decoration: none;
}

/* ----------------------------------------------------------------------------- */
/** SLIDER **/
/* ----------------------------------------------------------------------------- */
.slider-wrapper {
    position: relative;
    margin-bottom: var(--global_component_mb);
    height: 600px;
}

.home .slider-wrapper {
    height: calc(100vh - 90px);
}

.slider {
    position: relative;
    height: 100%;
}

.home .slider-wrapper .slider {
    height: 100%;
}

.slider .slide {
    position: relative;
    height: 600px;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center bottom;
}

.home .slider .slide {
    height: calc(100vh - 90px);
}

.slider .slide a {
    display: block;
    color: var(--body_text_color);
    text-decoration: none;
    width: 100%;
    height: 100%;
}

.slider-wrapper .slick-caption {
    position: absolute;
    left: 0;
    bottom: 50px;
    z-index: 10;
    pointer-events: auto;
    padding-left: 105px;
}

.slider-wrapper .slick-caption .slick-caption-inner {
    /* border-left: 10px solid var(--secondary_color);
    padding: 20px 30px 20px 20px;
    background-color: rgba(0, 0, 0, 0.05);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    border-radius: 5px; */
}

.slider-wrapper .slick-caption h1,
.slider-wrapper .slick-caption h2 {
    /* text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.8); */
}

.slider-wrapper .slick-caption h1 {
    font-family: 'SF Pro Display bold', sans-serif;
}

.slider-wrapper .slick-caption h2,
.slider-wrapper .slick-caption .sub-caption {
    font-family: 'SF Pro Display regular', sans-serif;
}

.slider-wrapper .slick-caption .sub-caption {
    font-size: 28px;
    color: var(--primary_color_5);
}

.slider-wrapper .slick-caption .sub-caption p {
    color: var(--primary_color_5);
    margin-bottom: 0;
}

.slider-wrapper .slick-caption .wp-block-button__link {
    font-size: 21px!important;
    padding: 10px 15px!important;
    color: var(--primary_color_5)!important;
    background-color: var(--primary_color_2)!important;
    border: 1px solid var(--primary_color_2)!important;
    border-radius: 40px;
    position: relative;
    line-height: 1.4;
    display: inline-flex;
    align-items: center;
    height: auto;
    margin-top: 4px;
    text-shadow: none;
}

.slider-wrapper .slick-caption .wp-block-button:not(.is-style-outline) .wp-block-button__link {
    font-size: 21px!important;
    padding: 15px 30px!important;
    color: var(--primary_color_2)!important;
    background-color: var(--primary_color_5)!important;
    border: 1px solid var(--primary_color_5)!important;
    border-radius: 40px !important;
    text-shadow: none;
}

.slider-wrapper .slick-caption .wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
    color: var(--primary_color_2)!important;
    background-color: var(--primary_color_5)!important;
}

/* Styles spécifiques pour le slider en home */
.home .slider-wrapper .slick-caption {
    top: 60%;
    bottom: auto;
    transform: translateY(-50%);
}
.home .slider-wrapper .slick-caption h1 {
    font-size: 60px;
}
.home .slider-wrapper .slick-caption h2 {
    font-size: 50px;
}

.home .slider-wrapper .slick-caption p {
    font-size: 28px;
}

.home .slider-wrapper .slick-caption h1,
.home .slider-wrapper .slick-caption h2 {
    text-transform: uppercase;
}

.slick-prev,
.slick-next {
    font-size: 0 !important;
    line-height: 0 !important;
    position: absolute;
    top: 50%;
    display: block !important;
    padding: 0 !important;
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
    cursor: pointer;
    color: transparent !important;
    border: none !important;
    outline: none;
    background: transparent !important;
    z-index: 15;
    margin-top: 0 !important;
    border-radius: 0 !important;
    height: auto !important;
    align-items: unset !important;
}
.slick-prev:before,
.slick-next:before {
    font-weight: 400;
    font-family: "Font Awesome 6 Pro";
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-size: 50px;
    line-height: 1;
    opacity: 0.75;
    color: white;
}
.slick-prev {
    left: 30px;
}
.slick-prev:before {
    content: "\f104";
}
.slick-next {
    right: 30px;
}
.slick-next:before {
    content: "\f105";
}

/* ----------------------------------------------------------------------------- */
/** GALLERY **/
/* ----------------------------------------------------------------------------- */
.gallery {
    margin-bottom: var(--global_component_mb);
}

.lightgallery {
    margin: 0 -5px;
    row-gap: 10px;
}

.grid-item {
    padding-left: 5px;
    padding-right: 5px;
}

.lightgallery .gallery-item {
    position: relative;
    display: block;
}

.grid-item img {
    width: 100%;
    height: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
}

.lightgallery .gallery-item .gallery-overlay {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    visibility: hidden;
    transition: 0.6s;
    background: var(--secondary_color);
}

.lightgallery .gallery-item:after {
    content: "\f002";
    font-family: "Font Awesome 6 Pro";
    font-weight: 400;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-size: 38px;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    opacity: 0;
    visibility: hidden;
    transition: 0.6s;
}

.lightgallery .gallery-item:hover .gallery-overlay {
    opacity: 0.55;
    visibility: visible;
}

.lightgallery .gallery-item:hover:after {
    opacity: 1;
    visibility: visible;
}

/* ----------------------------------------------------------------------------- */
/** ACCORDION **/
/* ----------------------------------------------------------------------------- */
.accordion {
    margin-bottom: var(--global_component_mb);
}
.accordion-item {
    background: #eee;
    transition: all 0.3s ease;
    margin-bottom: 5px;
}
.accordion-item .accordion-item-header h1,
.accordion-item .accordion-item-header h2,
.accordion-item .accordion-item-header h3,
.accordion-item .accordion-item-header h4,
.accordion-item .accordion-item-header h5,
.accordion-item .accordion-item-header h6 {
    font-size: 20px;
    font-weight: 500;
    margin: 0px;
    padding: 0px;
}
.accordion-item .accordion-item-header {
    padding: 35px 90px 35px 35px;
    display: block;
    position: relative;
    transition: 0.3s;
    transition-delay: 0.35s;
    cursor: pointer;
}
.accordion-item .accordion-item-header:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 35px;
    width: 22px;
    height: 2px;
    background: var(--body_text_color);
    transform: translateY(-50%);
    transition: 0.3s;
}
.accordion-item .accordion-item-header:before {
    content: "";
    position: absolute;
    top: 50%;
    right: 45px;
    width: 2px;
    height: 22px;
    background: var(--body_text_color);
    transform: translateY(-50%);
    transition: 0.3s;
}
.accordion-item .accordion-item-header.active:before {
    transform: translateY(-50%);
    height: 0px;
}
.accordion-item .accordion-item-content {
    padding: 10px 35px 25px 35px;
    display: none;
}
.accordion-item .accordion-item-content p:last-child {
    margin-bottom: 0px !important;
}

/* ----------------------------------------------------------------------------- */
/** TABS **/
/* ----------------------------------------------------------------------------- */
.tabs {
    margin-bottom: var(--global_component_mb);
}
.tabs-nav ul {
    padding: 0px;
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
}
.tabs-nav ul li {
    display: inline-block;
    list-style-type: none;
    padding: 10px 15px;
    background: #eee;
    transition: all 0.3s ease;
    cursor: pointer;
}
.tabs-nav ul li:hover,
.tabs-nav ul li.active {
    background: var(--secondary_color);
    color: #fff;
}
.tabs-content .tab {
    display: none;
}

.tabs-content .tab.active {
    display: block;
}

/* ----------------------------------------------------------------------------- */
/** BOX COLOR **/
/* ----------------------------------------------------------------------------- */
.wp-block-group.has-background:not(.is-style-section),
.wp-block-group.has-border-color {
    padding: 30px;
    margin-bottom: var(--global_component_mb);
}

.wp-block-group.has-background:not(.is-style-section) > *:last-child,
.wp-block-group.has-border-color > *:last-child {
    padding-bottom: 0;
    margin-bottom: 0;
}

/* ----------------------------------------------------------------------------- */
/** POSTS LIST **/
/* ----------------------------------------------------------------------------- */
.posts-by-category,
.events-by-category {
    margin-bottom: var(--global_component_mb);
}

.posts-by-category-list,
.events-by-category-list {
    row-gap: var(--grid_gutter);
}

.card {
    height: 100%;
    box-shadow: 0 19px 60px rgb(0 0 0 / 10%), 0 15px 60px rgb(0 0 0 / 10%);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    color: var(--body_text_color);
}

.card .img-wrap img {
    max-width: 100%;
    height: auto;
}

.card .post-content {
    padding: 30px 40px;
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    height: 100%;
    transition: 0.3s;
}

.card h3 {
    margin-bottom: 20px;
    padding: 0;
}

.card .categories .category {
    color: #fff;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-top: 10px;
    display: inline-block;
    margin-right: 5px;
    background: var(--body_text_color);
    padding: 2px 10px;
    border-radius: 5px;
    transition: 0.3s;
}

.card .card-info {
    font-size: 15px;
    display: inline-flex;
}

.card .card-info i {
    position: relative;
    width: 25px;
    min-width: 25px;
    top: 1px;
}

.post-item.animation {
    animation: fadeIn 0.5s;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(30px);
    }

    to {
        opacity: 1;
        transform: translateY(0px);
    }
}

.card:hover .post-content {
    background: var(--secondary_color);
    color: #fff;
}

.ias-post,
.load-more-post {
    text-align: center;
}

.ias-post .loader {
    width: 50px;
    height: 50px;
    border-radius: 100%;
    position: relative;
    margin: 0 auto;
}

.ias-post .loader:before,
.ias-post .loader:after {
    content: "";
    position: absolute;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
    border-radius: 100%;
    border: 5px solid transparent;
    border-top-color: var(--secondary_color);
}

.ias-post .loader:before {
    z-index: 100;
    animation: spin 1s infinite;
}

.ias-post .loader:after {
    border: 5px solid #eeeeee;
}

@keyframes spin {
    0% {
        -webkit-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

.load-more-post .btn {
    position: relative;
}

.load-more-post .btn .text {
    transition: 0.3s;
}

.load-more-post .btn svg {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: 0.3s;
    opacity: 0;
    visibility: hidden;
}

.load-more-post .btn.loading svg {
    opacity: 1;
    visibility: visible;
}

.load-more-post .btn.loading .text {
    opacity: 0;
    visibility: hidden;
}

/* ----------------------------------------------------------------------------- */
/** TABLE **/
/* ----------------------------------------------------------------------------- */

table {
    width: 100%;
    border: 0;
}

table tbody tr {
    background: #fafafa;
    border-bottom: 0;
}

table tbody tr:nth-child(even) {
    background: transparent;
}

table tr td,
.wp-block-table td,
.wp-block-table th {
    border: 0;
    padding: 19px 25px 21px 25px;
}

table tr td a:hover {
    color: var(--secondary_color);
    text-decoration: none;
}

table p {
    margin-bottom: 0px;
}

.wp-block-table::-webkit-scrollbar {
    height: 4px;
    width: 4px;
    background: #d2dce1;
}

.wp-block-table::-webkit-scrollbar-corner {
    background: #d2dce1;
}

.wp-block-table::-webkit-scrollbar-thumb {
    background: var(--secondary_color);
    border-radius: 0;
}

/* ----------------------------------------------------------------------------- */
/** BLOCKQUOTE **/
/* ----------------------------------------------------------------------------- */

blockquote {
    border-left: 5px solid var(--secondary_color);
    margin: 0px;
    margin-bottom: var(--global_component_mb);
    padding: 0 0 0 35px;
}

blockquote p:first-of-type {
    font-size: 24px;
    font-style: italic;
    line-height: normal;
    font-style: italic;
    margin-bottom: 15px;
}

blockquote p + * {
    padding-left: 25px;
    position: relative;
    margin-bottom: 0px;
    font-style: normal;
}

blockquote p + *:before {
    content: "";
    position: absolute;
    left: 0px;
    top: 50%;
    transform: translateY(-50%);
    width: 15px;
    height: 1px;
    background-color: var(--body_text_color);
}

/* ----------------------------------------------------------------------------- */
/** Special link **/
/* ----------------------------------------------------------------------------- */

.special-link {
    display: block;
    margin-bottom: var(--global_component_mb);
    padding: 20px;
    background-color: #eee;
    color: var(--body_text_color);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.special-link > span {
    display: flex;
    flex-direction: column;
}

.special-link:hover {
    background-color: var(--secondary_color);
    color: #fff;
}

.special-link + .special-link {
    margin-top: calc(0px - var(--global_component_mb) + 10px);
}

.special-link:after {
    content: "";
    font-weight: 400;
    font-family: "Font Awesome 6 Pro";
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: var(--fa-display, inline-block);
    font-style: normal;
    font-variant: normal;
    line-height: 1;
    text-rendering: auto;
}

.special-link.extern-link:after {
    content: "\e09f";
}

.special-link.intern-link:after {
    content: "\f061";
}

.special-link.file-link:after {
    content: "\f15b";
}

/* ----------------------------------------------------------------------------- */
/** Tuile image text vertical **/
/* ----------------------------------------------------------------------------- */

/* Forcer les colonnes à avoir la même hauteur */
.row.alignfull > [class*="col-"] {
    display: flex;
    flex-direction: column;
}

/* Les tuiles enfants directs des colonnes principales prennent 100% de hauteur */
.row.alignfull > [class*="col-"] > .tuile-image-text-vertical,
.row.alignfull > [class*="col-"] > .tuile-image-text-vertical-white {
    height: 100%;
}

/* Les tuiles dans les wrappers flex prennent 100% de hauteur */
.h-100.d-flex.flex-column > .tuile-image-text-vertical,
.h-100.d-flex.flex-column > .tuile-image-text-vertical-white {
    flex: 1;
}

.tuile-image-text-vertical {
    background-color: var(--primary_color_2);
    color: white;
    border-radius: 30px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.tuile-image-text-vertical-white {
    background-color: white;
    color: var(--primary_color_2);
    border-radius: 30px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.tuile-image-text-vertical > *,
.tuile-image-text-vertical-white > * {
    flex: 1;
}

.tuile-image-text-vertical-white h3 {
    font-size: 1.5rem;
}

.tuile-image-text-vertical-white p {
    font-size: 20px;
}


.tuile-image-text-vertical .tuile-img-image,
.tuile-image-text-vertical-white .tuile-img-image{
    width: 100%;
}

.tuile-image-text-vertical .tuile-img-image img,
.tuile-image-text-vertical-white .tuile-img-image img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 30px 30px 0 0;
}

.tuile-image-text-vertical .tuile-img-content,
.tuile-image-text-vertical-white .tuile-img-content{
    padding: 50px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.tuile-image-text-vertical .tuile-img-titre h3,
.tuile-image-text-vertical-white .tuile-img-titre h3 {
    margin: 0;
}

.tuile-image-text-vertical .tuile-img-paragraphe p,
.tuile-image-text-vertical-white .tuile-img-paragraphe p{
    margin: 0;
}

/* Forcer les tuiles verticales à prendre toute la hauteur disponible */
.tuile-image-text-vertical,
.tuile-image-text-vertical-white {
    height: 100%;
}

/* Classe personnalisée pour les images qui doivent prendre toute la hauteur */
.image-full-height {
    height: 100%;
    display: flex;
    flex-direction: column;
    margin: 0;
    margin-bottom: 0!important;
}

.image-full-height img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 30px;
}

/* ----------------------------------------------------------------------------- */
/** FORM **/
/* ----------------------------------------------------------------------------- */

/* Fond gris pour le wrapper du formulaire */
.gform_wrapper.gravity-theme,
.gform_wrapper {
    background-color: var(--primary_color_3);
    padding: 50px 30px;
    border-radius: 0;
}

/* Cacher les labels et les mentions nécessaire */
.gform_wrapper .gfield_label,
.gform_wrapper .gfield_required,
.gform_wrapper .gfield_required_text {
    display: none !important;
}

/* Styles des champs de saisie */
.gform_wrapper.gravity-theme input[type="text"],
.gform_wrapper.gravity-theme input[type="password"],
.gform_wrapper.gravity-theme input[type="email"],
.gform_wrapper.gravity-theme input[type="url"],
.gform_wrapper.gravity-theme input[type="date"],
.gform_wrapper.gravity-theme input[type="month"],
.gform_wrapper.gravity-theme input[type="time"],
.gform_wrapper.gravity-theme input[type="datetime"],
.gform_wrapper.gravity-theme input[type="datetime-local"],
.gform_wrapper.gravity-theme input[type="week"],
.gform_wrapper.gravity-theme input[type="number"],
.gform_wrapper.gravity-theme input[type="search"],
.gform_wrapper.gravity-theme input[type="tel"],
.gform_wrapper.gravity-theme input[type="color"],
.gform_wrapper.gravity-theme textarea,
.gform_wrapper.gravity-theme select,
.gform_wrapper input[type="text"],
.gform_wrapper input[type="password"],
.gform_wrapper input[type="email"],
.gform_wrapper input[type="url"],
.gform_wrapper input[type="date"],
.gform_wrapper input[type="month"],
.gform_wrapper input[type="time"],
.gform_wrapper input[type="datetime"],
.gform_wrapper input[type="datetime-local"],
.gform_wrapper input[type="week"],
.gform_wrapper input[type="number"],
.gform_wrapper input[type="search"],
.gform_wrapper input[type="tel"],
.gform_wrapper input[type="color"],
.gform_wrapper textarea,
.gform_wrapper select {
    font-size: 16px;
    border: none;
    border-radius: 40px;
    padding: 20px 25px;
    appearance: none;
    -webkit-appearance: none;
    transition: 0.3s;
    background-color: var(--primary_color_5);
    color: var(--primary_color_2);
    width: 100%;
}

/* Style du placeholder */
.gform_wrapper input::placeholder,
.gform_wrapper textarea::placeholder {
    color: var(--primary_color_2);
    opacity: 1;
}

/* Textarea spécifique */
.gform_wrapper textarea {
    border-radius: 30px;
    min-height: 150px;
    resize: vertical;
}

.gform_wrapper.gravity-theme input[type="text"]:focus,
.gform_wrapper.gravity-theme input[type="password"]:focus,
.gform_wrapper.gravity-theme input[type="email"]:focus,
.gform_wrapper.gravity-theme input[type="url"]:focus,
.gform_wrapper.gravity-theme input[type="date"]:focus,
.gform_wrapper.gravity-theme input[type="month"]:focus,
.gform_wrapper.gravity-theme input[type="time"]:focus,
.gform_wrapper.gravity-theme input[type="datetime"]:focus,
.gform_wrapper.gravity-theme input[type="datetime-local"]:focus,
.gform_wrapper.gravity-theme input[type="week"]:focus,
.gform_wrapper.gravity-theme input[type="number"]:focus,
.gform_wrapper.gravity-theme input[type="search"]:focus,
.gform_wrapper.gravity-theme input[type="tel"]:focus,
.gform_wrapper.gravity-theme input[type="color"]:focus,
.gform_wrapper.gravity-theme textarea:focus,
.gform_wrapper input[type="text"]:focus,
.gform_wrapper input[type="password"]:focus,
.gform_wrapper input[type="email"]:focus,
.gform_wrapper input[type="url"]:focus,
.gform_wrapper input[type="date"]:focus,
.gform_wrapper input[type="month"]:focus,
.gform_wrapper input[type="time"]:focus,
.gform_wrapper input[type="datetime"]:focus,
.gform_wrapper input[type="datetime-local"]:focus,
.gform_wrapper input[type="week"]:focus,
.gform_wrapper input[type="number"]:focus,
.gform_wrapper input[type="search"]:focus,
.gform_wrapper input[type="tel"]:focus,
.gform_wrapper input[type="color"]:focus,
.gform_wrapper textarea:focus {
    outline: none;
}

/* Bouton de soumission */
.gform_wrapper .gform_footer,
.gform_wrapper .gform-footer {
    text-align: center;
    margin-top: 30px;
}

.gform_wrapper .gform_button,
.gform_wrapper .gform_footer button,
.gform_wrapper .gform-footer button {
    background-color: var(--primary_color_2) !important;
    color: var(--primary_color_5) !important;
    border: 1px solid var(--primary_color_2) !important;
    font-size: 21px !important;
    padding: 15px 40px !important;
    border-radius: 40px !important;
    cursor: pointer;
    transition: 0.3s;
    font-family: var(--main_font);
    margin: auto!important;
    display: inline-block;
}

.gform_wrapper .gform_button:hover,
.gform_wrapper .gform_footer button:hover,
.gform_wrapper .gform-footer button:hover {
    background-color: var(--primary_color_4) !important;
    border-color: var(--primary_color_4) !important;
}

input[type="checkbox"] {
    border: 1px solid #ccc !important;
    border-radius: 0px;
    line-height: 0;
    width: 19px;
    min-width: 19px;
    height: 19px;
    margin-right: 10px;
    outline: 0;
    padding: 0;
    position: relative;
    appearance: none;
    -webkit-appearance: none;
    transition: 0.3s;
    background: #fff;
}

.gform_wrapper.gravity-theme .gfield_checkbox label,
.gform_wrapper.gravity-theme .gfield_radio label {
    font-size: var(--body_font_size);
}

.gform_wrapper.gravity-theme .gfield_label {
    font-size: var(--body_font_size);
    font-weight: normal;
}

.gfield_consent_label {
    display: initial !important;
}

.ginput_container_consent {
    display: flex;
    justify-content: flex-start;
}

.ginput_container_consent input[type="checkbox"] {
    top: 2px;
}

.gfield_visibility_visible {
    /* margin-bottom: 20px; */
}

.gfield_visibility_visible.hidden_label {
    margin-bottom: 0;
}

input[type="checkbox"]:hover {
    border: 1px solid var(--secondary_color) !important;
}

input[type="checkbox"]:checked {
    background: var(--secondary_color) !important;
    border: 1px solid var(--secondary_color) !important;
}

input[type="checkbox"]:checked:before {
    content: "";
    margin: 1px 6px;
    color: #fff;
    display: inline-block;
    transform: rotate(45deg);
    height: 12px;
    width: 6px;
    border-bottom: 2px solid #fff;
    border-right: 2px solid #fff;
}

input[type="radio"]:checked,
input[type="radio"]:not(:checked) {
    position: absolute;
    left: -9999px;
}

input[type="radio"]:checked + label,
input[type="radio"]:not(:checked) + label {
    position: relative;
    padding-left: 30px;
    cursor: pointer;
    line-height: 20px;
    display: inline-block;
}

input[type="radio"] + label {
    padding-left: 30px;
}

input[type="radio"]:checked + label:before,
input[type="radio"]:not(:checked) + label:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0px;
    width: 20px;
    height: 20px;
    border: solid 1px #ccc;
    border-radius: 100%;
    background: #fff;
    transition: 0.3s;
}

input[type="radio"]:disabled + label:before {
    opacity: 0.35;
}

input[type="radio"]:disabled + label {
    cursor: not-allowed;
}

input[type="radio"]:not(:checked):hover + label:before {
    border: 1px solid var(--secondary_color);
}

input[type="radio"]:checked + label:before {
    border: 1px solid var(--secondary_color);
}

input[type="radio"]:checked + label:after,
input[type="radio"]:not(:checked) + label:after {
    content: "";
    width: 12px;
    height: 12px;
    background: var(--secondary_color);
    position: absolute;
    top: 4px;
    left: 4px;
    border-radius: 100%;
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
}

input[type="radio"]:not(:checked) + label:after {
    opacity: 0;
    -webkit-transform: scale(0);
    transform: scale(0);
}

input[type="radio"]:checked + label:after {
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1);
}

.gfield_radio .gchoice {
    position: relative;
}

.ginput_container_fileupload {
    padding-bottom: 12px;
    border-bottom: solid 1px #cccccc;
    max-width: 335px;
}

.ginput_container_fileupload input[type="file"] {
    font-size: 14px;
    width: 100% !important;
}

select {
    display: none !important;
}

.dropdown {
    border: none;
    border: 0px;
    box-sizing: border-box;
    background: #fff;
    cursor: pointer;
    display: block;
    outline: none;
    padding: 15px;
    position: relative;
    transition: all 0.2s ease-in-out;
    user-select: none;
    width: 100%;
    border-radius: 0px;
    border: 1px solid #ccc;
}

/* .gform_wrapper .gfield.open .dropdown {
    border-color: var(--secondary_color);
} */

.dropdown:after {
    content: "\f107";
    font-weight: 400;
    font-family: "Font Awesome 6 Pro";
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    display: block;
    pointer-events: none;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 15px;
    transition: 0.3s;
    transform-origin: 50% 25%;
    color: var(--secondary_color);
}

.dropdown.open {
    border-color: var(--secondary_color);
}

.dropdown.open:after {
    transform: rotate(-180deg);
}

.dropdown.open .list {
    transform: scale(1);
    opacity: 1;
    pointer-events: auto;
}

.dropdown.open .option {
    cursor: pointer;
    margin-bottom: 0px;
}

.dropdown.wide {
    width: 100%;
}

.dropdown.wide .list {
    left: 0 !important;
    right: 0 !important;
}

.dropdown .list {
    box-sizing: border-box;
    transition: all 0.15s cubic-bezier(0.25, 0, 0.25, 1.75), opacity 0.1s linear;
    transform: scale(0.75);
    transform-origin: 50% 0;
    background-color: #fff;
    border-radius: 0px;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
    position: absolute;
    min-width: calc(100% + 2px);
    left: -1px;
    z-index: 999;
    top: calc(100% + 10px);
    border: 1px solid #ccc;
}

.dropdown .list:hover .option:not(:hover) {
    background-color: transparent !important;
}

.dropdown .list ul {
    height: auto;
    max-height: 400px;
    overflow: auto;
    padding: 0;
    margin: 0;
}

.dropdown .list ul::-webkit-scrollbar {
    height: 4px;
    width: 4px;
    background: #d2dce1;
}
.dropdown .list ul::-webkit-scrollbar-corner {
    background: #d2dce1;
}
.dropdown .list ul::-webkit-scrollbar-thumb {
    background: var(--secondary_color);
    border-radius: 0;
}

.dropdown .option {
    cursor: default;
    font-weight: normal;
    color: var(--body_text_color);
    outline: none;
    display: block;
    font-size: 18px;
    text-transform: none;
    padding: 12px 19px;
    text-align: left;
    transition: all 0.2s;
}

.dropdown .option:hover,
.dropdown .option:focus {
    background-color: #fafafa !important;
}

.dropdown .option.selected {
    font-weight: 600;
}

.dropdown .option.selected:focus {
    font-weight: 700;
}

.dropdown .current {
    opacity: 1;
    transition: all 0.3s ease;
}
.gfield .dropdown .current {
    opacity: 1;
    transition: all 0.3s ease;
}

.gfield.open .dropdown .current {
    opacity: 1;
}

.gform_required_legend {
    display: none;
}

/* ----------------------------------------------------------------------------- */
/** FOOTER **/
/* ----------------------------------------------------------------------------- */
.footer {
    background: var(--primary_color_3);
    padding: 50px 0px 0px 0px;
}

.menu-footer {
    display: inline-flex;
    gap: 20px;
    list-style: none;
    margin: 0;
    padding: 0;
}

/* ----------------------------------------------------------------------------- */
/** Tarteaucitron **/
/* ----------------------------------------------------------------------------- */

#tarteaucitronRoot * {
    color: var(--black) !important;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronTitle button,
#tarteaucitron #tarteaucitronServices .tarteaucitronDetails {
    color: #fff !important;
}

#tarteaucitronRoot #tarteaucitronAlertBig {
    color: var(--body_text_color) !important;
    padding: 9px 18px !important;
    width: 100% !important;
    left: 0 !important;
    margin: auto;
    text-align: left !important;
    bottom: 0px;
    background: rgba(255, 255, 255, 1) !important;
    overflow: hidden;
    box-sizing: border-box !important;
    box-shadow: 0 10px 50px 20px rgba(22, 22, 22, 0.2);
}

#tarteaucitronRoot .tarteaucitronAllow,
#tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronPersonalize2,
#tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk .tarteaucitronDeny,
#tarteaucitronRoot .tarteaucitronDeny {
    background-color: #00bd66 !important;
    border: none !important;
    color: #fff !important;
    font-size: 16px !important;
    line-height: normal !important;
    text-decoration: none !important;
    transition: all 0.2s linear !important;
    display: inline-block !important;
    cursor: pointer !important;
    position: relative;
    z-index: 1;
    margin-left: 15px !important;
    float: right;
    font-weight: 400 !important;
    padding: 9px 15px 9px 15px !important;
    text-align: center;
    overflow-wrap: break-word;
    box-sizing: border-box;
    border-radius: 0px !important;
}

#tarteaucitronRoot .tarteaucitronDeny {
    background-color: #f43965 !important;
}

#tarteaucitronRoot .tarteaucitronAllow:hover,
#tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronPersonalize2:hover {
    /* background-color: var(--secondary_color) !important; */
    opacity: 0.8;
}

#tarteaucitronAlertBig #tarteaucitronDisclaimerAlert {
    font-size: 12px !important;
    line-height: 1.5 !important;
    color: var(--body_text_color) !important;
    padding: 0px !important;
    width: 70%;
    float: left;
    margin-top: 9px;
}

#tarteaucitronRoot .tarteaucitronCheck::before {
    display: none !important;
}

#tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronCloseAlert {
    background-color: none !important;
    color: var(--body_text_color) !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    padding: 10px 0px !important;
    margin-bottom: 0 !important;
    line-height: 1 !important;
    float: right;
    margin-left: 15px;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk .tarteaucitronDeny {
    background-color: #a94442 !important;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronMainLine {
    background: none !important;
    border: none !important;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronLine {
    background: #fff !important;
    border: none !important;
}

#tarteaucitronRoot button#tarteaucitronBack {
    opacity: 0.5 !important;
    background: var(--body_text_color) !important;
}

#tarteaucitron .tarteaucitronBorder {
    border: none !important;
}

#tarteaucitronRoot .tarteaucitronH1 {
    text-align: center;
    margin: 15px 0 28px;
    font-size: 35px !important;
    font-family: var(--secondary_font);
    font-weight: 400 !important;
    line-height: 1.05 !important;
    color: var(--body_text_color) !important;
}

.tarteaucitronMainLine div#tarteaucitronInfo {
    font-size: 18px !important;
    color: var(--body_text_color) !important;
}

.tarteaucitronTitle {
    background: #fff;
}

#tarteaucitronRoot div#tarteaucitron {
    outline: none;
}

#tarteaucitron #tarteaucitronInfo {
    background: none !important;
    color: var(--body_text_color) !important;
    padding: 0 !important;
    border: none !important;
}

#tarteaucitronRoot .tarteaucitronH2 {
    color: var(--body_text_color) !important;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronTitle button,
#tarteaucitron #tarteaucitronServices .tarteaucitronDetails {
    background-color: var(--body_text_color) !important;
    margin-top: 0 !important;
}

#tarteaucitronClosePanel {
    background: none !important;
    font-size: 0 !important;
    padding: 0 !important;
    width: auto !important;
    outline: none !important;
    right: 20px !important;
    color: var(--body_text_color) !important;
    z-index: 2;
    top: 15px;
}

#tarteaucitronClosePanel:after {
    content: "\f00d";
    font-family: "Font Awesome 6 Pro";
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: var(--fa-display, inline-block);
    font-style: normal;
    font-variant: normal;
    line-height: 1;
    text-rendering: auto;
    font-weight: 300;
    font-size: 30px !important;
}

#tarteaucitron div#tarteaucitronServices {
    margin-top: 0px !important;
}

#tarteaucitronRoot div#tarteaucitron {
    background: #fff;
    border-radius: 0px;
    padding: 20px 0;
}

#tarteaucitronRoot .tarteaucitronCross::before {
    display: none !important;
}

div#tarteaucitronServices {
    box-shadow: none !important;
}

@media (max-width: 991px) {
    #tarteaucitronAlertBig #tarteaucitronDisclaimerAlert {
        width: 100%;
        margin-top: 0;
    }

    #tarteaucitronRoot .tarteaucitronAllow,
    #tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronPersonalize2 {
        float: left;
        margin-left: 0px !important;
        margin-top: 10px;
    }

    #tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronCloseAlert,
    #tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk .tarteaucitronDeny,
    #tarteaucitronRoot .tarteaucitronDeny.tarteaucitronCTAButton {
        float: left;
        margin-left: 10px !important;
        margin-top: 10px;
    }
}

@media (max-width: 767px) {
    #tarteaucitronRoot .tarteaucitronAsk button {
        margin-left: 0 !important;
    }

    #tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronCloseAlert,
    #tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk .tarteaucitronDeny,
    #tarteaucitronRoot .tarteaucitronDeny {
        margin-left: 15px;
    }

    #tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronCloseAlert {
        font-size: 12px !important;
    }

    #tarteaucitronRoot .tarteaucitronAllow,
    #tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronPersonalize2,
    #tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk .tarteaucitronDeny.tarteaucitronCTAButton,
    #tarteaucitronRoot #tarteaucitronAlertBig .tarteaucitronDeny.tarteaucitronCTAButton {
        font-size: 12px !important;
    }
}

#tarteaucitronRoot #tarteaucitronPercentage {
    background: var(--secondary_color) !important;
    box-shadow: none !important;
    height: 3px !important;
}

/* ----------------------------------------------------------------------------- */
/** TUILES **/
/* ----------------------------------------------------------------------------- */

.tuile {
    display: flex;
    min-height: 300px;
    transition: all 0.3s ease;
    flex: 1; 
    display: flex; 
    flex-direction: column; 
    justify-content: flex-start; 
    text-align: left;
    position: relative; 
    overflow: hidden; 
    border-radius: 8px; 
    padding: 0; 
    background: var(--primary_color_5);
}

.tuile-picto {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: auto; 
    height: auto; 
    margin: 0;
    transition: all 0.6s ease;
}

.tuile-picto img {
    width: 30px;
    max-height: 30px;
    height: auto;
    max-width: 100%;
    /*filter: brightness(0) invert(1);*/
}

.tuile-contenu {
    padding: 0;
    color: var(--primary_color_5);
    position: relative;
    overflow: visible;
    max-width: calc(100% - 40px);
}

.tuile .tuile-bouton {
    margin: 0;
}

.tuile .tuile-bouton .btn {
    font-size: 21px!important;
    padding: 10px 15px!important;
    color: #000!important;
    background-color: #EFEFEF!important;
    border: 1px solid #EFEFEF!important;
    border-radius: 40px;
    position: relative;
    line-height: 1.4;
    display: inline-flex;
    align-items: center;
    height: auto;
    margin-top: 4px;
}

.tuile .tuile-bouton .btn:hover {
    color: #000!important;
    background-color: var(--primary_color_5)!important;
}

.tuile:hover {
    background-color: var(--secondary_color_5);
}

.tuile .tuile-titre {
    transition: all 0.3s ease;
}

.tuile:hover .tuile-titre {
    color: var(--primary_color_5);
    
}


.tuile-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4); /* Overlay sombre semi-transparent */
    z-index: 1;
}

.tuile-text-content {
    position: relative;
    z-index: 2;
}

.tuile-contenu .tuile-titre {
    color: var(--primary_color_4);
    text-transform: none;
    font-weight: 600;
    margin: 0; 
    font-size: 18px;
    line-height: 1.2;
}

/* Ajustement pour les tuiles avec image de fond */
.tuile[style*="background-image"] .tuile-contenu .tuile-titre {
    color: #ffffff;
}

.tuile-contenu .tuile-texte {
    color: white;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

/* Styles pour les tuiles cliquables */
.tuile-link {
    display: block;
    text-decoration: none;
    color: inherit;
}

.tuile-link:hover {
    text-decoration: none;
    color: inherit;
}

.tuile-link:hover .tuile {
    box-shadow: 0px 20px 40px -10px rgb(22 41 68 / 50%);
}

.tuile-link:hover .tuile-bg-image {
    transform: scale(1.1);
}


/* ----------------------------------------------------------------------------- */
/** TITRE SECTEUR **/
/* ----------------------------------------------------------------------------- */
.titre-secteur-wrapper {
    position: relative;
    overflow: visible;
    width: 100%;
    margin-bottom: var(--global_component_mb);
}

.titre-secteur-bandeau {
    position: relative;
    width: 100%;
    padding: 10px 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.titre-secteur-mascotte {
    display: flex;
    align-items: center;
}

.titre-secteur-mascotte img {
    max-height: 180px;
    height: auto;
    width: auto;
}

.titre-secteur-titre {
    display: flex;
    align-items: center;
}

.titre-secteur-titre h2 {
    font-weight: 800;
    text-transform: uppercase;
    background-color: #864a00;
    color: transparent;
    text-shadow: 2px 2px 3px rgba(255, 255, 255, 0.5);
    -webkit-background-clip: text;
    -moz-background-clip: text;
    background-clip: text;
    font-size: 50px;
    margin: 0;
    line-height: 1.2;
    font-family: 'SF Pro Display bold', sans-serif;
    font-optical-sizing: auto;
}
/* ----------------------------------------------------------------------------- */
/** TEMOIGNAGES **/
/* ----------------------------------------------------------------------------- */
.slider-temoignages {
    position: relative;
    padding: 40px 0;
}

.slide-temoignages {
    text-align: center;
    padding: 0 20px;
}

.contenu-temoignage {
    position: relative;
    font-size: 1.2em;
    line-height: 1.6;
    color: var(--secondary_color_1);
    font-style: italic;
    margin-bottom: 20px;
    padding: 40px 40px 0 40px;
    overflow: hidden;
}

.quote-left {
    font-size: 60px;
    color: var(--secondary_color_3);
    position: absolute;
    top: 0px;
    left: 5px;
    line-height: 1;
    z-index: 1;
}

.quote-right {
    font-size: 60px;
    color: var(--secondary_color_3);
    position: absolute;
    bottom: 40px;
    right: 5px;
    line-height: 1;
    z-index: 1;
}

.auteur-temoignage {
    font-weight: bold;
    color: var(--secondary_color_1);
    text-align: center;
    font-size: 20px;
}

/* Styles pour les dots de pagination Slick */
.slider-temoignages .slick-dots {
    text-align: center;
    margin-top: 10px;
    padding: 0;
}

.slider-temoignages .slick-dots li {
    display: inline-block;
    margin: 0 5px;
}

.slider-temoignages .slick-dots li button {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: none;
    background-color: #ccc;
    font-size: 0;
    cursor: pointer;
    transition: background-color 0.3s ease;
    padding: 0;
    margin: 0;
    display: block;
}

.slider-temoignages .slick-dots li.slick-active button {
    background-color: var(--primary_color_1);
}


/* ----------------------------------------------------------------------------- */
/** DARK MODE **/
/* ----------------------------------------------------------------------------- */

/* @media (prefers-color-scheme: dark) {
    
} */

/* ----------------------------------------------------------------------------- */
/** RESPONSIVE **/
/* ----------------------------------------------------------------------------- */

@media screen and (max-width: 991px) {
    /* ----------------------------------------------------------------------------- */
    /** MOBILE MENU **/
    /* ----------------------------------------------------------------------------- */

    /* Cacher le bouton Contactez-nous en dehors du menu burger */
    .button-area {
        display: none;
    }

    .menuburger {
        position: relative;
        z-index: 99999;
        cursor: pointer;
        width: 38px;
        height: 18px;
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
        -webkit-transition: 0.5s ease-in-out;
        -moz-transition: 0.5s ease-in-out;
        -o-transition: 0.5s ease-in-out;
        transition: 0.5s ease-in-out;
        cursor: pointer;
        z-index: 5;
        display: block;
    }

    .menuburger span {
        display: block;
        position: absolute;
        height: 3px;
        width: 40px;
        background: #ffffff;
        border-radius: 0px;
        opacity: 1;
        left: 50%;
        -webkit-transform: rotate(0deg);
        -moz-transform: translateX(-50%) rotate(0deg);
        -o-transform: translateX(-50%) rotate(0deg);
        transform: translateX(-50%) rotate(0deg);
        -webkit-transition: 0.25s ease-in-out;
        -moz-transition: 0.25s ease-in-out;
        -o-transition: 0.25s ease-in-out;
        transition: 0.25s ease-in-out;
    }

    .menuburger.active span {
        background: var(--primary_color_2);
    }

    .mobile-menu ul li a {
        color: var(--primary_color_2) !important;
        font-family: 'SF Pro Display regular', sans-serif;
        font-size: 28px;
        font-weight: normal;
    }

    .menuburger span:nth-child(1) {
        top: 0px;
    }

    .menuburger span:nth-child(2) {
        top: 10px;
    }

    .menuburger span:nth-child(3) {
        top: 20px;
    }

    .menuburger.active span:nth-child(1) {
        top: 50%;
        -webkit-transform: translate(-50%, -50%) rotate(135deg) scaleX(0.7);
        -moz-transform: translate(-50%, -50%) rotate(135deg) scaleX(0.7);
        -o-transform: translate(-50%, -50%) rotate(135deg) scaleX(0.7);
        transform: translate(-50%, -50%) rotate(135deg) scaleX(0.7);
        opacity: 1;
    }

    .menuburger.active span:nth-child(2) {
        opacity: 0;
        left: 40px;
    }

    .menuburger.active span:nth-child(3) {
        top: 50%;
        -webkit-transform: translate(-50%, -50%) rotate(-135deg) scaleX(0.7);
        -moz-transform: translate(-50%, -50%) rotate(-135deg) scaleX(0.7);
        -o-transform: translate(-50%, -50%) rotate(-135deg) scaleX(0.7);
        transform: translate(-50%, -50%) rotate(-135deg) scaleX(0.7);
    }

    .main-menu-outer {
        display: none;
        position: fixed;
        width: 100%;
        height: 100%;
        left: 0;
        top: 0;
        background-color: #fff;
        z-index: 2;
        overflow: auto;
    }

    .main-menu-outer:after {
        content: "";
        position: absolute;
        background: rgb(255, 255, 255);
        background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0px, rgba(255, 255, 255, 1) 50px);
        width: calc(100% - 20px);
        left: 0px;
        height: 120px;
        pointer-events: none;
    }

    .main-menu-inner {
        padding: 120px 30px 50px 30px;
        margin-bottom: 0px;
        display: flex;
        flex-direction: column;
        align-items: center;
        position: fixed;
        background: #fff;
        width: 100%;
        height: 100vh;
        overflow-y: auto;
        overflow-x: hidden;
    }

    .main-menu-inner li {
        margin-right: 0;
    }

    .main-menu-inner li a {
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    .main-menu-inner li .sub-menu {
        position: fixed;
        background: #fff;
        min-width: inherit;
        opacity: 1;
        visibility: visible;
        transform: none;
        box-shadow: none;
        padding: 120px 30px 50px 30px;
        z-index: 1;
        overflow-y: auto;
        overflow-x: hidden;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        transform: translateX(100%) !important;
    }

    .main-menu-inner li.menu-item-has-children.sub-open > .sub-menu {
        transform: translateX(0px) !important;
    }

    .mobile-menu ul.active {
        overflow: hidden;
    }

    .mobile-menu ul.active > li > a,
    .mobile-menu ul.active > .sub-heading {
        transform: translateX(-100%);
    }

    .main-menu-inner li .sub-menu li {
        margin-bottom: 0px;
        display: block;
        padding-left: 40px;
    }

    .main-menu-inner li .sub-menu li a {
        font-size: 18px;
    }

    .main-menu-inner li.menu-item-has-children > a:after {
        content: "\f105";
        moz-osx-font-smoothing: grayscale;
        -webkit-font-smoothing: antialiased;
        display: var(--fa-display, inline-block);
        font-style: normal;
        font-variant: normal;
        line-height: 1;
        text-rendering: auto;
        font-weight: 400;
        font-family: "Font Awesome 6 Pro";
    }

    .main-menu-inner li .sub-menu .sub-heading {
        font-weight: 700;
        color: var(--secondary_color);
        margin-bottom: 10px;
        display: flex;
        align-items: center;
        gap: 10px;
        line-height: 1;
        padding-left: 0;
        font-size: 25px;
        transition: 0.3s;
    }

    .main-menu-inner li .sub-menu .sub-heading .back-btn {
        width: 30px;
        height: 30px;
        background: #f1f1f1;
        display: inline-flex;
        border-radius: 100%;
        align-items: center;
        justify-content: center;
        font-size: 18px;
        cursor: pointer;
        transition: 0.3s;
    }

    .main-menu-inner li .sub-menu .sub-heading .back-btn:hover {
        background-color: var(--secondary_color);
        color: #fff;
    }
}

@media screen and (max-width: 767px) {
    /* ----------------------------------------------------------------------------- */
    /** SLIDER RESPONSIVE **/
    /* ----------------------------------------------------------------------------- */
    .slider-wrapper .slick-caption {
        bottom: 30px;
        padding: 0 15px;
    }
    
    .slider-wrapper .slick-caption .slick-caption-inner {
        padding: 15px 20px 15px 15px;
    }
    
    .home .slider-wrapper .slick-caption {
        top: 50%;
        bottom: auto;
        transform: translateY(-50%);
    }
    
    .home .slider-wrapper .slick-caption h1 {
        font-size: 35px !important;
    }
    
    .home .slider-wrapper .slick-caption h2 {
        font-size: 28px !important;
    }

    /* ----------------------------------------------------------------------------- */
    /** TETE MASCOTTE RESPONSIVE **/
    /* ----------------------------------------------------------------------------- */
    .tete-mascotte {
        max-width: 150px;
    }
    
    .tete-mascotte-wrapper {
        margin-bottom: 4px; /* Ajustement proportionnel pour mobile */
        height: 93px; /* Ajustement proportionnel de la hauteur (75% de 124px) */
    }
}

/* ----------------------------------------------------------------------------- */
/** Classes utilitaires mobile **/
/* ----------------------------------------------------------------------------- */

@media (max-width: 767px) {
    .mt-mobile-30 {
        margin-top: 30px !important;
    }
    
    .mb-mobile-30 {
        margin-bottom: 30px !important;
    }
    
    .mr-mobile-30 {
        margin-right: 30px !important;
    }
    
    .ml-mobile-30 {
        margin-left: 30px !important;
    }
}

@media (max-width: 1199px) {
    .mt-lg-30 {
        margin-top: 30px !important;
    }
    
    .mb-lg-30 {
        margin-bottom: 30px !important;
    }
    
    .mr-lg-30 {
        margin-right: 30px !important;
    }
    
    .ml-lg-30 {
        margin-left: 30px !important;
    }
    .menu-content {
        padding: 5px 50px;
    }
    .main-menu-inner {
        gap: 30px;
    }
}
/* ----------------------------------------------------------------------------- */
/** Tuiles Grid / Slider **/
/* ----------------------------------------------------------------------------- */

.tuiles-container {
    position: relative;
}

.tuiles-grid {
    margin-left: -15px;
    margin-right: -15px;
}

.tuile {
    position: relative;
    height: 300px;
    border-radius: 20px;
    overflow: hidden;
    background-color: #F3F4F6;
}

.tuile-picto {
    position: absolute;
    top: 30px;
    left: 30px;
    z-index: 2;
}

.tuile-picto img {
    max-width: 50px;
    height: auto;
}

.tuile-contenu {
    position: absolute;
    top: 100px;
    left: 30px;
    right: 30px;
    z-index: 2;
}

.tuile-titre {
    margin: 0 0 30px 0;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.3;
}

/* Mobile slider styles */
@media (max-width: 767px) {
    .tuiles-container {
        padding: 0;
        margin-bottom: 60px;
    }
    
    .tuiles-grid.slick-initialized {
        margin-left: 0;
        margin-right: 0;
    }
    
    .tuiles-grid.slick-initialized .col-12,
    .tuiles-grid.slick-initialized .col-md-6,
    .tuiles-grid.slick-initialized .col-lg-3 {
        padding-left: 0;
        padding-right: 0;
    }
    
    .tuile {
        margin: 0 15px;
    }
    
    /* Cacher le compteur Slick */
    .tuiles-grid .slick-counter,
    .tuiles-grid .slick-slide-count {
        display: none !important;
    }
    
    /* Cacher les flèches */
    .tuiles-grid .slick-prev,
    .tuiles-grid .slick-next {
        display: none !important;
    }
    
    /* Slick dots - très discrets comme la maquette */
    .tuiles-grid .slick-dots {
        bottom: -45px;
        display: flex !important;
        justify-content: center;
        align-items: center;
        gap: 8px;
        padding: 0;
        margin: 0;
        list-style: none;
    }
    
    .tuiles-grid .slick-dots li {
        width: 8px;
        height: 8px;
        margin: 0;
        padding: 0;
        line-height: 0;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    
    .tuiles-grid .slick-dots li button {
        width: 8px;
        height: 8px;
        padding: 3px 3px!important;
        margin: 0;
        border: none;
        border-radius: 50%;
        background-color: #D1D5DB;
        font-size: 0;
        line-height: 0;
        cursor: pointer;
        transition: all 0.2s ease;
        overflow: hidden;
        text-indent: -9999px;
    }
    
    .tuiles-grid .slick-dots li button:before {
        display: none;
    }
    
    .tuiles-grid .slick-dots li button:hover {
        background-color: #9CA3AF;
    }
    
    .tuiles-grid .slick-dots li.slick-active button {
        background-color: #6B7280;
        padding: 5px 5px!important;
    }
}

/* ----------------------------------------------------------------------------- */
/** Tuiles Bleu Mobile (Grid + Slider) **/
/* ----------------------------------------------------------------------------- */

.tuiles-bleu-container {
    position: relative;
}

.tuiles-bleu-grid {
    margin-left: -15px;
    margin-right: -15px;
}

/* Forcer les colonnes à avoir la même hauteur */
.tuiles-bleu-grid > [class*="col-"] {
    display: flex;
    flex-direction: column;
}

.tuile-bleu {
    background-color: var(--primary_color_2);
    color: white;
    border-radius: 30px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.tuile-bleu-img-image {
    width: 100%;
}

.tuile-bleu-img-image img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 30px 30px 0 0;
}

.tuile-bleu-img-content {
    padding: 50px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.tuile-bleu-img-titre h3 {
    margin: 0;
    font-size: 1.5rem;
}

.tuile-bleu-img-paragraphe p {
    margin: 0;
    font-size: 16px;
}

/* Mobile slider styles */
@media (max-width: 767px) {
    .tuiles-bleu-container {
        padding: 0;
        margin-bottom: 60px;
    }
    
    .tuiles-bleu-grid.slick-initialized {
        margin-left: 0;
        margin-right: 0;
    }
    
    .tuiles-bleu-grid.slick-initialized .col-12,
    .tuiles-bleu-grid.slick-initialized .col-md-4,
    .tuiles-bleu-grid.slick-initialized .col-sm-6,
    .tuiles-bleu-grid.slick-initialized .col-lg-3 {
        padding-left: 0;
        padding-right: 0;
    }
    
    .tuile-bleu {
        margin: 0 15px;
        height: 600px !important;
    }
    
    /* Cacher le compteur Slick */
    .tuiles-bleu-grid .slick-counter,
    .tuiles-bleu-grid .slick-slide-count {
        display: none !important;
    }
    
    /* Cacher les flèches */
    .tuiles-bleu-grid .slick-prev,
    .tuiles-bleu-grid .slick-next {
        display: none !important;
    }
    
    /* Slick dots - réutilisation des mêmes styles que tuiles-grid */
    .tuiles-bleu-grid .slick-dots {
        bottom: -45px;
        display: flex !important;
        justify-content: center;
        align-items: center;
        gap: 8px;
        padding: 0;
        margin: 0;
        list-style: none;
    }
    
    .tuiles-bleu-grid .slick-dots li {
        width: 8px;
        height: 8px;
        margin: 0;
        padding: 0;
        line-height: 0;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    
    .tuiles-bleu-grid .slick-dots li button {
        width: 8px;
        height: 8px;
        padding: 3px 3px!important;
        margin: 0;
        border: none;
        border-radius: 50%;
        background-color: #D1D5DB;
        font-size: 0;
        line-height: 0;
        cursor: pointer;
        transition: all 0.2s ease;
        overflow: hidden;
        text-indent: -9999px;
    }
    
    .tuiles-bleu-grid .slick-dots li button:before {
        display: none;
    }
    
    .tuiles-bleu-grid .slick-dots li button:hover {
        background-color: #9CA3AF;
    }
    
    .tuiles-bleu-grid .slick-dots li.slick-active button {
        background-color: #6B7280;
        padding: 5px 5px!important;
    }

    .menu-content {
        padding: 5px 30px;
    }
}

/* ----------------------------------------------------------------------------- */
/** Tuile Horizontale **/
/* ----------------------------------------------------------------------------- */

.tuile-horizontale {
    background-color: var(--primary_color_2);
    color: white;
    border-radius: 30px;
    overflow: hidden;
    display: flex;
    align-items: stretch;
    min-height: 400px;
}

.tuile-horizontale-image {
    width: 48%;
    flex-shrink: 0;
}

.tuile-horizontale-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.tuile-horizontale-content {
    width: 52%;
    padding: 60px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 20px;
}

/* Variante image à droite */
.tuile-horizontale-image-droite {
    flex-direction: row-reverse;
}

.tuile-horizontale-picto img {
    max-width: 80px;
    height: auto;
}

.tuile-horizontale-titre h3 {
    margin: 0;
    font-size: 2rem;
    font-weight: 700;
}

.tuile-horizontale-paragraphe p {
    margin: 0;
    font-size: 1.1rem;
    line-height: 1.6;
}

.tuile-horizontale-bouton .btn {
    display: inline-block;
    padding: 15px 40px;
    background-color: white;
    color: var(--primary_color_2);
    border-radius: 25px;
    text-decoration: none;
    font-weight: 600;
    transition: all 0.3s ease;
}

.tuile-horizontale-bouton .btn:hover {
    background-color: var(--primary_color_3);
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
}

/* Responsive */
@media (max-width: 992px) {
    .tuile-horizontale {
        flex-direction: column;
    }
    
    .tuile-horizontale-image-droite {
        flex-direction: column;
    }
    
    .tuile-horizontale-image {
        width: 100%;
        min-height: 300px;
    }
    
    .tuile-horizontale-content {
        width: 100%;
        padding: 40px;
    }

    .mt-991px {
        margin-top: 30px!important;
    }

    .center-991px {
        margin: auto !important;
    }
}

/* ----------------------------------------------------------------------------- */
/** Tuile Personne **/
/* ----------------------------------------------------------------------------- */

.tuile-personne {
    background-color: var(--primary_color_3);
    color: var(--primary_color_2);
    border-radius: 30px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
    margin-top: 30px;
}

.tuile-personne-image {
    width: 100%;
    background-color: white;
}

.tuile-personne-image img {
    width: 100%;
    height: auto;
    display: block;
}

.tuile-personne-content {
    padding: 30px;
    display: flex;
    flex-direction: column;
    gap: 15px;
    flex: 1;
}

.tuile-personne-lieu p {
    margin: 0;
    font-size: 0.9rem;
    text-transform: uppercase;
    font-weight: 600;
    opacity: 0.7;
}

.tuile-personne-nom h3 {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
}

.tuile-personne-email a,
.tuile-personne-phone a {
    color: var(--primary_color_2);
    font-size: 1rem;
    text-decoration: none;
    display: block;
}

.tuile-personne-email a:hover,
.tuile-personne-phone a:hover {
    color: var(--primary_color_1);
    text-decoration: underline;
}

/* ----------------------------------------------------------------------------- */
/** Tuile Commentaire **/
/* ----------------------------------------------------------------------------- */

.tuile-commentaire {
    background-color: var(--primary_color_3);
    color: var(--primary_color_2);
    border-radius: 30px;
    padding: 40px;
    display: flex;
    flex-direction: column;
    height: calc(100% - 30px);
    margin-bottom: 30px;
}

.tuile-commentaire-titre h3 {
    margin: 0 0 20px 0;
    font-size: 1.5rem;
    font-weight: 700;
    text-align: left;
}

.tuile-commentaire-paragraphe p {
    margin: 0;
    font-size: 1rem;
    line-height: 1.6;
    text-align: left;
}

.tuile-commentaire-auteur {
    text-align: right;
    margin-top: 16px;
}

.tuile-commentaire-auteur p {
    margin: 0;
    font-size: 1rem;
    color: var(--primary_color_4);
    opacity: 50%;
}

.pictoEnChiffres img {
    width: 35px!important;
}

/* ----------------------------------------------------------------------------- */
/** Standardisation des fonts pour tous les blocs tuile-* **/
/* ----------------------------------------------------------------------------- */

/* Tuiles bleues - h3 30px bold */
.tuile-image-text-vertical h3,
.tuile-horizontale h3,
.tuiles-bleu-grid .tuile-bleu h3 {
    font-size: 30px !important;
    font-weight: 700 !important;
}

/* Tuiles blanches/grises - h3 20px bold */
.tuile-image-text-vertical-white h3,
.tuile-commentaire h3,
.tuile-personne h3 {
    font-size: 20px !important;
    font-weight: 700 !important;
}

/* Tous les paragraphes dans tous les blocs tuile-* - 16px regular */
.tuile-image-text-vertical p,
.tuile-image-text-vertical-white p,
.tuile-horizontale p,
.tuile-commentaire p,
.tuile-personne p,
.tuiles-bleu-grid .tuile-bleu p {
    font-size: 16px !important;
    font-weight: 400 !important;
    text-align: justify !important;
}

.margin-top-30 {
    margin-top: 30px !important;
}

.margin-bottom-30 {
    margin-bottom: 30px !important;
}

.margin-top-40 {
    margin-top: 40px !important;
}

.margin-bottom-40 {
    margin-bottom: 40px !important;
}

figure {
    margin: 0!important;
}

.gform-theme--framework input[type]:where(:not(.gform-text-input-reset):not([type=hidden])):where(:not(.gform-theme__disable):not(.gform-theme__disable *):not(.gform-theme__disable-framework):not(.gform-theme__disable-framework *)) {
    box-shadow: none!important;
}

@media (max-width: 500px) {
    .wp-block-cover .wp-block-cover__inner-container p {
        font-size: 48px !important;
    }

    h2.wp-block-heading {
        font-size: 36px !important;
    }

    .wp-block-group.is-style-section-fond-bleu {
        padding: 20px 20px !important;
    }
}

.imgFullHeight img {
    width: 100% !important;
}

.is-style-section-fond-bleu p {
    text-align: justify;
}

.isNotJustifyAlignLeft {
    text-align: left !important;
}