:root { 
    --background-color: #160024; /* Background color for the entire website, including individual sections */
    --default-color: #4d4643; /* Default color used for the majority of the text content across the entire website */
    --heading-color: #2b2320; /* Color for headings, subheadings and title throughout the website */
    --accent-color: #7925c1; /* Accent color that represents your brand on the website. It's used for buttons, links, and other elements that need to stand out */
    --surface-color: #ffffff; /* The surface color is used as a background of boxed elements within sections, such as cards, icon boxes, or other elements that require a visual separation from the global background. */
    --contrast-color: #ffffff; /* Contrast color for text, ensuring readability against backgrounds of accent, heading, or default colors. */
}

/* Nav Menu Colors - The following color variables are used specifically for the navigation menu. They are separate from the global colors to allow for more customization options */
:root {
    --nav-color: #dfa3ff;  /* The default color of the main navmenu links */
    --nav-hover-color: #f849ff; /* Applied to main navmenu links when they are hovered over or active */
    --nav-mobile-background-color: #ffffff; /* Used as the background color for mobile navigation menu */
    --nav-dropdown-background-color: #ffffff; /* Used as the background color for dropdown items that appear when hovering over primary navigation items */
    --nav-dropdown-color: #212529; /* Used for navigation links of the dropdown items in the navigation menu. */
    --nav-dropdown-hover-color: #f03c02; /* Similar to --nav-hover-color, this color is applied to dropdown navigation links when they are hovered over. */
}

@media (min-width: 1200px) {
    .navmenu .dropdown ul a:hover, .navmenu .dropdown ul .active:hover, .navmenu .dropdown ul li:hover > a {
        color: #f8eaff; 
        background-color: rgba(255, 32, 186, 0.7);
        border-radius: 5px;
        text-shadow: 2px 1px 3px rgba(93, 0, 162, 0.4);    
    }
}

@media (max-width: 1199px) {
    .navmenu a, .navmenu a:focus {
        padding: 5px 5px;
        font-size: 16px;
    }
}
@media (max-width: 1199px) {
    .navmenu a:hover, .navmenu .active, .navmenu .active:focus {
        color: rgb(129, 0, 168);
    }
}

@media (max-width: 1199px) {
    .navmenu a i {
        background-color: rgb(143, 40, 198);
    }
    .navmenu a i {
        color: #ffc1fd;
    }
}

.main {
    background-color: #ffffff;
}

.header .branding {
    min-height: 125px;
    padding: 10px 0;
    /*background-color:#2a0040;
    border-bottom: 2px solid #ffdff8;*/

    background-image: url("../../design/header_2025_bg.png");
    background-repeat: no-repeat;
    background-position: left top;

    box-shadow: 0px 10px 8px 0px rgba(255,104,254,0.2);  /* offset-x | offset-y | blur-radius | spread-radius | color */
}

@media (max-width: 575px) {
    .header .branding {
        min-height: 80px;
        padding: 10px 0;

        background-image: url("../../design/header_mini_2025_bg.png");


    }
}


::selection {
    background: #300071;
    color: #f28aff;
    text-shadow: none;
}


/* Drapeaux */
/* -------- */
.drapeau {
    margin-right: 10px;
}

.header .logo {
    height: 100px;
    width:440px;
    position: relative;
    left: -120px;
}
@media (max-width: 575px) {
    .header .logo {
        height: 60px;
        width:260px;
        position: relative;
        left: -5px;
    }
}


.badge_18 i {
    font-size: 16px;
    padding-left: 20px;
    opacity: 0.7;
}

.header .topbar .social-links a img {
    height: 25px;
    opacity: 0.85;
    transition: 0.5s;
}
.header .topbar .social-links a {
    margin-left: 0px;
}
.header .topbar .social-links a img:hover {
    opacity: 1;
    transform: rotate(-10deg);
}

.header .topbar .contact-info i span {
    padding-left: 5px;
    color: var(--default-color);
    font-size: 14px;
}


@media (max-width: 575px) {
    .header .topbar .social-links a img {
        height: 20px;
    }
    .header .topbar {
        height: 20px;
    }
    .badge_18 i {
        padding: 0 0 0 5px;
    }
}

/* ------------------- HERO --------------- */
.hero {
    background-color: #e19df9;
}

.hero h2 {
    font-size: 36px;
    font-family: Times, "Times New Roman", "serif";
    font-weight: 700;
    color: #77008d;
    text-shadow: 0px 0px 8px rgba(253, 203, 255, 0.89);    
}

.hero .btn-get-started {
    font-weight: 500;
    font-size: 16px;
    letter-spacing: 1px;
    display: inline-block;
    padding: 8px 32px;
    transition: 0.5s;
    margin: 10px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.75);
    color:rgb(255, 255, 255);
    /*background-color:rgb(129, 0, 168);*/
    background: linear-gradient(45deg,rgba(161, 0, 190, 0.7) 50%,rgba(115, 0, 150, 0.7) 90%); 
    text-shadow: 0px 0px 8px rgba(255, 255, 190, 0.54);    
    box-shadow: 0px 0 4px rgba(255, 255, 255, 0.7), 0px 0 15px rgba(255, 68, 183, 0.8);    
}

.hero .btn-get-started:hover {
    color:rgb(129, 0, 168);
    background-color:rgb(255, 172, 226);
    text-shadow: 0px 0px 8px rgba(255, 255, 6, 0.62);    
    box-shadow: 0px 0 8px rgba(255, 255, 255, 0.7), 0px 0 15px rgba(255, 255, 255, 0.5);    
}


/* ------------------- #HERO --------------- */



@media (max-width: 575px) {
    .hero h2 {
        font-size: 28px;
    }
    .hero .btn-get-started {
        padding: 3px 5px;
    }
}

.hero .carousel-item::before {
    /* background: color-mix(in srgb, var(--background-color), transparent 80%); */
    background: linear-gradient(to right, rgba(177, 0, 255, 0.15) 5%,rgba(255, 177, 0, 0.1) 50%,rgba(158, 0, 178, 0.30) 95%);
}


.hero .container {
    background: rgba(237, 161, 255, 0.68);
    background: linear-gradient(to right, rgba(177, 0, 255, 0.4) 20%,rgba(237, 161, 255, 0.7) 50%,rgba(177, 0, 255, 0.45) 80%);

    border-top: 1px solid rgba(221, 79, 255, 0.2);
    border-right: 1px solid rgba(152, 0, 146, 0.1);
    border-bottom: 2px solid rgba(36, 0, 44, 0.1);
    border-left: 1px solid rgba(247, 216, 255, 0.1);
    border-radius: 20px;
}


.fond_add_shadow { 
    box-shadow: inset 0px 15px 10px -10px rgba(121, 37, 193, 0.4);  /* offset-x | offset-y | blur-radius | spread-radius | color */    /*margin-top: 25px;*/
}


section, .section {
    /*padding: 20px 0;*/
}

.section-title {
    padding-bottom: 20px;
    border-radius: 15px;
}

.section-title p {
    margin-bottom: 10px;
}




/* HHHHHHHHHHHHHHHHHHHHHHHHHH    H1   HHHHHHHHHHHHHHHHHHHHHHHHHH */

h1 {
    font-family: Times, "Times New Roman", "serif";
    font-size: 45px;
    text-align: center;
    /*font-weight: bold;*/
    color: rgb(76, 33, 83);
    text-shadow: 1px 1px 9px rgb(233, 161, 255);
}

@media (max-width: 575px) {
    h1 {
        font-size: 30px;
    }
}
/* HHHHHHHHHHHHHHHHHHHHHHHHHH    H2   HHHHHHHHHHHHHHHHHHHHHHHHHH */

h2 {
    font-family: Times, "Times New Roman", "serif";
    font-style: italic;
    font-size: 32px;
    border-radius: 5px;
    font-weight: 700;
    position: relative;
}

