/*!
Theme Name: WebLine
Theme URI: https://webline-solutions.fr/
Author: WebLine
Author URI: http://webline-solutions.fr/
Description: Description
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: webline
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/


/* Variable CSS */

:root {
    /* Font Color */
    --first-color: #0040E4;
    --second-color: #FFD600;
    --third-color: #6F4FE5;
    --fourth-color: #DFC8FE;
    --fifth-color: #000000;
    --sixth-color: #ffffff;
    --seventh-color: #332E2E;

    /* Font Size */
    --text-size-big: clamp(30px, 4.9vw, 120px);
    --text-size-xl: clamp(36px, 4.6vw, 67px);
    --text-size-l: clamp(30px, 3.9vw, 56px);
    --text-size-m: clamp(22px, 3.3vw, 47px);
    --text-size-xm: clamp(19px, 1.9vw, 42px);
    --text-size-s: clamp(18px, 1.1vw, 33px);
    --text-size-xs: clamp(15px, 0.9vw, 17px);
    --text-size-special: clamp(22px, 1.4vw, 33px);

    /* Line height */
    --line-height-xl: clamp(48px, 4.6vw, 64px);
    --line-height-l: clamp(38.4px, 4vw, 56px);
    --line-height-m: clamp(22px, 2.5vw, 47px);
    --line-height-xm: clamp(19px, 1.9vw, 42px);
    --line-height-s: clamp(18px, 1.1vw, 33px);
    --line-height-xs: clamp(20px, 1.6vw, 30px);
    --line-height-special: clamp(22px, 1.4vw, 33px);

    /* Padding Size */
    --pad-xl-s: clamp(50px, 13.1vw, 300px);
    --pad-xl: clamp(30px, 6.5vw, 150px) var(--pad-xl-s);
    --pad-l: clamp(30px, 5vw, 150px);
    --pad-m: clamp(20px, 3vw, 80px);
    --pad-s: clamp(15px, 2vw, 50px);
    --pad-xs: clamp(13px, 1vw, 40px);
    --pad-mobile: 20px;

    /* CTA Padding */
    --cta-pad: clamp(10px, 0.8vw, 30px) clamp(20px, 1.6vw, 50px);
    --cta-pad-rev: clamp(15px, 1vw, 50px) clamp(10px, .5vw, 30px);

    /* Gap Size */
    --gap-xxl: clamp(25px, 10.5vw, 200px);
    --gap-xl: clamp(20px, 4.7vw, 90px);
    --gap-l: clamp(18px, 5vw, 32px);
    --gap-m: clamp(15px, 2vw, 30px);
    --gap-s: clamp(12px, 1.2vw, 24px);
    --gap-xs: clamp(12px, 0.8vw, 24px);
    scroll-behavior: smooth;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font: var(--text-size-xs) 'Montserrat-Regular';
    line-height: var(--line-height-xs);
}

ul {
    padding-left: 40px;
}

.cmplz-cookiebanner {
    background-image: url(../../uploads/2024/09/pappers-background-1-66e824610c968.webp);
    background-size: contain;
}

.banniere_home_a p, 
.offres_a p, 
.equipe_a p, 
.encart_cta_a p
/* .banniere_home_a span, 
.offres_a span, 
.equipe_a span, 
.encart_cta_a span */ { 
    font-size: var(--text-size-xs);
}

.page-b *:not(strong, span, a, h1, h2, h3, h4, h5, h6) {
    color: #2B2E37;
    font: 14px/1.6 "Montserrat-Medium";
}

.page-b #masthead {
    padding: 10px;
}

.page-b #masthead nav {
    display: flex;
    justify-content: space-around;
}

.page-b #masthead .logo img {
    object-fit: contain;
    aspect-ratio: 1;
}

.page-b #masthead .custom-logo-link {
    display: flex;
    text-decoration: none;
    align-items: center;
}

.page-b #masthead .custom-logo-link:after {
    content: 'Webline';
    color: #2B2E37;
}

.page-b #masthead .cta_ab {
    display: none;
}

.page-b h2 {
    font-family: 'Montserrat-SemiBold';
}

.page-b .encadre {
    border-radius: 4px;
    padding: 3px 6px;
    font-family: 'TitanOne';
}

body {
    max-width: 100vw;
    overflow-x: hidden;
}

/* Class CSS Title and Text */
/* Big Title Bold */
.t1 {
    font-size: var(--text-size-big);
    font-family: 'Montserrat-Bold';
    color: var(--first-color);
}

