/*
Theme Name: Un Coffre à l'Autre
Version: 1.0
*/

:root{
    --bordeaux:#7B1028;
    --rose:#C33A6A;
    --rose-logo:#7c3244;
    --gris:#f5f5f5;
    --section:#f9f9f8;
    --blanc:#ffffff;
    --texte:#2D2D2D;
    --noir:#000000; 
}

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

body{
    font-family:'Poppins',sans-serif;
    color:var(--texte);
    background:#fff;
}

img{
    max-width:100%;
    display:block;
}

a{
    text-decoration:none;
}

.container{
    max-width:1400px;
    margin:0 auto;
}

/* =========================
   HERO
========================= */

.hero{
    min-height:750px;

    background-image:url('./assets/images/hero.png');
    background-size:cover;
    background-position:center center;
    background-repeat:no-repeat;
    display:flex;
    align-items:flex-start; /* au lieu de center */
}

.hero-content{
    width:680px;
    margin-left:70px;
    margin-top:60px;
}

.hero-content{
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.hero h1{
    color: var(--bordeaux);
    font-size: 3.5rem;
    line-height: 1.05;
    margin-bottom: 25px;
}

.hero p{
    font-size: 1.5rem;
    color: var(--texte);
    margin-bottom: 35px;
    line-height: 1.4;
}

.hero-buttons{
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
}

.btn{
    display: inline-block;
    background: var(--bordeaux);
    color: #fff;
    padding: 14px 28px;
    border-radius: 4px;
    font-weight: 600;
    text-transform: uppercase;
    font-size: .9rem;
    transition: .3s;
}

.btn:hover{
    background: var(--rose);
}

.btn-outline{
    background: transparent;
    border: 2px solid var(--bordeaux);
    color: var(--bordeaux);
}

.btn-outline:hover{
    background: var(--bordeaux);
    color: #fff;
}

/* RESPONSIVE */
@media(max-width: 1024px){
    .hero-container{
        grid-template-columns: 1fr;
        padding-left: 40px;
        padding-right: 40px;
    }
    .hero-content{
        text-align: center;
        align-items: center;
    }
}

@media(max-width: 768px){
    .hero h1{
        font-size: 2.8rem;
    }
    .hero p{
        font-size: 1.2rem;
    }
}
/* =========================
   HEADER
========================= */

/* =========================
   TOP BAR
========================= */

.top-bar{
    background:#111;
    color:#fff;
    font-size:14px;
}

.top-bar .container{
    max-width:1400px;
    margin:0 auto;
    padding:10px 20px;

    display:flex;
    justify-content:space-between;
    align-items:center;
}

.top-contact{
    display:flex;
    align-items:center;
    gap:10px;
}

.top-social{
    display:flex;
    align-items:center;
    gap:15px;
}

.top-social a{
    color:#fff;
    font-size:18px;
    transition:.2s;
}

.top-social a:hover{
    color:var(--rose);
}

@media(max-width:768px){

    .top-bar .container{
        flex-direction:column;
        gap:10px;
    }

}

.site-header{
    background:var(--bordeaux);
    color:#fff;
    padding:20px;
    position:sticky;
    top:0;
    z-index:999;
    box-shadow:0 2px 10px rgba(0,0,0,.15);
}

.header-inner{
    max-width:1200px;
    margin:auto;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:30px;
}

.logo a{
    color:#fff;
    text-decoration:none;
    font-size:1.5rem;
    font-weight:bold;
}

.main-menu{
    display:flex;
    gap:20px;
    list-style:none;
    margin:0;
    padding:0;
}

.main-menu a{
    color:#fff;
    text-decoration:none;
    padding:8px 12px;
    border-radius:6px;
    transition:.3s;
}

.main-menu a:hover{
    background:rgba(255,255,255,.15);
}


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

.header-actions a{
    padding:8px 12px;
    border-radius:6px;
    transition:.3s;
    color:#fff;
}

.header-actions a:hover{
    background:rgba(255,255,255,.15);
    color:#fff;
}

.cart-count{
    background:var(--rose);
    border-radius:50%;
    padding:3px 8px;
    font-size:.75rem;
    margin-left:5px;
}

@media(max-width:768px){

    .header-inner{
        flex-direction:column;
        gap:20px;
    }

    .main-menu{
        flex-wrap:wrap;
        justify-content:center;
    }

}

/* =========================
   USP SECTION
========================= */

.usp-section{
    background:#f8f8f8;
    padding:60px 0;
    margin-bottom:120px;
}

.usp-section .container{
    max-width:1400px;
    margin:0 auto;
    padding:0 20px;
    
}

.usp-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    text-align:center;
}

