/*
body.archive .container-content,
body.search .container-content,
body.blog .container-content{
    width: 100%;
    max-width: var(--wideSize);
}

.container-title,
.container-metas{
}

body.page:not(.home) .container-content,
body.single .container-content{
    width: var(--contentSize);
}
*/

/**************************/
/*******généralités********/
/**************************/

html{
    margin: 0 !important;
}

h1{
    font-size: var(--font-size-x-large);
    font-weight: 700;
}

h2{
    font-size: var(--font-size-x-large);
    font-weight: 400;
}

strong{
    font-weight: 700;
}

em{
    font-style: italic;
}

a{
    position: relative;
    padding-left: 0;
    padding-right: 0;
}

a:not(.wp-block-button__link):not(.coordonnees)::after{
    content : '';
    position: absolute;
    left: 50%;
    bottom: 0;
    width: 0%;
    height: 2px;
    background: var(--couleur-2);
    transition: all var(--transition-basic-duration);
}

a:not(.wp-block-button__link):not(.coordonnees)::before{
    content : '';
    position: absolute;
    right: 50%;
    bottom: 0;
    width: 0%;
    height: 2px;
    background: var(--couleur-2);
    transition: all var(--transition-basic-duration);
}

a:hover::after,
a:hover::before
{
    width: 50%;
}

a:has(img)::after,
a:has(img)::before
{
    display: none;
}

h2.wp-block-heading{
    font-size: var(--font-size-xx-large);
    font-weight: 700;
}

h2.wp-block-heading strong{
    color: var(--couleur-1);
    text-transform: uppercase;
    font-weight: 800;
}

h2.wp-block-heading em{
    display: block;
    font-style: normal;
    margin: 0;
    padding: 0;
    font-size: var(--font-size-large);
    font-weight: 700;
}


/*********************/
/*******header********/
/*********************/

/* logo */

header#colleno{
    height: var(--header-height);
    background-color: var(--couleur-3);
    transition: all var(--transition-basic-duration);
    border-radius: 0 0 var(--arrondi-large) var(--arrondi-large);
}

header#colleno.mini{
    height: var(--header-height-mini);
}

.header-container{
    position: relative;
    height: 100%;
}

.header-container section.block-logo {
    height: 80%;
    position: relative;
}

.header-container section.block-logo h1{
    display: flex;
    flex-direction: column;
    font-size: var(--font-size-large);
    text-align: justify;
    text-align-last: justify;
    background-color: var(--couleur-6);
    padding: .5em;
    border-radius: var(--arrondi-medium);
    margin-bottom: 0;
}

.header-container section.block-logo h1 strong{
    font-size: 2.75em;
    font-weight: 800;
}

header#colleno.mini .header-container section.block-logo h1{
    font-size: var(--font-size-small);
}

.header-container .block-logo a.logo_box{
    display: block;
    height: 100%;
    width: fit-content;
}

header#colleno .header-container .block-logo a img,
header#colleno .header-container .block-logo a svg
{
    display: block;
    height: 100%;
    width: auto;
    min-height: 0;
}

.block-primary-menu ul.menu, .block-footer-menu ul.menu {
    gap: 2vw;
}

.block-primary-menu ul.menu > li{
    font-size: var(--font-size-large);
    font-weight: 800;
    text-transform: uppercase;
}

.block-primary-menu ul.menu > li > a,
.block-footer-menu ul.menu > li > a
{
    padding: 0.5rem 0rem;
}

.block-primary-menu ul.menu > li > a:hover,
.block-footer-menu ul.menu > li > a:hover
{
    text-decoration: underline;
}

.footer-sub-container{
    padding: .5rem;;
}

/*sous menus centrés*/

/*.block-primary-menu ul.sub-menu {
    left: 50%;
    opacity: 0;
    margin-left: 0;
    margin-right: 0;
    transform: translateX(calc(-50% - 10px));
}

.block-primary-menu ul.menu>li:hover ul.sub-menu {
    transform: translateX(-50%);
}*/


#main-container {
  padding-top: 6rem;
  position: relative;
  overflow: hidden;
}

:root{
    --n: 24;   /* number of dashes */
    --d: 4deg; /* control the space between dashes */
}

