@font-face {
    font-family: 'magic';
    src        : url('../webfonts/MagicSound.woff2') format('woff2');
    font-weight: normal;
    font-style : normal;
}

@font-face {
    font-family: 'marianne';
    src        : url('../webfonts/Marianne-Regular.woff2') format('woff2');
    font-weight: normal;
    font-style : normal;
}

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

:root {
    --vert: #1C7F91;
}

html {
    scroll-behavior: smooth;
    min-height     : 100vh;
}

body {
    min-height : 100%;
    font-family: 'marianne';
    background : #fff;
    font-size  : 1rem;
    color      : red,
}

h4.align_center,
p.align_center {
    text-align: center;
}

img.align_center {
    display: block;
    margin : 0 auto;
}

figure,
media,
audio,
img {
    max-width: 100%;
}

img {
    height: auto;
}

#whole_wrapper {
    min-height    : 100vh;
    display       : flex;
    flex-direction: column;
    margin        : 0 auto;
    position      : relative;
    overflow-x    : hidden;
}

#main {
    flex-grow     : 1;
    padding-block : 3.25rem;
    padding-inline: 1rem;
}

@media (min-width: 800.1px) {
    #main {
        padding-inline: 0;
    }
}

h4 {
    font-size: 24px;
}

.nav-item,
#transition,
footer {
    text-align: left
}

.container-fluid {
    width  : 100% !important;
    padding: 0;
}

.container {
    width        : min(800px, 100%);
    margin-inline: auto;
}

.container>h1 {
    margin-bottom: 1rem;
}

.container p {
    /* text-align    : justify; */
    padding-bottom: 1rem;
}

.container h4 {
    padding-bottom: .7rem;
}

.container h2 {
    padding-top   : .5rem;
    padding-bottom: 1rem;
}

#headpart {
    width           : 100%;
    background-color: #1C7F91;
    color           : rgb(255, 255, 255);
}

#bigtitle {
    display        : flex;
    flex-direction : column;
    justify-content: center;
}

#bigtitle h1 {
    font-family  : 'magic';
    font-size    : clamp(1rem, -0.08rem + 4.1vw, 3rem);
    color        : #fff;
    padding-right: 30px;
    padding-top  : 10px;
}

#bigtitle h2 {
    font-size: clamp(1.25rem, 0.7rem + 2.08vw, 1.875rem);
}

#top_logo {
    width  : clamp(5rem, 3.65rem + 5.13vw, 7.5rem);
    display: block;
}

.top_logo_title {
    display: flex;
    gap    : 1rem;
}

.bouton_tenir {
    display          : block;
    width            : 160px;
    text-align       : center;
    /* vertical-align: baseline; */
    background-color : #faf9d0;
    color            : #000;
    border-radius    : 5px;
    margin           : .5rem auto 0 auto;
    /* padding       : 0.5rem auto; */
}

@media (min-width: 390px) {
    .bouton_tenir {
        margin: 0 auto;
    }
}

.tenir {
    vertical-align: auto;
    padding-top   : 0.5rem;
    padding-bottom: 0.5rem !important;
}

.bouton_tenir a {
    text-decoration: none;
    color          : black;
    font-family    : 'marianne';
    font-size      : 1rem;

}

.bouton_tenir a:visited {
    color: #000;
}

#mainnav li a {
    color          : #ffffff;
    text-decoration: none;
}

/* #mainnav li a:hover, */
#mainnav li a.activ {
    color           : #ffd13a;
    /* border-bottom: #ffd13a solid 2px; */
}

#mainnav li a::after {
    content         : '';
    display         : block;
    width           : 100%;
    height          : 2px;
    background      : #ffd13a;
    transform       : scaleX(0);
    transform-origin: right;
    transition      : transform .3s;
}

#mainnav li a:focus-visible::after,
#mainnav li a:hover::after {
    transform       : scaleX(1);
    transform-origin: left;
}

#mainnav {
    position  : fixed;
    left      : 0;
    top       : 0;
    width     : 100%;
    height    : 100%;
    background: #1C7F91;
    z-index   : 1000;
    padding   : 40px 20px;
    text-align: center;
    transform : translateX(-100%);
    transition: transform .5s ease-in-out;
    color     : white;
}

#mainnav.open {
    display  : block;
    transform: translateX(0);
}

#openmenu,
#closemenu {
    font-size: 2rem;
    color    : black;
}

#openmenu {
    position: absolute;
    top     : 1rem;
    right   : 1rem;
}

#containerbandeau img {
    width: 100%;
}

#totop {
    display      : block;
    padding      : 8px;
    font-size    : 2rem;
    position     : fixed;
    right        : 20px;
    bottom       : 20px;
    background   : #1C7F91;
    color        : rgb(255, 255, 255) !important;
    z-index      : 40;
    line-height  : 1 !important;
    border-radius: 6px;
    transition   : opacity .3s;
    opacity      : .4;
}

