/*
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: 3.8
License: License asticoweb.com
License URI: https://asticoweb.com
Text Domain: asticotheme
*/

::selection {
    background: var(--bleu);
    color: white;
    text-shadow: none;
}

::-webkit-selection {
    background: var(--bleu);
    color: white;
    text-shadow: none;
}

::-moz-selection {
    background: var(--bleu);
    color: white;
    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: 'Krub', sans-serif;
    position: relative;
}

body {

    overflow-x: hidden;
    overflow-y: overlay;
}

::-webkit-scrollbar {
    width: 15px;
    height: 15px;
}

::-webkit-scrollbar-track {
    box-shadow: inset 0 0 15px 15px transparent;
    border: solid 5px transparent;
}

::-webkit-scrollbar-thumb {
    box-shadow: inset 0 0 15px 15px #00244c;
    border: solid 5px transparent;
    border-radius: 15px;
}

::-webkit-scrollbar-button {
    display: none;
}

.page main > section > h1,
br.clear,
a.post-edit-link {

    display: none;
}

input::placeholder,
textarea::placeholder {

    opacity: 1 !important;
}

a {

    color: var(--ciel);
}

:root {
    --bleu: #003c72;
    --bleu2: #0048a8;
    --ciel: #4cc5d8;
    --vert: #26bf64;
    --jaune: #ffe133;
    --rose: #e57fca;
    --violet: #994d92;
}

/*------------------------------------*\
    BORDER
\*------------------------------------*/

.border-top .elementor-container:before,
.border-bottom .elementor-container:after,
.elementor-post .elementor-post__thumbnail:after {

    content: '';
    position: absolute;
    left: 0;
    background: white;
    z-index: 3;
    pointer-events: none;
    width: 100%;
    height: 20px;
    mask: url(/wp-content/uploads/border-horizontal.svg) no-repeat;
    -webkit-mask: url(/wp-content/uploads/border-horizontal.svg) no-repeat;
    mask-size: cover;
    -webkit-mask-size: cover;
    mask-position: bottom center;
    -webkit-mask-position: bottom center;
}

.border-top .elementor-container:before {

    top: -1px;
    transform: rotate(180deg);

}

.border-bottom .elementor-container:after {

    bottom: -1px;
}

.elementor-post .elementor-post__thumbnail:after {

    bottom: -1px;
}

.elementor-posts-container .elementor-post:nth-child(even) .elementor-post__thumbnail:after {

    mask-position: 10% bottom;
    -webkit-mask-position: 10% bottom;
}

.border-right:after,
.border-left:after {

    content: '';
    position: absolute;
    background: white;
    pointer-events: none;
    width: 30px;
    height: 100%;
    mask: url(/wp-content/uploads/border-vertical.svg) no-repeat;
    -webkit-mask: url(/wp-content/uploads/border-vertical.svg) no-repeat;
    mask-size: cover;
    -webkit-mask-size: cover;
    mask-position: left center;
    -webkit-mask-position: left center;
}

.border-right:after {

    transform: rotate(180deg);
    right: -1px;
}

.border-left:after {

    left: -1px;
}

@media only screen and (max-width:850px) {

    .border-right:after,
    .border-left:after {

        left: auto;
        right: auto;
        bottom: 0;
        width: 100%;
        height: 20px;
        transform: none;
        mask: url(/wp-content/uploads/border-horizontal.svg) no-repeat;
        -webkit-mask: url(/wp-content/uploads/border-horizontal.svg) no-repeat;
        mask-size: cover;
        -webkit-mask-size: cover;
        mask-position: bottom center;
        -webkit-mask-position: bottom center;
    }


}

/*------------------------------------*\
    LOADER
\*------------------------------------*/

#loader,
#overlay {

    position: fixed;
    z-index: 9999;
    width: 100vw;
    height: 100vh;
    background-color: var(--bleu);
    display: flex;
    justify-content: center;
    align-items: center;
    transition: transform 1s, background-color .5s;
}

