/* +P
  __      ____
 /\ \    /\  _`\  
 \_\ \___\ \ \L\ \
/\___  __\\ \ ,__/
\/__/\ \_/ \ \ \/ 
    \ \_\   \ \_\ 
     \/_/    \/_/ 
     plusproduit.com
     
     plusb theme 2026.02.19
*/

/* #region VARIABLES */

:root {
    scroll-behavior: auto;
    /* Typo --------- */
    --bs-body-font-family: "DM Sans", sans-serif;
    /* taille texte mobile */
    --bs-body-font-size: 16px;
    --bs-body-line-height: 1.3;
    /* --bs-body-font-weight: 400; */
    --p-body-font-strong-weight: 700;
    --p-alt-font-family: var(--bs-body-font-family);
    --p-alt-font-weight: 600;
    --p-alt-line-height: 1;
    --p-small-font-size: 0.8em;

    /* Colors --------- */
    --bs-body-color: #433E3F;
    --bs-body-color-rgb: 67, 62, 63;
    --bs-heading-color: var(--bs-body-color);
    --bs-body-bg: #E9E8E6;
    --bs-body-bg-rgb: 233, 232, 230;
    --bs-primary: #EA0029;
    --bs-primary-rgb: 234, 0, 41;
    --bs-secondary: #fa6216;
    --bs-secondary-rgb: 250, 98, 22;
    /* light et dark par défaut couleur fond + texte */
    --bs-dark: var(--bs-body-color);
    --bs-dark-rgb: var(--bs-body-color-rgb);
    --bs-light: #ded7ce;
    --bs-light-rgb: 222, 215, 206;
    --bs-emphasis-color: var(--bs-primary);
    --bs-emphasis-color-rgb: var(--bs-primary-rgb);
    --bs-gradient: linear-gradient(180deg, rgba(var(--bs-primary-rgb), 0.2), rgba(var(--bs-secondary-rgb), 0.5));

    /* Link */
    --bs-link-color: var(--bs-primary);
    --bs-link-color-rgb: var(--bs-primary-rgb);
    --bs-link-hover-color: var(--bs-body-color);
    --bs-link-hover-color-rgb: var(--bs-body-color-rgb);
    --bs-link-decoration: none;

    /* taille du header mobile */
    --p-header-height: 100px;
    /* taille du logo mobile */
    --p-logo-width: 40px;

    /* Max width as a variable */
    --p-max-width: 1920px;

    /* Borders */
    --bs-border-width: 2px;
    --bs-border-color: var(--bs-body-color);
    /* --bs-border-radius: 0; */

    /* Shadows */
    --bs-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    --bs-box-shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    --bs-box-shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);
    --bs-box-shadow-inset: inset 0 1px 2px rgba(0, 0, 0, 0.075);

    /* Swiper JS */
    --swiper-navigation-size: 30px;
    --swiper-theme-color: var(--bs-primary);
    --swiper-pagination-color: var(--bs-primary);
    /* --swiper-navigation-top-offset: 88%; */
}

/* Nav links */
.navbar-nav {
    --bs-navbar-active-color: var(--bs-primary);
    --bs-nav-link-font-size: 1rem;
    --bs-nav-link-font-weight: 700;
    --bs-nav-link-color: var(--bs-body-color);
    --bs-nav-link-hover-color: var(--bs-primary);
    --bs-nav-link-padding-x: 0.5em;
    --bs-nav-link-padding-y: 0.25rem;
}

.text-light .navbar-nav {
    --bs-navbar-active-color: var(--bs-white);
    --bs-nav-link-color: var(--bs-body-bg);
    --bs-nav-link-hover-color: var(--bs-white);
}

@media (min-width: 768px) {
    :root {
        /* taille texte large screen */
        --bs-body-font-size: 18px;
    }
}

@media (min-width: 992px) {
    :root {
        /* taille du header desktop */
        --p-header-height: 40px;
        /* taille du logo desktop */
        --p-logo-width: 60px;
    }
}

/* #endregion */

/* #region STRUCTURE ---------- */

html {
    background-color: var(--bs-dark);
}

/* >>>>>>>>>> Gouttières !!!!! */
:root,
.row,
.container,
.container-fluid,
.container-lg,
.container-md,
.container-sm,
.container-xl,
.container-xxl {
    --bs-gutter-x: 3rem;
    /* --bs-gutter-y: 3rem; */
}

/* classe max-width */
.max-width {
    max-width: var(--p-max-width);
}

.region-highlighted-wrapper {
    min-height: 100px;
}

.region-highlighted-inner {
    background: var(--bs-light);
}

.region-highlighted {
    max-width: var(--p-max-width);
    margin: 0 auto;
}

.main-content {
    padding-bottom: 3rem;
}

/* #endregion */


/* #region LINKS + CTA ---------- */

a {
    text-decoration: var(--bs-link-decoration);
}

.text-light {
    --bs-link-decoration: underline;
    --bs-link-hover-color: var(--bs-white);
    --bs-link-hover-color-rgb: var(--bs-white-rgb);
}