@media (max-width: 575px) {
    h2:before, h2:after, .fond_degrade h2:before, .fond_degrade h2:after, .fond_sombre h2:before, .fond_sombre h2:after, .fond_clair h2:before, .fond_clair h2:after {
        content: "";
        width: 0px;
        height: 0px;
    }
}


h2:before,
h2:after {
    content: "";
    width: 0px;
    height: 0px;
}

h2:before {
    margin: 0 15px 10px 0;
}

h2:after {
    margin: 0 0 10px 15px;
}

@media (max-width: 575px) {
    h2 {
        font-size: 27px;
    }
}

h2.geant {
    font-size: 73px;
    margin: 20px 30px 50px 30px;
    letter-spacing: -.15rem;
}

@media (max-width: 575px) {
    h2.geant {
        font-size: 40px;
        margin: 0px 20px 40px 20px;
    }
}
/* HHHHHHHHHHHHHHHHHHHHHHHHHH    h3   HHHHHHHHHHHHHHHHHHHHHHHHHH */

h3 {
    color: #4c2a5c;
    font-family: Times, "Times New Roman", "serif";
    font-size: 25px;
    font-weight: 700;
    display: inline-block;
    padding: 3px 10px;
    margin: 15px 0px 20px 0px;
}


@media (max-width: 575px) {
    h3 {
        font-size: 30px;
    }
}


.txt_surlignage {
    background-color: #ffe8fc;
    transform: rotate(-1deg);
    font-weight: bold;
    border-radius: 8px;
    padding: 10px 20px;
    border: 1px solid rgba(196, 0, 255, 0.29);
}
.fond_clair .txt_surlignage {
    background: linear-gradient(to right, rgba(255, 0, 245, 0.22) 5%,rgb(235, 90, 255) 50%,rgb(149, 73, 237) 95%);
    color: #401d48;
    text-shadow: 1px 1px 4px rgba(243, 104, 255, 0.88);
}
.fond_sombre .txt_surlignage {
    background: linear-gradient(to right, rgba(255, 0, 245, 0.22) 5%,rgba(114, 0, 129, 0.59) 50%,rgba(92, 0, 199, 0.24) 95%);
    color: rgb(255, 255, 255);
    text-shadow: 1px 1px 3px rgb(235, 0, 255);
    font-weight:300;
}
.fond_sombre .txt_surlignage i {
    text-shadow: none;
}




.text-center {
    text-align: center;
}

/* GGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGG */


.offset_ancre
{ 
    scroll-margin-top: 200px;
}


i {
    font-size: 1.25rem;
    margin-right: 0.5rem;
    line-height: 1.2;
    color: var(--accent-color);
}

.img-fluid {
    border-radius: 40px 4px 12px 4px;
}

.simple_border_radius {
    border-radius: 6px;
}
.sans_border_radius {
    border-radius: 0px;
}


img.float_left {
    float: left;
    margin: 0px 20px 0px 0px;
    padding: 0;
}

img.float_right {
    float: right;
    margin: 0px 0px 0px 20px;
    padding: 0;
}

.legende_photo_gen {
    text-align: center;
    font-size: 10px;
    color: #535353;
}

.evidence {
    padding: 30px 25px 30px 25px;
    background-color: color-mix(in srgb, var(--default-color), transparent 96%);
    border-radius: 8px;
    /*margin: 25px 25px 35px 25px;*/
}

@media (max-width: 500px) {
    .evidence {
        padding: 10px 15px 10px 15px;
    }
}

.evidence h4 {
    text-transform: uppercase;
    font-size: 1.1rem;
    color: color-mix(in srgb, var(--default-color), transparent 50%);
}


.evidence p {
    color: #503564;
    font-size: 17px
}

.evidence p:last-child {
    margin-bottom: 0;
}




.evidence hr {
    border: 1px dashed rgba(255, 255, 255, 0.3);
}

.bouton_rond_clair {
    color: var(--accent-color);
    background: rgba(102, 6, 255, 0.07);
    display: inline-block;
    padding: 8px 35px 10px 35px;
    border-radius: 20px;
    transition: none;
    font-size: 16px;
    font-weight: 700;
    font-family: var(--heading-font);
    transition: 0.3s;
    border: 1px solid var(--accent-color);
    letter-spacing: 0.5px;
    box-shadow: 0px 0px 10px 1px rgba(152, 32, 255, 0.3);
}
.fond_sombre a.bouton_rond_clair {
    color: var(--accent-color);
    border: 1px solid var(--accent-color);
}
.fond_sombre a.bouton_rond_clair:hover {
    color: var(--contrast-color);
}

.bouton_rond_clair:hover {
    background: var(--accent-color);
    color: var(--contrast-color);
    box-shadow: 0px 0px 13px 5px rgba(152, 32, 255, 0.5);
}


.bouton_rond_sombre {
    color: var(--accent-color);
    background: #160024;
    display: inline-block;
    padding: 8px 35px 10px 35px;
    border-radius: 20px;
    transition: none;
    font-size: 16px;
    font-weight: 700;
    font-family: var(--heading-font);
    transition: 0.3s;
    border: 1px solid var(--accent-color);
    letter-spacing: 0.5px;
    box-shadow: 0px 0px 20px 5px rgba(152, 32, 255, 0.07);

}
.bouton_rond_sombre:hover {
    background: var(--accent-color);
    color: var(--contrast-color);
    box-shadow: 0px 0px 10px 3px rgba(152, 32, 255, 0.25);
}





/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Fond clair
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++  */

.fond_clair {
    background-color: #ffffff;
}

.fond_clair h2 {
    color: rgb(129, 0, 168);
    text-shadow: 1px 1px 9px rgb(233, 161, 255);
}

.fond_clair h2:before, .fond_clair h2:after
{
    background: rgba(129, 0, 168, 1);
    box-shadow: 0px 0px 4px rgb(255, 97, 194);
}


/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Fond sombre
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++  */

.fond_sombre {
    background-color: var(--background-color);
    box-shadow: inset 0px 15px 10px -10px rgba(152, 32, 255, 0.76);
}

.fond_sombre p, .fond_sombre li {
    color: #f2dbef;
    font-weight: 300;
    letter-spacing: .05rem;
}

.fond_sombre a {
    /* ne pas utiliser car induit les vignettes et autres */
}
.fond_sombre p a, .fond_sombre li a {
    color: #ff9ff3;
    border-bottom: 1px dotted #bb80ff;
}

.fond_sombre h2 {
    color:rgba(255, 217, 239, 0.9);
    text-shadow: 1px 1px 7px rgba(221, 0, 255, 0.65);
}

.fond_sombre h2:before,
.fond_sombre h2:after {
    background: rgba(245, 121, 255, 0.57);
    box-shadow: 0px 1px 5px rgba(221, 0, 255, 0.5);
}

.fond_sombre h3{
    color: rgba(240, 193, 220, 0.9);
    text-shadow: 1px 1px 15px rgba(238, 124, 255, 0.46);
}

.fond_sombre .citation {
    border-top: 1px solid rgba(255, 187, 255, 0.11);
    border-bottom: 1px solid rgba(255, 187, 255, 0.11);
    padding: 10px 50px 10px 20px;
    margin: 40px 20px 20px 20px;
}
.fond_sombre .citation p {
    color: #fc98f8;
    font-weight: 200;
    letter-spacing: 1.1px;
    line-height: 1.55em;
    text-align: center;
    text-shadow: 1px 1px 8px rgba(238, 124, 255, 0.3);
}
.fond_sombre .citation p::first-letter {
    font-size: 1.9rem;
    color: #ff9cff;
}

.fond_sombre strong {
    font-weight: bolder;
    color: #ff94c9;
}

