
.swiper-section {
    overflow: hidden
}

.swiper-section .slide-item {
    position: relative;
    z-index: 2
}

.swiper-section .slide-item.swiper-slide-active {
    position: relative;
    z-index: 4
}

.swiper-section a {
    background: #fff;
    border-radius: 50px;
    padding: 10px 40px;
    margin-bottom: 20px;
    display: inline-flex;
    align-items: center;
    transform-origin: bottom left;
    transition: all .3s linear;
    font-weight: 700
}

.swiper-section a:hover {
    color: #fff;
    background-color: #203f78
}

.swiper-section a:hover svg {
    fill: #fff
}

.swiper-section a svg {
    width: 20px;
    margin-left: 10px;
    fill: #3d5564;
    transition: all .3s linear
}

.swiper-section .slide-content {
    position: absolute;
    color: #fff
}

.swiper-section .slide-title {
    font-weight: 800;
    text-transform: uppercase;
    font-family: "Rubik", sans-serif
}

.swiper-section .slide-title span {
    font-weight: 300
}

.main-slider-pagination {
    position: absolute;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    row-gap: 10px;
    top: 0;
    left: 20px !important;
    width: 30px !important
}

.main-slider-pagination .swiper-pagination-bullet {
    background: #fff;
    width: 5px;
    height: 20px;
    border-radius: 20px;
    opacity: 1;
    transition: all .3s linear
}

.main-slider-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
    background: #203f78;
    height: 40px
}

@media only screen and (min-width: 320px) {
    .swiper-section {
        width: 100vw
    }

    .slide-title {
        font-size: 2em
    }

    .slide-content {
        bottom: 15%;
        left: 50%;
        transform: translateX(-50%);
        width: 90%
    }
}

@media only screen and (min-width: 1024px) {
    .slide-content {
        bottom: 15%;
        left: 20vmax;
        width: 500px;
        transform: none
    }

    .slide-title {
        font-size: 3em
    }
}

.headerVom nav > ul {
    display: flex;
    column-gap: 25px;
    list-style: none;
    margin-bottom: 0
}

.headerVom nav > ul > li {
    position: relative
}

.headerVom nav > ul > li:hover > a {
    color: #203f78
}

.headerVom nav > ul > li:hover > a:after {
    bottom: -15px;
    opacity: 1;
    visibility: visible
}

.headerVom nav > ul > li > a {
    color: #fff;
    text-transform: uppercase;
    font-weight: 600;
    transition: all .2s linear
}
.inner-header nav > ul > li > a {
    color: #000;
}

.headerVom nav > ul > li > a::after {
    content: "";
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #203f78;
    position: absolute;
    bottom: -50px;
    left: 50%;
    transform: translateX(-50%);
    transition: all .2s linear;
    opacity: 0;
    visibility: hidden
}

header.headerVom {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 2;
    padding: 30px 15px
}


.header-right {
    column-gap: 25px
}

.shopping-cart {
    position: relative
}

.shopping-cart span {
    position: absolute;
    top: -20px;
    right: -20px;
    background-color: #fff;
    color: #3d5564;
    border-radius: 50%;
    border-bottom-left-radius: 0;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px
}

.testimonials-carousel {
    font-family: "Indie Flower", cursive;
    font-size: 24px;
    position: relative
}

.testimonials-carousel strong {
    display: block;
    font-family: "Nunito", sans-serif;
    font-size: 16px
}

.testimonials-carousel strong:first-of-type {
    margin-top: 15px
}

.testimonials-pagination {
    display: flex;
    flex-direction: column;
    row-gap: 15px;
    justify-content: center;
    position: absolute;
    left: -50px;
    top: 0;
    height: 100%
}

.testimonials-pagination:after {
    content: "";
    height: 100%;
    width: 1px;
    background: #828282;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%)
}

.testimonials-pagination .swiper-pagination-bullet {
    background: #fff;
    width: 15px;
    height: 15px;
    border: 1px solid #828282;
    position: relative;
    z-index: 2;
    opacity: 1
}

.testimonials-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
    background: #203f78;
    border-color: transparent
}

.google-map {
    height: 600px;
    width: 100%
}

.contact-wrapper {
    margin-top: -70px;
    background: #fff;
    z-index: 3;
    position: relative;
    padding: 15px
}

.contact-item {
    display: grid;
    grid-template-columns: 40px 1fr
}