.text-light,
.bg-primary {
    --bs-link-color: var(--bs-body-bg);
    --bs-link-color-rgb: var(--bs-body-bg-rgb);
}

.btn {
    --bs-border-radius: 0;
    --bs-btn-padding-x: 1em;
    --bs-btn-padding-y: .5em;
    --bs-btn-font-size: .8rem;
    --bs-btn-font-weight: var(--p-body-font-strong-weight);
    --bs-btn-line-height: 1;
    margin-bottom: .5rem;
}

.btn-primary {
    --bs-btn-bg: var(--bs-primary);
    --bs-btn-color: var(--bs-body-bg);
    --bs-btn-border-color: var(--bs-primary);
    --bs-btn-hover-bg: var(--bs-body-color);
    --bs-btn-hover-color: var(--bs-body-bg);
    --bs-btn-hover-border-color: var(--bs-body-color);
    --bs-btn-active-bg: var(--bs-primary);
    --bs-btn-active-border-color: var(--bs-primary);
}

.text-light .btn-primary {
    --bs-btn-color: var(--bs-primary);
    --bs-btn-bg: var(--bs-body-bg);
    --bs-btn-border-color: var(--bs-body-bg);
    --bs-btn-active-color: var(--bs-body-bg);
    --bs-btn-active-bg: var(--bs-primary);
    --bs-btn-active-border-color: var(--bs-body-bg);
}

.btn-outline-primary {
    --bs-btn-color: var(--bs-primary);
    --bs-btn-border-color: var(--bs-primary);
    --bs-btn-hover-bg: var(--bs-primary);
    --bs-btn-hover-color: var(--bs-body-bg);
    --bs-btn-hover-border-color: var(--bs-primary);
    --bs-btn-active-bg: var(--bs-primary);
    --bs-btn-active-border-color: var(--bs-primary);
}

.file--application-pdf {
    background: url('images/icons/application-pdf.png') no-repeat left .2em;
    padding-left: 1.2em;
}

/* #endregion */


/* #region PAGINATION ---------- */

.pagination {
    line-height: 1;
    --bs-pagination-padding-y: 0.7em;
    --bs-pagination-padding-x: 1em;
    --bs-pagination-border-color: var(--bs-primary);
    --bs-pagination-hover-color: var(--bs-body-color);
    --bs-pagination-hover-bg: var(--bs-body-bg);
    --bs-pagination-hover-border-color: var(--bs-primary);
    --bs-pagination-active-color: var(--bs-body-bg);
    --bs-pagination-active-bg: var(--bs-primary);
    --bs-pagination-active-border-color: var(--bs-primary);
}

/* #endregion */


/* #region TYPOGRAPHY ---------- */

h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5,
h6,
.h6,
.font2 {
    font-family: var(--p-alt-font-family);
    font-weight: var(--p-alt-font-weight);
    line-height: var(--p-alt-line-height);
    margin-bottom: .4em;
}

h1,
.h1 {
    font-size: 4rem;
    color: var(--bs-primary);
    line-height: .85;
}

h2,
.h2 {
    font-size: 2.2rem;
}

h3,
.h3 {
    font-size: 1.6rem;
}

h3 a {
    color: var(--bs-body-color);
}

h3 a:hover {
    color: var(--bs-primary);
}

h2 strong,
.h2 strong,
h3 strong,
.h3 strong {
    font-weight: var(--p-alt-font-weight);
}

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

.lead {
    font-weight: var(--p-alt-font-weight);
    letter-spacing: -0.02em;
}

small,
.small {
    font-size: var(--p-small-font-size);
}

hr {
    opacity: 1;
    border-color: var(--bs-primary);
}

.text-light {
    --bs-heading-color: var(--bs-body-bg);
}

.field__label {
    font-weight: var(--p-body-font-strong-weight);
}

.text-formatted ul {
    padding-left: 1em;
}

.text-formatted li {
    margin-bottom: .7em;
    padding-left: 1em;
    list-style-type: none;
    position: relative;
}

.text-formatted li::before {
    content: "•";
    color: var(--bs-primary);
    position: absolute;
    left: 0;
    top: 0;
    line-height: .85;
    font-size: 1.5em;
}

/* #endregion */

/* #region HEADER + OFFCANVAS ----------- */

.region-header {
    --bs-gutter-y: 0;
    padding: 0;
    height: 0;
    align-items: flex-start;
}

.region-header .block-system-branding-block {
    background: var(--bs-primary);
    margin-top: 0;
    padding: 1rem 2rem;
    border-radius: 0 0 1rem 0;
}

#block-plusb-offcanvasbutton {
    background: var(--bs-light);
    border-radius: 0 0 0 1rem;
    transition: background-color .5s .1s;
    padding-top: 0.5em;
    padding-bottom: 0.5em;
}

.p-offcanvas-on #block-plusb-offcanvasbutton {
    background: transparent;
}

