.elementor-kit-8{--e-global-color-primary:#3335CB;--e-global-color-secondary:#FF802D;--e-global-color-text:#111111;--e-global-color-accent:#BE3CA5;--e-global-color-a86c0a1:#5B32C5;--e-global-color-6a4015c:#FFFFFF;--e-global-typography-primary-font-family:"Roboto";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Roboto Slab";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;}.elementor-kit-8 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1440px;}.e-con{--container-max-width:1440px;--container-default-padding-top:0px;--container-default-padding-right:0px;--container-default-padding-bottom:0px;--container-default-padding-left:0px;}.elementor-widget:not(:last-child){--kit-widget-spacing:0px;}.elementor-element{--widgets-spacing:0px 0px;--widgets-spacing-row:0px;--widgets-spacing-column:0px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS *//* ====================================
   Crush Pro - Variables CSS
   ==================================== */

:root {
    /* === Couleurs === */
    --primary: #3335CB;
    /* Bleu */
    --secondary: #FF802D;
    /* Orange */
    --accent: #BE3CA5;
    /* Fuchsia */
    --tertiary: #5B32C5;
    /* Violet */
    --white: #FFFFFF;
    --text: #111111;

    /* === Dégradés === */
    --gradient-1: linear-gradient(90deg, #FF802D 0%, #9E3CA6 50%, #5B32C6 100%);
    --gradient-2: linear-gradient(96.88deg, #FF802D -10.44%, #BE3CA5 50.5%, #5B32C5 88.67%);

    /* === Typographie === */
    /* Polices */
    --font-primary: 'Momo Trust Display', sans-serif;
    --font-secondary: 'Lato', sans-serif;

    /* Tailles de titres */
    --title-primary-size: 83px;
    --title-secondary-size: 52px;

    /* Propriétés titres */
    --title-line-height: 100%;
    --title-letter-spacing: 0.5px;
    --title-weight: 400;

    /* Propriétés paragraphes */
    --text-size: 20px;
    --text-line-height: 28px;
    --text-weight: 300;
    --text-letter-spacing: 0%;
}


/* ====================================
   Typographie - Classes utilitaires
   ==================================== */

.principal-title {
    font-family: var(--font-primary);
    font-weight: var(--title-weight);
    font-size: var(--title-primary-size);
    line-height: var(--title-line-height);
    letter-spacing: var(--title-letter-spacing);
}

.secondary-title {
    font-family: var(--font-primary);
    font-weight: var(--title-weight);
    font-size: var(--title-secondary-size);
    line-height: var(--title-line-height);
    letter-spacing: var(--title-letter-spacing);
}

body {
       font-family: var(--font-secondary), sans-serif !important;
}

p {
    font-family: var(--font-secondary);
    font-weight: var(--text-weight);
    font-size: var(--text-size);
    line-height: var(--text-line-height);
    letter-spacing: var(--text-letter-spacing);
}


main {
    min-height: calc(100vh - 350px);
}

/* ====== HEADER ====== */
header {
    .left-links span,
    .right-links span {
        font-family: 'Momo Trust Display', sans-serif !important;
        font-weight: 400;
        font-style: Regular;
        font-size: 16px;
        line-height: 100%;
        letter-spacing: 0.5px;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        position: relative;
        display: inline-block;
        cursor: pointer;
    }
    
    .left-links span:hover,
    .right-links span:hover {
        filter: brightness(0.7);
        letter-spacing: 1px;
        transform: translateY(-1px);
    }
    
    /* Effet underline animé */
    .left-links span::after,
    .right-links span::after {
        content: '';
        position: absolute;
        bottom: -4px;
        left: 50%;
        width: 0;
        height: 1px;
        background: currentColor;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        transform: translateX(-50%);
        filter: brightness(0.8);
    }
    
    .left-links span:hover::after,
    .right-links span:hover::after {
        width: 100%;
    }
}

.gradient-1 {
    background: var(--gradient-1);
}

.gradient-2 {
    background: var(--gradient-2);
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}


/* reset des margins de Editeur de texte widget */
p {
    margin: 0 !important;
}

/* Fin reset */

/* ===== Boutons ===== */

.btn-slide-down {
    display: flex;
    justify-content: center;
    align-items: center;
}

.btn-slide-down .elementor-button {
    width: 33px;
    height: 55px;
    border-radius: 22px !important;
    opacity: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    overflow: hidden;
    z-index: 1;
}

.btn-slide-down .elementor-button::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 0%;
    background: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 100 100'%3E%3Cpath fill='rgba(255,255,255,0.9)' d='M0 10q25-10 50 0t50 0v90H0Z'/%3E%3C/svg%3E") repeat-x,
        url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 100 100'%3E%3Cpath fill='rgba(255,255,255,0.8)' d='M0 12q25-7 50 0t50 0v88H0Z'/%3E%3C/svg%3E") repeat-x;
    background-position: 0 bottom, 0 bottom;
    background-size: 50px 100%, 75px 100%;
    border-radius: 22px;
    z-index: -1;
    transition: height 0.8s ease-in-out;
}

.btn-slide-down .elementor-button:hover::after {
    height: 120%;
}

.btn-slide-down .elementor-button svg {
    color: var(--secondary);
    animation: bounce-smooth 2s ease-in-out infinite;
    transition: transform 0.3s ease-in-out;
    position: relative;
    z-index: 2;
}

.btn-slide-down .elementor-button:hover svg {
    animation: none;
    transform: translateY(0);
}

@keyframes bounce-smooth {

    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-10px);
    }
}

