/* +P
  __      ____
 /\ \    /\  _`\  
 \_\ \___\ \ \L\ \
/\___  __\\ \ ,__/
\/__/\ \_/ \ \ \/ 
    \ \_\   \ \_\ 
     \/_/    \/_/ 
     Yeah! 2022 plusproduit.com
     
     plus10 theme 22.12.24
*/

/* Couleurs et gouttières dans global.css */

html {
    font-size: 23px;
    background-color: var(--bs-body-color);
}

body {
    background: transparent;
}


/* #region STRUCTURE */

main {
    background-color: var(--bs-body-bg);
    /* taille du header voir global.css */
    /* padding-top: var(--p-header-height); */
}

.main-content {
    padding-top: var(--p-header-height);
}

.region-content {
    padding-bottom: 2rem;
}

#block-plus10-entityviewcontenu {
    min-height: 200px;
}

.toolbar-fixed .main-content {
    padding-top: calc(var(--p-header-height) + 39px);
}

.toolbar-tray-open.toolbar-horizontal .main-content {
    padding-top: calc(var(--p-header-height) + 79px);
}

.breadcrumb ol,
.mini {
    margin: 0 0 .5em;
    padding: .8rem 0 0;
    list-style-type: none;
    display: flex;
    font-weight: normal;
    font-size: .65rem;
    color: var(--bs-secondary);
}

.breadcrumb ol li::after {
    content: "→";
    margin-right: .4em;

}

.breadcrumb ol li:nth-last-child(1):after {
    content: "";
}

/* #endregion */


/* #region HEADER */

/* Navbar */
.site-header-inner {
    padding: 8px 0;
    /* background-color: rgba(var(--bs-body-bg-rgb), 0); */
}

/* Fixed-top */
.scrolled .fixed-top .site-header-inner {
    /* padding-top: 5px; */
    /* padding-bottom: 5px; */
    background-color: rgba(var(--bs-dark-rgb), 0.95);
}

/* Aligne logo et menu au centre vertical */
.region-header {
    align-items: center;
}

/* annule le 100% par défaut -> bs col-auto */
.region-header .block {
    flex: 0 0 auto;
    width: auto;
}

/* cache burger sur le desktop */
/* #p-offcanvasbtn {
    display: none;
} */

/* fait de la place pour le burger fixed 1060?  */
@media (max-width: 991.98px) {
    .region-header {
        padding-right: 75px;
    }

    .region-header .block-system-branding-block {
        padding-right: 0;
    }

    /* cache les menus dans le header */
    .region-header nav {
        display: none;
    }

    /* Affiche burger sur mobile */
    #p-offcanvasbtn {
        display: block;
    }
}

/* Pousse les autres éléments dans le header à droite */
.region-header .block-system-branding-block {
    margin-right: auto;
}

.block-system-branding-block .block-inner {
    display: flex;
    align-items: center;
}

/* Logo ----------- */
.site-logo img {
    width: 100%;
    height: auto;
}

.site-logo {
    width: 50px;
    margin-right: .6rem;
}

/* .scrolled .fixed-top .site-logo {
    width: 25px;
} */

.site-name {
    font-size: 15px;
    font-weight: var(--p-body-font-strong-weight);
    line-height: 1.2;
    width: 112px;
}

.site-name a,
.site-name a:hover {
    /* font-size: 16px; */
    color: var(--bs-body-bg);
}

.site-slogan {
    font-size: .8rem;
}

.p-invert-color .fixed-top .site-name a,
.p-invert-color .fixed-top .site-slogan {
    color: var(--bs-light);
}

/* le délai permet le calcul du padtop */

.p-loaded .site-header {
    transition: top .4s ease-in-out .2s;
}

.p-loaded .site-header-inner {
    transition: .4s ease-out .6s;
}

.p-loaded .site-logo {
    transition: width .4s ease-out .6s;
}

