/*
 * Custom code goes here.
 * A template should always ship with an empty custom.css
 */
.logo {
    max-width:320px;
}
.header-top .form-search-control {
    background:white;
    border:solid 1px #e3e3e3;
    width:360px;
    color:#333;
    font-size:16px;
    border-radius:25px !important;
    padding:.8rem 2rem .8rem 1rem;
    font-weight:400;
}
#search_widget .input-group {
}
.header-top {
    padding-top:10px;
    padding-bottom:0;
}
.elementor-element-624fx0w {
    margin-top:22px;
}
.elementor-element-otahs7m {
    align-items:center;
}
.search-widget .search-btn {
    position:absolute;
    right:0;
    height:100%;
    z-index:4;
    background:none;
    cursor:pointer;
    border:none;
    padding:0 1em;
    font-size:16px;
    color:#d4af37;
}
#index #wrapper, #module-iqitelementor-Preview.elementor-landing-body #wrapper {
    padding-top:0;
    padding-bottom:0;
}
#close_menu {
    display:none;
}
.header-top .header-btn-w .header-btn .title {
    display:block !important;
    font-size:10px;
    font-weight:bold !important;
    color:#000;
}
.desktop-header-style-1 .search-widget, .desktop-header-style-2 .search-widget {
    max-width:100%;
}
.product-miniature {
    transition:border-color 0.3s ease; /* Transition pour un effet fluide */
}
.elementor-element-817uioo {
    margin-bottom:100px;
}
h2 {
    font-size:40px;
}
.elementor-element-s28n6pl {
    margin-bottom:25px;
}
.descTitleHn {
    font-style: normal;
    font-weight: 400;
    font-size: 18px;
    text-align: center;
    color: #5e5e5e;
    margin: 20px 0;
    position: relative;
    line-height: 1.5;
}

.col-header-center {
    text-align:center;
    display:flex;
    justify-content:center;
    align-items:center;
}
.product-miniature-grid .product-availability {
    display:none !important;
}
.mt-10 {
    margin-top:10px
}
.container-action-list-product {
    display:flex;
    align-items:center;
    justify-content:flex-end;
}
.products-sort-nb-dropdown a {
    padding:10px 20px;
}
.products-sort-nb-dropdown a .select-title .select-title-name {
    padding-right:15px;
}
.products-selection .form-control {
    padding:10px 20px;
    margin:0;
}
.products-selection {
    margin:0 0 1rem 0;
    padding:0;
    border-top:none;
    border-bottom:1px solid rgba(160, 160, 160, .25);
}
.pl_faceted_position_2 .col-xs-12 {
    display:flex;
    justify-content:space-between;
    align-items:center;
}
.titre_newsletter {
    color:#FFF;
    font-size:25px;
    font-weight:700;
    line-height:40px;
    padding-bottom:10px;
    text-align:left;
}
.texte_newsletter {
    color:#FFF;
    max-width:51%;
    font-size:16px;
}
.texte_newsletter p {
    line-height:20px;
    font-size:16px;
}
.product-flag {
    background:#000; /* couleur dorée */
    color:white; /* texte en noir pour contraste */
    font-size:14px;
    font-weight:700;
}
.product-flags .new {
    background:#d4af37; /* couleur dorée */
    color:white; /* texte en noir pour contraste */
}
.product-flags .product-flag {
    font-size:14px; /* ajusté à 14px */
    font-style:normal;
    font-weight:700; /* en gras */
    text-transform:none;
}
.reinsurance {
    display:flex;
    justify-content:space-around;
    padding:20px;
    background-color:#ffffff; /* Fond blanc */
}
.reinsurance-item {
    text-align:center;
    width:22%; /* Largeur ajustée pour bien répartir les éléments */
    padding:10px;
}
.reinsurance-icon {
    max-width:50px; /* Taille des icônes */
    margin-bottom:10px;
}
.reinsurance-title {
    color:#d4af37; /* Couleur dorée pour les titres */
    font-size:16px;
    font-weight:700;
    margin:5px 0;
}
.reinsurance-description {
    color:#000000; /* Texte en noir pour lisibilité sur fond blanc */
    font-size:14px;
    font-weight:300;
}
#footer .title {
    text-align: left;
    max-width: 1500px;
    width: 100%;
    margin: 0 auto;
}
.elementor-element-o9avn6d img {
    object-fit:cover;
    width:100%;
}
.elementor-element-66umnzz,
.elementor-element-omemn42 {
    margin-bottom:100px;
}
.elementor-element-d49m74l {
    margin-top: -400px;
    background: white;
    padding-top: 60px;
    padding-left: 60px;
    padding-right: 60px;
    width: 100%;
}