/* Texte tronqué - VERSION GRID PURE pour les éléments NON "fonctionnement" */
[data-expand-id]:not([data-expand-id*="fonctionnement"]) {
    display: grid;
    grid-template-rows: 0.3fr;
    max-height: 2em;
    overflow: hidden;
    transition: grid-template-rows 0.4s ease, max-height 0.4s ease;
}

[data-expand-id]:not([data-expand-id*="fonctionnement"]) {
    display: grid;
    grid-template-rows: 0.3fr;
    max-height: 2em;
    overflow: hidden;
    transition: grid-template-rows 0.4s ease, max-height 0.4s ease;

    &>* {
        min-height: 0;
        overflow: hidden;
    }

    &>*:first-child {
        overflow: hidden;
        min-height: 33px;
    }
}

/* Expanded : tout visible */
[data-expand-id].expanded {
    grid-template-rows: 1fr;
    max-height: 300vh;

    &>* {
        overflow: visible;
    }
}

/* Conteneur .text-container avec transition (pour "fonctionnement") */
.text-container {
    display: grid;
    grid-template-rows: 0fr;
    opacity: 0;
    transition: grid-template-rows 0.4s ease, opacity 0.3s ease;
}

.text-container>* {
    overflow: hidden;
    min-height: 0;
}

.text-container.active {
    grid-template-rows: 1fr;
    opacity: 1;
}

/* Bouton et icône */
.btn-lire-container {
    width: fit-content;
    height: fit-content;
    cursor: pointer;
}

.btn-lire-container svg {
    transform: translateY(4px) translateX(1px) rotate(30deg);
    transition: transform 0.3s ease;
}

.btn-lire-container:hover:not(.expanded) svg {
    transform: translateY(4px) translateX(1px) rotate(30deg);
}

.btn-lire-container.expanded svg {
    transform: translateY(4px) translateX(1px) rotate(-30deg);
}

.btn-primary .elementor-button {
    font-family: 'Momo Trust Display', sans-serif;
    font-weight: 400;
    font-style: Regular;
    line-height: 100%;
    letter-spacing: 0.5px;
    text-align: center;
    background: var(--gradient-1) !important;
    color: var(--white);
    transition: background 0.3s ease;
}

/* Bouton en état "Réduire" */
.btn-lire-container.expanded .btn-primary .elementor-button {
    background: #FF802D !important;
}

/* ====== FIN BOUTON ======= */
/* Container custom avec paddings responsive */
#custom-container {
    padding-left: 12px;
    padding-right: 12px;
}

/* Tablette (< 1024px) */
@media (max-width: 1024px) {
    #custom-container {
        padding-left: 60px;
        padding-right: 60px;
    }
}