@media (max-width: 991.98px) {

    .site-header-inner,
    .scrolled .fixed-top .site-header-inner {
        padding: 10px 0;
    }

    .site-logo,
    .scrolled .fixed-top .site-logo {
        width: 32px;
    }

}

/* #endregion */


/* #region DROPDOWN multilevel nav */

.menu-item--expanded {
    position: relative;
}

.site-header ul.nav>.menu-item--expanded,
.site-header ul.nav .menu-item--expanded>ul {
    border-left: 2px solid transparent;
}

.site-header ul.nav ul {
    list-style-type: none;
    padding: 0;
    margin: 0;
    width: 12rem;
    font-size: .8rem;
}

/* moins la largeur du border */
.site-header ul.nav>li>ul,
.site-header ul.nav>li>ul>li>ul {
    display: none;
    position: absolute;
    left: -2px;
}

.site-header ul.nav .menu-item--expanded:hover,
.site-header ul.nav .menu-item--expanded:hover>ul {
    display: block;
    background-color: rgba(var(--bs-body-bg-rgb), .95);
    border-color: var(--bs-primary);
}

/* troisième niveau */

.site-header ul.nav>li>ul>li>ul {
    display: none;
    left: 40px;
}

/* #endregion */


/* #region LANGUAGE */

.block-language .links a {
    text-transform: uppercase;
    font-size: 17px;
    padding: 0;
    color: #9A9088;
    font-weight: var(--p-body-font-strong-weight);
}

.block-language .links a:hover,
.block-language .links a.is-active {
    color: var(--bs-body-color);
}

.block-language .links li {
    margin-right: 10px;
    color: #9A9088;
}

.block-language .links li::after {
    content: '-';
    margin-left: 10px;
}

.block-language .links li:nth-last-child(1)::after {
    content: '';
}

/* #endregion */


/* #region FOOTER */

.site-footer_top {
    padding: 20vh 0 5vh;
}

.site-footer_bottom {
    padding: 2vh 0;
}

#block-plus10-footer1 .text-formatted a {
    text-decoration: underline;
    color: var(--bs-light);
}

#block-plus10-footer1 .text-formatted a:hover {
    text-decoration: none;
}

#block-plus10-footer1 .text-formatted .small {
    font-size: .65rem;
}

#block-plus10-identitedusite {
    order: -2;
    margin-bottom: 1rem;
}

#block-plus10-footer1 .group-right {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

#block-plus10-footer1 .group-left {
    padding-right: 0;
}

@media (min-width:980px) {

    #block-plus10-identitedusite {
        order: 0;
    }

    .site-footer .site-logo {
        margin: 0 0 0 auto;
    }

}

/* #endregion */


/* #region TYPOGRAPHY */

h1,
h2,
h3,
h4,
h5,
h6,
.font2 {
    /* font-family: var(--p-alt-font-family); */
    font-weight: var(--p-alt-font-weight);
    margin-bottom: 1rem;
}

h1,
h2,
.big {
    font-size: 2rem;
}

h3 {
    font-size: 1rem;
    font-weight: var(--p-body-font-strong-weight);
}

p {
    margin-bottom: 1.4rem;
}

b,
strong {
    font-weight: var(--p-body-font-strong-weight);
}

.small,
small {
    font-size: 0.75em;
}

hr {
    opacity: 1;
    border-top: 1px solid var(--bs-body-color);
}

.field__label,
.field-label-above,
.field-label-inline,
figcaption {
    font-size: .8rem;
    font-weight: var(--p-body-font-strong-weight);
}

.field-label-inline {
    float: left;
    margin: 0 1rem 1rem 0;
}

/* listes contenu */
.text-formatted ul,
.text-formatted ol {
    margin: 1.5rem;
}

/* citation */
blockquote {
    font-size: 1.5rem;
    padding: 1.5rem 0 .5rem 1.5rem;
    border-left: 5px solid var(--bs-primary);
}

/* #endregion */


/* #region COLORS + LINKS + SOCIAL */

/* #region COLORS */
.color1 {
    color: var(--bs-body-color);
}