.elementor-element-d49m74l p {
    line-height:28px !important;
    letter-spacing:-.28px !important;
    font-size:17px;
}
#footer-container-main, #checkout-footer {
    color:#a3a3a3;
    background:#171717;
}
#wrapper {
    padding-bottom:5.857143rem;
}
.h2 {
    font-size:32px;
    margin-bottom:10px;
    padding-top:50px;
    padding-bottom:20px;
    font-weight:700;
}
.product-miniature-grid .product-price {
    font-size:16px;
}

.products-grid .product-miniature-layout-2 .product-description {
    padding: 15px 0;
}

.brand-text {
    margin-bottom: 4px;
    font-weight: bold;
    text-transform: uppercase;
}
.elementor-element-d49m74l h2 {
    font-size: 40px;
    letter-spacing: 0.4px;
    line-height: 45px;
    font-weight: 900;
    margin-bottom: 25px;
    margin-top: 0;
}
.elementor-element-ww04agb {
    width:25% !important;
}
.elementor-element-d49m74l {
    width:75% !important;
}
#footer-container-main {
    background-color:#171717; /* Fond sombre */
    padding:30px 0;
    color:#a3a3a3; /* Texte en gris clair */
}
#footer-container-main h5.block-title {
    color:#ffffff; /* Titres en blanc */
    font-size:18px;
    font-weight:700;
    margin-bottom:15px;
    border-bottom:1px solid #d4af37; /* Ligne dorée sous les titres */
    padding-bottom:10px;
}
#footer-container-main a {
    color:#c0c0c0; /* Liens en gris plus clair pour contraste */
    text-decoration:none;
    transition:color 0.3s;
}
#footer-container-main a:hover {
    color:#d4af37; /* Changement en doré au survol */
}
#footer-container-main .contact-rich .part {
    display:flex;
    align-items:center;
    margin-bottom:10px;
}
#footer-container-main .contact-rich .icon {
    color:#d4af37; /* Icônes dorées */
    font-size:18px;
    margin-right:10px;
}
#footer-container-main .block-content ul {
    list-style:none;
    padding:0;
    margin:0;
}
#footer-container-main .block-content ul li {
    margin-bottom:8px;
}
#footer-container-main hr {
    border:none;
    border-top:1px solid #555555; /* Ligne de séparation subtile entre les éléments */
    margin:10px 0;
}
#footer-container-main .copyright-img img {
    max-width:150px; /* Ajuste la taille de l'image des méthodes de paiement */
    opacity:0.7; /* Rend l'image discrète */
    transition:opacity 0.3s;
}
#footer-container-main .copyright-img img:hover {
    opacity:1; /* Met en surbrillance l'image au survol */
}
#footer-copyrights {
    background-color:#2b2b2b; /* Un gris plus clair pour le bas du footer */
    padding:15px 0;
    color:#a3a3a3;
    font-size:14px;
    text-align:center;
}
.c-footer__seo {
    margin-top:20px;
    padding:10px 0;
    color:#a3a3a3; /* Couleur du texte en gris clair pour le fond sombre */
    font-size:14px;
    line-height:1.6;
}
.c-footer__seo p {
    margin-bottom:15px; /* Espace entre les paragraphes */
}
.c-footer__seo a {
    color:#d4af37; /* Liens en doré pour cohérence avec le reste du footer */
    text-decoration:none;
    transition:color 0.3s;
}
.c-footer__seo a:hover {
    color:#ffffff; /* Changement au blanc au survol */
}
#footer-copyrights .container {
    text-align:center;
}
#footer-copyrights .copyright-img {
    text-align:right;
}
.footer-help {
    display:flex;
    align-items:flex-start;
    border:1px solid #fff;
    border-radius:5px;
    background-color:#2b2b2b;
    width:50%;
    margin-left:25%;
    margin-bottom:20px;
}
.footer-help-icon {
    display:flex;
    flex-direction:column;
    background-color:#ffffff;
    padding:20px;
    border-radius:5px 0 0 5px;
    color:#333333;
    font-weight:700;
    margin-right:10px;
    width:200px;
    text-align:center;
    align-items:center;
    justify-content:center;
    font-size:18px;
}
.footer-help-icon img {
    margin-top:10px;
    width:38px;
    height:auto;
}
.col-header-right {
    padding-top:40px;
}
.col-recherche-et-menu {
    text-align:center;
    display:flex;
    justify-content:center;
    align-items:flex-start;
    flex-direction:column;
    padding-top:40px;
}
.footer-help-buttons {
    display:flex;
    gap:10px;
    padding:14px;
    align-items:center;
    justify-content:center;
    width:100%;
    height:100%;
}
.footer-help-btn {
    border:1px solid #ffffff;
    color:#ffffff;
    border-radius:20px;
    text-decoration:none;
    transition:background-color 0.3s, color 0.3s;
    font-size:14px;
    font-weight:400;
    padding:10px 30px;
}
#footer-copyrights .copyright-img img {
    max-width:120px; /* Taille de l'image des moyens de paiement */
    opacity:0.7; /* Opacité pour un effet discret */
    transition:opacity 0.3s;
}
#footer-copyrights .copyright-img img:hover {
    opacity:1; /* Pleine opacité au survol */
}
#product #product-availability {
    display:none;
}
body#checkout section.checkout-step .step-number {
    display:inline-block;
    height:25px;
    width:25px;
    background-color:#d4af37;
    text-align:center;
    border-radius:25px;
    padding-top:2px;
    color:#fff;
    margin-right:3px;
}
.go-to-description {
    margin-top:1rem;
    margin-bottom:1rem;
    float:left;
    width:100%;
}
#product #content-wrapper h2.section-title {
    font-size:40px;
    margin-top:100px;
    color:#000;
    font-weight:400;    
}
#product #content-wrapper .section-title:after {
    display:none;
}
#product #content-wrapper .section-title {
    padding:0;
}
#content-wrapper .product_header_container .page-title, .exp-info-product {
    margin-bottom:1.2rem;
}
.product_header_container {
    padding-bottom:1rem;
    margin-bottom:0.2rem;
}
#footer-copyrights p,
#footer-copyrights a {
    color:#d0d0d0; /* Texte en gris clair pour contraste */
    margin:0;
    text-align:center;
}
.product_header_container, .product-additional-info {
    border:none;
}
.col-product-info #product .product-price {
    color: black;
    font-weight: 900;
    font-size: 45px;
    margin-top: 20px;
    float: left;
    width: 100%;
    margin-bottom: 15px;
}
.product_header_container .product-price, .product_p_price_container .product-price {
    font-size:2.25rem;
}
#product .brand-product {
    text-transform:uppercase;
    font-weight:600;
    font-size:14px;
}
#product h1 span {
    line-height:1.24;
    font-size:25px;
    font-weight:400;
}
.col-left-product-cover {
    border:1px solid #efefef;
}
@media (max-width:768px) {
    #footer-copyrights .container {
        flex-direction:column;
        text-align:center;
    }
    #footer-copyrights .copyright-img {
        margin-top:10px;
        text-align:center;
    }
}
.cart-products-count-btn {
    background:black;
}
.li-niveau1 a span {
    padding: 0px 10px 0px 10px;
    margin: 0px 0px 0px 0px;
}
#product .btn.add-to-cart  {
    font-weight: 500;
    width: 190px;
    font-size: 15px;
}
#product #ps_checkout-payment-method-logo-block-title {
    display:none;
}
.stuck #search_widget {
    display:none;
}
.stuck #adtm_menu {
    margin-top:0;
}
.stuck .logo {
    max-width:140px;
}
body {
    overflow-x: hidden;
}
.stuck #adtm_menu .li-niveau1 a.a-niveau1 .advtm_menu_span {
    font-size:14px;
}