.usp-item{
    position:relative;
    padding:0 50px;
}

.usp-item:not(:last-child)::after{
    content:"";
    position:absolute;
    top:15px;
    right:0;
    width:1px;
    height:90px;
    background:#d9d9d9;
}

.usp-icon{
    display:flex;
    justify-content:center;
    align-items:center;
    margin-bottom:15px;
}

.usp-icon img{
    width:55px;
    height:55px;
    object-fit:contain;
    display:block;
}

.usp-item h3{
    color:var(--bordeaux);
    text-transform:uppercase;
    font-size:16px;
    font-weight:700;
    margin-bottom:10px;
}

.usp-item p{
    font-size:15px;
    line-height:1.5;
    color:var(--texte);
}

/* =========================
   CREATOR
========================= */

.creator-section{
    background: var(--section);
    margin-top:120px;
    margin-bottom:120px;
}


.creator{
    display:grid;
    grid-template-columns: 1fr 1fr;
    align-items:center;
}

.creator-content{
    max-width:500px;
    padding-left:60px;

    display:flex;
    flex-direction:column;
    justify-content:center;
}

.creator-section .container{
    max-width:none;
    width:100%;
    padding:0;
}


.creator-image{
    display:flex;
    justify-content:center;
}

.creator-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
.creator-content h2{
    max-width:450px;
    margin-bottom:30px;
    line-height:1.15;
}

.creator-content p{
    max-width:420px;
    margin-bottom:35px;
    line-height:1.7;
}

.creator-content .btn{
    width:fit-content;
}
/* =========================
   PROCESS
========================= */


.process-section{
    padding:80px 0;
    background:#fff;
    padding:0 20px;
    padding:0 20px;
    margin-bottom:120px;
}

.process-section .container{
    max-width:1200px;
    margin:0 auto;
}

.process-section h2{
    text-align:center;
    color:var(--bordeaux);
    text-transform:uppercase;
    margin-bottom:50px;
}

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

.process-step{
    padding:0;
    border:none;
    background:none;
}

.process-step img{
    width:50px;
    height:50px;
    object-fit:contain;
    margin:0 auto 20px;
}

.process-step h3{
    font-size:18px;
    font-weight:700;
    text-transform:uppercase;
    margin-bottom:15px;
}

.process-step p{
    font-size:15px;
    line-height:1.6;
    color:var(--texte);
}
.step-top{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:20px;
    margin-bottom:20px;
}

.step-number{
    width:28px;
    height:28px;
    border-radius:50%;
    background:var(--bordeaux);
    color:#fff;
    font-size:14px;
    font-weight:700;
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}
/* =========================
   RESPONSIVE
========================= */

@media(max-width:1024px){

    .process-grid{
        grid-template-columns:repeat(2,1fr);
        gap:40px;
    }

}

@media(max-width:768px){

    .process-grid{
        grid-template-columns:1fr;
    }

}

/* =========================
   NOUVEAUTÉS
========================= */

.home-products{
    max-width:1600px;
    margin:0 auto;
    padding:80px 0;
}