.contact-item svg {
    grid-column: 1/2;
    grid-row: 1/4;
    opacity: .4;
    fill: #3d5564;
    position: relative;
    top: 2px
}

.contact-item strong {
    grid-column: 2/3;
    grid-row: 2/3
}

.contact-item p {
    grid-column: 2/3;
    grid-row: 3/4
}


.home-product-box {
    height: 300px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    column-gap: 20px
}

.home-product-box img {
    height: 150px;
    object-fit: contain;
    filter: drop-shadow(0 2.8px 2.2px rgba(0, 0, 0, 0.056)) drop-shadow(0 6.7px 5.3px rgba(0, 0, 0, 0.081)) drop-shadow(0 12.5px 10px rgba(0, 0, 0, 0.1)) drop-shadow(0 22.3px 17.9px rgba(0, 0, 0, 0.119)) drop-shadow(0 100px 80px rgba(0, 0, 0, 0.2))
}

.home-product-box-content {
    display: flex;
    flex-direction: column;
    row-gap: 15px
}

.home-product-box-content .product-title {
    font-size: 18px;
    font-weight: 700;
    text-transform: uppercase;
    position: relative
}

.home-product-box-content .product-title:after {
    content: "";
    background: #203f78;
    height: 5px;
    width: 50px;
    position: absolute;
    left: 0;
    bottom: -5px;
    border-radius: 50px
}

.home-product-box-content .product-price {
    font-weight: 800;
    font-size: 24px
}

[class*=home-product-box] img {
    position: relative;
    left: 33%;
    transform: translate3d(-50%, 0, 0);
    transition: all .3s ease-in-out
}

[class*=home-product-box] .home-product-box-content {
    position: relative;
    opacity: 0;
    visibility: hidden
}

[class*=home-product-box] .home-product-box-content * {
    transition: all .1s ease-in-out;
    opacity: 0;
    visibility: hidden;
    top: 25px
}

[class*=home-product-box] .home-product-box-content .product-title {
    transition-delay: .5s
}

[class*=home-product-box] .home-product-box-content .product-price {
    transition-delay: .4s
}

[class*=home-product-box] .home-product-box-content a {
    transition-delay: .3s
}

[class*=home-product-box]:hover img {
    transform: translate3d(-150%, 0, 0)
}

[class*=home-product-box]:hover .home-product-box-content {
    opacity: 1;
    visibility: visible
}

[class*=home-product-box]:hover .home-product-box-content * {
    opacity: 1;
    visibility: visible;
    top: 0
}

[class*=home-product-box]:hover .home-product-box-content .product-title {
    transition-delay: .3s
}

.dark-box {
    color: #fff
}

.home-product-box-2x {
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center
}

.home-product-box-2x img {
    height: 150px;
    object-fit: contain;
    filter: drop-shadow(0 2.8px 2.2px rgba(0, 0, 0, 0.056)) drop-shadow(0 6.7px 5.3px rgba(0, 0, 0, 0.081)) drop-shadow(0 12.5px 10px rgba(0, 0, 0, 0.1)) drop-shadow(0 22.3px 17.9px rgba(0, 0, 0, 0.119)) drop-shadow(0 100px 80px rgba(0, 0, 0, 0.2))
}

