/*
    Theme Name: Sitel
    Version: 1.0
    Author: Bastien (Rose & Piment)
*/

@font-face {
    font-family: 'Kanit Li';
    src: url('fonts/Kanit-Light.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}


@font-face {
    font-family: 'Kanit Re';
    src: url('fonts/Kanit-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Kanit Me';
    src: url('fonts/Kanit-Medium.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Kanit Sb';
    src: url('fonts/Kanit-SemiBold.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'icomoon';
    src: url('fonts/icomoon.ttf?gia2d2') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: block;
}

[class^="icon-"], [class*=" icon-"] {
    /* use !important to prevent issues with browser extensions that change fonts */
    font-family: 'icomoon' !important;
    speak: never;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    font-size: 2.8rem;
    margin-bottom: 1rem;

    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.icon-eclair:before { content: "\e900"; }
.icon-services:before { content: "\e901"; }
.icon-zoom:before { content: "\e902"; }
.icon-contact:before { content: "\e903"; }
.icon-coeur:before { content: "\e904"; }
.icon-environnement:before { content: "\e905"; }


/*--------------------------------------------------------------
    Generale
--------------------------------------------------------------*/

body,
html {
    width: 100%;
    height: auto;
    font-size: 14px;
    overflow-x: hidden;
}
body { 
    font-family: 'Kanit Li', Helvetica, sans-serif;
    overflow-x: hidden;
    color: #000;
}

section { padding: 3rem 0; } 

b,
strong {
    font-family: 'Kanit Sb', Helvetica, sans-serif;
    font-weight: unset;
}

a {
    color: #000;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
}

button:hover,
button:focus, 
a:hover,
a:focus {
    color: #e54330;
    box-shadow: 0 !important;
    outline: 0 !important;
    text-decoration: none;
}

p {
    color: #000;
    margin-bottom: 20px;
}
p:last-child { margin-bottom: 0; }

h1,
h2,
h3,
h4,
h5,
h6 { font-family: 'Kanit Sb', Helvetica, sans-serif; }

h1 {
    color: #2ebce4;
    text-transform: uppercase;
    font-size: 2rem;
    margin-bottom: 1rem;
}

h2 {
    color: #2ebce4;
    text-transform: uppercase;
    font-size: 1.7rem;
}

h3 {
    text-transform: uppercase;
    margin-bottom: 1rem;
}

figure { margin: 0; }

blockquote {
    padding: 1.25rem;
    background-color: #ccc;
    color: #fff
}

.card {
    border-radius: 0;
    border: 0;
    background-color: transparent;
}
.card img,
.card-img { border-radius: 0 !important; }

.modal-content {
    border: 0;
    border-radius: 0;
}

.bg-light { background-color: #f2f2f2 !important }

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
    /* IE10+ CSS here */
    .card > * { flex: 0 0 auto; }
}


/*--------------------------------------------------------------
    Top Nav
--------------------------------------------------------------*/

.top-nav {
    background-color: #000;
    padding: 0.8rem 1.5rem 0;
}
.top-nav .top-nav-wrapper {
    display: table;
    margin-left: auto;
}
.top-nav ul {
    list-style: none;
    padding-left: 0;
}
.top-nav ul li { display: inline; }
.top-nav ul li a {
    font-family: 'Kanit Me', Helvetica, sans-serif;
    font-size: 0.9rem;
    color: #fff;
    text-decoration: none;
}

.top-nav .navbar-center,
.top-nav .navbar-right { 
    display: table-cell;
    vertical-align: middle;
}
.top-nav .navbar-center li a { padding: 0.2rem 0.7rem; }
.top-nav .navbar-center li i,
.top-nav .navbar-center li svg {
    font-size: 1rem;
    vertical-align: middle;
    color: #e54330;
}

.top-nav .navbar-center a:hover,
.top-nav .navbar-center a:focus,
.top-nav .navbar-center a:hover *,
.top-nav .navbar-center a:focus * { color: #e54330; }
.top-nav .navbar-right { padding-left: 0.5rem; }


/*--------------------------------------------------------------
    Header
--------------------------------------------------------------*/

header {
    position: relative;
    z-index: 15;
}

header .navbar { 
    background-color: #000;
    padding: 0 1rem 0.5rem;
}
header .navbar h1 { margin-bottom: 0; }
header .navbar h1 .logo { max-width: 100px; }
header .navbar .navbar-nav li { 
    border-right: 1px solid #e54330; 
    position: relative;
}
header .navbar .navbar-nav li:last-child { border-right: 0; }
header .navbar .navbar-nav li.active:after {
    content: "";
    width: 3rem;
    height: 3px;
    background-color: #e54331;
    position: absolute;
    left: 0;
    bottom: -0.2rem;
    right: 0;
    margin: 0 auto;
}
header .navbar .navbar-nav li a {
    color: #fff;
    font-size: 0.9rem;
    text-align: center;
    padding: 0.1rem 1rem !important;
    position: relative;
}
header .navbar .navbar-nav li a:hover,
header .navbar .navbar-nav li a:focus { color: #e54330; }

header .navbar .navbar-nav .dropdown-toggle::after { display: none; }
header .navbar .navbar-nav .dropdown-menu {
    border: 0;
    border-radius: 0;
}
header .navbar .navbar-nav .dropdown-menu a {
    font-size: 0.9rem;
    color: #fff !important;
    margin-top: 0;
    white-space: normal;
}
header .navbar .navbar-nav .dropdown-menu a:before { display: none; }
header .navbar .navbar-nav .dropdown-menu a:focus, 
header .navbar .navbar-nav .dropdown-menu a:hover {
    background-color: transparent;
    text-decoration: underline;
}

/* Fixed navigation */

header .navbar.fixed-header {
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1500;
    padding: 0.5rem 1rem;
}
header .navbar.fixed-header .navbar-nav { border: 0; }
header .navbar.fixed-header .navbar-nav li a { margin-top: 0; }
header .navbar.fixed-header .navbar-nav li a:before { display: none; }

@media screen and (max-width: 991px) {
    header .navbar .navbar-nav li { border-right: 0; }
    header .navbar .navbar-nav li a { padding: 0.1rem 1rem !important; }
    header .navbar .navbar-toggler {
        color: #fff;
        font-size: 1.45rem;
        border-color: #fff;
        margin-right: 1rem;
    }
    header .navbar .navbar-toggler-icon { background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewSbx='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255,255,255, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E"); }
}

@media screen and (max-width: 767px) {
    header .navbar .navbar-nav { margin: 0 auto !important; }
}

@media screen and (max-width: 575px) {
    header .navbar .navbar-nav li { border-right: 0; }
    header .navbar .navbar-nav li a {
        text-align: center;
        padding: 0.3rem 0 !important;
    }
    header .navbar .navbar-nav { margin-top: 1rem; }
    header .navbar .navbar-nav li { 
        text-align: center;
        padding: 0.2rem 0.5rem;
    }
    header .navbar .navbar-nav li a { 
        padding-bottom: 0; 
        margin-top: 0;
    }
    header .navbar .navbar-nav li a:before { display: none; } 
}

@media screen and (max-width: 256px) {
    header .navbar .logo { max-width: 100%; }
}


/*--------------------------------------------------------------
    Breadcrumb
--------------------------------------------------------------*/

.breadcrumb { 
    background-color: #fff;
    padding: 0.75rem 0;
}
.breadcrumb-item + .breadcrumb-item::before {
    color: #e54330;
    content: ">";
}


/*--------------------------------------------------------------
    Carousel
--------------------------------------------------------------*/

#carousel-accueil,
[id^="carousel-page-"] { position: relative; }
#carousel-accueil:before,
[id^="carousel-page-"]:before { 
    content: "";
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    width: 100%;
    height: 100px;
    position: absolute;
    z-index: 2;
    left: 0;
    right: 0;
    bottom: 0;
}
#carousel-accueil:before { background-image: url(img/bordure-grise.svg); }
#carousel-page-rouge:before { background-image: url(img/bordure-blanche-rouge.svg); }
#carousel-page-bleue:before { background-image: url(img/bordure-blanche-bleue.svg); }

#carouselAccueil:before { 
    content: "";
    background-image: url(img/background.png);
    background-repeat: no-repeat;
    background-position: center right;
    width: 100%;
    height: 500px;
    min-height: 500px;
    position: absolute; 
    z-index: 1;
}
#carouselAccueil .carousel-item {
    height: 500px;
    min-height: 500px;
    background: no-repeat center center scroll;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

#carouselPage:before { 
    content: "";
    background-image: url(img/background.png);
    background-repeat: no-repeat;
    background-position: center right;
    width: 100%;
    height: 380px;
    min-height: 380px;
    position: absolute; 
    z-index: 1;
}
#carouselPage .carousel-item {
    height: 380px;
    min-height: 380px;
    background: no-repeat center center scroll;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

.carousel .carousel-item .carousel-caption {
    bottom: unset;
    text-align: left;
    top: 50%;
    right: 50%;
    left: 10%;
    transform: translateY(-50%);
}
.carousel .carousel-item .carousel-caption * { 
    color: #fff;
    text-transform: uppercase;
    text-shadow: 4px 4px 5px rgba(0,0,0,0.6);
}
.carousel .carousel-item .carousel-caption .titre {
    font-size: 2.2rem;
    line-height: 1.2;
    margin-bottom: 1rem;
}
.carousel .carousel-item .carousel-caption .buttons-section { display: flex; }
.carousel .carousel-item .carousel-caption .buttons-section [class^="btn-"] {
    font-family: 'Kanit Re', Helvetica, sans-serif;
    line-height: 1;
    padding: 0.5rem 1rem 0.6rem 1rem;
    margin-top: 1rem;
    margin-right: 1rem;
    text-shadow: none;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.carousel .carousel-item .carousel-caption .buttons-section [class^="btn-"]:last-child { margin-right: 0; }
.carousel .carousel-item .carousel-caption .btn-1 {
    border: 1px solid #2ebce4;
    background-color: #2ebce4;
}
.carousel .carousel-item .carousel-caption .btn-2 {
    border: 1px solid #e54330;
    background-color: #e54330;
}
.carousel .carousel-item .carousel-caption [class^="btn-"]:hover,
.carousel .carousel-item .carousel-caption [class^="btn-"]:focus {
    border: 1px solid #222;
    background-color: #222;
    text-decoration: none;
}
.carousel .carousel-control-next, 
.carousel .carousel-control-prev { width: 10%; }

@media screen and (max-width: 1199px) {
    .carousel .carousel-item .carousel-caption { right: 45%; }
}

@media screen and (max-width: 991px) {
    .carousel .carousel-item .carousel-caption { right: 50%; }
}

@media screen and (max-width: 767px) {
    .carousel:before { display: none; }
    .carousel .carousel-item .carousel-caption { right: 10%; }
}

@media screen and (max-width: 575px) {
    .carousel .carousel-item .carousel-caption .titre { font-size: 1.4rem; }
    .carousel .carousel-item .carousel-caption [class^="btn-"] { font-size: 0.8rem; }
}


/*--------------------------------------------------------------
    Intro
--------------------------------------------------------------*/

#intro h2 {
    font-family: 'Kanit Li', Helvetica, sans-serif;
    color: #000;
    font-size: 2.5rem;
    line-height: 1;
    margin-bottom: 0;
    text-align: center;
}
#intro h2 * { font-size: 3.5rem; }
#intro .border-left { border-left: 1px solid #e54330 !important; }

@media screen and (max-width: 767px) {
    #intro .border-left { border-left: none !important; }
}


/*--------------------------------------------------------------
    Services
--------------------------------------------------------------*/

#services .card .card-img-overlay { 
    background-color: rgba(0, 0, 0, 0.5); 
    border-radius: 0;
}
#services .card .card-title {
    margin-bottom: 0;
    position: relative;
    width: 100%;
    height: 100%;
}
#services .card .card-title img {
    position: absolute;
    top: 50%;
    right: 0;
    left: 0;
    transform: translateY(-50%);
    margin: 0 auto;
}

#services .flip-card {
    width: 100%;
    height: 239px;
    display: block;
    position: relative;
    -webkit-perspective: 600px;
    -moz-perspective: 600px;
    perspective: 600px;
}
#services .flip-card:hover .front {
    z-index: 0;
    -webkit-transform: rotateY(180deg);
    -ms-transform: rotate(180deg);
    transform: rotateY(180deg);
}
#services .flip-card:hover .back {
    -webkit-transform: rotateY(0deg);
    -ms-transform: rotate(0deg);
    transform: rotateY(0deg);
    height: 100%;
    overflow: hidden;
}
#services .flip-card .front,
#services .flip-card .back {
    display: inline-block;
    position: absolute;
    z-index: 1;
    cursor: pointer;
    -webkit-transition: all 1s;
    transition: all 1s;
    -webkit-backface-visibility: hidden;
    -ms-backface-visibility: hidden;
    backface-visibility: hidden;
}
#services .flip-card .back {
    -webkit-transform: rotateY(180deg);
    -ms-transform: rotate(180deg);
    transform: rotateY(180deg);
}