.home-products h2{
    text-align:center;
    color:var(--bordeaux);
    margin-bottom:40px;
    text-transform:uppercase;
}


/* =========================
   COLLECTIONS VEDETTES
========================= */

.collections-section{
    padding:80px 0;
    background:#fff;
}

.collections-section .container{
    max-width:1200px;
    margin:0 auto;
    padding:0 20px;
}

.collections-section h2{
    text-align:center;
    color:var(--bordeaux);
    text-transform:uppercase;
    margin-bottom:40px;
}

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

.collection-card{
    text-align:center;
}

.collection-card img{
    width:100%;
    border-radius:4px;
}

.collection-card h3{
    margin:15px 0 10px;
    font-size:18px;
    text-transform:uppercase;
}

.collection-card .btn{
    margin-top:10px;
}

/* =========================
   RESPONSIVE
========================= */

@media(max-width:1024px){

    .collections-grid{
        grid-template-columns:repeat(2,1fr);
    }

}

@media(max-width:768px){

    .collections-grid{
        grid-template-columns:1fr;
    }

}

/* =========================
   PINTEREST
========================= */

.pinterest-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
    margin-top:40px;
}

/* =========================
   TESTIMONIALS
========================= */

.testimonials{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:30px;
}

.testimonial{
    background:#fff;
    border:1px solid #e5e5e5;
    border-radius:8px;
    padding:30px;
    text-align:center;
}

.testimonials-section{
    max-width:1200px;
    margin:0 auto;
    padding:80px 0 140px;
}

.stars{
    color:var(--bordeaux);
    font-size:20px;
    margin-bottom:15px;
}

/* =========================
   NEWSLETTER
========================= */

.newsletter{
    background:var(--bordeaux);
    color:#fff;
    text-align:center;
    padding:80px 0;
    margin-bottom:120px;

    position:relative;
    left:50%;
    right:50%;
    margin-left:-50vw;
    margin-right:-50vw;
    width:100vw;
}

.newsletter .container{
    max-width:1600px;
    margin:0 auto;
    padding:0 20px;
}

.newsletter form{
    max-width:600px;
    margin:30px auto 0;
    display:flex;
    gap:10px;
}

.newsletter input{
    flex:1;
    padding:14px;
    border:none;
    border-radius:6px;
}

.newsletter button{
    background:var(--rose);
    color:#fff;
    border:none;
    padding:14px 25px;
    border-radius:6px;
    cursor:pointer;
}


/* =========================
   FOOTER
========================= */

.footer-logo{
    text-align:center;
    margin-bottom:25px;
}

.footer-logo img{
    max-width:280px;
    width:100%;
    height:auto;
    display:block;
    margin:0 auto;
}
.site-footer{
    background:var(--noir);
    color:#fff;
    padding:60px 0 20px;
    margin-top:120px;
}

.site-footer .container{
    max-width:1200px;
    margin:0 auto;
}

.footer-grid{
    display:flex;
    justify-content:center;
    text-align:center;
}

.footer-menu{
    display:flex;
    gap:20px;
    justify-content:center;

    list-style:none;
    margin:20px 0 0;
    padding:0;
}



.footer-menu li{
    margin:0;
    padding:0;
}


.footer-menu a{
    color:#fff;
    padding:8px 12px;
    border-radius:6px;
    text-decoration:none;
    transition:.3s;
}

.footer-menu a:hover{
    background:rgba(255,255,255,.15);
}

.footer-bottom{
    margin-top:40px;
    padding-top:20px;
    border-top:1px solid rgba(255,255,255,.2);
    text-align:center;
}

.site-footer ul,
.site-footer li,
.site-footer .sub-menu{
    list-style:none !important;
    margin:0 !important;
    padding:0 !important;
}

.site-footer .menu{
    display:flex;
    justify-content:center;
    gap:20px;
}

.site-footer .sub-menu{
    display:none;
}
/* =========================
   RESPONSIVE
========================= */