#totop:hover {
    opacity: 1;
}

#mainnav ul {
    margin: 0;
}

#mainnav li {
    display  : block;
    margin   : 0 0 15px 0;
    font-size: 1.5rem;
}

#mainnav li::last-child {
    margin-right: 0;
}

#nav {
    padding: 24px;
}

ul {
    list-style: none;
}

.bandeau {
    width: 100%;
}


.container li {
    text-align: justify;
}

.evt ul {
    padding-left: 0;
}

.evt ul li {
    padding-inline: 1rem;
    padding-top   : .5rem;
    border-bottom : 2px solid #222;
}

.evt li h2 {
    padding-bottom: 1rem;
}

.evt li p.date {
    padding-bottom: .3rem;
}

.evt img {
    display: block;
    margin : auto;
    width  : 60%;
}

.vignette {
    display              : grid;
    gap                  : 2.5rem;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.vignette img {
    margin-bottom: .4rem;
}

.vignette h4 {
    line-height  : 1;
    margin-bottom: .1rem;
}

.vignette p:last-of-type {
    margin-bottom: .2rem;
}

.bigfoot {
    background-color: #4eaebe;
    color           : #ffffff;
    padding-block   : 1.2rem;
}

.bigfoot a {
    color          : #ffffff;
    text-decoration: none;
    display        : inline-block;
}

/* .bigfoot li a:hover, */
.bigfoot li a.activ {
    color        : #ffd13a;
    border-bottom: #ffd13a solid 1px;
}

.bigfoot li a::after {
    content   : '';
    display   : block;
    width     : 0;
    height    : 2px;
    background: #ffd13a;
    transition: width .3s;
}

.bigfoot li a:hover::after {
    width     : 100%;
    transition: width .3s;
}

.containerfoot {
    width             : min(1000px, 96%);
    /* display        : flex;
    flex-wrap         : wrap;
    justify-content   : space-evenly; */
    display           : grid;
    /* padding        : auto; */
    margin-inline     : auto;
}

@media (min-width: 650px) {
    .containerfoot {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 992px) {
    .containerfoot {
        grid-template-columns: repeat(4, 1fr);
    }
}

.footbox {
    min-width : 220px;
    margin    : 2px;
    padding   : 10px;
    transition: 0.3s;
    text-align: center;
}

@media (min-width: 650px) {
    .footbox {
        text-align: left;
    }
}

#foot_logo {
    display: inline-block;
    width  : clamp(5rem, 3.65rem + 5.13vw, 7.5rem);
}

footer {
    background-color   : #1C7F91;
    color              : rgba(255, 255, 255, .8);
    font-size          : .9rem;
    /* height          : 80px; */
    padding-block      : .4rem;
    position           : relative;
    bottom             : 0;
    left               : 0;
    width              : 100%;
    font-family        : "marianne";
    text-align         : center;
}

footer a {
    color          : rgba(255, 255, 255, .8);
    text-decoration: none;
}

footer a:hover {
    color          : rgba(255, 255, 255, .8);
    text-decoration: underline;
}

footer .sep {
    display: inline-block;
    margin : 0 5px;
}

.lg-sub-html p {
    font-size: 1.2rem !important;
    color    : #333;
}

#formcontact {
    margin       : 0 auto;
    width        : 100%;
    padding      : 3rem 10%;
    border       : 1px solid rgb(0, 0, 0);
    border-radius: 1em;
}

form {
    margin: 0 auto;
}

#formulaire {
    width    : 100%;
    max-width: 900px;
    margin   : 0 auto;
    padding  : 0 5%;
}

form div+div {
    margin-top: 1em;
}

input,
textarea {
    font      : 1em sans-serif;
    width     : 100%;
    box-sizing: border-box;
    border    : 1px solid #999;
}

input:focus,
textarea:focus {
    border-color: #000;
}

textarea {
    vertical-align: top;
    height        : 5em;
}

.button {
    padding-left: 90px;
}

button {
    margin: auto;
}



/* FORMULAIRE */

.alert,
.alert-warning {
    margin-inline   : auto;
    color           : #664d03;
    background-color: #fff3cd;
    border-color    : #ffecb5;
    position        : relative;
    padding         : 1rem 1rem;
    margin-bottom   : 1rem;
    border          : 1px solid transparent;
    border-radius   : 0.25rem;
    font-family     : 'marianne';
    max-width       : 90%;
}

.invisible {
    position: absolute;
    left    : -9999px;
}

.input-container {
    position: relative;
    margin  : 20px;
}

.input-field {
    display         : block;
    width           : 100%;
    padding         : 10px;
    font-size       : 16px;
    border          : none;
    border-bottom   : 2px solid #ccc;
    outline         : none;
    background-color: transparent;
}

