:root{
    --primary:#1E2D3B;
    --secondary:#BB3434;
    --light:#F7F8FA;
    --text:#334155;
    --white:#FFFFFF;
}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    font-family:'Inter',sans-serif;
    color:var(--text);
    line-height:1.6;
    background:#fff;
}

h1,h2,h3{
    color:var(--primary);
}

.header-btn{
    padding:12px 22px;
    font-size:.95rem;
}

.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;

    padding:15px 28px;

    border-radius:10px;

    text-decoration:none;

    font-weight:600;

    font-family:inherit;

    font-size:1rem;

    border:none;

    cursor:pointer;

    transition:.3s;
}

.btn-primary{
    background:var(--secondary);
    color:white;
}

.btn-primary:hover{
    background:#a72f2f;
    transform:translateY(-2px);
}

.btn-outline{
    border:2px solid white;
    color:white;
}

.btn-outline:hover{
    background:white;
    color:var(--primary);
}

.topbar{
    background:var(--primary);
    color:white;
    font-size:.85rem;
}

.topbar .container{
    display:flex;
    justify-content:space-between;
    align-items:center;
    height:36px;
}

.topbar a{
    color:white;
    text-decoration:none;
}

.topbar a:hover{
    color:white;
    text-decoration:none;
}

.topbar-phone{
    display:flex;
    align-items:center;
    gap:8px;
}

.topbar-phone img{
    width:16px;
    height:16px;
    filter:brightness(0) invert(1);
}

.topbar-catalog{
    display:flex;
    align-items:center;
    gap:8px;
}

.topbar-catalog img{
    width:16px;
    height:16px;
    filter:brightness(0) invert(1);
}

header{
    position:fixed;
    top:36px;
    width:100%;
    background:rgba(255,255,255,.98);
    backdrop-filter:blur(12px);
    z-index:999;
    box-shadow:0 2px 20px rgba(0,0,0,.05);
    transition:top .25s ease;
}

header.scrolled{
    top:0;
}

.navbar{
    display:flex;
    justify-content:space-between;
    align-items:center;
    min-height:90px;
}

.menu-toggle{
    display:none;
    background:none;
    border:none;
    font-size:2rem;
    color:var(--primary);
    cursor:pointer;
}

.mobile-menu{
    position:fixed;

    top:126px; /* topbar 36px + header 90px */

    right:-100%;

    width:280px;

    height:calc(100vh - 126px);

    background:white;

    box-shadow:-5px 0 20px rgba(0,0,0,.08);

    padding:30px;

    transition:.3s;

    z-index:998;

    overflow-y:auto;
}

.mobile-menu.active{
    right:0;
}

.mobile-menu a,
.mobile-menu summary{
    display:block;
    padding:15px 0;
    color:var(--primary);
    text-decoration:none;
    font-weight:500;
    cursor:pointer;
}

.mobile-menu details a{
    padding-left:20px;
    font-size:.95rem;
}

.logo{
    display:flex;
    align-items:center;
}

.logo img{
    height:60px;
    width:auto;
    display:block;
    transition:.3s;
}

.logo img:hover{
    transform:scale(1.02);
}

.header-actions{
    display:flex;
    align-items:center;
    gap:20px;
}

.header-icon{
    position:relative;
    display:flex;
    align-items:center;
    justify-content:center;
    width:44px;
    height:44px;
    border-radius:12px;
    transition:.3s;
}

.header-icon:hover{
    background:#F7F8FA;
}

.header-icon img{
    width:24px;
    height:24px;
}

.cart-count{
    position:absolute;
    top:-4px;
    right:-4px;
    width:20px;
    height:20px;
    border-radius:50%;
    background:var(--secondary);
    color:white;
    font-size:.75rem;
    font-weight:700;
    display:flex;
    align-items:center;
    justify-content:center;
}

nav ul{
    display:flex;
    list-style:none;
    gap:35px;
    align-items:center;
}

nav li{
    position:relative;
}

nav a{
    text-decoration:none;
    color:var(--primary);
    font-weight:500;
}

/* MENU CATALOGUE */
.dropdown{
    position:relative;
}