@media(max-width:1024px){

    .hero-container,
    .creator{
        grid-template-columns:1fr;
    }

    .collections,
    .process-grid,
    .testimonials,
    .footer-grid{
        grid-template-columns:repeat(2,1fr);
    }

}

@media(max-width:768px){

    .header-inner{
        flex-direction:column;
        gap:20px;
    }

    .main-menu{
        flex-wrap:wrap;
        justify-content:center;
    }

    .hero{
        padding:60px 20px;
    }

    .hero-content h1{
        font-size:2.3rem;
    }

    .collections,
    .process-grid,
    .pinterest-grid,
    .testimonials,
    .footer-grid{
        grid-template-columns:1fr;
    }

    .newsletter form{
        flex-direction:column;
    }

}

/* =========================
   WOOCOMMERCE
========================= */

.shop-header{
    text-align:center;
    background:var(--gris);
}

.shop-header h1{
    margin-bottom:15px;
}






.single-product-section{
    padding:80px 40px;
}

.single-product .product{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:50px;
}

.single-product .price{
    color:var(--bordeaux);
    font-size:1.5rem;
    font-weight:bold;
}

.single-product .single_add_to_cart_button{
    background:var(--bordeaux) !important;
}

@media(max-width:768px){


    .single-product .product{
        grid-template-columns:1fr;
    }

}
/* =========================
   BOUTIQUE - PRODUITS
========================= */
.woocommerce ul.products,
.featured-products ul.products {
    display: grid !important;
    grid-template-columns: repeat(5, 1fr) !important;
    gap: 20px !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.woocommerce ul.products li.product,
.featured-products ul.products li.product {
    width: auto !important;
    float: none !important;
    clear: none !important;
    margin: 0 !important;
}

.woocommerce ul.products li.product.first,
.woocommerce ul.products li.product:first-child {
    margin-left: 0 !important;
    clear: none !important;
}

.woocommerce ul.products li.product::before,
.woocommerce ul.products li.product::after,
.featured-products ul.products::before,
.featured-products ul.products::after {
    content: none !important;
    display: none !important;
}

.shop-products .container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 20px;
}

.woocommerce-checkout .woocommerce{
    max-width:1200px;
    margin:0 auto;
    padding:40px 20px;
}


/* =========================
   WOOCOMMERCE CONTAINER
========================= */

.woocommerce{
    max-width:none;
    margin:0;
    padding:0;
}

/* =========================
   PAGES WOOCOMMERCE
========================= */

.woocommerce-cart .woocommerce,
.woocommerce-account .woocommerce{
    max-width:1400px;
    margin:0 auto;
    padding:0 20px;
}
/* Boutons checkout */

.woocommerce button.button,
.woocommerce a.button,
.woocommerce input.button,
#place_order{
    background:#000 !important;
    color:#fff !important;
    border:none !important;
    border-radius:4px !important;
    padding:14px 24px !important;
    font-weight:600 !important;
}

.woocommerce button.button:hover,
.woocommerce a.button:hover,
.woocommerce input.button:hover,
#place_order:hover{
    background:#222 !important;
    color:#fff !important;
}
/* =========================
   MON COMPTE
========================= */

.woocommerce-account .woocommerce{
    max-width:1000px;
    margin:0 auto;
    padding:0 20px;
}

/* On supprime les colonnes WooCommerce */

.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content{
    float:none !important;
    width:100% !important;
}

/* Menu */

.woocommerce-account .woocommerce-MyAccount-navigation{
    margin:40px 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:12px;
    list-style:none;
    margin:0;
    padding:0;
    flex-wrap:nowrap;
    overflow-x:auto;
}

.woocommerce-account .woocommerce-MyAccount-navigation li{
    flex:0 0 auto;
}

.woocommerce-account .woocommerce-MyAccount-navigation a{
    display:block;
    padding:12px 18px;
    font-size:.95rem;
    background:#fff;
    border:1px solid #ddd;
    border-radius:8px;
    text-decoration:none;
    color:#222;
}