#services .card.front .card-img-overlay { background-color: rgba(0, 0, 0, 0.5); }
#services .card.front .card-img-overlay * {
    text-transform: uppercase;
    text-align: center;
}

#services .card.back img {
    width: 100%;
    min-height: 100%;
    height: 100%;
    max-height: 30rem;
    object-fit: cover;
    border-radius: 0;
}
#services .card.back .card-text {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
#services .card.back .card-text * {
    font-family: 'Kanit Re', Helvetica, sans-serif;
    color: #fff;
    text-transform: uppercase;
}
#services .card.back .card-text ul {
    margin-bottom: 0;
    list-style: none;
}
#services .card.back .card-text ul li::before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f00c";
    color: #ef8823;
    margin-right: -14px;
    position: absolute;
    left: 1.3rem;
}

@media screen and (max-width: 1199px) {
    #services .flip-card { height: 197px; }
}

@media screen and (max-width: 991px) {
    #services .flip-card { height: 220px; }
}

@media screen and (max-width: 767px) {
    #services .flip-card { height: 217px; }
}

@media screen and (max-width: 575px) {
    #services .flip-card { height: 275px; }
}


/*--------------------------------------------------------------
    Services 2
--------------------------------------------------------------*/

#services-2 .card {
    color: inherit;
    cursor: pointer;
    width: 100%;
    max-width: 100%;
    height: 225px;
    min-height: 225px;
    perspective: 1000px;
    position: relative;
}
#services-2 .card-img {
    width: 100%;
    min-height: 100%;
    height: 100%;
    max-height: 30rem;
    object-fit: cover;
    border-radius: 0;
}

