/**
 * Theme Name:     Artecollezione
 * Author:         Alain DORENLOT
 * Template:       Divi
 * Text Domain:    artecollezione
 * Description:    Arte Collezione est une société française spécialiste des bijoux agrémentés de diamants.
 * Author URI:     https://dorenlot.fr
 * Version:        1.0
 */

/* =========================================================
   01 - MENU / HEADER DIVI
   ========================================================= */

/* Sous-menus plus larges */
ul.sub-menu {
    min-width: 300px;
    white-space: normal;
}

ul.sub-menu li {
    min-width: 100%;
}

ul.sub-menu a {
    display: inline-block;
    white-space: nowrap;
}

/* Barre supérieure Divi */
#et-info,
#et-info span,
#et-info a {
    color: #000 !important;
}

#et-info {
    display: flex;
    align-items: center;
    width: 100%;
}

.custom-user-bar {
    color: #fff;
    font-family: 'Proza Libre', sans-serif;
    font-size: 14px;
}

.custom-user-bar a {
    color: #fff;
    text-decoration: underline;
}

.custom-user-bar strong {
    font-weight: 700;
}

.custom-user-bar-wrapper {
    display: flex;
    align-items: center;
    width: 100%;
}

.left-part {
    margin-right: auto;
}

.right-part {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-left: auto;
}

.account-link {
    color: #f25c54;
    font-weight: 600;
    text-decoration: none;
}

#et-secondary-menu {
    display: flex;
    align-items: center;
    margin: 0 0 0 15px !important;
}

#et-top-navigation {
    display: flex;
    align-items: center;
    justify-content: space-between;
}


/* =========================================================
   02 - FORMULAIRES / SELECT
   ========================================================= */

/* Supprime la flèche native des select */
select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding-right: 30px;
}

/* Supprime la flèche ajoutée par Divi/WooCommerce */
.et_pb_wc_cart_products select,
.woocommerce select {
    background-image: none !important;
}


/* =========================================================
   03 - PAGE PRODUIT : GALERIE IMAGE
   ========================================================= */

/* Vignettes à gauche de l'image produit */
.single-product div.product .woocommerce-product-gallery {
    display: flex;
    flex-direction: row-reverse;
    align-items: flex-start;
    gap: 20px;
}

.single-product div.product .woocommerce-product-gallery .flex-control-thumbs {
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: 15%;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box;
}

.single-product div.product .woocommerce-product-gallery .flex-viewport {
    width: 85%;
    margin: 0;
    margin-right: auto;
    padding: 0;
    box-sizing: border-box;
}

.woocommerce div.product div.images .flex-control-thumbs li {
    width: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
}


/* =========================================================
   04 - WOOCOMMERCE : GRILLE CATEGORIES + PRODUITS
   ========================================================= */

/* Cache les compteurs de catégories */
mark.count {
    display: none !important;
}

/* Titres produits et catégories */
.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product-category h2,
.woocommerce ul.products li.product-category .woocommerce-loop-category__title,
.woocommerce ul.products li.product h2.woocommerce-loop-product__title {
    width: 100%;
    text-align: center !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 20px !important;
    font-weight: 500;
    line-height: 1.3;
}

/* Pas de cadre autour des cartes */
.woocommerce ul.products li.product,
.woocommerce ul.products li.product-category {
    border: none !important;
    padding: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    box-sizing: border-box !important;
}

/* Images carrées : produits + catégories */
.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product-category a img {
    width: 100% !important;
    aspect-ratio: 1 / 1;
    object-fit: contain;
    object-position: center;
    background: #fff !important;
    border: 1px solid #cfcfcf !important;
    border-radius: 8px !important;
    padding: 8px !important;
    box-sizing: border-box !important;
    transition: transform 0.25s ease, border-color 0.25s ease;
}

/* Zoom léger au survol */
.woocommerce ul.products li.product:hover img,
.woocommerce ul.products li.product-category:hover img {
    transform: scale(1.02);
    border-color: #888 !important;
}