.color2 {
    color: var(--bs-primary);
}

.bg1 {
    background-color: var(--bs-body-bg);
}


.bg-neg,
.text-bg-primary,
.text-bg-dark {
    color: var(--bs-body-bg) !important;
}

.text-bg-primary {
    background-color: var(--bs-primary) !important;
}

.text-bg-secondary {
    background-color: var(--bs-secondary) !important;
    color: var(--bs-body-color) !important;
}

.text-bg-dark {
    background-color: var(--bs-dark) !important;
}

/* #endregion */

/* #region LINKS a + nav-link */

a {
    color: var(--bs-primary);
    text-decoration: none;
}

a:hover,
a:focus,
a.is-active {
    color: var(--bs-dark);
    text-decoration: none;
}

/* nav ---- */
.nav-link,
.links a {
    color: var(--bs-body-color);
}

.nav-link:hover,
.nav-link:focus,
.nav-link.active,
.nav-link.is-active,
.links a:hover,
.links a:focus,
.links a.is-active {
    color: var(--bs-primary);
}

/* bg-neg links ------------- */

.bg-neg a,
.text-bg-primary a {
    color: var(--bs-white);
}

.bg-neg a:hover,
.bg-neg a:focus,
.bg-neg a.is-active,
.text-bg-primary a:hover,
.text-bg-primary a:focus,
.text-bg-primary a.is-active,
.text-bg-dark a:hover,
.text-bg-dark a:focus,
.text-bg-dark a.is-active {
    color: var(--bs-light);
}


/* pagination */