/* Mobile paysage (< 768px) */
@media (max-width: 768px) {
    #custom-container {
        padding-left: 32px;
        padding-right: 32px;
    }
}

/* Mobile portrait (< 480px) */
@media (max-width: 480px) {
    #custom-container {
        padding-left: 20px;
        padding-right: 20px;
    }
}



/* ===========> HOME */

/* Hero */

.hero-paragraphe {
    font-family: 'Lato', sans-serif;
    font-weight: 400;
    font-style: Regular;
    font-size: 24px;
    line-height: 100%;
    letter-spacing: 0.5px;
    text-align: center;
}


.trouver-le-pro-img img,
#trouver-le-pro img {
    user-select: none;
    -webkit-user-drag: none;
    -khtml-user-drag: none;
    -moz-user-drag: none;
    -o-user-drag: none;
    pointer-events: none;
}

/** TRICKS bouton trouver le job **/

/* Rendre le conteneur parent positionné pour l'absolute */
.elementor-element-eb2c507 {
    position: relative;
}

/* Cacher visuellement le bouton mais garder son lien accessible */
.elementor-element-eb2c507 .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

#trouver-le-pro {
    transform: translateX(-42%) !important;
}

/* Partie sur le slider */

.image-cover {
    position: absolute;
    top: 0;
    inset: 0 !important;
    left: 0;
    width: 100%;
    height: 100%;
}

.image-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: relative;


}

.slide-content-container {
    &::before {
        content: "";
        position: absolute;
        inset: 0;
        background: #000000;
        opacity: 0.5;
        z-index: -2;
    }
}

.elementor-swiper-button-prev {
    left: 40px !important;
    top: 50% !important;
    transform: translate(0px, -50%) !important;
}

.elementor-swiper-button-next {
    right: 40px !important;
    top: 50% !important;
    transform: translate(0px, -50%) !important;
    left: inherit !important;
}


.swiper-pagination-bullets {
    height: max-content;
    inset-inline-start: calc(50% + 0px) !important;
    top: calc(100% + -83px) !important;
    transform: translate(calc(50% * 1), -100%);
    width: max-content;
    z-index: 3;
}


.slider-title h2 {
    font-family: 'Momo Trust Display', sans-serif !important;
    font-weight: 400;
    font-style: Regular;
    font-size: 32px;
    line-height: 100%;
    letter-spacing: 0.5px;
    text-align: center;

}

/* Partie sur la FAQ */

/* Supprimer les bordures par défaut d'Elementor */
.elementor-widget-n-accordion {
    --n-accordion-border-width: 0px !important;
    --n-accordion-border-color: transparent !important;
}

.e-n-accordion-item {
    border: none !important;
}

/* Style du titre avec bordure gradient via pseudo-element */
.e-n-accordion-item-title {
    display: flex !important;
    width: 100%;
    justify-content: space-between !important;
    align-items: center;
    position: relative;
    border: none !important;
}

.e-n-accordion-item-title::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: var(--gradient-1);
}

.e-n-accordion-item-title-text {
    font-family: 'Lato', sans-serif !important;
    font-weight: 700;
    font-style: normal;
    font-size: 20px !important;
    line-height: 28px;
    letter-spacing: 0%;
}

.faq-answer {
    font-family: 'Lato', sans-serif !important;
    font-weight: 300;
    font-style: normal;
    font-size: 14px !important;
    line-height: 28px;
    letter-spacing: 0%;
    padding: 10px !important;
}

/* Fin FAQ */

/*==============> FIN HOME */



/* Container custom avec paddings responsive */
#custom-container {
    padding-left: 12px;
    padding-right: 12px;
}

/* Tablette (< 1024px) */
@media (max-width: 1024px) {
    #custom-container {
        padding-left: 60px;
        padding-right: 60px;
    }
}

/* Mobile paysage (< 768px) */
@media (max-width: 768px) {
    #custom-container {
        padding-left: 32px;
        padding-right: 32px;
    }
}

/* Mobile portrait (< 480px) */
@media (max-width: 480px) {
    #custom-container {
        padding-left: 20px;
        padding-right: 20px;
    }
}



/* ===========> HOME */

/* Hero */