.t1_1 {
    font-size: var(--text-size-big);
    font-family: 'Montserrat-Bold';
    color: var(--second-color);
}

/* Medium Title Light (Blue and White) */
.t2 {
    font-family: 'Montserrat-Light';
    color: var(--first-color);
    font-size: var(--text-size-m);
    letter-spacing: 0.3vw;
}

.t3 {
    font-family: 'Montserrat-Light';
    color: var(--second-color);
    font-size: var(--text-size-m);
    letter-spacing: 0.3vw;
}

/* Small Title Bold (Blue and White) */
.t4 {
    font-size: var(--text-size-s);
    font-family: 'Montserrat-SemiBold';
    color: var(--first-color);
    letter-spacing: clamp(2px, .1vw, 10px);
}

.t5 {
    font-size: var(--text-size-s);
    font-family: 'Montserrat-SemiBold';
    color: var(--second-color);
}

/* CSS général version _b */
main>section.center,
main>section>div.center {
    max-width: calc(1265px + 40px * 2);
    margin: 0 auto;
}

.encart_cta_a .center,
.center.equipe_a {
    max-width: calc(1265px + 40px * 2);
    margin: 0 auto;
}

.page-b .cta_b {
    width: max-content;
    border-radius: 9px;
    display: inline-flex;
}

.page-b .cta_b :where(a, p) {
    border-radius: 6px;
    padding-left: 10px;
    gap: var(--gap-l);
}

.cta_b {
    width: max-content;
    max-width: 100%;
    padding: 10px;
    border-radius: 100000px;
    background: var(--first-color);
}

.cta_b :where(a, p) {
    position: relative;
    z-index: 1;
    transition: color .3s;
    padding-left: 19px;
    color: var(--sixth-color);
    text-decoration: none;
    border-radius: 100000px;
    overflow: hidden;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--gap-m);
}

.cta_b a:hover {
    color: var(--first-color);
}

.cta_b :where(a, p):before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
    transition: width .3s;
    height: 100%;
    width: 29px;
    padding: 0px 11px;
    background-color: var(--sixth-color);
}

.cta_b :where(a, p):hover:before {
    -webkit-animation: initial;
    animation: initial;
    width: 100%;
}

:where(.page-b .cta_b.show:not(:hover), .banner_b .cta_b:not(:hover)) a:before {
    -webkit-animation: widthAnimation 2.4s infinite forwards;
    animation: widthAnimation 2.4s infinite forwards;
}

/* Breadcrumbs */
.container-bcrumbs {
    padding: 15px 0;
}

.container-bcrumbs .bcrumbs {
    max-width: calc(1100px - 30px * 2);
    margin: 0 auto;
    padding: 0 30px;
}

.container-bcrumbs .bcrumbs * {
    color: #2B2E37;
    font: 14px/1.6 "Montserrat-Medium";
}

.container-bcrumbs .separator {
    position: relative;
    height: 11px;
    width: 17px;
    margin: 0 4px;
    display: inline-block;
}

.container-bcrumbs .separator:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url('../../uploads/2024/11/Arrow-4.svg');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    display: block;
}

.bcrumbs span:not(.encadre, .home) {
    font-family: Montserrat-SemiBold
}

.bcrumbs .home span {
    font-family: Montserrat-ExtraBold
}

.bcrumbs .home span.current-item {
    font-family: Montserrat-Regular;
}

.bcrumbs span.encadre {
    color: var(--first-color);
    background-color: rgb(0, 64, 228, .2)
}

.bcrumbs a {
    text-decoration: none;
}

@-webkit-keyframes widthAnimation {
    0%,
    50% {
        width: 29px;
    }

    7.5% {
        width: 41.175px;
    }

    15% {
        width: 40.0875px;
    }

    22.5% {
        width: 37.9625px;
    }

    30% {
        width: 39.3625px;
    }

    37.5% {
        width: 38.565px;
    }
}

@keyframes widthAnimation {
    0%,
    33% {
        width: 29px;
    }

    5% {
        width: 41.175px;
    }

    10% {
        width: 40.0875px;
    }

    15% {
        width: 37.9625px;
    }

    20% {
        width: 39.3625px;
    }

    25% {
        width: 38.565px;
    }
}

:where(.page-b .cta_b.show:not(:hover), .banner_b .cta_b:not(:hover)) img {
    -webkit-animation: wobble-ver-img 2.4s infinite forwards;
    animation: wobble-ver-img 2.4s infinite forwards;
}