.h2, .h2 span {
    font-size: 40px;
    margin-bottom: 10px;
    padding-top: 50px;
    padding-bottom: 20px;
    font-weight: 900;
    text-align: left;
}

.stuck .col-recherche-et-menu, .stuck .col-header-right {
    padding-top:0;
}
.elementor-element-6o02h4r,
.elementor-element-9v5uxw4  {
    margin-bottom:100px;
}
.elementor-element-dcpanzv {
    margin-bottom:30px;
}
#index h2.elementor-heading-title {
    font-size:40px;
    margin-bottom:20px;
    font-weight:bold;
}
#wrapper {
    background:white;
    box-shadow:none;
    color:black;
}
.flags-discount {
    position:relative;
    top:initial;
    left:initial;
}
.flags-discount li {
    background:black;
    font-size:12px !important;
}
.elementor-element-jpiz92p {
    padding:15px;
}

.product-miniature  .product-price-and-shipping {
    display: flex;
    align-items: center;
    gap: 8px;
}

.product-miniature  .regular-price.text-muted {
    font-size: 16px;
    color: #5e5e5e !important;
}

.rte-content ol, .rte-content ul {
    list-style: none; /* Supprime les puces par défaut */
    padding-left: 0; /* Supprime le décalage gauche */
}
#storytelling,
#introduction {
    list-style: none; /* Supprime les puces par défaut */
    padding-left: 0; /* Supprime le décalage gauche */
}
#storytelling li,
#introduction li {
    position: relative; /* Nécessaire pour placer l'image */
    padding-left: 30px; /* Décale le texte pour laisser de la place à l'image */
    margin-bottom: 10px; /* Espace entre les éléments */
}
#storytelling li::before ,
#introduction li::before {
    content: url('/img/check-list.png'); /* Chemin vers votre image */
    position: absolute; /* Place l'image à gauche du texte */
    left: 0; /* Aligne l'image avec le texte */
    top: 0; /* Ajuste l'alignement vertical si nécessaire */
    width: 20px; /* Optionnel : ajuste la taille de l'image */
    height: 20px; /* Optionnel : ajuste la taille de l'image */
}
.two-columns {
    column-count: 2; /* Nombre de colonnes */
    column-gap: 20px; /* Espace entre les colonnes */
}
.btn-primary {
    transition: all 0.3s ease-in-out; /* Animation fluide */
}
#product-images-thumbs.swiper-container-vertical .thumb-container {
    padding:0;
}
#product-images-thumbs img {
    width: 131px !important;
    height: auto;
    scale:1;
}
.swiper-container-vertical>.swiper-wrapper {
    flex-direction: column;
    gap: 20px;
}
.col-product-info {
    padding-left:50px;
}
.col-left-product-thumbs {
   margin-top:9px;
}
/* Hover sur le bouton */
.btn-primary:hover {
    box-shadow:0 8px 15px rgba(0, 0, 0, 0.2); /* Légère ombre portée */
    transform:translateY(-2px); /* Légère élévation */
}

