/**
 * Red Moon Studio — WooCommerce
 * @package RedMoon v1.2.0
 */

/* ══════════════════════════════════════════════════════
   RESET GLOBAL
══════════════════════════════════════════════════════ */
.woocommerce-page .site-header { z-index: 1000; }

/* Supprimer sidebar */
.woocommerce-page .widget-area,
.woocommerce aside.woocommerce-sidebar,
#secondary,
.col2-set #col2 { display: none !important; }

/* Zone principale pleine largeur */
.woocommerce-page #primary,
.woocommerce-page #main,
.woocommerce-page .woocommerce,
.woocommerce-page .woocommerce-page { width: 100% !important; max-width: 100% !important; float: none !important; }

/* ══════════════════════════════════════════════════════
   GRILLE — sélecteurs WooCommerce NATIFS + rm-*
══════════════════════════════════════════════════════ */

/* Forcer grille sur ul.products quelle que soit la source */
.woocommerce ul.products,
.woocommerce-page ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 0 !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    float: none !important;
    clear: both !important;
    background: transparent !important;
}
@media (min-width: 1400px) {
    .woocommerce ul.products,
    .woocommerce-page ul.products { grid-template-columns: repeat(4, 1fr) !important; }
}
@media (max-width: 900px) {
    .woocommerce ul.products,
    .woocommerce-page ul.products { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 480px) {
    .woocommerce ul.products,
    .woocommerce-page ul.products { grid-template-columns: 1fr !important; }
}

/* ══════════════════════════════════════════════════════
   CARTE PRODUIT — styles sur classes WooCommerce NATIFS
   (fonctionnent même si content-product.php n'est pas chargé)
══════════════════════════════════════════════════════ */

/* Li produit */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
    background: #141414 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid rgba(255,255,255,0.04) !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    float: none !important;
    width: auto !important;
    transition: background .25s !important;
    position: relative !important;
}
.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover { background: #1c1c1c !important; }

/* ── IMAGE : ZONE CARRÉE FIXE ─────────────────────── */

/* Le lien image qui entoure la miniature */
.woocommerce ul.products li.product > a:first-child,
.woocommerce-page ul.products li.product > a:first-child,
.woocommerce ul.products li.product .woocommerce-LoopProduct-link,
.rm-product-img-wrap {
    display: block !important;
    position: relative !important;
    width: 100% !important;
    aspect-ratio: 1 / 1 !important;
    overflow: hidden !important;
    background: #1a1a1a !important;
    flex-shrink: 0 !important;
}

/* Image elle-même — toutes les classes possibles */
.woocommerce ul.products li.product > a:first-child img,
.woocommerce ul.products li.product .woocommerce-LoopProduct-link img,
.woocommerce ul.products li.product img.wp-post-image,
.woocommerce ul.products li.product img.attachment-woocommerce_thumbnail,
.woocommerce ul.products li.product .rm-product-img,
.rm-product-img-wrap img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    padding: 10% !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    transition: transform .4s ease !important;
}
.woocommerce ul.products li.product:hover img,
.rm-product-card:hover .rm-product-img-wrap img {
    transform: scale(1.04) !important;
}

/* ── TEXTE SOUS L'IMAGE ───────────────────────────── */

/* Titre natif WooCommerce */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.rm-product-title {
    font-family: var(--font-body) !important;
    font-size: 0.72rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: var(--color-text) !important;
    padding: 0.9rem 1rem 0.2rem !important;
    margin: 0 !important;
    line-height: 1.35 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}
.rm-product-title a { color: inherit; text-decoration: none; }
.rm-product-title a:hover { color: var(--color-primary); }

/* Prix natif WooCommerce */
.woocommerce ul.products li.product .price,
.rm-product-price {
    color: var(--color-primary) !important;
    font-family: var(--font-display) !important;
    font-size: 1.15rem !important;
    letter-spacing: 0.02em !important;
    padding: 0 1rem 0.5rem !important;
    display: block !important;
    margin: 0 !important;
    line-height: 1.2 !important;
}
.woocommerce ul.products li.product .price del,
.rm-product-price del {
    color: var(--color-muted) !important;
    font-size: 0.78rem !important;
    font-family: var(--font-body) !important;
}
.woocommerce ul.products li.product .price ins,
.rm-product-price ins { text-decoration: none !important; }