.dropdown::after{
    content:"";
    position:absolute;
    top:100%;
    left:0;
    width:100%;
    height:55px;
}
/* flèche */
.dropdown > a::after{
    content:"▼";
    font-size:.65rem;
}

/* SOUS MENU */
.dropdown-menu{
    position:absolute;
    top:55px;
    left:50%;
    transform:translateX(-50%) translateY(10px);
    width:240px;
    display:block !important; /* IMPORTANT */
    background:white;
    padding:10px 0;
    margin:0;
    border-radius:12px;
    box-shadow:0 15px 40px rgba(0,0,0,.12);
    opacity:0;
    visibility:hidden;
    transition:opacity .25s ease, transform .25s ease, visibility .25s;
    z-index:2000;
}

/* éléments du sous menu */
.dropdown-menu li{
    display:block !important; /* IMPORTANT */
    width:100%;
    margin:0;
    padding:0;
    list-style:none;
}

.dropdown-menu li:not(:last-child){
    border-bottom:1px solid #f1f1f1;
}

.dropdown-menu a{
    display:block;
    width:100%;
    padding:13px 22px;
    white-space:nowrap;
    color:var(--primary);
    font-size:.95rem;
}

.dropdown-menu a:hover{
    background:#F7F8FA;
    color:var(--secondary);
}

/* ouverture */
.dropdown:hover .dropdown-menu{
    opacity:1;
    visibility:visible;
    transform:translateX(-50%) translateY(0);
}

.dropdown-sub{
    position:relative;
}

.dropdown-submenu{
    position:absolute;
    top:0;
    left:100%;
    min-width:240px;
    background:#fff;
    list-style:none;
    opacity:0;
    visibility:hidden;
    transition:.2s;
}

.dropdown-sub:hover .dropdown-submenu{
    opacity:1;
    visibility:visible;
}

.container{
    width:90%;
    max-width:1200px;
    margin:auto;
}

.trusted .container{
    width:100%;
    max-width:100%;
}

section{
    padding:90px 0;
}


footer{
    background:var(--primary);
    color:white;
    padding:60px 0;
}

.footer-grid{
    display:grid;
    grid-template-columns:2fr 1fr 1fr 1fr;
    gap:40px;
}

footer h3{
    color:white;
    margin-bottom:20px;
    font-size:1.2rem;
}

footer p,
footer li{
    color:#d7dbe0;
    font-size:.95rem;
}

footer ul{
    list-style:none;
}

footer li{
    margin-bottom:10px;
}

footer a{
    color:#d7dbe0;
    text-decoration:none;
    transition:.3s;
}

footer a:hover{
    color:white;
}

.footer-bottom{
    padding-top:25px;
    border-top:1px solid rgba(255,255,255,.15);
    text-align:center;
}


.footer-bottom p{
    font-size:.8rem;
    color:#b8c0c8;
}

.footer-sites{
    margin-top:40px;
    padding-top:25px;
    padding-bottom:25px;
    border-top:1px solid rgba(255,255,255,.15);
    text-align:center;
    font-size:.9rem;
}


.footer-sites p{
    display:inline;
    margin-right:10px;
    color:#d7dbe0;
}

.footer-sites a{
    color:#d7dbe0;
}


.footer-sites a:hover{
    color:white;
}

.footer-sites span{
    margin:0 10px;
    color:#94a3b8;
}

.footer-social{
    display:flex;
    gap:12px;
    margin-top:22px;
}

.footer-social a{
    width:42px;
    height:42px;
    border-radius:10px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(255,255,255,.08);
    transition:.3s;
}

.footer-social a:hover{
    background:var(--secondary);
    transform:translateY(-2px);
}

.footer-social img{
    width:22px;
    height:22px;
    filter:brightness(0) invert(1);
}

/* =====================
   BREADCRUMB
===================== */
.breadcrumb{
    display:flex;
    gap:10px;
    align-items:center;
    font-size:.9rem;
    color:#64748b;

    flex-wrap:nowrap;
    overflow:hidden;
}

.breadcrumb-home{
    display:flex;
    align-items:center;
}

.breadcrumb-home img{
    width:16px;
    height:16px;
    display:block;
}