/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
fond_degrade
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++  */
.fond_degrade { 
    /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#ff5ef4+0,9a45c1+31,ffffff+91 */
    background: linear-gradient(180deg,#E19DF9 0%,#ffffff 60%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    box-shadow: 0px -10px 8px -8px rgba(137, 0, 127, 0.33);  /* offset-x | offset-y | blur-radius | spread-radius | color */    /*margin-top: 25px;*/
}

.fond_degrade h2 {
    color: rgb(129, 0, 168);
    text-shadow: 1px 1px 9px rgb(233, 161, 255);
}
.fond_degrade h2.geant {
    color: rgba(129, 0, 168, 0.8);
    text-shadow: -1px 1px 3px rgba(255, 255, 255, 0.38);
}


.fond_degrade h2:before, .fond_degrade h2:after 
{
    background: rgba(129, 0, 168, 1);
    box-shadow: 0px 0px 4px rgb(255, 97, 194);
}





/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
transition_clair_a_sombre
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++  */
.transition_clair_a_sombre {
    /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#ffffff+6,c60095+33,150a22+71 */
    background: linear-gradient(to bottom, #ffffff 0%, rgb(255, 131, 222) 100%); 
    padding: 0;
    height: 25px;
}

/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
transition_sombre_a_clair
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++  */
.transition_sombre_a_clair {
    /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#ffffff+6,c60095+33,150a22+71 */
    background: linear-gradient(to bottom, #150A22 0%, rgb(118, 0, 118) 50%, rgb(255, 255, 255) 100%); 
    padding: 0;
    height: 10px;
}




/*--------------------------------------------------------------
# Call To Action Section
--------------------------------------------------------------*/
.call-to-action {
    padding: 50px 0;
    position: relative;
    clip-path: inset(0);
}
.call-to-action p {
    text-align: center;
    line-height: 18px;
    margin: 5px 40px 5px 40px;
    padding: 10px;
    color: rgb(109, 26, 134);
    font-size: 17px;
    /*background: rgba(252, 231, 255, 0.3);*/
    /* box-shadow: 1px 1px 4px rgba(185, 185, 185, 0.37);    */
    /* border-bottom: double rgba(253, 190, 255, 0.78);*/
    /*border-radius: 15px 15px 15px 15px;*/
}

.call-to-action p strong {
    color: rgb(161, 39, 198);
}

.call-to-action .container {
    position: relative;
    z-index: 3;
}

.call-to-action h2 {
    text-align: center;
}

.call-to-action .cta-btn {
    font-family: Times, "Times New Roman", "serif";
    font-weight: 500;
    font-size: 18px;
    letter-spacing: 1px;
    display: inline-block;
    padding: 7px 32px;
    transition: 0.5s;
    margin: 10px 5px 0px 5px;
    border-radius: 4px;
    border: 1px solid rgba(255, 255, 255, 0.38);
    color:rgb(255, 255, 255);
    background: linear-gradient(45deg,rgba(161, 0, 190, 0.89) 50%,rgba(214, 39, 255, 0.8) 90%); 
    text-shadow: 0px 0px 18px rgba(255, 255, 190, 0.8);    
    box-shadow: -1px -0px 3px rgba(255, 158, 229, 0.62), 0px 0 8px rgba(63, 0, 87, 0.39);   
    border-radius: 10px;

    background-color: var(--surface-color);
    color: var(--accent-color);
    font-family: var(--heading-font);
    font-weight: 500;
    font-size: 16px;
    letter-spacing: 1px;
    display: inline-block;
    padding: 12px 40px;
    border-radius: 4px;
    transition: 0.5s;
    margin: 10px;
    border: 2px solid var(--accent-color);
}

.call-to-action .cta-btn:hover {
    color:rgb(129, 0, 168);
    background:rgba(255, 172, 226, 0.9);
    text-shadow: 0px 0px 8px rgba(255, 255, 6, 0.62);    
    box-shadow: 0px 0 8px rgba(255, 255, 255, 0.7), 0px 0 15px rgba(255, 255, 255, 0.5);  

    background: var(--accent-color);
    color: var(--contrast-color);
}



/*--------------------------------------------------------------
# Services Section
--------------------------------------------------------------*/
.services .service-item {
    background-color:#efc5ff;
    box-shadow: 0px 5px 20px 0px rgba(255, 61, 159, 0.55);
    padding: 14px 14px;
    transition: all ease-in-out 0.3s;
    border-radius: 42px 10px 20px 10px;
    border-bottom: 5px solid var(--surface-color);
    height: 100%;
}

.services .img {
    border-radius: 32px 10px 20px 10px;
    overflow: hidden;
    box-shadow: 0px 0 10px rgba(72, 50, 82, 0.7);    
}

.services .img img {
    transition: 0.6s;
    border-radius: 0;
}

.services .details {
    background:#ffffff;
    padding: 30px 30px 40px 30px;
    margin: -100px 30px 0 30px;
    transition: all ease-in-out 0.3s;
    position: relative;
    text-align: center;
    border-radius: 42px 10px 20px 10px;
    /*box-shadow:  2px 2px 13px rgba(255, 255, 255, 0.66); */
    box-shadow:  inset 1px 2px 30px rgba(226, 0, 255, 0.2); 
    transform: rotate(-1.5deg);
}

@media (max-width: 575px) {
    .services .details {
        padding: 10px 10px;
        margin: -120px 30px 0 30px;
    }
}

.services .service-item h3 {
    font-family: var(--default-font);
    color:#3c3c3c;
    margin: 0px 0 15px 0;
    font-size: 23px;
    transition: ease-in-out 0.3s;
    line-height: 24px
}
.services .service-item:hover .details h3 {
    color: #4a265a;
}

@media (min-width: 1365px) {
    .services .service-item:hover {
        transform: translateY(-10px);
        box-shadow: 0px 15px 15px rgba(141, 111, 157, 0.6);
    }

    .services .service-item:hover h3 {
        color: var(--accent-color);
    }
}


.services .details p {
    color:#423948;
    line-height: 22px;
    font-size: 15px;
    margin-bottom: 0;
}



.services .service-item:hover .img img {
    transform: scale(1.2);
}



.service_btn {
    font-family: Times, "Times New Roman", "serif";
    font-weight: 500;
    font-size: 18px;
    letter-spacing: 1px;
    display: inline-block;
    padding: 7px 32px;
    transition: 0.5s;
    margin: 20px 5px 0px 5px;
    border-radius: 4px;
    /*border: 1px solid rgb(137, 0, 255);*/
    color:rgb(255, 255, 255);
    background: linear-gradient(45deg,rgba(161, 0, 190, 0.89) 50%,rgba(214, 39, 255, 0.8) 90%); 
    text-shadow: 0px 0px 18px rgba(255, 255, 190, 0.8);    
    box-shadow: 0px 0 8px rgba(180, 0, 166, 0.44);   
    border-radius: 10px;
}
.service_btn:hover {
    /* pas possible */  
}






/*--------------------------------------------------------------
# About Section
--------------------------------------------------------------*/
.about .inner-title {
    font-size: 2.75rem;
    font-weight: 700;
    margin: 30px 0;
}

@media (min-width: 991px) {
    .about .inner-title {
        max-width: 65%;
        margin: 0 0 80px 0;
    }
}

.about ul {
    list-style: none;
    padding: 0;
    font-size: 15px;
}

.about ul li {
    display: flex;
    align-items: center;
}

.about ul li.people {
    background-color: rgba(236, 186, 255, 0.37);
    padding: 10px 0px 8px 25px ;
    margin: 10px 15px 5px 15px ;
    border: 1px solid rgba(68, 68, 68, 0.13);
    border-radius: 20px 10px 10px 10px;
    font-size: 16px;
}
@media (max-width: 992px) {
    .about ul li.people {
        padding: 10px 5px 5px 15px ;
        margin: 15px 0px 10px 0px ;
        border: 1px solid rgba(68, 68, 68, 0.13);
        border-radius: 20px 10px 10px 10px;
        font-size: 16px;
    }
}
.about ul i {
    font-size: 1.25rem;
    margin-right: 0.5rem;
    line-height: 1.2;
    color: var(--accent-color);
}

.about .watch-video i {
    font-size: 2rem;
    transition: 0.3s;
    color: var(--accent-color);
}

.about .watch-video a {
    font-weight: 600;
    color: color-mix(in srgb, var(--default-color), transparent 20%);
    margin-left: 8px;
    transition: 0.3s;
}

.about .watch-video:hover a {
    color: var(--accent-color);
}

.about img {
    /*min-height: 400px; ne va pas sur petits écrans*/
    position: relative;
    box-shadow: 0px 0px 6px 1px rgba(87, 0, 150, 0.46);  /* offset-x | offset-y | blur-radius | spread-radius | color */    /*margin-top: 25px;*/    

}

@media (min-width: 992px) {
    .about .about-img {
        position: absolute;
        top: 0;
        right: 0;
        min-height: 600px;
    }
}

.about .about-img img {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 1;
}





/*--------------------------------------------------------------
# Parallax Zone Section
--------------------------------------------------------------*/
.parallax_1 {
    --background-color: none;
}

.parallax_1 .container {
    padding-top: 80px;
    padding-bottom: 80px;
    border-radius: 15px;
    overflow: hidden;
    position: relative;
    clip-path: inset(0 round 15px);

}

.parallax_1 .container img.bg_parallax {
    position: fixed;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
    border-radius: 15px;
    overflow: hidden;

}

.parallax_1 .container:before {
    content: "";
    background: linear-gradient(to right, rgba(255, 0, 235, 0.15) 5%,rgba(255, 253, 224, 0.2) 50%,rgba(92, 0, 199, 0.4) 95%);
    position: absolute;
    inset: 0;
    z-index: 2;
}

.parallax_1 .container .content {
    position: relative;
    z-index: 3;
}

.parallax_1 .zone_txt {
    background-color: rgba(253, 196, 255, 0.77);
    box-shadow: inset 0px 0px 10px 0px rgba(175, 66, 255, 0.6);  /* offset-x | offset-y | blur-radius | spread-radius | color */    /*margin-top: 25px;*/    
    text-align: center;
    border-radius: 15px;
    padding: 10px 10px 10px 10px;
}
.parallax_1 h3 {
    color: rgb(129, 0, 168);
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 20px;
    text-shadow: 1px 1px 3px rgba(242, 155, 255, 0.87);
    font-weight: 700;
    font-family: Times, "Times New Roman", "serif";
    font-style: italic;
}

.parallax_1 p {
    margin-bottom: 20px;
    color: #d033ff;
    font-size: 20px;
    text-shadow: 1px 1px 10px rgba(255, 121, 204, 0.72);

}

.parallax_1 .pulsating-play-btn {
    display: block;
    margin: 0 auto 10px auto;
}

.parallax_1 .parallax_btn {
    font-family: Times, "Times New Roman", "serif";
    font-weight: 500;
    font-size: 18px;
    letter-spacing: 1px;
    display: inline-block;
    padding: 7px 32px;
    transition: 0.5s;
    margin: 10px 5px 0px 5px;
    border-radius: 4px;
    border: 1px solid rgba(255, 255, 255, 0.38);
    color:rgb(255, 255, 255);
    background: linear-gradient(45deg,rgba(161, 0, 190, 0.89) 50%,rgba(214, 39, 255, 0.8) 90%); 
    text-shadow: 0px 0px 18px rgba(255, 255, 190, 0.8);    
    box-shadow: -1px -0px 3px rgba(255, 158, 229, 0.62), 0px 0 8px rgba(63, 0, 87, 0.39);   
    border-radius: 10px;
    transform: rotate(-1deg);
    margin-bottom: 20px;
}

.parallax_1 .parallax_btn:hover {
    color:rgb(129, 0, 168);
    background:rgba(255, 172, 226, 0.9);
    text-shadow: 0px 0px 8px rgba(255, 255, 6, 0.62);    
    box-shadow: 0px 0 8px rgba(255, 255, 255, 0.7), 0px 0 15px rgba(255, 255, 255, 0.5);   
}


@keyframes pulsate-btn {
    0% {
        transform: scale(0.6, 0.6);
        opacity: 1;
    }

    100% {
        transform: scale(1, 1);
        opacity: 0;
    }
}




.pulsating-play-btn {
    width: 94px;
    height: 94px;
    background: radial-gradient(#c400ff 50%, color-mix(in srgb, #8900ff, transparent 75%) 52%);*/
}

.parallax_1 img.img_dans_txt{
    opacity: 0.8;
    border-radius: 20px;
    box-shadow: 0px 0 8px rgba(176, 68, 255, 0.56), 0px 0 15px rgba(255, 255, 255, 0.52);   
}



/*--------------------------------------------------------------
# Pricing Section
--------------------------------------------------------------*/
h3 i {
    /*color: #059652;*/
    font-size: 34px;
    padding-right: 3px;
}

.pricing .pricing-item {
    background-color: var(--surface-color);
    box-shadow: 0 3px 20px -2px rgba(0, 0, 0, 0.1);
    border-top: 3px solid rgba(62, 62, 62, 0.05);
    padding: 10px 40px 30px 40px;
    height: 100%;
    border-radius: 10px;
}

.pricing .pricing-item a {
    color: var(--accent-color);
}
.pricing .pricing-item h3 {
    font-family: "Lato", sans-serif;
    color: #290046;
    font-weight: 600;
    margin-bottom: 15px;
    font-size: 20px;
    border: none;
}

.pricing .pricing-item h4 {
    color: var(--accent-color);
    font-size: 48px;
    font-weight: 400;
    font-family: var(--heading-font);
    margin-bottom: 0;
    line-height: 0.3;
}

.pricing .pricing-item h4 sup {
    font-size: 28px;
}

.pricing .pricing-item h4 span {
    color:#7d009b;
    font-size: 18px;
}



.pricing .pricing-item strong {
    color: #059652;
}
.pricing .pricing-item p {
    color: #1a1a1a;
    line-height: 22px;
    margin: 0;
    padding: 20px 0 0 0;
    font-size: 14px;
    text-align: left;
}
.pricing .pricing-item p.asterisque {
    font-size: 13px;
    font-style: italic;
    color: #363636;
}
.pricing .pricing-item ul {
    padding: 10px 0;
    list-style: none;
    color: #1a1a1a;
    text-align: left;
    line-height: 17px;
}

.pricing .pricing-item ul li {
    color: #1a1a1a;
    padding: 8px 0;
    display: flex;
    align-items: center;
}

.pricing .pricing-item ul i {
    color: #059652;
    font-size: 24px;
    padding-right: 3px;
}

.pricing .pricing-item p i {
    color: #059652;
    /*font-size: 20px;*/
    padding-right: 3px;
}

.pricing .pricing-item ul .na {
    color:#4a4a4a;
}

.pricing .pricing-item ul .na i {
    color: color-mix(in srgb, var(--default-color), transparent 60%);
}

.pricing .pricing-item ul .na span {
    text-decoration: line-through;
}



.pricing .pricing-item.featured {
    background: #dcffeb;
    box-shadow: inset 0px 0px 12px 3px rgba(255, 255, 255, 0.95);  /* offset-x | offset-y | blur-radius | spread-radius | color */    /*margin-top: 25px;*/

}


@media (max-width: 992px) {
    .pricing .pricing-item .box {
        max-width: 60%;
        margin: 0 auto 30px auto;
    }
}

@media (max-width: 767px) {
    .pricing .pricing-item .box {
        max-width: 80%;
        margin: 0 auto 30px auto;
    }
}

@media (max-width: 420px) {
    .pricing .pricing-item .box {
        max-width: 100%;
        margin: 0 auto 30px auto;
    }
}


li.mode_paiement {
    text-align: left;
    list-style: none;


}
li.mode_paiement img {
    max-width: 65px;
    margin: 0 20px 0 0 ;
}








/*--------------------------------------------------------------
# Portfolio Section Galerie (c'est celui du Template "Company")
--------------------------------------------------------------*/
.fond_portfolio {
    box-shadow: inset 0px 15px 20px -15px rgba(78, 39, 111, 0.3);  /* offset-x | offset-y | blur-radius | spread-radius | color */    /*margin-top: 25px;*/
    background: linear-gradient(120deg,rgba(95, 68, 118, 0.3) 0%,rgba(255, 109, 244, 0.3) 60%); 
    border-radius:15px;

}

.portfolio .portfolio-filters {
    padding: 0;
    margin: 0 auto 20px auto;
    list-style: none;
    text-align: center;
}

.fond_titre_portfolio { /* surtout pour les sections de TITRES */
    /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#ff5ef4+0,9a45c1+31,ffffff+91 */
    background: linear-gradient(180deg,rgba(225, 157, 249, 0.3) 0%,#ffffff 60%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    box-shadow: 0px -10px 8px -8px rgba(137, 0, 127, 0.2);  /* offset-x | offset-y | blur-radius | spread-radius | color */    /*margin-top: 25px;*/
}

.portfolio img {
    border-radius: 30px 5px 10px 5px;
    box-shadow: -3px -3px 6px rgba(40, 0, 52, 0.2);
    margin-top: 8px;
}



.portfolio .portfolio-filters li {
    color:rgb(129, 0, 168);
    cursor: pointer;
    display: inline-block;
    padding: 8px 20px 10px 20px;
    margin: 0;
    font-size: 15px;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 5px;
    border-radius: 17px 4px 7px 4px;
    transition: all 0.3s ease-in-out;
    font-family: var(--heading-font);
}

.portfolio .portfolio-filters li:hover,
.portfolio .portfolio-filters li.filter-active {
    color:rgb(255, 255, 255);
    background-color:rgb(129, 0, 168);
    text-shadow: 0px 0px 8px rgba(255, 255, 6, 0.62);    
    box-shadow: 0px 0 4px rgba(255, 255, 255, 0.7), 0px 0 15px rgba(255, 68, 183, 0.5);    
}

.portfolio .portfolio-filters li:first-child {
    margin-left: 0;
}

.portfolio .portfolio-filters li:last-child {
    margin-right: 0;
}

@media (max-width: 575px) {
    .portfolio .portfolio-filters li {
        font-size: 14px;
        margin: 0 0 10px 0;
    }
}

.portfolio .portfolio-item {
    position: relative;
    overflow: hidden;
}

.portfolio .portfolio-item .portfolio-info {
    opacity: 0;
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: -100%;
    z-index: 3;
    transition: all ease-in-out 0.5s;
    background: linear-gradient(120deg,rgba(168, 104, 255, 0.7) 0%,rgba(255, 109, 244, 0.5) 60%); 
    padding: 15px;
    border-radius: 40px 0px 9px 0px;
}

.portfolio .portfolio-item .portfolio_loupe a {
    position: absolute;
    opacity: 0;
    top: -100%;
    left: calc(50% - 70px);

    /* faire une zone cliquable plus grande */
    width: 150px;
    height: 150px;
    padding: 50px 0 0 50px;

    z-index: 10;
    transition: all ease-in-out 0.5s;   
}
.portfolio .portfolio-item:hover .portfolio_loupe a {
    opacity: 0.8;
    top: calc(30%);
    left: calc(50% - 70px);
    cursor: zoom-in;
}
.portfolio .portfolio-item .portfolio_loupe a i {
    font-size: 40px;
}


.portfolio .portfolio-item .portfolio_loupe .preview-link,
.portfolio .portfolio-item .portfolio_loupe .details-link {
    position: absolute;
    font-size: 25px;
    /*right: 50px;
    top: calc(50% - 14px);*/

    /* right: 50%;
    top:50%;*/

    color: color-mix(in srgb, var(--default-color), transparent 30%);
    transition: 0.3s;
    line-height: 0;
}

.portfolio .portfolio-item .portfolio_loupe .preview-link:hover,
.portfolio .portfolio-item .portfolio_loupe .details-link:hover {
    color: color: #F44;
}

.portfolio .portfolio-item portfolio_loupe .details-link {
    right: 14px;
    font-size: 28px;
}



.portfolio .portfolio-item .portfolio-info h4 {
    color: #ffffff;
    font-size: 18px;
    font-weight: 600;
    padding-right: 50px;
    text-shadow: 0px 0px 4px rgba(255, 255, 6, 0.7);    

}

.portfolio .portfolio-item .portfolio-info p {
    color:rgb(58, 0, 75);
    font-size: 14px;
    margin-bottom: 0;
    padding-right: 50px;
}

.portfolio .portfolio-item:hover .portfolio-info {
    opacity: 1;
    bottom: 0;
}


.glightbox {
    cursor: zoom-in;
}
.glightbox-clean .gslide-description {
    background: linear-gradient(120deg,rgba(168, 104, 255, 0.9) 0%,rgba(255, 109, 244, 0.8) 60%); 
    border-radius: 0px 0px 9px 9px;
}
.glightbox-clean .gslide-title {
    font-size: 0.8em;
    font-weight: normal;
    font-family: Times, "Times New Roman", "serif";
    color: rgb(129, 21, 255);
    margin: 0px;
    padding: 0;
    line-height: 1.0em;
}
.gslide-image img.zoomable {
    border-radius:9px 9px 0px 0px ;
}


/* %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% */




/*--------------------------------------------------------------
# Testimonials Section
--------------------------------------------------------------*/
.testimonials .testimonial-item {
    background-color: var(--surface-color);
    box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
    box-sizing: content-box;
    padding: 20px;
    margin: 20px 15px;
    position: relative;
    height: 100%;
    border-radius: 30px 5px 10px 5px;
}

.testimonials .testimonial-item .testimonial-img {
    width: 150px;
    border-radius: 75px;
    margin-right: 15px;
    float: left;
}

.testimonials .testimonial-item h3 {
    font-size: 18px;
    color: #363636;
    font-weight: bold;
    margin: 10px 0 5px 0;
    text-decoration: none;
    border: none;
}

.testimonials .testimonial-item h4 {
    font-size: 14px;
    color: color-mix(in srgb, var(--default-color), transparent 40%);
    margin: 0;
}

.testimonials .testimonial-item .stars {
    margin: 10px 0;
}

.testimonials .testimonial-item .stars i {
    color: #ffc107;
    margin: 0 1px;
}

.testimonials .testimonial-item .quote-icon-left,
.testimonials .testimonial-item .quote-icon-right {
    color: color-mix(in srgb, var(--accent-color), transparent 50%);
    font-size: 26px;
    line-height: 0;
}

.testimonials .testimonial-item .quote-icon-left {
    display: inline-block;
    left: -5px;
    position: relative;
}

.testimonials .testimonial-item .quote-icon-right {
    display: inline-block;
    right: -5px;
    position: relative;
    top: 10px;
    transform: scale(-1, -1);
}

.testimonials .testimonial-item p {
    clear: both;
    font-style: italic;
    margin: 15px auto 15px auto;
    color: #610084;
}

.testimonials .swiper-wrapper {
    height: auto;
}

.testimonials .swiper-pagination {
    margin-top: 20px;
    position: relative;
}

.testimonials .swiper-pagination .swiper-pagination-bullet {
    width: 12px;
    height: 12px;
    background-color: color-mix(in srgb, var(--default-color), transparent 85%);
    opacity: 1;
}

.testimonials .swiper-pagination .swiper-pagination-bullet-active {
    background-color: var(--accent-color);
}

@media (max-width: 767px) {
    .testimonials .testimonial-wrap {
        padding-left: 0;
    }

    .testimonials .testimonial-item {
        padding: 30px;
        margin: 15px;
    }

    .testimonials .testimonial-item .testimonial-img {
        position: static;
        left: auto;
    }
}

/* %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% */




/*--------------------------------------------------------------
# Faq 2 Section
--------------------------------------------------------------*/
.faq-2 .faq-container {
    border-radius: 15px;
    /*background-color: rgb(249, 227, 255);*/
    margin-top: 15px;

    scroll-behavior: smooth;
}

.faq-2 .faq-container .faq-item {
    border-radius: 7px;
    background-color: rgb(255, 238, 255);


    position: relative;
    padding: 20px;
    margin-bottom: 20px;
    overflow: hidden;

    counter-increment: faq-item; /* Compter et afficher numéro */

}

.faq-2 .faq-container .faq-item h3:before {
    content: counter(faq-item)"."; /* Compter et afficher numéro */

    font-size: 16px;
    padding: 0 5px;
    margin-right: 10px;
    line-height: 0;
    transition: 0.3s;
    color: #f7d8ff;
    border-radius: 8px 4px 4px 4px;
    background-color: rgb(98, 0, 128);
    box-shadow: -1px -1px 4px rgba(255, 255, 255, 0.3);


}

.faq-2 .faq-container .faq-item:last-child {
    margin-bottom: 0;
}

.faq-2 .faq-container .faq-item h3 {
    font-weight: 600;
    font-size: 18px;
    line-height: 24px;
    margin: 0 30px 0 32px;
    transition: 0.3s;
    cursor: pointer;
    color: #53006c;
}

.faq-2 .faq-container .faq-item h3 span {
    color: var(--accent-color);
    padding-right: 5px;
}

.faq-2 .faq-container .faq-item h3:hover {
    color: var(--accent-color);
}

.faq-2 .faq-container .faq-item .faq-content { /* Modif selon Chat GPT */
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
    visibility: hidden;
    opacity: 0;
}

.faq-2 .faq-container .faq-item .faq-content p {
    margin-bottom:8px;
    overflow: hidden;
}

.faq-2 .faq-container .faq-item .faq-content p strong, .faq-2 .faq-container .faq-item .faq-content li strong {
    padding: 0 3px;
    border-radius: 3px;
    color:#a02bbc;
    background-color: #ffd6f9;
}
.faq-2 .faq-container .faq-item .faq-content p a {
    /*text-decoration: underline;*/
    border-bottom: 1px dotted rgba(146, 0, 190, 0.91);     /* dashed groove none dotted inset*/
    padding: 0 2px 0 2px;

}

.faq-2 .faq-container .faq-item .faq-icon {
    /*position: absolute;
    top: 22px;
    left: 20px;
    font-size: 20px;
    line-height: 0;
    transition: 0.3s;
    color: var(--accent-color);*/
}

.faq-2 .faq-container .faq-item .faq-toggle {
    position: absolute;
    top: 20px;
    right: 20px;
    font-size: 16px;
    line-height: 0;
    transition: 0.3s;
    cursor: pointer;
}

.faq-2 .faq-container .faq-item .faq-toggle:hover {
    color: #f00;
}

.faq-2 .faq-container .faq-active h3 {
    color: #760091;

}

.faq-2 .faq-container .faq-active .faq-content { /* Modif selon Chat GPT */
    max-height: 1000px; /* Vous pouvez ajuster cette valeur à une hauteur maximale raisonnable */
    visibility: visible;
    opacity: 1;
    padding-top: 10px;
    transition: max-height 2s ease, opacity 2s ease;
}

.faq-2 .faq-container .faq-active .faq-toggle {
    transform: rotate(90deg);
    color: #00f;
}

.offset_ancre_faq { 
    scroll-margin-top: 165px;
}

/* %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% */








.pre_footer_diagonal {
    height:30px;
    background:linear-gradient(-1.1deg, #121212, #121212 48%, white 52%, white);
}

.footer {
    background-color: #121212;
}

.footer .footer-top {
    padding-top: 40px;
}
@media (max-width: 575px) {
    .footer .footer-top {
        padding-top: 30px;
    }
}

.footer .footer-about {
    margin: 0px;
}
.footer .footer-links ul li {
    padding: 7px 0;
}
.footer .footer-links ul li,
.footer .footer-links ul a {
    color: #9d92b7;
    line-height: 1;
}
@media (max-width: 575px) {
    .footer .footer-links ul li {
        padding: 3px 0;
    }
}
@media (max-width: 992px) {
    .footer .footer-links ul li {
        letter-spacing: 0px;
    }
}

#liens_partenaires {
    border-top: 1px solid #272727;
    background-color: #121212;
    padding-bottom: 60px;
}
#liens_partenaires h3 {
    display: block;
    border: none;
    text-decoration: none;
    font-family: Times, "Times New Roman", "serif";    
    /*letter-spacing: 2px;*/
    color: #272727;
    font-style: italic;
    font-size: 28px;
    padding: 0 0 20px 0;
    margin: 20px 0;
    font-weight: 400;
}
@media (max-width: 575px) {
    #liens_partenaires h3 {
        font-size: 23px;
    }
}

#liens_partenaires h3:before,
#liens_partenaires h3:after {
    background: #272727;
    margin: 0 20px 10px 20px;
    content: "";
    width: 50px;
    height: 1px;
    display: inline-block;
}

img.banners_partenaires {
    border-radius: 5px;
    padding: 0px;
    opacity: 1;
    transition: 0.5s;
    box-shadow: 3px 3px 14px rgba(98, 0, 255, 0.07);    
    box-shadow: 0px 0px 2px rgba(255, 25, 247, 0.2);    
}
@media (max-width: 992px) {
    img.banners_partenaires {
        margin: 5px 0;   
    }
}

img.banners_partenaires:hover {
    border-radius: 0px;
    box-shadow: 3px 3px 20px rgba(98, 0, 255, 0.2);    
    opacity: 0.8;
    transform: scale(1.1);
}


.footer h4 {
    color:#a14ebf;
}
.footer h4::after {
    content: "";
    position: absolute;
    display: block;
    width: 90%;
    height: 1px;
    background:rgba(255, 130, 255, 0.51);
    bottom: 0;
    left: 0;
}



.footer input[type="checkbox"]#checkbox2  {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 15px;
    height: 15px;
    border: 2px solid #8b8b8b;
    border-radius: 4px;
    outline: none;
    cursor: pointer;
    margin-left: 12px;
}

.footer input[type="checkbox"]#checkbox2:checked {
    background-color: rgb(99, 0, 129);
    border-color: #4a4a4a;
}
input[type="checkbox"]:checked::after {
    content: "✔";
    display: block;
    text-align: center;
    color: #1d41ba;
    font-size: 14px;
}




