:root { --currentColor: var(--violet); }

/* INTRO -------------------------------------------------------------- */  
#intro {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--padding);
}
    /* BLOC Qualiopi */
    #qualiopi {
        font-weight: var(--fw-normal);
        font-size: var(--fs-xs);
        background-color: var(--blanc);
        border-radius: 8px;
        overflow: hidden;
        max-width: 25rem;
        height: fit-content;
        border: 2px solid var(--blanc);
    }

        #qualiopi img {
            max-width: 10rem;
        }

        #qualiopi p:first-of-type {
            visibility: visible;
            display: block;
            height: fit-content;
            color:#000091;
            padding: 0 1rem ;
            margin-bottom: 1rem;
        }
            #qualiopi p:first-of-type span {
                display: inline;
                text-transform: uppercase;
                color: #E1000F;
                white-space: nowrap;
            }
        #qualiopi p.dl {
            visibility: hidden;
            height: 0;
            margin: 0;
        }

/* SECTION SIGNATURE ---------------------------------------------- */
#signature {
    padding: var(--padding);
}
#signature h2 { 
    font-weight: var(--fw-gras);
    margin-bottom: 0;
}
    .signature-titre,
    .signature-titre span:after {
        font-size: var(--t3);
        font-weight: var(--fw-normal);
        line-height: 1.1;
    }
    .signature-titre {
        border-top: var(--border);
        border-bottom: none;
    }
    .signature-details details:first-of-type .signature-titre {
        border-top: none;
    }
    .signature-details details:first-of-type[open] .signature-titre {
        border-top: var(--border);
    }
    .signature-details details[open] .signature-titre,
    .signature-details details[open] .signature-contenu {
        color: inherit;
        background-color: inherit;
        padding-left: 0;
        padding-right: 0;
    }
    .signature-details details[open] .signature-titre {
        border-bottom:none;
        font-weight: var(--fw-gras);
    }
        .signature-img {
            display: none;
            height: 0;
        }
        .signature-details details[open] + .signature-img {
            display: inherit;
            height: auto;
            margin-bottom: var(--padding);
        }
        .signature-details details[open] ~ details:nth-of-type(-1) .signature-titre {
            border-bottom: var(--border);
        }