.pagination {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.page-link,
.page-link:hover {
    color: var(--bs-primary);
}

.active>.page-link,
.page-link.active {
    color: var(--bs-body-bg);
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.bg-neg .page-link,
.text-bg-primary .page-link {
    color: var(--bs-light);
    background-color: var(--bs-primary);
    border-color: var(--bs-body-bg);
}

.bg-neg .page-link:hover,
.text-bg-primary .page-link:hover {
    color: var(--bs-body-bg);
    background-color: rgba(255, 255, 255, 0.2);
}

.bg-neg .active>.page-link,
.bg-neg .page-link.active,
.text-bg-primary .active>.page-link,
.text-bg-primary .page-link.active {
    color: var(--bs-primary);
    background-color: var(--bs-body-bg);
    border-color: var(--bs-body-bg);
}

/* js pager */

.js-pager__items {
    list-style-type: none;
    margin: 2rem 0;
    padding: 0;
    display: flex;
    justify-content: center;
}


/* nav ---- */
.bg-neg .nav-link,
.bg-neg .links a,
.text-bg-primary .nav-link,
.text-bg-primary .links a {
    color: var(--bs-light);
}

.bg-neg .nav-link:hover,
.bg-neg .nav-link:focus,
.bg-neg .nav-link.active,
.bg-neg .nav-link.is-active,
.bg-neg .links a:hover,
.bg-neg .links a:focus,
.bg-neg .links a.is-active,
.text-bg-primary .nav-link:hover,
.text-bg-primary .nav-link:focus,
.text-bg-primary .nav-link.active,
.text-bg-primary .nav-link.is-active,
.text-bg-primary .links a:hover,
.text-bg-primary .links a:focus,
.text-bg-primary .links a.is-active {
    color: var(--bs-white);
}

/* #endregion */


/* #region BTN + CTA */

.btn,
.cta a,
.more-link a,
.node-readmore a,
.button {
    display: inline-block;
    width: auto;
    text-align: center;
    line-height: 1.5;
    padding: .5em 1.5em;
    /* text-transform: uppercase; */
    text-decoration: none;
    border-radius: 1rem;
    border: 2px solid var(--bs-primary);
    color: var(--bs-body-bg);
    background-color: var(--bs-primary);
    /* font-weight: var(--p-body-font-strong-weight); */
    font-size: .8rem;
    /* letter-spacing: .12em; */
    transition: .6s;
    margin: 0 1em 1em 0;
}

.btn:hover,
.btn:first-child:active,
.cta a:hover,
.more-link a:hover,
.node-readmore a:hover,
.button:hover {
    color: var(--bs-primary);
    text-decoration: none;
    background-color: var(--bs-body-bg);
    border-color: var(--bs-primary);
}

/* bg-neg cta */
.bg-neg .btn,
.bg-neg .cta a,
.bg-neg .more-link a,
.bg-neg .node-readmore a,
.bg-neg .button,
.text-bg-primary .btn,
.text-bg-primary .cta a,
.text-bg-primary .more-link a,
.text-bg-primary .node-readmore a,
.text-bg-primary .button {
    border-color: var(--bs-primary);
    background-color: var(--bs-primary);
    color: var(--bs-dark);
}

.bg-neg .btn:hover,
.bg-neg .btn:first-child:active,
.bg-neg .cta a:hover,
.bg-neg .more-link a:hover,
.bg-neg .node-readmore a:hover,
.bg-neg .button:hover,
.text-bg-primary .btn:hover,
.text-bg-primary .btn:first-child:active,
.text-bg-primary .cta a:hover,
.text-bg-primary .more-link a:hover,
.text-bg-primary .node-readmore a:hover,
.text-bg-primary .button:hover {
    color: var(--bs-light);
    background-color: var(--bs-body-color);
    border-color: var(--bs-body-color);
}


/* Button outline à ajouter ============================================= */

/* #endregion */


/* #region SOCIAL */

.social-link a {
    display: inline-block;
    width: 35px;
    height: 30px;
    margin-right: 3px;
    margin-top: 5px;
    overflow: hidden;
    background: url('img/sn-ext.svg') no-repeat center center;
    background-size: contain;
    color: var(--bs-light);
    text-indent: -1300px;
    font-size: 10px;
}

.social-link a[href^="https://www.linkedin.com/"] {
    background-image: url('img/sn-in.svg');
}

.bg-neg .social-link a[href^="https://www.linkedin.com/"] {
    background-image: url('img/sn-in-neg.svg');
}

.social-link a[href^="https://www.facebook.com/"] {
    background-image: url('img/sn-fb.svg');
}

.bg-neg .social-link a[href^="https://www.facebook.com/"] {
    background-image: url('img/sn-fb-neg.svg');
}

.social-link a[href^="https://www.instagram.com/"] {
    background-image: url('img/sn-insta.svg');
}

.bg-neg .social-link a[href^="https://www.instagram.com/"] {
    background-image: url('img/sn-insta-neg.svg');
}

.social-link a[href^="https://twitter.com/"] {
    background-image: url('img/sn-tw.svg');
}

.bg-neg .social-link a[href^="https://twitter.com/"] {
    background-image: url('img/sn-tw-neg.svg');
}

.social-link a[href^="https://www.youtube.com/"] {
    background-image: url('img/sn-yt.svg');
}

.bg-neg .social-link a[href^="https://www.youtube.com/"] {
    background-image: url('img/sn-yt-neg.svg');
}

.social-link a:hover {
    opacity: .8;
}

/* #endregion */


/* #endregion */


/* #region PAGE */

/* Front - Accueil */

.path-frontpage .main-content {
    padding-top: 0;
}

.path-frontpage .region-content {
    padding-bottom: 0;
}

/* Node */

.path-node.page-node-type-page .main-content {
    padding-top: 4rem;
}

/* Accroche */

.page-acc {
    position: relative;
    overflow: hidden;
}

.page-acc h2 {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    display: flex;
    margin: 0;
}

.page-acc h2 a {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--bs-light);
    text-align: center;
    background-color: rgba(var(--bs-dark-rgb), .5);

    transition: .7s;
}

.page-acc:hover h2 a {
    background-color: rgba(var(--bs-dark-rgb), .3);
}

.page-acc img {
    transition: 1s ease-in-out;
}

.page-acc:hover img {
    transform: scale(1.1);
}

/* #endregion */


/* #region Galerie */

.media-img-acc {
    position: relative;
    overflow: hidden;
}

.cartouche {
    font-size: .75rem;
    padding: .5rem;

    position: absolute;
    left: 0;
    right: 0;

    transition: .4s ease-in-out .1s;
}

.cartouche h3,
.pswp__dynamic-caption h3 {
    font-size: .75rem;
    margin: 0;
}

.cartouche p,
.pswp__dynamic-caption p {
    margin-bottom: 0.3em;
}

.media-img-acc .cartouche {
    transform: translateY(0);
}

.p-masonry-item .p-masonry-item-inner {
    padding: .25rem;
}

.bef-exposed-form,
.p-masonry {
    margin-top: 5rem;
}

.p-masonry-item {
    width: 100%;
}

@media (max-width:991.98px) {

    .bef-exposed-form,
    .p-masonry {
        margin-top: 1rem;
    }

    .bef-checkboxes .js-form-item {
        margin-bottom: 0.5em;
    }
}

@media (min-width:768px) {
    .p-masonry-item {
        width: 50%;
    }
}


@media (min-width:992px) {

    .media-img-acc:hover .cartouche {
        transform: translateY(-100%);
    }

}

/* BEF --- */
#views-exposed-form-galerie-galerie {
    position: relative;
}

