@charset "UTF-8";
/* Polices */
/* Tailles de texte */
/* Espacements */
/* Dimensions */
/* Couleurs */
/*dimension formulaire*/
/*Spécifique à card*/
/*spécifique à carrousel*/
/* Spécifique à input hauteur*/
/*Spécifique à section*/
/* Espacements */
/*Importation des polices d'écritures*/
/*pour les titres*/
@font-face {
    font-family: "BebasNeue";
    src: url("../../assets/fonts/font_h1/BebasNeue-Regular.ttf");
}

/*pour les moyens titres*/
@font-face {
    font-family: "Poppins";
    src: url("../../assets/fonts/font_h2_h3_p/Poppins-Black.ttf");
}

/*pour les textes*/
@font-face {
    font-family: "Poppins_texte";
    src: url("../../assets/fonts/font_h2_h3_p/Poppins-Light.ttf");
}

@font-face{
  font-family: "Material Symbols Outlined";
  src: url("../../assets/fonts/MaterialSymbolsOutlined[FILL,GRAD,opsz,wght].woff2") format("woff2");
  font-weight: 100 700;
  font-style: normal;
  font-display: swap;
}

.material-symbols-outlined{
  font-family: "Material Symbols Outlined";
  font-weight: 200;        /* adapte au besoin */
  font-style: normal;
  font-size: 24px;         /* taille par défaut */
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  direction: ltr;
  -webkit-font-smoothing: antialiased;
  font-variation-settings: "FILL" 0, "wght" 200, "GRAD" 0, "opsz" 24;
}

h1 {
    font-family: "Microsoft JhengHei UI", sans-serif;
    font-size: 3.7rem;
}

@media (max-width: 1024px) {
    h1 {
        font-size: 3rem;
    }
}

@media (max-width: 768px) {
    h1 {
        font-size: 2.2rem;
    }
}

h1 {
    margin-bottom: 44px;
}

@media (max-width: 1024px) {
    h1 {
        margin-bottom: 42px;
    }
}

@media (max-width: 768px) {
    h1 {
        margin-bottom: 40px;
    }
}

h2 {
    font-family: "Microsoft JhengHei UI", sans-serif;
    font-size: 2.5rem;
}

@media (max-width: 1024px) {
    h2 {
        font-size: 2rem;
    }
}

@media (max-width: 768px) {
    h2 {
        font-size: 1.5rem;
    }
}

h2 {
    margin-bottom: 20px;
}

@media (max-width: 1024px) {
    h2 {
        margin-bottom: 16px;
    }
}

@media (max-width: 768px) {
    h2 {
        margin-bottom: 12px;
    }
}

h3 {
    font-family: "Microsoft JhengHei UI", sans-serif;
    font-size: 2rem;
}

@media (max-width: 1024px) {
    h3 {
        font-size: 1.5rem;
    }
}

@media (max-width: 768px) {
    h3 {
        font-size: 1rem;
    }
}

h3 {
    margin-bottom: 16px;
}

@media (max-width: 1024px) {
    h3 {
        margin-bottom: 12px;
    }
}

@media (max-width: 768px) {
    h3 {
        margin-bottom: 10px;
    }
}

h4 {
    font-family: "Microsoft JhengHei UI", sans-serif;
    font-size: 1.5rem;
}

@media (max-width: 1024px) {
    h4 {
        font-size: 1.2rem;
    }
}

@media (max-width: 768px) {
    h4 {
        font-size: 0.9rem;
    }
}

