html, body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

/* Ce conteneur englobe votre sidebar, votre contenu principal et votre footer */
.page {
    display: flex; /* Active le mode Flexbox */
    flex-direction: column; /* Aligne les enfants (main, footer) verticalement */
    min-height: 100vh; /* Force le conteneur à faire AU MINIMUM la hauteur de l'écran */
}

/* La balise <main> contient le contenu principal de votre page */
main {
    flex-grow: 1; /* Permet au contenu principal de s'étirer pour occuper tout l'espace vertical disponible */
}


h2{
    font-size:32px;color:black;font-weight:700;
}


a, .btn-link {
    color: #006bb7;
}

/* Classe pour les listes à puces avec espacement personnalisé */
 ul li {
    margin-bottom: 7px; /* <-- Vous pouvez modifier cette valeur pour augmenter ou réduire l'espace */
}
    /* C'est une bonne pratique pour s'assurer que le dernier élément n'a pas de marge en bas */
    ul li:last-child {
        margin-bottom: 0;
    }


.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}


/* Styles personnalisés accordions */
.section-title {
    color: #1a202c;
    font-weight: 700;
}

.accordion-item {
    border-radius: 0.5rem;
    border: 1px solid #e2e8f0;
    margin-bottom: 1rem;
    box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    transition: all 0.3s ease-in-out;
}

    .accordion-item:hover {
        transform: translateY(-2px);
        box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    }

.accordion-button {
    font-weight: 600;
    color: #2d3748;
    border-radius: 0.5rem !important;
}

    .accordion-button:not(.collapsed) {
        background-color: #e2e8f0;
        color: #1a202c;
        box-shadow: none;
    }

    .accordion-button:focus {
        box-shadow: 0 0 0 0.25rem rgba(59, 130, 246, 0.25);
    }

.accordion-body ul {
    padding-left: 1.5rem;
}

.partner-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 1.5rem;
    height: 100%;
}

    .partner-card img {
        max-height: 80px;
        margin-bottom: 1rem;
    }

.btn-cta {
    background-color: #3b82f6;
    color: white;
    font-weight: 600;
    padding: 0.75rem 1.5rem;
    border-radius: 0.5rem;
    text-decoration: none;
    transition: background-color 0.3s ease;
}

    .btn-cta:hover {
        background-color: #2563eb;
        color: white;
    }
/* Styles personnalisés accordions */

/*Style pour les article debut*/
.article-titleh1 {
    color: #ffffff;
    text-align: center;
    font-size: 32px;
    margin-top: 0;
    margin-bottom: 25px;
    background: linear-gradient(to right, #34495e, #2c3e50);
    padding: 25px;
    border-radius: 8px;
}
.article-titleh2 {
    color: #2c3e50;
    text-align: left;
    font-size: 24px;
    margin-top: 40px;
    margin-bottom: 15px;
}
.article-titleh3 {
    color: #34495e;
    text-align: left;
    font-size: 20px;
    margin-top: 30px;
    margin-bottom: 10px;
}

/* Style de a retenir de cet article */
.article-aretenir {
    background-color: #f3f9ff;
    border-left: 5px solid #2980b9;
    padding: 15px 20px;
    margin: 30px 0;
    font-size: 16px;
    text-align: left;
    border-radius: 5px;
}            
            .article-aretenir p {
                margin: 0;
                font-weight: bold;
                color: #2c3e50;
            }    
            .article-aretenir ul {
                list-style-position: inside;
                padding-left: 0;
                margin-top: 10px;
                margin-bottom: 0px;
                text-align: left;
            }    
            .article-aretenir li {
                margin-bottom: 5px;
            }
/*   fin Style de a retenir de cet article */

/* liste personnalisée */
.styled-list {
    list-style-type: none;
    padding-left: 20px;
    font-size: 16px;
    line-height: 1.7;
}

@media (max-width: 767px) {
    .styled-list {
        list-style-type: none;
        padding-left: 10px;
        font-size: 16px;
        line-height: 1.7;
    }
}
        .styled-list li {
            padding-left: 20px;
            border-left: 3px solid #27ae60;
            margin-bottom: 16px;
        }

        .styled-list strong {
            color: #2c3e50;
        }
    /* fin liste personnalisée */

    /*  bloc témoignage/avis */
    .article-testimonial {
        border-left: 4px solid #f1c40f;
        background-color: #fefdf9;
        padding: 15px 20px 15px 40px;
        margin: 20px 0;
        font-style: italic;
        color: #555;
        text-align: left;
        position: relative;
    }

    .article-testimonial-quote {
        font-family: Georgia, serif;
        font-size: 60px;
        color: #f1c40f;
        position: absolute;
        left: 10px;
        top: 0px;
    }

    .article-testimonial p {
        margin: 0;
    }

        .article-testimonial p:first-of-type {
            margin-bottom: 10px;
        }
    /*  fin bloc témoignage/avis */


    /* section "À lire aussi" */
    .related-articles-heading {
        color: #2c3e50;
        border-top: 1px solid #dddddd;
        padding-top: 20px;
        margin-top: 40px;
        text-align: left;
        font-size: 24px;
        margin-bottom: 15px;
    }

    .related-articles-list {
        text-align: left;
        list-style-type: none;
        padding-left: 0;
    }

        .related-articles-list li {
            margin-bottom: 10px;
        }

    .related-articles-link {
        color: #005A9C;
        text-decoration: none;
    }

    /* fin section "À lire aussi" */


    /* section FAQ */
    .faq-heading {
        color: #2c3e50;
        text-align: left;
        font-size: 24px;
        margin-top: 40px;
        margin-bottom: 25px;
    }

    .faq-item {
        border-bottom: 1px solid #e8e8e8;
        padding-bottom: 20px;
        margin-bottom: 20px;
    }

        .faq-item h3 {
            color: #34495e;
            text-align: left;
            font-size: 18px;
            margin-top: 0;
            margin-bottom: 10px;
        }

            .faq-item h3 span {
                color: #005A9C;
                font-weight: bold;
                margin-right: 8px;
            }

        .faq-item p {
            margin: 0;
            font-size: 16px;
            color: #555;
            text-align: left;
            line-height: 1.6;
            padding-left: 28px;
        }

    /* Fin section FAQ */

    /*Images articles*/

    .article-image {
        max-width: 65%;
        height: auto;
        display: block;
        margin: 15px auto 30px auto; /* Centre l'image horizontalement */
        border-radius: 8px;
    }
    /*fin Images articles*/

    /*Conteneur des articles*/
    .article-container {
        max-width: 900px;
        margin: 10px auto 0 auto;
        font-family: Arial, sans-serif;
        line-height: 1.7;
        background-color: #ffffff;
        padding: 20px 25px 20px 25px;
        border-radius: 5px;
        box-shadow: 0 2px 10px rgba(0,0,0,0.05);
    }

    @media (max-width: 768px) {
        .article-container {
            /* Le padding est encore réduit */
            padding: 15px;
            /* Le conteneur prend toute la largeur */
            margin: 0;
            border-radius: 0;
            box-shadow: none;
        }
    }
    /*Fin Conteneur des articles*/

/* paragraphs*/
.article-paragraph {
    margin-bottom: 20px;
    font-size: 16px;
    color: #333333;
    text-align: left;
}
/* fin paragraphs*/