/*
Theme Name: asticotheme
Theme URI: None
Author: asticoweb.com
Author URI: https://asticoweb.com
Description: Simple wordpress theme made with ❤️ by asticoweb.com | All rights reserved ©
Tags: theme, madewithlove, asticonet, asticoweb, asticoweb.com, asticotheme, coding, spreadthelove, personal, personaluseonly
Version: 5.0
License: License asticoweb.com
License URI: https://asticoweb.com
Text Domain: asticotheme
*/

::selection {
    background: var(--or);
    color: var(--bleu);
    text-shadow: none;
}

::-webkit-selection {
    background: var(--or);
    color: var(--bleu);
    text-shadow: none;
}

::-moz-selection {
    background: var(--or);
    color: var(--bleu);
    text-shadow: none;
}

*,
*:after,
*:before {
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-font-smoothing: antialiased;
    font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    outline: none !important;
    text-decoration: none;

}

section,
div,
header,
nav,
article,
section,
aside,
footer,
h1,
h2,
h3,
h4,
h5,
h6,
p,
a,
ul,
li,
figure,
figcaption,
class,
img {

    margin: 0;
    padding: 0;
}


html,
body {

    width: 100%;
    padding: 0;
    margin: 0;
    font-family: 'gotham', sans-serif;
    position: relative;
    scroll-behavior: smooth;
    -webkit-tap-highlight-color: transparent;
}

body {

    overflow-x: hidden;
    overflow-y: overlay;
    background: white;
}

body:not(#tinymce) {

    opacity: 0;
    transition: opacity .5s;
}

main,
body>.elementor,
footer {

    transform: translateY(-100px);
    transition: transform .5s;
}

main,
body>.elementor {

    background: white;
}

::-webkit-scrollbar {
    width: 10px;
    height: 10px;
    border-left: solid 1px var(--blanc90);
}

::-webkit-scrollbar-thumb {
    background: var(--or);
    border-left: solid 1px var(--blanc90);
}

::-webkit-scrollbar-button {
    display: none;
}

.page main>section>h1,
br.clear,
a.post-edit-link {

    display: none;
}

input::placeholder,
textarea::placeholder {

    opacity: 1 !important;
}

input {

    accent-color: var(--or);
}


:root {
    --bleu: #00213f;
    --bleu2: #003a79;
    --ciel: #27aae1;
    --or: #b48e43;
    --gris25: #2f3a3f;
    --gris50: #60707f;
    --gris75: #90a9bf;
    --blanc90: #dae1e5;
    --blanc95: #e7eef2;
}

.balance {

    text-wrap: balance;
}

/*------------------------------------*\
    DARK MODE
\*------------------------------------*/

input[type="search"] {

    background: white;
}

/*------------------------------------*\
    UNDERLINE
\*------------------------------------*/

.underline .elementor-button-text,
.elementor-widget-text-editor a {

    position: relative;
}

.elementor-widget-text-editor a {

    line-height: 1.25 !important;
    display: inline-block;
}

.underline .elementor-button-text:before,
.elementor-widget-text-editor a:before {
    content: '';
    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
    transition: transform .3s;
    position: absolute;
    width: 100%;
    height: 2px;
    background: var(--or);
    top: 100%;
    left: 0;
    pointer-events: none;
}


.underline a:hover .elementor-button-text:before,
.elementor-widget-text-editor a:hover::before {

    transform-origin: 100% 50% !important;
    transform: scale3d(0, 1, 1) !important;
}

.underline a {

    background: transparent !important;
    border-radius: 0 !important;
    padding: 0 !important;
    line-height: 1.25 !important;
    color: var(--bleu) !important;
}

/*------------------------------------*\
    SWIPER
\*------------------------------------*/

.custom-swiper .swiper {

    overflow: visible;
    padding: 0 !important;
}

.custom-swiper .elementor-swiper-button {

    border-radius: 7.5px;
    width: 50px;
    height: 50px;
    background-color: var(--bleu);
    display: flex;
    justify-content: center;
    align-items: center;
    top: auto !important;
    bottom: calc(100% + 50px) !important;
    transform: none !important;
}

.custom-swiper .elementor-swiper-button.swiper-button-lock {

    display: none !important;
}

.custom-swiper .elementor-swiper-button i {

    font-size: 14px !important;
    color: white !important;
}

.custom-swiper .elementor-swiper-button-prev {

    left: auto !important;
    right: 62.5px;
}

.custom-swiper .swiper-button-disabled {

    pointer-events: none !important;
    opacity: 1 !important;
    background-color: var(--blanc90);
}