.breadcrumb a{
    color:var(--secondary);
    text-decoration:none;
}


.breadcrumb strong{
    color:var(--primary);
    font-weight:600;
}

.breadcrumb a,
.breadcrumb strong{
    white-space:nowrap;
    display:block;
}

.numbers{
    background:var(--primary);
    color:white;
}

.numbers h2{
    color:white;
}

.numbers-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:30px;
    text-align:center;
}

.number{
    font-size:3rem;
    font-weight:800;
    color:var(--secondary);
    display:flex;
    align-items:center;
    justify-content:center;
    height:70px;
}


.stars-number{
    flex-direction:column;
    gap:0;
    line-height:.75;
}


.stars-number span{
    display:block;
    letter-spacing:3px;
    font-size:2.2rem;
}


.numbers-grid p{
    margin-top:15px;
}

.testimonials-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
    gap:25px;
}

/* =====================
   TESTIMONIALS
===================== */
.testimonials{
    background:#fff;
    padding-bottom: 0;
}

.testimonial-decor{
    text-align:center;
}

.testimonial-decor img{
    width:100%;
    max-width:300px;
}

.testimonial-decor.top{
    margin-bottom:15px;
}

.testimonial-decor.bottom{
    margin-top:15px;
}

.testimonial-slider{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:40px;
}

.testimonial-card{
    position:relative;
    max-width:850px;
    width:100%;
    background:white;
    padding:50px;
    border-radius:24px;
    box-shadow:
    0 20px 50px rgba(0,0,0,.08);
    text-align:center;
}

.stars{
    font-size:2rem;
    letter-spacing:5px;
    margin-bottom:25px;
}

.testimonial-text{
    font-size:1rem;
    color:var(--primary);
    line-height:1.5;
    min-height:90px;
}

.quote{
    position:absolute;
    font-size:6rem;
    color:rgba(187,52,52,.25);
    font-family:serif;
}

.quote-left{
    top:20px;
    left:40px;
}

.quote-right{
    bottom:-15px;
    right:40px;
}

.testimonial-card h3{
    margin-top:35px;
    font-size:0.9rem;
}

.testimonial-card > span{
    color:#64748b;
    font-size:0.9rem;
}

.testimonial-arrow{
    width:55px;
    height:55px;
    border-radius:50%;
    border:none;
    background:white;
    box-shadow:
    0 10px 25px rgba(0,0,0,.12);
    font-size:2rem;
    color:var(--primary);
    cursor:pointer;
}

.testimonial-dots{
    display:flex;
    justify-content:center;
    gap:12px;
    margin-top:30px;
}

.testimonial-dots span{
    width:12px;
    height:12px;
    border-radius:50%;
    background:#ddd;
}

.testimonial-dots .active{
    background:var(--secondary);
}

.review-summary{
    text-align:center;
    margin-bottom:-40px;
}


.review-summary strong{
    font-size:1.8rem;
    color:var(--primary);
}


.review-summary span{
    font-size:1.5rem;
    letter-spacing:4px;
}


.review-summary p{
    color:#64748b;
    margin-top:5px;
}


.testimonial-action{
    text-align:center;
    margin-top:15px;
}

.cta{
    background:var(--secondary);
    text-align:center;
    color:white;
}

.cta h2{
    color:white;
    font-size:2.5rem;
    margin-bottom:20px;
}

.section-title{
    text-align:center;
    margin-bottom:60px;
}

.section-title h2{
    font-size:2.5rem;
}

.overlay h3{
    color:white;
    font-size:1.6rem;
}

/* =====================
   CLIENT LOGOS
===================== */
.trusted{
    background:#fff;
    overflow:hidden;
}


.trusted-slider{
    overflow:hidden;
    width:100%;
}


.trusted-track{

    display:flex;

    gap:60px;

    align-items:center;

    width:max-content;

    will-change:transform;

}


.trusted-track.no-transition{
    transition:none;
}


.client-logo{

    display:flex;

    align-items:center;

    justify-content:center;

    width:180px;

    height:100px;

    flex-shrink:0;

}



.client-logo img{

    max-width:140px;

    max-height:70px;

    object-fit:contain;

    filter:grayscale(100%);

    opacity:.7;

    transition:.3s;

}