.woocommerce-account .woocommerce-MyAccount-navigation .is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation a:hover{
    background:var(--bordeaux);
    color:#fff;
    border-color:var(--bordeaux);
}

/* Contenu */

.woocommerce-account .woocommerce-MyAccount-content{
    max-width:760px;
    margin:40px auto 0;
    background:#fff;
    border:1px solid #eee;
    border-radius:10px;
    padding:40px;
    box-shadow:0 5px 20px rgba(0,0,0,.05);
}
/* =========================
   TOUS LES BOUTONS WOOCOMMERCE
========================= */
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.woocommerce-checkout #place_order,
.woocommerce .button.alt{
    background:#000 !important;
    color:#fff !important;
    border:none !important;
    border-radius:4px !important;

    padding:14px 24px !important;

    font-weight:600 !important;
    text-transform:none !important;

    transition:.2s;
}

/* Hover */
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover,
.woocommerce-checkout #place_order:hover,
.woocommerce .button.alt:hover{
    background:#222 !important;
    color:#fff !important;
}

/* Champs checkout */

.woocommerce-checkout input,
.woocommerce-checkout select,
.woocommerce-checkout textarea{
    border:1px solid #ddd !important;
    border-radius:4px !important;
    padding:12px !important;
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce .button.alt{
    background:var(--rose-logo) !important;
    color:#fff !important;
    border:none !important;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce .button.alt:hover{
    background:#a82f60 !important;
    color:#fff !important;
}

/* =========================
   TITLE ET PRIXFICHE PRODUIT
========================= */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2{
    color:var(--bordeaux) !important;
}

.woocommerce ul.products li.product .price{
    color:#7a7a7a !important;
    font-weight:600;
}

/* =========================
   FICHE PRODUIT
========================= */

.single-product .product{
    max-width:1400px;
    margin:0 auto;
    padding:60px 40px;
}

/* Titre */
.single-product .product_title{
    color:var(--bordeaux) !important;
    font-size:3rem;
    line-height:1.15;
    font-weight:700;
    margin-bottom:20px;
}

/* Prix */
.single-product .price{
    color:#7a7a7a !important;
    font-size:1.4rem;
    font-weight:600;
    margin-bottom:30px;
}

/* Image produit */
.single-product div.product div.images img{
    border-radius:0;
    box-shadow:none;
}

/* Description courte */
.single-product .woocommerce-product-details__short-description{
    margin:30px 0;
    color:#555;
    line-height:1.8;
}

/* Champ quantité */
.single-product .quantity .qty{
    height:42px;
    width:60px;
    border:1px solid #d8d8d8;
}

/* Bouton panier */
.single-product .single_add_to_cart_button{
    background:var(--bordeaux) !important;
    color:#fff !important;
    border:none !important;
    padding:14px 30px !important;
    font-weight:600;
}

.single-product .single_add_to_cart_button:hover{
    opacity:.9;
}

/* Catégorie */
.single-product .product_meta{
    margin-top:30px;
    color:#666;
}

.single-product .product_meta a{
    color:var(--bordeaux);
    text-decoration:none;
}

/* Onglets description */
.woocommerce-tabs{
    margin-top:80px;
}
/* =========================
   IMAGE FICHE PRODUIT
========================= */

.woocommerce div.product div.images img{
    display:block;
    width:100%;
    height:auto;
}

.woocommerce div.product div.images{
    background:#fff;
    border:1px solid #e5e5e5;
    border-radius:8px;
    padding:15px;
    box-sizing:border-box;
}
/* =========================
   PAGE
========================= */

.page-content{
    max-width: 1400px;
    padding:80px 40px;
    margin-bottom:120px;
}

/* =========================
   BLOG
========================= */

.blog-single{
    max-width: 1400px;
    padding:80px 40px;
}

.post-thumbnail{
    margin-bottom:30px;
}

.post-thumbnail img{
    width:100%;
    border-radius:12px;
}

.post-meta{
    margin:15px 0;
    color:#777;
}

.post-content{
    max-width: 1400px;
    margin-top:20px;
}

/* =========================
   SEARCH
========================= */

.search-item{
    padding:20px 0;
    border-bottom:1px solid #ddd;
}

.search-item h2{
    margin-bottom:10px;
}

/* =========================
   404
========================= */

.error-404{
    text-align:center;
    padding:120px 20px;
}

.error-404 h1{
    font-size:6rem;
    color:var(--bordeaux);
}



.featured-products ul.products{
    display:grid !important;
    grid-template-columns:repeat(5,1fr) !important;
    gap:20px !important;
    list-style:none !important;
    padding:0 !important;
    margin:0 !important;
}

.featured-products ul.products li.product{
    width:auto !important;
    float:none !important;
    clear:none !important;
    margin:0 !important;
}



/* =========================
   FEATURED PRODUCTS
========================= */
.featured-products {
    max-width: 1400px;          /* limite la largeur générale */
    margin: 0 auto;             /* centre la section */
    padding: 0 20px;            /* espace sur les côtés */
    margin-bottom:120px;
}

.featured-products h2 {
    margin-bottom: 30px;        /* espace entre le titre et les produits */
}

.featured-products ul.products {
    display: grid !important;
    grid-template-columns: repeat(5, 1fr) !important; /* 5 produits par ligne */
    gap: 20px !important;       /* espace entre produits */
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
/* =========================
   CARTES PRODUITS ACCUEIL + BOUTIQUE
========================= */

.featured-products ul.products li.product,
.shop-products ul.products li.product{
    width:auto !important;
    float:none !important;
    clear:none !important;
    margin:0 !important;

    background:#fff;
    border:1px solid #e5e5e5;
    border-radius:8px;
    padding:15px;

    transition:.2s;
}

/* Hover */
.featured-products ul.products li.product:hover,
.shop-products ul.products li.product:hover{
    transform:translateY(-3px);
    box-shadow:0 6px 18px rgba(0,0,0,.08);
}

/* =========================
   CARTES PRODUITS PARTOUT
========================= */

.woocommerce ul.products li.product{
    background:#fff;
    border:1px solid #e5e5e5;
    border-radius:8px;
    padding:15px;
    transition:.2s;
    box-sizing:border-box;
}

/* Hover */
.woocommerce ul.products li.product:hover{
    transform:translateY(-3px);
    box-shadow:0 6px 18px rgba(0,0,0,.08);
}
/* Produits similaires */
.related ul.products li.product{
    background:#fff;
    border:1px solid #e5e5e5;
    border-radius:8px;
    padding:15px;
    transition:.2s;
}

.related ul.products li.product:hover{
    transform:translateY(-3px);
    box-shadow:0 6px 18px rgba(0,0,0,.08);
}
.related h2{
    color:var(--bordeaux);
    margin-bottom:30px;
}

/* Corrige le premier produit */
.featured-products ul.products li.product:first-child,
.shop-products ul.products li.product:first-child{
    margin-left:0 !important;
}

/* WooCommerce */
.woocommerce ul.products li.product.first{
    margin-left:0 !important;
    clear:none !important;
}

/* Supprime toutes les marges héritées */
.woocommerce ul.products li.product{
    margin-left:0 !important;
}

/* Supprime les pseudo-éléments qui créent parfois du blanc */
.featured-products ul.products::before,
.featured-products ul.products::after,
.shop-products ul.products::before,
.shop-products ul.products::after{
    display:none !important;
    content:none !important;
}

/* Assure l'alignement des cartes */
.featured-products ul.products li.product img,
.shop-products ul.products li.product img{
    width:100%;
    height:auto;
    display:block;
}