/*Fonts*/
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;500&display=swap');
@font-face {
    font-family: 'Palace Script MT';
    src: url('font/PalaceScriptMT.eot');
    src: url('font/PalaceScriptMT.eot?#iefix') format('embedded-opentype'),
    url('font/PalaceScriptMT.woff2') format('woff2'),
    url('font/PalaceScriptMT.woff') format('woff'),
    url('font/PalaceScriptMT.ttf') format('truetype');
    font-weight: normal;
    font-style: italic;
    font-display: swap;
}


/*A*/
a{
    color: #416db9;
    display: inline-block;
    font-weight: 500;
    vertical-align: top;
}
a:hover{text-decoration: unset;}
.arrow-back-to-top__container {
    display: none;
    position: fixed;
    bottom: 80px;
    right: 10px;
    z-index: 9;
    border: 2px solid #000000;
    border-radius: 50%;
    box-shadow: 0 3px 9px rgba(0,0,0,0.4);
    background-color: #ffffff;
}
.arrow-back-to-top__container:hover {cursor: pointer;}
.arrow-back-to-top__container:hover .arrow-back-to-top__picture {animation: upAndDown 1.5s infinite;}
.arrow-back-to-top__picture {
    display: block;
    margin: 10px;
    max-height: 30px;
    transform: translateY(0);
}