@-webkit-keyframes wobble-ver-img {
    0%,
    50% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
        -webkit-transform-origin: 50% 50%;
        transform-origin: 50% 50%;
    }
    7.5% {
        -webkit-transform: translateY(-7.5px) rotate(-1.5deg);
        transform: translateY(-7.5px) rotate(-1.5deg);
    }
    15% {
        -webkit-transform: translateY(3.75px) rotate(1.5deg);
        transform: translateY(3.75px) rotate(1.5deg);
    }
    22.5% {
        -webkit-transform: translateY(-3.75px) rotate(-0.9deg);
        transform: translateY(-3.75px) rotate(-0.9deg);
    }
    30% {
        -webkit-transform: translateY(2.25px) rotate(0.6deg);
        transform: translateY(2.25px) rotate(0.6deg);
    }
    37.5% {
        -webkit-transform: translateY(-1.5px) rotate(-0.3deg);
        transform: translateY(-1.5px) rotate(-0.3deg);
    }
}

@keyframes wobble-ver-img {
    0%,
    50% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
        -webkit-transform-origin: 50% 50%;
        transform-origin: 50% 50%;
    }
    7.5% {
        -webkit-transform: translateY(-7.5px) rotate(-1.5deg);
        transform: translateY(-7.5px) rotate(-1.5deg);
    }
    15% {
        -webkit-transform: translateY(3.75px) rotate(1.5deg);
        transform: translateY(3.75px) rotate(1.5deg);
    }
    22.5% {
        -webkit-transform: translateY(-3.75px) rotate(-0.9deg);
        transform: translateY(-3.75px) rotate(-0.9deg);
    }
    30% {
        -webkit-transform: translateY(2.25px) rotate(0.6deg);
        transform: translateY(2.25px) rotate(0.6deg);
    }
    37.5% {
        -webkit-transform: translateY(-1.5px) rotate(-0.3deg);
        transform: translateY(-1.5px) rotate(-0.3deg);
    }
}

.cta_b a img {
    transition: transform .2s;
    margin-right: 11px;
}

.cta_b a:hover img {
    -webkit-animation: initial;
    animation: initial;
    transform: rotate(-45deg);
}

.cta_a {
    position: relative;
    display: inline-block;
}

.cta_button {
    position: relative;
    background-color: var(--second-color);
    color: var(--fifth-color);
    padding: 20px 60px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    z-index: 2;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
    border-radius: 15px;
    border: solid 2px;
    font-family: 'Gluten-Regular';
    font-size: var(--text-size-s);
    transition: background-color 0.2s ease, color 0.2s ease, transform 0.4s ease;
}

.cta_a:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--sixth-color);
    z-index: 1;
    transform: translate(10px, 10px);
    border-radius: 15px;
    border: solid 2px;
    transition: background-color 0.2s ease, color 0.2s ease, transform 0.4s ease;
}

.cta_a:hover .cta_button {
    background-color: var(--fifth-color);
    color: var(--sixth-color);
    transform: scale(1.08);
}

.cta_a:hover:before {
    transform: translate(0, -2px);
}

.cta_ab {
    position: relative;
    display: inline-block;
}

.cta_button_ab {
    position: relative;
    background-color: var(--first-color);
    color: var(--sixth-color);
    padding: 10px 30px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    z-index: 2;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
    border-radius: 1000px;
    border: solid 2px;
    font-family: 'Gluten-Regular';
    font-size: var(--text-size-s);
    transition: background-color 0.2s ease, color 0.2s ease, transform 0.4s ease;
}

.cta_ab:before {
    content: "";
    position: absolute;
    top: 4px;
    left: 15px;
    width: 93%;
    height: 80%;
    background-color: var(--sixth-color);
    z-index: 1;
    transform: translate(10px, 10px);
    border-radius: 1000px;
    border: solid 2px;
    transition: background-color 0.2s ease, color 0.2s ease, transform 0.4s ease;
}

.cta_ab:hover .cta_button_ab {
    background-color: var(--fifth-color);
    color: var(--sixth-color);
    transform: scale(1.08);
}

.cta_ab:hover:before {
    transform: translate(0, -2px);
}

/* Fin CSS général version _b */

/* Provisoire pour le menu permet de mettre en row */
ul.nav-menu {
    display: flex;
    gap: 1.6vw;
}