.client-logo:hover img{

    filter:grayscale(0);

    opacity:1;

}

.breadcrumb-section{

    padding:100px 0 15px;

    background:var(--light);

    transition:
    padding-top .25s ease;

}

body.header-scrolled .breadcrumb-section{

    padding-top:64px;

}

.modal-overlay{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.6);
    display:none;
    align-items:center;
    justify-content:center;
    z-index:5000;
    padding:20px;
}

.modal-overlay.active{
    display:flex;
}

.modal-box{
    background:white;
    border-radius:20px;
    padding:35px;
    max-width:500px;
    width:100%;
    text-align:center;
    box-shadow:0 20px 50px rgba(0,0,0,.15);
}

.modal-box h3{
    margin-bottom:15px;
}

.modal-box p{
    margin-bottom:25px;
    color:#64748b;
}

.testimonial-card.fade{

    animation:
    testimonialFade .5s ease;

}

@keyframes testimonialFade{
    from{
        opacity:0;
        transform:translateY(15px);
    }
    to{
        opacity:1;
        transform:translateY(0);
    }
}

.hero-review{
    margin-top:35px;
    margin-bottom:25px;
}

.hero-review a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:14px;
    text-decoration:none;
    color:white;
    background:rgba(255,255,255,.12);
    padding:12px 20px;
    border-radius:50px;
    backdrop-filter:blur(8px);
    transition:.3s;
    max-width:100%;
}

.hero-review a:hover{
    background:rgba(255,255,255,.22);
    transform:translateY(-2px);
}

.hero-stars{
    display:flex;
    align-items:center;
    flex-shrink:0;
    color:#ffc107;
    font-size:1.25rem;
    letter-spacing:1px;
    line-height:1;
}

.hero-rating{
    display:flex;
    flex-direction:column;
    text-align:left;
    white-space:nowrap;
}

.hero-rating strong{
    font-size:1.15rem;
    line-height:1.2;
}

.hero-rating span{
    font-size:.85rem;
    color:#ddd;
}

.rating-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    margin:0 0 15px;
    padding:10px 18px;
    background:white;
    border:1px solid #e2e8f0;
    border-radius:999px;
    text-decoration:none;
    color:var(--primary);
    transition:.3s;
    max-width:100%;
}

.rating-badge:hover{
    transform:translateY(-2px);
    box-shadow:0 8px 25px rgba(0,0,0,.08);
}

.rating-badge-stars{
    display:flex;
    align-items:center;
    flex-shrink:0;
    color:#ffc107;
    letter-spacing:1px;
    font-size:1rem;
}

.rating-badge-text{
    font-size:.9rem;
    white-space:nowrap;
}

.rating-badge-text strong{
    color:var(--secondary);
}

/* =====================
   ETOILES HERO + BADGES
===================== */

.hero-stars .star-full,
.rating-badge-stars .star-full{
    color:#ffc107;
}


.hero-stars .star-empty,
.rating-badge-stars .star-empty{
    color:rgba(255,193,7,.25);
}


/* demi étoile hero + badge */

.hero-stars .star-half,
.rating-badge-stars .star-half{

    position:relative;

    display:inline-block;

    color:rgba(255,193,7,.25);

}


.hero-stars .star-half::before,
.rating-badge-stars .star-half::before{

    content:"★";

    position:absolute;

    left:0;

    top:0;

    width:50%;

    overflow:hidden;

    color:#ffc107;

}


/* =====================

   ETOILES BLOCS AVIS

===================== */

.testimonial-card .star-full,

.review-summary-stars .star-full{

    color:var(--secondary);

}

.testimonial-card .star-empty,

.review-summary-stars .star-empty{

    color:rgba(187,52,52,.25);

}

.testimonial-card .star-half,

.review-summary-stars .star-half{

    position:relative;

    display:inline-block;

    color:rgba(187,52,52,.25);

}

.testimonial-card .star-half::before,

.review-summary-stars .star-half::before{

    content:"★";

    position:absolute;

    left:0;

    top:0;

    width:50%;

    overflow:hidden;

    color:var(--secondary);

}