.custom-swiper .swiper-pagination {

    position: absolute !important;
    left: 0 !important;
    transform: none !important;
    bottom: auto !important;
    top: calc(100% + 50px) !important;
    color: var(--gris50) !important;
    display: flex !important;
    gap: 12.5px !important;
}

.custom-swiper .swiper-pagination-bullet {

    background-color: var(--gris75) !important;
    transition: background-color .5s !important;
    margin: 0 !important;
    width: 6.25px !important;
    height: 6.25px !important;
    border-radius: 100% !important;
    opacity: 1 !important;
}

.custom-swiper .swiper-pagination-bullet:hover,
.custom-swiper .swiper-pagination-bullet-active {

    background-color: var(--ciel) !important;
}

@media screen and (max-width: 1024px) {


    .custom-swiper .elementor-swiper-button {

        display: none !important;
    }
}

@media screen and (max-width: 650px) {


    .custom-swiper .swiper {

        margin-right: 25px;
    }

    .custom-swiper .swiper-pagination {

        display: none !important;
    }

}

/*------------------------------------*\
    OVERLAY
\*------------------------------------*/

.overlay:not(:has(.elementor-background-video-container)):before,
.overlay:not(:has(.elementor-background-video-container)):after,
.overlay .elementor-background-video-container:before,
.overlay .elementor-background-video-container:after {

    content: '' !important;
    position: absolute;
    inset: 0;
    background: var(--bleu);
}

.overlay:before,
.overlay .elementor-background-video-container:before {

    mix-blend-mode: color !important;
    z-index: 1;
}

.overlay:after,
.overlay .elementor-background-video-container:after {

    opacity: .9;
    z-index: 2;
}


/*------------------------------------*\
    HEADER
\*------------------------------------*/

#header {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 9999;
}

#header:before {

    content: '';
    position: absolute;
    inset: 0;
    background-color: white;
    border-bottom: solid 1px var(--blanc90);
    z-index: -1;
    translate: 0 calc(-100% - 1px);
    transition: translate .3s;
}

#header.active-header:before {

    translate: 0;
}

#header .wrapper {
    max-width: 1680px;
    width: 100%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 37.5px;
    transition: padding .3s;
}

.active-header .wrapper {

    padding: 18.75px !important;
}

#header a#logo {

    display: flex;
}

#header svg,
#footer svg,
#header a#logo img,
#footer a#logo img {

    height: 50px;
    width: auto;
    fill: white;
    transition: fill .3s;
}

.active-header a#logo svg {

    fill: var(--bleu2) !important;
}

#header a#logo:hover svg {

    fill: var(--or) !important;
}

#header ul,
#header .btn,
#header .gtranslate_wrapper {

    display: flex;
    align-items: center;
}

#header .btn {

    gap: 25px;
}

#header .gtranslate_wrapper {

    gap: 12.5px;
}

#header .gtranslate_wrapper a.glink {

    color: var(--gris75);
    transition: color .3s;
}

#header .gtranslate_wrapper a.glink:hover {

    color: var(--or);
}

#header .gtranslate_wrapper a.glink.gt-current-lang {

    color: var(--ciel);
}

#header li {

    display: flex;
    align-items: center;
    list-style: none;
}

#header ul li:not(:last-child)::after {

    content: '';
    display: inline-block;
    width: 3px;
    height: 22.5px;
    background-color: var(--or);
    margin: 0 25px;
    -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 5 75' preserveAspectRatio='none'%3E%3Cpath d='M1.89,74.46c-1.32-15.32-1.89-27.07-1.89-36.96S.6,15.86,1.89.54c.02-.31.29-.54.62-.54s.58.23.61.54c1.32,15.34,1.89,27.09,1.89,36.96s-.57,21.62-1.89,36.96c-.03.3-.29.54-.61.54s-.59-.23-.62-.54'/%3E%3C/svg%3E");
    mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 5 75' preserveAspectRatio='none'%3E%3Cpath d='M1.89,74.46c-1.32-15.32-1.89-27.07-1.89-36.96S.6,15.86,1.89.54c.02-.31.29-.54.62-.54s.58.23.61.54c1.32,15.34,1.89,27.09,1.89,36.96s-.57,21.62-1.89,36.96c-.03.3-.29.54-.61.54s-.59-.23-.62-.54'/%3E%3C/svg%3E");

}

#header ul li a {

    color: white;
    transition: color .3s;
}

.active-header ul li a {

    color: var(--bleu2) !important;
}