#loader {

    display: none;
}

.home #loader {

    display: flex;
}

#overlay {

    z-index: 9998;
}


#loader .border,
#overlay .border {

    position: absolute;
    left: 0;
    top: 100%;
    background-color: var(--bleu);
    pointer-events: none;
    width: 100%;
    height: 20px;
    mask: url(/wp-content/uploads/border-horizontal.svg) no-repeat;
    -webkit-mask: url(/wp-content/uploads/border-horizontal.svg) no-repeat;
    mask-size: cover;
    -webkit-mask-size: cover;
    mask-position: bottom center;
    -webkit-mask-position: bottom center;
    transform: rotate(180deg);
    transition: transform 1s, background-color .5s;
}

#loader #logo {

    height: 50vh;
    transform: scale(0);
    opacity: 0;
    animation: scale .75s forwards;
    animation-timing-function: cubic-bezier(0.645, 0.045, 0.355, 2);

}

@keyframes scale {
    to {
        transform: scale(1);
        opacity: 1;
    }
}

#loader #logo #line-bleu {

    stroke-dasharray: 350;
    stroke-dashoffset: 350;
    animation: line 2s forwards;
    animation-delay: .75s;
}

#loader #logo .line {

    stroke-dasharray: 120;
    stroke-dashoffset: 120;
    animation: line 1s forwards;
    animation-delay: 1.9s;
}

@keyframes line {
    to {
        stroke-dashoffset: 0;
    }
}

#loader #logo #maternelle-primaire {

    animation: rotate 1s forwards;
    animation-delay: 1.9s;
    transform: rotate(45deg);
    opacity: 0;
    transform-origin: center;
}

@keyframes rotate {
    to {
        transform: rotate(0deg);
        opacity: 1;
    }
}

#loader #logo .txt {

    transform-box: fill-box;
    animation: txt 1s forwards;
    transform: translateY(50%);
    opacity: 0;
    animation-delay: .75s;
}

#loader #logo #wimille,
#loader #logo #ecole {

    opacity: 0;
    animation: txt 1s forwards;
    animation-delay: .75s;
}

#loader #logo #wimille {

    animation-delay: 1.75s;
}

#loader #logo #sainte {

    transform: translateY(100%);
}

#loader #logo #jeanne {

    animation-delay: 1.25s;
}

#loader #logo #d-arc {

    animation-delay: 1.75s;
}

@keyframes txt {
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/*------------------------------------*\
    HEADER
\*------------------------------------*/

#header {

    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 999;
    padding: 0 100px;
    transition: all .3s;
}

#header:before {

    content: '';
    position: absolute;
    left: 0;
    top: 100%;
    background: transparent;
    pointer-events: none;
    width: 100%;
    height: 20px;
    mask: url(/wp-content/uploads/border-horizontal.svg) no-repeat;
    -webkit-mask: url(/wp-content/uploads/border-horizontal.svg) no-repeat;
    mask-size: cover;
    -webkit-mask-size: cover;
    mask-position: bottom center;
    -webkit-mask-position: bottom center;
    transform: rotate(180deg);
    transition: all .3s;
}

.active-header {

    background: white;
    filter: drop-shadow(0 0 10px rgba(4, 24, 38, 0.2));

}

.active-header:before {

    background: white !important;
}

#header .bloc {

    display: flex;
    justify-content: flex-end;
    align-items: center;
    position: relative;
}

#header .bloc #menu-btn {

    display: none;
}

#header .bloc a#logo {

    padding-top: 12.5px;
    position: absolute;
    left: 0;
    top: 0;
    filter: drop-shadow(0 0 10px rgba(4, 24, 38, 0.2));

}

#header .bloc a#logo svg {

    height: 125px;
}

#header li {

    list-style: none;
    display: inline-block;
}

#header #nav a {

    color: white;
    font-weight: 600;
    font-size: 1.1vw;
    display: inline-block;
    position: relative;
    transition: all .3s;
    cursor: pointer;
}