.menu-toggle {
    display: none;
}

.page-a #masthead {
    background-image: url(../../uploads/2024/09/pappers-background-1-66e824610c968.webp);
}

.page-a .simple-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: calc(1265px + 40px * 2);
    margin: 0 auto;
    padding: 20px 40px;
}

.page-a .custom-logo {
    max-width: 70px;
    height: max-content;
}

@media (max-width:768px) {
    .page-a .custom-logo {
        max-width: 40px;
    }
    .page-a #masthead {
        background-position: center;
        background-size: contain;
    }
    .cta_button {
        font-size: var(--text-size-xs);
    }
}

/* Bouton lire plus */

.read-more {
    position: relative;
    max-height: 140px;
    overflow: hidden;
}

.activ_read_more .read-more {
    max-height: 100%;
}

.much_long .read-more:after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
    transition: opacity .3s;
    height: clamp(20px, 15%, 50px);
    width: 100%;
    opacity: 1;
    visibility: visible;
    background: linear-gradient(0deg, #ffffff, transparent);
}

.page-a .much_long .read-more:after {
    display: none;
}

.activ_read_more .read-more:after {
    opacity: 0;
    visibility: hidden;
}

:not(.activ_read_more) .btn-read-more {
    display: none;
}

.btn-read-more {
    all: unset;
    margin-top: 10px;
    color: var(--first-color);
    letter-spacing: 0.4px;
    cursor: pointer;
}

.page-a .btn-read-more {
    all: unset;
    margin-top: 10px;
    color: var(--fifth-color);
    letter-spacing: 0.4px;
    cursor: pointer;
    background-color: var(--sixth-color);
    border-radius: 20px;
    padding: 5px 10px;
    width: max-content;
}


/* FIN Bouton lire plus */

/* Footer part */
.footer {
    overflow: hidden;
    background-color: var(--seventh-color);
}

.page-a .footer {
    background-image: url(../../uploads/2024/09/pappers-background-1-66e824610c968.webp);
    background-size: contain;
}

.page-a .footer :where(a, p, li, .wpcf7-response-output) {
    color: var(--fifth-color);
}

.footer * {
    font: var(--text-size-xs) 'Montserrat-Light';
}

.footer li {
    list-style-type: none;
}

.footer a {
    text-decoration: none;
}

.footer :where(a, p, li, .wpcf7-response-output) {
    color: var(--sixth-color);
}

.footer .content {
    position: relative;
    width: 100%;
}

.footer.show .content .logo {
    transform: rotate(30deg);
}

.footer .content .logo {
    position: absolute;
    top: -50px;
    transform: rotate(0deg);
    transform-origin: bottom;
    transition: transform .3s;
    min-height: 130px;
    width: 75px;
    background-color: var(--second-color);
    display: flex;
    justify-content: center;
    align-items: flex-end;
}

.footer .logo img {
    transform: rotate(-30deg);
    height: 64px;
    width: 58px;
    padding: 5px;
}

.footer .content nav {
    padding: var(--pad-xs);
}

.shortcode {
    position: relative;
}

.footer .shortcode {
    width: 100%;
}

.footer .shortcode form {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-xs);
}

.shortcode .wpcf7-form-control-wrap {
    position: static;
}

.shortcode .wpcf7-not-valid-tip {
    position: absolute;
    top: 110%;
}

.shortcode .wpcf7 form .wpcf7-response-output {
    position: fixed;
    top: 0;
    left: 50%;
    z-index: 10;
    transform: translateX(-50%);
    max-width: 90%;
    margin: 1em 0.5em 1em;
    padding: 1.2em 1em;
    color: var(--seventh-color);
    font-family: 'Montserrat-Regular';
    border-radius: 6px;
    background: var(--sixth-color);
    opacity: 0;
}

.shortcode .wpcf7 form:not(.init) .wpcf7-response-output {
    animation: pop 5s;
}

@keyframes pop {
    10% {
        opacity: 1;
    }

    90% {
        opacity: 1;
    }
}

.footer .shortcode .email_line * {
    width: 100%;
    display: flex;
}

.footer .shortcode input {
    /* all: unset; */
    border: 0;
    padding: var(--cta-pad);
    background: var(--sixth-color);
}

.footer input::placeholder {
    color: hsla(0, 5%, 19%, 0.52);
}

.footer input:-moz-placeholder {
    color: hsla(0, 5%, 19%, 0.52);
}