/* Desktop : 5 éléments par ligne */
@media (min-width: 981px) {
    body.woocommerce ul.products li.product,
    body .woocommerce ul.products li.product,
    body .woocommerce ul.products li.product-category,
    body .et_pb_module .woocommerce ul.products li.product,
    body .et_pb_module .woocommerce ul.products li.product-category {
        width: 18% !important;
        max-width: 18% !important;
        margin: 0 1% 30px 1% !important;
        float: left !important;
        clear: none !important;
    }

    body.woocommerce ul.products li.product:nth-child(4n+1),
    body .woocommerce ul.products li.product:nth-child(4n+1),
    body .woocommerce ul.products li.product-category:nth-child(4n+1),
    body .et_pb_module .woocommerce ul.products li.product:nth-child(4n+1),
    body .et_pb_module .woocommerce ul.products li.product-category:nth-child(4n+1) {
        clear: none !important;
    }

    body.woocommerce ul.products li.product:nth-child(5n+1),
    body .woocommerce ul.products li.product:nth-child(5n+1),
    body .woocommerce ul.products li.product-category:nth-child(5n+1),
    body .et_pb_module .woocommerce ul.products li.product:nth-child(5n+1),
    body .et_pb_module .woocommerce ul.products li.product-category:nth-child(5n+1) {
        clear: both !important;
    }
}

/* Tablette : 3 éléments par ligne */
@media (min-width: 768px) and (max-width: 980px) {
    body .woocommerce ul.products li.product,
    body .woocommerce ul.products li.product-category,
    body .et_pb_module .woocommerce ul.products li.product,
    body .et_pb_module .woocommerce ul.products li.product-category {
        width: 31.33% !important;
        max-width: 31.33% !important;
        margin: 0 1% 30px 1% !important;
        float: left !important;
        clear: none !important;
    }

    body .woocommerce ul.products li.product:nth-child(3n+1),
    body .woocommerce ul.products li.product-category:nth-child(3n+1),
    body .et_pb_module .woocommerce ul.products li.product:nth-child(3n+1),
    body .et_pb_module .woocommerce ul.products li.product-category:nth-child(3n+1) {
        clear: both !important;
    }
}

/* Mobile : 2 éléments par ligne */
@media (max-width: 767px) {
    body .woocommerce ul.products li.product,
    body .woocommerce ul.products li.product-category,
    body .et_pb_module .woocommerce ul.products li.product,
    body .et_pb_module .woocommerce ul.products li.product-category {
        width: 48% !important;
        max-width: 48% !important;
        margin: 0 1% 25px 1% !important;
        float: left !important;
        clear: none !important;
    }

    body .woocommerce ul.products li.product:nth-child(2n+1),
    body .woocommerce ul.products li.product-category:nth-child(2n+1),
    body .et_pb_module .woocommerce ul.products li.product:nth-child(2n+1),
    body .et_pb_module .woocommerce ul.products li.product-category:nth-child(2n+1) {
        clear: both !important;
    }
}


/* =========================================================
   05 - FORMULAIRE LOGIN WOOCOMMERCE
   ========================================================= */

.woocommerce form.login {
    max-width: 600px;
    margin: auto;
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 12px;
    padding: 30px;
    background: rgba(0,0,0,0.5);
    backdrop-filter: blur(8px);
}

.woocommerce form .form-row input.input-text {
    width: 100%;
    padding: 14px;
    background: rgba(0,0,0,0.6) !important;
    color: #fff;
    border: 1px solid #fff;
    border-radius: 8px !important;
    font-family: 'Proza Libre', sans-serif;
    font-size: 16px;
    transition: all 0.3s ease;
}

.woocommerce form .form-row input.input-text:focus {
    border-color: #f25c54;
    outline: none;
    box-shadow: 0 0 5px rgba(242, 92, 84, 0.5);
}

.woocommerce form .form-row label {
    color: #fff;
    font-weight: 500;
}

.woocommerce form .form-row .woocommerce-form__input-checkbox {
    accent-color: #f25c54;
}

.woocommerce-LostPassword a {
    color: #f25c54;
}

.woocommerce-LostPassword a:hover {
    color: #fff;
}


/* =========================================================
   06 - BOUTONS WOOCOMMERCE
   ========================================================= */

.woocommerce button.button,
.woocommerce button.button:hover,
.woocommerce button.button:focus,
.woocommerce button.button:active,
.woocommerce input.button,
.woocommerce input.button:hover {
    background: #f25c54 !important;
    color: #fff !important;
    border: 1px solid #f25c54 !important;
    border-radius: 100px !important;
    padding: 12px 30px !important;
    font-weight: 700;
    font-family: 'Proza Libre', sans-serif;
    transition: none !important;
    transform: none !important;
    box-shadow: none !important;
}

.woocommerce button.button:hover {
    opacity: 0.9 !important;
}

.woocommerce button.button::after {
    display: none !important;
}