#services-2 .front,
#services-2 .back {
    display: flex;
    background-position: center;
    background-size: cover;
    text-align: center;
    justify-content: center;
    align-items: center;
    position: absolute;
    height: 100%;
    width: 100%;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform-style: preserve-3d;
    transition: ease-in-out 600ms;
}

#services-2 .front {
    font-family: 'Kanit Me', Helvetica, sans-serif;
    background-size: cover;
    padding: 1rem;
    font-size: 1.618rem;
    color: #fff;
    overflow: hidden;
}
#services-2 .front:before {
    position: absolute;
    display: block;
    content: "";
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: transparent;
    opacity: 0.25;
    z-index: -1;
}
#services-2 .square-box {
    background-color: rgba(0, 0, 0, 0.6);
    border-radius: 100%;
    position: relative;
    width: 100%;
    min-width: 60px;
    max-width: 110px;
    overflow: hidden;
}
#services-2 .square-box:before {
    content: "";
    display: block;
    padding-top: 100%;
}
#services-2 .square-box .square-content {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    padding: 0.5rem;
}
#services-2 .square-box .square-content div {
    display: table;
    width: 100%;
    height: 100%;
}
#services-2 .square-box .square-content div > span {
    display: table-cell;
    vertical-align: middle;
    color: #fff;
    line-height: 1.2;
    font-size: 0.9rem;
    text-transform: uppercase;
}
#services-2 .card:hover .front { transform: rotateY(180deg); }
#services-2 .card:nth-child(even):hover .front { transform: rotateY(-180deg); }