/* SECTION PARCOURS ------------------------------- */ 
#parcours {
    border-top: none;
}
.liste-parcours {
    row-gap: 0;
    padding: var(--padding);
    min-height: fit-content;

}

    /* BLOC Catalogue titre */
    .liste-parcours .liste-header {
        display: grid;
        grid-template-columns: subgrid;
        align-content: center;
        padding: .5rem 0 calc(var(--padding)*2) 0;
        border-bottom: 1px solid;
    }
        .liste-header h2 {
            font-size: var(--fs-m);
            margin: 0 0 var(--padding) 0;
            font-weight: var(--fw-gras);
            padding-bottom: 0;
        }

    /* BLOC Filtres NAV --------------------------------- */
    .liste-header h2,
        nav.filtercloud, 
            nav.filtercloud h4,
            nav.filtercloud a {
            display: flex;
            flex-wrap: wrap;
        }
    .liste-header,
        nav.filtercloud {
            align-content: center;
        }
        .liste-header h2,
            nav.filtercloud h4 {
                height: fit-content;
                align-self: center;
            }
            nav.filtercloud h4{
                font-weight: var(--fw-normal);
                margin: 0;
            }
            nav.filtercloud h4, 
            nav.filtercloud a {
                padding-inline-end: .5rem;
                font-size: var(--fs-xs);
                line-height: 1.5rem;
            }
            nav.filtercloud a {
                border: none;
                font-weight: var(--fw-normal);
                border: 1px solid;
                border-radius: 1rem;
                padding-inline-start: .5rem;
                padding-bottom: .1rem;
                margin: .25rem;
            }
                nav.filtercloud a.filtre-actif { 
                    color: var(--lightColor);
                    background-color: var(--currentColor);
                    border-color: transparent;
                }      
            
    /* ARTICLE Parcours */
    .liste-parcours article {
        border-top: 4px solid currentColor;
        padding: var(--padding) 0 0 0;
        margin-bottom: calc(var(--padding)*2);
        min-height: calc(90vh - var(--hauteurMenu));
            display: grid;
            grid-template-columns: subgrid;

    }
        /* BLOC TITRE ----------------------- */
        .formation-titre {
            margin-bottom: var(--padding);
        }
        .formation-titre,
            .formation-titre a
        {
            display: block;
            height: 100%;
            width: 100%;
            border: none;
            font-weight: var(--fw-normal);
            margin-bottom: var(--padding);
        }
            .formation-titre a h3 {
                display: inline;
                overflow-wrap: normal ;
                word-break: keep-all;
                hyphens: none;
                font-weight: var(--fw-gras);
                margin: 0 0 1rem 0;
                line-height: 1.4;
                border-bottom: 1px solid;
            }
                .liste-parcours article.cursus .formation-titre a span {
                    display: flex;
                    flex-wrap: wrap;
                    width: fit-content;
                    font-size: var(--fs-l);
                    font-weight: var(--fw-normal);
                    padding-left: .15rem;
                }
                    .liste-parcours article.cursus .formation-titre a h3:before {
                        content: "→ ";
                        white-space: pre;
                    }

        /* BLOC INFOS  */
        .formation-resume {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            padding: 0;
            height: fit-content;
            align-self:  flex-end;
        }
            .formation-resume ul {
                list-style: none;
            }    
            .formation-resume ul,
            .formation-resume > div {
                grid-column: span 2;
                padding: .5rem 0;
            }
            /* BLOC Ligne 1 : Details */
            .formation-resume ul.formations-details {
                display: grid;
                grid-template-columns: auto 1fr ;
                gap: 0 var(--padding);
                border-top:none;
                border-bottom: var(--border);
            }
                li.tarifs{
                    justify-self: end;
                }

            /* BLOC Ligne 2 : infos secondaires */
            .formation-resume ul.formations-infos-secondaires {
                display: none; /* Masquer */
                height: 0;
            }

            /* BLOC Ligne 3 : Description */
            .formation-resume .formation-description,
            .formation-resume div:nth-last-of-type(2) {
                border-bottom: none;
            }
                .formation-description h4 {
                    hyphens: none;
                    word-break: keep-all ;
                    font-size: var(--t5);
                }
                .formation-description .liste-parcours-cursus {
                    display: flex;
                    flex-direction: column;
                    padding: 0;
                }
                    .liste-parcours-cursus li {
                        border-bottom: 1px dotted;
                        padding: .5rem 0;
                        margin-bottom: 0;
                    }
                        .liste-parcours-cursus li a {
                            border-bottom: none;
                            font-weight: var(--fw-normal);
                        }
                        .liste-parcours-cursus li a::before {
                            content: "→ ";
                            white-space: pre;;
                        }

                    .liste-parcours-cursus li:last-of-type {
                        border-bottom: none;
                    }
                
            /* BLOC Ligne 4 : Bouton lien */
            .formation-resume .formation-link {
                display: block;
                height: auto;
                width: 100%;
                padding: 0;
                border: none;
            } 
                .bouton {
                    border: var(--border);
                }


@media screen and (min-width: 1024px) {
main a:hover {
    background-color: transparent;
}
/* INTRO ----------------------------- */  
#intro {
    grid-template-columns: repeat(2, 1fr);
}
    #intro h1 {
        grid-column: span 1;
        margin-top: 0;
    }

    /* BLOC Qualiopi */ 
    #qualiopi {
        grid-column: span 1;
        justify-self: start;
    }
        #qualiopi img {
            max-width: 12rem;
        }
    a#qualiopi:hover  {
        border-color: var(--currentColor);
        color: var(--currentColor);
    }
        a#qualiopi:hover p:first-of-type, 
        a#qualiopi:hover  p:first-of-type span {
            visibility: hidden;
            height: 0;
        }
        a#qualiopi:hover p.dl {
            visibility: visible;
            padding: 0 1rem ;
            margin-top: 0;
            margin-bottom: 1rem;
            height: fit-content;
            font-size: var(--fs-s);
            font-weight: var(--fw-gras);
        }
    /* BLOC Éléments clefs ET Résumé */        
    #intro > div.grid {
        grid-column: 1/-1;
    }