#main-container::before{
    content:'';
    position: absolute;
    right: 0;
    top: 20%;
    transform: translateX(50%);
    display: block;
    height: 50vw;
    aspect-ratio: 1;
    opacity: 0.4;
    z-index: 0;
    border-radius: 50%;
    padding: 20px; /* border thickness */
    /* the coloration (more examples: https://css-tip.com/dashed-rounded-border/ */
    background: 
        repeating-conic-gradient(
        var(--couleur-1) 0 calc(  360deg/var(--n)), 
        var(--couleur-2) 0 calc(2*360deg/var(--n))
        );
    mask: 
        linear-gradient(#0000 0 0) content-box intersect, 
        repeating-conic-gradient(from calc(var(--d)/2),
        #000  0 calc(360deg/var(--n) - var(--d)),
        #0000 0 calc(360deg/var(--n))
    );
}

#main-container > *{
    z-index: 1;
}

/*****************/
/*****contact*****/
/*****************/

.zone-contacts{
    display: flex;
    margin-top: 3rem;
}

.zone-contact-coordonnees{
    flex:0.3;
}

.zone-contact-form{
    flex:0.7;
}

.wpcf7-list-item-label{
    font-size: var(--font-size-small);
}

.wp-block-group a.coordonnees{
    font-size: var(--font-size-x-large);
    display: inline-block;
    padding-left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.wp-block-group .clic-button{
    display: none;
}

a.coordonnees:hover{
    color: var(--couleur-5);
}

#main-container .container-content {
    padding-bottom: 0;
}

/**********************/
/*****fil d'Ariane*****/
/**********************/

.breadcrumbs{
    margin: 1.75rem 0 0 2.5rem;
    text-transform: uppercase;
    font-style: italic;
    font-size: var(--font-size-small)
}

.breadcrumbs a{
    color: inherit;
}

.breadcrumbs a:hover{
    text-decoration: underline;
}

.breadcrumbs span span{
    position: relative;
    padding-right: 1rem;
    margin-right: 1rem;
}

.breadcrumbs span span::after{
    content : '';
    position: absolute;
    right: -1rem;
    top: 50%;
    width: .5rem;
    height: .375rem;
    transform: translate(-100%,-50%);
    background-image: url('../images/pictos/breadcrumbs-picto.svg');
    background-repeat: no-repeat;
    background-size: contain;
}

.breadcrumbs span span.breadcrumb_last::after{
    display: none;
}

/****************/
/*****footer*****/
/****************/

footer#colophon{
    max-width: 100vw;
    overflow: hidden;
    border-top: 4px solid var(--couleur-1);
    background-color: var(--couleur-6);
}

.footer-container{
    justify-content: center;
    gap: 10vw;
    padding: .5rem;
}

.footer-sub-container {
    background-color: var(--couleur-6);
}

/*****************/
/*****archive*****/
/*****************/

:where(.archive,.blog) .archive-wrapper{
    flex-wrap: wrap;
    gap: 2rem;
    justify-content: space-between;
}

:where(.archive,.blog) article{
    width: 30%;
}

:where(.archive,.blog) .post-thumbnail{
    width: 100%;
    height: auto;
}

:where(.archive,.blog) article.post-extrait + article.post-extrait {
    margin-top: 0;
}

.post-thumbnail{
    overflow: hidden;
}

article.post-extrait > * + .post-content {
    margin-left: 0;
}


/*************************/
/*****bloc flex-start*****/
/*************************/

/*règles CSS permettant de gérer l'affichage d'un contenu flex en flex start
centré dans un conteneur
structure :

<div class="flex-start-container">
    <div class="flex-start-wrapper">
        <div class="flex-start-element">


        </div>
    </div>
        <div class="flex-start-wrapper">
        <div class="flex-start-element">


        </div>
    </div>
</div>
*/


:root{
    --flex-start-container-width: 84vw;
    --flex-start-nb-columns: 5;
    --flex-start-element-width: calc(100% / var(--flex-start-nb-columns));
    --flex-start-element-height: 20vw;
    --flex-start-element-padding: .8vw;
}

.flex-start-container{
    width: var(--flex-start-container-width);
    padding: var(--flex-start-element-padding);
}

.flex-start-wrapper{
    width: var(--flex-start-element-width);
    height: var(--flex-start-element-height);
    padding: var(--flex-start-element-padding);
    transition: all var(--transition-basic-duration);
}

.flex-start-element{
    width: 100%;
    height: 100%;
    margin: 0;
}