#services-2 .back {
    background: #fff;
    transform: rotateY(-180deg);
    padding: 0 0.5rem;
    font-size: 0.95rem;
}
#services-2 .back * { color: #fff; }
#services-2 .card:hover .back { transform: rotateY(0deg); }
#services-2 .card:nth-child(even) .back { transform: rotateY(180deg); }
#services-2 .card:nth-child(even):hover .back { transform: rotateY(0deg); }

#services-2 .title-wrapper {
    color: inherit;
    width: 100%;
    max-width: 100%;
    height: 225px;
    min-height: 225px;
    position: relative;
}
#services-2 .title-wrapper .front {
    align-items: start;
    text-align: left;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    border-bottom-left-radius: 20px;
}
#services-2 .title-wrapper .front .title {
    text-transform: uppercase;
    line-height: 1.2;
    font-size: 1.2rem;
    margin-top: 1rem;
    width: 100%;
}



/*--------------------------------------------------------------
    Contenu
--------------------------------------------------------------*/

#contenu img {
    width: 100%;
    min-height: 100%;
    height: 100%;
    max-height: 30rem;
    object-fit: cover;
    border-radius: 0;
}

#contenu .bis * { color: #fff; }
#contenu .bis [class^="icon-"] { color: #000; }


/*--------------------------------------------------------------
    Contenu Page
--------------------------------------------------------------*/