h4 {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    h4 {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    h4 {
        margin-bottom: 8px;
    }
}

p, a, label, input, button, li, select, span {
    font-family: "Poppins_texte", sans-serif;
    font-size: 1.2rem;
}

@media (max-width: 1024px) {
    p, a, label, input, button, li, select, span {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    p, a, label, input, button, li, select, span {
        font-size: 0.95rem;
    }
}

ul {
    list-style: disc outside;
    padding-inline-start: 2.5rem;
}

ol {
    list-style: decimal outside;
    padding-inline-start: 2.5rem;
}

@media (max-width: 1024px) {
    ul, ol {
        padding-inline-start: 2.25rem;
    }
}

@media (max-width: 768px) {
    ul, ol {
        padding-inline-start: 2rem;
    }
}


table {
    font-family: "Poppins_texte", sans-serif;
    font-size: 0.8rem;
    border: unset !important;
}

@media (max-width: 1024px) {
    table {
        font-size: 0.7rem;
    }
}

@media (max-width: 768px) {
    table {
        font-size: 0.6rem;
    }
}

label {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    label {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    label {
        margin-bottom: 8px;
    }
}

input {
    margin-bottom: 16px;
}

@media (max-width: 1024px) {
    input {
        margin-bottom: 12px;
    }
}

@media (max-width: 768px) {
    input {
        margin-bottom: 10px;
    }
}

*, ::before, ::after {
    margin: 0;
    padding: 0;
    outline: none;
    box-sizing: border-box;
}

body {
    overflow-x: hidden;
}

select {
    cursor: pointer;
}

/* Table moderne, coins arrondis, ombre légère */
table {
    border-collapse: separate;
    border-spacing: 0;
    width: max-content; /* s’étend selon le contenu */
    min-width: 100%; /* mais occupe au moins la largeur dispo */
    max-width: 100%;
    background: #ffff;
    border-radius: 12px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, .05);
    overflow: auto; /* clippe les coins arrondis (support moderne) */
}

/* En-têtes */
thead th {
    background: #f8fafc;
    font-weight: 600;
}

/* Cellules */
th,
td {
    padding: 12px 14px;
    border-right: 1px solid #eaeef2;
    border-bottom: 1px solid #eaeef2;
    text-align: left;
    vertical-align: top;
    line-height: 1.45;
    word-break: break-word;
}

/* Retire les dernières bordures */
tr > *:last-child {
    border-right: 0;
}

tr:last-child > * {
    border-bottom: 0;
}

/* Zébrage + hover doux */
tbody tr:nth-child(odd) td {
    background: #fbfdff;
}

tbody tr:hover td {
    background: #f1f5f9;
}

/* Coins arrondis sûrs (au cas où overflow: hidden du tableau ne suffit pas) */
thead tr:first-child th:first-child {
    border-top-left-radius: 12px;
}

thead tr:first-child th:last-child {
    border-top-right-radius: 12px;
}

tbody tr:last-child td:first-child {
    border-bottom-left-radius: 12px;
}

tbody tr:last-child td:last-child {
    border-bottom-right-radius: 12px;
}

/* Légende éventuelle */
caption {
    caption-side: bottom;
    text-align: left;
    padding: 8px 10px;
    font-size: 0.95rem;
}

/* ===== Responsif ===== */
@media (max-width: 1024px) {
    th, td {
        padding: 10px 12px;
        font-size: 0.98rem;
    }
}

@media (max-width: 768px) {
    th, td {
        padding: 8px 10px;
        font-size: 0.95rem;
    }
}

section {
    padding: 100px 5%;
}

@media (max-width: 1024px) {
    section {
        padding: 70px 5%;
    }
}

@media (max-width: 768px) {
    section {
        padding: 50px 5%;
    }
}

.container {
    padding: 40px;
}

@media (max-width: 1024px) {
    .container {
        padding: 30px;
    }
}

@media (max-width: 768px) {
    .container {
        padding: 20px;
    }
}

.container__links {
    display: flex;
    flex-direction: column;
    gap: 35px;
}

@media (max-width: 1024px) {
    .container__links {
        gap: 32.5px;
    }
}

@media (max-width: 768px) {
    .container__links {
        gap: 30px;
    }
}

.container__links a {
    transition: color ease-in-out 0.2s;
    font-size: 1.5rem;
}

@media (max-width: 1024px) {
    .container__links a {
        font-size: 1.2rem;
    }
}

@media (max-width: 768px) {
    .container__links a {
        font-size: 0.9rem;
    }
}

/*.container__links a:hover {*/
/*    color: dodgerblue;*/
/*}*/

.content {
    max-width: 1280px;
    margin: 0 auto;
}

.content {
    padding: 150px 25px;
    /*padding-top: 150px;*/
}

@media (max-width: 1024px) {
    .content {
        padding: 125px 22.5px;
        /*padding-top: 125px;*/
    }
}

@media (max-width: 768px) {
    .content {
        padding: 100px 20px;
        /*padding-top: 100px;*/
    }
}

/* WebKit (Chrome, Safari, Edge) */
*::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

*::-webkit-scrollbar-track {
    background: transparent;
}

*::-webkit-scrollbar-thumb {
    background: linear-gradient(135deg, #4C4C4C, #A9CBB7);
    border-radius: 12px;
    transition: background 0.3s ease;
}

*:hover::-webkit-scrollbar-thumb {
    background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
}

/* Firefox */
* {
    scrollbar-width: thin;
}


.container_button {
    display: flex;
    align-items: center;
    justify-content: center;
}

.container_button_left {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.container_button_right {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.container_button button, .container_button a {
    display: flex;
    border: none;
    align-items: center;
    justify-content: center;
    color: #4C4C4C;
    border-radius: 50px;
    outline: none;
    cursor: pointer;
    font-weight: 700;
    /*text-transform: uppercase;*/
}

.container_button .login_btn {
    background-image: linear-gradient(120deg, #A9CBB7, #F7E1D7);
    color: white;
    transition: background-image 0.2s ease-in-out;
}

.container_button .login_btn:hover {
    background-image: linear-gradient(120deg, #87AC9B, #e3c4b7);
}

.container_button .signup_btn {
    background-image: linear-gradient(135deg, #F2C288, #EFCFD1);
    color: white;
    transition: background-image 0.2s ease-in-out;
}

.container_button .signup_btn:hover {
    background-image: linear-gradient(135deg, #d5a569, #d5b3b5);
}


.container_button button, .container_button a {
    padding: 15px;
}

@media (max-width: 1024px) {
    .container_button button, .container_button a {
        padding: 12px;
    }
}

@media (max-width: 768px) {
    .container_button button, .container_button a {
        padding: 10px;
    }
}

.container_button button, .container_button a {
    margin-top: 24px;
}

@media (max-width: 1024px) {
    .container_button button, .container_button a {
        margin-top: 22px;
    }
}

@media (max-width: 768px) {
    .container_button button, .container_button a {
        margin-top: 20px;
    }
}

.container_button button, .container_button a {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .container_button button, .container_button a {
        margin-bottom: 45px;
    }
}

@media (max-width: 768px) {
    .container_button button, .container_button a {
        margin-bottom: 40px;
    }
}


/* Articles styles*/
.articles {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    justify-items: center;
    gap: 40px;
}

@media (max-width: 1024px) {
    .articles {
        gap: 30px;
    }
}

@media (max-width: 768px) {
    .articles {
        gap: 20px;
    }
}

/*@media (max-width: 768px) {*/
/*    .articles {*/
/*        display: block;*/
/*    }*/
/*}*/

.articles__card {
    display: block;
    position: relative;
    overflow: hidden;
    border-radius: 15px;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
    height: 500px;
    flex-basis: 350px;
}

@media (max-width: 1024px) {
    .articles__card {
        height: 450px;
        flex-basis: 325px;
    }
}

@media (max-width: 768px) {
    .articles__card {
        height: 400px;
        flex-basis: 300px;
    }
}

@media (max-width: 768px) {
    .articles__card {
        max-width: 300px;
    }

    .articles__card {
        margin: 0 auto 0px auto;
    }
}

@media (max-width: 768px) and (max-width: 1024px) {
    .articles__card {
        margin: 0 auto 0px auto;
    }
}

@media (max-width: 768px) and (max-width: 768px) {
    .articles__card {
        margin: 0 auto 25px auto;
    }
}

.articles__card__action_links {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 10;
    display: flex;
    gap: 8px;
}

.articles__card__action_links a {
    background-color: white;
    border-radius: 50%;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    cursor: pointer;
    height: 40px;
    width: 40px;
}

.articles__card__categorie_container {
    position: absolute;
    top: 30%;
    right: 5px;
    z-index: 10;
    display: flex;
    gap: 8px;
}

.articles__card__categorie {
    font-weight: 700;
    border-radius: 50px;
    color: #FFFFFF;
    background-color: rgba(196, 196, 196, 0.42);
    font-size: 0.7rem;
}


@media (max-width: 1024px) {
    font-size: 0.6rem;
}

@media (max-width: 1024px) {
    font-size: 0.5rem;
}

.articles__card__categorie_container .articles__card__categorie {
    padding: 10px;
}

@media (max-width: 1024px) {
    .articles__card__categorie_container .articles__card__categorie {
        padding: 8px;
    }
}

@media (max-width: 768px) {
    .articles__card__categorie_container .articles__card__categorie {
        padding: 6px;
    }
}


@media (max-width: 1024px) {
    .articles__card__action_links a {
        height: 35px;
        width: 35px;
    }
}

@media (max-width: 768px) {
    .articles__card__action_links a {
        height: 30px;
        width: 30px;
    }
}

.articles__card__action_links a:hover {
    background-color: #f1f1f1;
}

.articles__card__action_links a span {
    color: black;
}

.articles__card__img-container {
    position: relative;
    height: 40%;
}

.articles__card__img-container img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

.articles__card__content {
    height: 60%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-self: stretch;
    gap: 15px;
}

@media (max-width: 1024px) {
    .articles__card__content {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .articles__card__content {
        gap: 10px;
    }
}

.articles__card__content {
    padding: 15px;
}

@media (max-width: 1024px) {
    .articles__card__content {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .articles__card__content {
        padding: 10px;
    }
}

.articles__card__content__text h3 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.articles__card__content__text p {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.articles__card__content_bottom {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

@media (max-width: 1024px) {
    gap: 12.5px;
}

@media (max-width: 768px) {
    gap: 10px;
}

.articles__card__content__date {
    color: grey;
    font-style: italic;
    font-weight: 400;
}

.articles__card__content__user {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
}

@media (max-width: 1024px) {
    .articles__card__content__user {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .articles__card__content__user {
        gap: 6px;
    }
}

.articles__card__content__user-icon {
    border-radius: 50%;
    overflow: hidden;
}

.articles__card__content__user-icon img {
    object-fit: cover;
}

/* Articles end styles */
/* Categories styles */
.categories {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 40px;
}

@media (max-width: 1024px) {
    .categories {
        gap: 30px;
    }
}

@media (max-width: 768px) {
    .categories {
        gap: 20px;
    }
}

@media (max-width: 768px) {
    .categories {
        display: block;
    }
}

.categories .category--card {
    position: relative;
    overflow: hidden;
    border-radius: 15px;
    height: 300px;
}

@media (max-width: 1024px) {
    .categories .category--card {
        height: 250px;
    }
}

@media (max-width: 768px) {
    .categories .category--card {
        height: 90px;
    }
}

@media (max-width: 768px) {
    .categories .category--card {
        max-width: 500px;
    }

    .categories .category--card {
        margin: 0 auto 0px auto;
    }
}

@media (max-width: 768px) and (max-width: 1024px) {
    .categories .category--card {
        margin: 0 auto 0px auto;
    }
}

@media (max-width: 768px) and (max-width: 768px) {
    .categories .category--card {
        margin: 0 auto 25px auto;
    }
}

.categories .category--card__action_links {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 13;
    display: flex;
    gap: 8px;
}

.categories .category--card__action_links a {
    background-color: white;
    border: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    cursor: pointer;
    height: 40px;
    width: 40px;
}

@media (max-width: 1024px) {
    .categories .category--card__action_links a {
        height: 35px;
        width: 35px;
    }
}

@media (max-width: 768px) {
    .categories .category--card__action_links a {
        height: 30px;
        width: 30px;
    }
}

.categories .category--card__action_links a:hover {
    background-color: #f1f1f1;
}

.categories .category--card__main {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
    text-decoration: none;
    color: inherit;
    border-radius: 15px;
}

@media (max-width: 768px) {
    .categories .category--card__main {
        max-width: 500px;
    }
}

.categories .category--card__image {
    position: absolute;
    inset: 0;
    z-index: 10;
}

.categories .category--card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.categories .category--card__image::after {
    content: "";
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.3);
    z-index: 11;
}

.categories .category--card__content {
    position: relative;
    z-index: 12;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    padding: 1rem;
    color: white;
    font-weight: bold;
    font-size: 1.5rem;
    text-align: center;
}

/* Categories end styles */

/*Style label start*/
label {
    font-weight: 700;
    letter-spacing: 1.5px;
    display: inline-block;
    color: #A9CBB7;
}

/*Style label end*/

input {
    color: #A9CBB7;
    display: block;
    outline: none;
    border: solid 1px #AAC8CE;
    border-radius: 50px;
    width: 100%;
}

input {
    padding: 15px;
}

@media (max-width: 1024px) {
    input {
        padding: 12px;
    }
}

@media (max-width: 768px) {
    input {
        padding: 10px;
    }
}

input {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    input {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    input {
        margin-bottom: 8px;
    }
}


.form-group {
    margin-bottom: 16px;
}

@media (max-width: 1024px) {
    .form-group {
        margin-bottom: 14px;
    }
}

@media (max-width: 768px) {
    .form-group {
        margin-bottom: 12px;
    }
}

/*Erreur pour formulaire*/
.text_error {
    color: #D16464;
}

.text_error {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .text_error {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .text_error {
        margin-bottom: 8px;
    }
}

select {
    display: block;
    outline: none;
    background-color: white;
    border: solid 1px #A9CBB7;
    border-radius: 15px;
    /*height: 45px;*/
    margin-bottom: 12px;
}

select option {
    text-align: center;
}

@media (max-width: 1024px) {
    select {
        /*height: 40px;*/
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    select {
        /*height: 35px;*/
        margin-bottom: 8px;
    }
}

select {
    padding: 15px;
}

@media (max-width: 1024px) {
    select {
        padding: 12px;
    }
}

@media (max-width: 768px) {
    select {
        padding: 10px;
    }
}

form {
    margin: 0 auto;
    max-width: 700px;
}

form {
    margin-top: 70px;
}

@media (max-width: 1024px) {
    form {
        margin-top: 60px;
    }
}

@media (max-width: 768px) {
    form {
        margin-top: 50px;
    }
}

@media (max-width: 1024px) {
    form {
        max-width: 450px;
    }
}

@media (max-width: 768px) {
    form {
        max-width: 300px;
    }
}

/* Formulaire côté dashboard Boutons styles */
.dashboard_form .container_button {
    gap: 35px;
}

.dashboard_form .container_button {
    margin-top: 24px;
}

@media (max-width: 1024px) {
    .dashboard_form .container_button {
        margin-top: 22px;
    }
}

@media (max-width: 768px) {
    .dashboard_form .container_button {
        margin-top: 20px;
    }
}

@media (max-width: 1024px) {
    .dashboard_form .container_button {
        gap: 32.5px;
    }
}

@media (max-width: 768px) {
    .dashboard_form .container_button {
        gap: 30px;
    }
}


.dashboard_form .container_button a {
    color: #FFFFFF;
    background-color: #D16464;
    transition: background-color 0.3s ease;
}

.dashboard_form .container_button a:hover {
    background-color: rgb(197.328358209, 60.671641791, 60.671641791);
}

.dashboard_form .container_button .submit-button {
    background-color: #7EBF8D;
    color: #FFFFFF;
    transition: background-color 0.3s ease;
}

.dashboard_form .container_button .cancel_button {
    color: #4C4C4C;
    background-color: #ececec;
    align-self: center;
    transition: background-color 0.3s ease;
    margin: unset;
}

.dashboard_form .container_button .submit-button:hover {
    background-color: rgb(91.9119170984, 174.0880829016, 110.8756476684);
}

/* Formulaire côté dashboard Boutons end styles */

/*Style a start*/

a {
    text-decoration: none;
    color: #4C4C4C;
    transition: 0.3s ease-in-out color;
}

.container__link-button {
    display: flex;
    justify-content: center;
    align-items: center;
}

.container__link-button a {
    border-radius: 50px;
    outline: none;
    color: #FFFFFF;
    background-color: #A9CBB7;
}

.container__link-button a {
    padding: 45px;
}

@media (max-width: 1024px) {
    .container__link-button a {
        padding: 42.5px;
    }
}

@media (max-width: 768px) {
    .container__link-button a {
        padding: 40px;
    }
}

.container__link_left {
    display: flex;
    justify-content: flex-start;
    align-items: center;
}

.container__link_right {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.link_login_style, .link_signup_style {
    border-radius: 15px;
    border: solid 1px #4C4C4C;
    color: #4C4C4C;
    font-weight: 700;
    display: flex;
    justify-content: space-around;
    align-items: center;
}

.link_login_style, .link_signup_style {
    padding: 15px;
}

@media (max-width: 1024px) {
    .link_login_style, .link_signup_style {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .link_login_style, .link_signup_style {
        padding: 10px;
    }
}

.link_login_style, .link_signup_style {
    margin-bottom: 15px;
}

@media (max-width: 1024px) {
    .link_login_style, .link_signup_style {
        margin-bottom: 12.5px;
    }
}

@media (max-width: 768px) {
    .link_login_style, .link_signup_style {
        margin-bottom: 10px;
    }
}

.link_create_article_style {
    border-radius: 15px;
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    color: #FFFFFF;
    font-weight: 700;
    display: flex;
    justify-content: space-around;
    align-items: center;
}

.link_create_article_style {
    padding: 15px;
}

@media (max-width: 1024px) {
    .link_create_article_style {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .link_create_article_style {
        padding: 10px;
    }
}

.link_create_article_style {
    margin-bottom: 15px;
}

@media (max-width: 1024px) {
    .link_create_article_style {
        margin-bottom: 12.5px;
    }
}

@media (max-width: 768px) {
    .link_create_article_style {
        margin-bottom: 10px;
    }
}

.link_create_categorie_style {
    border-radius: 15px;
    border: solid 2px unset;
    background: linear-gradient(135deg, #4C4C4C, #A9CBB7);
    color: white;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: space-around;
}

.link_create_categorie_style {
    padding: 15px;
}

@media (max-width: 1024px) {
    .link_create_categorie_style {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .link_create_categorie_style {
        padding: 10px;
    }
}

.link_create_categorie_style {
    margin-bottom: 15px;
}

@media (max-width: 1024px) {
    .link_create_categorie_style {
        margin-bottom: 12.5px;
    }
}

@media (max-width: 768px) {
    .link_create_categorie_style {
        margin-bottom: 10px;
    }
}

/*Style a end*/


/*Style navbar public start*/
/* Navbar Layout */
.container_navbar_public {
    position: fixed;
    top: 0;
    color: #4C4C4C;
    backdrop-filter: blur(5px);
    display: flex;
    align-items: center;
    z-index: 99;
    width: 100%;
    height: 85px;
}

.container_navbar_public {
    transition: transform 0.3s ease-in-out;
}

.container_navbar_public.navbar--hidden {
    transform: translateY(-100%);
}


.container_navbar_public {
    padding: 0 25px;
}

@media (max-width: 1024px) {
    .container_navbar_public {
        padding: 0 22.5px;
    }
}

@media (max-width: 768px) {
    .container_navbar_public {
        padding: 0 20px;
    }
}

@media (max-width: 1024px) {
    .container_navbar_public {
        width: 100%;
        height: 80px;
    }
}

@media (max-width: 768px) {
    .container_navbar_public {
        width: 100%;
        height: 75px;
    }
}

.container_navbar_public {
    margin-bottom: 100px;
}

@media (max-width: 1024px) {
    .container_navbar_public {
        margin-bottom: 75px;
    }
}

@media (max-width: 768px) {
    .container_navbar_public {
        margin-bottom: 50px;
    }
}

.navbar_public {
    flex-grow: 1;
    max-width: 1280px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.navbar_public__logo {
    display: flex;
    align-items: center;
}

.navbar_public__toggle {
    border: none;
    cursor: pointer;
    display: none;
    margin: unset;
    background-color: unset;
}

@media (max-width: 1024px) {
    .navbar_public__toggle {
        display: block;
    }
}

.navbar_public__links_desktop {
    display: flex;
    align-items: center;
    gap: 35px;
}

@media (max-width: 1024px) {
    .navbar_public__links_desktop {
        gap: 32.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public__links_desktop {
        gap: 30px;
    }
}

@media (max-width: 1024px) {
    .navbar_public__links_desktop {
        display: none;
    }
}

.navbar_public__links_desktop.navbar__links__single-page a {
    font-weight: 500;
    text-decoration: none;
    border-radius: 50px;
    transition: background-color 0.15s ease-in-out, color 0.15s ease-in-out;
    /* Lueur blanche légère */
    text-shadow: 0 0 2px rgba(255, 255, 255, 0.9),
    0 0 6px rgba(255, 255, 255, 0.6);
}

.navbar_public__links_desktop.navbar__links__single-page a {
    padding: 15px;
}

@media (max-width: 1024px) {
    .navbar_public__links_desktop.navbar__links__single-page a {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public__links_desktop.navbar__links__single-page a {
        padding: 10px;
    }
}

.navbar_public__links_desktop.navbar__links__single-page a:hover {
    color: #FFFFFF;
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    text-shadow: unset;
}

.navbar_public .navbar__links__contact a {
    color: #FFFFFF;
    background: linear-gradient(90deg, #ffb700, #ffd500);
    background-size: cover;
    font-weight: 700;
    border-radius: 50px;
    transition: background 0.2s ease-in-out, color 0.2s ease-in-out;
    display: flex;
    align-items: center;
    gap: 15px;
}

.navbar_public .navbar__links__contact a {
    padding: 15px;
}

@media (max-width: 1024px) {
    .navbar_public .navbar__links__contact a {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public .navbar__links__contact a {
        padding: 10px;
    }
}

@media (max-width: 1024px) {
    .navbar_public .navbar__links__contact a {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public .navbar__links__contact a {
        gap: 10px;
    }
}

.navbar_public .navbar__links__contact a:hover, .navbar_public .navbar__links__contact a:focus {
    background: #FFFFFF;
    color: #ffb700;
}

.navbar_public__links_general_side_nav {
    display: none;
}

@media (max-width: 1024px) {
    .navbar_public__links_general_side_nav {
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        align-items: flex-start;
        position: absolute;
        background-color: #FFFFFF;
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
        transition: right 0.3s cubic-bezier(0.77, 0, 0.18, 1);
        z-index: 99;
        right: -400px;
        width: 400px;
        top: 85px;
        height: calc(100vh - 85px);
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .navbar_public__links_general_side_nav {
        right: -250px;
        width: 250px;
        top: 80px;
        height: calc(100vh - 80px);
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .navbar_public__links_general_side_nav {
        right: -300px;
        width: 300px;
        top: 75px;
        height: calc(100vh - 75px);
    }
}

@media (max-width: 1024px) {
    .navbar_public__links_general_side_nav {
        padding: 25px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .navbar_public__links_general_side_nav {
        padding: 22.5px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .navbar_public__links_general_side_nav {
        padding: 20px;
    }
}

@media (max-width: 1024px) {
    .navbar_public__links_general_side_nav.active {
        right: 0;
    }
}

.navbar_public__links_general_side_nav .navbar_public__links {
    display: flex;
    flex-direction: column;
    align-self: stretch;
    align-items: flex-start;
}

.navbar_public__links_general_side_nav .navbar_public__links a {
    background: none;
    text-decoration: none;
    font-weight: 500;
    border-radius: 50px;
    transition: background-color 0.15s ease-in-out, color 0.15s ease-in-out;
}

.navbar_public__links_general_side_nav .navbar_public__links a:focus, .navbar_public__links_general_side_nav .navbar_public__links a:hover {
    color: #FFFFFF;
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
}

.navbar_public__links_general_side_nav .navbar_public__links a {
    padding: 15px;
}

@media (max-width: 1024px) {
    .navbar_public__links_general_side_nav .navbar_public__links a {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public__links_general_side_nav .navbar_public__links a {
        padding: 10px;
    }
}

.navbar_public__links_general_side_nav .navbar_public__links a {
    margin-bottom: 15px;
}

@media (max-width: 1024px) {
    .navbar_public__links_general_side_nav .navbar_public__links a {
        margin-bottom: 12.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public__links_general_side_nav .navbar_public__links a {
        margin-bottom: 10px;
    }
}

@media (max-width: 1024px) {
    .navbar_public__links_general_side_nav .navbar_public__links a {
        border: none;
    }
}

.navbar_public__links_general_side_nav .navbar__links__contact {
    align-self: center;
}

.navbar_public__links_general_side_nav .navbar__links__contact a {
    color: #FFFFFF;
    border: solid 2px #FFFFFF;
    background: linear-gradient(90deg, #ffcb49, #ffe356);
    background-size: cover;
    font-weight: 700;
    border-radius: 50px;
    transition: background 0.2s ease-in-out, color 0.2s ease-in-out;
    display: flex;
    align-items: center;
    gap: 15px;
}

.navbar_public__links_general_side_nav .navbar__links__contact a {
    padding: 15px;
}

@media (max-width: 1024px) {
    .navbar_public__links_general_side_nav .navbar__links__contact a {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public__links_general_side_nav .navbar__links__contact a {
        padding: 10px;
    }
}

@media (max-width: 1024px) {
    .navbar_public__links_general_side_nav .navbar__links__contact a {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public__links_general_side_nav .navbar__links__contact a {
        gap: 10px;
    }
}

.navbar_public__links_general_side_nav .navbar__links__contact a:hover, .navbar_public__links_general_side_nav .navbar__links__contact a:focus {
    align-self: stretch;
    border: solid 2px #ffcb49;
    background: #FFFFFF;
    color: #ffcb49;
}

.navbar_public .menu-item {
    /* new start */
    position: relative;
}

.navbar_public .submenu-toggle {
    background: none;
    border: 0;
    cursor: pointer;
    border-radius: 50px;
    font-weight: 500;
    align-items: stretch;
    color: #4C4C4C;
    display: flex;
    gap: 15px;
    transition: background-color 0.15s ease-in-out, color 0.15s ease-in-out;
    text-shadow: 0 0 2px rgba(255, 255, 255, 0.9),
    0 0 6px rgba(255, 255, 255, 0.6);
}

@media (max-width: 1024px) {
    .navbar_public .submenu-toggle {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public .submenu-toggle {
        gap: 10px;
    }
}

.navbar_public .submenu-toggle {
    padding: 15px;
}

@media (max-width: 1024px) {
    .navbar_public .submenu-toggle {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public .submenu-toggle {
        padding: 10px;
    }
}

.navbar_public .submenu-toggle:hover, .navbar_public .submenu-toggle:focus {
    color: #FFFFFF;
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    text-shadow: unset;
}

.navbar_public .submenu-toggle .material-symbols-outlined {
    transition: transform 0.2s ease;
}

.navbar_public .submenu-toggle.is-open .material-symbols-outlined {
    transform: rotate(180deg);
}

.navbar_public .navbar_public__links_desktop .submenu-links {
    position: absolute;
    left: 0;
    top: 150%;
    min-width: 100%;
    background-color: #FFFFFF;
    border-radius: 50px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
    z-index: 100;
    /* Animation “fade & slide” sans dimensions absolues */
    opacity: 0;
    visibility: hidden;
    transform: translateY(6px);
    transition: opacity 0.15s ease, transform 0.15s ease, visibility 0s 0.15s;
    gap: 35px;
}

@media (max-width: 1024px) {
    .navbar_public .navbar_public__links_desktop .submenu-links {
        gap: 32.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public .navbar_public__links_desktop .submenu-links {
        gap: 30px;
    }
}

.navbar_public .navbar_public__links_desktop .submenu-links {
    padding: 25px;
}

@media (max-width: 1024px) {
    .navbar_public .navbar_public__links_desktop .submenu-links {
        padding: 22.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public .navbar_public__links_desktop .submenu-links {
        padding: 20px;
    }
}

.navbar_public .navbar_public__links_desktop .submenu-links.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    transition: opacity 0.15s ease, transform 0.15s ease;
}

.navbar_public .navbar_public__links_desktop .submenu-links a {
    display: block;
    white-space: nowrap;
    text-decoration: none;
    border-radius: 50px;
    transition: background-color 0.15s ease-in-out, color 0.15s ease-in-out;
}

.navbar_public .navbar_public__links_desktop .submenu-links a {
    padding: 15px;
}

@media (max-width: 1024px) {
    .navbar_public .navbar_public__links_desktop .submenu-links a {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .navbar_public .navbar_public__links_desktop .submenu-links a {
        padding: 10px;
    }
}

.navbar_public .navbar_public__links_desktop .submenu-links a:hover, .navbar_public .navbar_public__links_desktop .submenu-links a:focus {
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
    -webkit-text-fill-color: transparent;
}

@media (max-width: 1024px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-toggle {
        margin-bottom: 15px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-toggle {
        margin-bottom: 12.5px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-toggle {
        margin-bottom: 10px;
    }
}

@media (max-width: 1024px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-toggle:hover, .navbar_public .navbar_public__links_general_side_nav .submenu-toggle:focus {
        color: #FFFFFF;
        background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    }

    .navbar_public .navbar_public__links_general_side_nav .submenu-links {
        position: static;
        box-shadow: none;
        border-radius: 0;
        /* On utilise display pour un expand simple et fiable en mobile */
        display: none;
        margin-left: 0;
    }

    .navbar_public .navbar_public__links_general_side_nav .submenu-links {
        margin-bottom: 15px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-links {
        margin-bottom: 12.5px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-links {
        margin-bottom: 10px;
    }
}

@media (max-width: 1024px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-links {
        padding: 0 15px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-links {
        padding: 0 12.5px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-links {
        padding: 0 10px;
    }
}

@media (max-width: 1024px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-links.active {
        display: flex;
        flex-direction: column;
        gap: 10px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-links.active {
        gap: 8px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-links.active {
        gap: 6px;
    }
}

@media (max-width: 1024px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-links a {
        margin-bottom: unset;
        border-radius: 8px;
    }

    .navbar_public .navbar_public__links_general_side_nav .submenu-links a {
        padding: 15px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-links a {
        padding: 12.5px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-links a {
        padding: 10px;
    }
}

@media (max-width: 1024px) {
    .navbar_public .navbar_public__links_general_side_nav .submenu-links a:hover, .navbar_public .navbar_public__links_general_side_nav .submenu-links a:focus {
        background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
        background-clip: text;
        -webkit-background-clip: text;
        color: transparent;
        text-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
        -webkit-text-fill-color: transparent;
    }
}

/* Menu Icons */
#menu-icon.active {
    display: none;
}

#close-icon {
    display: none;
}

#close-icon.active {
    display: inline;
}

/*Style navbar public end*/

/*Style navbar-dashboard start*/
html, body {
    height: 100%;
    /*overflow: hidden;*/
}

.user_container {
    position: absolute;
    top: 0;
    z-index: 98;
    width: 100%;
    background-color: #FAFAF9;
    transition: transform 0.3s ease-in-out;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.user_container {
    padding: 25px;
}

@media (max-width: 1024px) {
    .user_container {
        padding: 22.5px;
    }
}

@media (max-width: 768px) {
    .user_container {
        padding: 20px;
    }
}

.user_container.user_container--hidden {
    transform: translateY(-100%);
}

.user_container .user_presentation {
    display: flex;
    align-items: center;
    gap: 35px;
}

.user_container .user_presentation .icon {
    border-radius: 50%;
    overflow: hidden;
}

@media (max-width: 1024px) {
    .user_container .user_presentation {
        gap: 30px;
    }
}

@media (max-width: 768px) {
    .user_container .user_presentation {
        gap: 25px;
    }
}

.user_container .user_presentation .full-name_container {
    font-weight: 700;
}

.main-container-dashboard {
    display: flex;
    height: 100vh;
    overflow: hidden;
    position: relative;
}

/* Navbar à gauche */

.navbar_dashboard {
    position: relative;
    z-index: 99;
    flex-shrink: 0;
    height: 100vh;
    overflow-y: auto;
    overflow-x: hidden;
    background-color: #FAFAF9;
    transition: width 0.3s ease;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    align-self: stretch;
    gap: 75px;
}

@media (max-width: 1024px) {
    gap: 65px;
}

@media (max-width: 768px) {
    gap: 55px;
}


.navbar_dashboard--expanded {
    width: 300px;
}

@media (max-width: 1024px) {
    .navbar_dashboard--expanded {
        width: 200px;
    }
}

@media (max-width: 768px) {
    .navbar_dashboard--expanded {
        width: 180px;
    }
}

/*!* Pour empêcher toute transition au chargement initial*!*/
/*.navbar_dashboard.no-transition {*/
/*    transition: none !important;*/
/*}*/


.navbar_dashboard--hidden {
    display: none;
}

.navbar_dashboard {
    padding: 25px;
}

@media (max-width: 1024px) {
    .navbar_dashboard {
        padding: 22.5px;
    }
}

@media (max-width: 768px) {
    .navbar_dashboard {
        padding: 20px;
    }
}

/* Navbar repliée */
.navbar_dashboard.collapsed {
    /*transition: unset;*/
    width: 80px;
}

.navbar_dashboard.collapsed .navbar_dashboard__label {
    /*transition: unset;*/
    display: none;
}

.navbar_dashboard.collapsed .navbar_dashboard__links a,
.navbar_dashboard.collapsed .navbar_dashboard__form-logout button {
    justify-content: center;
}

.navbar_dashboard.collapsed .navbar_dashboard__links {
    align-items: center;
}

@media (max-width: 1024px) {
    .navbar_dashboard.collapsed {
        width: 70px;
    }
}

@media (max-width: 768px) {
    .navbar_dashboard.collapsed {
        width: 60px;
    }
}

/* En cas de navbar repliée */
.navbar_dashboard.collapsed ~ .navbar_dashboard__trigger {
    top: 70px;
    left: calc(80px - 40px / 2);
}

@media (max-width: 1024px) {
    .navbar_dashboard.collapsed ~ .navbar_dashboard__trigger {
        top: 60px;
        left: calc(70px - 35px / 2);
    }
}

@media (max-width: 768px) {
    .navbar_dashboard.collapsed ~ .navbar_dashboard__trigger {
        top: 50px;
        left: calc(60px - 30px / 2);
    }
}

/* Trigger */
.navbar_dashboard__trigger {
    position: fixed;
    background-color: #FFFFFF;
    color: #4C4C4C;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: width 0.3s ease, left 0.3s ease;
    box-shadow: 0 0 6px rgba(0, 0, 0, 0.1);
    z-index: 99;
    height: 40px;
    width: 40px;
}

@media (max-width: 1024px) {
    .navbar_dashboard__trigger {
        height: 35px;
        width: 35px;
    }
}

@media (max-width: 768px) {
    .navbar_dashboard__trigger {
        height: 30px;
        width: 30px;
    }
}

.navbar_dashboard__trigger {
    top: 70px;
    left: calc(300px - 40px / 2);
}

@media (max-width: 1024px) {
    .navbar_dashboard__trigger {
        top: 60px;
        left: calc(200px - 35px / 2);
    }
}

@media (max-width: 768px) {
    .navbar_dashboard__trigger {
        top: 50px;
        left: calc(180px - 30px / 2);
    }
}

/* Contenu principal */
.content_dashboard {
    flex-grow: 1;
    background-color: #FFFFFF;
    overflow-y: auto;
    transition: margin-left 0.3s ease;
}

/*.content_dashboard {*/
/*    padding: 100px;*/
/*}*/

/*@media (max-width: 1024px) {*/
/*    .content_dashboard {*/
/*        padding: 70px;*/
/*    }*/
/*}*/

/*@media (max-width: 768px) {*/
/*    .content_dashboard {*/
/*        padding: 50px;*/
/*    }*/
/*}*/

/* Links navbar */
.navbar_dashboard__links {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    align-self: stretch;
    gap: 35px;
}

.navbar_dashboard__links a {
    display: flex;
    align-items: center;
    gap: 15px;
}

.navbar_dashboard__links a:hover {
    color: #7f7f7f;
}

@media (max-width: 1024px) {
    .navbar_dashboard__links a {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .navbar_dashboard__links a {
        gap: 10px;
    }
}

@media (max-width: 1024px) {
    .navbar_dashboard__links {
        gap: 32.5px;
    }
}

@media (max-width: 768px) {
    .navbar_dashboard__links {
        gap: 30px;
    }
}

.navbar_dashboard__form-logout {
    margin: unset;
}

.navbar_dashboard__form-logout button {
  color: #fff;
  border: 1px solid #FAFAF9;
  background: linear-gradient(135deg, #E57373, #F28B82);
  transition: all 0.3s ease;
}

.navbar_dashboard__form-logout button:hover {
  border: 1px solid #F28B82;
  background: #FAFAF9;
  color: #E57373; // rouge doux au hover
}


/*Notification*/
/* On encapsule l’icône pour ancrer le badge */
.nav-icon-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

/* Le badge n’influence pas le flux (absolute) */
.nav-badge {
  position: absolute;
  left: -6px;        /* ← “à gauche” de l’icône */
  top: -6px;         /* léger décalage vers le haut */
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: 50px;
  background: #ff4040;
  color: #FFFFFF;
  font-size: 11px;
  font-weight: 700;
  line-height: 18px;
  text-align: center;
  pointer-events: none;     /* clics non interceptés */
}

/* Optionnel : si la navbar est très petite, on rapproche un peu */
.navbar_dashboard.collapsed .nav-badge {
  left: -4px;
  top: -4px;
}

/*Style navbar-dashboard end*/


/*Style Breadcrumb start*/
.breadcrumb {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

@media (max-width: 1024px) {
    .breadcrumb {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .breadcrumb {
        gap: 6px;
    }
}

.breadcrumb {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .breadcrumb {
        margin-bottom: 45px;
    }
}

@media (max-width: 768px) {
    .breadcrumb {
        margin-bottom: 40px;
    }
}

.container__links .breadcrumb__link, .container__links .breadcrumb__item {
    white-space: nowrap;
}

.container__links .breadcrumb__link {
    display: flex;
    justify-content: center;
    align-items: center;
    color: #DADADA;
    transition: color 0.2s ease-in-out;
    font-size: 1.2rem;
}

.container__links .breadcrumb__link:hover {
    color: #7EBF8D;
}

@media (max-width: 1024px) {
    .container__links .breadcrumb__link {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .container__links .breadcrumb__link {
        font-size: 0.95rem;
    }
}

.breadcrumb__separator, .breadcrumb__item {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #4C4C4C;
}

/*Style Breadcrumb start*/

/*Style dropzone start*/
.dropzone-container {
    border: 2px dashed #AAC8CE;
    border-radius: 15px;
    text-align: center;
    position: relative;
    width: 100%;
    max-width: 700px;
    margin-bottom: 20px;
    transition: border-color 0.3s;
    background-color: #FAFAF9;
}

.dropzone-container {
    padding: 40px;
}

@media (max-width: 1024px) {
    .dropzone-container {
        padding: 30px;
    }
}

@media (max-width: 768px) {
    .dropzone-container {
        padding: 20px;
    }
}

.dropzone-container.dragover {
    border-color: #A9CBB7;
    background-color: rgba(169, 203, 183, 0.25);
}

.dropzone-label {
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
    font-size: 1.5rem;
    gap: 20px;
}

@media (max-width: 1024px) {
    .dropzone-label {
        font-size: 1.2rem;
    }
}

@media (max-width: 768px) {
    .dropzone-label {
        font-size: 0.9rem;
    }
}

@media (max-width: 1024px) {
    .dropzone-label {
        gap: 15px;
    }
}

@media (max-width: 768px) {
    .dropzone-label {
        gap: 10px;
    }
}

.upload-button {
    border-color: #A9CBB7;
    background-color: #A9CBB7;
    color: #FFFFFF;
    border-radius: 15px;
    text-align: center;
    transition: background-color 0.3s;
}

.upload-button:hover {
    opacity: 0.8;
}

.upload-button {
    padding: 15px;
}

@media (max-width: 1024px) {
    .upload-button {
        padding: 12px;
    }
}

@media (max-width: 768px) {
    .upload-button {
        padding: 10px;
    }
}

.preview-image {
    border-radius: 50%;
    object-fit: cover;
    width: 200px;
    height: 200px;
    margin-left: auto;
    margin-right: auto;
    display: block;
}

.preview-image {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .preview-image {
        margin-bottom: 10px;
        width: 175px;
        height: 175px;
    }
}

@media (max-width: 768px) {
    .preview-image {
        margin-bottom: 8px;
        width: 150px;
        height: 150px;
    }
}

.preview-image--rect {
    border-radius: 15px;
    object-fit: cover;
    display: block;
    width: 100%;
    height: auto;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
    max-width: 450px;
}

@media (max-width: 1024px) {
    .preview-image--rect {
        max-width: 400px;
    }
}

@media (max-width: 768px) {
    .preview-image--rect {
        max-width: 350px;
    }
}

.hidden-input {
    display: none;
}

.hidden-input-modal {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    opacity: 0;
}

/*Style dropzone end*/
/*Style modale start*/
.modale_container {
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100%;
    background-color: rgba(76, 76, 76, 0.18);
    z-index: 100;
    overflow-y: auto;
}

.modale_container__window {
    border-radius: 15px;
    background-color: #FFFFFF;
    max-width: 700px;
    margin-top: 30px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 30px;
}

@media (max-width: 1024px) {
    .modale_container__window {
        margin-top: 25px;
        margin-bottom: 25px;
    }
}

@media (max-width: 768px) {
    .modale_container__window {
        margin-top: 20px;
        margin-bottom: 20px;
    }
}

.modale_container__window, .modale_container {
    padding: 40px;
}

@media (max-width: 1024px) {
    .modale_container__window, .modale_container {
        padding: 30px;
    }
}

@media (max-width: 768px) {
    .modale_container__window, .modale_container {
        padding: 20px;
    }
}

.modale_container__window_cross {
    background-color: transparent;
    color: #DADADA;
    border: none;
    cursor: pointer;
}

.modale_container__window_cross {
    margin-bottom: 30px;
}

@media (max-width: 1024px) {
    .modale_container__window_cross {
        margin-bottom: 28.5px;
    }
}

@media (max-width: 768px) {
    .modale_container__window_cross {
        margin-bottom: 26px;
    }
}

.modale_container .btn--danger, .modale_container button {
    margin: unset;
}

.modale_container .btn--danger {
    border-radius: 50px;
    background-color: #D16464;
    color: #FFFFFF;
}

.modale_container .btn--danger:hover {
    background-color: rgb(197.328358209, 60.671641791, 60.671641791);
}

.modale_container.unactive {
    display: none;
}

/*Style modale end*/
/*Style message start*/

.messages_container {
    position: fixed;
    color: #FFFFFF;
    z-index: 105;
    width: 100%;
}

/* Classe pour masquer le messages_container */
.messages_container--hidden {
    display: none;
}

.messages_container .message {
    position: relative;
    display: flex;
    align-items: center;
    border-radius: 15px;
    transform: translateX(-150%);
    opacity: 0;
    transition: transform 0.4s ease, opacity 0.4s ease;
    gap: 30px;
    max-width: 400px;
}

.messages_container .message.visible {
    transform: translateX(0);
    opacity: 1;
}

.messages_container .message.hide {
    transform: translateX(-150%);
    opacity: 0;
}

.messages_container .message .close-btn {
    background-color: transparent;
    border: unset;
    outline: none;
    cursor: pointer;
}

@media (max-width: 1024px) {
    .messages_container .message {
        gap: 25px;
    }
}

@media (max-width: 768px) {
    .messages_container .message {
        gap: 20px;
    }
}

@media (max-width: 1024px) {
    .messages_container .message {
        max-width: 350px;
    }
}

@media (max-width: 768px) {
    .messages_container .message {
        max-width: 300px;
    }
}

.messages_container .message {
    padding: 20px;
}

@media (max-width: 1024px) {
    .messages_container .message {
        padding: 17.5px;
    }
}

@media (max-width: 768px) {
    .messages_container .message {
        padding: 15px;
    }
}

.messages_container {
    padding: 20px;
}

@media (max-width: 1024px) {
    .messages_container {
        padding: 17.5px;
    }
}

@media (max-width: 768px) {
    .messages_container {
        padding: 15px;
    }
}

.messages_container {
    top: 85px;
}

@media (max-width: 1024px) {
    .messages_container {
        top: 80px;
    }
}

@media (max-width: 768px) {
    .messages_container {
        top: 75px;
    }
}

.carrousel_wrapper {
    position: relative;
    /*Masquer la barre de défilement Pour chrome, Edge, et Safari*/
    /*Customisable*/
    /*Navigation carrousel*/
}

.carrousel_wrapper .carrousel_track {
    display: flex;
    flex-shrink: 0;
    flex-wrap: nowrap;
    max-width: 1400px;
    scroll-behavior: smooth;
    overflow-x: auto;
    scrollbar-width: none; /*Masquer la barre pour firefox*/
    scroll-snap-type: x mandatory;
    scroll-padding-left: 0;
    gap: 50px;
}

@media (max-width: 1024px) {
    .carrousel_wrapper .carrousel_track {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .carrousel_wrapper .carrousel_track {
        gap: 25px;
    }
}

.carrousel_wrapper .carrousel_track::-webkit-scrollbar {
    display: none;
}

.carrousel_wrapper .carrousel_item {
    scroll-snap-align: start;
    flex: 0 0 100%;
}

.carrousel_wrapper .carrousel_dots {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
}

.carrousel_wrapper .carrousel_dots .dot {
    border-radius: 50%;
    background-color: #FFFFFF;
    cursor: pointer;
    opacity: 0.5;
    transition: transform 0.3s ease, opacity 0.3s ease;
    height: 12px;
    width: 12px;
}

@media (max-width: 1024px) {
    .carrousel_wrapper .carrousel_dots .dot {
        height: 10px;
        width: 10px;
    }
}

@media (max-width: 768px) {
    .carrousel_wrapper .carrousel_dots .dot {
        height: 8px;
        width: 8px;
    }
}

.carrousel_wrapper .carrousel_dots .dot_active {
    transform: scale(1.5);
    opacity: 1;
}

.logo {
    height: 80px;
    width: 80px;
}

@media (max-width: 1024px) {
    .logo {
        height: 50px;
        width: 50px;
    }
}

@media (max-width: 768px) {
    .logo {
        height: 40px;
        width: 40px;
    }
}

.logo img {
    object-fit: contain;
    width: 100%;
    height: 100%;
}

.icon {
    height: 40px;
    width: 40px;
}

@media (max-width: 1024px) {
    .icon {
        height: 35px;
        width: 35px;
    }
}

@media (max-width: 768px) {
    .icon {
        height: 30px;
        width: 30px;
    }
}

.icon img {
    object-fit: contain;
    width: 100%;
    height: 100%;
}

.icon .icon__user_pp {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

/*Propre aux icones de Google*/
.material-symbols-outlined {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
}

@media (max-width: 1024px) {
    .material-symbols-outlined {
        font-size: 26px;
    }
}

@media (max-width: 768px) {
    .material-symbols-outlined {
        font-size: 24px;
    }
}

.arrow-icon {
    transition: transform ease-in-out 0.3s;
}

.arrow-icon.active {
    transform: rotateZ(90deg);
}

/*Search input style*/
.search-container {
    position: relative;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.search-container {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .search-container {
        margin-bottom: 50px;
    }
}

@media (max-width: 768px) {
    .search-container {
        margin-bottom: 50px;
    }
}

@media (max-width: 768px) {
    .search-container {
        display: block;
    }
}

.search-input {
    position: relative;
    display: flex;
    align-items: center;
    background-color: #FAFAF9;
    box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
    border-radius: 50px;
    font-size: 1.2rem;
    flex-basis: 450px;
    /* Nouveau style pour les filtres */
}

@media (max-width: 1024px) {
    .search-input {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .search-input {
        font-size: 0.95rem;
    }
}

.search-input {
    padding: 7px;
}

@media (max-width: 1024px) {
    .search-input {
        padding: 6px;
    }
}

@media (max-width: 768px) {
    .search-input {
        padding: 5px;
    }
}

@media (max-width: 1024px) {
    .search-input {
        flex-basis: 445px;
    }
}

@media (max-width: 768px) {
    .search-input {
        flex-basis: 440px;
    }
}

@media (max-width: 768px) {
    .search-input {
        max-width: 100%;
    }
}

.search-input__filter {
    border: none;
    background: transparent;
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 60px;
    width: 60px;
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .search-input__filter {
        height: 52.5px;
        width: 52.5px;
    }
}

@media (max-width: 768px) {
    .search-input__filter {
        height: 45px;
        width: 45px;
    }
}

.search-input__filter:hover {
    opacity: 0.8;
}

.search-input__form {
    margin: unset;
    max-width: unset;
    display: flex;
    justify-content: space-between;
    align-items: center;
    align-self: stretch;
    flex-grow: 1;
    font-size: 28px;
}

@media (max-width: 1024px) {
    .search-input__form {
        font-size: 26px;
    }
}

@media (max-width: 768px) {
    .search-input__form {
        font-size: 24px;
    }
}

.search-input__form__field {
    border: none;
    background: transparent;
    outline: none;
    margin: unset;
    width: 85%;
    font-size: 1.2rem;
}

@media (max-width: 1024px) {
    .search-input__form__field {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .search-input__form__field {
        font-size: 0.95rem;
    }
}

.search-input__submit {
    border: none;
    border-radius: 50px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #A9CBB7;
    color: #FFFFFF;
    height: 60px;
    width: 60px;
    transition: opacity 0.2s ease;
}

@media (max-width: 1024px) {
    .search-input__submit {
        height: 52.5px;
        width: 52.5px;
    }
}

@media (max-width: 768px) {
    .search-input__submit {
        height: 45px;
        width: 45px;
    }
}

.search-input__submit:hover {
    opacity: 0.9;
}

.search-input .search-filters {
    display: none;
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    background-color: #FFFFFF;
    box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
    border-radius: 15px;
    max-width: 400px;
    z-index: 20;
    opacity: 0;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.search-input .search-filters {
    padding: 15px;
}

@media (max-width: 1024px) {
    .search-input .search-filters {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .search-input .search-filters {
        padding: 10px;
    }
}

.search-input .search-filters.active {
    display: block;
    opacity: 1;
}

.search-input .filters-form {
    display: flex;
    flex-direction: column;
    margin: unset;
    justify-content: flex-start;
    gap: 10px;
}

@media (max-width: 1024px) {
    .search-input .filters-form {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .search-input .filters-form {
        gap: 6px;
    }
}

.search-input .filters-form .filter-item {
    display: flex;
    flex-direction: column;
}

.search-input .filters-form .filter-item input, select {
    padding: 7px;
}

@media (max-width: 1024px) {
    .search-input .filters-form .filter-item input, select {
        padding: 6px;
    }
}

@media (max-width: 768px) {
    .search-input .filters-form .filter-item input, select {
        padding: 5px;
    }
}


.search-input .filters-form .filter-item input[type=checkbox] {
    width: unset;
    margin: unset;
    cursor: pointer;
}

.search-input .filters-form .filters-apply {
    background-color: #A9CBB7;
    color: #FFFFFF;
    font-weight: 700;
    border: none;
    padding: 10px;
    border-radius: 50px;
    cursor: pointer;
    margin-top: 15px;
    transition: background-color 0.2s ease;
}

.search-input .filters-form .filters-apply:hover {
    opacity: 0.9;
}

/*Search input end style*/
.container_empty {
    margin: 0 auto;
    height: 70vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 25px;
}

@media (max-width: 1024px) {
    .container_empty {
        gap: 20px;
    }
}

@media (max-width: 768px) {
    .container_empty {
        gap: 15px;
    }
}

.container_empty__image {
    border-radius: 10px;
    overflow: hidden;
    height: 150px;
    width: 150px;
}

@media (max-width: 1024px) {
    .container_empty__image {
        height: 125px;
        width: 125px;
    }
}

@media (max-width: 768px) {
    .container_empty__image {
        height: 100px;
        width: 100px;
    }
}

.container_empty__image img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

.container_empty__text {
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #4C4C4C;
}

/* Swtich style*/
.switch-checkbox {
    display: none;
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .switch-checkbox {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .switch-checkbox {
        margin-bottom: 8px;
    }
}

.switch-label {
    display: flex;
    align-items: center;
    cursor: pointer;
    font-weight: 500;
}

.switch-label .switch-slider {
    position: relative;
    width: 40px;
    height: 22px;
    background-color: #e3e3e3;
    border-radius: 20px;
    margin-right: 12px;
    transition: background 0.3s;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.07);
    flex-shrink: 0;
}

.switch-label .switch-slider::before {
    content: "";
    position: absolute;
    left: 2px;
    top: 2px;
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 50%;
    transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.13);
}

.switch-checkbox:checked + .switch-label .switch-slider {
    background-color: #A9CBB7;
}

.switch-checkbox:checked + .switch-label .switch-slider::before {
    transform: translateX(18px);
}

/* Swtich end style*/
/*Pagination style start*/
.pagination {
    display: flex;
    justify-content: center;
    font-family: inherit;
    user-select: none;
}

.pagination {
    margin-top: 70px;
}

@media (max-width: 1024px) {
    .pagination {
        margin-top: 60px;
    }
}

@media (max-width: 768px) {
    .pagination {
        margin-top: 50px;
    }
}

.pagination__list {
    display: flex;
    list-style: none;
    gap: 10px;
}

@media (max-width: 1024px) {
    .pagination__list {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .pagination__list {
        gap: 6px;
    }
}

.pagination__item {
    display: flex;
    align-items: center;
}

.pagination__link {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 6px;
    border-radius: 50px;
    background: #FAFAF9;
    color: #A9CBB7;
    font-weight: 500;
    text-decoration: none;
    box-shadow: 0 1px 8px rgba(100, 100, 111, 0.09);
    transition: background 0.15s, color 0.15s, box-shadow 0.2s;
    border: none;
    outline: none;
    font-size: 1.15rem;
    min-height: 38px;
    min-width: 38px;
}

.blog_presentation .pagination__link {
    color: #EFCFD1;
}

@media (max-width: 1024px) {
    .pagination__link {
        min-height: 36px;
        min-width: 36px;
    }
}

@media (max-width: 768px) {
    .pagination__link {
        min-height: 34px;
        min-width: 34px;
    }
}

.pagination__link:hover, .pagination__link:focus {
    background: #A9CBB7;
    color: #FFFFFF;
    box-shadow: 0 2px 10px rgba(100, 100, 111, 0.17);
}

.pagination__link--active {
    background: #A9CBB7;
    color: #FFFFFF;
    font-weight: 700;
    box-shadow: 0 2px 10px rgba(100, 100, 111, 0.15);
    pointer-events: none;
}

.pagination__link--prev, .pagination__link--next {
    padding: 0;
    font-size: 1.3rem;
    min-height: 38px;
    min-width: 38px;
}

@media (max-width: 1024px) {
    .pagination__link--prev, .pagination__link--next {
        min-height: 36px;
        min-width: 36px;
    }
}

@media (max-width: 768px) {
    .pagination__link--prev, .pagination__link--next {
        min-height: 34px;
        min-width: 34px;
    }
}

.pagination__link--prev .material-symbols-outlined, .pagination__link--next .material-symbols-outlined {
    font-size: 2rem;
    vertical-align: middle;
}

.pagination__ellipsis {
    color: #DADADA;
    font-size: 1.4rem;
    padding: 0 4px;
    user-select: none;
}

/* Pagination end styles */

/* Quillfield styles*/
.quill-field-container {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .quill-field-container {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .quill-field-container {
        margin-bottom: 8px;
    }
}

/* Style du wrapper Quill */
.quill-wrapper {
    border: 1px solid #DADADA;
    border-radius: 15px;
    cursor: text;
}

.quill-wrapper .ql-toolbar {
    border-top-left-radius: 12px;
    border-top-right-radius: 12px;
    background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
}

.quill-wrapper .ql-container {
    flex: 1;
    display: flex;
    flex-direction: column;
    border-bottom-left-radius: 12px;
    border-bottom-right-radius: 12px;
    min-height: 300px;
}

.quill-wrapper .ql-editor {
    flex: 1;
    min-height: 300px;
    height: 100%;
}

/* Quillfield end styles*/

/* 2fa styles*/
.text_information {
    margin-top: 70px;
}

@media (max-width: 1024px) {
    .text_information {
        margin-top: 60px;
    }
}

@media (max-width: 768px) {
    .text_information {
        margin-top: 50px;
    }
}

#cancel_button {
    background-color: #D16464;
    color: #FFFFFF;
}

#cancel_button:hover {
    background-color: rgb(197.328358209, 60.671641791, 60.671641791);
}

#next_button {
    background-color: #AAC8CE;
    color: #FFFFFF;
}

#next_button:hover {
    background-color: rgb(137.6492537313, 179.0671641791, 187.3507462687);
}

#return_button {
    background-color: #F2C288;
    color: #4C4C4C;
}

#return_button:hover {
    background-color: rgb(236.9772727273, 170.4318181818, 90.0227272727);
}

#terminate_button {
    background-color: #7EBF8D;
    color: #FFFFFF;
}

#terminate_button:hover {
    background-color: rgb(91.9119170984, 174.0880829016, 110.8756476684);
}

.qr_code {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* 2fa end styles */

/*Style Personal_information start*/
.container_user_personal_information_grid {
    display: grid;
    grid-template-columns: 0.7fr 0.3fr;
    align-items: center;
    gap: 50px;
}

@media (max-width: 1024px) {
    .container_user_personal_information_grid {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .container_user_personal_information_grid {
        gap: 25px;
    }
}

.container_user_personal_information_grid {
    margin-top: 70px;
}

@media (max-width: 1024px) {
    .container_user_personal_information_grid {
        margin-top: 60px;
    }
}

@media (max-width: 768px) {
    .container_user_personal_information_grid {
        margin-top: 50px;
    }
}

@media (max-width: 768px) {
    .container_user_personal_information_grid {
        display: flex;
        flex-direction: column-reverse;
    }

    .container_user_personal_information_grid .text_information_container {
        width: 100%;
    }
}

.container_user_personal_information_grid .text_information_container {
    grid-column: 1 / 2;
    display: flex;
    flex-direction: column;
    gap: 35px;
}

@media (max-width: 1024px) {
    .container_user_personal_information_grid .text_information_container {
        gap: 32.5px;
    }
}

@media (max-width: 768px) {
    .container_user_personal_information_grid .text_information_container .container__link_left {
        justify-content: center;
        gap: 30px;
    }
}

.container_user_personal_information_grid .text_information_container .user_first_name_last_name_information {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 35px;
}

@media (max-width: 1024px) {
    .container_user_personal_information_grid .text_information_container .user_first_name_last_name_information {
        gap: 32.5px;
    }
}

@media (max-width: 768px) {
    .container_user_personal_information_grid .text_information_container .user_first_name_last_name_information {
        gap: 30px;
    }
}

.container_user_personal_information_grid .text_information_container .user_first_name_last_name_information p {
    border-radius: 15px;
    width: 100%;
    border: solid 2px #AAC8CE;
    color: #AAC8CE;
    font-weight: 700;
}

.container_user_personal_information_grid .text_information_container .user_first_name_last_name_information p {
    padding: 20px;
}

@media (max-width: 1024px) {
    .container_user_personal_information_grid .text_information_container .user_first_name_last_name_information p {
        padding: 17.5px;
    }
}

@media (max-width: 768px) {
    .container_user_personal_information_grid .text_information_container .user_first_name_last_name_information p {
        padding: 15px;
    }
}

.container_user_personal_information_grid .text_information_container p {
    border-radius: 15px;
    border: solid 2px #AAC8CE;
    color: #AAC8CE;
    font-weight: 700;
}

.container_user_personal_information_grid .text_information_container p {
    padding: 20px;
}

@media (max-width: 1024px) {
    .container_user_personal_information_grid .text_information_container p {
        padding: 17.5px;
    }
}

@media (max-width: 768px) {
    .container_user_personal_information_grid .text_information_container p {
        padding: 15px;
    }
}

.container_user_personal_information_grid .text_information_container .container__link_left #update_user_information {
    border-radius: 50px;
    background: linear-gradient(90deg, #7EBF8D, #A9CBB7);
    color: #FFFFFF;
    font-weight: 700;
}

.container_user_personal_information_grid .text_information_container .container__link_left #update_user_information {
    padding: 20px;
}

@media (max-width: 1024px) {
    .container_user_personal_information_grid .text_information_container .container__link_left #update_user_information {
        padding: 17.5px;
    }
}

@media (max-width: 768px) {
    .container_user_personal_information_grid .text_information_container .container__link_left #update_user_information {
        padding: 15px;
    }
}

.pp_container_personal_information {
    position: relative;
    justify-self: center;
    grid-column: 2 / 3;
}

.pp_container_personal_information .user_pp {
    border-radius: 50%;
    overflow: hidden;
    height: 250px;
    width: 250px;
}

@media (max-width: 1024px) {
    .pp_container_personal_information .user_pp {
        height: 225px;
        width: 225px;
    }
}

@media (max-width: 768px) {
    .pp_container_personal_information .user_pp {
        height: 200px;
        width: 200px;
    }
}

.pp_container_personal_information .user_pp img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

.pp_container_personal_information .update_user_pp {
    position: absolute;
    background: linear-gradient(90deg, #7EBF8D, #A9CBB7);
    color: #FFFFFF;
    font-weight: 700;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    bottom: 15px;
    right: 30px;
    height: 10px;
    width: 10px;
}

.pp_container_personal_information .update_user_pp {
    padding: 15px;
}

@media (max-width: 1024px) {
    .pp_container_personal_information .update_user_pp {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .pp_container_personal_information .update_user_pp {
        padding: 10px;
    }
}

@media (max-width: 1024px) {
    .pp_container_personal_information .update_user_pp {
        height: 8px;
        width: 8px;
    }
}

@media (max-width: 768px) {
    .pp_container_personal_information .update_user_pp {
        height: 6px;
        width: 6px;
    }
}


/*Update pp page*/
.up_pp_page_container {
    border-radius: 50%;
    margin: 0 auto;
    overflow: hidden;
    height: 250px;
    width: 250px;
}

.up_pp_page_container {
    margin-top: 70px;
}

@media (max-width: 1024px) {
    .up_pp_page_container {
        margin-top: 60px;
    }
}

@media (max-width: 768px) {
    .up_pp_page_container {
        margin-top: 50px;
    }
}

.up_pp_page_container {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .up_pp_page_container {
        margin-bottom: 50px;
    }
}

@media (max-width: 768px) {
    .up_pp_page_container {
        margin-bottom: 50px;
    }
}

@media (max-width: 1024px) {
    .up_pp_page_container {
        height: 225px;
        width: 225px;
    }
}

@media (max-width: 768px) {
    .up_pp_page_container {
        height: 200px;
        width: 200px;
    }
}

.up_pp_page_container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.user-extra-info {
    margin-top: 70px;
}

@media (max-width: 1024px) {
    .user-extra-info {
        margin-top: 60px;
    }
}

@media (max-width: 768px) {
    .user-extra-info {
        margin-top: 50px;
    }
}

.group_user {
    border-radius: 20px;
    color: white;
}

.group_user {
    padding: 7px;
}

@media (max-width: 1024px) {
    .group_user {
        padding: 6px;
    }
}

@media (max-width: 768px) {
    .group_user {
        padding: 5px;
    }
}

#group_directrice {
    background: linear-gradient(135deg, #EFCFD1, #F2C288, #D8A7A7);
}

#group_adminstration {
    background: linear-gradient(135deg, #A9CBB7, #AAC8CE, #F7E1D7);
}

.user-extra-info__list {
    display: flex;
    flex-direction: column;
    gap: 35px;
    list-style-type: none;
}

@media (max-width: 1024px) {
    .user-extra-info__list {
        gap: 30px;
    }
}

@media (max-width: 768px) {
    .user-extra-info__list {
        gap: 25px;
    }
}

.user-extra-info__list {
    padding: 10px;
}

@media (max-width: 1024px) {
    .user-extra-info__list {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .user-extra-info__list {
        padding: 30px;
    }
}

/*requests list styles*/
.requests-list {
    display: flex;
    /*align-items: center;*/
    flex-direction: column;
    gap: 10px;
}

@media (max-width: 1024px) {
    .requests-list {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .requests-list {
        gap: 6px;
    }
}

.card--request {
    display: grid;
    grid-template-columns: 0.2fr 0.6fr 0.2fr;
    gap: 25px;
}

@media (max-width: 1024px) {
    .card--request {
        gap: 22.5px;
    }
}

@media (max-width: 768px) {
    .card--request {
        gap: 20px;
    }
}

@media (max-width: 768px) {
    .card--request {
        display: block;
        margin-bottom: 25px;
    }
}

.card--request__user-icon-container {
    grid-column: 1/2;
    display: flex;
    align-items: center;
    justify-content: center;
}

.card--request__user-icon-container__user-icon {
    border-radius: 50%;
    overflow: hidden;
    height: 75px;
    width: 75px;
}

@media (max-width: 1024px) {
    .card--request__user-icon-container__user-icon {
        height: 70px;
        width: 70px;
    }
}

@media (max-width: 768px) {
    .card--request__user-icon-container__user-icon {
        height: 65px;
        width: 65px;
    }
}

.card--request__user-icon-container__user-icon img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.card--request__user-information-container {
    grid-column: 2/3;
    display: flex;
    flex-direction: column;
    align-self: stretch;
}

@media (max-width: 768px) and (max-width: 1024px) {
    .card--request__user-information-container {
        margin-bottom: 12.5px;
    }
}

@media (max-width: 768px) {
    .card--request__user-information-container {
        margin-bottom: 10px;
    }
}

.card--request__user-information-container__user-information-nom-prenom {
    font-weight: 700;
}

@media (max-width: 768px) {
    .card--request__user-information-container__user-information-nom-prenom {
        text-align: center;
    }

    .card--request__user-information-container__user-information-nom-prenom {
        margin-bottom: 15px;
    }
}

@media (max-width: 768px) and (max-width: 1024px) {
    .card--request__user-information-container__user-information-nom-prenom {
        margin-bottom: 12.5px;
    }
}

@media (max-width: 768px) and (max-width: 768px) {
    .card--request__user-information-container__user-information-nom-prenom {
        margin-bottom: 10px;
    }
}

.card--request__user-information-container__user-information-email {
    font-style: italic;
}

@media (max-width: 768px) {
    .card--request__user-information-container__user-information-email {
        text-align: center;
    }
}

.card--request__user-information-container__user-information-date {
    color: #6C757D;
}

@media (max-width: 768px) {
    .card--request__user-information-container__user-information-date {
        text-align: center;
    }
}

.card--request__actions {
    grid-column: 3/4;
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 8px;
}

.card--request__actions form {
    margin-top: unset;
}

@media (max-width: 1024px) {
    .card--request__actions {
        gap: 6px;
    }
}

@media (max-width: 768px) {
    .card--request__actions {
        gap: 4px;
    }
}

.card--request__actions .action-button {
    display: inline-block;
    color: #FFFFFF;
    border-radius: 15px;
    border: none;
    font-weight: 700;
    cursor: pointer;
    text-decoration: none;
    text-align: center;
    min-width: 100px;
    transition: background 0.15s, box-shadow 0.15s;
}

.card--request__actions .action-button {
    padding: 15px;
}

@media (max-width: 1024px) {
    .card--request__actions .action-button {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .card--request__actions .action-button {
        padding: 10px;
    }
}

.card--request__actions .action-button--agree {
    background-color: #7EBF8D;
}

.card--request__actions .action-button--agree:hover, .card--request__actions .action-button--agree:focus {
    box-shadow: 0 0 0 2px rgba(20, 180, 90, 0.18);
}

.card--request__actions .action-button--disagree {
    background-color: #D16464;
}

.card--request__actions .action-button--disagree:hover, .card--request__actions .action-button--disagree:focus {
    box-shadow: 0 0 0 2px rgba(200, 40, 40, 0.18);
}


.card--request__user-information-container__user-information-role {
    display: flex;
    align-items: center;
    justify-content: center;
}

/*Rédiger article styles */
.create_article_form {
    max-width: 900px;
}

.create_article_form #id_description {
    width: 100%;
    max-width: 100%;
    min-height: 200px;
    border: solid 1px #AAC8CE;
    border-radius: 15px;
    color: #A9CBB7;
}

.create_article_form #id_description {
    padding: 15px;
}

@media (max-width: 1024px) {
    .create_article_form #id_description {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .create_article_form #id_description {
        padding: 10px;
    }
}

.create_article_form #id_description {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .create_article_form #id_description {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .create_article_form #id_description {
        margin-bottom: 8px;
    }
}

.create_article_form #id_categorie {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .create_article_form #id_categorie {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .create_article_form #id_categorie {
        margin-bottom: 8px;
    }
}

.create_article_form input,
.create_article_form #id_description:focus {
    outline: none;
}

.create_article_form #id_contenu {
    min-height: 200px;
    border-radius: 15px;
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .create_article_form #id_contenu {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .create_article_form #id_contenu {
        margin-bottom: 8px;
    }
}

.create_article_form #id_contenu {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .create_article_form #id_contenu {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .create_article_form #id_contenu {
        margin-bottom: 8px;
    }
}

.create_article_form .container_button {
    gap: 35px;
}

.create_article_form .container_button {
    margin-top: 24px;
}

@media (max-width: 1024px) {
    .create_article_form .container_button {
        margin-top: 22px;
    }
}

@media (max-width: 768px) {
    .create_article_form .container_button {
        margin-top: 20px;
    }
}

@media (max-width: 1024px) {
    .create_article_form .container_button {
        gap: 32.5px;
    }
}

@media (max-width: 768px) {
    .create_article_form .container_button {
        gap: 30px;
    }
}

.create_article_form .container_button a {
    background-color: #D16464;
    color: white;
}

.create_article_form .container_button .submit-button {
    background-color: #7EBF8D;
    color: white;
}

/*Rédiger article end styles*/

/*dropzone-article styles*/
.dropzone-container--article {
    border: 2px dashed #AAC8CE;
    border-radius: 15px;
    text-align: center;
    position: relative;
    width: 100%;
    max-width: 100%;
    margin-bottom: 20px;
    transition: border-color 0.3s;
}

.dropzone-container--article {
    padding: 40px;
}

@media (max-width: 1024px) {
    .dropzone-container--article {
        padding: 30px;
    }
}

@media (max-width: 768px) {
    .dropzone-container--article {
        padding: 20px;
    }
}

.dropzone-container--article.dragover {
    background-color: #F7E1D7;
}

.dropzone-container--article .dropzone-label {
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
    gap: 20px;
}

@media (max-width: 1024px) {
    .dropzone-container--article .dropzone-label {
        gap: 15px;
    }
}

@media (max-width: 768px) {
    .dropzone-container--article .dropzone-label {
        gap: 10px;
    }
}

.dropzone-container--article .upload-button {
    background-color: #A9CBB7;
    color: #FFFFFF;
    border-radius: 8px;
    text-align: center;
    transition: background-color 0.3s;
}

.dropzone-container--article .upload-button {
    padding: 15px;
}

@media (max-width: 1024px) {
    .dropzone-container--article .upload-button {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .dropzone-container--article .upload-button {
        padding: 10px;
    }
}

.dropzone-container--article .upload-button:hover {
    opacity: 0.9;
}

.dropzone-container--article .preview-image--rect {
    border-radius: 15px;
    object-fit: contain;
    display: block;
    width: 100%;
    max-width: 500px;
    height: auto;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

/*dropzone-article end styles*/

/* ---------- Dropzone PDF: preview en "chips" ---------- */

.dropzone-container--article .preview-files {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-start;
    align-items: center;
    margin-bottom: 18px; /* espace entre les chips et le label */
    max-height: 220px; /* évite que la zone ne devienne immense si beaucoup de fichiers */
    overflow: auto;
    padding-right: 4px; /* un petit air pour le scroll */
}

/* Chip générique (nom + icône + croix) */
.dropzone-container--article .file-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border: 1px dashed #AAC8CE; /* cohérent avec la bordure dropzone */
    background: #fff; /* fond clair pour contraster sur dragover */
    border-radius: 10px;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: background-color .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.dropzone-container--article .file-chip:hover {
    border-color: #A9CBB7; /* cohérent avec .upload-button */
    background: #F9FAFB;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .06);
}

/* Icône fichier (Material Symbols) */
.dropzone-container--article .file-chip__icon {
    font-size: 18px;
    line-height: 1;
}

/* Nom tronqué proprement */
.dropzone-container--article .file-chip__name {
    display: inline-block;
    max-width: clamp(120px, 32vw, 360px);
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Bouton suppression (croix) */
.dropzone-container--article .file-chip__remove {
    margin-left: 2px;
    border: 0;
    background: transparent;
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    color: #B94A48; /* rouge doux lisible */
    padding: 0 4px;
    border-radius: 6px;
    transition: background-color .2s ease, color .2s ease;
}

.dropzone-container--article .file-chip__remove:hover,
.dropzone-container--article .file-chip__remove:focus {
    background: rgba(185, 74, 72, .08);
    outline: none;
}

/* Accessibilité focus globale */
.dropzone-container--article:focus-within {
    outline: 2px dashed #AAC8CE;
    outline-offset: 4px;
}

/* État dragover un peu plus expressif */
.dropzone-container--article.dragover {
    background-color: #F7E1D7;
    border-color: #A9CBB7;
}

/* Responsif: un peu plus compact en dessous de 768px */
@media (max-width: 768px) {
    .dropzone-container--article .preview-files {
        gap: 8px;
        margin-bottom: 14px;
    }

    .dropzone-container--article .file-chip {
        padding: 7px 9px;
    }

    .dropzone-container--article .file-chip__name {
        max-width: clamp(100px, 48vw, 240px);
    }
}

/* Optionnel: barre de scroll discrète sur la zone d’aperçu (si beaucoup de fichiers) */
.dropzone-container--article .preview-files::-webkit-scrollbar {
    height: 6px;
    width: 6px;
}

.dropzone-container--article .preview-files::-webkit-scrollbar-thumb {
    background: #AAC8CE;
    border-radius: 10px;
}

.dropzone-container--article .preview-files::-webkit-scrollbar-track {
    background: transparent;
}


/*Style dashboard start*/
.dashboard {
    display: flex;
    flex-direction: column;
}

.dashboard__section {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.dashboard__grid {
    display: grid;
    gap: 50px;
}

@media (max-width: 1024px) {
    .dashboard__grid {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .dashboard__grid {
        gap: 25px;
    }
}

.dashboard__grid--stats {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.dashboard__grid--infos {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.dashboard__chart canvas {
    width: 100%;
    height: auto;
}

.card {
    background-color: #FAFAF9;
    box-shadow: rgba(14, 63, 126, 0.06) 0px 0px 0px 1px, rgba(42, 51, 70, 0.03) 0px 1px 1px -0.5px, rgba(42, 51, 70, 0.04) 0px 2px 2px -1px, rgba(42, 51, 70, 0.04) 0px 3px 3px -1.5px, rgba(42, 51, 70, 0.03) 0px 5px 5px -2.5px, rgba(42, 51, 70, 0.03) 0px 10px 10px -5px, rgba(42, 51, 70, 0.03) 0px 24px 24px -8px;
    border-radius: 12px;
}

.card {
    padding: 30px;
}

@media (max-width: 1024px) {
    .card {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .card {
        padding: 30px;
    }
}

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

.card__title {
}

.card__stat-value {
    font-weight: bold;
    color: #A9CBB7;
}

.card__stat-label {
}

.card__text {
    display: flex;
    align-items: center;
    gap: 10px;
}

.card__text_connect-icon {
    background-color: #7EBF8D;
    border-radius: 50%;
    height: 10px;
    width: 10px;
}

@media (max-width: 1024px) {
    .card__text_connect-icon {
        height: 8px;
        width: 8px;
    }
}

@media (max-width: 768px) {
    .card__text_connect-icon {
        height: 6px;
        width: 6px;
    }
}

@media (max-width: 1024px) {
    .card__text {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .card__text {
        gap: 6px;
    }
}

/* Style dashboard end*/

/*Style article start*/
.article_presentation {
    position: relative;
    display: flex;
    align-items: flex-end;
    z-index: 0;
    overflow: hidden;
    border-radius: 25px;
    min-height: 600px;
}

.article_presentation {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .article_presentation {
        margin-bottom: 50px;
    }
}

@media (max-width: 768px) {
    .article_presentation {
        margin-bottom: 50px;
    }
}

.article_presentation__elements {
    position: relative;
    display: flex;
    flex-grow: 1;
    z-index: 2;
    gap: 50px;
}

.article_presentation__elements > * {
    flex: 1 1 0;
    min-width: 0;
}

@media (max-width: 1024px) {
    .article_presentation__elements {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .article_presentation__elements {
        gap: 25px;
    }
}

@media (max-width: 1024px) {
    .article_presentation__elements {
        display: block;
    }
}

.article_presentation__elements_information-left {
    position: relative;
    z-index: 2;
    color: #FFFFFF;
    flex-grow: 1;
}

@media (max-width: 1024px) {
    .article_presentation__elements_information-left__titre {
        text-align: center;
    }

    .article_presentation__elements_information-left__description {
        line-height: 30px;
    }

    .article_presentation__elements_information-left {
        margin-bottom: 40px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .article_presentation__elements_information-left {
        margin-bottom: 35px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .article_presentation__elements_information-left {
        margin-bottom: 30px;
    }
}

.article_presentation__elements_information-right {
    position: relative;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    align-self: stretch;
    justify-content: center;
    color: #FFFFFF;
    z-index: 2;
    gap: 35px;
}

@media (max-width: 1024px) {
    .article_presentation__elements_information-right {
        gap: 32.5px;
    }
}

@media (max-width: 768px) {
    .article_presentation__elements_information-right {
        gap: 30px;
    }
}

@media (max-width: 1024px) {
    .article_presentation__elements_information-right {
        align-items: flex-start;
    }
}

.article_presentation__elements_information-right .user_presentation {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.article_presentation__elements_information-right .user_presentation .icon {
    height: 40px;
    width: 40px;
}

@media (max-width: 1024px) {
    .article_presentation__elements_information-right .user_presentation .icon {
        height: 35px;
        width: 35px;
    }
}

@media (max-width: 768px) {
    .article_presentation__elements_information-right .user_presentation .icon {
        height: 30px;
        width: 30px;
    }
}

.article_presentation__elements_information-right .user_presentation .icon .icon__user_pp {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.article_presentation__elements_information-right .user_presentation .full-name_container {
    font-weight: 700;
}

.article_presentation__elements_information-right__date-time {
    display: flex;
    align-items: center;
}

.article_presentation__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.article_presentation__image::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background: rgba(0, 0, 0, 0.45);
}

.article_presentation__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.article_categorie {
    font-weight: 700;
    border-radius: 50px;
    color: #FFFFFF;
    background-color: rgba(196, 196, 196, 0.42);
}

.article_categorie {
    padding: 15px;
}

@media (max-width: 1024px) {
    .article_categorie {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .article_categorie {
        padding: 10px;
    }
}

/*Style article end*/

/*Style quill start*/
.article__content {
    margin-bottom: 150px;
}

@media (max-width: 1024px) {
    .article__content {
        margin-bottom: 125px;
    }
}

@media (max-width: 768px) {
    .article__content {
        margin-bottom: 100px;
    }
}


.article__content img {
    max-width: 100%;
    max-height: 400px; /* limite la hauteur à 400px */
    width: auto;
    height: auto;
    margin: 0 auto;
    display: block;
    border-radius: 8px;
    object-fit: contain;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.article__content iframe,
.article__content video {
    max-width: 100%;
}

.article__content p img {
    display: block;
}

.article__content p[style*="text-align: center"] img {
    margin-left: auto;
    margin-right: auto;
}

/*Style quill end*/


/*Style articles_suggest start*/
.articles_suggests {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    justify-items: center;
    gap: 40px;
}

.articles_suggestions__title {
    color: #4C4C4C;
}

.articles_suggests__card {
    display: block;
    position: relative;
    overflow: hidden;
    border-radius: 15px;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
    height: 500px;
    flex-basis: 350px;
}

@media (max-width: 1024px) {
    .articles_suggests__card {
        height: 450px;
        flex-basis: 325px;
    }
}

@media (max-width: 768px) {
    .articles_suggests__card {
        height: 400px;
        flex-basis: 300px;
    }
}

@media (max-width: 768px) {
    .articles_suggests__card {
        max-width: 300px;
    }

    .articles_suggests__card {
        margin: 0 auto 0px auto;
    }
}

@media (max-width: 768px) and (max-width: 1024px) {
    .articles_suggests__card {
        margin: 0 auto 0px auto;
    }
}

@media (max-width: 768px) and (max-width: 768px) {
    .articles_suggests__card {
        margin: 0 auto 25px auto;
    }
}

.articles_suggests__card__content__text h3 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.articles_suggests__card__content__text p {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.articles_suggests__card__content__date {
    color: grey;
    font-style: italic;
    font-weight: 400;
}

.articles_suggests__card__content__user {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
}

@media (max-width: 1024px) {
    .articles_suggests__card__content__user {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .articles_suggests__card__content__user {
        gap: 6px;
    }
}

/* Style article_suggests end */

/*Styles Contact start*/
.contact_form {
}

.contact_form-container {
    display: grid;
    grid-template-columns: 0.65fr 0.35fr;
    gap: 50px;
}

@media (max-width: 1024px) {
    .contact_form-container {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .contact_form-container {
        gap: 25px;
    }
}

@media (max-width: 1024px) {
    .contact_form-container {
        display: block;
    }
}

.contact_form-container-titre {
    text-align: center;
    color: #4C4C4C;
}

.contact_form-container .contact_form {
    grid-column: 1/2;
    width: 100%;
}

@media (max-width: 1024px) {
    .contact_form-container .contact_form {
        width: unset;
    }

    .contact_form-container .contact_form {
        margin-bottom: 50px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .contact_form-container .contact_form {
        margin-bottom: 50px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .contact_form-container .contact_form {
        margin-bottom: 50px;
    }
}

.contact_form-container .contact_form #id_message {
    max-width: 100%;
    min-width: 100%;
    min-height: 100px;
    max-height: 250px;
    overflow: auto;
    border-radius: 15px;
    border: solid 1px #A9CBB7;
    color: #A9CBB7;
}

.contact_form-container .contact_form #id_message {
    padding: 15px;
}

@media (max-width: 1024px) {
    .contact_form-container .contact_form #id_message {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .contact_form-container .contact_form #id_message {
        padding: 10px;
    }
}

.contact_form-container .contact_form #id_message:focus {
    outline: none;
}

.contact_form-container .contact_form .container_button button {
    background-image: linear-gradient(90deg, #A9CBB7, #7EBF8D);
    color: #FFFFFF;
    gap: 15px;
}

@media (max-width: 1024px) {
    .contact_form-container .contact_form .container_button button {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .contact_form-container .contact_form .container_button button {
        gap: 10px;
    }
}


.contact_form-container .contact_form .container_button button:hover {
    opacity: 0.9;
}

.contact_form-container .contact-map_container {
    grid-column: 2/3;
    height: 100%;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 50px;
}

@media (max-width: 1024px) {
    .contact_form-container .contact-map_container {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .contact_form-container .contact-map_container {
        gap: 25px;
    }
}

@media (max-width: 1024px) {
    .contact_form-container .contact-map_container {
        display: block;
    }

    .contact_form-container .contact-map_container {
        margin-bottom: 50px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .contact_form-container .contact-map_container {
        margin-bottom: 50px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .contact_form-container .contact-map_container {
        margin-bottom: 50px;
    }
}

.contact_form-container .contact-map_container .contact-container {
    color: #4C4C4C;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

@media (max-width: 1024px) {
    .contact_form-container .contact-map_container .contact-container {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .contact_form-container .contact-map_container .contact-container {
        gap: 6px;
    }
}

.contact_form-container .contact-map_container .contact-container p {
    display: flex;
    align-items: center;
    gap: 15px;
}

@media (max-width: 1024px) {
    .contact_form-container .contact-map_container .contact-container p {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .contact_form-container .contact-map_container .contact-container p {
        gap: 10px;
    }
}

@media (max-width: 1024px) {
    .contact_form-container .contact-map_container .contact-container {
        margin-bottom: 50px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .contact_form-container .contact-map_container .contact-container {
        margin-bottom: 50px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .contact_form-container .contact-map_container .contact-container {
        margin-bottom: 50px;
    }
}

.contact_form-container .contact-map_container .map-container {
    flex-grow: 0.6;
    position: relative;
    z-index: 1;
}

.contact_form-container .contact-map_container .map-container #map {
    border-radius: 15px;
    height: 100%;
    width: 100%;
    overflow: hidden;
}

@media (max-width: 1024px) {
    .contact_form-container .contact-map_container .map-container #map {
        margin: 0 auto;
        max-width: 600px;
        height: 0;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .contact_form-container .contact-map_container .map-container #map {
        height: 250px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .contact_form-container .contact-map_container .map-container #map {
        height: 200px;
    }
}

@media (max-width: 1024px) {
    .contact_form-container .contact-map_container .map-container #map {
        margin-bottom: 50px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .contact_form-container .contact-map_container .map-container #map {
        margin-bottom: 50px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .contact_form-container .contact-map_container .map-container #map {
        margin-bottom: 50px;
    }
}

/*Styles Contact end*/


/* Style derniers_articles start */
.articles_recents {
    color: #4C4C4C;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    justify-items: center;
    gap: 40px;
}

@media (max-width: 1024px) {
    .articles_recents {
        gap: 30px;
    }
}

@media (max-width: 768px) {
    .articles_recents {
        gap: 20px;
    }
}

/*@media (max-width: 768px) {*/
/*    .articles_recents {*/
/*        display: block;*/
/*    }*/
/*}*/

.articles-recents__intro {
    color: #4C4C4C;
    text-align: center;
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .articles-recents__intro {
        margin-bottom: 40px;
    }
}

@media (max-width: 768px) {
    .articles-recents__intro {
        margin-bottom: 30px;
    }
}

.articles-recents__text {
    opacity: 0.85;
}


.articles_recents__title {
    color: #4C4C4C;
}

.articles_recents__card {
    display: block;
    position: relative;
    overflow: hidden;
    border-radius: 15px;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
    height: 500px;
    flex-basis: 350px;
}

@media (max-width: 1024px) {
    .articles_recents__card {
        height: 450px;
        flex-basis: 325px;
    }
}

@media (max-width: 768px) {
    .articles_recents__card {
        height: 400px;
        flex-basis: 300px;
    }
}

@media (max-width: 768px) {
    .articles_recents__card {
        max-width: 300px;
    }

    .articles_recents__card {
        margin: 0 auto 0px auto;
    }
}

@media (max-width: 768px) and (max-width: 1024px) {
    .articles_recents__card {
        margin: 0 auto 0px auto;
    }
}

@media (max-width: 768px) and (max-width: 768px) {
    .articles_recents__card {
        margin: 0 auto 25px auto;
    }
}

.articles_recents__card__content__text h3 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.articles_recents__card__content__text p {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.articles_recents__card__content__date {
    color: grey;
    font-style: italic;
    font-weight: 400;
}

.articles_recents__card__content__user {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
}

@media (max-width: 1024px) {
    .articles_recents__card__content__user {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .articles_recents__card__content__user {
        gap: 6px;
    }
}

.articles_recents_more_articles_link {
    font-weight: 700;
    display: flex;
    align-items: center;
    border-radius: 50px;
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    color: #FFFFFF;
    gap: 20px;
    transition: color 0.3s ease-in-out,
    background 0.3s ease-in-out;
}

.articles_recents_more_articles_link .material-symbols-outlined {
    transition: transform 0.3s ease-in-out,
    color 0.3s ease-in-out;
}

.articles_recents_more_articles_link:hover .material-symbols-outlined {
    transform: rotateZ(90deg);
}

.articles_recents_more_articles_link:hover, .articles_recents_more_articles_link:hover .material-symbols-outlined {
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
}

@media (max-width: 1024px) {
    .articles_recents_more_articles_link {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .articles_recents_more_articles_link {
        gap: 10px;
    }
}

.articles_recents_more_articles_link {
    margin-top: 50px;
}

@media (max-width: 1024px) {
    .articles_recents_more_articles_link {
        margin-top: 45px;
    }
}

@media (max-width: 768px) {
    .articles_recents_more_articles_link {
        margin-top: 40px;
    }
}

.articles_recents_more_articles_link {
    padding: 20px;
}

@media (max-width: 1024px) {
    .articles_recents_more_articles_link {
        padding: 17.5px;
    }
}

@media (max-width: 768px) {
    .articles_recents_more_articles_link {
        padding: 15px;
    }
}

/* Style derniers_articles end */

/*Style accueil start*/
.accueil {
    padding: unset;
}

.accueil__hero-banner {
    position: relative;
    /*Compatibilité tout écran*/
    height: 100dvh;
    min-height: 700px;
    display: flex;
    text-align: center;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    gap: 40px;
}

.accueil__hero-banner__video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
    /* Boost doux */
    filter: saturate(1.35) contrast(1.12) brightness(1.03) hue-rotate(-2deg);
}

.accueil__hero-banner::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.45); /* voile sombre (45%) */
    z-index: 1;
}

.accueil__hero-banner > *:not(.accueil__hero-banner__video) {
    position: relative;
    z-index: 2;
}

@media (max-width: 1024px) {
    .accueil__hero-banner {
        gap: 30px;
    }
}

@media (max-width: 768px) {
    .accueil__hero-banner {
        gap: 20px;
    }
}

.accueil__hero-banner__titre {
    color: white;
    font-weight: bold;
}

.accueil__hero-banner__titre--accent {
    display: block;
    /*border-radius: 50%;*/
    /*border-top: 2px solid #ffd500;*/
    background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
    -webkit-background-clip: text;
    font-size: unset;
    -webkit-text-fill-color: transparent;
}

.accueil__hero-banner__texte {
    font-size: 1.2rem;
    color: #FAFAF9;
}

@media (max-width: 1024px) {
    .accueil__hero-banner__texte {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .accueil__hero-banner__texte {
        font-size: 0.95rem;
    }
}

.accueil__hero-banner__cta {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 50px;
}

@media (max-width: 1024px) {
    .accueil__hero-banner__cta {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .accueil__hero-banner__cta {
        gap: 25px;
    }
}

.accueil__hero-banner__cta a {
    height: 100%;
    border-radius: 15px;
    font-weight: 700;
    transition: color 0.3s ease-in-out, background-image 0.3s ease-in-out, border 0.3s ease-in-out;
}

.accueil__hero-banner__cta a {
    padding: 20px;
}

@media (max-width: 1024px) {
    .accueil__hero-banner__cta a {
        padding: 17.5px;
    }
}

@media (max-width: 768px) {
    .accueil__hero-banner__cta a {
        padding: 15px;
    }
}

.accueil__hero-banner__cta .btn--secondary {
    border: 2px solid #FFFFFF;
    color: #FFFFFF;
    background-color: transparent;
    background-image: none;
}

.accueil__hero-banner__cta .btn--secondary:hover {
    color: #ffcb49;
    border: 2px solid #ffcb49;

}

.accueil__hero-banner__cta .btn--primary {
    color: #FFFFFF;
    /*background-image: linear-gradient(135deg, #D88181, #EFCFD1);*/
    background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
    display: flex;
    align-items: center;
    transition: background-image 0.3s ease-in-out;
}

.accueil__hero-banner__cta .btn--primary:hover {
    background: linear-gradient(90deg, #a9ccb8, #8dd99f);
}

.accueil__presentation {
    height: 80dvh;
    min-height: 800px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #FFFFFF;
}

.accueil__presentation__conteneur {
    position: relative;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
    gap: 50px;
}

@media (max-width: 1024px) {
    .accueil__presentation__conteneur {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .accueil__presentation__conteneur {
        gap: 25px;
    }
}

.accueil__presentation__conteneur .accueil__presentation__image-mobile {
    display: none;
}

@media (max-width: 1024px) {
    .accueil__presentation__conteneur .accueil__presentation__image-desktop {
        display: none;
    }

    .accueil__presentation__conteneur .accueil__presentation__image-mobile {
        position: absolute;
        border-radius: unset;
        display: block;
        z-index: 1;
        top: 0;
        left: 0;
        height: 100%;
        width: 100%;
        overflow: hidden;
    }

    .accueil__presentation__conteneur .accueil__presentation__image-mobile::before {
        content: "";
        position: absolute;
        inset: 0;
        background-color: rgba(0, 0, 0, 0.45);
        z-index: 2;
    }

    .accueil__presentation__conteneur .accueil__presentation__image-mobile img {
        height: 100%;
        width: 100%;
        object-fit: cover;
    }
}

.accueil__presentation__texte {
    flex: 1 1 50%;
    text-align: left;
    gap: 50px;
}

@media (max-width: 1024px) {
    .accueil__presentation__texte {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .accueil__presentation__texte {
        gap: 25px;
    }
}

@media (max-width: 1024px) {
    .accueil__presentation__texte {
        position: relative;
        z-index: 3;
        text-align: center;
    }
}

.accueil__presentation__titre {
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .accueil__presentation__titre {
        color: #FFFFFF;
    }
}

.accueil__presentation__description {
    font-family: "Poppins_texte", sans-serif;
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .accueil__presentation__description {
        color: #FFFFFF;
    }
}

.accueil__presentation__lien {
    border-radius: 50px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    color: #FFFFFF;
    background-image: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    gap: 15px;
    transition: color 0.3s ease-in-out, background 0.3s ease-in-out;
}

@media (max-width: 1024px) {
    .accueil__presentation__lien {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .accueil__presentation__lien {
        gap: 10px;
    }
}

.accueil__presentation__lien {
    margin-top: 50px;
}

@media (max-width: 1024px) {
    .accueil__presentation__lien {
        margin-top: 45px;
    }
}

@media (max-width: 768px) {
    .accueil__presentation__lien {
        margin-top: 40px;
    }
}

.accueil__presentation__lien {
    padding: 20px;
}

@media (max-width: 1024px) {
    .accueil__presentation__lien {
        padding: 17.5px;
    }
}

@media (max-width: 768px) {
    .accueil__presentation__lien {
        padding: 15px;
    }
}

@media (max-width: 1024px) {
    .accueil__presentation__lien {
        position: relative;
        z-index: 3;
        margin-left: auto;
    }
}

.accueil__presentation__lien:hover {
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
}

.accueil__presentation__lien span {
    transition: transform 0.3s ease-in-out,
    color 0.3s ease-in-out;
}

.accueil__presentation__lien:hover span {
    transform: translateX(5px);
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
}

.accueil__presentation__image {
    flex-grow: 1;
    flex-shrink: 1;
    text-align: center;
    border-radius: 50px;
    overflow: hidden;
    height: 450px;
    width: 450px;
}

@media (max-width: 1024px) {
    .accueil__presentation__image {
        height: 400px;
        width: 400px;
    }
}

@media (max-width: 768px) {
    .accueil__presentation__image {
        height: 400px;
        width: 400px;
    }
}

@media (max-width: 1024px) {
    .accueil__presentation__image {
        display: none;
    }
}

.accueil__presentation__image img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

.accueil .accueil-services {
    min-height: 900px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #fffdff;
    text-align: center;
    color: #4C4C4C;
}

.accueil .accueil-services__title {
    font-size: 2.5rem;
    margin-bottom: 2rem;
}

@media (max-width: 1024px) {
    .accueil .accueil-services__title {
        font-size: 2rem;
    }
}

@media (max-width: 768px) {
    .accueil .accueil-services__title {
        font-size: 1.5rem;
    }
}

.accueil .accueil-services__grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 50px;
}

@media (max-width: 1024px) {
    .accueil .accueil-services__grid {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .accueil .accueil-services__grid {
        gap: 25px;
    }
}

@media (max-width: 1024px) {
    .accueil .accueil-services__grid {
        flex-wrap: wrap;
        justify-content: center;
        align-items: stretch;
    }
}

.accueil .accueil-services__item {
    position: relative;
    background-color: #FFFFFF;
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(196, 196, 196, 0.42);
    width: 280px;
    max-width: 500px;
    transition: transform 0.1s ease-in-out, box-shadow 0.1s ease-in-out;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
}

@media (max-width: 1024px) {
    .accueil .accueil-services__item {
        gap: 30px;
    }
}

@media (max-width: 768px) {
    .accueil .accueil-services__item {
        gap: 20px;
    }
}

.accueil .accueil-services__item {
    padding: 40px;
}

@media (max-width: 1024px) {
    .accueil .accueil-services__item {
        padding: 30px;
    }
}

@media (max-width: 768px) {
    .accueil .accueil-services__item {
        padding: 20px;
    }
}

.accueil .accueil-services__item-top {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.accueil .accueil-services__item-top .icon_container {
    height: 80px;
    width: 80px;
}

@media (max-width: 1024px) {
    .accueil .accueil-services__item-top .icon_container {
        height: 70px;
        width: 70px;
    }
}

@media (max-width: 768px) {
    .accueil .accueil-services__item-top .icon_container {
        height: 60px;
        width: 60px;
    }
}

@media (max-width: 1024px) {
    .accueil .accueil-services__item-top .icon_container {
        margin: 0 auto;
    }
}

.accueil .accueil-services__item-top .icon_container img {
    object-fit: contain;
    width: 100%;
    height: 100%;
}

@media (max-width: 1024px) {
    .accueil .accueil-services__item-top .icon_container img {
        object-position: center;
    }
}

.accueil .accueil-services__item:hover {
    transform: scale(1.01);
}

.accueil .accueil-services__item::after {
    content: "";
    position: absolute;
    bottom: 24px;
    right: 12px;
    background-size: contain;
    background-repeat: no-repeat;
    pointer-events: none;
    opacity: 0.9;
}

.accueil .accueil-services__subtitle {
    font-weight: bold;
}

/*Style accueil end*/

/*Style contact-grid start*/
.message-grid-container {
    overflow-x: auto;
    width: 100%;
}

.message-grid-container .message-grid {
    min-width: 1024px;
    border-radius: 8px;
}

.message-grid-container .message-grid .grid-header {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    border-radius: 15px 15px 0 0;
    background-image: linear-gradient(90deg, #7EBF8D, #A9CBB7);
    color: #FFFFFF;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.message-grid-container .message-grid .grid-header {
    padding: 30px;
}

@media (max-width: 1024px) {
    .message-grid-container .message-grid .grid-header {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .message-grid-container .message-grid .grid-header {
        padding: 30px;
    }
}

.message-grid-container .message-grid .grid-header .grid-cell {
    margin: unset;
    text-align: center;
}

.message-grid-container .message-grid .grid-row {
    display: grid;
    align-items: center;
    grid-template-columns: repeat(6, 1fr);
    border-bottom: 1px solid #A9CBB7;
    transition: background-color 0.2s ease;
}

.message-grid-container .message-grid .grid-row:last-child {
    border-radius: 0 0 15px 15px;
}

.message-grid-container .message-grid .grid-row:hover {
    background-color: #f5f5f5;
}

.message-grid-container .message-grid .grid-row:last-child {
    border-bottom: none;
}

.message-grid-container .message-grid .grid-row .grid-cell {
    text-align: center;
}

.message-grid-container .message-grid .grid-row .grid-cell {
    padding: 30px;
}

@media (max-width: 1024px) {
    .message-grid-container .message-grid .grid-row .grid-cell {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .message-grid-container .message-grid .grid-row .grid-cell {
        padding: 30px;
    }
}

.message-grid-container .message-grid .grid-row .grid-cell-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

@media (max-width: 1024px) {
    .message-grid-container .message-grid .grid-row .grid-cell-actions {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .message-grid-container .message-grid .grid-row .grid-cell-actions {
        gap: 6px;
    }
}

.message-grid-container .message-grid .grid-row .grid-cell-actions button {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50px;
    font-weight: 700;
}

.message-grid-container .message-grid .grid-row .grid-cell-actions button {
    padding: 15px;
}

@media (max-width: 1024px) {
    .message-grid-container .message-grid .grid-row .grid-cell-actions button {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .message-grid-container .message-grid .grid-row .grid-cell-actions button {
        padding: 10px;
    }
}

.message-grid-container .message-grid .grid-row .grid-cell-statut {
    display: flex;
    justify-content: center;
    align-items: center;
}

.message-grid-container .message-grid .grid-row .grid-cell-statut p {
    font-size: 0.8rem;
}

@media (max-width: 1024px) {
    .message-grid-container .message-grid .grid-row .grid-cell-statut p {
        font-size: 0.7rem;
    }
}

@media (max-width: 768px) {
    .message-grid-container .message-grid .grid-row .grid-cell-statut p {
        font-size: 0.6rem;
    }
}

.message-grid-container .message-grid .grid-row .grid-cell-statut .statut-nouveau {
    border-radius: 50px;
    background-image: linear-gradient(135deg, #f6d365, #fda085);
    font-weight: 700;
    color: #FFFFFF;
}

.message-grid-container .message-grid .grid-row .grid-cell-statut .statut-nouveau {
    padding: 8px;
}

@media (max-width: 1024px) {
    .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-nouveau {
        padding: 7px;
    }
}

@media (max-width: 768px) {
    .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-nouveau {
        padding: 6px;
    }
}

.message-grid-container .message-grid .grid-row .grid-cell-statut .statut-lu {
    border-radius: 50px;
    background-image: linear-gradient(135deg, #a1c4fd, #c2e9fb);
    font-weight: 700;
    color: #FFFFFF;
}

.message-grid-container .message-grid .grid-row .grid-cell-statut .statut-lu {
    padding: 8px;
}

@media (max-width: 1024px) {
    .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-lu {
        padding: 7px;
    }
}

@media (max-width: 768px) {
    .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-lu {
        padding: 6px;
    }
}

.message-grid-container .message-grid .grid-row .grid-cell-statut .statut-traite {
    border-radius: 50px;
    background-image: linear-gradient(135deg, #d4fc79, #96e6a1);
    font-weight: 700;
    color: #FFFFFF;
}

.message-grid-container .message-grid .grid-row .grid-cell-statut .statut-traite {
    padding: 8px;
}

@media (max-width: 1024px) {
    .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-traite {
        padding: 7px;
    }
}

@media (max-width: 768px) {
    .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-traite {
        padding: 6px;
    }
}

.message-grid-container .message-grid .grid-row .grid-cell:last-child {
    text-align: right;
}

.message-grid-container .message-grid .action-button {
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 0.8rem;
}

@media (max-width: 1024px) {
    .message-grid-container .message-grid .action-button {
        font-size: 0.7rem;
    }
}

@media (max-width: 768px) {
    .message-grid-container .message-grid .action-button {
        font-size: 0.6rem;
    }
}

.message-grid-container .message-grid .action-button {
    padding: 8px;
}

@media (max-width: 1024px) {
    .message-grid-container .message-grid .action-button {
        padding: 7px;
    }
}

@media (max-width: 768px) {
    .message-grid-container .message-grid .action-button {
        padding: 6px;
    }
}

.message-grid-container .message-grid .action-button.view {
    background-color: unset;
    color: #7EBF8D;
}

.message-grid-container .message-grid .action-button.view:hover {
    opacity: 0.9;
}

.message-grid-container .message-grid .action-button.delete {
    background-color: unset;
    color: #D16464;
}

.message-grid-container .message-grid .action-button.delete:hover {
    opacity: 0.9;
}

@media (max-width: 1024px) {
    .message-grid-container .message-grid .message-grid-container {
        overflow-x: scroll;
    }
}

/*Style contact-grid end*/

/* Style gestion_site start */
.site-sections__grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 50px;
}

@media (max-width: 1024px) {
    .site-sections__grid {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .site-sections__grid {
        gap: 25px;
    }
}

.site-sections__card {
    width: 100%;
    max-width: 320px;
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    border-radius: 15px;
    background-image: linear-gradient(90deg, #7EBF8D, #A9CBB7);
    color: #FFFFFF;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
    transition: box-shadow 0.3s ease;
    gap: 10px;
}

@media (max-width: 1024px) {
    .site-sections__card {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .site-sections__card {
        gap: 6px;
    }
}

.site-sections__card {
    padding: 30px;
}

@media (max-width: 1024px) {
    .site-sections__card {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .site-sections__card {
        padding: 30px;
    }
}

.site-sections__card:hover {
    opacity: 0.9;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.site-sections__label {
    font-weight: 500;
    text-align: center;
}

/* Style gestion_site end */

/*Style blog_intro start*/
.blog-intro {
    position: relative;
    height: 70dvh;
    border-radius: 0 0 50px 50px;
    background-image: linear-gradient(60deg, #F7E1D7, #FFFFFF);
    min-height: 550px;
    width: 100%;
    display: flex;
    align-items: flex-end;
}

.blog-intro {
    padding: 40px;
}

@media (max-width: 1024px) {
    .blog-intro {
        padding: 30px;
    }
}

@media (max-width: 768px) {
    .blog-intro {
        padding: 20px;
    }
}

.blog-intro {
    margin-bottom: 100px;
}

@media (max-width: 1024px) {
    .blog-intro {
        margin-bottom: 75px;
    }
}

@media (max-width: 768px) {
    .blog-intro {
        margin-bottom: 50px;
    }
}

.blog-intro__container {
    width: 100%;
    margin: 0 auto;
    padding-bottom: unset;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.blog-intro__title {
    text-align: center;
    font-weight: 700;
    line-height: 1.2;
}

.blog-intro__description {
    text-align: center;
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.6;
}

.blog-intro .search-container_blog {
    position: relative;
    max-width: 900px;
    display: flex;
    justify-content: center;
    align-items: center;
}

@media (max-width: 768px) {
    .blog-intro .search-container_blog {
        display: block;
    }
}

.blog-intro .search-input-blog {
    position: relative;
    display: flex;
    align-items: center;
    background-color: #FFFFFF;
    box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
    border-radius: 50px;
    font-size: 1.2rem;
    flex-basis: 750px;
    /* Nouveau style pour les filtres */
}

@media (max-width: 1024px) {
    .blog-intro .search-input-blog {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .blog-intro .search-input-blog {
        font-size: 0.95rem;
    }
}

.blog-intro .search-input-blog {
    padding: 7px;
}

@media (max-width: 1024px) {
    .blog-intro .search-input-blog {
        padding: 6px;
    }
}

@media (max-width: 768px) {
    .blog-intro .search-input-blog {
        padding: 5px;
    }
}

@media (max-width: 1024px) {
    .blog-intro .search-input-blog {
        flex-basis: 650px;
    }
}

@media (max-width: 768px) {
    .blog-intro .search-input-blog {
        flex-basis: 550px;
    }
}

@media (max-width: 768px) {
    .blog-intro .search-input-blog {
        max-width: 100%;
    }
}

.blog-intro .search-input-blog__filter {
    border: none;
    background: transparent;
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 60px;
    width: 60px;
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .blog-intro .search-input-blog__filter {
        height: 52.5px;
        width: 52.5px;
    }
}

@media (max-width: 768px) {
    .blog-intro .search-input-blog__filter {
        height: 45px;
        width: 45px;
    }
}

.blog-intro .search-input-blog__filter:hover {
    opacity: 0.8;
}

.blog-intro .search-input-blog__form {
    margin: unset;
    max-width: unset;
    display: flex;
    justify-content: space-between;
    align-items: center;
    align-self: stretch;
    flex-grow: 1;
    font-size: 28px;
}

@media (max-width: 1024px) {
    .blog-intro .search-input-blog__form {
        font-size: 26px;
    }
}

@media (max-width: 768px) {
    .blog-intro .search-input-blog__form {
        font-size: 24px;
    }
}

.blog-intro .search-input-blog__form__field {
    border: none;
    background: transparent;
    outline: none;
    margin: unset;
    color: #EFCFD1;
    width: 85%;
    font-size: 1.2rem;
}

@media (max-width: 1024px) {
    .blog-intro .search-input-blog__form__field {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .blog-intro .search-input-blog__form__field {
        font-size: 0.95rem;
    }
}

.blog-intro .search-input-blog__submit {
    border: none;
    border-radius: 50px;
    cursor: pointer;
    background-color: #EFCFD1;
    color: #FFFFFF;
    transition: opacity 0.2s ease;
    height: 60px;
    width: 60px;
}

@media (max-width: 1024px) {
    .blog-intro .search-input-blog__submit {
        height: 52.5px;
        width: 52.5px;
    }
}

@media (max-width: 768px) {
    .blog-intro .search-input-blog__submit {
        height: 45px;
        width: 45px;
    }
}

.blog-intro .search-input-blog__submit:hover {
    opacity: 0.9;
}

.blog-intro .search-input-blog .search-filters {
    display: none;
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    background-color: #FFFFFF;
    box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
    border-radius: 15px;
    max-width: 400px;
    z-index: 13;
    opacity: 0;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.blog-intro .search-input-blog .search-filters {
    padding: 15px;
}

@media (max-width: 1024px) {
    .blog-intro .search-input-blog .search-filters {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .blog-intro .search-input-blog .search-filters {
        padding: 10px;
    }
}

.blog-intro .search-input-blog .search-filters.active {
    display: block;
    opacity: 1;
}

.blog-intro .search-input-blog .filters-form {
    display: flex;
    flex-direction: column;
    margin: unset;
    justify-content: flex-start;
    gap: 10px;
}

@media (max-width: 1024px) {
    .blog-intro .search-input-blog .filters-form {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .blog-intro .search-input-blog .filters-form {
        gap: 6px;
    }
}

.blog-intro .search-input-blog .filters-form .filter-item {
    display: flex;
    flex-direction: column;
}

.blog-intro .search-input-blog .filters-form .filter-item input[type=checkbox] {
    width: unset;
    margin: unset;
    cursor: pointer;
}

.blog-intro .search-input-blog .filters-form #filter-category {
    background-color: #FAFAF9;
}

.blog-intro .search-input-blog .filters-form .filters-apply {
    background-color: #EFCFD1;
    color: #FFFFFF;
    font-weight: 700;
    border: none;
    padding: 10px;
    border-radius: 50px;
    cursor: pointer;
    margin-top: 15px;
    transition: background-color 0.2s ease;
}

.blog-intro .search-input-blog .filters-form .filters-apply:hover {
    opacity: 0.9;
}

.blog-intro .switch-label {
    color: #EFCFD1;
}

.blog-intro .switch-label .switch-slider {
    position: relative;
    width: 40px;
    height: 22px;
    background-color: #e3e3e3;
    border-radius: 20px;
    margin-right: 12px;
    transition: background 0.3s;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.07);
    flex-shrink: 0;
}

.blog-intro .switch-label .switch-slider::before {
    content: "";
    position: absolute;
    left: 2px;
    top: 2px;
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 50%;
    transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.13);
}

.blog-intro .switch-checkbox:checked + .switch-label .switch-slider {
    background-color: #EFCFD1;
}

.blog-intro label {
    font-weight: 700;
    color: #EFCFD1;
}

.blog-intro select {
    border: solid 1px #EFCFD1;
    color: #EFCFD1;
}

.blog-articles {
    padding-top: unset;
}


.container__links_categories {
    display: flex;
    gap: 15px;
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: 25px;
}

@media (max-width: 1024px) {
    gap: 12.5px;
    margin-bottom: 22.5px;
}

@media (max-width: 768px) {
    gap: 10px;
    margin-bottom: 20px;
}

.container__links_categories p {
    cursor: pointer;
    padding: 10px;
}

@media (max-width: 1024px) {
    padding: 8px;
}

@media (max-width: 768px) {
    padding: 6px;
}

/*Style blog_intro end*/

/*Style Apropos update start*/
.dashboard-inner-form {
    margin: 0 auto;
    max-width: 700px;
}

@media (max-width: 1024px) {
    .dashboard-inner-form {
        max-width: 450px;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form {
        max-width: 300px;
    }
}

.dashboard-inner-form .section-dynamique {
    /* Conteneur général des cellules */
    /* Cellule individuelle */
    /* Actions (icônes) */
    /* Corps de la cellule */
}

.dashboard-inner-form .section-dynamique {
    margin-top: 86px;
}

@media (max-width: 1024px) {
    .dashboard-inner-form .section-dynamique {
        margin-top: 84px;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique {
        margin-top: 82px;
    }
}

.dashboard-inner-form .section-dynamique .section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.dashboard-inner-form .section-dynamique label {
    margin: unset;
}

.dashboard-inner-form .section-dynamique .section-header {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .dashboard-inner-form .section-dynamique .section-header {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .section-header {
        margin-bottom: 8px;
    }
}

.dashboard-inner-form .section-dynamique .section-header .container_button button {
    background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
    color: #FFFFFF;
    margin: unset;
}

.dashboard-inner-form .section-dynamique .section-header .container_button button:hover {
    opacity: 0.9;
}

.dashboard-inner-form .section-dynamique .section-header .container_button button, .dashboard-inner-form .section-dynamique .section-header .container_button span {
    font-size: 0.8rem;
}

@media (max-width: 1024px) {
    .dashboard-inner-form .section-dynamique .section-header .container_button button, .dashboard-inner-form .section-dynamique .section-header .container_button span {
        font-size: 0.7rem;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .section-header .container_button button, .dashboard-inner-form .section-dynamique .section-header .container_button span {
        font-size: 0.6rem;
    }
}

.dashboard-inner-form .section-dynamique .content-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
}

@media (max-width: 1024px) {
    .dashboard-inner-form .section-dynamique .content-grid {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .content-grid {
        gap: 6px;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .content-grid {
        display: block;
    }
}

.dashboard-inner-form .section-dynamique .content-cell {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-radius: 50px;
    background-image: linear-gradient(90deg, rgba(169, 203, 183, 0.38), rgba(126, 191, 141, 0.38));
    color: #4C4C4C;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    transition: background-color 0.2s ease;
    flex-shrink: 0;
    gap: 10px;
    font-size: 0.8rem;
}

@media (max-width: 1024px) {
    .dashboard-inner-form .section-dynamique .content-cell {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .content-cell {
        gap: 6px;
    }
}

.dashboard-inner-form .section-dynamique .content-cell {
    padding: 15px;
}

@media (max-width: 1024px) {
    .dashboard-inner-form .section-dynamique .content-cell {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .content-cell {
        padding: 10px;
    }
}

@media (max-width: 1024px) {
    .dashboard-inner-form .section-dynamique .content-cell {
        font-size: 0.7rem;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .content-cell {
        font-size: 0.6rem;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .content-cell {
        margin: 0 auto;
    }

    .dashboard-inner-form .section-dynamique .content-cell {
        margin-bottom: 12px;
    }
}

@media (max-width: 768px) and (max-width: 1024px) {
    .dashboard-inner-form .section-dynamique .content-cell {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) and (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .content-cell {
        margin-bottom: 8px;
    }
}

.dashboard-inner-form .section-dynamique .cell-actions {
    display: flex;
    gap: 10px;
}

@media (max-width: 1024px) {
    .dashboard-inner-form .section-dynamique .cell-actions {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .cell-actions {
        gap: 6px;
    }
}

.dashboard-inner-form .section-dynamique .cell-actions button {
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    cursor: pointer;
    border-radius: 50%;
    background-color: #FFFFFF;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
    transition: background-color 0.2s ease;
    height: 40px;
    width: 40px;
}

@media (max-width: 1024px) {
    .dashboard-inner-form .section-dynamique .cell-actions button {
        height: 35px;
        width: 35px;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .cell-actions button {
        height: 30px;
        width: 30px;
    }
}

.dashboard-inner-form .section-dynamique .cell-actions button {
    padding: 8px;
}

@media (max-width: 1024px) {
    .dashboard-inner-form .section-dynamique .cell-actions button {
        padding: 7px;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .cell-actions button {
        padding: 6px;
    }
}

.dashboard-inner-form .section-dynamique .cell-actions button:hover {
    background-color: #f1f1f1;
}

.dashboard-inner-form .section-dynamique .cell-body {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.dashboard-inner-form .section-dynamique .cell-body p, .dashboard-inner-form .section-dynamique span {
    font-size: 0.8rem;
    margin: unset;
}

@media (max-width: 1024px) {
    .dashboard-inner-form .section-dynamique .cell-body p, .dashboard-inner-form .section-dynamique span {
        font-size: 0.7rem;
    }
}

@media (max-width: 768px) {
    .dashboard-inner-form .section-dynamique .cell-body p, .dashboard-inner-form .section-dynamique span {
        font-size: 0.6rem;
    }
}

/*Style Apropos update end*/

/*Style Apropos start*/
/* ========== INTRO (2 COLS) ========== */
.apropos-intro {
    background-color: #FFFFFF;
    /* Col media (desktop) */
    /* Bloc stats */
    /* Palette sur fond sombre (tablet) */
}

.apropos-intro__container {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
    gap: 50px;
    /* Par défaut : l’image mobile est cachée */
}

@media (max-width: 1024px) {
    .apropos-intro__container {
        padding: 22.5px 20px;
    }
}

@media (max-width: 768px) {
    .apropos-intro__container {
        padding: 20px 30px;
    }
}

@media (max-width: 1024px) {
    .apropos-intro__container {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .apropos-intro__container {
        gap: 25px;
    }
}

.apropos-intro__container .apropos-intro__image-mobile {
    display: none;
}

@media (max-width: 1200px) {
    .apropos-intro__container {
        flex-direction: column;
        align-items: stretch;
        /* On masque la version desktop et on active la version mobile */
    }

    .apropos-intro__container .apropos-intro__image-desktop {
        display: none;
    }

    .apropos-intro__container .apropos-intro__image-mobile {
        position: absolute;
        inset: 0;
        display: block;
        z-index: 0;
        border-radius: 15px;
        overflow: hidden;
        /* Overlay sombre */
    }

    .apropos-intro__container .apropos-intro__image-mobile::before {
        content: "";
        position: absolute;
        inset: 0;
        background-color: rgba(0, 0, 0, 0.45);
        backdrop-filter: blur(2px);
        z-index: 1;
    }

    .apropos-intro__container .apropos-intro__image-mobile img {
        inline-size: 100%;
        block-size: 100%;
        object-fit: cover;
    }
}

.apropos-intro__col--media {
    flex: 0 0 auto;
}

.apropos-intro__col--content {
    position: relative;
    z-index: 2; /* au-dessus de l’image mobile */
}

.apropos-intro__figure {
    display: block;
    border-radius: 15px;
    overflow: hidden;
}

.apropos-intro__image {
    display: block;
    object-fit: cover;
    object-position: center;
    height: 450px;
    width: 450px;
}

@media (max-width: 1024px) {
    .apropos-intro__image {
        height: 400px;
        width: 400px;
    }
}

@media (max-width: 768px) {
    .apropos-intro__image {
        height: 400px;
        width: 400px;
    }
}

.apropos-intro__header {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .apropos-intro__header {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .apropos-intro__header {
        margin-bottom: 8px;
    }
}

.apropos-intro__title {
    color: #4C4C4C;
}

.apropos-intro__richtext {
    color: #4C4C4C;
}

.apropos-intro__stats {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: stretch;
    gap: 50px;
}

@media (max-width: 1024px) {
    .apropos-intro__stats {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .apropos-intro__stats {
        gap: 25px;
    }
}

.apropos-intro__stat {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    min-inline-size: 0;
    flex: 1 1 auto;
    background-color: #FFFFFF;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1); /* Ombre douce */
    border-radius: 10px;
}

.apropos-intro__stat {
    padding: 25px;
}

@media (max-width: 1024px) {
    .apropos-intro__stat {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .apropos-intro__stat {
        padding: 15px;
    }
}

@media (max-width: 1200px) {
    .apropos-intro__stat {
        background-color: rgba(255, 255, 255, 0.12);
    }
}

.apropos-intro__stat-value {
    font-weight: 700;
    color: #A9CBB7;
    font-size: 2.5rem;
}

@media (max-width: 1024px) {
    .apropos-intro__stat-value {
        font-size: 2rem;
    }
}

@media (max-width: 768px) {
    .apropos-intro__stat-value {
        font-size: 1.5rem;
    }
}

.apropos-intro__stat-value {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .apropos-intro__stat-value {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .apropos-intro__stat-value {
        margin-bottom: 8px;
    }
}

.apropos-intro__stat-label {
    color: #4C4C4C;
    opacity: 0.9;
}

@media (max-width: 1200px) {
    .apropos-intro__stat-label {
        color: #FFFFFF;
        opacity: 1;
    }
}

@media (max-width: 1200px) {
    .apropos-intro__title, .apropos-intro__richtext {
        color: #FFFFFF;
    }
}

/* ========== VALEURS (GRID DE CARTES) ========== */
.values {
    /* Col media (desktop) */
    /* Bloc stats */
    /* Palette sur fond sombre (tablet) */
}

.values__container {
    /* conteneur logique : on s’appuie sur les paddings globaux */
}

.values__header {
    text-align: center;
}

.values__header {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .values__header {
        margin-bottom: 40px;
    }
}

@media (max-width: 768px) {
    .values__header {
        margin-bottom: 30px;
    }
}

.values__title {
    color: #4C4C4C;
}

.values__intro {
    max-inline-size: 90ch;
    margin-inline: auto;
    color: #4C4C4C;
    opacity: 0.85;
}

.values__grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: stretch;
    gap: 50px;
}

@media (max-width: 1024px) {
    .values__grid {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .values__grid {
        gap: 25px;
    }
}

.values__item {
    width: 100%;
    max-width: 320px;
    display: flex; /* permet à la carte de s’étirer sur la hauteur */
    flex: 0 0 auto; /* largeur égale entre items sur la ligne */
}

/* Sous-composant : carte valeur */
.value-card {
    backdrop-filter: blur(5px);
    background-color: #FFFFFF;
    border-radius: 15px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    border: 1px solid rgba(255, 255, 255, 0.3); /* Bordure subtile */
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1); /* Ombre douce */
    gap: 10px;
}

.value-card {
    padding: 25px;
}

@media (max-width: 1024px) {
    .value-card {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .value-card {
        padding: 15px;
    }
}

@media (max-width: 1024px) {
    .value-card {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .value-card {
        gap: 6px;
    }
}

.value-card__title {
    color: #a1c4fd;
    font-weight: 700;
}

.value-card__text {
    color: #4C4C4C;
}

/* ========== ORGANIGRAMME (TITRE + DESC + IMAGE) ========== */
.org {
    background-color: #FFFFFF;
    /* Col media (desktop) */
    /* Bloc stats */
    /* Palette sur fond sombre (tablet) */
}

.org__header {
    text-align: center;
}

.org__header {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .org__header {
        margin-bottom: 50px;
    }
}

@media (max-width: 768px) {
    .org__header {
        margin-bottom: 50px;
    }
}

.org__title {
    color: #4C4C4C;
}

.org__intro {
    max-inline-size: 90ch;
    margin-inline: auto;
    color: #4C4C4C;
    opacity: 0.85;
}

.org__figure {
    display: block;
    text-align: center;
    overflow: auto; /* autorise un scroll si l’image dépasse dans un sens */
    -webkit-overflow-scrolling: touch;
    /* Arrondi cohérent avec le design system */
    border-radius: 10px;
}

.org__figure {
    margin-top: 100px;
}

@media (max-width: 1024px) {
    .org__figure {
        margin-top: 75px;
    }
}

@media (max-width: 768px) {
    .org__figure {
        margin-top: 50px;
    }
}

@media (max-width: 1024px) {
    .org__figure {
        border-radius: 8px;
    }
}

@media (max-width: 768px) {
    .org__figure {
        border-radius: 6px;
    }
}

.org__image {
    display: inline-block;
    vertical-align: top;
    object-fit: contain;
    object-position: center;
    /* Ne dépasse jamais la largeur dispo */
    max-inline-size: 100%;
    inline-size: auto;
    block-size: auto;
    /* Option “fit-height” progressive : on borne la hauteur par breakpoint
       (préserve la lisibilité sans écraser l’image). Si le visuel est plus grand,
       le figure passera en scroll grâce à overflow:auto. */
}

@media (max-width: 1200px) {
    .org__image {
        /* borne haute desktop issue du DS si définie */
    }
}

.org__caption {
    color: #4C4C4C;
    text-align: center;
}

.org__caption {
    margin-top: 12px;
}

@media (max-width: 1024px) {
    .org__caption {
        margin-top: 10px;
    }
}

@media (max-width: 768px) {
    .org__caption {
        margin-top: 8px;
    }
}

/* ---------- Variante de repli (au cas où) ----------
   À appliquer sur <figure class="org__figure org__figure--fit-height">
   Force l’image à “coller” à la hauteur bornée si nécessaire, tout en
   gardant un repli scroll pour explorer le visuel. */
.org__figure--fit-height {
    overflow: auto;
}

.org__figure--fit-height .org__image {
    /* on privilégie le maintien de la hauteur max */
    inline-size: auto;
    max-inline-size: 100%;
    /* déjà bornée par image_fit_height via les règles ci-dessus */
}

/*Style Apropos end*/


/*Style contact cta start*/
.contact-cta {
    background: linear-gradient(
            180deg,
            #ffffff 0%,
            #ffffff 80%,
            #f2fbe9 90%,
            #daefd9 100%
    );
    /*color: #FFFFFF;*/
    padding: 100px 5%;
}


@media (max-width: 1024px) {
    .contact-cta {
        padding: 70px 5%;
    }
}

@media (max-width: 768px) {
    .contact-cta {
        padding: 50px 5%;
    }
}

.contact-cta__container {
    display: flex;
    align-items: center; /* centrage vertical du contenu + bouton */
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 50px;
}

@media (max-width: 1024px) {
    .contact-cta__container {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .contact-cta__container {
        gap: 25px;
    }
}

@media (max-width: 1024px) {
    .contact-cta__container {
        flex-direction: column; /* pile sur petit écran */
        align-items: stretch;
        gap: 10px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .contact-cta__container {
        gap: 8px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .contact-cta__container {
        gap: 6px;
    }
}

.contact-cta__content {
    max-width: 700px;
}

.contact-cta__title {
    color: #4C4C4C;
}

.contact-cta__title {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .contact-cta__title {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .contact-cta__title {
        margin-bottom: 8px;
    }
}

.contact-cta__text {
    color: #4C4C4C;
}

.contact-cta__action {
    display: flex;
    align-items: center;
    justify-content: center;
}

@media (max-width: 1024px) {
    .contact-cta__action {
        margin-top: 24px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .contact-cta__action {
        margin-top: 22px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .contact-cta__action {
        margin-top: 20px;
    }
}

.contact-cta__button {
    color: #4C4C4C;
    background: rgba(218, 218, 218, 0.5);
    backdrop-filter: blur(45px);
    background-size: cover;
    font-weight: 700;
    border-radius: 50px;
    transition: background 0.2s ease-in-out, color 0.2s ease-in-out;
    display: flex;
    align-items: center;
    gap: 15px;
}

.contact-cta__button:hover {
    opacity: 0.8;
}

.contact-cta__button {
    padding: 15px;
}

@media (max-width: 1024px) {
    .contact-cta__button {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .contact-cta__button {
        padding: 10px;
    }
}

@media (max-width: 1024px) {
    .contact-cta__button {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .contact-cta__button {
        gap: 10px;
    }
}

/*Style contact cta end*/


/*Style footer start*/
.transition-footer {
    height: 300px;
    width: 100%;
    background: linear-gradient(
            180deg,
            #ffffff 0%,
            #ffffff 80%,
            #f2fbe9 90%,
            #daefd9 100%
    );
}

.site-footer {
    color: #4C4C4C;
    background: linear-gradient(
            180deg,
            #daefd9 0%,
            #d4e9d3 25%,
            #cce3cd 50%,
            #c0dcc4 75%,
            #b5d6bc 100%
    );
}

.site-footer__top {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 50px;
}

@media (max-width: 1024px) {
    .site-footer__top {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .site-footer__top {
        gap: 25px;
    }
}

@media (max-width: 1024px) {
    .site-footer__top {
        flex-direction: column;
    }
}

.site-footer__col {
    display: flex;
    flex-direction: column;
    /* largeur flexible, parts égales, repli si manque d’espace */
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 0;
}

.site-footer__col--links ul, .site-footer__list, .site-footer__social {
    list-style-type: none;
}

@media (max-width: 1024px) {
    .site-footer__col {
        /* en pile sur petit écran */
        min-inline-size: 0;
    }
}

.site-footer__title {
    font-weight: 700;
}

.site-footer__title {
    margin-bottom: 20px;
}

@media (max-width: 1024px) {
    .site-footer__title {
        margin-bottom: 16px;
    }
}

@media (max-width: 768px) {
    .site-footer__title {
        margin-bottom: 12px;
    }
}

.site-footer__list {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

@media (max-width: 1024px) {
    .site-footer__list {
        gap: 15px;
    }
}

@media (max-width: 768px) {
    .site-footer__list {
        gap: 10px;
    }
}

@media (max-width: 1024px) {
    .site-footer__list {
        padding: 30px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .site-footer__list {
        padding: 20px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .site-footer__list {
        padding: 30px;
    }
}


.site-footer__address {
    font-style: normal;
    display: flex;
    flex-direction: column;
    padding-inline-start: 2.5rem;
    gap: 20px;
}

@media (max-width: 1024px) {
    .site-footer__address {
        gap: 15px;
        padding-inline-start: 2rem;
    }
}

@media (max-width: 768px) {
    .site-footer__address {
        gap: 10px;
        padding-inline-start: 1.5rem;
    }
}

@media (max-width: 1024px) {
    .site-footer__address {
        padding: 30px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .site-footer__address {
        padding: 20px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .site-footer__address {
        padding: 30px;
    }
}

.site-footer__link {
    position: relative;
    display: inline-block;
    text-decoration: none;
    color: #4C4C4C;
}

.site-footer__link::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    height: 2px;
    width: 100%;
    background-color: #4C4C4C;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease-in-out;
}

.site-footer__link:hover::after {
    transform: scaleX(1);
}

.site-footer__link--highlight {
    font-weight: 700;
}

.site-footer__social {
    display: flex;
    align-items: center;
    gap: 10px;
}

@media (max-width: 1024px) {
    .site-footer__social {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .site-footer__social {
        gap: 6px;
    }
}

@media (max-width: 1024px) {
    .site-footer__social {
        padding: 30px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .site-footer__social {
        padding: 20px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .site-footer__social {
        padding: 30px;
    }
}

.site-footer__icon {
    border-radius: 50px;
    background-color: #FFFFFF;
    height: 40px;
    width: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.site-footer__icon {
    padding: 15px;
}

@media (max-width: 1024px) {
    .site-footer__icon {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .site-footer__icon {
        padding: 10px;
    }
}

@media (max-width: 1024px) {
    .site-footer__icon {
        height: 35px;
        width: 35px;
    }
}

@media (max-width: 768px) {
    .site-footer__icon {
        height: 30px;
        width: 30px;
    }
}

.site-footer__icon:hover {
    background-color: rgba(255, 255, 255, 0.8);
}

.site-footer__icon img {
    object-fit: contain;
    height: 100%;
    width: 100%;
}

.site-footer__bottom {
    /* séparation visuelle douce : utiliser un pseudo au lieu d’une bordure en px */
    position: relative;
    padding: 100px 5%;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

@media (max-width: 1024px) {
    .site-footer__bottom {
        padding: 70px 5%;
    }
}

@media (max-width: 768px) {
    .site-footer__bottom {
        padding: 50px 5%;
    }
}

.site-footer__bottom::before {
    content: "";
    display: block;
    inline-size: 100%;
    /* token “hairline” attendu dans le DS */
    opacity: 0.6;
    /* place la ligne au-dessus de la bande */
    position: absolute;
    inset-inline-start: 0;
    inset-block-start: 0;
}

.site-footer__hotline {
    font-weight: 700;
}

.site-footer__copyright {
    opacity: 0.9;
}

.site-footer a {
    color: #4C4C4C;
}

/*Style end footer*/

/*Style hebergements start*/
.hebergement-intro {
    /* Colonnes */
    /* Figure / Image desktop */
    /* Header + body (palette par défaut) */
    /* Palette lisible sur fond sombre en tablet (overlay actif) */
}

.hebergement-intro__container {
    position: relative;
    display: flex;
    border-radius: 15px;
    overflow: hidden;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 50px;
    /* Par défaut : l’image mobile est cachée */
}

@media (max-width: 1024px) {
    .hebergement-intro__container {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .hebergement-intro__container {
        gap: 25px;
    }
}

.hebergement-intro__container .hebergement-intro__image-mobile {
    display: none;
}

@media (max-width: 1024px) {
    .hebergement-intro__container {
        flex-direction: column;
        align-items: stretch;
        /* Masquer la version desktop et activer la version mobile en fond */
    }

    .hebergement-intro__container .hebergement-intro__image-desktop {
        display: none;
    }

    .hebergement-intro__container .hebergement-intro__image-mobile {
        position: absolute;
        inset: 0;
        display: block;
        z-index: 0;
        overflow: hidden;
        /* Overlay sombre + léger blur */
    }

    .hebergement-intro__container .hebergement-intro__image-mobile::before {
        content: "";
        position: absolute;
        inset: 0;
        background-color: rgba(0, 0, 0, 0.45);
        backdrop-filter: blur(2px);
        z-index: 1;
    }

    .hebergement-intro__container .hebergement-intro__image-mobile img {
        inline-size: 100%;
        block-size: 100%;
        object-fit: cover;
    }
}

.hebergement-intro__col--media {
    /* évite le shrink de l’image en desktop */
    flex-grow: 0;
    flex-shrink: 0;
    flex-basis: auto;
}

.hebergement-intro__col--content {
    position: relative; /* au-dessus de l’image mobile */
    z-index: 2;
    /* largeur flexible explicite */
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 0;
}

.hebergement-intro__figure {
    display: block;
    overflow: hidden;
    border-radius: 15px;
}

.hebergement-intro__image {
    display: block;
    object-fit: cover;
    object-position: center;
    height: 450px;
    width: 450px;
    /* token de dimension du DS */
}

@media (max-width: 1024px) {
    .hebergement-intro__image {
        height: 400px;
        width: 400px;
    }
}

@media (max-width: 768px) {
    .hebergement-intro__image {
        height: 400px;
        width: 400px;
    }
}

.hebergement-intro__header {
    text-align: start;
}

.hebergement-intro__header {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .hebergement-intro__header {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .hebergement-intro__header {
        margin-bottom: 8px;
    }
}

.hebergement-intro__title {
    color: #4C4C4C;
}

.hebergement-intro__body {
    color: #4C4C4C;
}

.hebergement-intro__text {
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .hebergement-intro {
        /* Contenu pleine largeur + fond transparent sur image */
    }

    .hebergement-intro__header, .hebergement-intro__body {
        text-align: start; /* laisse ta mise en page décider, pas centré par défaut */
    }

    .hebergement-intro__title, .hebergement-intro__text {
        color: #FFFFFF;
    }

    .hebergement-intro__col--content {
        inline-size: 100%;
        background-color: transparent;
        border-radius: 0;
        /* Option : donner de la respiration au texte sur fond image */
    }

    .hebergement-intro__col--content {
        padding: 100px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .hebergement-intro__col--content {
        padding: 70px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .hebergement-intro__col--content {
        padding: 50px;
    }
}


/* =========================
   ESPACES DE VIE
   ========================= */
.espaces {
    padding: 100px 5%;
}

@media (max-width: 1024px) {
    .espaces {
        padding: 70px 5%;
    }
}

@media (max-width: 768px) {
    .espaces {
        padding: 50px 5%;
    }
}

.espaces__container {
    display: flex;
    flex-direction: column;
    gap: 50px;
}

@media (max-width: 1024px) {
    .espaces__container {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .espaces__container {
        gap: 25px;
    }
}

.espaces__header {
    color: #4C4C4C;
    text-align: center;
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .espaces__header {
        margin-bottom: 40px;
    }
}

@media (max-width: 768px) {
    .espaces__header {
        margin-bottom: 30px;
    }
}


.espaces__text {
    max-inline-size: 90ch;
    margin-inline: auto;
    opacity: 0.85;
}

.espaces__list {
    display: flex;
    flex-direction: column;
    gap: 50px;
}

@media (max-width: 1024px) {
    .espaces__list {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .espaces__list {
        gap: 25px;
    }
}

/* ====== Carte espace ====== */
.espaces-card {
    position: relative;
    display: flex;
    align-items: stretch;
    border-radius: 50px;
    overflow: hidden;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
    /* on s’assure que l’image desktop est visible par défaut */
    /* Media (gauche) */
    /* Contenu (droite) */
    /* === Correctif tablet : le contenu prend TOUTE la largeur, sur image en fond === */
    min-block-size: 350px;
}

.espaces-card__image-mobile {
    display: none;
}

.espaces-card__media .espaces-card__image-desktop {
    display: block;
}

.espaces-card__media {
    position: relative;
    overflow: hidden;
    /* largeur flexible explicite */
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 0;
    min-block-size: unset;
}

.espaces-card__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

/*.espaces-card__media > .espaces-card__image-desktop,*/
/*.espaces-card__media > img.espaces-card__image-desktop {*/
/*  position: absolute;*/
/*  inset: 0;*/
/*  width: 100%;*/
/*  height: 100%;*/
/*  object-fit: cover;*/
/*  object-position: center;*/
/*  display: block;*/
/*}*/

.espaces-card__content {
    background-color: #FFFFFF;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 20px;
    /* largeur flexible explicite */
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 0;
}

@media (max-width: 1024px) {
    .espaces-card__content {
        gap: 15px;
    }
}

@media (max-width: 768px) {
    .espaces-card__content {
        gap: 10px;
    }
}

.espaces-card__content {
    padding: 25px;
}

@media (max-width: 1024px) {
    .espaces-card__content {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .espaces-card__content {
        padding: 15px;
    }
}

.espaces-card__title {
    color: #4C4C4C;
}

.espaces-card__description {
    color: #4C4C4C;
}

.espaces-card__bottom h4 {
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .espaces-card__bottom h3 {
        color: #FFFFFF;
    }
}

.espaces-card__actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    font-weight: 700;
    border-radius: 50px;
}

.espaces-card__actions a {
    color: #FFFFFF;
    background: linear-gradient(90deg, #7EBF8D, #A9CBB7);
    border-radius: 50px;
}

.espaces-card__actions a {
    margin-top: 24px;
}

@media (max-width: 1024px) {
    .espaces-card__actions a {
        margin-top: 22px;
    }
}

@media (max-width: 768px) {
    .espaces-card__actions a {
        margin-top: 20px;
    }
}

.espaces-card__actions a {
    padding: 15px;
}

@media (max-width: 1024px) {
    .espaces-card__actions a {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .espaces-card__actions a {
        padding: 10px;
    }
}

.espaces-card__actions a:hover {
    opacity: 0.8;
}

@media (max-width: 1024px) {
    .espaces-card .espaces-card {
        position: relative;
        display: block; /* le conteneur devient un bloc plein */
        inline-size: 100%; /* occupe toute la largeur disponible */
        min-inline-size: 0; /* évite toute contrainte résiduelle */
        /* on masque l’image desktop et on active l’image mobile en fond */
        /* >>> Le contenu couvre 100% de la carte, fond transparent sur l’overlay <<< */
        /* Texte lisible en blanc sur le fond sombre */
        /* CTA aligné à gauche en plein écran */
    }

    .espaces-card .espaces-card__media {
        border-radius: 0;
        display: none;
    }

    .espaces-card .espaces-card__image-mobile {
        position: absolute;
        inset: 0;
        display: block;
        z-index: 0;
        overflow: hidden;
    }

    .espaces-card .espaces-card__image-mobile::before {
        content: "";
        position: absolute;
        inset: 0;
        background-color: rgba(0, 0, 0, 0.45);
        backdrop-filter: blur(2px);
        z-index: 1;
    }

    .espaces-card .espaces-card__image-mobile img {
        inline-size: 100%;
        block-size: 100%;
        object-fit: cover;
    }

    .espaces-card .espaces-card__content {
        min-height: 300px;
        position: relative;
        z-index: 2; /* au-dessus de l’overlay */
        background: unset;
        gap: 20px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .espaces-card .espaces-card__content {
        gap: 15px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .espaces-card .espaces-card__content {
        gap: 10px;
    }
}

@media (max-width: 1024px) {
    .espaces-card .espaces-card__content {
        padding: 25px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .espaces-card .espaces-card__content {
        padding: 20px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .espaces-card .espaces-card__content {
        padding: 15px;
    }
}

@media (max-width: 1024px) {
    .espaces-card .espaces-card__title, .espaces-card .espaces-card__description {
        color: #FFFFFF;
    }

    .espaces-card .espaces-card__description {
        display: -webkit-box;
        -webkit-line-clamp: 5; /* nombre de lignes à afficher */
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .espaces-card .espaces-card__actions {
        display: flex;
        align-items: center;
        justify-content: flex-end;
    }

    .espaces-card .espaces-card__actions a {
        border-radius: 50px;
    }
}

/*Style hebergements end*/


/*Style services_intro start*/
/* Adapte les chemins RELATIFS à ton CSS compilé, pas au HTML.
   Idéalement renomme tes fichiers sans accents. */

/* valeurs par défaut (avant que le JS ne les mette à jour) */
.services-carousel {
    --offset: 0%;
    --scale: 1;
    --opacity: 1;
    --z: 1;
    --pe: none; /* cartes non interactives tant que le JS n’a pas centré */
}

.services-soins {
    --bg-image: none;
}

.services-hebergements {
    --bg-image: none;
}

.services-instances {
    --bg-image: none;
}

.services-activites {
    --bg-image: none;
}

/* =======================
   Section
   ======================= */
.services-carousel {
    color: #4C4C4C;
    overflow-y: auto; /* évite le clipping pendant les anims */
    overflow-x: hidden;
    /* Viewport = scène du carousel */
    /* Piste */
    /* Flèches */
}

.services-carousel {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .services-carousel {
        margin-bottom: 40px;
    }
}

@media (max-width: 768px) {
    .services-carousel {
        margin-bottom: 30px;
    }
}

.services-carousel__intro {
    text-align: center;
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    margin-bottom: 40px;
}

@media (max-width: 768px) {
    margin-bottom: 30px;
}

.services-carousel__text {
    opacity: 0.85;
}

.services-carousel__viewport {
    position: relative;
    overflow: visible; /* on laisse dépasser les cartes latérales */
    gap: 50px;
}

@media (max-width: 1024px) {
    .services-carousel__viewport {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .services-carousel__viewport {
        gap: 25px;
    }
}

.services-carousel__track {
    position: relative;
    /* NEW: sizer -> donne une hauteur stable, identique à une card */
}

.services-carousel__track::before {
    content: "";
    display: block;
    width: 100%;
    height: 450px;
    /* même hauteur responsive que les cards */
    aspect-ratio: 4/5; /* même ratio */
    visibility: hidden;
    pointer-events: none;
}

@media (max-width: 1024px) {
    .services-carousel__track::before {
        height: 400px;
    }
}

@media (max-width: 768px) {
    .services-carousel__track::before {
        height: 350px;
    }
}

.services-carousel__arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 12;
    border: none;
    cursor: pointer;
    background: #FFFFFF;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #4C4C4C;
    border-radius: 50px;
    box-shadow: 0 0.6em 1.4em rgba(0, 0, 0, 0.12);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.services-carousel__arrow {
    padding: 15px;
}

@media (max-width: 1024px) {
    .services-carousel__arrow {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .services-carousel__arrow {
        padding: 10px;
    }
}

.services-carousel__arrow:hover {
    transform: translateY(-50%) scale(1.06);
}

.services-carousel__arrow--prev {
    left: 0.25rem;
}

.services-carousel__arrow--next {
    right: 0.25rem;
}

.services-carousel__arrow-ico {
    display: inline-block;
    line-height: 1;
}

/* =======================
   Card
   ======================= */
.services-card {
    position: absolute;
    top: 0;
    left: 50%;
    /* transform piloté par VARIABLES CSS définies en JS */
    transform: translateX(calc(-50% + var(--offset, 0%))) scale(var(--scale, 1));
    opacity: var(--opacity, 1);
    z-index: var(--z, 1);
    pointer-events: var(--pe, none);
    border-radius: 1rem;
    overflow: hidden;
    isolation: isolate;
    height: 450px;
    aspect-ratio: 4/5;
    background-image: var(--bg-image, none); /* fallback none si non défini */
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    transition: transform 0.6s cubic-bezier(0.25, 0.8, 0.25, 1), opacity 0.6s ease;
    will-change: transform;
    /* contenu interne (ta demande) */
    /* hover actif quand la carte est centrale (JS met --pe:auto) */
}

@media (max-width: 1024px) {
    .services-card {
        height: 400px;
    }
}

@media (max-width: 768px) {
    .services-card {
        height: 350px;
    }
}

.services-card::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: url("../../../../media/none_image.png");
    background-size: contain;
    z-index: 0;
    pointer-events: none;
    opacity: 1;
    transition: opacity 0.35s ease;
}

.services-card__cta-ico {
    transition: transform 0.2s ease-in-out;
}

.services-card__content {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-end;
    position: relative;
    z-index: 1;
}

.services-card__content {
    padding: 25px;
}

@media (max-width: 1024px) {
    .services-card__content {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .services-card__content {
        padding: 15px;
    }
}

.services-card__title {
    margin-block: auto;
    align-self: center;
    color: #FFFFFF;
    background: rgba(0, 0, 0, 0.25);
    border-radius: 0.8em;
    backdrop-filter: blur(0.2em);
    text-align: center;
    font-weight: 600;
    letter-spacing: 0.02em;
    line-height: 1;
}

.services-card__title {
    padding: 15px;
}

@media (max-width: 1024px) {
    .services-card__title {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .services-card__title {
        padding: 10px;
    }
}

.services-card__cta {
    align-self: flex-end;
    color: #FFFFFF;
    border-radius: 50px;
    display: flex;
    gap: 15px;
    text-decoration: none;
}

@media (max-width: 1024px) {
    .services-card__cta {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .services-card__cta {
        gap: 10px;
    }
}

.services-card__cta {
    padding: 15px;
}

@media (max-width: 1024px) {
    .services-card__cta {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .services-card__cta {
        padding: 10px;
    }
}

.services-card:hover, .services-card:focus-visible {
    transform: translateX(calc(-50% + var(--offset, 0%))) translateY(-0.25em) scale(calc(var(--scale, 1) + 0.02));
}

.services-card:hover .services-card__cta-ico, .services-card:focus-visible .services-card__cta-ico {
    transform: translateX(0.35em); /* “vers le texte” (l’icône est à droite) */
    opacity: 0.95;
}

.services-card:hover::before, .services-card:focus-visible::before {
    opacity: 1;
    transform: translate3d(8%, -8%, 0);
}

/*Style services_intro end*/


/*Style services_intro end*/
/* =======================
   Section Soins
   ======================= */
.soins-intro {
    /* Colonnes (texte à gauche, image à droite en desktop) */
    /* Figure / Image desktop */
    /* Header + body (palette par défaut) */
    /* Palette lisible sur fond sombre en tablet (overlay actif) */
}

.soins-intro__container {
    position: relative;
    display: flex;
    border-radius: 15px;
    overflow: hidden;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 50px;
    /* Par défaut : l’image mobile est cachée */
}

@media (max-width: 1024px) {
    .soins-intro__container {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .soins-intro__container {
        gap: 25px;
    }
}

.soins-intro__container .soins-intro__image-mobile {
    display: none;
}

@media (max-width: 1024px) {
    .soins-intro__container {
        flex-direction: column;
        align-items: stretch;
        /* Masquer la version desktop et activer la version mobile en fond */
    }

    .soins-intro__container .soins-intro__image-desktop {
        display: none;
    }

    .soins-intro__container .soins-intro__image-mobile {
        position: absolute;
        inset: 0;
        display: block;
        z-index: 0;
        overflow: hidden;
    }

    .soins-intro__container .soins-intro__image-mobile::before {
        content: "";
        position: absolute;
        inset: 0;
        background-color: rgba(0, 0, 0, 0.45);
        backdrop-filter: blur(2px);
        z-index: 1;
    }

    .soins-intro__container .soins-intro__image-mobile img {
        inline-size: 100%;
        block-size: 100%;
        object-fit: cover;
    }
}

.soins-intro__col--content {
    position: relative;
    z-index: 2;
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 0; /* colonne flexible */
    /* Laisser le texte sur fond transparent en desktop */
}

.soins-intro__col--media {
    flex-grow: 0;
    flex-shrink: 0;
    flex-basis: auto; /* évite le shrink de l’image */
}

.soins-intro__figure {
    display: block;
    overflow: hidden;
    border-radius: 15px;
}

.soins-intro__image {
    display: block;
    object-fit: cover;
    object-position: center;
    height: 450px;
    width: 450px;
}

@media (max-width: 1024px) {
    .soins-intro__image {
        height: 400px;
        width: 400px;
    }
}

@media (max-width: 768px) {
    .soins-intro__image {
        height: 400px;
        width: 400px;
    }
}

.soins-intro__header {
    text-align: start;
}

.soins-intro__header {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .soins-intro__header {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .soins-intro__header {
        margin-bottom: 8px;
    }
}

.soins-intro__title {
    color: #4C4C4C;
}

.soins-intro__body {
    color: #4C4C4C;
}

.soins-intro__text {
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .soins-intro__header, .soins-intro__body {
        text-align: start;
    }

    .soins-intro__title, .soins-intro__text {
        color: #FFFFFF;
    }

    .soins-intro__col--content {
        inline-size: 100%;
        background-color: transparent;
        border-radius: 0;
    }

    .soins-intro__col--content {
        padding: 100px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .soins-intro__col--content {
        padding: 70px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .soins-intro__col--content {
        padding: 50px;
    }
}

.soins {
    color: #4C4C4C;
}

.soins__list_intro {
    color: #4C4C4C;
    text-align: center;
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    margin-bottom: 40px;
}

@media (max-width: 768px) {
    margin-bottom: 30px;
}

.soins__text {
    opacity: 0.85;
}

.soins__list {
    display: flex;
    flex-direction: column;
    gap: 50px;
    /* espacement entre items */
}

@media (max-width: 1024px) {
    .soins__list {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .soins__list {
        gap: 25px;
    }
}

.soins__list_intro-text {
    opacity: 0.85;
    max-inline-size: 90ch;
    margin-inline: auto;
}

/* =======================
   Item (accordéon)
   ======================= */
.soins-item {
    background: #FFFFFF;
    color: #4C4C4C;
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 0.8em 1.6em rgba(0, 0, 0, 0.06);
    /* Header cliquable */
    /* Panneau (contenu) */
    /* rotate as soon as aria-expanded flips */
}

.soins-item__header {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.8rem;
    cursor: pointer;
    border: 0;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.02) 100%);
    /* ton DS */
    text-align: left;
}

.soins-item__header {
    padding: 25px;
}

@media (max-width: 1024px) {
    .soins-item__header {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .soins-item__header {
        padding: 15px;
    }
}

.soins-item__icon {
    height: 40px;
    width: 40px;
    object-fit: contain;
}

@media (max-width: 1024px) {
    .soins-item__icon {
        height: 35px;
        width: 35px;
    }
}

@media (max-width: 768px) {
    .soins-item__icon {
        height: 30px;
        width: 30px;
    }
}

.soins-item__title {
    margin: 0;
    color: #4C4C4C;
    font-weight: 600;
    font-size: 2rem;
}

@media (max-width: 1024px) {
    .soins-item__title {
        font-size: 1.5rem;
    }
}

@media (max-width: 768px) {
    .soins-item__title {
        font-size: 1rem;
    }
}

.soins-item__content {
    height: 0; /* <- au lieu de max-height */
    overflow: hidden;
    transition: height 0.35s ease; /* <- on anime la height */
    opacity: 0;
}

.soins-item__desc {
    margin: 0 auto;
}

.soins-item__desc {
    padding-top: 0;
}

.soins-item__chevron {
    font-size: 1.5rem;
    line-height: 1;
    color: #4C4C4C;
    transition: transform 0.2s ease;
}

.soins-item .accordion__toggle[aria-expanded=true] .soins-item__chevron,
.soins-item .soins-item.is-open .soins-item__chevron {
    transform: rotate(180deg);
}

.soins-item.is-open .soins-item__content {
    opacity: 1;
}

/*Style end soins*/

/* Style activites start */
.activites-intro {
    /* Colonnes (texte à gauche, image à droite en desktop) */
    /* Figure / Image desktop */
    /* Header + body (palette par défaut) */
    /* Palette lisible sur fond sombre en tablet (overlay actif) */
}

.activites-intro__container {
    position: relative;
    display: flex;
    border-radius: 15px;
    overflow: hidden;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 50px;
    /* Par défaut : l’image mobile est cachée */
}

@media (max-width: 1024px) {
    .activites-intro__container {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .activites-intro__container {
        gap: 25px;
    }
}

.activites-intro__container .activites-intro__image-mobile {
    display: none;
}

@media (max-width: 1024px) {
    .activites-intro__container {
        flex-direction: column;
        align-items: stretch;
        /* Masquer la version desktop et activer la version mobile en fond */
    }

    .activites-intro__container .activites-intro__image-desktop {
        display: none;
    }

    .activites-intro__container .activites-intro__image-mobile {
        position: absolute;
        inset: 0;
        display: block;
        z-index: 0;
        overflow: hidden;
    }

    .activites-intro__container .activites-intro__image-mobile::before {
        content: "";
        position: absolute;
        inset: 0;
        background-color: rgba(0, 0, 0, 0.45);
        backdrop-filter: blur(2px);
        z-index: 1;
    }

    .activites-intro__container .activites-intro__image-mobile img {
        inline-size: 100%;
        block-size: 100%;
        object-fit: cover;
    }
}

.activites-intro__col--content {
    position: relative;
    z-index: 2;
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 0;
}

.activites-intro__col--media {
    flex-grow: 0;
    flex-shrink: 0;
    flex-basis: auto;
}

.activites-intro__figure {
    display: block;
    overflow: hidden;
    border-radius: 15px;
}

.activites-intro__image {
    display: block;
    object-fit: cover;
    object-position: center;
    height: 450px;
    width: 450px;
}

@media (max-width: 1024px) {
    .activites-intro__image {
        height: 400px;
        width: 400px;
    }
}

@media (max-width: 768px) {
    .activites-intro__image {
        height: 400px;
        width: 400px;
    }
}

.activites-intro__header {
    text-align: start;
}

.activites-intro__header {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .activites-intro__header {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .activites-intro__header {
        margin-bottom: 8px;
    }
}

.activites-intro__title {
    font-size: 3rem;
    color: #4C4C4C;
    /* garder seulement la variation via font-weight si besoin */
}

@media (max-width: 1024px) {
    .activites-intro__title {
        font-size: 2.8rem;
    }
}

@media (max-width: 768px) {
    .activites-intro__title {
        font-size: 2.6rem;
    }
}

.activites-intro__body {
    color: #4C4C4C;
}

.activites-intro__text {
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .activites-intro__header, .activites-intro__body {
        text-align: start;
    }

    .activites-intro__title, .activites-intro__text {
        color: #FFFFFF;
    }

    .activites-intro__col--content {
        inline-size: 100%;
        background-color: transparent;
        border-radius: 0;
    }

    .activites-intro__col--content {
        padding: 100px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .activites-intro__col--content {
        padding: 70px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .activites-intro__col--content {
        padding: 50px;
    }
}

/* Style activites start */
.activites {
    color: #4C4C4C;
}

.activites-section__intro {
    color: #4C4C4C;
    text-align: center;
}

.activites-section__intro {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .activites-section__intro {
        margin-bottom: 40px;
    }
}

@media (max-width: 768px) {
    .activites-section__intro {
        margin-bottom: 30px;
    }
}

.activites-section__desc {
    max-inline-size: 90ch;
    margin-inline: auto;
    color: #4C4C4C;
    opacity: 0.85;
}

.activites-section--past .activite-card {
    border-radius: 50px 50px 0 0;
}

.activites-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    justify-items: center;
    gap: 40px;
    /* mobile: pile en bloc */
}

@media (max-width: 1024px) {
    .activites-grid {
        gap: 30px;
    }
}

@media (max-width: 768px) {
    .activites-grid {
        gap: 20px;
    }
}

@media (max-width: 768px) {
    .activites-grid {
        display: block;
    }
}

/* ===== Carte ===== */
.activite-card {
    display: block;
    position: relative;
    background: #FFFFFF;
    /* largeur/hauteur “fermé” via ta map (basis + height) */
    flex-basis: 450px;
    /* >>> clé pour l’accordéon : laisser la carte grandir */
    height: auto; /* annule la hauteur fixe posée par le mixin */
    min-height: 0; /* au cas où */
    /* mobile: centrée, largeur réduite + marge bas via ton mixin */
}

@media (max-width: 1024px) {
    .activite-card {
        flex-basis: 400px;
    }
}

@media (max-width: 768px) {
    .activite-card {
        flex-basis: 350px;
    }
}

.activite-card {
    margin-bottom: 75px;
}

@media (max-width: 1024px) {
    .activite-card {
        margin-bottom: 65px;
    }
}

@media (max-width: 768px) {
    .activite-card {
        margin-bottom: 55px;
    }
}

@media (max-width: 768px) {
    .activite-card {
        max-width: 300px;
        margin-inline: auto;
    }
}

.activite-card {
    position: relative;
    background: #FFFFFF;
}

.activite-card__header {
    position: relative;
    display: block;
    width: 100%;
    background-color: #FFFFFF;
    border: none;
    text-align: left;
    cursor: pointer;
}

.activite-card__header:focus-visible {
    outline: 2px solid #A9CBB7;
    outline-offset: 2px;
}

.activite-card__date-badge {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    transform: translateY(-45%) translateX(15%);
    display: inline-block;
    background-color: #fffdff;
    color: #FFFFFF;
    border-radius: 2rem;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.05em;
    padding: 5px 20px;
    font-size: 1.2rem;
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
}

@media (max-width: 1024px) {
    .activite-card__date-badge {
        padding: 3.75px 15px;
    }
}

@media (max-width: 768px) {
    .activite-card__date-badge {
        padding: 2.5px 10px;
    }
}

@media (max-width: 1024px) {
    .activite-card__date-badge {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .activite-card__date-badge {
        font-size: 0.95rem;
    }
}

.activite-card__media {
    position: relative;
    display: block;
    aspect-ratio: 3/2;
    overflow: hidden;
}

.activite-card__image {
    width: 100%;
    height: 100%;
    border-radius: 50px;
    object-fit: cover;
    display: block;
}

.activite-card__curved-separator {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 60%;
    height: 90%;
    pointer-events: none;
}

.activite-card__chevron {
    position: absolute;
    bottom: 15px;
    left: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #FFFFFF;
    background: rgba(76, 76, 76, 0.4);
    border-radius: 50%;
    transition: transform 0.2s ease;
}

.activite-card__chevron {
    padding: 15px;
}

@media (max-width: 1024px) {
    .activite-card__chevron {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .activite-card__chevron {
        padding: 10px;
    }
}

.activite-card__title-pill {
    position: absolute;
    left: 50%;
    bottom: 0;
    text-align: center;
    transform: translate(-50%, 50%);
    z-index: 2;
    pointer-events: none;
    display: inline-block;
    background-color: #FFFFFF;
    color: #4C4C4C;
    border-radius: 2rem;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.05em;
    padding: 5px 20px;
    font-size: 1.2rem;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

@media (max-width: 1024px) {
    .activite-card__title-pill {
        padding: 3.75px 15px;
    }
}

@media (max-width: 768px) {
    .activite-card__title-pill {
        padding: 2.5px 10px;
    }
}

@media (max-width: 1024px) {
    .activite-card__title-pill {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .activite-card__title-pill {
        font-size: 0.95rem;
    }
}

.activite-card__content,
.activite-card .accordion__content {
    overflow: hidden;
    height: 0;
    transition: height 0.25s ease;
    border-radius: 0 0 50px 50px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.activite-card .accordion__content .activite-card__meta {
    padding: 50px 30px 0 30px;
}

@media (max-width: 1024px) {
    .activite-card .accordion__content .activite-card__meta {
        padding: 50px 20px 0 20px;
    }
}

@media (max-width: 768px) {
    .activite-card .accordion__content .activite-card__meta {
        padding: 50px 20px 0 20px;
    }

}

.activite-card__content .activite-card__desc,
.activite-card .accordion__content .activite-card__desc {
    border-radius: 0 0 50px 50px;
}

.activite-card__content .activite-card__desc,
.activite-card .accordion__content .activite-card__desc {
    padding: 30px 30px;
}

@media (max-width: 1024px) {
    .activite-card__content .activite-card__desc,
    .activite-card .accordion__content .activite-card__desc {
        padding: 20px 20px;
    }
}

@media (max-width: 768px) {
    .activite-card__content .activite-card__desc,
    .activite-card .accordion__content .activite-card__desc {
        padding: 20px 20px;
    }
}

.activite-card__meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: #4C4C4C;
}

.activite-card__time {
    letter-spacing: 0.02em;
    display: flex;
    align-items: center;
}

.activite-card__desc {
    color: #4C4C4C;
    line-height: 1.6;
}

.activite-card.is-open .activite-card__chevron,
.activite-card.is-open .accordion__chevron {
    transform: rotate(180deg);
}

.accordion__chevron {
    transition: transform 0.2s ease;
}

.accordion__content {
    transition: height 0.25s ease;
    overflow: hidden;
}

.evenements {
    color: #4C4C4C;
}

.evenements__intro {
    color: #4C4C4C;
    text-align: center;
}

.evenements__intro {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .evenements__intro {
        margin-bottom: 40px;
    }
}

@media (max-width: 768px) {
    .evenements__intro {
        margin-bottom: 30px;
    }
}

.evenements__desc {
    max-inline-size: 90ch;
    margin-inline: auto;
    color: #4C4C4C;
    opacity: 0.85;
}

/* Conteneur “table” : on garde la rigidité du tableau.
   En mobile on autorise un scroll horizontal plutôt que de casser la structure. */
.evenements-board {
    border: 1px solid rgba(196, 196, 196, 0.42);
    border-radius: 12px;
    background: #FFFFFF;
    overflow: hidden;
    /* wrap pour scroll horizontal sur petits écrans */
}

@media (max-width: 768px) {
    .evenements-board {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
}

/* Une “ligne” = un grid à 3 colonnes */
.evenements-row {
    display: grid;
    grid-template-columns: 1.2fr 2fr 1fr;
    align-items: center;
    /* séparateurs */
    /* hover léger sur les lignes (sans changer la taille de police) */
    /* en-tête visuel, plus contrasté (font-weight seulement) */
}

.evenements-row:not(.evenements-row--head) {
    border-top: 1px solid rgba(196, 196, 196, 0.42);
    background: #FFFFFF;
}

.evenements-row:not(.evenements-row--head):hover {
    background: #FAFAF9;
}

.evenements-row--head {
    background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
    color: #FFFFFF;
}

.evenements-row--head .evenements-cell {
    font-weight: 700;
}

/* Cellules (pas de <span>, pas de font-size modifié) */
.evenements-cell {
    padding: 0.75rem 1rem;
    /* texte normal partout */
    font-weight: 400;
    /* renfort léger sur le titre */
}

.evenements-cell--title {
    font-weight: 600;
}

/* Responsive : on garde la grille (rigide), on laisse scroller en x si besoin.
   Si tu veux absolument “wrap” en mobile, on peut faire une 2e variante, mais tu m’as demandé de garder l’esprit tableau. */
@media (max-width: 768px) {
    .evenements-row {
        min-width: 560px;
    }
}

/*Syle activites end */

/*Style instances start*/
.instances-intro {
    /* Colonnes (image à gauche, texte à droite en desktop) */
}

.instances-intro__container {
    position: relative;
    display: flex;
    border-radius: 15px;
    overflow: hidden;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 50px;
    /* Par défaut : l’image mobile est cachée */
}

@media (max-width: 1024px) {
    .instances-intro__container {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .instances-intro__container {
        gap: 25px;
    }
}

.instances-intro__container .instances-intro__image-mobile {
    display: none;
}

@media (max-width: 1024px) {
    .instances-intro__container {
        flex-direction: column;
        align-items: stretch;
        /* Masquer la version desktop et activer la version mobile en fond */
    }

    .instances-intro__container .instances-intro__image-desktop {
        display: none;
    }

    .instances-intro__container .instances-intro__image-mobile {
        position: absolute;
        inset: 0;
        display: block;
        z-index: 0;
        overflow: hidden;
    }

    .instances-intro__container .instances-intro__image-mobile::before {
        content: "";
        position: absolute;
        inset: 0;
        background-color: rgba(0, 0, 0, 0.45);
        backdrop-filter: blur(2px);
        z-index: 1;
    }

    .instances-intro__container .instances-intro__image-mobile img {
        inline-size: 100%;
        block-size: 100%;
        object-fit: cover;
    }
}

.instances-intro__col--content {
    position: relative;
    z-index: 2;
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 0;
}

.instances-intro__col--media {
    flex-grow: 0;
    flex-shrink: 0;
    flex-basis: auto;
}

.instances-intro__figure {
    display: block;
    overflow: hidden;
    border-radius: 15px;
}

.instances-intro__image {
    display: block;
    object-fit: cover;
    object-position: center;
    height: 450px;
    width: 450px;
}

@media (max-width: 1024px) {
    .instances-intro__image {
        height: 400px;
        width: 400px;
    }
}

@media (max-width: 768px) {
    .instances-intro__image {
        height: 400px;
        width: 400px;
    }
}

.instances-intro__header {
    text-align: start;
}

.instances-intro__header {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .instances-intro__header {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .instances-intro__header {
        margin-bottom: 8px;
    }
}

.instances-intro__title {
    color: #4C4C4C;
}

.instances-intro__body {
    color: #4C4C4C;
}

.instances-intro__text {
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .instances-intro__header, .instances-intro__body {
        text-align: start;
    }

    .instances-intro__title, .instances-intro__text {
        color: #FFFFFF;
    }

    .instances-intro__col--content {
        inline-size: 100%;
        background-color: transparent;
        border-radius: 0;
    }

    .instances-intro__col--content {
        padding: 100px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .instances-intro__col--content {
        padding: 70px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .instances-intro__col--content {
        padding: 50px;
    }
}

.instances {
    color: #4C4C4C;
}

.instances__list_intro {
    text-align: center;
}

.instances__list_intro {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .instances__list_intro {
        margin-bottom: 40px;
    }
}

@media (max-width: 768px) {
    .instances__list_intro {
        margin-bottom: 30px;
    }
}

.instances__text {
    opacity: 0.85;
}

.instances__list {
    display: flex;
    flex-direction: column;
    gap: 50px;
}

@media (max-width: 1024px) {
    .instances__list {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .instances__list {
        gap: 25px;
    }
}

/* =======================
   Item (accordéon)
   ======================= */
.instances-item {
    background: #FFFFFF;
    color: #4C4C4C;
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 0.8em 1.6em rgba(0, 0, 0, 0.06);
}

.instances-item__header {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    grid-template-columns: auto 1fr auto;
    cursor: pointer;
    border: 0;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.02) 100%);
    text-align: left;
}

.instances-item__header {
    padding: 25px;
}

@media (max-width: 1024px) {
    .instances-item__header {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .instances-item__header {
        padding: 15px;
    }
}

.instances-item__icon {
    height: 40px;
    width: 40px;
    object-fit: contain;
}

@media (max-width: 1024px) {
    .instances-item__icon {
        height: 35px;
        width: 35px;
    }
}

@media (max-width: 768px) {
    .instances-item__icon {
        height: 30px;
        width: 30px;
    }
}

.instances-item__title {
    margin: 0;
    color: #4C4C4C;
    font-weight: 600;
    font-size: 2rem;
}

@media (max-width: 1024px) {
    .instances-item__title {
        font-size: 1.5rem;
    }
}

@media (max-width: 768px) {
    .instances-item__title {
        font-size: 1rem;
    }
}

.instances-item__content {
    height: 0;
    overflow: hidden;
    transition: height 0.35s ease;
    opacity: 0;
}

.instances-item__desc {
    margin: 0 auto;
}

.instances-item__desc {
    padding-top: 0;
}


.instances-item__chevron {
    font-size: 1.5rem;
    line-height: 1;
    color: #4C4C4C;
    transition: transform 0.2s ease;
}

.instances-item .accordion__toggle[aria-expanded=true] .instances-item__chevron, .instances-item.is-open .instances-item__chevron {
    transform: rotate(180deg);
}

.instances-item.is-open .instances-item__content {
    opacity: 1;
}

/*Style instances end*/
/*Style tarifs start*/
.tarifs-hero {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    inline-size: 100%;
    border-radius: 0 0 50px 50px;
    overflow: hidden;
    block-size: 80dvh;
    min-block-size: 300px; /* cohérent avec accueil */
    color: #FFFFFF;
}

.tarifs-hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.tarifs-hero__img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

.tarifs-hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background-color: rgba(0, 0, 0, 0.45); /* overlay sombre pour lisibilité */
    backdrop-filter: blur(1.5px);
}

.tarifs-hero__inner {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    /* espace vertical entre éléments */
}

@media (max-width: 1024px) {
    .tarifs-hero__inner {
        gap: 30px;
    }
}

@media (max-width: 768px) {
    .tarifs-hero__inner {
        gap: 20px;
    }
}

.tarifs-hero__inner {
    padding: 100px;
}

@media (max-width: 1024px) {
    .tarifs-hero__inner {
        padding: 70px;
    }
}

@media (max-width: 768px) {
    .tarifs-hero__inner {
        padding: 50px;
    }
}

.tarifs-hero__title {
    font-size: 3rem;
    font-weight: 800;
    color: #FFFFFF;
}

@media (max-width: 1024px) {
    .tarifs-hero__title {
        font-size: 2.8rem;
    }
}

@media (max-width: 768px) {
    .tarifs-hero__title {
        font-size: 2.6rem;
    }
}

.tarifs-hero__text {
    font-size: 1.2rem;
    color: #FFFFFF;
    max-inline-size: 70ch;
    margin-inline: auto;
}

@media (max-width: 1024px) {
    .tarifs-hero__text {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .tarifs-hero__text {
        font-size: 0.95rem;
    }
}

@media (max-width: 1024px) {
    .tarifs-hero__inner {
        padding: 100px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .tarifs-hero__inner {
        padding: 70px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .tarifs-hero__inner {
        padding: 50px;
    }
}

@media (max-width: 1024px) {
    .tarifs-hero__text {
        max-inline-size: 60ch;
    }
}

@media (max-width: 768px) {
    .tarifs-hero__text {
        max-inline-size: 55ch;
    }
}

/*Style tarifs end*/


/* ---- Quill v2 – AFFICHAGE (semantic HTML) ---- */
.quill-content {
    /* échelle simple; ajuste à ton design */
    --sp-xs: .5rem;
    --sp-sm: .8rem;
    --sp-md: 1rem;
    --sp-lg: 1.3rem;
    --sp-xl: 1.8rem;
    --sp-blank: .6rem; /* hauteur d'UNE ligne vide */

    color: #4C4C4C;
    line-height: 1.7;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
    max-width: 100%;
    min-width: 0; /* utile si parent flex/grid */
}

/* Paragraphes “normaux” */
.quill-content p {
    margin: 0 0 var(--sp-sm);
}

/* Lignes vides exactes ( <p><br></p> ) : elles s’additionnent visuellement */
.quill-content p:has(> br:only-child) {
    margin: 0;
}

.quill-content p:has(> br:only-child) > br {
    display: block; /* évite le margin-collapsing */
    height: var(--sp-blank);
    content: "";
}

/* Fallback si tu marques les lignes vides côté JS (classe .q-blank) */
.quill-content p.q-blank {
    margin: 0;
}

.quill-content p.q-blank > br {
    display: block;
    height: var(--sp-blank);
    content: "";
}

/* Titres : plus d’espace au-dessus que dessous */
.quill-content h2 {
    margin: var(--sp-xl) 0 var(--sp-sm);
    line-height: 1.25;
}

.quill-content h3 {
    margin: var(--sp-lg) 0 var(--sp-xs);
    line-height: 1.30;
}

.quill-content h4 {
    margin: var(--sp-md) 0 var(--sp-xs);
    line-height: 1.35;
}

.quill-content h5,
.quill-content h6 {
    margin: var(--sp-sm) 0 var(--sp-xs);
    line-height: 1.40;
}

/* Évite le “double saut” autour des titres si une ligne vide est déjà là */
.quill-content p:has(> br:only-child) + :is(h2,h3,h4,h5,h6) {
    margin-top: 0;
}

.quill-content :is(h2,h3,h4,h5,h6):has(+ p:has(> br:only-child)) {
    margin-bottom: 0;
}

.quill-content p.q-blank + :is(h2,h3,h4,h5,h6) {
    margin-top: 0;
}

/* fallback */
.quill-content :is(h2,h3,h4,h5,h6):has(+ p.q-blank) {
    margin-bottom: 0;
}

/* fallback */

/* Listes & indentation */
.quill-content ul,
.quill-content ol {
    padding-left: 1.5em;
    margin: 0 0 var(--sp-sm);
}

.quill-content ul {
    list-style: disc outside;
}

.quill-content ol {
    list-style: decimal outside;
}

.quill-content li {
    margin: .25em 0;
}

/* Indentation (quill v2 en data-indent) */
.quill-content [data-indent="1"] {
    margin-left: 1.5em;
}

.quill-content [data-indent="2"] {
    margin-left: 3em;
}

.quill-content [data-indent="3"] {
    margin-left: 4.5em;
}

.quill-content [data-indent="4"] {
    margin-left: 6em;
}

.quill-content [data-indent="5"] {
    margin-left: 7.5em;
}

.quill-content [data-indent="6"] {
    margin-left: 9em;
}

.quill-content [data-indent="7"] {
    margin-left: 10.5em;
}

.quill-content [data-indent="8"] {
    margin-left: 12em;
}

/* Alignements (classes Quill ou inline styles) */
.quill-content .ql-align-center,
.quill-content [style*="text-align:center"] {
    text-align: center;
}

.quill-content .ql-align-right,
.quill-content [style*="text-align:right"] {
    text-align: right;
}

.quill-content .ql-align-justify,
.quill-content [style*="text-align:justify"] {
    text-align: justify;
}

/* Tables */
.quill-content table {
    width: 100%;
    border-collapse: collapse;
    /* margin: 0 0 var(--sp-sm);  // décommente si tu veux un espace sous les tables */
    overflow: hidden;
    border-radius: 0 0 15px 15px; /* ton style */
}

.quill-content th,
.quill-content td {
    padding: .5em;
}

/* Soft break (Shift+Entrée) = retour sans “saut” vertical */
.quill-content br {
    display: inline;
}

/* Images responsives */
.quill-content img {
    max-width: 100%;
    height: auto;
}

/* Pas de marge finale */
.quill-content > :last-child {
    margin-bottom: 0;
}

/* Style quill end*/


/*Style aides start*/
.aides-intro {
    /* Colonnes (image à gauche, texte à droite en desktop) */
}

.aides-intro__container {
    position: relative;
    display: flex;
    border-radius: 15px;
    overflow: hidden;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 50px;
    /* Par défaut : l’image mobile est cachée */
}

@media (max-width: 1024px) {
    .aides-intro__container {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .aides-intro__container {
        gap: 25px;
    }
}

.aides-intro__container .aides-intro__image-mobile {
    display: none;
}

@media (max-width: 1024px) {
    .aides-intro__container {
        flex-direction: column;
        align-items: stretch;
        /* Masquer la version desktop et activer la version mobile en fond */
    }

    .aides-intro__container .aides-intro__image-desktop {
        display: none;
    }

    .aides-intro__container .aides-intro__image-mobile {
        position: absolute;
        inset: 0;
        display: block;
        z-index: 0;
        overflow: hidden;
    }

    .aides-intro__container .aides-intro__image-mobile::before {
        content: "";
        position: absolute;
        inset: 0;
        background-color: rgba(0, 0, 0, 0.45);
        backdrop-filter: blur(2px);
        z-index: 1;
    }

    .aides-intro__container .aides-intro__image-mobile img {
        inline-size: 100%;
        block-size: 100%;
        object-fit: cover;
    }
}

.aides-intro__col--content {
    position: relative;
    z-index: 2;
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 0;
}

.aides-intro__col--media {
    flex-grow: 0;
    flex-shrink: 0;
    flex-basis: auto;
}

.aides-intro__figure {
    display: block;
    overflow: hidden;
    border-radius: 15px;
}

.aides-intro__image {
    display: block;
    object-fit: cover;
    object-position: center;
    height: 450px;
    width: 450px;
}

@media (max-width: 1024px) {
    .aides-intro__image {
        height: 400px;
        width: 400px;
    }
}

@media (max-width: 768px) {
    .aides-intro__image {
        height: 400px;
        width: 400px;
    }
}

.aides-intro__header {
    text-align: start;
}

.aides-intro__header {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .aides-intro__header {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .aides-intro__header {
        margin-bottom: 8px;
    }
}

.aides-intro__title {
    font-size: 3rem;
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .aides-intro__title {
        font-size: 2.8rem;
    }
}

@media (max-width: 768px) {
    .aides-intro__title {
        font-size: 2.6rem;
    }
}

.aides-intro__body {
    color: #4C4C4C;
}

.aides-intro__text {
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .aides-intro__header, .aides-intro__body {
        text-align: start;
    }

    .aides-intro__title, .aides-intro__text {
        color: #FFFFFF;
    }

    .aides-intro__col--content {
        inline-size: 100%;
        background-color: transparent;
        border-radius: 0;
    }

    .aides-intro__col--content {
        padding: 100px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .aides-intro__col--content {
        padding: 70px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .aides-intro__col--content {
        padding: 50px;
    }
}

.aides {
    color: #4C4C4C;
}

.aides__list_intro {
    text-align: center;
}

.aides__list_intro {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .aides__list_intro {
        margin-bottom: 40px;
    }
}

@media (max-width: 768px) {
    .aides__list_intro {
        margin-bottom: 30px;
    }
}

.aides__text {
    opacity: 0.85;
}

.aides__list {
    display: flex;
    flex-direction: column;
    gap: 50px;
}

@media (max-width: 1024px) {
    .aides__list {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .aides__list {
        gap: 25px;
    }
}

/* =======================
   Item (accordéon)
   ======================= */
.aides-item {
    background: #FFFFFF;
    color: #4C4C4C;
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 0.8em 1.6em rgba(0, 0, 0, 0.06);
}

.aides-item__header {
    width: 100%;
    grid-template-columns: auto 1fr auto;
    display: flex;
    justify-content: space-between;
    cursor: pointer;
    border: 0;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.02) 100%);
    text-align: left;
}

.aides-item__header {
    padding: 25px;
}

@media (max-width: 1024px) {
    .aides-item__header {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .aides-item__header {
        padding: 15px;
    }
}

.aides-item__icon {
    height: 40px;
    width: 40px;
    object-fit: contain;
}

@media (max-width: 1024px) {
    .aides-item__icon {
        height: 35px;
        width: 35px;
    }
}

@media (max-width: 768px) {
    .aides-item__icon {
        height: 30px;
        width: 30px;
    }
}

.aides-item__title {
    margin: 0;
    color: #4C4C4C;
    font-weight: 600;
    font-size: 2rem;
}

@media (max-width: 1024px) {
    .aides-item__title {
        font-size: 1.5rem;
    }
}

@media (max-width: 768px) {
    .aides-item__title {
        font-size: 1rem;
    }
}

.aides-item__content {
    height: 0;
    overflow: hidden;
    transition: height 0.35s ease;
    opacity: 0;
}

.aides-item__desc {
    margin: 0 auto;
}

.aides-item__desc {
    padding: 25px;
}

@media (max-width: 1024px) {
    .aides-item__desc {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .aides-item__desc {
        padding: 15px;
    }
}

.aides-item__chevron {
    font-size: 1.5rem;
    line-height: 1;
    color: #4C4C4C;
    transition: transform 0.2s ease;
}

.aides-item .accordion__toggle[aria-expanded=true] .aides-item__chevron, .aides-item.is-open .aides-item__chevron {
    transform: rotate(180deg);
}

.aides-item.is-open .aides-item__content {
    opacity: 1;
}

/*Style aides end*/

/*Style procedures start*/
.procedures-intro__container {
    position: relative;
    display: flex;
    border-radius: 15px;
    overflow: hidden;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 50px;
}

@media (max-width: 1024px) {
    .procedures-intro__container {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .procedures-intro__container {
        gap: 25px;
    }
}

.procedures-intro__container .procedures-intro__image-mobile {
    display: none;
}

@media (max-width: 1024px) {
    .procedures-intro__container {
        flex-direction: column;
        align-items: stretch;
    }

    .procedures-intro__container .procedures-intro__image-desktop {
        display: none;
    }

    .procedures-intro__container .procedures-intro__image-mobile {
        position: absolute;
        inset: 0;
        display: block;
        z-index: 0;
        overflow: hidden;
    }

    .procedures-intro__container .procedures-intro__image-mobile::before {
        content: "";
        position: absolute;
        inset: 0;
        background-color: rgba(0, 0, 0, 0.45);
        backdrop-filter: blur(2px);
        z-index: 1;
    }

    .procedures-intro__container .procedures-intro__image-mobile img {
        inline-size: 100%;
        block-size: 100%;
        object-fit: cover;
    }
}

.procedures-intro__col--content {
    position: relative;
    z-index: 2;
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 0;
}

.procedures-intro__col--media {
    flex-grow: 0;
    flex-shrink: 0;
    flex-basis: auto;
}

.procedures-intro__figure {
    display: block;
    overflow: hidden;
    border-radius: 15px;
}

.procedures-intro__image {
    display: block;
    object-fit: cover;
    object-position: center;
    height: 450px;
    width: 450px;
}

@media (max-width: 1024px) {
    .procedures-intro__image {
        height: 400px;
        width: 400px;
    }
}

@media (max-width: 768px) {
    .procedures-intro__image {
        height: 400px;
        width: 400px;
    }
}

.procedures-intro__header {
    text-align: start;
}

.procedures-intro__header {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .procedures-intro__header {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .procedures-intro__header {
        margin-bottom: 8px;
    }
}

.procedures-intro__title {
    font-size: 3rem;
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .procedures-intro__title {
        font-size: 2.8rem;
    }
}

@media (max-width: 768px) {
    .procedures-intro__title {
        font-size: 2.6rem;
    }
}

.procedures-intro__body, .procedures-intro__text {
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .procedures-intro__header, .procedures-intro__body {
        text-align: start;
    }

    .procedures-intro__title, .procedures-intro__text {
        color: #FFFFFF;
    }

    .procedures-intro__col--content {
        inline-size: 100%;
        background-color: transparent;
        border-radius: 0;
    }

    .procedures-intro__col--content {
        padding: 100px;
    }
}

@media (max-width: 1024px) and (max-width: 1024px) {
    .procedures-intro__col--content {
        padding: 70px;
    }
}

@media (max-width: 1024px) and (max-width: 768px) {
    .procedures-intro__col--content {
        padding: 50px;
    }
}

/* ========== Procédures – LISTE & CARTES ========== */
/* ========== Procédures – LISTE & CARTES ========== */
.procedures {
    /* Carte procédure */
}

.procedures__list_intro {
    text-align: center;
}

.procedures__list_intro {
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .procedures__list_intro {
        margin-bottom: 40px;
    }
}

@media (max-width: 768px) {
    .procedures__list_intro {
        margin-bottom: 30px;
    }
}

.procedures__title {
    color: #4C4C4C;
    font-size: 2.25rem;
}

@media (max-width: 1024px) {
    .procedures__title {
        font-size: 1.75rem;
    }
}

@media (max-width: 768px) {
    .procedures__title {
        font-size: 1.25rem;
    }
}

.procedures__text {
    opacity: 0.85;
}

/*.procedures__container {*/
/*  padding: 100px;*/
/*}*/
/*@media (max-width: 1024px) {*/
/*  .procedures__container {*/
/*    padding: 70px;*/
/*  }*/
/*}*/
/*@media (max-width: 768px) {*/
/*  .procedures__container {*/
/*    padding: 50px;*/
/*  }*/
/*}*/
.procedures__container {
    margin-bottom: 100px;
}

@media (max-width: 1024px) {
    .procedures__container {
        margin-bottom: 75px;
    }
}

@media (max-width: 768px) {
    .procedures__container {
        margin-bottom: 50px;
    }
}

.procedures__list {
    display: flex;
    flex-wrap: wrap;
    flex-shrink: 0;
    list-style: none;
    padding: 0;
    margin: 0;
    gap: 50px;
    align-items: stretch;
    justify-content: center;
}

@media (max-width: 1024px) {
    .procedures__list {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .procedures__list {
        gap: 25px;
    }
}

.procedures__item {
    display: flex;
}

.procedures .procedure-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    background: #FFFFFF;
    border-radius: 50px;
    box-shadow: 0 4px 18px rgba(0, 0, 0, 0.06);
    text-align: center;
    min-height: 250px;
    width: 500px;
    /* Pastille / numéro d’ordre (étape) */
    /* Pièces jointes */
}

.procedures .procedure-card {
    padding: 25px;
}

@media (max-width: 1024px) {
    .procedures .procedure-card {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card {
        padding: 15px;
    }
}

@media (max-width: 1024px) {
    .procedures .procedure-card {
        min-height: 200px;
        width: 350px;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card {
        min-height: 150px;
        max-width: 300px;
    }

    .procedures .procedure-card {
        margin-bottom: 40px;
    }
}

@media (max-width: 768px) and (max-width: 1024px) {
    .procedures .procedure-card {
        margin-bottom: 35px;
    }
}

@media (max-width: 768px) and (max-width: 768px) {
    .procedures .procedure-card {
        margin-bottom: 30px;
    }
}

.procedures .procedure-card__header {
    align-self: stretch;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
}

@media (max-width: 1024px) {
    .procedures .procedure-card__header {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card__header {
        gap: 10px;
    }
}

.procedures .procedure-card__header {
    margin-bottom: 20px;
}

@media (max-width: 1024px) {
    .procedures .procedure-card__header {
        margin-bottom: 16px;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card__header {
        margin-bottom: 12px;
    }
}

.procedures .procedure-card__title {
    color: #4C4C4C;
    font-weight: 600;
    margin: unset;
}

.procedures .procedure-card__step {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #A9CBB7;
    flex-shrink: 0;
    border-radius: 50px;
    color: #FFFFFF;
    font-weight: 700;
    height: 40px;
    width: 40px;
}

@media (max-width: 1024px) {
    .procedures .procedure-card__step {
        height: 35px;
        width: 35px;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card__step {
        height: 30px;
        width: 30px;
    }
}

.procedures .procedure-card__step {
    padding: 15px;
}

@media (max-width: 1024px) {
    .procedures .procedure-card__step {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card__step {
        padding: 10px;
    }
}

.procedures .procedure-card__body {
    color: #4C4C4C;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.procedures .procedure-card__content {
    align-self: stretch;
    /* Contenu riche centré */
    text-align: center;
}

.procedures .procedure-card__content {
    margin-bottom: 44px;
}

@media (max-width: 1024px) {
    .procedures .procedure-card__content {
        margin-bottom: 42px;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card__content {
        margin-bottom: 40px;
    }
}

.procedures .procedure-card__attachments {
    width: 100%;
}

.procedures .procedure-card__attachments-title {
    font-size: 1.5rem;
    color: #4C4C4C;
    font-weight: 600;
    text-align: center;
}

@media (max-width: 1024px) {
    .procedures .procedure-card__attachments-title {
        font-size: 1.2rem;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card__attachments-title {
        font-size: 0.9rem;
    }
}

.procedures .procedure-card__attachments-title {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .procedures .procedure-card__attachments-title {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card__attachments-title {
        margin-bottom: 8px;
    }
}

.procedures .procedure-card__attachments-list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    list-style: none;
    padding: 0;
    margin: 0;
    gap: 10px;
}

@media (max-width: 1024px) {
    .procedures .procedure-card__attachments-list {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card__attachments-list {
        gap: 6px;
    }
}

.procedures .procedure-card__attachments-item {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
    justify-content: center;
}

@media (max-width: 1024px) {
    .procedures .procedure-card__attachments-item {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card__attachments-item {
        gap: 10px;
    }
}

.procedures .procedure-card__attachments-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    background: linear-gradient(60deg, #F7E1D7, #FFFFFF);
    color: #4C4C4C;
    border-radius: 50px;
    font-weight: 600;
    font-size: 1.2rem;
}

.procedures .procedure-card__attachments-link {
    padding: 15px;
}

@media (max-width: 1024px) {
    .procedures .procedure-card__attachments-link {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card__attachments-link {
        padding: 10px;
    }
}

@media (max-width: 1024px) {
    .procedures .procedure-card__attachments-link {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card__attachments-link {
        font-size: 0.95rem;
    }
}

.procedures .procedure-card__attachments-link:hover, .procedures .procedure-card__attachments-link:focus {
    opacity: 0.8;
}

.procedures .procedure-card__attachments-link-content {
    display: flex;
    align-items: center;
    gap: 15px;
}

@media (max-width: 1024px) {
    .procedures .procedure-card__attachments-link-content {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .procedures .procedure-card__attachments-link-content {
        gap: 10px;
    }
}

.procedures .procedure-card__attachments-label {
    margin-inline-end: 8px;
}

.procedures .procedure-card__attachments-meta {
    opacity: 0.8;
}

@media (max-width: 1024px) {
    .procedures__list {
        justify-content: center;
    }
}

/*Style procedures end*/

/*Style recrutement start*/
.recrutement-hero {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    inline-size: 100%;
    border-radius: 0 0 50px 50px;
    overflow: hidden;
    block-size: 80dvh;
    min-block-size: 300px; /* cohérent avec accueil */
    color: #FFFFFF;
}

.recrutement-hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.recrutement-hero__img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

.recrutement-hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background-color: rgba(0, 0, 0, 0.45); /* overlay sombre pour lisibilité */
    backdrop-filter: blur(1.5px);
}

.recrutement-hero__inner {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px; /* espace vertical entre éléments */
    padding: 100px;
}

@media (max-width: 1024px) {
    .recrutement-hero__inner {
        gap: 30px;
        padding: 70px;
    }
}

@media (max-width: 768px) {
    .recrutement-hero__inner {
        gap: 20px;
        padding: 50px;
    }
}

.recrutement-hero__title {
    font-size: 3rem;
    font-weight: 800;
    color: #FFFFFF;
}

@media (max-width: 1024px) {
    .recrutement-hero__title {
        font-size: 2.8rem;
    }
}

@media (max-width: 768px) {
    .recrutement-hero__title {
        font-size: 2.6rem;
    }
}

.recrutement-hero__text {
    font-size: 1.2rem;
    color: #FFFFFF;
    max-inline-size: 70ch;
    margin-inline: auto;
}

@media (max-width: 1024px) {
    .recrutement-hero__text {
        font-size: 1rem;
        max-inline-size: 60ch;
    }
}

@media (max-width: 768px) {
    .recrutement-hero__text {
        font-size: 0.95rem;
        max-inline-size: 55ch;
    }
}

.recrutement {
    --stick-offset: 0px; /* ex: 72px si header fixe */
    color: #4C4C4C;
    /* Colonne gauche : recherche + liste */
    /* Colonne droite : panneau de détail */
    /* Recherche / filtres */
    /* Liste des offres (listbox) */
}

.recrutement__container {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr; /* liste / détail */
    align-items: start;
    gap: 50px;
}

@media (max-width: 1024px) {
    .recrutement__container {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .recrutement__container {
        gap: 25px;
    }
}

.recrutement__sidebar {
    position: sticky;
    top: var(--stick-offset);
    align-self: start;
    max-block-size: calc(100vh - var(--stick-offset));
    overflow: auto;
    overscroll-behavior: contain;
    min-block-size: 0;
    display: flex;
    flex-direction: column;
    gap: 50px;
    /* Masque dégradé correct */
    -webkit-mask-repeat: no-repeat;

    mask-image: linear-gradient(
            to bottom,
            rgba(0, 0, 0, 1) 0%,
            rgba(0, 0, 0, 1) calc(100% - 64px),
            rgba(0, 0, 0, 0) 100%
    );
    mask-repeat: no-repeat;

}

@media (max-width: 1024px) {
    .recrutement__sidebar {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .recrutement__sidebar {
        gap: 25px;
    }
}

.recrutement__sidebar {
    padding: 40px;
}

@media (max-width: 1024px) {
    .recrutement__sidebar {
        padding: 30px;
    }
}

@media (max-width: 768px) {
    .recrutement__sidebar {
        padding: 20px;
    }
}

.recrutement__sidebar .search-container {
    position: sticky;
    top: 0;
    z-index: 5;
    justify-content: center;
}

.recrutement__sidebar .search-input {
    flex-basis: 600px;
}

.recrutement__sidebar .search-input {
    padding: 8px;
}

@media (max-width: 1024px) {
    .recrutement__sidebar .search-input {
        padding: 7px;
    }
}

@media (max-width: 768px) {
    .recrutement__sidebar .search-input {
        padding: 6px;
    }
}

@media (max-width: 1024px) {
    .recrutement__sidebar .search-input {
        flex-basis: 550px;
    }
}

@media (max-width: 768px) {
    .recrutement__sidebar .search-input {
        flex-basis: 500px;
    }
}

.recrutement__detail {
    position: sticky;
    top: 0; /* reste visible quand la liste scrolle */
    align-self: start;
    padding-bottom: 50px;
}

@media (max-width: 1024px) {
    .recrutement__detail {
        padding-bottom: 40px;
    }
}

@media (max-width: 768px) {
    .recrutement__detail {
        padding-bottom: 30px;
    }
}


.recrutement__detail-inner {
    background-color: #FFFFFF;
    border-radius: 15px;
    min-block-size: 100dvh;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    /* scroll interne + hauteur limitée à la fenêtre */
}

.recrutement__search {
    background: #FFFFFF;
    border-radius: 15px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.recrutement__search {
    padding: 25px;
}

@media (max-width: 1024px) {
    .recrutement__search {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .recrutement__search {
        padding: 15px;
    }
}

@media (max-width: 1024px) {
    .recrutement__search {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .recrutement__search {
        gap: 6px;
    }
}

.recrutement__search-label {
    display: inline-flex;
    align-items: center;
    color: #4C4C4C;
}

.recrutement__search-input {
    inline-size: 100%;
    background: #FFFFFF;
    border: 1px solid #FAFAF9;
    border-radius: 12px;
    font-size: 1.2rem;
}

.recrutement__search-input {
    padding: 15px;
}

@media (max-width: 1024px) {
    .recrutement__search-input {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .recrutement__search-input {
        padding: 10px;
    }
}

@media (max-width: 1024px) {
    .recrutement__search-input {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .recrutement__search-input {
        font-size: 0.95rem;
    }
}

.recrutement__search-input:focus {
    outline: none;
    border-color: #A9CBB7;
    box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.02);
}

.recrutement__filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}

@media (max-width: 1024px) {
    .recrutement__filters {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .recrutement__filters {
        gap: 6px;
    }
}

.recrutement__filter {
    display: inline-flex;
    align-items: center;
    color: #4C4C4C;
}

.recrutement__select {
    background: #FFFFFF;
    border: 1px solid #FAFAF9;
    border-radius: 10px;
    font-size: 1.2rem;
}

.recrutement__select {
    padding: 15px;
}

@media (max-width: 1024px) {
    .recrutement__select {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .recrutement__select {
        padding: 10px;
    }
}

@media (max-width: 1024px) {
    .recrutement__select {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .recrutement__select {
        font-size: 0.95rem;
    }
}

.recrutement__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 50px;
}

@media (max-width: 1024px) {
    .recrutement__list {
        gap: 35px;
    }
}

@media (max-width: 768px) {
    .recrutement__list {
        gap: 25px;
    }
}

.recrutement__item {
    display: block;
}

@media (max-width: 1024px) {
    .recrutement__container {
        grid-template-columns: 1fr;
    }

    .recrutement__sidebar, .recrutement__detail {
        position: static;
        max-block-size: none;
        overflow: visible;
        overscroll-behavior: auto;
    }
}

/* =========================
   JOB CARD – item dans la liste
   ========================= */
.job-card {
    inline-size: 100%;
    text-align: start;
    background: #FFFFFF;
    color: #4C4C4C;
    border: 1px solid transparent;
    border-radius: 15px;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.job-card {
    padding: 25px;
}

@media (max-width: 1024px) {
    .job-card {
        padding: 20px;
        gap: 10px;
    }
}

@media (max-width: 768px) {
    .job-card {
        padding: 15px;
        gap: 8px;
    }
}

.job-card__footer {
    display: flex;
    justify-content: flex-end;
}

.job-card__footer {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .job-card__footer {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .job-card__footer {
        margin-bottom: 8px;
    }
}

.job-card__apply {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    background: #A9CBB7;
    color: #FFFFFF;
    border: 1px solid #A9CBB7;
    border-radius: 999px;
    font-weight: 700;
    font-size: 1.2rem;
    gap: 15px;
}

@media (max-width: 1024px) {
    .job-card__apply {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .job-card__apply {
        font-size: 0.95rem;
    }
}

@media (max-width: 1024px) {
    .job-card__apply {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .job-card__apply {
        gap: 10px;
    }
}

.job-card__apply {
    padding: 15px;
}

@media (max-width: 1024px) {
    .job-card__apply {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .job-card__apply {
        padding: 10px;
    }
}

.job-card__apply:hover, .job-card__apply:focus {
    opacity: 0.92;
}

.job-card:focus {
    outline: none;
    border-color: #A9CBB7;
}

.job-card.is-active {
    border-color: #A9CBB7;
    box-shadow: 0 4px 18px rgba(0, 0, 0, 0.06);
    background: #FFFFFF;
}

.job-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

@media (max-width: 1024px) {
    .job-card__header {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .job-card__header {
        gap: 6px;
    }
}

.job-card__header {
    margin-bottom: 16px;
}

@media (max-width: 1024px) {
    .job-card__header {
        margin-bottom: 12px;
    }
}

@media (max-width: 768px) {
    .job-card__header {
        margin-bottom: 10px;
    }
}

.job-card__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 15px;
    border: 1px solid #A9CBB7;
    color: #A9CBB7;
    font-size: 0.8rem;
    font-weight: 600;
}

@media (max-width: 1024px) {
    .job-card__badge {
        font-size: 0.7rem;
    }
}

@media (max-width: 768px) {
    .job-card__badge {
        font-size: 0.6rem;
    }
}

.job-card__badge {
    padding: 8px;
}

@media (max-width: 1024px) {
    .job-card__badge {
        padding: 7px;
    }
}

@media (max-width: 768px) {
    .job-card__badge {
        padding: 6px;
    }
}

.job-card__title {
    margin: 0;
    font-weight: 700;
    outline: none;
    color: #4C4C4C;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1 1 auto;
    font-size: 2rem;
}

@media (max-width: 1024px) {
    .job-card__title {
        font-size: 1.5rem;
    }
}

@media (max-width: 768px) {
    .job-card__title {
        font-size: 1rem;
    }
}

.job-card__meta {
    display: inline-flex;
    align-items: center;
    color: #4C4C4C;
    opacity: 0.9;
}

.job-card__salary {
    font-size: 1.2rem;
    font-weight: 600;
}

@media (max-width: 1024px) {
    .job-card__salary {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .job-card__salary {
        font-size: 0.95rem;
    }
}

.job-card__excerpt {
    margin-bottom: 15px;
    font-size: 1.2rem;
}

.job-card__excerpt .quill-content {
    display: -webkit-box;
    -webkit-line-clamp: 3; /* Limite à 3 lignes */
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    hyphens: auto; /* Active la césure automatique */
    overflow-wrap: break-word; /* Permet de couper les mots si nécessaire */
    word-break: break-word;
}

@media (max-width: 1024px) {
    .job-card__excerpt {
        margin-bottom: 12.5px;
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .job-card__excerpt {
        margin-bottom: 10px;
        font-size: 0.95rem;
    }
}

.job-card__meta,
.job-card__excerpt {
    display: block; /* évite le comportement inline capricieux */
    min-inline-size: 0; /* autorise le wrap dans un container flex */
}

.job-card__label-description {
    display: block;
}

.job-card__label-description .quill-content {
    overflow: hidden;
    text-overflow: ellipsis;
    background-color: red;
}

/*.job-card__excerpt .quill-content {*/
/*    background-color: red;*/
/*    !*  flex: 1 1 auto;      !* ← occupe le reste, rétrécit si besoin *!*!*/
/*    !*  min-inline-size: 0;  !* ← autorise le wrap dans un flex item *!*!*/

/*    !* ellipsis multi-lignes (3 lignes) *!*/

/*    !*  !* wrap “propre” (pas de coupe brutale) *!*!*/
/*    !*  word-break: normal;*!*/
/*    !*  overflow-wrap: break-word; !* casse uniquement si un “mot” est trop long *!*!*/
/*    !*  -webkit-hyphens: auto;*!*/
/*    !*  hyphens: auto;*!*/
/*}*/


/* =========================
   JOB DETAIL – panneau de droite (structure “Titre / Infos / Missions”)
   ========================= */
.job-detail {
    /* Titre */
    /* Bloc d'infos (contrat / salaire) */
    /* Ligne label : valeur */
    /* Chip contrat = style outline (rappel job-card__badge) */
    /* Bloc Missions (contenu riche) */
}

.job-detail__apply-banner {
    display: none;
}

@media (max-width: 1024px) {
    .job-detail__apply-banner {
        position: sticky; /* reste visible quand le contenu défile */
        bottom: 0;
        width: 100%;
        background: #FFFFFF;
        border-top: 2px solid #A9CBB7;
        display: flex;
        justify-content: center;
        align-items: center;
    }
}

.job-detail__apply-banner {
    padding: 25px 25px 0 25px;
}

@media (max-width: 1024px) {
    .job-detail__apply-banner {
        padding: 20px 20px 0 20px;
    }
}

@media (max-width: 768px) {
    .job-detail__apply-banner {
        padding: 15px 15px 0 15px;
    }
}

.job-detail__apply {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: #A9CBB7;
    border: 1px solid #A9CBB7;
    border-radius: 999px;
    font-weight: 700;
    font-size: 1.2rem;
    gap: 15px;
}

@media (max-width: 1024px) {
    .job-detail__apply {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .job-detail__apply {
        font-size: 0.95rem;
    }
}

.job-detail__apply {
    padding: 15px;
}

@media (max-width: 1024px) {
    .job-detail__apply {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .job-detail__apply {
        padding: 10px;
    }
}

@media (max-width: 1024px) {
    .job-detail__apply {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .job-detail__apply {
        gap: 10px;
    }
}

.job-detail__apply:hover, .job-detail__apply:focus {
    opacity: 0.92;
}

.job-detail__header {
    margin-bottom: 16px;
}

@media (max-width: 1024px) {
    .job-detail__header {
        margin-bottom: 12px;
    }
}

@media (max-width: 768px) {
    .job-detail__header {
        margin-bottom: 10px;
    }
}

.job-detail__title {
    margin: 0;
    outline: none;
    color: #4C4C4C;
    font-weight: 700;
    overflow-wrap: normal;
    word-break: normal;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto;
}


.job-detail__infos {
    display: flex;
    flex-direction: column;
}

.job-detail__row {
    display: grid;
    grid-template-columns: auto 1fr; /* label court à gauche, valeur fluide à droite */
    align-items: center;
    gap: 10px;
}

@media (max-width: 1024px) {
    .job-detail__row {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .job-detail__row {
        gap: 6px;
    }
}

.job-detail__row {
    margin-bottom: 12px;
}

@media (max-width: 1024px) {
    .job-detail__row {
        margin-bottom: 10px;
    }
}

@media (max-width: 768px) {
    .job-detail__row {
        margin-bottom: 8px;
    }
}

.job-detail__row--block {
    align-items: start; /* pour la zone Missions (valeur multiligne) */
}

.job-detail__column {
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

.job-detail__column--block {
    align-items: start;
}

.job-detail__label {
    font-size: 1.2rem;
    font-weight: 600;
    color: #4C4C4C;
    text-transform: none;
    white-space: nowrap;
}

@media (max-width: 1024px) {
    .job-detail__label {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .job-detail__label {
        font-size: 0.95rem;
    }
}

.job-detail__content {
    hyphens: auto;
    overflow-wrap: break-word;
    word-break: break-word;
}

.job-detail__value {
    font-size: 1.2rem;
    color: #4C4C4C;
}

@media (max-width: 1024px) {
    .job-detail__value {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .job-detail__value {
        font-size: 0.95rem;
    }
}

.job-detail__chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 15px;
    border: 1px solid #FAFAF9;
    background: transparent;
    color: #4C4C4C;
    font-weight: 600;
}

.job-detail__chip {
    padding: 8px;
}

@media (max-width: 1024px) {
    .job-detail__chip {
        padding: 7px;
    }
}

@media (max-width: 768px) {
    .job-detail__chip {
        padding: 6px;
    }
}

.job-detail__chip--contrat {
    border-color: #A9CBB7;
    color: #A9CBB7;
}

.job-detail__body {
    margin-bottom: 40px;
}

@media (max-width: 1024px) {
    .job-detail__body {
        margin-bottom: 35px;
    }
}

@media (max-width: 768px) {
    .job-detail__body {
        margin-bottom: 30px;
    }
}

.job-detail__body .job-detail__content > *:last-child {
    margin-bottom: 0;
}

.job-detail__body .job-detail__content ul, .job-detail__body .job-detail__content ol {
    padding-inline-start: 1.25em;
}

/*Style recrutement end*/

/*Style candidature start*/
/* Bloc formulaire de candidature */
.candidature-form {
}

/* Conteneur + grille */
.candidature-container {
}

/* Titre */
.candidature-container__title {
    text-align: center;
    color: #4C4C4C;
}

/* Formulaire dans la grille */
.candidature-container .candidature-form {
    grid-column: 1/2;
    width: 100%;
}

@media (max-width: 1024px) {
    .candidature-container .candidature-form {
        width: unset;
        margin-bottom: 50px;
    }
}

/* Zone message */
.candidature-container .candidature-form #id_message {
    max-width: 100%;
    min-width: 100%;
    min-height: 100px;
    max-height: 250px;
    overflow: auto;
    border-radius: 15px;
    border: solid 1px #A9CBB7;
    color: #A9CBB7;
    padding: 15px;
}

@media (max-width: 1024px) {
    .candidature-container .candidature-form #id_message {
        padding: 12.5px;
    }
}

@media (max-width: 768px) {
    .candidature-container .candidature-form #id_message {
        padding: 10px;
    }
}

.candidature-container .candidature-form #id_message:focus {
    outline: none;
}

/* Actions / bouton envoyer */
.candidature-actions .submit-button {
    background-image: linear-gradient(90deg, #A9CBB7, #7EBF8D);
    color: #FFFFFF;
    gap: 15px;
}

@media (max-width: 1024px) {
    .candidature-actions .submit-button {
        gap: 12.5px;
    }
}

@media (max-width: 768px) {
    .candidature-actions .submit-button {
        gap: 10px;
    }
}

.candidature-actions .submit-button:hover {
    opacity: 0.9;
}

/*Style candidature end*/


/*Style candidature dashboard start */

.candidature-grid-container {
    overflow-x: auto;
    width: 100%;
}

.candidature-grid-container .candidature-grid {
    min-width: 1024px;
    border-radius: 8px;
}

/* Header */
.candidature-grid-container .candidature-grid .grid-header {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    border-radius: 15px 15px 0 0;
    background-image: linear-gradient(90deg, #7EBF8D, #A9CBB7);
    color: #FFFFFF;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 30px;
}

@media (max-width: 1024px) {
    .candidature-grid-container .candidature-grid .grid-header {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .candidature-grid-container .candidature-grid .grid-header {
        padding: 30px;
    }
}

.candidature-grid-container .candidature-grid .grid-header .grid-cell {
    margin: unset;
    text-align: center;
}

/* Rows */
.candidature-grid-container .candidature-grid .grid-row {
    display: grid;
    align-items: center;
    grid-template-columns: repeat(5, 1fr);
    border-bottom: 1px solid #A9CBB7;
    transition: background-color 0.2s ease;
}

.candidature-grid-container .candidature-grid .grid-row:last-child {
    border-radius: 0 0 15px 15px;
    border-bottom: none;
}

.candidature-grid-container .candidature-grid .grid-row:hover {
    background-color: #f5f5f5;
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell {
    text-align: center;
    padding: 30px;
}

@media (max-width: 1024px) {
    .candidature-grid-container .candidature-grid .grid-row .grid-cell {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .candidature-grid-container .candidature-grid .grid-row .grid-cell {
        padding: 30px;
    }
}

/* Actions */
.candidature-grid-container .candidature-grid .grid-row .grid-cell-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

@media (max-width: 1024px) {
    .candidature-grid-container .candidature-grid .grid-row .grid-cell-actions {
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .candidature-grid-container .candidature-grid .grid-row .grid-cell-actions {
        gap: 6px;
    }
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50px;
    font-weight: 700;
    border: none;
    background: unset;
    cursor: pointer;
    padding: 8px;
    transition: all 0.2s ease;
    font-size: 0.8rem;
}

@media (max-width: 1024px) {
    .candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button {
        font-size: 0.7rem;
        padding: 7px;
    }
}

@media (max-width: 768px) {
    .candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button {
        font-size: 0.6rem;
        padding: 6px;
    }
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button.view {
    color: #7EBF8D;
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button.view:hover {
    opacity: 0.9;
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button.delete {
    color: #D16464;
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button.delete:hover {
    opacity: 0.9;
}

/* Statut */
.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut {
    display: flex;
    justify-content: center;
    align-items: center;
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut p {
    font-size: 0.8rem;
}

@media (max-width: 1024px) {
    .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut p {
        font-size: 0.7rem;
    }
}

@media (max-width: 768px) {
    .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut p {
        font-size: 0.6rem;
    }
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-nouveau,
.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-lu,
.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-traite {
    border-radius: 50px;
    font-weight: 700;
    color: #FFFFFF;
    padding: 8px;
}

@media (max-width: 1024px) {
    .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-nouveau,
    .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-lu,
    .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-traite {
        padding: 7px;
    }
}

@media (max-width: 768px) {
    .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-nouveau,
    .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-lu,
    .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-traite {
        padding: 6px;
    }
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-nouveau {
    background-image: linear-gradient(135deg, #f6d365, #fda085);
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-lu {
    background-image: linear-gradient(135deg, #a1c4fd, #c2e9fb);
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-traite {
    background-image: linear-gradient(135deg, #d4fc79, #96e6a1);
}

/* Dernière cellule (actions) à droite si besoin */
.candidature-grid-container .candidature-grid .grid-row .grid-cell:last-child {
    text-align: right;
}

/* Responsiveness (overflow sur mobile) */
@media (max-width: 1024px) {
    .candidature-grid-container .candidature-grid .candidature-grid-container {
        overflow-x: scroll;
    }
}

/*Style candidature end*/

/*Style tarifs_intro start*/
.tarifs__intro {
    color: #4C4C4C;
    text-align: center;
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .tarifs__intro {
        margin-bottom: 40px;
    }
}

@media (max-width: 768px) {
    .tarifs__intro {
        margin-bottom: 30px;
    }
}

.tarifs__text {
    opacity: 0.85;
}

.tarifs__previews {
    display: grid;
    grid-template-columns: repeat(2, minmax(280px, 1fr));
    gap: 28px;
}

@media (max-width: 900px) {
    .tarifs__previews {
        grid-template-columns: 1fr;
    }
}

.tarifs-card {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 22px;
    padding: 22px 22px 22px 18px;
    border-radius: 16px;
    background: #FFFFFF;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
    color: #4C4C4C;
    text-decoration: none;
    transition: transform .18s ease, box-shadow .18s ease;
}

.tarifs-card:hover {
    transform: translateY(-2px);
    box-shadow: rgba(0, 0, 0, 0.12) 0 12px 18px -3px,
    rgba(0, 0, 0, 0.06) 0 6px 10px -2px;
}

.tarifs-card__icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background-image: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    flex-shrink: 0;
}

.tarifs-card__icon .material-symbols-outlined {
    font-size: 28px;
    color: #ffffff;
}

.tarifs-card__body {
    min-width: 0;
}

.tarifs-card__title {
    margin: 0 0 6px 0;
    line-height: 1.2;
    color: #4C4C4C;
}

.tarifs-card__desc {
    margin: 0;
    opacity: 0.85;
    display: -webkit-box;
    -webkit-line-clamp: 5; /* clamp pour tenir en une ligne de carte compacte */
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.tarifs-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-left: auto;
    padding: 10px 14px;
    border-radius: 999px;
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    color: #ffffff;
    font-weight: 700;
    white-space: nowrap;
    transition: background 0.3s ease,
    color 0.3s ease-in-out;
}

.tarifs-card:hover .tarifs-card__cta {
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
}

.tarifs-card .tarifs-card__cta .material-symbols-outlined {
    transition: transform 0.3s ease-in-out,
    color 0.3s ease-in-out;
}

.tarifs-card:hover .tarifs-card__cta .material-symbols-outlined {
    transform: translateX(5px);
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
}

@media (max-width: 768px) {
    .tarifs-card {
        grid-template-columns: auto 1fr;
        grid-template-areas:
      "icon title"
      "icon desc"
      "cta  cta";
        row-gap: 10px;
    }

    .tarifs-card__icon {
        grid-area: icon;
    }

    .tarifs-card__body {
        grid-area: title / title / desc / desc;
    }

    .tarifs-card__cta {
        grid-area: cta;
        justify-self: start;
    }
}

/*Style tarifs_intro end*/

/* Style admissions start */
/* ===== Admissions (home) start ===== */
.admissions__intro {
    color: #4C4C4C;
    text-align: center;
    margin-bottom: 50px;
}

@media (max-width: 1024px) {
    .admissions__intro {
        margin-bottom: 40px;
    }
}

@media (max-width: 768px) {
    .admissions__intro {
        margin-bottom: 30px;
    }
}

.admissions__text {
    opacity: .85;
}

/* Grille 2 colonnes */
.admissions__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 28px;
}

@media (max-width: 960px) {
    .admissions__grid {
        grid-template-columns:1fr;
    }
}

/* Carte générique */
.admissions-card {
    display: grid;
    grid-template-rows:auto auto 1fr auto;
    gap: 16px;
    padding: 22px;
    border-radius: 16px;
    background: #fff;
    color: #4C4C4C;
    text-decoration: none;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
    transition: transform .18s ease, box-shadow .18s ease;
}

.admissions-card:hover {
    transform: translateY(-2px);
    box-shadow: rgba(0, 0, 0, .12) 0 12px 18px -3px, rgba(0, 0, 0, .06) 0 6px 10px -2px;
}

.admissions-card__header {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 25px;
}

.admissions-card__header .material-symbols-outlined {
    margin-bottom: 16px;
}

@media (max-width: 1024px) {
    .admissions-card__header .material-symbols-outlined {
        margin-bottom: 12px;
    }
}

@media (max-width: 768px) {
    .admissions-card__header .material-symbols-outlined {
        margin-bottom: 10px;
    }
}

@media (max-width: 1024px) {
    .admissions-card__header {
        gap: 20px;
    }
}

@media (max-width: 768px) {
    .admissions-card__header {
        gap: 15px;
    }
}


.admissions-card__icon {
    font-size: 28px;
    color: #A9CBB7;
}

.admissions-card__title {
}

/* CTA pill */
.admissions-card__cta {
    justify-self: flex-end;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 999px;
    background-image: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    color: #fff;
    font-weight: 700;
    transition: color 0.3s ease-in-out,
    background-color 0.3s ease-in-out;
}

.admissions-card:hover .admissions-card__cta .material-symbols-outlined {
    transform: translateX(5px);
    transition: transform 0.3s ease-in-out;
}


.admissions-card:hover .admissions-card__cta, .admissions-card:hover .admissions-card__cta .material-symbols-outlined {
    background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
}

.admissions-card__desc {
    margin: 0;
    opacity: .85;
}

/* ---------- Recrutement : panneau interne 3 étapes ---------- */
.admissions-card--jobs .admissions-card__panel {
    border-radius: 12px;
    padding: 14px 16px;
    background: #fafafa;
    border: 1px solid rgba(0, 0, 0, .06);
}

.admissions-card__steps {
    counter-reset: num;
    list-style: none;
    margin: 0;
    padding: 0;
}

.admissions-card__steps li {
    position: relative;
    padding-left: 38px;
    margin: 10px 0;
}

.admissions-card__steps li::before {
    counter-increment: num;
    content: counter(num);
    position: absolute;
    left: 0;
    top: 0;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    font-size: .9rem;
    color: #fff;
    background-image: linear-gradient(90deg, #F7E1D7, #A9CBB7);
    box-shadow: rgba(0, 0, 0, .08) 0 2px 4px;
}

/*!* ---- Stepper lent + pauses sur collision ---- *!*/
/*.admissions-card--proc {*/
/*  !* durée globale (rallongée) + fenêtre de pause en % *!*/
/*  --dur: 10s;         !* ← rallonge si tu veux encore plus lent *!*/
/*  --pulse-scale: 1.12;*/
/*}*/

/*.admissions-card--proc .admissions-stepper {*/
/*  position: relative;*/
/*  height: 38px;*/
/*  margin-top: 2px;*/
/*}*/

/*.admissions-stepper__track {*/
/*  position: absolute;*/
/*  left: 6px; right: 6px; top: 50%;*/
/*  height: 6px; transform: translateY(-50%);*/
/*  border-radius: 999px;*/
/*  background: rgba(0,0,0,.08);*/
/*  overflow: hidden;*/
/*}*/

/*!* Barre : keyframes segmentées avec "pauses" aux points *!*/
/*.admissions-stepper__fill {*/
/*  width: 0%; height: 100%;*/
/*  background-color: #A9CBB7;*/
/*  animation: stepperSegmented var(--dur) linear infinite;*/
/*}*/

/*!* Collisions aux ~0%, 30%, 70%, 95% + courte pause à chaque fois *!*/
/*@keyframes stepperSegmented {*/
/*  0%   { width: 0%; }          !* Dot 1 (départ) *!*/
/*  28%  { width: 33.333%; }     !* approche dot 2 *!*/
/*  40%  { width: 33.333%; }     !* PAUSE sur dot 2 *!*/
/*  68%  { width: 66.666%; }     !* approche dot 3 *!*/
/*  80%  { width: 66.666%; }     !* PAUSE sur dot 3 *!*/
/*  95%  { width: 100%; }        !* approche dot 4 *!*/
/*  100% { width: 100%; }        !* PAUSE finale *!*/
/*}*/

/*.admissions-stepper__dots {*/
/*  position: absolute; inset: 0;*/
/*  display: grid; grid-template-columns: repeat(4,1fr);*/
/*  align-items: center;*/
/*}*/

/*!* Points : pulsation calée pile sur la collision *!*/
/*.admissions-stepper__dot {*/
/*  width: 18px; height: 18px; margin: 0 auto;*/
/*  border-radius: 50%;*/
/*  border: 2px solid rgba(0,0,0,.25);*/
/*  background: #fff;*/
/*  box-shadow: rgba(0,0,0,.06) 0 1px 2px;*/
/*  animation: dotPulse var(--dur) linear infinite;*/
/*}*/

/*!* Délais synchronisés avec les arrivées ci-dessus *!*/
/*.admissions-stepper__dot:nth-child(1) { animation-delay: 0s; }                               !* 0%  *!*/
/*.admissions-stepper__dot:nth-child(2) { animation-delay: calc(var(--dur) * 0.34); }          !* 30% *!*/
/*.admissions-stepper__dot:nth-child(3) { animation-delay: calc(var(--dur) * 0.60); }          !* 70% *!*/
/*.admissions-stepper__dot:nth-child(4) { animation-delay: calc(var(--dur) * 0.85); }          !* 95% *!*/

/*!* Pulse court autour de l’impact *!*/
/*@keyframes dotPulse {*/
/*  0%, 6%   { background:#fff; border-color:rgba(0,0,0,.25); transform:scale(.96);*/
/*             box-shadow: rgba(0,0,0,.06) 0 1px 2px; }*/
/*  8%, 18%  { background:#7EBF8D; border-color:transparent; transform:scale(var(--pulse-scale));*/
/*             box-shadow: rgba(0,0,0,.18) 0 4px 10px; }*/
/*  22%,100% { background:#fff; border-color:rgba(0,0,0,.25); transform:scale(.96);*/
/*             box-shadow: rgba(0,0,0,.06) 0 1px 2px; }*/
/*}*/

/*!* Optionnel : garder la synchro si tu changes la vitesse au hover*/
/*.admissions-card--proc:hover { --dur: 8s; }*/
/**!*/

/*!* Accessibilité *!*/
/*@media (prefers-reduced-motion: reduce) {*/
/*  .admissions-stepper__fill, .admissions-stepper__dot { animation: none; }*/
/*}*/

/* ---- Stepper fluide (sans pause) + dots synchro) ---- */
.admissions-card--proc {
    --dur: 10s; /* vitesse globale */
    --pulse-scale: 1.12;
}

.admissions-card--proc .admissions-stepper {
    position: relative;
    height: 38px;
    margin-top: 2px;
}

.admissions-stepper__track {
    position: absolute;
    left: 6px;
    right: 6px;
    top: 50%;
    height: 6px;
    transform: translateY(-50%);
    border-radius: 999px;
    background: rgba(0, 0, 0, .08);
    overflow: hidden;
}

/* Barre : progression continue (linéaire), plus AUCUNE pause */
.admissions-stepper__fill {
    width: 0%;
    height: 100%;
    background-color: #A9CBB7;
    will-change: width; /* évite les “resserrements” visuels */
    animation: stepperSmooth var(--dur) linear infinite;
}

@keyframes stepperSmooth {
    0% {
        width: 0%;
    }
    33.333% {
        width: 33.333%;
    }
    66.666% {
        width: 66.666%;
    }
    100% {
        width: 100%;
    }
}

.admissions-stepper__dots {
    position: absolute;
    inset: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    align-items: center;
}

/* Dots : pulsation calée pile au passage de la barre, sans pause */
.admissions-stepper__dot {
    width: 18px;
    height: 18px;
    margin: 0 auto;
    border-radius: 50%;
    border: 2px solid rgba(0, 0, 0, .25);
    background: #fff;
    box-shadow: rgba(0, 0, 0, .06) 0 1px 2px;
    animation: dotPulse var(--dur) linear infinite;
}

.admissions-stepper__dot:nth-child(1) {
    animation-delay: .22222s;
}

.admissions-stepper__dot:nth-child(2) {
    animation-delay: calc(var(--dur) * .30000);
}

.admissions-stepper__dot:nth-child(3) {
    animation-delay: calc(var(--dur) * .55555);
}

.admissions-stepper__dot:nth-child(4) {
    animation-delay: calc(var(--dur) * .80);
}

/* petit offset pour éviter le reset simultané */

@keyframes dotPulse {
    0%, 6% {
        background: #fff;
        border-color: rgba(0, 0, 0, .25);
        transform: scale(.96);
        box-shadow: rgba(0, 0, 0, .06) 0 1px 2px;
    }
    8%, 18% {
        background: #7EBF8D;
        border-color: transparent;
        transform: scale(var(--pulse-scale));
        box-shadow: rgba(0, 0, 0, .18) 0 4px 10px;
    }
    22%, 100% {
        background: #fff;
        border-color: rgba(0, 0, 0, .25);
        transform: scale(.96);
        box-shadow: rgba(0, 0, 0, .06) 0 1px 2px;
    }
}

/* Accessibilité */
@media (prefers-reduced-motion: reduce) {
    .admissions-stepper__fill, .admissions-stepper__dot {
        animation: none;
    }
}


/* Start admissions end */


/* 404 page */
/* ——— 404 simple et sobre ——— */
.error404 {
  min-height: 70vh;
  display: grid;
  place-items: center;
  padding: 2rem 1rem;
}

.error404__card {
  width: min(720px, 92vw);
  padding: 1.75rem;
  border: 1px solid #e6e8eb;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 6px 18px rgba(0,0,0,.05);
  text-align: center;
}

.error404__title {
  margin: 0 0 .5rem;
  font-size: clamp(22px, 3.2vw, 30px);
  font-weight: 700;
}

.error404__desc {
  margin: 0 auto 1rem;
  max-width: 60ch;
  color: #4c4c4c;
  line-height: 1.6;
}

.error404__desc code {
  background: #f6f7f8;
  border: 1px dashed #e1e3e6;
  border-radius: 6px;
  padding: 0 .4rem;
  font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: .95em;
  color: #333;
}

.error404__actions {
  display: flex;
  gap: .6rem;
  justify-content: center;
  flex-wrap: wrap;
  margin: 1rem 0 .25rem;
}

.error404__btn {
  appearance: none;
  border: 1px solid #dcdfe4;
  background: #fff;
  color: #1f2328;
  padding: .7rem 1rem;
  border-radius: 10px;
  cursor: pointer;
  text-decoration: none;
  transition: background .15s ease, border-color .15s ease, transform .05s ease;
}
.error404__btn:hover { background: #f6f7f8; border-color: #cfd3d9; }
.error404__btn:active { transform: translateY(1px); }

.error404__btn--primary {
  background: #1f6feb;
  border-color: #1f6feb;
  color: #fff;
}
.error404__btn--primary:hover { background: #195ec7; border-color: #195ec7; }

.error404__muted {
  margin-top: .5rem;
  color: #727b87;
  font-size: .95rem;
}

/* Petits écrans */
@media (max-width: 480px) {
  .error404__card { padding: 1.25rem; }
  .error404__actions { gap: .5rem; }
}


/*Cookies start style*/
    /* ===== Consent minimal (patch) ===== */
    .consent-root {
        position: fixed;
        right: 16px;
        bottom: 16px;
        z-index: 9999;
        display: flex;
        flex-direction: column;
        gap: 8px
    }

    #consent-trigger {
        padding: 8px 12px;
        border-radius: 999px;
        border: 1px solid #ddd;
        background: #fff;
        color: #111;
        cursor: pointer;
        font-size: 12px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, .08)
    }

    .consent-panel {
        width: 320px;
        max-width: 86vw;
        border-radius: 12px;
        padding: 16px;
        background: #111;
        color: #fff;
        box-shadow: 0 12px 30px rgba(0, 0, 0, .25);
        display: none /* fermé par défaut */
    }

    .consent-panel.open {
        display: block
    }

    /* ← affichage fiable quand "open" */
    #consent-trigger:hover + .consent-panel {
        display: block
    }

    /* bonus: hover */

    .consent-panel h3 {
        margin: 0 0 8px;
        font-size: 16px
    }

    .consent-panel p {
        margin: 0 0 12px;
        line-height: 1.45;
        font-size: 14px
    }

    .consent-actions {
        display: flex;
        align-items: center;
        gap: 12px;
        justify-content: space-between
    }

    .consent-link {
        color: #A9CBB7;
        text-decoration: underline;
        font-size: 14px
    }

    .consent-buttons {
        display: flex;
        gap: 8px
    }

    .btn {
        padding: 8px 12px;
        border-radius: 8px;
        cursor: pointer;
        font-size: 14px
    }

    .btn-outline {
        background: transparent;
        color: #fff;
        border: 1px solid #555
    }

    .btn-primary {
        background: #A9CBB7;
        color: #111;
        border: none
    }

    .form-consent-banner {
        color: #e69a00; /* jaune-orangé lisible */
        font-size: 14px;
        line-height: 1.4;
        margin: 6px 0 10px;
    }

    .form-consent-banner .form-consent-link {
        background: none;
        border: none;
        color: #e69a00;
        text-decoration: underline;
        cursor: pointer;
        font-size: 14px;
        padding: 0;
    }

    .form-consent-banner .form-consent-link:hover {
        text-decoration: none;
    }

    .consent-panel-wrapper {
        position: relative; /* ici la croix sera ancrée */
        padding: 16px;
    }

    .consent-close {
        position: absolute;
        top: 8px;
        right: 10px;
        border: none;
        background: transparent;
        font-size: 20px;
        color: #fff;
        cursor: pointer;
        line-height: 1;
    }

    .consent-close:hover {
        color: #A9CBB7;
    }

/* Cookies end style*/

/* Style PolitiqueConfidentiel start*/
/* --- Échelle d'espacement (mobile-first) --- */
.content-policies {
  --section-gap: 1.25rem;         /* entre grands blocs (H2) */
  --para-gap: 0.75rem;            /* entre paragraphes d'un même bloc */
  --title-gap: 1.25rem;           /* sous le H1 */
  --breadcrumb-gap: 1rem;         /* sous le fil d’Ariane */
  --h2-bottom: 0.75rem;           /* espace sous H2 */
  --h3-top: 0.75rem;              /* espace au-dessus H3 */
  --h3-bottom: 0.5rem;            /* espace sous H3 */
  --indent-1: 1rem;               /* retrait des sous-points (H3 + texte associé) */
  --guide-color: rgba(0, 0, 0, 0.08); /* guide vertical très subtil */
}

/* ≥ 768px */
@media (min-width: 768px) {
  .content-policies {
    --section-gap: 1.75rem;
    --para-gap: 1rem;
    --title-gap: 1.75rem;
    --breadcrumb-gap: 1.25rem;
    --h2-bottom: 1rem;
    --h3-top: 1rem;
    --h3-bottom: 0.625rem;
    --indent-1: 1.25rem;
  }
}

/* ≥ 1024px */
@media (min-width: 1024px) {
  .content-policies {
    --section-gap: 2.25rem;
    --para-gap: 1.125rem;
    --title-gap: 2rem;
    --breadcrumb-gap: 1.5rem;
    --h2-bottom: 1.125rem;
    --h3-top: 1.125rem;
    --h3-bottom: 0.75rem;
    --indent-1: 1.5rem;
  }
}

/* --- Fil d’Ariane + Titre --- */
.content-policies .container__links { margin-bottom: var(--breadcrumb-gap); }
.content-policies .privacy__title { margin: 0 0 var(--title-gap); }

/* --- Espacement des sections principales (H2) --- */
.content-policies .privacy__section:not(:last-of-type) {
  margin-bottom: var(--section-gap);
}

/* --- H2 : sous-titre de bloc --- */
.content-policies .privacy__subtitle {
  margin: 0 0 var(--h2-bottom);
}

/* --- Paragraphes : respiration interne --- */
.content-policies .privacy__section p {
  margin: 0; /* reset */
}
.content-policies .privacy__section p + p {
  margin-top: var(--para-gap);
}

/* --- H3 : sous-points arborescents (2.1, 2.2, etc.) --- */
.content-policies .privacy__heading {
  margin: var(--h3-top) 0 var(--h3-bottom);
  padding-left: var(--indent-1);
  border-left: 2px solid var(--guide-color); /* repère visuel discret */
}

/* Texte associé directement à un H3 : même retrait pour une belle “branche” */
.content-policies .privacy__heading + p {
  padding-left: calc(var(--indent-1) + 0.25rem);
}

/* Si plusieurs paragraphes suivent le H3, on maintient l’aération */
.content-policies .privacy__heading + p + p {
  padding-left: calc(var(--indent-1) + 0.25rem);
  margin-top: var(--para-gap);
}

/* --- Cas d’intros de section un peu plus aérées (optionnel) --- */
.content-policies .privacy__intro p + p {
  margin-top: calc(var(--para-gap) * 0.75);
}

/* --- Liens dans la page : garder le style existant, juste un léger underlining net --- */
.content-policies a {
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Style PolitiqueConfidentiel end*/