.footer .copyright {
    color: #6f486b;
    font-size: 12px;
    text-align: right;
    padding: 0 90px 20px 0;
}

.footer .credits {
    font-style: italic;
    margin-top: 0;

    color: #b7b7b7;
    font-size: 11px;
    text-shadow: 0px 0px 7px rgba(255, 255, 190, 0.2);    

}

.footer .credits a {
    color: #aa79a5;
}

.footer li {
    font-size: 12px;    
}




/* Page Photographe */
#section_titre_photographe {
    /*background-color: #141c24;  */
    background: linear-gradient(45deg,#1f2b33 50%,#11121a 90%); 
    padding-top: 5px;
}

#section_titre_photographe h1 {
    color: #507293;
    text-shadow: none;
    font-size: 70px;
}
@media (max-width: 950px) {
    #section_titre_photographe h1 {
        font-size: 30px;
    }
}

#section_intro_photographe {
    padding-top: 1px;    
    padding-bottom: 1px;    
}




/* FORMULAIRE de contact */
.contact .php-email-form {
    background-color: rgba(255, 0, 235, 0.16);    
    padding: 20px;
    border-radius: 15px;

}

.contact .php-email-form input[type=text],
.contact .php-email-form input[type=email],
.contact .php-email-form textarea {
    color: var(--default-color);
    background-color: rgb(255, 207, 246);    
    border-radius: 8px;
    box-shadow: 2px 1px 4px rgba(95, 0, 137, 0.09);
    font-size: 14px;
    border-color: color-mix(in srgb, var(--default-color), transparent 80%);
}