/* =====================
   COOKIES
===================== */


.cookie-banner{

    position:fixed;

    bottom:16px;

    left:50%;

    transform:translateX(-50%);

    width:calc(100% - 32px);

    max-width:960px;

    z-index:9999;

}


.cookie-banner-inner{

    background:white;

    border-radius:16px;

    padding:20px 24px;

    box-shadow:0 12px 30px rgba(0,0,0,.15);

    display:flex;

    align-items:center;

    justify-content:space-between;

    gap:20px;

}


.cookie-banner p{

    margin:0;

    color:var(--text);

}



.cookie-buttons{

    display:flex;

    gap:12px;

}


.btn-cookie{

    padding:10px 18px;

    border-radius:10px;

    cursor:pointer;

    font-weight:500;

    font-family:inherit;

}



.btn-accept{

    background:var(--secondary);

    color:white;

    border:none;

}



.btn-customize{

    background:white;

    border:1px solid #ddd;

    color:var(--primary);

}

.cookie-subtitle{

    font-size:.9rem;

    color:#64748b;

    margin-bottom:24px;

}

.cookie-modal{

    position:fixed;

    inset:0;

    background:rgba(0,0,0,.55);

    display:none;

    align-items:center;

    justify-content:center;

    z-index:10000;

    padding:20px;

}

.cookie-modal-content{

    background:white;

    padding:30px 40px;

    border-radius:12px;

    max-width:500px;

    width:90%;

    box-shadow:0 4px 20px rgba(0,0,0,.3);

}



.cookie-option{

    display:flex;

    justify-content:space-between;

    align-items:center;

    padding:18px 0;

    border-bottom:1px solid #eee;

}

.modal-actions{
    text-align:center;
    margin-top:25px;
}

.cookie-option span{

    display:block;

    font-size:.85rem;

    color:#64748b;

}

.switch{
    position:relative;
    width:44px;
    height:24px;
    flex-shrink:0;
}

.switch input{
    display:none;
}

.slider{
    position:absolute;
    inset:0;
    background:#D1D5DB;
    border-radius:999px;
    transition:.3s;
}

.slider::before{
    content:"";
    position:absolute;
    width:18px;
    height:18px;
    left:3px;
    top:3px;
    background:white;
    border-radius:50%;
    transition:.3s;
}

.switch input:checked + .slider{
    background:var(--secondary);
}

.switch input:checked + .slider::before{
    transform:translateX(20px);
}

.switch input:disabled + .slider{
    opacity:.6;
    cursor:not-allowed;
}