/* Bouton natif WooCommerce */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.button,
.rm-product-actions .button,
.rm-btn-view {
    display: block !important;
    margin: 0.2rem 1rem 1rem !important;
    padding: 0.55rem 0.5rem !important;
    background: transparent !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    color: rgba(255,255,255,0.35) !important;
    font-size: 0.6rem !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
    font-family: var(--font-body) !important;
    font-weight: 400 !important;
    cursor: pointer !important;
    transition: all .2s !important;
    text-align: center !important;
    border-radius: 0 !important;
    width: calc(100% - 2rem) !important;
    box-sizing: border-box !important;
    text-decoration: none !important;
    line-height: 1 !important;
}
.woocommerce ul.products li.product .button:hover,
.rm-product-actions .button:hover,
.rm-btn-view:hover {
    background: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
    color: #fff !important;
}
.woocommerce ul.products li.product .added_to_cart { display: none !important; }

/* Badge promo */
.woocommerce span.onsale,
.rm-badge-sale {
    position: absolute !important;
    top: 8px !important; left: 8px !important; right: auto !important;
    background: var(--color-primary) !important;
    color: #fff !important;
    font-size: 0.6rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    border-radius: 0 !important;
    min-width: auto !important;
    min-height: auto !important;
    line-height: 1 !important;
    padding: 4px 8px !important;
}

/* ── INFOS ZONE (rm-product-info) ──────────────────── */
.rm-product-info {
    padding: 0;
    display: flex;
    flex-direction: column;
    flex: 1;
}

/* ══════════════════════════════════════════════════════
   BARRE TRI
══════════════════════════════════════════════════════ */
.woocommerce-result-count {
    color: var(--color-muted);
    font-size: 0.7rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin: 0;
}
.woocommerce-ordering select {
    background: var(--color-card);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    padding: 0.45rem 0.8rem;
    font-family: var(--font-body);
    font-size: 0.7rem;
    letter-spacing: 0.06em;
    cursor: pointer;
    outline: none;
    border-radius: 0;
}
.woocommerce-ordering select:focus { border-color: var(--color-primary); }

/* ══════════════════════════════════════════════════════
   PAGE PRODUIT UNIQUE
══════════════════════════════════════════════════════ */

.woocommerce div.product { max-width: 100%; }
.woocommerce div.product .woocommerce-product-gallery img { border: 1px solid var(--color-border); width: 100%; }
.woocommerce-product-details__short-description {
    color: var(--color-muted);
    font-size: 0.95rem;
    line-height: 1.8;
    margin-bottom: 2rem;
    border-top: 1px solid var(--color-border);
    padding-top: 1.5rem;
}
.woocommerce form.cart { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; margin-bottom: 2rem; }
.woocommerce form.cart .qty {
    background: var(--color-card) !important; border: 1px solid var(--color-border) !important;
    color: var(--color-text) !important; padding: 0.7rem 1rem !important; width: 80px !important; text-align: center; border-radius: 0;
}
.woocommerce form.cart .single_add_to_cart_button,
.woocommerce a.button.alt, .woocommerce button.button.alt {
    background: var(--color-primary) !important; color: #fff !important; border: none !important;
    border-radius: 0 !important; font-family: var(--font-body) !important; font-size: 0.78rem !important;
    letter-spacing: 0.14em !important; text-transform: uppercase !important; padding: 0.9rem 2.5rem !important;
    cursor: pointer !important; transition: background .2s !important;
}
.woocommerce form.cart .single_add_to_cart_button:hover { background: #e5000c !important; }

/* Onglets */
.woocommerce-tabs ul.tabs { list-style: none; display: flex; gap: 0; border-bottom: 1px solid var(--color-border); padding: 0; margin-bottom: 2rem; }
.woocommerce-tabs ul.tabs li { margin: 0; background: none !important; border: none !important; }
.woocommerce-tabs ul.tabs li a { display: block; padding: 0.75rem 1.5rem; font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-muted); text-decoration: none; border-bottom: 2px solid transparent; transition: color .2s, border-color .2s; }
.woocommerce-tabs ul.tabs li.active a, .woocommerce-tabs ul.tabs li a:hover { color: var(--color-text); border-bottom-color: var(--color-primary); }
.woocommerce-tabs .panel { color: var(--color-muted); font-size: 0.95rem; line-height: 1.8; }