/*B*/
#banner-homepage{background-image: url("../images/bg-image-for-homepage.jpg");}
.banner {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
    margin-bottom: 80px;
}
.banner__inner {
    background-color: rgba(0,0,0,0.3);
    color: #ffffff;
    padding: 90px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.banner__picture {
    max-width: 50px;
    padding: 15px;
}
.banner__picture-box {
    background-color: rgba(255,255,255,0.8);
    display: inline-flex;
    border: 3px solid #416db9;
    border-radius: 50%;
}
.banner__text-box {
    margin-top: 20px;
    text-align: center;
}
.banner__text-label {
    font-size: 24px;
    font-weight: 500;
    line-height: 30px;
    margin-bottom: 20px;
}
.banner__text-link{color: #ffffff;}
body{
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 24px;
    position: relative;
    margin: 0;
}
.bold{font-weight: 500;}
.breadcrumb{
    margin: 40px 0;
    font-size: 14px;
    color: #9c9c9c;
}
.button{
    border: 2px solid #416db9;
    border-radius: 45px;
    font-weight: 500;
    padding: 15px 45px;
    text-align: center;
    text-decoration: none;
    transition: all ease-in-out .2s;
}
.button:hover{
    background-color: #416db9;
    color: #ffffff;
    transition: all ease-in-out .2s;
}
.button-full{
    background-color: #416db9;
    color: #ffffff;
    transition: all ease-in-out .2s;
}
.button-full:hover{
    background-color: #ffffff;
    border: 2px solid #416db9;
    color: #416db9;
    transition: all ease-in-out .2s;
}

/*F*/
.footer {border-top: 5px solid #416db9;}
.footer__column-title {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 20px;
}
.footer__column {margin-bottom: 25px;}
.footer__column:not(:last-child) {margin-right: 50px;}
.footer__contact-box:not(:last-child) {margin-bottom: 10px;}
.footer__container {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    padding: 20px 20px 0;
    margin: 0 auto;
    max-width: 1300px;
}
.footer__copyright {
    font-size: 12px;
    font-weight: 700;
    padding: 20px 20px 80px;
}
.footer__rs-item {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
}
.footer__rs-item:not(:last-child) {margin-right: 40px;}
.footer__rs-item img{
margin-right:20px;
max-width: 40px;
}

/*I*/
img{max-width: 100%;}

/*P*/
p{margin: 0;}
.promotions__introduction{margin-bottom: 40px;}
.promotions__item{
    position: relative;
    border: 1px solid #ccc;
}
.promotions__item:not(:last-child){margin-bottom: 20px;}
.promotions__item-infos{padding: 30px 20px;}
.promotions__item-description{
    font-size: 18px;
    font-weight: 300;
    margin-bottom: 10px;
}
.promotions__item-name{
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 10px;
}
.promotions__new-price{
    color: #416db9;
    font-size: 20px;
    font-weight: 500;
}
.promotions__old-price{
    text-decoration: line-through;
    color: #555555;
}
.promotions__picture{display: block;}
.promotions__rebate{
    position: absolute;
    top: 5px;
    left: 5px;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    padding: 5px 60px 5px 10px;
    background: rgb(255,255,255);
    background: linear-gradient(90deg, rgba(255,255,255,1) 0%, rgba(255,255,255,0.3) 85%, transparent 100%);
    border-left: 3px solid #416db9;
}
.promotions__rebate-label{
    font-size: 14px;
    font-weight: 500;
}
.promotions__rebate-picto{
    margin-right: 10px;
    max-height: 30px;
}

/*S*/
.sticky{
    position: fixed;
    top: 0;
    width: 100%;
    background-color: #ffffff;
    z-index: 99;
}
.sticky + .content {padding-top: 140px;}
.subtitle{
    font-size: 20px;
    font-weight: 500;
    line-height: 28px;
    margin-bottom: 40px;
}
.swiper-pagination{
    bottom: -10px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.swiper-pagination .swiper-pagination-bullet{
    height: 12px;
    width: 12px;
}
.swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active{
    height: 18px;
    width: 18px;
    background-color: #416db9;
}
.swiper-wrapper{margin-bottom: 60px;}

/*T*/
.title__primary{
    font-size: 32px;
    line-height: 40px;
    margin: 40px 0;
    text-transform: uppercase;
}
.title__primary-with-subtitle{margin: 40px 0 10px;}
.title__secondary{
    font-size: 24px;
    font-weight: 500;
    line-height: 30px;
    margin: 0 0 10px;
    color: #416db9;
}

/*U*/
ul{
    margin: 20px 0 0 0;
    padding: 0 0 0 20px;
}

/*W*/
.wrapper{
    box-sizing: border-box;
    padding: 0 20px;
    margin: 0 auto 80px;
    max-width: 1300px;
}
.wrapper-with-slider{
    box-sizing: border-box;
    padding: 0 10px;
    margin: 0 auto 80px;
    max-width: 1300px;
}
.wrapper-with-slider .swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet{margin: 0 12px;}
.wrapper-with-slider__content{margin-bottom: 40px;}
.wrapper-with-slider__content, .wrapper-with-slider .swiper-container{padding: 0 10px;}
.wysiwyg > a{margin-top: 20px;}
.wysiwyg p:not(:last-child){margin-bottom: 10px;}


/*========================================
    Breakpoints
========================================*/

/*Mobile Paysage*/
@media only screen and (min-width: 565px) {
    .footer__container {
        flex-direction: row;
        justify-content: space-between;
    }
    .footer__column {width: 48%;}
    .footer__column:not(:last-child) {margin-right: 0;}
    .footer__copyright {
        padding: 20px 0;
        text-align: center;
    }
}

/*Tablet Landscape*/
@media only screen and (min-width: 768px) {
    .arrow-back-to-top__container {
        bottom: 50px;
        right: 20px;
    }
    .banner__inner {padding: 60px 20px;}
    .promotions__item {max-width: 48%;}
    .promotions__item:not(:last-child) {margin-bottom: 25px;}
    .promotions__wrapper {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }
}

/*Tablet Paysage*/
@media only screen and (min-width: 1024px) {
    .footer__column {width: 25%;}
}

/*Laptop*/
@media only screen and (min-width: 1200px) {
    .promotions__item {max-width: 32%;}
    .promotions__item:last-child {margin-bottom: 25px;}
}

/*Desktop*/
@media only screen and (min-width: 1500px) {
    .swiper-has-navigation-arrows{position: relative;}
    .swiper-has-navigation-arrows .swiper-container{position: static;}
    .swiper-has-navigation-arrows .swiper-button-next{right: -60px;}
    .swiper-has-navigation-arrows .swiper-button-next::after{padding-left: 6px;}
    .swiper-has-navigation-arrows .swiper-button-prev{left: -60px;}
    .swiper-has-navigation-arrows .swiper-button-prev::after{padding-right: 6px;}
    .swiper-has-navigation-arrows .swiper-button-prev, .swiper-has-navigation-arrows .swiper-button-next{
        background-color: #416db9;
        border-radius: 50%;
        height: 56px;
        width: 56px;
    }
    .swiper-has-navigation-arrows .swiper-button-prev::after, .swiper-has-navigation-arrows .swiper-button-next::after{
        color: #ffffff;
        font-size: 30px;
    }
}

/*Desktop*/
@media only screen and (min-width: 1600px) {
    .arrow-back-to-top__container {right: 5%;}
}

/*Desktop*/
@media only screen and (min-width: 2000px) {
    .arrow-back-to-top__container {right: 10%;}
}

/*Desktop*/
@media only screen and (min-width: 2500px) {
    .arrow-back-to-top__container {right: 20%;}
}

/*Desktop*/
@media only screen and (min-width: 3000px) {
    .arrow-back-to-top__container {right: 25%;}
}

/*Animations*/
@keyframes upAndDown {
    0% {transform: translateY(0);}
    50% {transform: translateY(-5px);}
    100% {transform: translateY(0);}
}