#header ul li a:hover {

    color: var(--or) !important;
}

#footer #reserver,
#header #reserver {

    color: white;
    background-color: var(--or);
    border-radius: 7.5px;
    padding: 15px 25px;
    transition: background-color .3s;
}

#footer #reserver:hover,
#header #reserver:hover {

    background-color: var(--bleu2);
}

/*------------------------------------*\
    FOOTER
\*------------------------------------*/

#footer {

    background-color: var(--bleu);
}

#footer .wrapper,
#footer .container {

    display: flex;
    justify-content: space-between;
}

#footer .wrapper {
    max-width: 1680px;
    width: 100%;
    margin: 0 auto;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 100px;
    padding-bottom: 50px;
    gap: 50px 0;
}

#footer .container:not(.bottom) {

    flex-direction: column;
    gap: 25px;
    align-items: flex-start;
}

#footer ul {

    list-style: none;
}

#footer a {

    color: white;
    transition: color .3s;
}

#footer a:hover {

    color: var(--or);
}

#footer p {

    color: var(--gris75);
    font-size: 12px;
    width: 350px;
}

#footer .social svg {

    height: 25px;
    width: auto;
    transition: fill .3s;
}

#footer .social a:hover svg {

    fill: var(--or);
}

#footer .bottom {

    width: 100%;
    padding-top: 50px;
    border-top: solid 1px black;
}

#footer .bottom ul {

    display: flex;
    gap: 37.5px;
    list-style: none;
}

#footer .bottom li,
#footer .bottom a,
#footer button {

    border: none;
    padding: 0;
    background: transparent;
    color: var(--gris75);
    font-size: 14px;
    line-height: 1;
    transition: color .3s;
    cursor: pointer;
}

#footer .bottom a:hover,
#footer button:hover {

    color: var(--ciel);
}


#footer a#asticoweb {

    position: relative;
    display: flex;
    align-items: center;
    transition: color .3s;
}

#footer a#asticoweb:hover {

    color: var(--or);
}

#footer a#asticoweb:before {

    content: '';
    display: inline-block;
    width: 22.5px;
    height: 22.5px;
    margin-right: 6.25px;
    background-color: var(--gris75);
    transition: background-color .3s;
    -webkit-mask: url('data:image/svg+xml,<%3Fxml version="1.0" encoding="UTF-8"%3F><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 194.4 200"><path d="M90.5,102.2c-1.2-.2-2.9-.3-4.1-.3-5.9-.4-12.2,1.5-15.3,6.3-5,6.9-3.9,19,3.7,23.8,3.4,2.3,7.8,2.8,13.4,2.2h0c11.7-1,22.3-7.9,28.6-17.6-6.6-7.8-15.9-13.2-26.3-14.4Z"/><path d="M108.3,0C59.7,0,0,59.3,0,109.3s59.7,90.7,108.3,90.7,86.1-40.7,86.1-90.7h0C194.4,59.5,156.9,0,108.3,0ZM137.2,142.2c0,3-2.5,5.4-5.5,5.3-2.9,0-5.3-2.4-5.3-5.3,0-3.1-.4-6.2-1.2-9.1-10,10.4-24.1,16.7-38.5,16.9-7.2.3-14.5-1.2-20.5-5.5-10.6-7.3-14.6-21.3-11.6-33.4,3-12.6,13.9-21.7,26.8-22.3,1.8-.2,3.7-.1,5.5,0,1,.1,3.1.2,4.1.3,11.6,1.5,22.6,7,30.8,15.3.4-1.6.6-3.5.8-5.1.1-1.1.1-2.7.1-3.9-.1-3.6-.8-7.1-2.3-10.4-.5-.9-1.1-2.3-1.7-3.1-8.6-14.2-28.9-16.6-40.3-4.5-9.8,9.5-24-4-14.9-14.3,17.9-18.3,49.2-17.5,65.9,2,6.7,7.5,10.7,17.4,11.1,27.4h0c.5,10.2-2.2,20.5-7.2,29.4,2.7,6.5,4,13.5,3.9,20.3Z"/></svg>') no-repeat;
    mask: url('data:image/svg+xml,<%3Fxml version="1.0" encoding="UTF-8"%3F><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 194.4 200"><path d="M90.5,102.2c-1.2-.2-2.9-.3-4.1-.3-5.9-.4-12.2,1.5-15.3,6.3-5,6.9-3.9,19,3.7,23.8,3.4,2.3,7.8,2.8,13.4,2.2h0c11.7-1,22.3-7.9,28.6-17.6-6.6-7.8-15.9-13.2-26.3-14.4Z"/><path d="M108.3,0C59.7,0,0,59.3,0,109.3s59.7,90.7,108.3,90.7,86.1-40.7,86.1-90.7h0C194.4,59.5,156.9,0,108.3,0ZM137.2,142.2c0,3-2.5,5.4-5.5,5.3-2.9,0-5.3-2.4-5.3-5.3,0-3.1-.4-6.2-1.2-9.1-10,10.4-24.1,16.7-38.5,16.9-7.2.3-14.5-1.2-20.5-5.5-10.6-7.3-14.6-21.3-11.6-33.4,3-12.6,13.9-21.7,26.8-22.3,1.8-.2,3.7-.1,5.5,0,1,.1,3.1.2,4.1.3,11.6,1.5,22.6,7,30.8,15.3.4-1.6.6-3.5.8-5.1.1-1.1.1-2.7.1-3.9-.1-3.6-.8-7.1-2.3-10.4-.5-.9-1.1-2.3-1.7-3.1-8.6-14.2-28.9-16.6-40.3-4.5-9.8,9.5-24-4-14.9-14.3,17.9-18.3,49.2-17.5,65.9,2,6.7,7.5,10.7,17.4,11.1,27.4h0c.5,10.2-2.2,20.5-7.2,29.4,2.7,6.5,4,13.5,3.9,20.3Z"/></svg>') no-repeat;
}