@media(max-width:768px){

    header{
        height:70px;
    }

    .navbar{
        min-height:70px;
    }

    .logo img{
        height:42px;
    }

    .header-actions{
        gap:10px;
    }

    .header-icon{
        width:38px;
        height:38px;
    }

    .header-icon img{
        width:20px;
        height:20px;
    }

    .menu-toggle{
        display:block;
        font-size:1.7rem;
    }

    .mobile-menu{

        top:100px; /* topbar 30px + header 70px */

        height:calc(100vh - 100px);

    }

    .mobile-menu a,
    .mobile-menu summary{
        padding:10px 0px 10px 0;
    }

    /* catégorie parente */
    .mobile-category-group > summary{
        display:block;
        margin:0;
        padding:10px 0px 10px 20px;
        color:var(--primary);
        font-size:.95rem;
        font-weight:500;
        cursor:pointer;
        list-style:none;
    }

    /* supprime le triangle natif */
    .mobile-category-group summary::-webkit-details-marker{
        display:none;
    }

    /* petit indicateur */
    .mobile-category-group summary::after{
        content:"+";
        float:right;
        font-weight:600;
    }

    .mobile-category-group[open] summary::after{
        content:"−";
    }

    /* tous les liens dans une catégorie */
    .mobile-category-group > a{
        display:block;
        padding:10px 0px 10px 0;
        padding-left:20px;
        color:var(--primary);
        font-size:.95rem;
        font-weight:400;
    }

    /* le lien voir catégorie */
    .mobile-category-group > a:first-of-type{
        padding-left:40px;
    }

    /* sous catégories */
    .mobile-subcategory{
        font-weight:500;
        padding-left:40px !important;
        font-weight:500;
    }

    .stats-grid,
    .numbers-grid{
        grid-template-columns:repeat(2,1fr) !important;
        gap:25px;
    }

    .number{
        font-size:2.2rem;
    }

    .btn{
        width:100%;
        max-width:280px;
    }

    .footer-grid{
        grid-template-columns:1fr;
        text-align:center;
    }

    nav{
        display:none;
    }

    .topbar{
        font-size:.75rem;
    }

    .topbar .container{
        height:30px;
    }

    header{
        top:30px;
        height:70px;
    }

    header.scrolled{
        top:0;
    }
    header.scrolled + .mobile-menu{

        top:70px;

        height:calc(100vh - 70px);

    }

    .breadcrumb-section{
        padding:75px 0 12px;
    }

    body.header-scrolled .breadcrumb-section{
        padding-top:45px;
    }

    .trusted-track{
        gap:25px;
    }

    .client-logo{
        width:120px;
        height:80px;
    }

    .client-logo img{
        max-width:100px;
        max-height:55px;
    }

    .client-logo img{
        filter:none;
        opacity:1;
    }

    .breadcrumb{
        gap:6px;
        font-size:.85rem;
    }

    .breadcrumb-mobile-hide{
        display:none;
    }

    .breadcrumb a,
    .breadcrumb strong{
        max-width:140px;
        overflow:hidden;
        text-overflow:ellipsis;
    }

    .breadcrumb a:not(.breadcrumb-home):not(:last-of-type){
        display:none;
    }

    .section-title{

        margin-bottom:35px;

    }

    .section-title h2{

        font-size:1.8rem;

    }

    .review-summary{

        margin-bottom:-20px;

    }

    .review-summary strong{

        font-size:1.4rem;

    }

    .review-summary span{
        font-size:1.1rem;
        letter-spacing:2px;
        margin-left:5px;
    }

    .review-summary p{

        font-size:.9rem;

    }

    .testimonial-decor img{

        max-width:180px;

    }

    .testimonial-decor.top{
        margin-bottom:20px;
    }

    .testimonial-decor.bottom{
        margin-top:20px;
    }

    .testimonial-slider{
        gap:8px;
    }

    .testimonial-card{
        padding:35px 20px;
        border-radius:18px;
    }

    .stars{
        font-size:1.4rem;
        letter-spacing:2px;
        margin-bottom:15px;
    }

    .testimonial-text{
        font-size:.95rem;
        line-height:1.5;
        min-height:auto;
    }

    .quote{
        font-size:3.5rem;
    }

    .quote-left{
        top:10px;
        left:15px;
    }

    .quote-right{
        bottom:-10px;
        right:15px;
    }

    .testimonial-card h3{
        margin-top:25px;
        font-size:.85rem;
    }

    .testimonial-card span{
        font-size:.8rem;
    }

    .testimonial-arrow{
        width:35px;
        height:35px;
        flex-shrink:0;
        font-size:1.5rem;
        display:flex;
        align-items:center;
        justify-content:center;
        padding:0;
    }

    .testimonial-dots{
        margin-top:20px;
    }

    .testimonial-dots span{
        width:9px;
        height:9px;
    }

    .testimonial-action{
        margin-top:20px;
    }

    .rating-badge{

        width:auto;
        max-width:100%;

        padding:8px 14px;

        gap:8px;

        border-radius:999px;

    }


    .rating-badge-stars{

        font-size:.85rem;

    }


    .rating-badge-text{

        font-size:.8rem;

    }

    .hero-review a{
        padding:10px 14px;
        gap:10px;
    }

    .hero-stars{
        font-size:1.1rem;
        letter-spacing:0;
    }

    .hero-rating strong{
        font-size:1rem;
    }

    .hero-rating span{
        font-size:.75rem;
    }

    .cookie-banner-inner{
        flex-direction:column;
        text-align:center;
    }

    .cookie-buttons{
        width:100%;
        flex-direction:column;
    }

    .btn-cookie{
        width:100%;
    }

    .footer-social{
        justify-content:center;
    }
}