#contenu-page { position: relative; }
#contenu-page h2 { color: #000; }
#contenu-page .contenu { position: relative; }
#contenu-page .card-img {
    width: 100%;
    min-height: 100%;
    height: 100%;
    max-height: 40rem;
    object-fit: cover;
    border-radius: 0;
}


/*--------------------------------------------------------------
    Contact
--------------------------------------------------------------*/

#contact .adresse * {
    font-family: 'Kanit Me', Helvetica, sans-serif;
    font-size: 1.1rem;
    color: #2ebce4;
    line-height: 1;
}
#contact .adresse .btn {
    background-color: #e54330;
    text-transform: uppercase;
    border-radius: 0;
    color: #fff;
}
#contact .adresse .btn:hover,
#contact .adresse .btn:focus { background-color: #000; }


/*--------------------------------------------------------------
    Contact (Form)
--------------------------------------------------------------*/

#contact-us .form {
    width: 100%;
    height: 50px;
    padding: 10px 15px;
    background: #fafafa;
    border: 1px solid #f2f2f2;
    margin-bottom: 15px;
    color: #000 !important;
    font-size: 0.8rem;
    -webkit-transition: all 0.4s;
    -moz-transition: all 0.4s;
    transition: all 0.4s;
}
#contact-us .form:hover { border: 1px solid #e54330; }
#contact-us .form:focus {
    color: #fff;
    outline: none;
    border: 1px solid #e54330;
}
#contact-us textarea {
    height: 14.5rem !important;
    max-width: 100%;
}
#contact-us p { margin-bottom: 0; }
#contact-us .form-btn {
    display: block;
    font-size: 0.9rem;
    height: auto;
    padding: 0.5rem 2rem;
    color: #fff;
    background: #e54330;
    border: 1px solid #e54330;
    border-radius: 0;
    outline: none;
    margin-top: 0;
    margin-left: auto;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
}
#contact-us .form-btn:hover {
    background: #2ebce4;
    color: #fff;
    border: 1px solid #2ebce4;
}
#contact-us .form-btn:active { opacity: 0.9; }
#contact-us .wpcf7-list-item { margin: 0 !important; }

#contact-us ::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
    color: #000;
    opacity: 1; /* Firefox */
}

#contact-us :-ms-input-placeholder { /* Internet Explorer 10-11 */
    color: #000;
}