#product-images-thumbs .swiper-slide {
    height:131px !important;
}

.razzi-tab-wrapper {
    margin: 20px 0;
    border-radius: 5px;
    overflow: hidden;
}
.razzi-static-layout {
    display: none;
}
.razzi-static-layout ul {
    list-style-type: disc;
    margin: 0;
    padding-left: 20px;
}
.razzi-static-layout li {
    margin-bottom: 10px;
    color: #000;
}
.razzi-tab-mobile {
    display: block;
}
.elementor-element-zsm5197 h4 {
    font-weight:bold;
    margin-bottom:10px;
}
.elementor-element-zsm5197,
.elementor-element-zsm5197 p,
.elementor-element-zsm5197 h4{
    font-size:12px;
    line-height:20px;
    text-align:justify;
}
.product-reference {
    display: flex;
    justify-content:flex-start;
    gap: 20px;
}
.info-item {
    display: flex;
    align-items: center;
    gap: 5px;
}
.info-reference {
    font-size: 15px;
}
.info-stock {
    color:#009688;
    font-size: 15px;
    font-weight: 700;
    line-height: 15px;
}

@media screen and (max-width: 1399px) {
    /* H1 "Bijoux de Prestige" */
    .elementor-element.elementor-element-wt53nin .elementor-heading-title {
        font-size: 34px;
    }

    /* "Qualité, Élégance, Savoir-Faire" (nécessite suppression du style inline) */
    .qualite-eleg-sf {
        font-size: 32px;
    }

    /* Blocs réassurance (2 colonnes) */
    .elementor-element-psig3hq .elementor-image-box-title,
    .elementor-element-9iv9eqw .elementor-image-box-title {
        font-size: 16px;
    }
    .elementor-element-psig3hq .elementor-image-box-description p,
    .elementor-element-9iv9eqw .elementor-image-box-description p {
        font-size: 14px;
    }
}