.footer input:-ms-input-placeholder {
    color: hsla(0, 5%, 19%, 0.52);
}

.footer .shortcode input[type="submit"] {
    cursor: pointer;
    color: var(--seventh-color);
    font-family: 'Montserrat-Regular';
    background-color: var(--second-color);
}

.footer .container {
    position: relative;
}

.footer .container .social {
    padding: var(--pad-xs);
}

.footer .social img {
    height: 78px;
    width: 78px;
    border: 4px solid white;
    border-radius: 50%;
    transition: transform 0.3s ease;
}

.footer .social img:hover {
    transform: scale(1.1);
}

.footer .container .bars {
    position: absolute;
    bottom: 5px;
    transform-origin: bottom;
    height: 300px;
    display: flex;
    gap: 20px;
    align-items: flex-end;
}

.footer .container .bars div {
    height: 0%;
    width: 75px;
    transition: height .3s;
    background-color: var(--second-color);
}

.footer .container.show .bars div {
    height: 100%;
}

.footer .container.show .bars div.center {
    height: 70%;
}

.footer .container.show .bars div.right {
    height: 86%;
}

.footer .bottom_part {
    text-align: center;
    padding: var(--cta-pad);
}

.footer .bottom_part p {
    color: white;
}

.page-a .footer .bottom_part p {
    color: var(--fifth-color);
}

/* END Footer part */

/* responsive */
@media (max-width: 768px) {
    .page-b #masthead .custom-logo-link:after {
        font: 27px/100% 'TitanOne';
    }

    .page-b #masthead .logo img {
        height: 40px;
        width: 40px;
    }

    .page-b h2 {
        margin-bottom: 30px;
    }

    .page-b :where(h2, h2 *) {
        font-size: 24px;
        line-height: 34px;
    }

    .page-b h2 strong {
        font: 24px / 34px 'Montserrat-Bold';
    }

    .page-b .cta_b :where(a, p) {
        font: 22px/30px 'Montserrat-Medium';
    }

    .cta_b :where(a, p) {
        font: 30px/37px 'Montserrat-Medium';
    }

    main>section.center,
    main>section>div.center {
        padding: 60px 20px;
    }

    .encart_cta_a .center,
    .center.equipe_a,
    .testimonials_a.center  {
        padding: 60px 20px;
    }

    .footer * {
        font: 22px/29px 'Montserrat-Medium';
    }

    .footer .content {
        padding-top: 110px;
    }

    .footer .shortcode {
        margin-top: 10px;
    }

    .footer .shortcode form {
        padding: var(--pad-xs);
    }

    .footer form>:where(.email_line, p) {
        width: 100%;
    }

    .footer .shortcode input[type="submit"] {
        width: 100%;
    }

    .footer .social img {
        height: 68px;
        width: 68px;
    }

    .footer .container {
        padding-bottom: 190px;
    }

    .footer .container .bars {
        left: 50%;
        transform: rotate(30deg) translate(-50%, 85%);
    }

    .footer .bottom_part {
        position: relative;
        z-index: 100;
        background: var(--seventh-color);
    }
}

@media (min-width: 768px) {
    .page-b #masthead .custom-logo-link:after {
        font: 37px/100% 'TitanOne';
    }

    .page-b #masthead .logo img {
        height: 50px;
        width: 50px;
    }

    .page-b h2.max {
        max-width: 60%;
        min-width: 580px;
    }

    .page-b h2 {
        margin-bottom: 50px;
    }

    .page-b :where(h2, h2 *) {
        font-size: 44px;
        line-height: 54px;
    }

    .page-b h2 strong {
        font: 44px / 54px 'Montserrat-Bold';
    }

    .cta_b :where(a, p) {
        font: 28px/35px 'Montserrat-Medium';
    }

    main>section.center,
    main>section>div.center {
        padding: 60px 40px;
    }

    .footer .up_part {
        display: flex;
        justify-content: space-between;
    }

    .footer .content {
        max-width: 50%;
        padding-top: 150px;
    }

    .footer .shortcode {
        margin-top: 50px;
    }

    .footer .shortcode .email_line {
        width: 70%;
    }

    .footer .container {
        width: 50%;
        padding-bottom: 150px;
    }

    .footer .container .social {
        display: flex;
        flex-direction: column;
        align-items: flex-end;
    }

    .footer .container .bars {
        right: 0;
        transform: rotate(30deg) translateY(75%);
    }
}