.bef-exposed-form #edit-actions {
    position: absolute;
    right: 0;
    top: 0;
    margin: 0;
    line-height: 1;
    font-size: .65rem;
}

.bef-exposed-form #edit-actions .button {
    color: var(--bs-body-color);
    text-decoration: underline;
    font-size: .65rem;
    background-color: transparent;
    padding: 0;
    border: 0 none;
    border-radius: 0;
    line-height: 1;
}

.bef-exposed-form #edit-actions .button:hover {
    box-shadow: none;
}

/* Photoswipe --- */
.pswp__dynamic-caption {
    background-color: var(--bs-body-color);
    font-size: .75rem;
    padding: 1em;
}

.pswp__bg {
    background-color: #fff;
}

.pswp__icn {
    fill: var(--bs-dark);
    color: var(--bs-light);
}

.pswp__icn-shadow {
    stroke: var(--bs-light);
}


/* #endregion */

/* #region Paragraphs */

.region-highlighted .section {
    border-bottom: 1px solid var(--bs-body-color);
}

.region-highlighted .section:nth-last-child(1) {
    border-bottom: 0 none;
}

/* #region texte / accordéon */
.p-text-title h3 {
    padding: 1em 0 .8em;
    margin-bottom: .5em;
}

.p-text-text {
    overflow: hidden;
}

.p-text-acc .p-text-title {
    cursor: pointer;
    position: relative;
}

.p-text-acc .p-text-title::after {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    top: 1em;
    width: 30px;
    height: 30px;
    background: url('img/arrow.svg') no-repeat center center;
    background-size: contain;

    transition: .5s ease-in-out;
}

.p-text-acc-open .p-text-title::after {
    transform: rotate(90deg);
}

.p-text-acc-btn {
    position: absolute;
    right: 3rem;
    top: 1.2rem;
    font-size: 14px;
    overflow: hidden;

    background: transparent none;
    border: 0 none;

    transition: .7s;
}

.p-text-acc-open .p-text-acc-btn {
    /* text-indent: -200px; */
    opacity: 0;
    right: 2rem;
}

@media (max-width:767.98px) {
    .p-text-acc-btn {
        display: none;
    }

    .p-text-acc .p-text-title::after {
        top: .6em;
    }
}

/* #endregion */

/* #region Text + img  */

.p-text-img,
.p-text-2col {
    padding-top: 10vh;
    padding-bottom: 8vh;
}

@media (min-width:980px) {
    .p-text-img .row {
        align-items: center;
        flex-direction: row-reverse;
    }
}

/* Hero */

.p-text-img-hero {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
    display: flex;
    align-items: flex-end;
}

.p-text-img-hero>div {
    flex-grow: 1;
}