.qualite-eleg-sf {
    font-size: 42px;
    font-weight: 300;
    font-family: Roboto, sans-serif;
}

/* ===== ≤ 1024px (tablette) ===== */
@media screen and (max-width: 1024px) {
    .elementor-element.elementor-element-wt53nin .elementor-heading-title {
        font-size: 28px;
    }
    .qualite-eleg-sf { font-size: 26px; }

    .elementor-element-psig3hq .elementor-image-box-title,
    .elementor-element-9iv9eqw .elementor-image-box-title {
        font-size: 15px;
    }
    .elementor-element-psig3hq .elementor-image-box-description p,
    .elementor-element-9iv9eqw .elementor-image-box-description p {
        font-size: 13px;
    }

    #footer span.h2 { display: none; }
}
.cart-products-count-btn {
    background: #87adc9;
}

/*}*/
/* ===== ≤ 767px (mobile) ===== */
@media screen and (max-width: 767px) {

    .col-product-info {
        padding-left: 15px;
    }
    #product article .product-price {
        font-size: 16px;
    }
    .row-pourquoi-nous {
        display:none;
    }
    .elementor-element-jpiz92p {
        display:none;
    }
    .elementor-element.elementor-element-27vyr6k .elementor-iqit-banner .elementor-iqit-banner-title {
        font-size: 48px;
    }
    .elementor-element.elementor-element-frzsr2p .elementor-iqit-banner .elementor-iqit-banner-title {
        font-size: 26px;
    }
    .elementor-element.elementor-element-frzsr2p .elementor-iqit-banner .elementor-iqit-banner-description {
        font-size: 12px;
    }
    .elementor-element-19nn7hd .elementor-column {
        width: 33.333333%;
    }
    .elementor-element-19nn7hd .elementor-column > div{
        padding: 3px;
    }
    #index .elementor-element-19nn7hd .elementor-column h2 {
        font-size: 16px;
    }
    #index .elementor-element-ro1anr6,
    #index .elementor-element-6o02h4r,
    #index .elementor-element-9v5uxw4,
    #index .elementor-element.elementor-element-19nn7hd {
        margin-bottom: 50px;
    }
    .elementor-element-d49m74l {
        margin-top: -400px;
        background: white;
        padding-top: 20px;
        padding-left: 10px;
        padding-right: 0px;
        width: 100%;
    }

    .elementor-element-d49m74l p {
        line-height: 24px !important;
        letter-spacing: 0 !important;
        font-size: 14px;
    }

    .elementor-element-d49m74l h2 {
        font-size: 16px;
        letter-spacing: 0.4px;
        line-height: 23px;
        font-weight: 900;
        margin-bottom: 5px;
        margin-top: 0;
    }
    .footer-help {
        width: calc(100% - 30px);
        margin-left: 15px;
        margin-bottom: 0px;
        margin-top: 10px;
    }
    .c-footer__seo {
        margin-top: 10px;
        width: calc(100% - 30px);
        margin-left: 15px;
        margin-bottom: 0px;
    }
    #index .elementor-element-19nn7hd .elementor-column .elementor-iqit-banner-subtitle {
        font-size: 12px;
    }
    .product-miniature-grid .product-title {
        font-size: 1.2rem;
    }

    #index .product-description {
        display: flex;
        align-items: center;
    }
    .logo {
        max-width:160px;
    }
    .elementor-element.elementor-element-wt53nin .elementor-heading-title {
        font-size: 40px;
        line-height: 1.2;
        margin-bottom: .5rem;
    }
    .qualite-eleg-sf { font-size: 22px; }

    .elementor-element-psig3hq .elementor-image-box-title,
    .elementor-element-9iv9eqw .elementor-image-box-title {
        font-size: 14px;
    }
    .elementor-element-psig3hq .elementor-image-box-description p,
    .elementor-element-9iv9eqw .elementor-image-box-description p {
        font-size: 12px;
    }
}
@media screen and (max-width: 620px) {
    #footer .reinsurance {
        display:none;
    }
    .img_newsletter {
        display:none !important;
    }
    .elementor-element.elementor-element-wt53nin .elementor-heading-title,
    {
        font-size: 32px;
        margin-bottom: 20px;
    }

    .elementor-element.elementor-element-60zaf4c .elementor-iqit-banner .elementor-iqit-banner-title {
        margin: 24px 0;
        color: #ffffff;
        font-size: 36px;
    }
    .elementor-element.elementor-element-60zaf4c .elementor-button {
        margin-top: 20px;
        font-size: 12px;
    }
    .elementor-element.elementor-element-60zaf4c .elementor-iqit-banner .elementor-iqit-banner-description {
        font-size: 22px;
    }
    .elementor-element.elementor-element-60zaf4c .elementor-iqit-banner-content{
    text-align: left;
    padding: 5%;
}
    .texte_newsletter p {
        line-height: 16px;
        font-size: 12px;
    }
    .texte_newsletter {
        color: #FFF;
        max-width: 100%;
        font-size: 12px;
    }
    .elementor-element.elementor-element-27vyr6k .elementor-iqit-banner .elementor-iqit-banner-title {
        font-size: 28px;
    }
    .elementor-element-wvpk0yc {
        margin-bottom:50px;
    }
    .elementor-element.elementor-element-27vyr6k .elementor-iqit-banner .elementor-iqit-banner-description {
        font-size: 18px;
    }
    .elementor-element-d49m74l {
        display: none;
    }

    .elementor-element-ww04agb {
        display: none;
        width: 0 !important;
    }
    .elementor-element-o9avn6d {
        display: none !important;
        width: 0 !important;
    }
    .elementor-element-66umnzz, .elementor-element-omemn42 {
        margin-bottom: 50px !important;
    }
}
/* ===== ≤ 480px (petits smartphones) ===== */
@media screen and (max-width: 480px) {
    .elementor-element.elementor-element-wt53nin .elementor-heading-title {
        font-size: 20px;
    }
    #mobile-header .mobile-main-bar {
        padding-top: 1rem;
        padding-bottom: 1rem;
    }
    #index .elementor-element.elementor-element-60zaf4c .elementor-button {
        margin-top: 5px;
    }
    #index .elementor-element.elementor-element-60zaf4c .elementor-iqit-banner .elementor-iqit-banner-title {
        margin: 10px 0;
        font-size: 26px;
    }
    #index .elementor-element.elementor-element-60zaf4c .elementor-iqit-banner .elementor-iqit-banner-description {
        font-size: 12px;
    }
    .qualite-eleg-sf { font-size: 18px; }

    #index .elementor-element-psig3hq .elementor-image-box-title,
    #index .elementor-element-9iv9eqw .elementor-image-box-title {
        font-size: 13px;
    }
    #index .elementor-element-psig3hq .elementor-image-box-description p,
    #index .elementor-element-9iv9eqw .elementor-image-box-description p {
        font-size: 11px;
    }
    #index .elementor-element-66umnzz, .elementor-element-omemn42 {
        margin-bottom: 50px !important;
        display: none;
    }
    #index .footer-help-icon {
        display:none;
    }
    #index .elementor-element.elementor-element-27vyr6k .elementor-iqit-banner .elementor-iqit-banner-description,
    #index .elementor-element-19nn7hd .elementor-column .elementor-iqit-banner-subtitle {
        display:none;
    }
    #index .elementor-iqit-banner-title,
    #index .elementor-text-editor > h2 {
        font-size: 26px;
    }
    .elementor-button.elementor-size-medium {
        font-size: 11px;
    }
    #index .elementor-element-19nn7hd .elementor-column h2 {
        font-size: 14px;
        letter-spacing: 1.3px;
        margin-bottom: 5px;
    }
    .descTitleHn {
        display:none;
    }
}