#footer a#asticoweb:hover::before {

    background-color: var(--or);
}

#footer .bw {

    background: #001120;
    padding: 25px 100px;
}

#footer .bw p,
#footer .bw a {

    width: auto;
    font-size: 12px;
    text-wrap: balance;
}

#footer .bw a {

    color: var(--or);
}

#footer .bw a:hover {

    color: var(--ciel);
}

/*------------------------------------------------------------------------*\
    RESPONSIVE
\*------------------------------------------------------------------------*/

@media only screen and (max-width:1024px) {

    .img {

        aspect-ratio: 4/3;
    }

    /*------------------------------------*\
    HEADER
\*------------------------------------*/

    #header #nav {

        position: fixed;
        bottom: 0;
        left: 0;
        width: 100%;
        padding: 25px;
        background-color: white;
        border-top: solid 1px var(--blanc90);
        display: flex;
        overflow-x: auto;
    }


    #header #nav::-webkit-scrollbar {
        border-top: solid 1px var(--blanc90);
    }

    #header #nav::-webkit-scrollbar-thumb {
        background: var(--or);
        border-top: solid 1px var(--blanc90);
    }

    #header ul li a {

        color: var(--bleu2) !important;
        text-wrap: nowrap;
    }

    #header ul#menu-menu {

        justify-content: center;
    }

    #header .gtranslate_wrapper {

        position: fixed;
        top: 50%;
        right: 0;
        background-color: white;
        padding: 12.5px;
        border: solid 1px var(--blanc90);
        border-right: 0;
        flex-direction: column;
        transition: translate .3s;
    }

    #header .gtranslate_wrapper a {

        line-height: 1;
    }

    .scroll-down .gtranslate_wrapper {

        translate: 100% !important;
    }

    /*------------------------------------*\
        FOOTER
\*------------------------------------*/

    #footer {

        margin-bottom: 79px;
    }

    #footer .wrapper {

        padding: 100px 50px 50px 50px;
    }

    #footer .wrapper,
    #footer .container {

        flex-direction: column;
        justify-content: center;
        align-items: center !important;
        text-align: center;
    }

    #footer .bottom {

        gap: 25px;
    }

    #footer .bottom ul {

        flex-wrap: wrap;
        align-items: center;
        justify-content: center;
    }

    #footer .bw {

        padding: 50px 25px;
        gap: 0;
    }
}

@media only screen and (max-width:650px) {

    #header .wrapper {

        padding: 18.75px;
    }

    #header svg,
    #footer svg,
    #header a#logo img,
    #footer a#logo img {

        height: 40px;
    }

    /*------------------------------------*\
        FOOTER
\*------------------------------------*/

    #footer {

        margin-bottom: 75.5px;
    }

    #footer .wrapper {

        padding: 50px 25px 25px 25px;
        gap: 25px;
    }

    #footer .bottom {

        padding-top: 25px;
    }

    #footer .bottom li,
    #footer .bottom a,
    #footer button {

        font-size: 12px;
    }

    #footer .bottom ul {

        gap: 25px;
    }


    #footer .bw {

        padding: 25px;
        gap: 0;
    }
}