#header #nav .nav-bottom ul#menu-menu {

    display: flex;
    justify-content: flex-end;
}

#header #nav .nav-bottom a {

    line-height: 1.75em;
}

#header #nav .nav-top a:after,
#header #nav .nav-bottom a:before {
    content: '';
    transform-origin: 100% 50%;
    transform: scale3d(0, 1, 1);
    transition: transform .3s, background .3s;
    position: absolute;
    width: 100%;
    height: 2px;
    top: 100%;
    left: 0;
    pointer-events: none;
}

#header #nav .nav-top a:hover::after,
#header #nav .nav-bottom a:hover::before {

    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
}

#header #nav .nav-top ul li:nth-child(5n + 1) a:after,
#header #nav .nav-bottom ul li:nth-child(5n + 1) a:before,
#header #nav .nav-bottom ul li .sub-menu li:nth-child(5n + 1) a:before {

    background: var(--ciel);
}

#header #nav .nav-top ul li:nth-child(5n + 2) a:after,
#header #nav .nav-bottom ul li:nth-child(5n + 2) a:before,
#header #nav .nav-bottom ul li .sub-menu li:nth-child(5n + 2) a:before {

    background: var(--vert);
}

#header #nav .nav-top ul li:nth-child(5n + 3) a:after,
#header #nav .nav-bottom ul li:nth-child(5n + 3) a:before,
#header #nav .nav-bottom ul li .sub-menu li:nth-child(5n + 3) a:before {

    background: var(--jaune);
}

#header #nav .nav-top ul li:nth-child(5n + 4) a:after,
#header #nav .nav-bottom ul li:nth-child(5n + 4) a:before,
#header #nav .nav-bottom ul li .sub-menu li:nth-child(5n + 4) a:before {

    background: var(--rose);
}

#header #nav .nav-top ul li:nth-child(5n + 5) a:after,
#header #nav .nav-bottom ul li:nth-child(5n + 5) a:before,
#header #nav .nav-bottom ul li .sub-menu li:nth-child(5n + 5) a:before {

    background: var(--violet);
}

.active-link-nav-bottom {

    color: var(--bleu) !important;
}

#header li:not(:last-child) {

    margin-right: 50px;
}

#header #nav .nav-top {

    display: flex;
    justify-content: flex-end;
    border-bottom: solid 1px var(--ciel);
    transition: all .3s;
}

.active-nav-top {

    border-bottom: solid 1px #e5e5e5 !important;
}

#header #nav .nav-top ul {

    width: auto;
}

#header #nav .nav-top a {

    color: var(--ciel);
    font-weight: 500;
    font-size: .9vw;
    position: relative;
}

#header #nav .nav-top ul li:nth-child(5n + 1) a,
#header #nav .nav-top ul li:nth-child(5n + 1) a:hover {

    color: var(--ciel);
}

#header #nav .nav-top ul li:nth-child(5n + 2) a,
#header #nav .nav-top ul li:nth-child(5n + 2) a:hover {

    color: var(--vert);
}

#header #nav .nav-top ul li:nth-child(5n + 3) a,
#header #nav .nav-top ul li:nth-child(5n + 3) a:hover {

    color: var(--jaune);
}

#header #nav .nav-top ul li:nth-child(5n + 4) a,
#header #nav .nav-top ul li:nth-child(5n + 4) a:hover {

    color: var(--rose);
}

#header #nav .nav-top ul li:nth-child(5n + 5) a,
#header #nav .nav-top ul li:nth-child(5n + 5) a:hover {

    color: var(--violet);
}

#header #nav .nav-top a:before {
    font-family: 'Material Icons Outlined';
    font-weight: normal;
    font-size: 1.1vw;
    margin-right: 6.25px;
    display: inline-block;
    transform: translateY(3.5px);
}

#header #nav .nav-top a.blog:before {

    content: 'campaign';
}

#header #nav .nav-top a.actus:before {

    content: 'feed';
}