.hero-paragraphe {
    font-family: 'Lato', sans-serif;
    font-weight: 400;
    font-style: Regular;
    font-size: 24px;
    line-height: 100%;
    letter-spacing: 0.5px;
    text-align: center;
}


.trouver-le-pro-img img,
#trouver-le-pro img {
    user-select: none;
    -webkit-user-drag: none;
    -khtml-user-drag: none;
    -moz-user-drag: none;
    -o-user-drag: none;
    pointer-events: none;
}

/** TRICKS bouton trouver le job **/

/* Rendre le conteneur parent positionné pour l'absolute */
.elementor-element-eb2c507 {
    position: relative;
}

/* Cacher visuellement le bouton mais garder son lien accessible */
.elementor-element-eb2c507 .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

#trouver-le-pro {
    transform: translateX(-42%) !important;
}

/* Partie sur le slider */

.image-cover {
    position: absolute;
    top: 0;
    inset: 0 !important;
    left: 0;
    width: 100%;
    height: 100%;
}

.image-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: relative;


}

.slide-content-container {
    &::before {
        content: "";
        position: absolute;
        inset: 0;
        background: #000000;
        opacity: 0.5;
        z-index: -2;
    }
}

.elementor-swiper-button-prev {
    left: 40px !important;
    top: 50% !important;
    transform: translate(0px, -50%) !important;
}

.elementor-swiper-button-next {
    right: 40px !important;
    top: 50% !important;
    transform: translate(0px, -50%) !important;
    left: inherit !important;
}

.swiper-pagination  {
    @media (width <= 1024px){
        transform: translateY(1rem) !important;
    }
}

.swiper-pagination-bullets {
    height: max-content;
    inset-inline-start: calc(50% + 0px) !important;
    top: calc(100% + -83px) !important;
    transform: translate(calc(50% * 1), -100%);
    width: max-content;
    z-index: 3;
}


.slider-title h2 {
    font-family: 'Momo Trust Display', sans-serif !important;
    font-weight: 400;
    font-style: Regular;
    font-size: 32px;
    line-height: 100%;
    letter-spacing: 0.5px;
    text-align: center;

}

/* Partie fonctionnement */

.fonctionnement-item-circle {
    background: linear-gradient(118.44deg, #ED8E37 -29.89%, #EC8C38 4.57%, #E9873F 17.27%, #E47E4B 26.34%, #DC725C 33.6%, #D36172 39.04%, #C84D8D 44.49%, #BE3CA5 48.11%, #AE3AA9 55.37%, #9037B3 68.07%, #7835BB 82.58%, #6833C0 98.91%, #5E32C3 115.24%, #5B32C5 137.01%);
    border-radius: 999px 999px 0 999px;
    transition: all .3s ease-in-out;

    h3 {
        font-family: 'Lato', sans-serif;
        font-weight: 700;
        font-style: Bold;
        font-size: 20px;
        line-height: 28px;
        letter-spacing: 0%;
        color: white;

    }

    .number span {
        font-family: 'Momo Trust Display', sans-serif !important;
        font-weight: 400 !important;
        font-size: 100px !important;
        line-height: 100% !important;
        letter-spacing: 0.5px !important;
        color: white;
    }
}

.fonctionnement-item-circle.active {
    background: var(--secondary) !important;
}

.text-container {
    display: grid;
    grid-template-rows: 0fr;
    opacity: 0;
    transition: grid-template-rows 0.4s ease, opacity 0.3s ease;
}

.text-container>* {
    overflow: hidden;
}

.text-container.active {
    grid-template-rows: 1fr;
    opacity: 1;
}


.item-fonctionnement-conteneur {
    width: 351px !important;
    height: 351px !important;
}


.h2-title h2 {
    font-family: 'Momo Trust Display';
    font-weight: 400;
    font-size: 32px;
    line-height: 100%;
    letter-spacing: 0.5px;
    text-align: center;

}

/* Partie sur les Categories */

.icon-cat {
    opacity: 0;
    transform: translate(50%, -50%) !important;
    transition: all .3s ease-in-out;
}

.icon-cat.active {
    opacity: 1;
}


/* Partie sur les avantages */


/*==============> FIN HOME *//* End custom CSS */