#contact-us ::-ms-input-placeholder { /* Microsoft Edge */
    color: #000;
}

.wpcf7-list-item-label { 
    color: #000 !important;
    font-size: 78%;
}
.wpcf7-spinner { display: none; }

.grecaptcha-badge { display: none; }


/*--------------------------------------------------------------
    Footer
--------------------------------------------------------------*/

footer .pre-footer { background-color: #000; }
footer .pre-footer * { 
    color: #fff;
    font-size: 0.8rem;
}
footer .pre-footer ul {
    list-style: none;
    padding-left: 0;
}
footer .pre-footer ul.nav_footer {
    font-family: 'Kanit Sb', Helvetica, sans-serif;
    list-style-type: none;
    margin-bottom: 1.5rem;
}
footer .pre-footer ul.nav_footer:last-of-type { margin-bottom: 0; }
footer .pre-footer ul.nav_footer li:last-child { margin-bottom: 0; }
footer .pre-footer ul.nav_footer li a { font-size: 0.7rem; }
footer .pre-footer ul.nav_footer li a:hover,
footer .pre-footer ul.nav_footer li a:focus { 
    color: #e54330;
    text-decoration: underline; 
}
footer .pre-footer ul.social-icon-colored li svg,
footer .pre-footer ul.social-icon-colored li i { font-size: 16px; }

footer .footer * { color: #ccc; }

@media screen and (max-width: 767px) {
    footer .pre-footer .border-right { border-right: 0 !important; }
}

@media screen and (max-width: 575px) {
    footer .pre-footer img { 
        margin: 0 auto; 
        display: block;
    }
    footer .pre-footer * { text-align: center; }
    footer .pre-footer .social-links { 
        padding-left: 0 !important;
        margin-bottom: 0.8rem;
    }
}


/*--------------------------------------------------------------
    Social
--------------------------------------------------------------*/

.social-links ul {
    position: relative;
    display: block;
    margin-bottom: 0;
}
.social-links .social-icon-colored li {
    position: relative;
    display: inline-block;
    margin: 0px 4px 0px;
}
.social-links .social-icon-colored li a {
    background-color: #222;
    position: relative;
    display: block;
    height: 25px;
    width: 25px;
    line-height: 26px;
    text-align: center;
    font-size: 16px;
    color: #fff;
    border-radius: 50%;
    border: 1px solid #fff;
    -webkit-transition: all 300ms ease;
    -moz-transition: all 300ms ease;
    -ms-transition: all 300ms ease;
    -o-transition: all 300ms ease;
    transition: all 300ms ease;

}
.social-links .social-icon-colored li a:hover {
    color: #e54330;
    border: 1px solid #e54330;
    -webkit-transform: scale(1) rotate(-360deg);
    -moz-transform: scale(1) rotate(-360deg);
    -ms-transform: scale(1) rotate(-360deg);
    -o-transform: scale(1) rotate(-360deg);
    transform: scale(1) rotate(-360deg);
}


/*--------------------------------------------------------------
    Back to Top
--------------------------------------------------------------*/

.scroll-to-top {
    position: fixed;
    bottom: 15px;
    right: 15px;
    width: 60px;
    height: 60px;
    color: #fff;
    font-size: 24px;
    text-transform: uppercase;
    line-height: 60px;
    text-align: center;
    z-index: 100;
    cursor: pointer;
    background-color: #e54330;
    display: none;
    -webkit-transition: all 300ms ease;
    -ms-transition: all 300ms ease;
    -o-transition: all 300ms ease;
    -moz-transition: all 300ms ease;
    transition: all 300ms ease;		
}

.scroll-to-top:hover {
    color: #fff;
    background-color: #44c0ee;
}


/*--------------------------------------------------------------
    Logo Slider
--------------------------------------------------------------*/

#carousel-logo .slick-slide { margin: 0 2px; }
#carousel-logo .slick-slide img { width: 100%; }
#carousel-logo .slick-slider {
    position: relative;
    display: block;
    box-sizing: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}
#carousel-logo .slick-list {
    position: relative;
    display: block;
    overflow: hidden;
    margin: 0;
    padding: 0;
}
#carousel-logo .slick-list:focus { outline: none; }
#carousel-logo .slick-list.dragging {
    cursor: pointer;
    cursor: hand;
}
#carousel-logo .slick-slider .slick-track,
#carousel-logo .slick-slider .slick-list {
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}
#carousel-logo .slick-track {
    position: relative;
    top: 0;
    left: 0;
    display: block;
}
#carousel-logo .slick-track:before,
#carousel-logo .slick-track:after {
    display: table;
    content: '';
}
#carousel-logo .slick-track:after { clear: both; }
#carousel-logo .slick-loading .slick-track { visibility: hidden; }
#carousel-logo .slick-slide {
    display: none;
    float: left;
    height: 100%;
    min-height: 1px;
}
#carousel-logo [dir='rtl'] .slick-slide { float: right; }
#carousel-logo .slick-slide img { display: block; }
#carousel-logo .slick-slide.slick-loading img { display: none; }
#carousel-logo .slick-slide.dragging img { pointer-events: none; }
#carousel-logo .slick-initialized .slick-slide { display: block; }
#carousel-logo .slick-loading .slick-slide { visibility: hidden; }
#carousel-logo .slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent;
}
#carousel-logo .slick-arrow.slick-hidden { display: none; }
#carousel-logo .slick-dots {
    display: flex;
    justify-content: center;
    margin: 0;
    padding: 1rem 0;
    list-style-type: none;
    margin-top: 2rem;
}
#carousel-logo .slick-dots li { margin: 0 0.25rem; }
#carousel-logo .slick-dots button {
    display: block;
    width: 1rem;
    height: 1rem;
    padding: 0;
    border: none;
    border-radius: 100%;
    background-color: #003567;
    text-indent: -9999px;
}
#carousel-logo .slick-dots li.slick-active button { background-color: #d7cfaf; }
#carousel-logo .slick-arrow.slick-hidden { display: none; }
#carousel-logo .slick-prev,
#carousel-logo .slick-next {
    font-size: 0;
    line-height: 0;
    position: absolute;
    top: 50%;
    display: block;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    padding: 0;
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
    cursor: pointer;
    color: transparent;
    border: none;
    outline: none;
    background: #fd7666;
    z-index: 15;
}
#carousel-logo .slick-next { right: 0; }
#carousel-logo .slick-prev { left: 0; }
#carousel-logo .slick-prev:before,
#carousel-logo .slick-next:before {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    font-size: 25px;
    line-height: 1;
    color: #fff;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