#header #nav .nav-top a.contact:before {

    content: 'mail';
}

#header #nav .nav-top a.situer:before {

    content: 'place';
}

#header #nav .nav-top a.tarifs:before {

    content: 'description';
}

#header .bloc #nav ul li.menu-item-has-children > a:after {

    font-family: 'Material Icons Outlined';
    content: 'expand_more';
    margin-left: 6.25px;
    display: inline-block;
    transform: translateY(4px);

}

/*
.active-link-nav-top {

    color: grey !important;
}
*/

#header #nav .nav-top ul li a {

    padding: 12.5px 0;
}

#header #nav .nav-bottom ul li:not(#header #nav .nav-bottom ul li .sub-menu li) {

    padding: 20px 0;
}

    {}

/*------------------------------------*\
    SUB-MENU
\*------------------------------------*/

#header #nav {

    position: relative;
}

#header #nav ul li .sub-menu {

    position: absolute;
    background: white;
    min-width: 100%;
    min-height: 20vw;
    border: 1px solid #e5e5e5;
    border-radius: 5px;
    left: 0;
    display: none;
    padding: 50px;
    padding-right: calc(50% + 50px);
}

#header #nav ul li .sub-menu:before {

    content: '';
    width: 100%;
    height: 25px;
    display: inline-block;
    position: absolute;
    transform: translateY(-100%);
    left: 0;
    top: 0;
}

@keyframes submenu {

    from {

        opacity: 0;
        top: calc(100% + 50px);
    }

    to {

        opacity: 1;
        top: calc(100% + 25px);
    }
}

#header #nav ul li:hover .sub-menu {

    display: inline-block;
    opacity: 1;
    animation: submenu .3s forwards;
    animation-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1);
    filter: drop-shadow(0 0 10px rgba(4, 24, 38, 0.2));
}

#header #nav ul li .sub-menu .bloc-img {

    width: 50%;
    height: 100%;
    background-color: var(--bleu);
    display: inline-block;
    position: absolute;
    right: 0;
    top: 0;

    background-image: url(/wp-content/uploads/ecole-ste-jeanne-d-arc-cours-enfants-scaled.jpg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    transition: background .3s;
    border-radius: 0 5px 5px 0;
    overflow: hidden;
}

#header #nav ul li:nth-child(2) .sub-menu .bloc-img {

    background-image: url(/wp-content/uploads/ecole-sainte-jeanne-d-arc-wimille-asticoweb-001.jpg);
}

#header #nav ul li:nth-child(3) .sub-menu .bloc-img {
    background-image: url(/wp-content/uploads/ecole-sainte-jeanne-d-arc-wimille-asticoweb-007.jpg);

}

#header #nav ul li:nth-child(4) .sub-menu .bloc-img {
    background-image: url(/wp-content/uploads/ecole-sainte-jeanne-d-arc-wimille-asticoweb-004);

}

#header #nav ul li .sub-menu .bloc-img:before {

    content: '';
    position: absolute;
    background: white;
    pointer-events: none;
    width: 30px;
    height: 100%;
    mask: url(/wp-content/uploads/border-vertical.svg) no-repeat;
    -webkit-mask: url(/wp-content/uploads/border-vertical.svg) no-repeat;
    mask-size: cover;
    -webkit-mask-size: cover;
    mask-position: left center;
    -webkit-mask-position: left center;
}


#header #nav ul li .sub-menu li {

    width: 100%;
}

#header #nav ul li .sub-menu li:not(:last-child) {

    margin-bottom: 12.5px;
}

#header #nav ul li .sub-menu li a {

    line-height: 1.75em;
    font-weight: 500;
    transition: all .3s;
    position: relative;
    display: inline-block;
    padding: 0;
    color: var(--bleu);
}


#header #nav ul li .sub-menu li a:hover,
#header #nav ul li .sub-menu li.current-menu-item a {

    font-weight: bold;
}

#header #nav ul li a img,
#header #nav ul li .sub-menu li a img {

    display: none !important;
}