.select-field {
    display         : block;
    width           : 100%;
    padding         : 10px;
    font-size       : 16px;
    border          : none;
    border-bottom   : 2px solid #ccc;
    outline         : none;
    background-color: transparent;
}

.input-label {
    position      : absolute;
    top           : 0;
    left          : 0;
    font-size     : 16px;
    color         : rgba(204, 204, 204, 0);
    pointer-events: none;
    transition    : all 0.3s ease;
}

.select-label {
    font-size     : 16px;
    pointer-events: none;
    transition    : all 0.3s ease;
    font-family   : 'marianne';
    color         : #757575;
}

.input-highlight {
    position        : absolute;
    bottom          : 0;
    left            : 0;
    height          : 2px;
    width           : 0;
    background-color: #1C7F91;
    transition      : all 0.3s ease;
}

.input-field:focus+.input-label {
    top        : -20px;
    font-size  : 12px;
    color      : #1C7F91;
    font-family: 'marianne';
}

.input-field:focus+.input-label+.input-highlight {
    width: 100%;
}

.text-field {
    display         : block;
    width           : 100%;
    padding         : 10px;
    font-size       : 16px;
    border          : 2px solid #ccc;
    outline         : none;
    background-color: transparent;
}

.text-field:focus {
    font-size   : 16px;
    border-color: #1C7F91;
    font-family : 'marianne';
}

.envoi {
    display: flex;
}

button:not(.lg-icon) {
    display         : flex;
    align-items     : center;
    justify-content : center;
    outline         : none;
    cursor          : pointer;
    width           : 150px;
    height          : 50px;
    background-image: linear-gradient(to top, #D8D9DB 0%, #fff 80%, #FDFDFD 100%);
    border-radius   : 10px;
    border          : 1px solid #8F9092;
    transition      : all 0.2s ease;
    font-family     : "mariane", sans-serif;
    font-size       : 14px;
    font-weight     : 600;
    color           : #606060;
    text-shadow     : 0 1px #fff;
}

button:not(.lg-icon):hover {
    box-shadow: 0 4px 3px 1px #FCFCFC, 0 6px 8px #D6D7D9, 0 -4px 4px #CECFD1, 0 -6px 4px #FEFEFE, inset 0 0 3px 3px #CECFD1;
}

button:not(.lg-icon):active,
button:not(.lg-icon):focus {
    box-shadow: 0 4px 3px 1px #FCFCFC, 0 6px 8px #D6D7D9, 0 -4px 4px #CECFD1, 0 -6px 4px #FEFEFE, inset 0 0 5px 3px #999, inset 0 0 30px #aaa;
}

@media (min-width: 1200px) {
    h1 {
        font-size: 2.5rem;
    }

    header h1 {
        font-size: 4rem;
    }
}

@media (min-width: 768px) {
    #mainnav {
        position          : static;
        height            : auto;
        background        : #1C7F91;
        z-index           : 1000;
        padding           : 0;
        text-align        : left;
        display           : flex;
        justify-content   : end;
        width             : min(1200px, 100%);
        /* padding-inline : 1.5rem; */
        opacity           : 1;
        margin            : 1rem auto 0 auto;
        transform         : none;
    }

    #mainnav ul {
        margin: 0;
    }

    #mainnav li {
        display  : inline-block;
        margin   : 0 10px 0 0;
        font-size: 1rem;
    }

    #mainnav li::last-child {
        margin-right: 0;
    }

    #openmenu,
    #closemenu {
        display: none;
    }
}

/* @media (max-width: 1170px) {
    img {
        width  : 100%;
        padding: 20px;
    }
} */

@media (max-width: 970px) {
    /* .containerfoot .footbox {
        flex-basis  : 40%;
        padding-left: 20px;
    } */

    img {
        padding: 0;
    }

    .containerbandeau {
        padding: 0;
    }

    .container ul {
        padding-left : 1rem;
        padding-right: 1rem;
    }

    .container li {
        display      : block;
        padding-left : 1rem;
        padding-right: 1rem;
        text-align   : justify;
    }

    a {
        display: inline-block;
    }

    .bigtitle h1 {
        font-size: 1rem;
    }
}

/*************
 * galleries
 ************/

.grid_sizer,
.grid_item {
    width  : 100%;
    padding: 1px;
}

.grid_sizer a,
.grid_item a {
    display : block;
    width   : 100%;
    height  : 100%;
    overflow: hidden;
}

.grid_sizer a img,
.grid_item a img {
    transition: transform 0.3s;
}

.grid_sizer a:hover img,
.grid_item a:hover img {
    transform: scale(1.1);
}

@media (min-width: 576px) {

    .grid_sizer,
    .grid_item {
        width: 50%;
    }
}

