

<style>
    #dynamicMap {
        font-size: 1rem;
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        display: block;
        overflow: hidden;
    }


    #dynamicMap.overlayed:after {
        content: "";
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        display: block;
        background: #000000BB;
        /*
         backdrop-filter: blur(3px) opacity(1);
         */
    }

    #map {
        position: relative;
        overflow: hidden;
        background: #ededed;
    }

    #map:after {
        content: "";
        position: absolute;
        width: 100%;
        height: 100%;
        display: block;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        pointer-events: none;
    }

    .mapWrapper {
        position: relative;
        top: 0;
        left: 0;
    }

    .mapButtons {
        position: absolute;
        bottom: 20px;
        right: 20px;
    }

    #legende {
        position: absolute;
        top: 130px;
        right: 75px;
        background: #FFFFFF;
        border: 1px solid #000000;
        padding: 20px;
        font-size: 1.2em;
    }

    #legende ul {
        list-style-type: none;
        padding-left: 0;
        margin-bottom: 0;
    }

    #legende ul li {
        position: relative;
        margin-left: 0;
        cursor: pointer;
    }

    #legende ul li:not(:last-child) {
        margin-bottom: 0.2rem;
    }

    .carte {
        position: relative;
        width: 100%;
    }

    button {
        font-family: "stevie-sans", sans-serif;
        font-weight: 500;
        font-style: normal;
    }

    .btn-container a {
        margin-left: 10px;
    }

    .btn-map {
        background: #000000;
        color: #ffffff;
        border-radius: 1em;
        padding: 5px;
        line-height: 1;
        border: 3px solid #000000;
        transition: all 0.3s;
        font-size: 1.2em;
        font-family: "stevie-sans", sans-serif;
        font-weight: 500;
        font-style: normal;
    }


    .btn-video {
        background: #000000;
        color: #ffffff;
        border-radius: 0.2em;
        padding: 5px 5px 5px 30px;
        line-height: 1;
        transition: all 0.3s;
        font-family: "stevie-sans", sans-serif;
        font-weight: 500;
        font-style: normal;
        position: relative;
        border: 1px solid #000000;
    }

    .btn-video:hover {
        background: #ffffff !important;
        color: #000000;
        border: 1px solid #000000;
    }

    .btn-video:after {
        font-family: "bootstrap-icons";
        content: "\F3C3";
        position: absolute;
        left: 5px;
        top: 5px;
    }


    .btn-map:hover {
        background: #ffffff !important;
        color: #000000;
        border-radius: 1em;
        padding: 5px;
        line-height: 1;
    }

    .btn-map.btn-search, .btn-map.btn-language {
        font-size: 1em;
        padding: 0.2em 0.4em;
        border-radius: 1em;
    }

    .btn-map.btn-small {
        padding: 0;
        font-size: 1em;
        position: relative;
        top: -0.2em;
        color: #000000;
        background: transparent;
        border: none;
        transform: translateY(0.2em);
    }

    .pointeurCarte {
        font-family: sans-serif;
        position: absolute;
        width: 2em;
        height: 2em;
        display: block;
        border-radius: 1em;
        color: #000000;
        padding-top: 0.2em;
        padding-right: 0.1em;
        background: #FFFFFF;
        text-align: center;
        font-weight: bold;
        font-size: 1.2em;
        line-height: 1.3em;
        opacity: 0;
        border: 3px solid #000000;
        cursor: pointer;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        letter-spacing: -.05em;
    }

    .pointeurCarte:active {
        cursor: pointer;
        background: #000000 !important;
        color: #ffffff !important;
        box-shadow: 0 0 10px 5px #ffffff;
    }

    .pointeurCarte.is-active {
        background: #000000 !important;
        color: #ffffff !important;
        box-shadow: 0 0 10px 5px #ffffff;
        animation-name: rebond;
        animation-duration: 1s;
        animation-iteration-count: infinite;
        animation-timing-function: cubic-bezier(0.5, 0, 0.5, 1);
    }

    @keyframes rebond {
        0% {
            transform: scale(1);
        }
        50% {
            transform: scale(1.2);
        }
        100% {
            transform: scale(1);
        }
    }

    .pointeurCarte.visible {
        opacity: 1;
    }

    img.calque, svg.calque {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
    }


    ul#listing {
        list-style-type: none;
        padding-left: 0;
        columns: 3;
        margin: 0;
    }

    ul#listing li {
        position: relative;
        margin-left: 0;
        cursor: pointer;
        margin-bottom: 1rem;
    }

    ul#listing li.disabled {
        display: none;
    }

    .modal-hd .card-header.typesMarqueurs {
        padding-bottom: 1rem;
    }

    ul#typesListing {
        list-style-type: none;
        padding-left: 0;
        columns: 4;
        column-fill: balance;
        margin: 0;
    }

    ul#typesListing li {
        position: relative;
        margin-left: 0;
        cursor: pointer;
    }

    li[data-toggle="typeMarqueur"].disabled,
    li[data-toggle="resetMarqueurs"].disabled {
        opacity: 0.5;
    }

    span.filtrePuce {
        width: 1em;
        height: 1em;
        border-radius: 0.5em;
        border: 2px solid #000000;
        display: inline-block;
        margin-right: 10px;
        transform: translateY(3px);
        background: #FFFFFF;
        color: #000000;
    }


    /***********
    SCROLLBAR
    ***********/

    /* width */
    ::-webkit-scrollbar {
        width: 40px;
    }

    /* Track */
    ::-webkit-scrollbar-track {
        box-shadow: inset 0 0 10px #AAAAAA;
        border-radius: 0;
        background: #DDDDDD;
        border-left: 2px solid #000000;
    }

    /* Handle */
    ::-webkit-scrollbar-thumb {
        background: #64c2d1;
        border-radius: 0;
        border-left: 2px solid #000000;
        box-shadow: 0 0 8px #666666;
    }


    /***********
    FENETRES MODALES
    ***********/

    .modal-hd {
        position: absolute;
        z-index: 1000;
        top: 50%;
        left: 250px;
        right: 250px;
        transform: translateY(-50%);
        display: none;
        max-height: 80vh;
        overflow: hidden;
        border: 2px solid #000000;
        box-shadow: 0 0 20px #666666;
    }

    .modal-video {
        position: absolute;
        z-index: 1000;
        top: 50%;
        left: 200px;
        right: 200px;
        transform: translateY(-50%);
        display: none;
        max-height: 80vh;
        overflow: hidden;
        border: 2px solid #000000;
        box-shadow: 0 0 20px #666666;
    }

    .modal-hd .card {
        max-height: 80vh;
        overflow-y: scroll;
        font-size: 1.3rem;
        line-height: 1.6rem;
    }

    .modal-video .card {
        max-height: 80vh;
        overflow: auto;
        font-size: 1.3rem;
        line-height: 1.6rem;
    }


    .modal-hd button {
        position: fixed;
        bottom: 8px;
        right: 48px;
        z-index: 3000;
        background-color: #000000;
        color: #FFFFFF;
        border-radius: 20px;
        padding: 2px 10px;
        border: none;
        font-size: 1.2rem;
    }


    .modal-video button {
        position: fixed;
        top: 8px;
        right: 8px;
        z-index: 3000;
        background-color: #000000;
        color: #FFFFFF;
        border-radius: 20px;
        padding: 2px 10px;
        border: none;
        font-size: 1.2rem;
    }


    .modal-hd .card, .modal-video .card {
        border: none;
        border-radius: 0;
    }

    .modal-hd .card-header {
        padding: 2rem;
        background: #FFFFFF;
        box-shadow: 0 10px 10px 0 #00000033;
    }


    .modal-hd .puceTitre {
        font-family: sans-serif;
        width: 2em;
        height: 2em;
        display: block;
        border-radius: 1em;
        color: #000000;
        padding-top: 0.4em;
        padding-right: 0.1em;
        background: #FFFFFF;
        text-align: center;
        font-weight: bold;
        font-size: 0.5em;
        line-height: 1em;
        border: 3px solid #000000;
        letter-spacing: -.05em;
        float: left;
        margin-right: 20px;
        transform: translatey(-3px);
    }


    .modal-hd .card-header figure {
        margin: 0;
    }

    .modal-hd .card-header img {
        float: right;
        max-height: 150px;
    }

    .modal-hd .card-body {
        padding: 2rem;
    }

    .modal-video .card-body {
        padding: 0rem;
        line-height: 0;
    }

    .modal-hd .card-header .modal-hd-title {
        font-size: 2.4rem;
        margin: 0;
    }


    .masqueYoutube-1 {
        position: absolute;
        bottom: 0;
        pointer-events: unset;
        width: 140px;
        height: 50px;
        right: 0;
        display: block;
        z-index: 2999;
    }

    .masqueYoutube-2 {
        position: absolute;
        top: 0;
        pointer-events: unset;
        width: calc(100% - 130px);
        height: 60px;
        left: 0;
        display: block;
        z-index: 2999;
    }

    .cke_editable {
        font-size: 1.3rem !important;
    }


    .square-box {
        position: relative;
        width: 100%;
        overflow: hidden;
        background: var(--couleurFond);
        transition: transform 0.3s;
    }

    .square-box:hover {
        transform: scale(1.1);
    }

    .square-box:before {
        content: "";
        display: block;
        padding-top: 100%;
    }

    .square-content {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        color: white;
        text-align: center;
    }


    .galeriePhotos .col {
        padding-top: 15px;
        padding-bottom: 15px;
    }

    .galeriePhotos figure {
        width: 100%;
        height: 100%;
        overflow: hidden;
        margin: 0 !important;
    }

    .galeriePhotos figure img {
        object-fit: cover;
        width: 100%;
        height: 100% !important;
        transition: transform 0.3s;
    }

    .galeriePhotos figure:hover img {
        transform: scale(1.1);
    }


    .galeriePhotos figcaption {
        padding: 1px 3px 3px;
        font-size: 0.8em;
        color: #999999;
    }

</style>