/* Produits similaires */
.up-sells h2, .related h2 { font-family: var(--font-display); font-size: 1.8rem; letter-spacing: 0.05em; margin-bottom: 2rem; color: var(--color-text); }

/* ══════════════════════════════════════════════════════
   PANIER
══════════════════════════════════════════════════════ */
.woocommerce-cart-form { padding: 100px var(--gutter) 2rem; }
.woocommerce-cart .cart-collaterals { padding: 0 var(--gutter) 5vw; }
.woocommerce table.shop_table { border-collapse: collapse !important; width: 100% !important; background: var(--color-card) !important; border: 1px solid var(--color-border) !important; }
.woocommerce table.shop_table th { background: var(--color-dark) !important; color: var(--color-text) !important; font-family: var(--font-body) !important; font-size: 0.7rem !important; letter-spacing: 0.16em !important; text-transform: uppercase !important; padding: 1rem 1.5rem !important; border: none !important; border-bottom: 1px solid var(--color-border) !important; }
.woocommerce table.shop_table td { color: var(--color-muted) !important; padding: 1.2rem 1.5rem !important; border: none !important; border-bottom: 1px solid var(--color-border) !important; vertical-align: middle !important; background: var(--color-card) !important; }
.woocommerce table.shop_table .product-name a { color: var(--color-text) !important; }
.woocommerce table.shop_table .product-price, .woocommerce table.shop_table .product-subtotal { color: var(--color-primary) !important; font-family: var(--font-display) !important; font-size: 1.3rem !important; }
.woocommerce .cart-collaterals .cart_totals { background: var(--color-card); border: 1px solid var(--color-border); padding: 2rem; max-width: 480px; margin-left: auto; }
.woocommerce .cart-collaterals .cart_totals h2 { font-family: var(--font-display); font-size: 1.5rem; letter-spacing: 0.05em; margin-bottom: 1.5rem; color: var(--color-text); }
.woocommerce .cart-collaterals .cart_totals table th, .woocommerce .cart-collaterals .cart_totals table td { border-bottom: 1px solid var(--color-border) !important; padding: 0.8rem 0 !important; color: var(--color-muted) !important; background: transparent !important; }
.woocommerce .cart-collaterals .cart_totals .order-total td { color: var(--color-text) !important; font-family: var(--font-display) !important; font-size: 1.8rem !important; }
.woocommerce a.checkout-button { background: var(--color-primary) !important; color: #fff !important; border: none !important; border-radius: 0 !important; font-size: 0.78rem !important; letter-spacing: 0.14em !important; text-transform: uppercase !important; padding: 1rem 2rem !important; display: block !important; text-align: center !important; margin-top: 1.5rem !important; transition: background .2s !important; }
.woocommerce a.checkout-button:hover { background: #e5000c !important; }

/* ══════════════════════════════════════════════════════
   MESSAGES & CHECKOUT
══════════════════════════════════════════════════════ */
.woocommerce-message, .woocommerce-info, .woocommerce-error { background: var(--color-card) !important; border-top: 3px solid var(--color-primary) !important; color: var(--color-text) !important; padding: 1rem 1.5rem !important; font-size: 0.88rem !important; margin-bottom: 1.5rem !important; list-style: none !important; border-left: none !important; border-right: none !important; border-bottom: none !important; }
.woocommerce-checkout .woocommerce { padding: 100px var(--gutter) 5vw; }
.woocommerce form .form-row label { color: var(--color-muted); font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; display: block; margin-bottom: 0.4rem; }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce form .form-row select { background: var(--color-card) !important; border: 1px solid var(--color-border) !important; color: var(--color-text) !important; padding: 0.8rem 1rem !important; width: 100% !important; font-family: var(--font-body) !important; font-size: 0.9rem !important; border-radius: 0 !important; outline: none !important; }
.woocommerce form .form-row input.input-text:focus { border-color: var(--color-primary) !important; }

/* ══════════════════════════════════════════════════════
   BREADCRUMB & PAGINATION
══════════════════════════════════════════════════════ */
.woocommerce-breadcrumb { color: var(--color-muted); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; display: block; padding: 0 0 1rem; }
.woocommerce-breadcrumb a { color: var(--color-primary); }
.woocommerce nav.woocommerce-pagination { margin-top: 4rem; text-align: center; }
.woocommerce nav.woocommerce-pagination ul { display: inline-flex; gap: 0.5rem; border: none !important; }
.woocommerce nav.woocommerce-pagination ul li { border: none !important; }
.woocommerce nav.woocommerce-pagination ul li a, .woocommerce nav.woocommerce-pagination ul li span { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--color-border) !important; background: transparent !important; color: var(--color-muted) !important; font-size: 0.82rem; transition: all .2s; border-radius: 0 !important; padding: 0 !important; line-height: 1 !important; }
.woocommerce nav.woocommerce-pagination ul li a:hover, .woocommerce nav.woocommerce-pagination ul li span.current { background: var(--color-primary) !important; border-color: var(--color-primary) !important; color: #fff !important; }

/* ══════════════════════════════════════════════════════
   PAGE PRODUIT UNIQUE — classes rm-single-*
══════════════════════════════════════════════════════ */
.rm-single-page {
    padding-top: 72px;
    background: var(--color-bg, #080808);
    min-height: 100vh;
}
.rm-single-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5vw;
    padding: 3rem var(--gutter, 5vw) 5vw;
    align-items: start;
    box-sizing: border-box;
}
@media (max-width: 768px) {
    .rm-single-layout { grid-template-columns: 1fr; padding-top: 2rem; }
}
.rm-single-img-main {
    background: #1a1a1a;
    border: 1px solid var(--color-border);
    overflow: hidden;
}
.rm-single-img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
    max-height: 500px;
    padding: 2rem;
    box-sizing: border-box;
}
.rm-single-thumbs {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 6px;
    margin-top: 6px;
}
.rm-single-thumb {
    background: #1a1a1a;
    border: 1px solid var(--color-border);
    overflow: hidden;
    aspect-ratio: 1 / 1;
    cursor: pointer;
    transition: border-color .2s;
}
.rm-single-thumb:hover { border-color: var(--color-primary); }
.rm-single-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rm-single-breadcrumb {
    color: var(--color-muted);
    font-size: 0.7rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}
.rm-single-breadcrumb a { color: var(--color-primary); text-decoration: none; }
.rm-single-breadcrumb a:hover { text-decoration: underline; }
.rm-single-breadcrumb span { opacity: 0.4; }
.rm-single-title {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 3.5vw, 3rem);
    letter-spacing: 0.03em;
    color: var(--color-text);
    margin: 0 0 1rem;
    line-height: 1;
}
.rm-single-price {
    font-family: var(--font-display);
    font-size: 2.5rem;
    color: var(--color-primary);
    margin-bottom: 1.5rem;
    line-height: 1;
}
.rm-single-price del { font-size: 1.2rem; color: var(--color-muted); font-family: var(--font-body); margin-right: 0.5rem; }
.rm-single-price ins { text-decoration: none; }
.rm-single-desc {
    color: var(--color-muted);
    font-size: 0.92rem;
    line-height: 1.8;
    margin-bottom: 2rem;
    border-top: 1px solid var(--color-border);
    padding-top: 1.5rem;
}
.rm-single-tabs {
    padding: 0 var(--gutter, 5vw) 2rem;
    border-top: 1px solid var(--color-border);
}
.rm-single-related { padding: 0 var(--gutter, 5vw) 5vw; }
.rm-single-related h2, .rm-single-tabs h2 {
    font-family: var(--font-display);
    font-size: 1.8rem;
    letter-spacing: 0.05em;
    margin-bottom: 2rem;
    color: var(--color-text);
}