/*------------------------------------*\
    FOOTER
\*------------------------------------*/

#footer {

    padding: 100px 200px 50px 200px;
    background: var(--bleu);
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    position: relative;
}

#footer:after {

    content: '';
    position: absolute;
    left: 0;
    bottom: 100%;
    background: var(--bleu);
    pointer-events: none;
    width: 100%;
    height: 20px;
    mask: url(/wp-content/uploads/border-horizontal.svg) no-repeat;
    -webkit-mask: url(/wp-content/uploads/border-horizontal.svg) no-repeat;
    mask-size: cover;
    -webkit-mask-size: cover;
    mask-position: bottom center;
    -webkit-mask-position: bottom center;
}

#footer img {

    width: 150px;
}

#footer li,
#footer a,
#footer p {

    font-size: .9vw;
    color: white;
    line-height: 1.75em;
}

#footer a {

    transition: all .3s;
    position: relative;
    display: inline-block;
}

#footer a:hover {

    opacity: 1 !important;
    color: var(--ciel) !important;
}

#footer a:after {
    content: '';
    transform-origin: 100% 50%;
    transform: scale3d(0, 1, 1);
    transition: transform .3s, background .3s;
    position: absolute;
    width: 100%;
    height: 1.5px;
    bottom: 0;
    left: 0;
    pointer-events: none;
    background: var(--ciel);
}

#footer a:hover::after {

    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
}

#footer h2 {

    font-size: 1.1vw;
    color: var(--ciel);
    font-family: 'Jeanne';
}

#footer ul li {

    list-style: none;
}

#footer ul li a img,
#footer ul li .sub-menu {

    display: none;
}

#footer .full {

    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 50px;
}

#footer .full a,
#footer .full p {

    opacity: .5;
}

#footer .full ul li {

    display: inline-block;
}

#footer .full ul li:first-child {

    margin-right: 25px;
}

/*------------------------------------------------------------------------*\
    RESPONSIVE
\*------------------------------------------------------------------------*/