/* SECTION SIGNATURE ---------------------------------------------- */
.signature-details {
    gap: 0;
}
.signature-details details {
    grid-column: 1/-1;
}
.signature-details details[open], 
.signature-img
 {
    grid-column: span 6;
}
.signature-details details[open] .signature-titre:hover span {
    background-color: var(--blanc);
    border-radius: 1rem;
    padding: 0;
}
.signature-details details[open] .signature-titre:hover span:after {
    vertical-align: top;
}
.signature-details details[open] .signature-titre,
.signature-details details[open] .signature-contenu {
    padding-right: var(--padding);
}
.signature-details details[open] + .signature-img {
    border-top: var(--border);
    padding: 1rem 0;
}
/* SECTION Parcours --------------------------------- */
#parcours {
    height: fit-content;
}
    /* BLOC Catalogue titre ------------------------- */ 
    .liste-parcours .liste-header {
        grid-column: span 12;
        min-height: fit-content;
        padding: .6rem 0;
    }
        .liste-header h2 {
            margin: 0;
        }
            .liste-header h2:after {
                content:" ↓";
                white-space: pre;
            }

        .liste-parcours .liste-header h2,
        .liste-parcours .liste-header h2 + div {
            grid-column: span 6;
        }

        /* BLOC Filtres NAV */
        nav.filtercloud a {
            padding-bottom: 0;
        } 
            nav.filtercloud a:hover { 
                color: var(--lightColor);
                background-color: var(--currentColor);
                border-color: transparent;
            }
       
    /* ARTICLE Parcours  -------------------------- */  
    .liste-parcours article {
        grid-column: span 12;
        min-height: fit-content;
        padding: calc(var(--padding)/2) 0 0 0;
            display: grid;
            grid-template-columns: subgrid;
            row-gap: 0;
    }
        /* BLOC Titre et résumé */
        .liste-parcours article .formation-titre,
        .liste-parcours article .formation-resume 
        {
            grid-column: span 6;
            align-self: start;
            height: fit-content;
        }
        .liste-parcours article .formation-titre{
            height: 100%;
        }
        /* BLOC Titre */
        .formation-titre {
            margin-bottom: 0;
        }
            .formation-titre a:hover {
                color: currentColor;
            }
                .formation-titre a h3 {
                    display: inline;
                    font-size: var(--t2);
                    font-weight: var(--fw-normal);
                    line-height: 1.2;
                }
                    
                    /* Survol */
                    .formation-titre a:hover h3,
                    .formation-titre a:hover span  {
                        color: var(--bleu);
                        background-color: var(--blanc);
                        border-bottom: none;
                    }


        /* BLOC Infos */  
        .formation-resume {
            grid-column: span 6;
            padding: .2rem 0 0 0;
                display: grid;
                grid-template-columns: repeat(3, 1fr);
                gap: 0 calc(var(--padding)/2);
        }
            .formation-resume ul,
            .formation-resume .formation-description,
            .formation-resume .formation-link {
                grid-column: span 3;
            }

            .formation-resume ul {
                border-bottom: 1px solid;
            }

            .formation-resume ul.formations-details,
            .formation-resume ul.formations-infos-secondaires{
                padding-bottom: 0;
            }

            .formation-resume ul.formations-infos-secondaires,
            .formation-resume .formation-description {
                display: inherit;
                height: fit-content;
            }

            .formation-resume ul.formations-details, 
            .formation-resume ul.formations-infos-secondaires,
            .formation-resume .formation-description {
                border-top:0;
                    display: grid;
                    grid-template-columns: subgrid;
                    gap: inherit;
            }
            
            /* Bloc Ligne 1 : Détails */
                li.tarifs {
                    grid-column: span 2;
                        display: flex;
                        justify-content: space-between;
                        justify-self: auto;
                }
                
            /* Bloc Ligne 2 : Info secondaires */
                li.public {
                    grid-column: span 2;
                }
                    li.public p:last-of-type {
                        margin-bottom: 0;
                    }
                    
            /* Bloc Ligne 3 : Description */
                .formation-description h4, 
                .formation-description .liste-parcours-cursus {
                    grid-column: span 3;
                }
                .formation-description .liste-parcours-cursus {
                    border-bottom: none;
                }
                    .liste-parcours-cursus li a:hover {
                        color: var(--bleu);
                        background-color: var(--blanc);
                    }

            /* Bloc Ligne 4 : Info secondaires */
            .formation-resume .formation-link {
                display: none; /* Masquer */
                height: 0;
                width: 0;
            }   
}