@media (min-width: 768px) {

    .grid_sizer,
    .grid_item {
        width: calc(100%/3);
    }
}

/************
 * bibi forms
 ************/

.cal_login h1 {
    text-align: center;
}

#creer_form_wrap,
#login_form_wrap {
    padding-top: 1.5rem;
}

#creer_form_wrap form {
    width: min(600px, 100%);
}

#login_form_wrap form {
    width: min(400px, 100%);
}

.forminp {
    padding-bottom: 1rem;
}

.forminp label {
    display      : block;
    margin-bottom: 0.5rem;
}

p.alert-success,
p.alert-danger {
    background   : rgba(235, 93, 22, 0.2);
    color        : red;
    font-weight  : 700;
    padding      : .5rem 1rem;
    margin-bottom: 1rem;
}

p.alert-success {
    background: rgba(22, 235, 51, 0.1);
    color     : var(--vert);
}

textarea.forminput,
input[type=text].forminput,
input[type=email].forminput,
input[type=number].forminput,
input[type=password].forminput {
    width        : 100%;
    height       : 100%;
    background   : #fff;
    border       : 1px solid #dedede;
    border-radius: 5px;
    transition   : border 300ms;
    padding      : 7px 1rem;
    font-size    : 1rem;
    font-family  : inherit;
    color        : #333;
}

select.select-field.formselect {
    display         : block;
    width           : 100%;
    padding         : 10px;
    font-size       : 16px;
    border          : 1px solid #dedede;
    outline         : none;
    background-color: transparent;
}





.input_help {
    font-style : italic;
    font-weight: .8rem;
    color      : var(--vert);
    margin     : 0;
}

/*********
 * fancy box
 *********/
.fancybox__carousel .fancybox__slide.has-iframe .fancybox__content {
    max-width    : 650px;
    height       : auto;
    padding      : 0;
    border-radius: 10px;
}

.fancybox__carousel .fancybox__slide.has-iframe .fancybox__content iframe {
    border-radius: 5px;

}

.fancybox__carousel .fancybox__slide.has-iframe .fancybox__content .carousel__button.is-close,
.fancybox__carousel .fancybox__slide.has-iframe .fancybox__content .f-button.is-close-btn {
    top         : -50px;
    right       : 10px;
    font-size   : 1.5rem;
    font-weight : bold;
    z-index     : 50000;
    background  : white !important;
    color       : #333 !important;
    stroke-width: 3px;
    box-shadow  : 0 0 8px rgba(0, 0, 0, .5);
    transition  : background-color 250ms;
    width       : 40px !important;
    height      : 40px !important;
}

.fancybox__carousel .fancybox__slide.has-iframe .fancybox__content .carousel__button.is-close:hover,
.fancybox__carousel .fancybox__slide.has-iframe .fancybox__content .f-button.is-close-btn:hover {
    background: green !important;
    color     : white !important;
}

#tinyframe .fancybox__slide.has-iframe .fancybox__content {
    max-width    : 500px;
    height       : 600px !important;
    padding      : 0;
    border-radius: 10px;
}


#tinyframe .fancybox__slide.has-iframe iframe {
    border-radius: 10px;
}

.fancybox__backdrop {
    background: rgba(0, 0, 0, .3);
}

.fancybox__carousel .fancybox__slide.has-iframe .fancybox__content {
    width  : 100%;
    height : 100%;
    padding: 0;
}

.fancybox__carousel .fancybox__slide.has-iframe .fancybox__content iframe {
    width : 100%;
    height: 100%;
}

/*************
 * zi calendar
 *************/

.cal_wrapper {
    width : min(800px, 95%);
    margin: 0 auto;
}

#calendar {
    width : 100%;
    margin: 1rem auto;
}

#calendar button {
    background    : #111;
    border-radius : 0.25em;
    display       : inline-block;
    font-size     : 1em;
    font-weight   : 400 !important;
    line-height   : 1.5;
    padding       : 0.3rem 0.8rem !important;
    width         : auto !important;
    height        : auto !important;
    text-align    : center;
    user-select   : none;
    vertical-align: middle;
}

.fc-event.concert {
    background   : green !important;
    font-size    : 1rem;
    font-weight  : 700;
    padding-block: .2rem;
}

/***********
 * cosmétique
 ***********/
.txt_center {
    text-align: center !important;
}

.txt_right {
    text-align: right !important;
}

a.greenlink {
    color          : var(--vert);
    text-decoration: none;
}

a.greenlink:hover,
a.greenlink:focus-visible {
    color          : var(--vert);
    text-decoration: underline;
}

a.buttlike {
    display        : inline-block;
    padding        : .5rem 1.2rem;
    color          : white;
    background     : var(--vert);
    text-decoration: none;
    border-radius  : 3px;
}