#carousel-logo .slick-prev:before {
    content: '\f0d9';
    margin-right: 2px;
}
#carousel-logo .slick-next:before {
    content: '\f0da';
    margin-left: 4px;
}


/*--------------------------------------------------------------
    404
--------------------------------------------------------------*/

.erreur {
    height: 100%;
    background-color: #f8f9fa;
}
.erreur .text-wrapper {
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}
.erreur .title {
    font-size: 5em;
    font-weight: 700;
    color: #000;
    position: relative;
    text-align: center;
}
.erreur .subtitle {
    font-size: 1.5em;
    font-weight: 700;
    color: #0033a0;
    position: relative;
    text-align: center;
}
.erreur .buttons { margin-top: 4em; }
.erreur .buttons a.button {
    background-color: #ffa81a;
    display: block;
    font-weight: 700;
    text-decoration: none;
    padding: 15px;
    text-transform: uppercase;
    color: white;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
.erreur .buttons a.button:hover {
    background-color: #fff;
    color: #ffa81a;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
.erreur .subtitle:before,
.erreur .title:before {
    content: attr(data-content);
    position: absolute;
    left: -2px;
    text-shadow: 1px 0 blue;
    top: 0;
    color: white;
    overflow: hidden;
    clip: rect(0, 900px, 0, 0);
    -webkit-animation: noise-anim-2 3s infinite linear alternate-reverse;
    animation: noise-anim-2 3s infinite linear alternate-reverse;
}