.p-text-img-hero .container-lg {
    position: relative;
    padding-bottom: 10vh;
}

/* .p-text-img-hero h2 {
    color: var(--bs-primary);
    font-size: .75rem;
    margin: 0;
} */

.p-text-img-hero .text-formatted {
    max-width: 760px;
}

.p-text-img-bg-img,
.p-text-img-bg-img img {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    max-width: none;
    width: 100%;
    height: 100vh;
}

.p-text-img-bg-img img {
    object-fit: cover;
    object-position: center center;
}

/* #endregion */

/* #region Dia text */
.dia-txt {
    padding: 12vh 0;
}

.dia-txt .swiper-slide {
    text-align: center;
    height: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-right: calc(var(--bs-gutter-x) * .5);
    padding-left: calc(var(--bs-gutter-x) * .5);
}

.swiper-button-next,
.swiper-button-prev {
    left: 40px;
    top: auto;
    bottom: 0;
    display: block;
    width: auto;
    height: auto;
}

.swiper-button-next {
    right: auto;
    left: 100px;
}

.swiper-button-next:after,
.swiper-button-prev:after {
    content: "";
    display: block;
    background: url('img/arrow.svg') no-repeat center center;
    background-size: contain;
    width: 40px;
    height: 40px;
}

.swiper-button-prev:after {
    transform: rotate(180deg);
}

/* #endregion */

/* #region Dia img */

.dia-img {
    padding-top: 10vh;
    padding-bottom: 10vh;
}

.dia-img .media-img-acc img {
    height: 40vh;
    width: auto;
}

.dia-img .swiper {
    margin-bottom: 1rem;
}

.dia-img .swiper-slide {
    width: auto;
    margin-right: .7rem;
}

/* #endregion */

/* #region Dia pages */

.dia-pages {
    padding-top: 10vh;
    padding-bottom: 10vh;
}

.dia-pages .swiper-slide {
    width: 45%;
    margin-right: .7rem;
}

@media (min-width: 980px) {
    .dia-pages .swiper-slide {
        width: 28%;
    }
}

/* #endregion */

/* #region Documents */

.p-docs {
    border-top: 1px solid var(--bs-border-color);
}

.p-doc {
    padding: 1rem 0;
    border-bottom: 1px solid var(--bs-border-color);
}

.p-doc a {
    color: var(--bs-body-color);
    text-decoration: underline;
    display: block;
    padding-right: 2em;
    padding-bottom: 1em;
    margin-bottom: -1em;
    background: url('img/pdf-doc.svg') no-repeat right top;
    background-size: contain;
    position: relative;
}

.p-doc-date {
    margin-left: -.2em;
}

.p-doc-date::before {
    content: ",";
}

/* #endregion */


/* #endregion */


/* #region MEDIA QUERIES */

/* #region MOBILE FIRST */

/* Small devices (landscape phones, 576px and up) */
@media (min-width: 576px) {}

/* Medium devices (tablets, 768px and up) */
@media (min-width: 768px) {}

/* Large devices (desktops, 992px and up) */
@media (min-width: 992px) {}

/* Extra large devices (large desktops, 1200px and up) */
@media (min-width: 1200px) {}

/* #endregion */


/* #region DESKTOP FIRST */

/* Large devices (desktops, less than 1200px) */
@media (max-width: 1199.98px) {}

/* Medium devices (tablets, less than 992px) */
@media (max-width: 991.98px) {}

/* Small devices (landscape phones, less than 768px) */
@media (max-width: 767.98px) {
    html {
        font-size: 18px;
    }

    h1,
    h2 {
        font-size: 1.5rem;
    }

    .page-acc h2,
    .big {
        font-size: 1.2rem;
    }

    .mini {
        font-size: .7rem;
    }
}

/* Extra small devices (portrait phones, less than 576px) */
@media (max-width: 575.98px) {

    /* module nbsp */
    .nbsp {
        display: inline-block;
    }
}

/* #endregion */

/* #endregion */