#block-plusb-offcanvasbutton .text-formatted {
    display: flex;
    align-items: center;
}

#block-plusb-offcanvasbutton .text-formatted .btn {
    margin-bottom: 0;
    margin-right: 2em;
}

.p-offcanvas-overflow {
    position: relative;
}

.p-offcanvas-overflow::before,
.p-offcanvas-overflow::after {
    content: "";
    position: absolute;
    left: 5vw;
    top: 10vh;
    width: 20vw;
    height: 30vh;
    background: url('images/e.svg') no-repeat;
    background-size: contain;
    opacity: 0;

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

.p-offcanvas-overflow::after {
    transform: rotateY(-180deg);
    width: 15vw;
    top: 70vh;
    left: 15vw;
}

.p-offcanvas-on .p-offcanvas-overflow::before {
    top: 30vh;
    opacity: 0.2;
}

.p-offcanvas-on .p-offcanvas-overflow::after {
    top: 60vh;
    opacity: 0.2;
}

.region-offcanvas {
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    align-items: flex-end;
    gap: 1em;
    min-height: 90vh;
}

.region-offcanvas .menu--main .navbar-nav {
    --bs-nav-link-font-size: 2.5rem;
}

.region-offcanvas .menu--main .navbar-nav ul {
    --bs-nav-link-padding-y: .5em;
    --bs-nav-link-font-size: 1.5rem;
}

.region-offcanvas .nav-link {
    padding-left: 0;
    padding-right: 0;
}

@media (min-width:992px) {
    #p-offcanvas {
        /* Si le off-canvas vient de la droite */
        left: 10%;
    }

    .p-offcanvas-on #p-offcanvas {
        box-shadow: 0 0 20px #000a;
    }

    .region-offcanvas>.block {
        width: 100%;
        max-width: 600px;
    }
}

/* #endregion */

/* #region FOOTER */

.site-footer,
.site-footer .block {
    position: relative;
}

.site-footer::before {
    content: "";
    position: absolute;
    left: 10vw;
    top: 3vh;
    width: 20vh;
    height: 20vh;
    background: url('images/e.svg') no-repeat center center;
    background-size: contain;
    opacity: 0.2;
    filter: invert(1);
}

.site-footer .menu--main .nav-link {
    --bs-nav-link-font-size: 1.3rem;
}

/* #endregion */

/* #region BASIC PAGE */

/* #region FRONT --- */
.path-frontpage .main-content {
    background: var(--bs-light);
}

.path-frontpage .main-content .container-lg {
    max-width: var(--p-max-width);
    padding: 0;
}

.path-frontpage .block-system-main-block {
    width: 66.66%;
    margin-left: auto;
    padding-bottom: 5vh;
}

.path-frontpage .block-system-main-block>div {
    max-width: 600px;
}

/* #endregion */

.fe-banner img {
    display: block;
    aspect-ratio: 2 / 1;
    object-fit: cover;
    width: 66.66%;
    margin-left: auto;
}

/* #endregion */

/* #region PARAGRAPHES ----------- */

.fe-py {
    padding-top: 7vh;
    padding-bottom: 8vh;
}

.fond-beige {
    background: var(--bs-light);
}

.fond-violet {
    background: #394194;
}

.inverse .row {
    flex-direction: row-reverse;
}

.fe-2cols .text-formatted {
    padding-top: 2rem;
}

.fe-2cols .group-right {
    margin-left: auto;
}

.fe-2cols.inverse .group-right {
    margin-left: 0;
    margin-right: auto;
}

.fe-img-style {
    position: relative;
    padding-bottom: 1rem;
}

.fe-img-style::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    height: 1rem;
    width: 50%;
    background: #C8C8C8;
}

.fond-beige .fe-img-style::before {
    background: #8a8183;
}

.fe-img-style img {
    display: block;
    max-width: 500px;
    margin-left: auto;
    position: relative;
}

.inverse .fe-img-style img {
    margin-left: 0;
    margin-right: auto;
}

.inverse .fe-img-style::before {
    left: auto;
    right: 0;
}

.fe-2cols-alt .row {
    align-items: center;
}

.p-accordion .group-title,
.p-accordion .group-title:hover,
.p-accordion .group-rows-inner {
    background: transparent;
}

/* #region Chiffre */

.fe-chiffres .row .col-12 {
    text-align: center;
    --bs-primary: #026776;
}

.fe-chiffres .row .col-12:nth-child(3n-1) {
    --bs-primary: #E94D34;
}

.fe-chiffres .row .col-12:nth-child(3n) {
    --bs-primary: #394194;
}

.fe-chiffre-chiffre {
    font-size: 4rem;
    color: var(--bs-primary);
    font-weight: var(--p-alt-font-weight);
    line-height: .65;
}

.fe-chiffre-texte {
    position: relative;
    font-size: 2rem;
    background: var(--bs-primary);
    color: var(--bs-light);
    font-weight: var(--p-alt-font-weight);
}


/* #endregion */
/* #endregion */