/* ===== ≤ 360px (ultra-compact) ===== */
@media screen and (max-width: 360px) {
    .elementor-element.elementor-element-wt53nin .elementor-heading-title {
        font-size: 18px;
    }
    .qualite-eleg-sf { font-size: 16px; }

    .elementor-element-psig3hq .elementor-image-box-title,
    .elementor-element-9iv9eqw .elementor-image-box-title {
        font-size: 12px;
    }
    .elementor-element-psig3hq .elementor-image-box-description p,
    .elementor-element-9iv9eqw .elementor-image-box-description p {
        font-size: 10px;
    }
}

@media (max-width: 768px) {
    .mobile-product-header {
        text-align: center;
        margin-bottom: 10px;
    }
    .mobile-product-header .page-title {
        font-size: 1.3rem;
        margin-bottom: 5px;
    }
    .mobile-product-header .info-item {
        display: inline-block;
        margin: 0 5px;
        font-size: 0.9rem;
    }

    #product .product-price {
        font-size: 24px;
    }
}

@media (max-width: 990px) {
    /* === BASE === */
    .loupita-menu {
        position: fixed;
        inset: 0;
        background: #fff;
        color: #111;
        transform: translateX(-100%);
        transition: transform 0.4s ease;
        z-index: 9999;
        font-family: 'Montserrat', sans-serif;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }

    .loupita-menu.active {
        transform: translateX(0);
    }

    .menu-overlay {
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.1);
    }

    .menu-panel {
        position: relative;
        z-index: 2;
        width: 85%;
        height: 100%;
        background: #fff;
        padding: 2rem 1.5rem;
        overflow-y: auto;
        box-shadow: 0 0 20px rgba(0,0,0,0.1);
    }

    /* === HEADER === */
    .menu-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 1.5rem;
    }

    .menu-logo img {
        height: 60px;
        width: auto;
    }

    .burger-close {
        background: none;
        border: none;
        cursor: pointer;
        padding: 0.5rem;
        stroke: #000;
        transition: stroke 0.3s ease;
    }
    .burger-close:hover svg {
        stroke: #d4af37;
    }

    /* === NAVIGATION === */
    .menu-nav ul {
        list-style: none;
        padding: 0;
        margin: 0;
    }

    .menu-section {
        border-bottom: 1px solid #eee;
    }

    .menu-title {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 1.1rem 0;
        font-size: 0.95rem;
        color: #111;
        font-weight: 600;
        text-decoration: none;
        text-transform: uppercase;
        transition: color 0.2s;
    }

    .menu-title svg {
        stroke: #d4af37;
        width: 18px;
        height: 18px;
        flex-shrink: 0;
        margin-left: 8px;
        transition: transform 0.3s ease;
    }

    .menu-title:hover {
        color: #d4af37;
    }

    .menu-section.open .menu-title svg {
        transform: translateX(4px);
    }

    /* === SOUS-MENUS === */
    .submenu {
        display: none;
        padding-left: 0.8rem;
        margin-bottom: 0.8rem;
    }

    .menu-section.open .submenu {
        display: block;
    }

    .submenu a {
        display: block;
        padding: 0.6rem 0;
        color: #444;
        font-size: 0.9rem;
        font-weight: 500;
        text-decoration: none;
        transition: color 0.2s;
    }

    .submenu a:hover {
        color: #d4af37;
    }

    /* === FOOTER === */
    .menu-footer {
        margin-top: 2rem;
        border-top: 1px solid #eee;
        padding-top: 1.2rem;
        text-align: center;
    }

    .footer-links {
        margin-bottom: 1rem;
    }

    .footer-links a {
        display: inline-block;
        margin: 0 0.6rem;
        color: #444;
        font-size: 0.8rem;
        font-weight: 600;
        text-decoration: none;
        transition: color 0.2s;
    }

    .footer-links a:hover {
        color: #d4af37;
    }

    .footer-social {
        margin-top: 0.8rem;
    }

    .social-title {
        font-size: 0.75rem;
        color: #999;
        margin-bottom: 0.5rem;
        letter-spacing: 0.5px;
    }

    .social-icons {
        display: flex;
        justify-content: center;
        gap: 1rem;
    }

    .social-link svg {
        transition: transform 0.2s ease, opacity 0.2s ease;
        opacity: 0.9;
    }

    .social-link:hover svg {
        transform: scale(1.1);
        opacity: 1;
    }

    #loupita-mobile-menu .social-link.facebook svg { stroke: #1877F2; }
    #loupita-mobile-menu  .social-link.instagram svg { stroke: #E1306C; }
    #loupita-mobile-menu .social-link.pinterest svg { stroke: #E60023; }

    .footer-mention {
        margin-top: 1rem;
        font-size: 0.7rem;
        color: #888;
        letter-spacing: 0.4px;
    }


}

.ps-shoppingcart .cart-products-count-btn {
    top: -2px;
    right: 40px;
}