@media only screen and (max-width:850px) {

    /*------------------------------------*\
    EXIT
\*------------------------------------*/

    #exit {

        position: fixed;
        left: 0;
        top: 0;
        width: 100vw;
        height: 100vh;
        background: rgba(0, 60, 114, .5);
        z-index: 998;
        cursor: pointer;
        display: none;
    }


    /*------------------------------------*\
    LOADER
\*------------------------------------*/

    #loader #logo {

        height: auto;
        width: 50vw;

    }

    /*------------------------------------*\
    HEADER
\*------------------------------------*/

    #header {

        padding: 0;

    }

    #header .bloc {
        min-height: 100px;
        padding: 0 50px;
    }

    #header .bloc a#logo {

        left: 50px;
    }

    #header .bloc #menu-btn {

        display: inline-block;
        font-family: 'Jeanne', sans-serif;
        font-size: 4vw;
        color: white;
        transition: all .3s;

        -webkit-touch-callout: none;
        -webkit-user-select: none;
        -khtml-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;

    }

    #header .bloc #menu-btn:before {

        content: 'Fermer';
        position: absolute;
        right: 0;
        bottom: 100%;
        color: transparent;
        transition: all .3s;
    }

    .active-menu-btn {

        color: var(--bleu) !important;
    }


    .close-menu-btn {

        transform: translateY(100%);
        color: transparent !important;
    }

    .close-menu-btn:before {

        color: var(--bleu) !important;
    }

    #header .bloc #nav {

        position: absolute;
        top: 100%;
        display: none;
        background: #e5e5e5;
        width: 100%;
        left: 0;
        z-index: -1;
        padding: 50px;
        height: calc(100vh - 100px);
        overflow-y: auto;
    }

    #header .bloc #nav:before {

        content: '';
        position: absolute;
        left: 0;
        top: 100%;
        background: #e5e5e5;
        pointer-events: none;
        width: 100%;
        height: 20px;
        mask: url(/wp-content/uploads/border-horizontal.svg) no-repeat;
        -webkit-mask: url(/wp-content/uploads/border-horizontal.svg) no-repeat;
        mask-size: cover;
        -webkit-mask-size: cover;
        mask-position: bottom center;
        -webkit-mask-position: bottom center;
        transform: rotate(180deg);
        transition: all .3s;
    }

    #header #nav .nav-top a {
        font-size: 2vw;
    }

    #header #nav a {

        font-size: 2.5vw;
    }

    #header #nav a,
    .active-link-nav-bottom {

        color: var(--bleu);
    }

    #header li:not(:last-child) {

        margin: 0 12.5px;
    }

    #header .nav-bottom li:not(:last-child) {

        margin: 0;
    }

    #header #nav .nav-top a:before {

        font-size: 2vw;
    }

    #header #nav .nav-top,
    .active-nav-top {

        border-bottom: solid 1px #cccccc !important;
    }

    #header #nav .nav-top ul {

        margin: 0 auto;
        display: flex;
        justify-content: center;
        align-items: center;
        flex-wrap: wrap;
    }

    #header #nav .nav-bottom {

        padding-top: 50px;
    }

    #header #nav .nav-bottom ul#menu-menu {

        flex-wrap: wrap;
    }

    #header #nav .nav-bottom ul > li {

        width: 50%;
        margin-bottom: 37.5px;
        text-align: center;

    }

    #header #nav .nav-bottom ul li a {

        padding: 0;
        margin-bottom: 12.5px;
    }

    #header #nav ul li .sub-menu li:not(:last-child) {

        margin: 0;
    }

    #header #nav ul li .sub-menu {
        position: static;
        background: transparent;
        min-width: auto;
        min-height: auto;
        border: none;
        border-radius: 0;
        display: inline-block;
        padding: 0;
        padding-right: 0;
    }

    #header #nav ul li .sub-menu .bloc-img,
    #header #nav ul li .sub-menu:before,
    #header .bloc #nav ul li.menu-item-has-children > a:after {

        display: none;
    }

    #header #nav ul li:hover .sub-menu {

        animation: none;
    }

    /*------------------------------------*\
    FOOTER
\*------------------------------------*/

    #footer {

        padding: 100px 50px 50px 50px;
    }

    #footer .content:first-child {

        display: none;
    }

    #footer li,
    #footer a,
    #footer p {

        font-size: 1.5vw;
    }

    #footer h2 {

        font-size: 2vw;
    }

}

@media only screen and (max-width:650px) {

    /*------------------------------------*\
    HEADER
\*------------------------------------*/

    #header .bloc {

        padding: 0 25px;
    }

    #header .bloc a#logo {

        left: 25px;
    }

    #header .bloc #menu-btn {

        font-size: 6vw;
    }

    #header .bloc #nav {

        padding: 50px 25px;
    }


    #header #nav .nav-top a {
        font-size: 3.5vw;
    }

    #header #nav a {

        font-size: 4vw;
    }

    #header #nav .nav-top a:before {

        font-size: 5vw;
    }


    #header #nav .nav-bottom ul > li {

        width: 100%;

    }

    /*------------------------------------*\
    FOOTER
\*------------------------------------*/

    #footer {

        padding: 50px 25px 25px 25px;
    }

    #footer .content {

        width: 100%;
        text-align: center;
    }

    #footer .content:first-child {

        display: inline-block;
    }

    #footer .content:not(:last-child) {

        margin-bottom: 50px;
    }


    #footer li,
    #footer a,
    #footer p {

        font-size: 3vw;
    }


    #footer h2 {

        font-size: 4vw;
    }


    #footer .full {

        margin-top: 25px;
    }

    #footer .full a,
    #footer .full p {

        font-size: 3vw;
    }

    #footer .full {

        flex-wrap: wrap;
        justify-content: center;
    }

    #footer .full ul li:first-child {

        margin-right: 12.5px;
    }

}