/* placeholder */
.contact .php-email-form input[type=text]::placeholder,
.contact .php-email-form input[type=email]::placeholder,
.contact .php-email-form textarea::placeholder {
    color: #462771;
}

.php-email-form p {
    font-size: 13px;
    margin: 0;
    padding: 0 0 0 20px;
}

.php-email-form i {
    font-size: 12px;
    margin: 0;
    padding: 0;
}

.contact .php-email-form textarea {
    height: 150px;
}

.contact .php-email-form button[type="submit"] {
    background:#b100ff;
    color: var(--contrast-color);
    border: 0;
    padding: 13px 50px;
    transition: 0.4s;
    border-radius: 4px;
}


.table-light {

}




/* plateformes */
#plateformes img {
    border-radius: 4px;
    margin:4px;    
}


.images_plateformes img {
    box-shadow: 1px 2px 8px rgba(25, 0, 64, 0.1);  /* offset-x | offset-y | blur-radius | spread-radius | color */
    transition: 0.5s;
    box-shadow: 0px 0px 8px rgba(136, 0, 208, 0.1);  /* offset-x | offset-y | blur-radius | spread-radius | color */
}
.images_plateformes img:hover {
    transform: rotate(-3deg);
    box-shadow: 1px 2px 20px rgba(136, 0, 208, 0.4);  /* offset-x | offset-y | blur-radius | spread-radius | color */


}



/* IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII */
/* Page Index */
/* IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII */
.index_boudoir {
    /* = MAIN */

}
.index_boudoir .mobile-nav-toggle {
    display: none;
}
/*@media (max-width: 1199px) {
.mobile-nav-toggle {
display: none;
}
}*/


#bloc_haut_avec_anim {
    background-color: #E19DF9;    
}
.section_logo_index {
    margin-top: 20px;
    padding: 0;
    background-color: var(--background-color);
    font-size: 55px;
    position: relative;
    top:-40px;
    z-index: 10;
}

.logo_index_boudoir img {
    border-radius:0px;
    padding-top: 20px;
    width: 100%;
    max-width: 750px;
}
.logo_index_boudoir a img:hover {

}



.arche_head_index_haut {
    padding: 0;
    height: 20px;
    background-image: url("../../design/arche_head_index_haut_1.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    background-color: #E19DF9;

    /* Animation */
    position: relative; /* Permet de manipuler l'élément avec 'top' */
    top: -20px; /* Position initiale */
    opacity: 0; /* Masqué au début */
    transition: opacity 0.5s ease; /* Animation de l'opacité */

    z-index: 11;
}
.arche_head_index_haut.animate {
    top: 0px; /* Position finale, au-dessus de l'élément */
    opacity: 1; /* Rendre visible */
    transition: top 2s ease, opacity 0.5s ease; /* Transition pour l'animation */
}
@media (max-width: 575px) {
    .arche_head_index_haut {
        height: 10px;
    }
}

.arche_head_index_bas {
    padding: 0;
    height: 20px;
    background-image: url("../../design/arche_head_index_2.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    background-color: #E19DF9;


    /* Animation */
    position: relative; /* Permet de manipuler l'élément avec 'top' */
    top: -60px; /* Position initiale */
    opacity: 0; /* Masqué au début */
    transition: opacity 0.5s ease; /* Animation de l'opacité */

    z-index: 9;
}

.arche_head_index_bas.animate {
    top: -40px; /* Position finale, au-dessus de l'élément */
    opacity: 1; /* Rendre visible */
    transition: top 2s ease, opacity 0.5s ease; /* Transition pour l'animation */
}


@media (max-width: 575px) {
    .arche_head_index_bas {
        height: 10px;
    }
}


.section_titre_index {
    box-shadow: none;
    position: relative;
    top: -40px;
}


.section_titre_index h1, .section_titre_index h2 {
    padding: 0;
    margin: 0;
    font-family: Times, "Times New Roman", "serif";
    font-size: 40px;
    text-align: center;
    /*font-weight: bold;*/
    color: #87239a;
    text-shadow: 1px 1px 9px rgb(233, 161, 255);
    letter-spacing: 4px;
}

@media (max-width: 575px) {
    .section_titre_index h1 {
        font-size: 30px;
        letter-spacing: 1px;
    }
}
.section_titre_index h2 {
    color: #692f88;
    font-family: Times, "Times New Roman", "serif";
    font-size: 22px;
    font-weight: 700;
    display: inline-block;
    padding: 0;
    margin: 5px 0px 20px 0px;
    transform: rotate(-2deg);
    letter-spacing: 1px;

}
.section_titre_index h2:before, .section_titre_index h2:after {
    content: none;
}


@media (max-width: 575px) {
    .section_titre_index h2 {
        font-size: 19px;
    }
}

.choix_langues {
    background-color: #fff;
    margin: 0;
    /*box-shadow: 0px 0px 8px 0px rgba(101, 64, 150, 0.4); */ /* offset-x | offset-y | blur-radius | spread-radius | color */
    position: relative;
    top:-60px;    
}

.legende_case_18_ans {
    min-width: 400px;
    color: var(--accent-color);
    background: rgba(102, 6, 255, 0.1);
    display: inline-block;
    padding: 5px 30px 10px 30px;
    border-radius: 5px;
    font-size: 16px;
    line-height: 12px;
    font-weight: 400;
    text-align: center;
    box-shadow: 0px 0px 5px 0px rgba(255, 255, 255, 0.38);  /* offset-x | offset-y | blur-radius | spread-radius | color */
}

@media (max-width: 575px) {
    .legende_case_18_ans {
        font-size: 14px;
        letter-spacing: -1px;
        padding: 5px 0px 10px 0px;
        min-width: inherit;
    }
}

.legende_case_18_ans p {
    padding: 0 15px;
}

.zone_case_a_cocher {
    display: flex; /* Utilisation de Flexbox pour le centrage */
    justify-content: center; /* Centre les éléments horizontalement */
    margin-top: 15px;
}

.zone_case_a_cocher label input {
    margin: 0px 5px 0px 5px;
}
.checked_18_sans_rechargement {
    accent-color: blue; 
}

.zone_drapeaux_index {
    margin: 0;
    padding: 0;
    display: flex; /* Utilisation de Flexbox pour le centrage */
    justify-content: center; /* Centre les éléments horizontalement */
    align-items: center; /* Centre les éléments verticalement (optionnel, selon vos besoins) */
}
.drapeaux_index {
    text-align: center; /* Assure que le contenu individuel est centré */
    padding: 20px 20px;
}
@media (max-width: 575px) {
    .drapeaux_index {
        padding: 5px 5px;
    }
}

.drapeaux_index img {
    width: calc(35vw); /* Largeur proportionnelle de l'écran */
    max-width: 200px; /* Limite maximale */
    height: auto; /* Maintient les proportions de l'image */
}


.drapeaux_index img {
    transition: all ease-in-out 0.2s;
    opacity: 1;
}
.drapeaux_index img:hover {
    opacity: 0.8;
    transform: rotate(-3deg);
}
.drapeaux_index p, .drapeaux_index p a, .drapeaux_index i {
    color: #994fb4;
    /*font-size: 15px;*/
}

.arche_illu_index_haut {
    padding: 0;
    height: 20px;
    background-image: url("../../design/arche_head_index_haut_1.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    background-color: #ffffff;
}

.arche_illu_index_bas {
    padding: 0;
    height: 20px;
    background-image: url("../../design/arche_head_index_3.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    background-color: #ffffff;
}


.image_illu_index {
    margin: 0;
    padding: 0;
    box-shadow: none; 
}


.image_illu_index img {
    margin: 0 auto;
    width: 100%;
    max-width: 900px;
    border-radius: 40px;
    box-shadow: 1px 0px 5px 3px rgba(255, 47, 254, 0.3);  /* offset-x | offset-y | blur-radius | spread-radius | color */    
    transition: box-shadow 0.3s ease-in-out;

}
.image_illu_index img:hover {
    box-shadow: 1px 0px 40px 8px rgba(255, 47, 254, 0.3);  /* offset-x | offset-y | blur-radius | spread-radius | color */    
}
@media (max-width: 575px) {
    .image_illu_index img {
        border-radius: 30px;
        box-shadow: 1px 0px 5px 3px rgba(255, 47, 254, 0.3);  /* offset-x | offset-y | blur-radius | spread-radius | color */    
    }
}
.index_boudoir .txt_surlignage {
    font-size: 24px;
    font-weight: normal;
}
@media (max-width: 575px) {
    .index_boudoir .txt_surlignage {
        font-size: 20px;
    }
}


/*    Page Erreur 404    */
/*---------------------- */
h1.page_erreur {
    font-size: 80px;
    letter-spacing: 1px;
    padding: 30px 0 10px 0 ;
    text-align: center;
    color: rgb(76, 33, 83);
    text-shadow: none;  
    transform: rotate(-1deg);
}

@media (max-width: 575px) {
    h1.page_erreur {
        font-size: 25px;
        letter-spacing: 0px;
        padding: 30px 0 10px 0 ;
        transform: rotate(-1deg);
        font-weight: 700;
    }
}

.bords_ronds_video {
    border-radius: 15px; 
    overflow: hidden; 
    box-shadow: 0px 0px 8px 0px rgba(34, 0, 74, 0.3);  /* offset-x | offset-y | blur-radius | spread-radius | color */
}

@media (max-width: 575px) {
    .bords_ronds_video {
        border-radius: 10px; 
    }
}

p.votre_ip {
    font-size: 12px;
    color: #4b007b;
}


.sensitive-image {
    background-color: rgba(245, 236, 244, 0.7);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border-radius: 40px 4px 12px 4px;
    color: white;
    font-family: Arial, sans-serif;
    text-align: center;
}
.sensitive-image i {
    font-size: 50px;
    margin-bottom: 10px;
}
.sensitive-image.carre {
    width: 100%;
    max-width: 600px;
    aspect-ratio: 1 / 1;
}
.sensitive-image.horizontal {
    width: 100%;
    max-width: 600px;
    aspect-ratio: 3 / 2;
}
.sensitive-image.vertical {
    width: 100%;
    max-width: 600px;
    aspect-ratio: 4 / 5;
}


.sensitive-image p {
    color: #999;
    margin-bottom: 8px;
}
.sensitive-image p.lien_sensitive {
    color: rgb(26, 105, 232);
    font-size: 12px;
    line-height: 10px;
    margin: 0;
}

.sensitive-image i {
    font-size: 60px;
    margin-bottom: 10px;
    color: #999;
}


/* VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV */
/* Pour vidéo verticale */
.ratio-9x16 {
    padding-top: 177.77%; /* (16 / 9) * 100% */
    position: relative;
}

.ratio-9x16 video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}


/* --------------------------------------------------------------------- */
/* mosaique_gal */
/* Style pour les conteneurs mosaique_gal */
.mosaique_gal {
    float: left; 
    margin: 8px; 
    padding: 5px; 
    width: 240px; 
    height: 240px; 
    display: flex; /* Utilisation de flexbox pour centrer les images */
    justify-content: center; /* Centrage horizontal */
    align-items: center; /* Centrage vertical */
    overflow: hidden; 
    background-color: rgba(155, 91, 160, 0.05);
    border-radius: 10px;
}

/* Style pour les liens dans les mosaique_gal */
.mosaique_gal a {
    display: flex; /* Utilisation de flexbox pour centrer l'image */
    justify-content: center; /* Centrage horizontal */
    align-items: center; /* Centrage vertical */
    width: 100%; /* Prend toute la largeur du conteneur */
    height: 100%; /* Prend toute la hauteur du conteneur */
}

/* Style pour les images dans les mosaique_gal */
.mosaique_gal img {
    max-width: 100%; /* Largeur maximale de l'image */
    max-height: 100%; /* Hauteur maximale de l'image */
    width: auto; /* Largeur automatique pour garder les proportions */
    height: auto; /* Hauteur automatique pour garder les proportions */
    object-fit: contain; /* Garde les proportions de l'image */
    border-radius: 10px;
}



/* Images de substitution */
.mosaique_gal .sensitive-image {
    padding: 5px; 
}

.mosaique_gal .sensitive-image a {
    display:contents;
}

.mosaique_gal .sensitive-image.carre {
    width: 230px;
    height: 230px;
    border-radius: 10px;
}
.mosaique_gal .sensitive-image.horizontal {
    width: 230px;
    height: 140px;
    border-radius: 10px;
}
.mosaique_gal .sensitive-image.vertical {
    width: 140px;
    height: 230px;
    border-radius: 10px;
}

@media (max-width: 575px) {
    .mosaique_gal {
        margin: 5px; 
        padding: 5px; 
        width: 150px; 
        height: 180px; 
        background-color: rgba(255, 200, 251, 0.05);
        border-radius: 5px;
    }


    /* Images de substitution */
    .mosaique_gal .sensitive-image.carre {
        width: 140px;
        height: 140px;
        border-radius: 10px;
    }
    .mosaique_gal .sensitive-image.horizontal {
        width: 170px;
        height: 120px;
        border-radius: 10px;
    }
    .mosaique_gal .sensitive-image.vertical {
        width: 120px;
        height: 170px;
        border-radius: 10px;
    }
    .sensitive-image i {
        font-size: 45px;
    }

}




.float_stop {
    clear: both;
}





/*----------------------------------------------------------------- 
Pagination
https://getbootstrap.com/docs/5.3/components/pagination/
----------------------------------------------------------------- */
.pagination-lg {
    --bs-pagination-padding-x: 1.5rem;
    --bs-pagination-padding-y: 0.5rem;
    --bs-pagination-border-radius: 24px;
}
@media (max-width: 575px) {
    .pagination-lg {
        --bs-pagination-padding-x: 0.9rem;
        --bs-pagination-padding-y: 0.9rem;
        --bs-pagination-border-radius: 15px;
    }
}

.page-link {
    font-size: 20px;
    color: #4e0080;
    border-color: #4e0080;
    background-color: #fcebff;
    box-shadow: 2px 2px 12px 2px rgba(255, 192, 255, 0.79);  /* offset-x | offset-y | blur-radius | spread-radius | color */
}

@media (max-width: 575px) {
    .page-link {
        font-size: 19px;
    }
}

.page-link:hover {
    color: #f2c0fd;
    background-color: #4e0080;
    border-color: var(--bs-pagination-hover-border-color);
}

.disabled > .page-link, .page-link.disabled {
    color: #9f9f9f;
    pointer-events: none;
    background-color: #ffffff;
    border-color: #4e0080;
}


/* FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  FR  */
/* Spécifique à site FR : */

.section_titre_index h2 {
    font-size: 35px;
    font-weight: normal;
    letter-spacing: 1px;
    color: rgb(208, 65, 180);
}

.footer .copyright {
    padding-bottom: 90px;
}


#noCookieBanner {
    opacity: 0.8;
    position: fixed;
    bottom: 20px; /* pour décoller du bas */
    left: 50%;
    transform: translateX(-50%);
    min-height: 64px; 
    width: calc(100% - 150px);
    z-index: 1055;

    font-size: 14px;
    --bs-alert-color: #343434;
    --bs-alert-bg: #d89cff;
    --bs-alert-border-color: #d89cff;
    --bs-alert-link-color: var(--bs-dark-text-emphasis);
}

@media (max-width: 576px) {
    #noCookieBanner {
        width: calc(100% - 20px);
    }
}


.alert-dismissible .btn-close {
    right: 100px;
    padding: 1.25rem 1rem;
}
@media (max-width: 576px) {
    .alert-dismissible .btn-close {
        right: 50px;
    }
}
h3 strong {
    font-size: 1.2em;
    text-shadow: 0px 0px 10px rgba(255, 0, 216, 0.33);        
}