.box-1 {
    background: #902c2e;
    background: linear-gradient(144deg, #902c2e 0%, #611b1d 100%)
}

.box-2 {
    background: #f2f2f2;
    background: linear-gradient(144deg, #f2f2f2 0%, #dddddd 100%)
}

.box-3 {
    background: #e7f0f2;
    background: linear-gradient(144deg, #e7f0f2 0%, #a5aeb0 100%)
}

.box-4 {
    background: #3f5b5f;
    background: linear-gradient(144deg, #3f5b5f 0%, #2f3d40 100%)
}

.box-5 {
    background: #755656;
    background: linear-gradient(144deg, #755656 0%, #353535 100%)
}

.img-cover {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center
}

.img-contain {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center center
}

*, *:after, *:before {
    margin: 0;
    padding: 0;
    -webkit-font-smoothing: antialiased;
    font-smoothing: antialiased;
    text-rendering: optimizeLegibility
}

.cf:after, .cf:before {
    display: table;
    content: " "
}

.cf:after {
    clear: both
}

.cf {
    zoom: 1
}

.row-no-padding {
    margin-left: 0;
    margin-right: 0
}

.row-no-padding [class*=col-] {
    padding-left: 0 !important;
    padding-right: 0 !important
}

a {
    color: #3d5564;
    text-decoration: none
}

a:hover, a:focus, a:active {
    text-decoration: none;
    outline: none
}

html, body {
    height: 100%;
    min-height: 100%
}

body {
    font-size: 16px;
    color: #3d5564;
    font-family: "Nunito", sans-serif;
    font-weight: 400;
    overflow-x: hidden
}

.img-contain {
    object-fit: contain;
    object-position: center center;
    height: 100%;
    width: 100%
}

.primary-button {
    background: #203f78;
    color: #fff;
    border-radius: 50px;
    padding: 6px 25px;
    font-weight: 600;
    font-size: .9em;
    transition: all .3s linear;
    border: 0
}

.primary-button:hover {
    background: #3d5564;
    color: #fff
}

.section-title h2 {
    text-transform: uppercase;
    font-weight: 800
}

.img-cover {
    object-position: center center;
    object-fit: cover;
    width: 100%;
    height: 100%
}

.page-title-wrapper {
    background: #203f78;
    text-align: center;
    padding: 50px 0
}

.page-title-wrapper h1 {
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    margin: 0
}

.inner-header {
    position: relative !important;
}

.inner-header .shopping-cart path {
    fill: #203f78 !important
}

.inner-header .shopping-cart span {
    background: #203f78;
    color: #fff
}

.inner-header * {
    color: #3d5564
}

.inner-header .primary-button {
    color: #fff
}

.styled-form {
    display: flex;
    column-gap: 15px;
    flex-wrap: wrap
}

.styled-form *:active, .styled-form *:focus {
    outline: 0
}

.styled-form .form-item {
    display: flex;
    flex-direction: column;
    border: 2px solid #00000010;
    padding: 10px;
    border-radius: 5px;
    margin-bottom: 15px
}

.styled-form label {
    text-transform: uppercase;
    font-weight: bold;
    font-size: 12px;
    margin-bottom: 0
}

.styled-form input:not([type=submit]) {
    border: 0;
    width: 100%
}

.styled-form input::-webkit-outer-spin-button, .styled-form input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0
}

.styled-form input[type=number] {
    -moz-appearance: textfield
}

.styled-form select {
    appearance: none;
    border: 0;
    background: url("../images/icons/select-chevron.svg") 95% 60% no-repeat;
    padding: 0;
    margin: 0;
    width: 100%
}

.styled-form textarea {
    border: 0
}

@media only screen and (max-width: 767px) {
    .google-map {
        height: 245px;
    }

    .sponsorpopup #sponsor_filtre {
        margin-top: 60px;
    }
}

@media only screen and (min-width: 320px) {
    .mobile-header {
        background: #fff;
        position: fixed;
        z-index: 5;
        top: 0;
        left: 0;
        width: 100vw;
        border-bottom: 1px solid #eee
    }

    .mobile-logo {
        position: absolute;
        left: 50%;
        transform: translateX(-50%)
    }

    #toggle-nav {
        display: flex;
        flex-direction: column;
    }

    #toggle-nav span {
        background: #203f78;
        height: 2px;
        width: 25px;
        border-radius: 50px
    }

    .mobile-logo {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translateY(-50%) translateX(-50%)
    }

    .mobile-cart span {
        background: #203f78;
        color: #fff;
    }

    .nav-panel {
        font-weight: 400
    }

    .nav-panel .mm-title {
        color: #203f78 !important;
        font-weight: bold
    }

    .nav-panel .mm-navbar-top {
        border-bottom: 1px solid rgba(0, 0, 0, .1)
    }

    .nav-panel .nav-panel-logo {
        width: 12em;
        margin: 0 auto
    }

    .nav-panel .nav-panel-logo img {
        width: 100%
    }

    .primary-button {
        padding: 6px 18px;
    }

    .product-title {
        font-size: 15px;
        height: 45px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
}

.inner-header ul li a {
    color: #3d5564;
}

.primBox {
    background: #203f78;
    color: #fff;
    border-radius: 50px;
    padding: 0px 15px;
    transition: all .3s linear;
    border: 0;
    font-size: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 30px;
    line-height: 30px;
    position: absolute;
    top: 0;
    left: 0;
    font-weight: bold;
    z-index: 99;
}